1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * Copyright (C) 2013 Samsung Electronics
4  * Hyungwon Hwang <human.hwang@samsung.com>
5  */
6 
7 #ifndef __CONFIG_ODROID_XU3_H
8 #define __CONFIG_ODROID_XU3_H
9 
10 #include <configs/exynos5420-common.h>
11 #include <configs/exynos5-common.h>
12 
13 #define CONFIG_BOARD_COMMON
14 
15 #define CONFIG_SYS_SDRAM_BASE		0x40000000
16 
17 #define TZPC_BASE_OFFSET		0x10000
18 
19 #define SDRAM_BANK_SIZE			(256UL << 20UL)	/* 256 MB */
20 /* Reserve the last 22 MiB for the secure firmware */
21 #define CONFIG_SYS_MEM_TOP_HIDE		(22UL << 20UL)
22 #define CONFIG_TZSW_RESERVED_DRAM_SIZE	CONFIG_SYS_MEM_TOP_HIDE
23 
24 #define CONFIG_SYS_INIT_SP_ADDR		(CONFIG_SYS_LOAD_ADDR - 0x1000000)
25 
26 /* USB */
27 #define CONFIG_USB_EHCI_EXYNOS
28 
29 /* DFU */
30 #define CONFIG_SYS_DFU_DATA_BUF_SIZE	SZ_32M
31 #define DFU_DEFAULT_POLL_TIMEOUT	300
32 #define DFU_MANIFEST_POLL_TIMEOUT	25000
33 
34 /* THOR */
35 #define CONFIG_G_DNL_THOR_VENDOR_NUM	CONFIG_USB_GADGET_VENDOR_NUM
36 #define CONFIG_G_DNL_THOR_PRODUCT_NUM	0x685D
37 
38 /* UMS */
39 #define CONFIG_G_DNL_UMS_VENDOR_NUM	0x0525
40 #define CONFIG_G_DNL_UMS_PRODUCT_NUM	0xA4A5
41 
42 /* FIXME: MUST BE REMOVED AFTER TMU IS TURNED ON */
43 #undef CONFIG_EXYNOS_TMU
44 
45 #define CONFIG_DFU_ALT_SYSTEM               \
46 	"uImage fat 0 1;"                   \
47 	"zImage fat 0 1;"                   \
48 	"Image.itb fat 0 1;"                \
49 	"uInitrd fat 0 1;"                  \
50 	"boot.scr fat 0 1;"                 \
51 	"boot.cmd fat 0 1;"                 \
52 	"exynos5422-odroidxu3.dtb fat 0 1;" \
53 	"exynos5422-odroidxu3-lite.dtb fat 0 1;" \
54 	"exynos5422-odroidxu4.dtb fat 0 1;" \
55 	"exynos5422-odroidhc1.dtb fat 0 1;" \
56 	"boot part 0 1;"                    \
57 	"root part 0 2\0"
58 
59 #define CONFIG_DFU_ALT_BOOT_EMMC           \
60 	"u-boot raw 0x3e 0x800 mmcpart 1;" \
61 	"bl1 raw 0x0 0x1e mmcpart 1;"      \
62 	"bl2 raw 0x1e 0x1d mmcpart 1;"     \
63 	"tzsw raw 0x83e 0x200 mmcpart 1;"  \
64 	"params.bin raw 0x1880 0x20\0"
65 
66 #define CONFIG_DFU_ALT_BOOT_SD   \
67 	"u-boot raw 0x3f 0x800;" \
68 	"bl1 raw 0x1 0x1e;"      \
69 	"bl2 raw 0x1f 0x1d;"     \
70 	"tzsw raw 0x83f 0x200;"  \
71 	"params.bin raw 0x1880 0x20\0"
72 
73 /* Enable: board/samsung/common/misc.c to use set_dfu_alt_info() */
74 #define CONFIG_MISC_COMMON
75 #define CONFIG_SET_DFU_ALT_BUF_LEN	(SZ_1K)
76 
77 /* Set soc_rev, soc_id, board_rev, board_name, fdtfile */
78 #define CONFIG_ODROID_REV_AIN		9
79 #define CONFIG_REVISION_TAG
80 
81 /*
82  * Need to override existing one (smdk5420) with odroid so set_board_info will
83  * use proper prefix when creating full board_name (SYS_BOARD + type)
84  */
85 #undef CONFIG_SYS_BOARD
86 #define CONFIG_SYS_BOARD		"odroid"
87 
88 /* Define new extra env settings, including DFU settings */
89 #undef CONFIG_EXTRA_ENV_SETTINGS
90 #define CONFIG_EXTRA_ENV_SETTINGS \
91 	EXYNOS_DEVICE_SETTINGS \
92 	EXYNOS_FDTFILE_SETTING \
93 	MEM_LAYOUT_ENV_SETTINGS \
94 	BOOTENV \
95 	"rootfstype=ext4\0" \
96 	"console=console=ttySAC2,115200n8\0" \
97 	"fdtfile=exynos5422-odroidxu3.dtb\0" \
98 	"board_name=odroidxu3\0" \
99 	"mmcbootdev=0\0" \
100 	"mmcrootdev=0\0" \
101 	"mmcbootpart=1\0" \
102 	"mmcrootpart=2\0" \
103 	"dfu_alt_system="CONFIG_DFU_ALT_SYSTEM \
104 	"dfu_alt_info=Autoset by THOR/DFU command run.\0"
105 
106 #endif	/* __CONFIG_H */
107