]> git.kernelconcepts.de Git - karo-tx-uboot.git/blob - include/configs/tegra-common-post.h
Merge branch 'master' of git://git.denx.de/u-boot-net
[karo-tx-uboot.git] / include / configs / tegra-common-post.h
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 */