a4ac27b1876f996a9cfb2b484246d0af2473ce0f
[platform/kernel/u-boot.git] / include / configs / exynos78x0-common.h
1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * Configuration settings for the EXYNOS 78x0 based boards.
4  *
5  * Copyright (c) 2020 Dzmitry Sankouski (dsankouski@gmail.com)
6  * based on include/exynos7420-common.h
7  * Copyright (C) 2016 Samsung Electronics
8  * Thomas Abraham <thomas.ab@samsung.com>
9  */
10
11 #ifndef __CONFIG_EXYNOS78x0_COMMON_H
12 #define __CONFIG_EXYNOS78x0_COMMON_H
13
14 /* High Level Configuration Options */
15 #define CONFIG_SAMSUNG                  /* in a SAMSUNG core */
16 #define CONFIG_S5P
17
18 #include <asm/arch/cpu.h>               /* get chip and board defs */
19 #include <linux/sizes.h>
20
21 /* Miscellaneous configurable options */
22 #define CONFIG_SYS_CBSIZE               1024    /* Console I/O Buffer Size */
23
24 /* Boot Argument Buffer Size */
25 #define CONFIG_SYS_BARGSIZE             CONFIG_SYS_CBSIZE
26
27 #define CPU_RELEASE_ADDR                secondary_boot_addr
28
29 #define CONFIG_SYS_BAUDRATE_TABLE \
30         {9600, 19200, 38400, 57600, 115200, 230400, 460800, 921600}
31
32 #define CONFIG_SYS_SDRAM_BASE           0x40000000
33 #define CONFIG_SYS_INIT_SP_ADDR         (CONFIG_SYS_TEXT_BASE + SZ_2M - GENERATED_GBL_DATA_SIZE)
34 #define CONFIG_SYS_BOOTM_LEN    SZ_32M
35 /* DRAM Memory Banks */
36 #define SDRAM_BANK_SIZE         (256UL << 20UL) /* 256 MB */
37 #define PHYS_SDRAM_1            CONFIG_SYS_SDRAM_BASE
38 #define PHYS_SDRAM_1_SIZE       SDRAM_BANK_SIZE
39 #define PHYS_SDRAM_2            (CONFIG_SYS_SDRAM_BASE + SDRAM_BANK_SIZE)
40 #define PHYS_SDRAM_2_SIZE       SDRAM_BANK_SIZE
41 #define PHYS_SDRAM_3            (CONFIG_SYS_SDRAM_BASE + (2 * SDRAM_BANK_SIZE))
42 #define PHYS_SDRAM_3_SIZE       SDRAM_BANK_SIZE
43 #define PHYS_SDRAM_4            (CONFIG_SYS_SDRAM_BASE + (3 * SDRAM_BANK_SIZE))
44 #define PHYS_SDRAM_4_SIZE       SDRAM_BANK_SIZE
45 #define PHYS_SDRAM_5            (CONFIG_SYS_SDRAM_BASE + (4 * SDRAM_BANK_SIZE))
46 #define PHYS_SDRAM_5_SIZE       SDRAM_BANK_SIZE
47 #define PHYS_SDRAM_6            (CONFIG_SYS_SDRAM_BASE + (5 * SDRAM_BANK_SIZE))
48 #define PHYS_SDRAM_6_SIZE       SDRAM_BANK_SIZE
49 #define PHYS_SDRAM_7            (CONFIG_SYS_SDRAM_BASE + (6 * SDRAM_BANK_SIZE))
50 #define PHYS_SDRAM_7_SIZE       SDRAM_BANK_SIZE
51 #define PHYS_SDRAM_8            (CONFIG_SYS_SDRAM_BASE + (7 * SDRAM_BANK_SIZE))
52 #define PHYS_SDRAM_8_SIZE       SDRAM_BANK_SIZE
53 #define PHYS_SDRAM_9            (CONFIG_SYS_SDRAM_BASE + (8 * SDRAM_BANK_SIZE))
54 #define PHYS_SDRAM_9_SIZE       SDRAM_BANK_SIZE
55 #define PHYS_SDRAM_10           (CONFIG_SYS_SDRAM_BASE + (9 * SDRAM_BANK_SIZE))
56 #define PHYS_SDRAM_10_SIZE      SDRAM_BANK_SIZE
57 #define PHYS_SDRAM_11           (CONFIG_SYS_SDRAM_BASE + (10 * SDRAM_BANK_SIZE))
58 #define PHYS_SDRAM_11_SIZE      SDRAM_BANK_SIZE
59 #define PHYS_SDRAM_12           (CONFIG_SYS_SDRAM_BASE + (11 * SDRAM_BANK_SIZE))
60 #define PHYS_SDRAM_12_SIZE      SDRAM_BANK_SIZE
61
62 #ifndef MEM_LAYOUT_ENV_SETTINGS
63 #define MEM_LAYOUT_ENV_SETTINGS \
64         "bootm_size=0x10000000\0" \
65         "bootm_low=0x40000000\0"
66 #endif
67
68 #ifndef EXYNOS_DEVICE_SETTINGS
69 #define EXYNOS_DEVICE_SETTINGS \
70         "stdin=serial\0" \
71         "stdout=serial\0" \
72         "stderr=serial\0"
73 #endif
74
75 #ifndef EXYNOS_FDTFILE_SETTING
76 #define EXYNOS_FDTFILE_SETTING
77 #endif
78
79 /* Cannot use bootdelay > 0, because timer is not working */
80 #define EXTRA_ENV_SETTINGS \
81         "bootdelay=0\0" \
82         "bootcmd=source $prevbl_initrd_start_addr:bootscript\0" \
83         EXYNOS_DEVICE_SETTINGS \
84         EXYNOS_FDTFILE_SETTING \
85         MEM_LAYOUT_ENV_SETTINGS
86
87 #define CONFIG_EXTRA_ENV_SETTINGS \
88         EXTRA_ENV_SETTINGS
89
90 #endif  /* __CONFIG_EXYNOS78x0_COMMON_H */