[U-Boot] [PATCH] arm: exynos7420: remove custome low level init function
Alison Wang
alison.wang at nxp.com
Thu Nov 17 02:44:57 CET 2016
> From: Thomas Abraham <thomas.ab at samsung.com>
>
> Remove the custom low-level initialization function and reuse the
> default low-level initialization function. But this requires the
> ARMV8_MULTIENTRY config option to be enabled for Exynos7420.
>
> On Exynos7420, the boot CPU belongs to the second cluster and so
> with ARMV8_MULTIENTRY config option enabled, the 'branch_if_master'
> macro fails to detect the CPU as boot CPU. As a temporary workaround
> the CPU_RELEASE_ADDR is set to point to '_main'.
>
> Cc: Minkyu Kang <mk7.kang at samsung.com>
> Cc: Alison Wang <alison.wang at nxp.com>
> Signed-off-by: Thomas Abraham <thomas.ab at samsung.com>
> ---
> arch/arm/mach-exynos/Kconfig | 1 +
> arch/arm/mach-exynos/soc.c | 18 ++++++++++--------
> include/configs/exynos7420-common.h | 1 +
> 3 files changed, 12 insertions(+), 8 deletions(-)
>
> diff --git a/arch/arm/mach-exynos/Kconfig b/arch/arm/mach-
> exynos/Kconfig
> index ce2a16f..07118fc 100644
> --- a/arch/arm/mach-exynos/Kconfig
> +++ b/arch/arm/mach-exynos/Kconfig
> @@ -126,6 +126,7 @@ choice
> config TARGET_ESPRESSO7420
> bool "ESPRESSO7420 board"
> select ARM64
> + select ARMV8_MULTIENTRY
> select SUPPORT_SPL
> select OF_CONTROL
> select SPL_DISABLE_OF_CONTROL
> diff --git a/arch/arm/mach-exynos/soc.c b/arch/arm/mach-exynos/soc.c
> index f9c7468..cf149ad 100644
> --- a/arch/arm/mach-exynos/soc.c
> +++ b/arch/arm/mach-exynos/soc.c
> @@ -9,6 +9,16 @@
> #include <asm/io.h>
> #include <asm/system.h>
>
> +#ifdef CONFIG_TARGET_ESPRESSO7420
> +/*
> + * Exynos7420 uses CPU0 of Cluster-1 as boot CPU. Due to this,
> branch_if_master
> + * fails to identify as the boot CPU as the master CPU. As temporary
> workaround,
> + * setup the slave CPU boot address as "_main".
> + */
> +extern void _main(void);
> +void *secondary_boot_addr = (void *)_main;
> +#endif /* CONFIG_TARGET_ESPRESSO7420 */
> +
> void reset_cpu(ulong addr)
> {
> #ifdef CONFIG_CPU_V7
> @@ -23,11 +33,3 @@ void enable_caches(void)
> dcache_enable();
> }
> #endif
> -
> -#ifdef CONFIG_ARM64
> -void lowlevel_init(void)
> -{
> - armv8_switch_to_el2();
> - armv8_switch_to_el1();
> -}
> -#endif
> diff --git a/include/configs/exynos7420-common.h
> b/include/configs/exynos7420-common.h
> index f7c4709..1cea74e 100644
> --- a/include/configs/exynos7420-common.h
> +++ b/include/configs/exynos7420-common.h
> @@ -47,6 +47,7 @@
> #define CONFIG_IRAM_BASE 0x02100000
> #define CONFIG_IRAM_SIZE 0x58000
> #define CONFIG_IRAM_END (CONFIG_IRAM_BASE +
> CONFIG_IRAM_SIZE)
> +#define CPU_RELEASE_ADDR secondary_boot_addr
>
> /* Number of CPUs available */
> #define CONFIG_CORE_COUNT 0x8
>
Reviewed-by: Alison Wang <alison.wang at nxp.com>
Thanks.
Best Regards,
Alison Wang
More information about the U-Boot
mailing list