69adf6462ac37de7b73f6b8656594c6594934c50
[platform/kernel/u-boot.git] / include / configs / tegra-common-post.h
1 /* SPDX-License-Identifier: GPL-2.0+ */
2 /*
3  * (C) Copyright 2010-2012
4  * NVIDIA Corporation <www.nvidia.com>
5  */
6
7 #ifndef __TEGRA_COMMON_POST_H
8 #define __TEGRA_COMMON_POST_H
9
10 /*
11  * Size of malloc() pool
12  */
13 #ifdef CONFIG_DFU_OVER_USB
14 #define CONFIG_SYS_MALLOC_LEN   (SZ_4M + \
15                                         CONFIG_SYS_DFU_DATA_BUF_SIZE + \
16                                         CONFIG_SYS_DFU_MAX_FILE_SIZE)
17 #else
18 #define CONFIG_SYS_MALLOC_LEN           (4 << 20)       /* 4MB  */
19 #endif
20
21 #define CONFIG_SYS_NONCACHED_MEMORY     (1 << 20)       /* 1 MiB */
22
23 #ifndef CONFIG_SPL_BUILD
24
25 #if CONFIG_IS_ENABLED(CMD_USB)
26 # define BOOT_TARGET_USB(func) func(USB, usb, 0)
27 #else
28 # define BOOT_TARGET_USB(func)
29 #endif
30
31 #ifndef BOOT_TARGET_DEVICES
32 #define BOOT_TARGET_DEVICES(func) \
33         func(MMC, mmc, 1) \
34         func(MMC, mmc, 0) \
35         BOOT_TARGET_USB(func) \
36         func(PXE, pxe, na) \
37         func(DHCP, dhcp, na)
38 #endif
39 #include <config_distro_bootcmd.h>
40 #else
41 #define BOOTENV
42 #endif
43
44 #ifdef CONFIG_TEGRA_KEYBOARD
45 #define STDIN_KBD_KBC ",tegra-kbc"
46 #else
47 #define STDIN_KBD_KBC ""
48 #endif
49
50 #ifdef CONFIG_USB_KEYBOARD
51 #define STDIN_KBD_USB ",usbkbd"
52 #else
53 #define STDIN_KBD_USB ""
54 #endif
55
56 #ifdef CONFIG_LCD
57 #define STDOUT_LCD ",lcd"
58 #else
59 #define STDOUT_LCD ""
60 #endif
61
62 #ifdef CONFIG_DM_VIDEO
63 #define STDOUT_VIDEO ",vidconsole"
64 #else
65 #define STDOUT_VIDEO ""
66 #endif
67
68 #ifdef CONFIG_CROS_EC_KEYB
69 #define STDOUT_CROS_EC  ",cros-ec-keyb"
70 #else
71 #define STDOUT_CROS_EC  ""
72 #endif
73
74 #define TEGRA_DEVICE_SETTINGS \
75         "stdin=serial" STDIN_KBD_KBC STDIN_KBD_USB STDOUT_CROS_EC "\0" \
76         "stdout=serial" STDOUT_LCD STDOUT_VIDEO "\0" \
77         "stderr=serial" STDOUT_LCD STDOUT_VIDEO "\0" \
78         ""
79
80 #ifndef BOARD_EXTRA_ENV_SETTINGS
81 #define BOARD_EXTRA_ENV_SETTINGS
82 #endif
83
84 #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
85
86 #ifndef CONFIG_CHROMEOS_EXTRA_ENV_SETTINGS
87 #define CONFIG_CHROMEOS_EXTRA_ENV_SETTINGS
88 #endif
89
90 #ifdef CONFIG_ARM64
91 #define FDT_HIGH "ffffffffffffffff"
92 #define INITRD_HIGH "ffffffffffffffff"
93 #else
94 #define FDT_HIGH "ffffffff"
95 #define INITRD_HIGH "ffffffff"
96 #endif
97
98 #define CONFIG_EXTRA_ENV_SETTINGS \
99         TEGRA_DEVICE_SETTINGS \
100         MEM_LAYOUT_ENV_SETTINGS \
101         "fdt_high=" FDT_HIGH "\0" \
102         "initrd_high=" INITRD_HIGH "\0" \
103         BOOTENV \
104         BOARD_EXTRA_ENV_SETTINGS \
105         CONFIG_CHROMEOS_EXTRA_ENV_SETTINGS
106
107 #if defined(CONFIG_TEGRA20_SFLASH) || defined(CONFIG_TEGRA20_SLINK) || defined(CONFIG_TEGRA114_SPI)
108 #define CONFIG_TEGRA_SPI
109 #endif
110
111 /* overrides for SPL build here */
112 #ifdef CONFIG_SPL_BUILD
113
114 #define CONFIG_SKIP_LOWLEVEL_INIT_ONLY
115
116 /* remove USB */
117 #ifdef CONFIG_USB_EHCI_TEGRA
118 #undef CONFIG_USB_EHCI_TEGRA
119 #endif
120
121 #endif /* CONFIG_SPL_BUILD */
122
123 #endif /* __TEGRA_COMMON_POST_H */