2 * (C) Copyright 2010-2012
3 * NVIDIA Corporation <www.nvidia.com>
5 * See file CREDITS for list of people who contributed to this
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.
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.
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,
24 #ifndef __TEGRA_COMMON_POST_H
25 #define __TEGRA_COMMON_POST_H
27 #ifdef CONFIG_BOOTCOMMAND
29 #define BOOTCMDS_COMMON ""
34 #define BOOTCMDS_MMC \
36 "setenv devtype mmc; " \
37 "if mmc dev ${devnum}; then " \
40 "bootcmd_mmc0=setenv devnum 0; run mmc_boot;\0" \
41 "bootcmd_mmc1=setenv devnum 1; run mmc_boot;\0"
42 #define BOOT_TARGETS_MMC "mmc1 mmc0"
44 #define BOOTCMDS_MMC ""
45 #define BOOT_TARGETS_MMC ""
49 #define BOOTCMD_INIT_USB "run usb_init; "
50 #define BOOTCMDS_USB \
52 "if ${usb_need_init}; then " \
53 "set usb_need_init false; " \
58 "setenv devtype usb; " \
60 "if usb dev ${devnum}; then " \
64 "bootcmd_usb0=setenv devnum 0; run usb_boot;\0"
65 #define BOOT_TARGETS_USB "usb0"
67 #define BOOTCMD_INIT_USB ""
68 #define BOOTCMDS_USB ""
69 #define BOOT_TARGETS_USB ""
72 #ifdef CONFIG_CMD_DHCP
73 #define BOOTCMDS_DHCP \
76 "if dhcp ${scriptaddr} boot.scr.uimg; then "\
77 "source ${scriptaddr}; " \
79 #define BOOT_TARGETS_DHCP "dhcp"
81 #define BOOTCMDS_DHCP ""
82 #define BOOT_TARGETS_DHCP ""
85 #define BOOTCMDS_COMMON \
89 "if load ${devtype} ${devnum}:${rootpart} " \
90 "${scriptaddr} ${prefix}${script}; then " \
91 "echo ${script} found! Executing ...;" \
92 "source ${scriptaddr};" \
96 "echo Scanning ${devtype} ${devnum}...; " \
97 "for prefix in ${boot_prefixes}; do " \
98 "for script in ${boot_scripts}; do " \
104 BOOT_TARGETS_MMC " " \
105 BOOT_TARGETS_USB " " \
106 BOOT_TARGETS_DHCP " " \
109 "boot_prefixes=/ /boot/\0" \
111 "boot_scripts=boot.scr.uimg boot.scr\0" \
117 #define CONFIG_BOOTCOMMAND \
118 "for target in ${boot_targets}; do run bootcmd_${target}; done"
123 * Memory layout for where various images get loaded by boot scripts:
125 * scriptaddr can be pretty much anywhere that doesn't conflict with something
126 * else. Put it above BOOTMAPSZ to eliminate conflicts.
128 * kernel_addr_r must be within the first 128M of RAM in order for the
129 * kernel's CONFIG_AUTO_ZRELADDR option to work. Since the kernel will
130 * decompress itself to 0x8000 after the start of RAM, kernel_addr_r
131 * should not overlap that area, or the kernel will have to copy itself
132 * somewhere else before decompression. Similarly, the address of any other
133 * data passed to the kernel shouldn't overlap the start of RAM. Pushing
134 * this up to 16M allows for a sizable kernel to be decompressed below the
135 * compressed load address.
137 * fdt_addr_r simply shouldn't overlap anything else. Choosing 32M allows for
138 * the compressed kernel to be up to 16M too.
140 * ramdisk_addr_r simply shouldn't overlap anything else. Choosing 33M allows
141 * for the FDT/DTB to be up to 1M, which is hopefully plenty.
143 #define MEM_LAYOUT_ENV_SETTINGS \
144 "scriptaddr=0x10000000\0" \
145 "kernel_addr_r=0x01000000\0" \
146 "fdt_addr_r=0x02000000\0" \
147 "ramdisk_addr_r=0x02100000\0" \
149 #ifdef CONFIG_TEGRA_KEYBOARD
150 #define STDIN_KBD_KBC ",tegra-kbc"
152 #define STDIN_KBD_KBC ""
155 #ifdef CONFIG_USB_KEYBOARD
156 #define STDIN_KBD_USB ",usbkbd"
157 #define CONFIG_SYS_USB_EVENT_POLL
158 #define CONFIG_PREBOOT "usb start"
160 #define STDIN_KBD_USB ""
163 #define TEGRA_DEVICE_SETTINGS \
164 "stdin=serial" STDIN_KBD_KBC STDIN_KBD_USB "\0" \
165 "stdout=serial,lcd\0" \
166 "stderr=serial,lcd\0" \
168 #define CONFIG_EXTRA_ENV_SETTINGS \
169 TEGRA_DEVICE_SETTINGS \
170 MEM_LAYOUT_ENV_SETTINGS \
173 /* overrides for SPL build here */
174 #ifdef CONFIG_SPL_BUILD
176 /* remove devicetree support */
177 #ifdef CONFIG_OF_CONTROL
178 #undef CONFIG_OF_CONTROL
181 /* remove I2C support */
182 #ifdef CONFIG_TEGRA_I2C
183 #undef CONFIG_TEGRA_I2C
185 #ifdef CONFIG_CMD_I2C
186 #undef CONFIG_CMD_I2C
189 /* remove MMC support */
193 #ifdef CONFIG_GENERIC_MMC
194 #undef CONFIG_GENERIC_MMC
196 #ifdef CONFIG_TEGRA_MMC
197 #undef CONFIG_TEGRA_MMC
199 #ifdef CONFIG_CMD_MMC
200 #undef CONFIG_CMD_MMC
203 /* remove partitions/filesystems */
204 #ifdef CONFIG_DOS_PARTITION
205 #undef CONFIG_DOS_PARTITION
207 #ifdef CONFIG_EFI_PARTITION
208 #undef CONFIG_EFI_PARTITION
210 #ifdef CONFIG_CMD_FS_GENERIC
211 #undef CONFIG_CMD_FS_GENERIC
213 #ifdef CONFIG_CMD_EXT4
214 #undef CONFIG_CMD_EXT4
216 #ifdef CONFIG_CMD_EXT2
217 #undef CONFIG_CMD_EXT2
219 #ifdef CONFIG_CMD_FAT
220 #undef CONFIG_CMD_FAT
222 #ifdef CONFIG_FS_EXT4
223 #undef CONFIG_FS_EXT4
230 #ifdef CONFIG_USB_EHCI
231 #undef CONFIG_USB_EHCI
233 #ifdef CONFIG_USB_EHCI_TEGRA
234 #undef CONFIG_USB_EHCI_TEGRA
236 #ifdef CONFIG_USB_STORAGE
237 #undef CONFIG_USB_STORAGE
239 #ifdef CONFIG_CMD_USB
240 #undef CONFIG_CMD_USB
243 /* remove part command support */
244 #ifdef CONFIG_PARTITION_UUIDS
245 #undef CONFIG_PARTITION_UUIDS
248 #ifdef CONFIG_CMD_PART
249 #undef CONFIG_CMD_PART
252 #endif /* CONFIG_SPL_BUILD */
254 #endif /* __TEGRA_COMMON_POST_H */