ARM: 8947/1: Fix __arch_get_hw_counter() access to CNTVCT
authorVincenzo Frascino <vincenzo.frascino@arm.com>
Thu, 5 Dec 2019 10:04:51 +0000 (11:04 +0100)
committerRussell King <rmk+kernel@armlinux.org.uk>
Fri, 6 Dec 2019 11:51:03 +0000 (11:51 +0000)
__arch_get_hw_counter() should check clock_mode to see if it can access
CNTVCT. With the conversion to unified vDSO this check has been left out.

This causes on imx v6 and v7 (imx_v6_v7_defconfig) and other platforms to
hang at boot during the execution of the init process as per below:

[   19.976852] Run /sbin/init as init process
[   20.044931] Kernel panic - not syncing: Attempted to kill init!
exitcode=0x00000004

Fix the problem verifying that clock_mode is set coherently before
accessing CNTVCT.

Investigated-by: Arnd Bergmann <arnd@arndb.de>
Reported-by: Guenter Roeck <linux@roeck-us.net>
Tested-by: Guenter Roeck <linux@roeck-us.net>
Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org>
Signed-off-by: Vincenzo Frascino <vincenzo.frascino@arm.com>
Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
arch/arm/include/asm/vdso/gettimeofday.h

index 5b879ae7afc1046951733872c7b0c3a974f4870c..0ad2429c324f6f9387c5350a1b9e93a963e8abec 100644 (file)
@@ -75,6 +75,9 @@ static __always_inline u64 __arch_get_hw_counter(int clock_mode)
 #ifdef CONFIG_ARM_ARCH_TIMER
        u64 cycle_now;
 
+       if (!clock_mode)
+               return -EINVAL;
+
        isb();
        cycle_now = read_sysreg(CNTVCT);