1 /*
2  * (C) Copyright 2010-2012
3  * NVIDIA Corporation <www.nvidia.com>
4  *
5  * See file CREDITS for list of people who contributed to this
6  * project.
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License as
10  * published by the Free Software Foundation; either version 2 of
11  * the License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21  * MA 02111-1307 USA
22  */
23 
24 #ifndef __TEGRA_COMMON_POST_H
25 #define __TEGRA_COMMON_POST_H
26 
27 #ifdef CONFIG_BOOTCOMMAND
28 
29 #define BOOTCMDS_COMMON ""
30 
31 #else
32 
33 #ifdef CONFIG_CMD_EXT2
34 #define BOOT_FSTYPE_EXT2 "ext2 "
35 #else
36 #define BOOT_FSTYPE_EXT2 ""
37 #endif
38 
39 #ifdef CONFIG_CMD_FAT
40 #define BOOT_FSTYPE_FAT "fat"
41 #else
42 #define BOOT_FSTYPE_FAT ""
43 #endif
44 
45 #ifdef CONFIG_CMD_MMC
46 #define BOOTCMDS_MMC \
47 	"mmc_boot=" \
48 		"setenv devtype mmc; " \
49 		"if mmc dev ${devnum}; then " \
50 			"run scan_boot; " \
51 		"fi\0" \
52 	"bootcmd_mmc0=setenv devnum 0; run mmc_boot;\0" \
53 	"bootcmd_mmc1=setenv devnum 1; run mmc_boot;\0"
54 #define BOOT_TARGETS_MMC "mmc1 mmc0"
55 #else
56 #define BOOTCMDS_MMC ""
57 #define BOOT_TARGETS_MMC ""
58 #endif
59 
60 #ifdef CONFIG_CMD_USB
61 #define BOOTCMD_INIT_USB "run usb_init; "
62 #define BOOTCMDS_USB \
63 	"usb_init=" \
64 		"if ${usb_need_init}; then " \
65 			"set usb_need_init false; " \
66 			"usb start 0; " \
67 		"fi\0" \
68 	\
69 	"usb_boot=" \
70 		"setenv devtype usb; " \
71 		BOOTCMD_INIT_USB \
72 		"if usb dev ${devnum}; then " \
73 			"run scan_boot; " \
74 		"fi\0" \
75 	\
76 	"bootcmd_usb0=setenv devnum 0; run usb_boot;\0"
77 #define BOOT_TARGETS_USB "usb0"
78 #else
79 #define BOOTCMD_INIT_USB ""
80 #define BOOTCMDS_USB ""
81 #define BOOT_TARGETS_USB ""
82 #endif
83 
84 #ifdef CONFIG_CMD_DHCP
85 #define BOOTCMDS_DHCP \
86 	"bootcmd_dhcp=" \
87 		BOOTCMD_INIT_USB \
88 		"if dhcp ${scriptaddr} boot.scr.uimg; then "\
89 			"source ${scriptaddr}; " \
90 		"fi\0"
91 #define BOOT_TARGETS_DHCP "dhcp"
92 #else
93 #define BOOTCMDS_DHCP ""
94 #define BOOT_TARGETS_DHCP ""
95 #endif
96 
97 #define BOOTCMDS_COMMON \
98 	"rootpart=1\0" \
99 	\
100 	"script_boot="                                                    \
101 		"if ${fs}load ${devtype} ${devnum}:${rootpart} "          \
102 				"${scriptaddr} ${prefix}${script}; then " \
103 			"echo ${script} found! Executing ...;"            \
104 			"source ${scriptaddr};"                           \
105 		"fi;\0"                                                   \
106 	\
107 	"scan_boot="                                                      \
108 		"echo Scanning ${devtype} ${devnum}...; "                 \
109 		"for fs in ${boot_fstypes}; do "                          \
110 			"for prefix in ${boot_prefixes}; do "             \
111 				"for script in ${boot_scripts}; do "      \
112 					"run script_boot; "               \
113 				"done; "                                  \
114 			"done; "                                          \
115 		"done;\0"                                                 \
116 	\
117 	"boot_targets=" \
118 		BOOT_TARGETS_MMC " " \
119 		BOOT_TARGETS_USB " " \
120 		BOOT_TARGETS_DHCP " " \
121 		"\0" \
122 	\
123 	"boot_fstypes=" \
124 		BOOT_FSTYPE_EXT2 " " \
125 		BOOT_FSTYPE_FAT " " \
126 		"\0" \
127 	\
128 	"boot_prefixes=/ /boot/\0" \
129 	\
130 	"boot_scripts=boot.scr.uimg boot.scr\0" \
131 	\
132 	BOOTCMDS_MMC \
133 	BOOTCMDS_USB \
134 	BOOTCMDS_DHCP
135 
136 #define CONFIG_BOOTCOMMAND \
137 	"for target in ${boot_targets}; do run bootcmd_${target}; done"
138 
139 #endif
140 
141 /*
142  * Memory layout for where various images get loaded by boot scripts:
143  *
144  * scriptaddr can be pretty much anywhere that doesn't conflict with something
145  *   else. Put it above BOOTMAPSZ to eliminate conflicts.
146  *
147  * kernel_addr_r must be within the first 128M of RAM in order for the
148  *   kernel's CONFIG_AUTO_ZRELADDR option to work. Since the kernel will
149  *   decompress itself to 0x8000 after the start of RAM, kernel_addr_r
150  *   should not overlap that area, or the kernel will have to copy itself
151  *   somewhere else before decompression. Similarly, the address of any other
152  *   data passed to the kernel shouldn't overlap the start of RAM. Pushing
153  *   this up to 16M allows for a sizable kernel to be decompressed below the
154  *   compressed load address.
155  *
156  * fdt_addr_r simply shouldn't overlap anything else. Choosing 32M allows for
157  *   the compressed kernel to be up to 16M too.
158  *
159  * ramdisk_addr_r simply shouldn't overlap anything else. Choosing 33M allows
160  *   for the FDT/DTB to be up to 1M, which is hopefully plenty.
161  */
162 #define MEM_LAYOUT_ENV_SETTINGS \
163 	"scriptaddr=0x10000000\0" \
164 	"kernel_addr_r=0x01000000\0" \
165 	"fdt_addr_r=0x02000000\0" \
166 	"ramdisk_addr_r=0x02100000\0" \
167 
168 #ifdef CONFIG_TEGRA_KEYBOARD
169 #define STDIN_KBD_KBC ",tegra-kbc"
170 #else
171 #define STDIN_KBD_KBC ""
172 #endif
173 
174 #ifdef CONFIG_USB_KEYBOARD
175 #define STDIN_KBD_USB ",usbkbd"
176 #define CONFIG_SYS_USB_EVENT_POLL
177 #define CONFIG_PREBOOT			"usb start"
178 #else
179 #define STDIN_KBD_USB ""
180 #endif
181 
182 #define TEGRA_DEVICE_SETTINGS \
183 	"stdin=serial" STDIN_KBD_KBC STDIN_KBD_USB "\0" \
184 	"stdout=serial\0" \
185 	"stderr=serial\0" \
186 
187 #define CONFIG_EXTRA_ENV_SETTINGS \
188 	TEGRA_DEVICE_SETTINGS \
189 	MEM_LAYOUT_ENV_SETTINGS \
190 	BOOTCMDS_COMMON
191 
192 /* overrides for SPL build here */
193 #ifdef CONFIG_SPL_BUILD
194 
195 /* remove devicetree support */
196 #ifdef CONFIG_OF_CONTROL
197 #undef CONFIG_OF_CONTROL
198 #endif
199 
200 /* remove I2C support */
201 #ifdef CONFIG_TEGRA_I2C
202 #undef CONFIG_TEGRA_I2C
203 #endif
204 #ifdef CONFIG_CMD_I2C
205 #undef CONFIG_CMD_I2C
206 #endif
207 
208 /* remove MMC support */
209 #ifdef CONFIG_MMC
210 #undef CONFIG_MMC
211 #endif
212 #ifdef CONFIG_GENERIC_MMC
213 #undef CONFIG_GENERIC_MMC
214 #endif
215 #ifdef CONFIG_TEGRA_MMC
216 #undef CONFIG_TEGRA_MMC
217 #endif
218 #ifdef CONFIG_CMD_MMC
219 #undef CONFIG_CMD_MMC
220 #endif
221 
222 /* remove partitions/filesystems */
223 #ifdef CONFIG_DOS_PARTITION
224 #undef CONFIG_DOS_PARTITION
225 #endif
226 #ifdef CONFIG_EFI_PARTITION
227 #undef CONFIG_EFI_PARTITION
228 #endif
229 #ifdef CONFIG_CMD_EXT2
230 #undef CONFIG_CMD_EXT2
231 #endif
232 #ifdef CONFIG_CMD_FAT
233 #undef CONFIG_CMD_FAT
234 #endif
235 
236 /* remove USB */
237 #ifdef CONFIG_USB_EHCI
238 #undef CONFIG_USB_EHCI
239 #endif
240 #ifdef CONFIG_USB_EHCI_TEGRA
241 #undef CONFIG_USB_EHCI_TEGRA
242 #endif
243 #ifdef CONFIG_USB_STORAGE
244 #undef CONFIG_USB_STORAGE
245 #endif
246 #ifdef CONFIG_CMD_USB
247 #undef CONFIG_CMD_USB
248 #endif
249 
250 /* remove part command support */
251 #ifdef CONFIG_PARTITION_UUIDS
252 #undef CONFIG_PARTITION_UUIDS
253 #endif
254 
255 #ifdef CONFIG_CMD_PART
256 #undef CONFIG_CMD_PART
257 #endif
258 
259 #endif /* CONFIG_SPL_BUILD */
260 
261 #endif /* __TEGRA_COMMON_POST_H */
262