]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
ARM: sunxi: Add initialization of CNTVOFF
authorMylène Josserand <mylene.josserand@bootlin.com>
Fri, 4 May 2018 19:05:40 +0000 (21:05 +0200)
committerMaxime Ripard <maxime.ripard@bootlin.com>
Tue, 8 May 2018 12:52:41 +0000 (14:52 +0200)
Add the initialization of CNTVOFF for sun8i-a83t.

For boot CPU, create a new machine that handles this
function's call in an "init_early" callback. We need to initialize
CNTVOFF before the arch timer's initialization otherwise, it will
not be taken into account and fails to boot correctly.
Because of that, this function can't be called in SMP's early_initcall
function which is called after timer's init.

For secondary CPUs, add this function into secondary_startup
assembly entry.

Signed-off-by: Mylène Josserand <mylene.josserand@bootlin.com>
Reviewed-by: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Maxime Ripard <maxime.ripard@bootlin.com>
arch/arm/mach-sunxi/headsmp.S
arch/arm/mach-sunxi/sunxi.c

index 37dc772701f3685b8acef657ad9f9b4287f80ee7..32d76be98541acc857c6c038b98c789426e89869 100644 (file)
@@ -71,6 +71,7 @@ ENDPROC(sunxi_mc_smp_cluster_cache_enable)
 
 ENTRY(sunxi_mc_smp_secondary_startup)
        bl      sunxi_mc_smp_cluster_cache_enable
+       bl      secure_cntvoff_init
        b       secondary_startup
 ENDPROC(sunxi_mc_smp_secondary_startup)
 
index 5e9602ce1573bc7ee26f235cc4c2200b8d99905e..de4b0e932f22e27278b494ad1a4207e143f80f9e 100644 (file)
@@ -16,6 +16,7 @@
 #include <linux/platform_device.h>
 
 #include <asm/mach/arch.h>
+#include <asm/secure_cntvoff.h>
 
 static const char * const sunxi_board_dt_compat[] = {
        "allwinner,sun4i-a10",
@@ -62,7 +63,6 @@ MACHINE_END
 static const char * const sun8i_board_dt_compat[] = {
        "allwinner,sun8i-a23",
        "allwinner,sun8i-a33",
-       "allwinner,sun8i-a83t",
        "allwinner,sun8i-h2-plus",
        "allwinner,sun8i-h3",
        "allwinner,sun8i-r40",
@@ -75,6 +75,24 @@ DT_MACHINE_START(SUN8I_DT, "Allwinner sun8i Family")
        .dt_compat      = sun8i_board_dt_compat,
 MACHINE_END
 
+static void __init sun8i_a83t_cntvoff_init(void)
+{
+#ifdef CONFIG_SMP
+       secure_cntvoff_init();
+#endif
+}
+
+static const char * const sun8i_a83t_cntvoff_board_dt_compat[] = {
+       "allwinner,sun8i-a83t",
+       NULL,
+};
+
+DT_MACHINE_START(SUN8I_A83T_CNTVOFF_DT, "Allwinner A83t board")
+       .init_early     = sun8i_a83t_cntvoff_init,
+       .init_time      = sun6i_timer_init,
+       .dt_compat      = sun8i_a83t_cntvoff_board_dt_compat,
+MACHINE_END
+
 static const char * const sun9i_board_dt_compat[] = {
        "allwinner,sun9i-a80",
        NULL,