[U-Boot] [PATCH 8/9] arm: exynos: add support for Exynos7420 SoC
Simon Glass
sjg at chromium.org
Wed Apr 20 16:41:18 CEST 2016
Hi Thomas,
On 13 April 2016 at 04:43, Thomas Abraham <ta.omasab at gmail.com> wrote:
> From: Thomas Abraham <thomas.ab at samsung.com>
>
> Add support for Exynos7420 SoC. The Exynos7420 SoC has four Cortex-A57
> and four Cortex-A53 CPUs and includes various peripheral controllers.
>
> Signed-off-by: Thomas Abraham <thomas.ab at samsung.com>
> ---
> arch/arm/dts/exynos7420.dtsi | 82 ++++++++++++++++++++++++
> arch/arm/mach-exynos/Kconfig | 11 +++
> arch/arm/mach-exynos/Makefile | 1 +
> arch/arm/mach-exynos/mmu-arm64.c | 35 ++++++++++
> arch/arm/mach-exynos/soc.c | 8 +++
> include/configs/espresso7420.h | 35 ++++++++++
> include/configs/exynos7420-common.h | 117 +++++++++++++++++++++++++++++++++++
> 7 files changed, 289 insertions(+), 0 deletions(-)
> create mode 100644 arch/arm/dts/exynos7420.dtsi
> create mode 100644 arch/arm/mach-exynos/mmu-arm64.c
> create mode 100644 include/configs/espresso7420.h
> create mode 100644 include/configs/exynos7420-common.h
>
Please see below:
Reviewed-by: Simon Glass <sjg at chromium.org>
> diff --git a/arch/arm/dts/exynos7420.dtsi b/arch/arm/dts/exynos7420.dtsi
> new file mode 100644
> index 0000000..990f8a1
> --- /dev/null
> +++ b/arch/arm/dts/exynos7420.dtsi
> @@ -0,0 +1,82 @@
> +/*
> + * Samsung Exynos7420 SoC device tree source
> + *
> + * Copyright (c) 2016 Samsung Electronics Co., Ltd.
> + * http://www.samsung.com
> + *
> + * SPDX-License-Identifier: GPL-2.0+
> + */
> +
> +/dts-v1/;
> +#include "skeleton.dtsi"
> +#include <dt-bindings/clock/exynos7420-clk.h>
> +/ {
> + compatible = "samsung,exynos7420";
> +
> + fin_pll: xxti {
> + compatible = "fixed-clock";
> + clock-output-names = "fin_pll";
> + u-boot,dm-pre-reloc;
> + #clock-cells = <0>;
> + };
> +
> + clock_topc: clock-controller at 10570000 {
> + compatible = "samsung,exynos7-clock-topc";
> + reg = <0x10570000 0x10000>;
> + u-boot,dm-pre-reloc;
> + #clock-cells = <1>;
> + clocks = <&fin_pll>;
> + clock-names = "fin_pll";
> + };
> +
> + clock_top0: clock-controller at 105d0000 {
> + compatible = "samsung,exynos7-clock-top0";
> + reg = <0x105d0000 0xb000>;
> + u-boot,dm-pre-reloc;
> + #clock-cells = <1>;
> + clocks = <&fin_pll>, <&clock_topc DOUT_SCLK_BUS0_PLL>,
> + <&clock_topc DOUT_SCLK_BUS1_PLL>,
> + <&clock_topc DOUT_SCLK_CC_PLL>,
> + <&clock_topc DOUT_SCLK_MFC_PLL>;
> + clock-names = "fin_pll", "dout_sclk_bus0_pll",
> + "dout_sclk_bus1_pll", "dout_sclk_cc_pll",
> + "dout_sclk_mfc_pll";
> + };
> +
> + clock_peric1: clock-controller at 14c80000 {
> + compatible = "samsung,exynos7-clock-peric1";
> + reg = <0x14c80000 0xd00>;
> + u-boot,dm-pre-reloc;
> + #clock-cells = <1>;
> + clocks = <&fin_pll>, <&clock_top0 DOUT_ACLK_PERIC1>,
> + <&clock_top0 CLK_SCLK_UART1>,
> + <&clock_top0 CLK_SCLK_UART2>,
> + <&clock_top0 CLK_SCLK_UART3>;
> + clock-names = "fin_pll", "dout_aclk_peric1_66",
> + "sclk_uart1", "sclk_uart2", "sclk_uart3";
> + };
> +
> + pinctrl at 13470000 {
> + compatible = "samsung,exynos7420-pinctrl";
> + reg = <0x13470000 0x1000>;
> + u-boot,dm-pre-reloc;
> +
> + serial2_bus: serial2-bus {
> + samsung,pins = "gpd1-4", "gpd1-5";
> + samsung,pin-function = <2>;
> + samsung,pin-pud = <3>;
> + samsung,pin-drv = <0>;
> + };
> + };
> +
> + serial at 14C30000 {
> + compatible = "samsung,exynos4210-uart";
> + reg = <0x14C30000 0x100>;
> + u-boot,dm-pre-reloc;
> + clocks = <&clock_peric1 PCLK_UART2>,
> + <&clock_peric1 SCLK_UART2>;
> + clock-names = "uart", "clk_uart_baud0";
> + pinctrl-names = "default";
> + pinctrl-0 = <&serial2_bus>;
> + };
> +};
> diff --git a/arch/arm/mach-exynos/Kconfig b/arch/arm/mach-exynos/Kconfig
> index acab947..52a5a30 100644
> --- a/arch/arm/mach-exynos/Kconfig
> +++ b/arch/arm/mach-exynos/Kconfig
> @@ -81,6 +81,16 @@ config TARGET_PEACH_PIT
> select SUPPORT_SPL
> select OF_CONTROL
>
> +config TARGET_ESPRESSO7420
> + bool "ESPRESSO7420 board"
> + select ARM64
> + select SUPPORT_SPL
> + select OF_CONTROL
> + select SPL_DISABLE_OF_CONTROL
> + select PINCTRL
> + select PINCTRL_EXYNOS7420
> + select CLK_EXYNOS
> +
> endchoice
>
> config SYS_SOC
> @@ -95,5 +105,6 @@ source "board/samsung/odroid/Kconfig"
> source "board/samsung/arndale/Kconfig"
> source "board/samsung/smdk5250/Kconfig"
> source "board/samsung/smdk5420/Kconfig"
> +source "board/samsung/espresso7420/Kconfig"
>
> endif
> diff --git a/arch/arm/mach-exynos/Makefile b/arch/arm/mach-exynos/Makefile
> index be5912e..a238a98 100644
> --- a/arch/arm/mach-exynos/Makefile
> +++ b/arch/arm/mach-exynos/Makefile
> @@ -7,6 +7,7 @@
>
> obj-y += soc.o
> obj-$(CONFIG_CPU_V7) += clock.o pinmux.o power.o soc.o system.o
> +obj-$(CONFIG_ARM64) += mmu-arm64.o
>
> obj-$(CONFIG_EXYNOS5420) += sec_boot.o
>
> diff --git a/arch/arm/mach-exynos/mmu-arm64.c b/arch/arm/mach-exynos/mmu-arm64.c
> new file mode 100644
> index 0000000..ba6d99d
> --- /dev/null
> +++ b/arch/arm/mach-exynos/mmu-arm64.c
> @@ -0,0 +1,35 @@
> +/*
> + * Copyright (C) 2016 Samsung Electronics
> + * Thomas Abraham <thomas.ab at samsung.com>
> + *
> + * SPDX-License-Identifier: GPL-2.0+
> + */
> +
> +#include <common.h>
> +#include <asm/armv8/mmu.h>
> +
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +#ifdef CONFIG_EXYNOS7420
> +static struct mm_region exynos7420_mem_map[] = {
> + {
> + .base = 0x10000000UL,
> + .size = 0x10000000UL,
> + .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
> + PTE_BLOCK_NON_SHARE |
> + PTE_BLOCK_PXN | PTE_BLOCK_UXN,
> + }, {
> + .base = 0x40000000UL,
> + .size = 0x80000000UL,
> + .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
> + PTE_BLOCK_INNER_SHARE,
> + }, {
> + /* List terminator */
> + .base = 0,
> + .size = 0,
> + .attrs = 0,
> + },
> +};
> +
> +struct mm_region *mem_map = exynos7420_mem_map;
> +#endif
> diff --git a/arch/arm/mach-exynos/soc.c b/arch/arm/mach-exynos/soc.c
> index 5cea5ed..0706f5d 100644
> --- a/arch/arm/mach-exynos/soc.c
> +++ b/arch/arm/mach-exynos/soc.c
> @@ -23,3 +23,11 @@ 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/espresso7420.h b/include/configs/espresso7420.h
> new file mode 100644
> index 0000000..2af33e7
> --- /dev/null
> +++ b/include/configs/espresso7420.h
> @@ -0,0 +1,35 @@
> +/*
> + * Configuration settings for the SAMSUNG ESPRESSO7420 board.
> + * Copyright (C) 2016 Samsung Electronics
> + * Thomas Abraham <thomas.ab at samsung.com>
> + *
> + * SPDX-License-Identifier: GPL-2.0+
> + */
> +
> +#ifndef __CONFIG_ESPRESSO7420_H
> +#define __CONFIG_ESPRESSO7420_H
> +
> +#include <configs/exynos7420-common.h>
> +
> +#define CONFIG_BOARD_COMMON
> +
> +#define CONFIG_ESPRESSO7420
> +#define CONFIG_ENV_IS_NOWHERE
> +
> +#define CONFIG_SYS_SDRAM_BASE 0x40000000
> +#define CONFIG_SYS_TEXT_BASE 0x43E00000
> +#define CONFIG_SPL_STACK CONFIG_IRAM_END
> +#define CONFIG_SYS_INIT_SP_ADDR CONFIG_IRAM_END
> +
> +/* select serial console configuration */
> +#define CONFIG_SERIAL2 /* use SERIAL 2 */
Is that needed?
> +#define CONFIG_DEFAULT_CONSOLE "console=ttySAC1,115200n8\0"
> +
> +#define CONFIG_IDENT_STRING " for ESPRESSO7420"
> +#define CONFIG_DEFAULT_CONSOLE "console=ttySAC1,115200n8\0"
> +
> +/* DRAM Memory Banks */
> +#define CONFIG_NR_DRAM_BANKS 8
> +#define SDRAM_BANK_SIZE (256UL << 20UL) /* 256 MB */
> +
> +#endif /* __CONFIG_ESPRESSO7420_H */
> diff --git a/include/configs/exynos7420-common.h b/include/configs/exynos7420-common.h
> new file mode 100644
> index 0000000..9a7e193
> --- /dev/null
> +++ b/include/configs/exynos7420-common.h
> @@ -0,0 +1,117 @@
> +/*
> + * Configuration settings for the Espresso7420 board.
> + * Copyright (C) 2016 Samsung Electronics
> + * Thomas Abraham <thomas.ab at samsung.com>
> + *
> + * SPDX-License-Identifier: GPL-2.0+
> + */
> +
> +#ifndef __CONFIG_EXYNOS7420_COMMON_H
> +#define __CONFIG_EXYNOS7420_COMMON_H
> +
> +/* High Level Configuration Options */
> +#define CONFIG_SAMSUNG /* in a SAMSUNG core */
> +#define CONFIG_EXYNOS7420 /* Exynos7 Family */
> +#define CONFIG_S5P
> +
> +#include <asm/arch/cpu.h> /* get chip and board defs */
> +#include <linux/sizes.h>
> +
> +#define CONFIG_ARCH_CPU_INIT
> +#define CONFIG_DISPLAY_BOARDINFO
> +#define CONFIG_BOARD_EARLY_INIT_F
> +
> +/* Size of malloc() pool before and after relocation */
> +#define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + (80 << 20))
> +
> +/* Miscellaneous configurable options */
> +#define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
> +#define CONFIG_SYS_PBSIZE 1024 /* Print Buffer Size */
> +#define CONFIG_SYS_MAXARGS 16 /* max number of command args */
> +
> +/* Boot Argument Buffer Size */
> +#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
> +
> +/* select serial console configuration */
> +#define CONFIG_BAUDRATE 115200
> +
> +/* FLASH and environment organization */
> +#define CONFIG_SYS_NO_FLASH
> +
> +/* Timer input clock frequency */
> +#define COUNTER_FREQUENCY 24000000
> +
> +/* Generic Interrupt Controller Definitions */
> +#define CONFIG_GICV2
> +#define GICD_BASE 0x11001000
> +#define GICC_BASE 0x11002000
Can these be in device tree? Or in arch/asm/include/... ?
> +
> +#define CONFIG_DEVICE_TREE_LIST "exynos7420-espresso7420"
> +
> +/* IRAM Layout */
> +#define CONFIG_IRAM_BASE 0x02100000
> +#define CONFIG_IRAM_SIZE 0x58000
> +#define CONFIG_IRAM_END (CONFIG_IRAM_BASE + CONFIG_IRAM_SIZE)
> +
> +/* Number of CPUs available */
> +#define CONFIG_CORE_COUNT 0x8
> +
> +/* select serial console configuration */
> +#define CONFIG_BAUDRATE 115200
> +#define CONFIG_SILENT_CONSOLE
> +#define CONFIG_SYS_CONSOLE_IS_IN_ENV
> +#define CONFIG_CONSOLE_MUX
> +
> +#define CONFIG_SYS_LOAD_ADDR (CONFIG_SYS_SDRAM_BASE + 0x3E00000)
> +
> +#define PHYS_SDRAM_1 CONFIG_SYS_SDRAM_BASE
> +#define PHYS_SDRAM_1_SIZE SDRAM_BANK_SIZE
> +#define PHYS_SDRAM_2 (CONFIG_SYS_SDRAM_BASE + SDRAM_BANK_SIZE)
> +#define PHYS_SDRAM_2_SIZE SDRAM_BANK_SIZE
> +#define PHYS_SDRAM_3 (CONFIG_SYS_SDRAM_BASE + (2 * SDRAM_BANK_SIZE))
> +#define PHYS_SDRAM_3_SIZE SDRAM_BANK_SIZE
> +#define PHYS_SDRAM_4 (CONFIG_SYS_SDRAM_BASE + (3 * SDRAM_BANK_SIZE))
> +#define PHYS_SDRAM_4_SIZE SDRAM_BANK_SIZE
> +#define PHYS_SDRAM_5 (CONFIG_SYS_SDRAM_BASE + (4 * SDRAM_BANK_SIZE))
> +#define PHYS_SDRAM_5_SIZE SDRAM_BANK_SIZE
> +#define PHYS_SDRAM_6 (CONFIG_SYS_SDRAM_BASE + (5 * SDRAM_BANK_SIZE))
> +#define PHYS_SDRAM_6_SIZE SDRAM_BANK_SIZE
> +#define PHYS_SDRAM_7 (CONFIG_SYS_SDRAM_BASE + (6 * SDRAM_BANK_SIZE))
> +#define PHYS_SDRAM_7_SIZE SDRAM_BANK_SIZE
> +#define PHYS_SDRAM_8 (CONFIG_SYS_SDRAM_BASE + (7 * SDRAM_BANK_SIZE))
> +#define PHYS_SDRAM_8_SIZE SDRAM_BANK_SIZE
I wish we could use device tree for this cruft. Any way?
> +
> +/* Configuration of ENV Blocks */
> +#define CONFIG_ENV_SIZE (16 << 10) /* 16 KB */
> +
> +#define BOOT_TARGET_DEVICES(func) \
> + func(MMC, mmc, 1) \
> + func(MMC, mmc, 0) \
> +
> +#ifndef MEM_LAYOUT_ENV_SETTINGS
> +#define MEM_LAYOUT_ENV_SETTINGS \
> + "bootm_size=0x10000000\0" \
> + "kernel_addr_r=0x42000000\0" \
> + "fdt_addr_r=0x43000000\0" \
> + "ramdisk_addr_r=0x43300000\0" \
> + "scriptaddr=0x50000000\0" \
> + "pxefile_addr_r=0x51000000\0"
> +#endif
> +
> +#ifndef EXYNOS_DEVICE_SETTINGS
> +#define EXYNOS_DEVICE_SETTINGS \
> + "stdin=serial\0" \
> + "stdout=serial\0" \
> + "stderr=serial\0"
> +#endif
> +
> +#ifndef EXYNOS_FDTFILE_SETTING
> +#define EXYNOS_FDTFILE_SETTING
> +#endif
> +
> +#define CONFIG_EXTRA_ENV_SETTINGS \
> + EXYNOS_DEVICE_SETTINGS \
> + EXYNOS_FDTFILE_SETTING \
> + MEM_LAYOUT_ENV_SETTINGS
> +
> +#endif /* __CONFIG_EXYNOS7420_COMMON_H */
> --
> 1.6.6.rc2
>
Regards,
Simon
More information about the U-Boot
mailing list