Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 1 | if TEGRA |
| 2 | |
Simon Glass | 0bdfc3e | 2016-09-12 23:18:39 -0600 | [diff] [blame] | 3 | config SPL_GPIO_SUPPORT |
| 4 | default y |
| 5 | |
Simon Glass | f2a8946 | 2016-09-12 23:18:41 -0600 | [diff] [blame] | 6 | config SPL_LIBCOMMON_SUPPORT |
| 7 | default y |
| 8 | |
Simon Glass | b16c92c | 2016-09-12 23:18:43 -0600 | [diff] [blame] | 9 | config SPL_LIBGENERIC_SUPPORT |
| 10 | default y |
| 11 | |
Simon Glass | e076d6f | 2016-09-12 23:18:56 -0600 | [diff] [blame] | 12 | config SPL_SERIAL_SUPPORT |
| 13 | default y |
| 14 | |
Stephen Warren | adf3abd | 2016-07-18 12:17:11 -0600 | [diff] [blame] | 15 | config TEGRA_IVC |
| 16 | bool "Tegra IVC protocol" |
| 17 | help |
| 18 | IVC (Inter-VM Communication) protocol is a Tegra-specific IPC |
| 19 | (Inter Processor Communication) framework. Within the context of |
| 20 | U-Boot, it is typically used for communication between the main CPU |
| 21 | and various auxiliary processors. |
| 22 | |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 23 | config TEGRA_COMMON |
| 24 | bool "Tegra common options" |
Stephen Warren | 905752c | 2016-09-13 10:46:00 -0600 | [diff] [blame] | 25 | select CLK |
Tom Warren | 7b5002e | 2015-07-17 08:12:51 -0700 | [diff] [blame] | 26 | select DM |
Simon Glass | a403c9f | 2015-11-29 13:18:01 -0700 | [diff] [blame] | 27 | select DM_ETH |
Tom Warren | 7b5002e | 2015-07-17 08:12:51 -0700 | [diff] [blame] | 28 | select DM_GPIO |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 29 | select DM_I2C |
Simon Glass | 01e9940 | 2015-10-18 21:17:16 -0600 | [diff] [blame] | 30 | select DM_KEYBOARD |
Tom Warren | a66f772 | 2016-09-13 10:45:48 -0600 | [diff] [blame] | 31 | select DM_MMC |
Simon Glass | d8af3c9 | 2016-01-30 16:38:01 -0700 | [diff] [blame] | 32 | select DM_PWM |
Stephen Warren | 905752c | 2016-09-13 10:46:00 -0600 | [diff] [blame] | 33 | select DM_RESET |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 34 | select DM_SERIAL |
| 35 | select DM_SPI |
| 36 | select DM_SPI_FLASH |
Stephen Warren | 905752c | 2016-09-13 10:46:00 -0600 | [diff] [blame] | 37 | select MISC |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 38 | select OF_CONTROL |
Simon Glass | fe4ee97 | 2016-02-16 18:09:19 -0700 | [diff] [blame] | 39 | select VIDCONSOLE_AS_LCD if DM_VIDEO |
Simon Glass | 7a99a87 | 2017-01-23 13:31:20 -0700 | [diff] [blame] | 40 | select BOARD_EARLY_INIT_F |
Daniel Thompson | a9e2c67 | 2017-05-19 17:26:58 +0100 | [diff] [blame] | 41 | imply CRC32_VERIFY |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 42 | |
Stephen Warren | 905752c | 2016-09-13 10:46:00 -0600 | [diff] [blame] | 43 | config TEGRA_NO_BPMP |
| 44 | bool "Tegra common options for SoCs without BPMP" |
| 45 | select TEGRA_CAR |
| 46 | select TEGRA_CAR_CLOCK |
| 47 | select TEGRA_CAR_RESET |
| 48 | |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 49 | config TEGRA_ARMV7_COMMON |
| 50 | bool "Tegra 32-bit common options" |
| 51 | select CPU_V7 |
| 52 | select SPL |
Ley Foon Tan | 48fcc4a | 2017-05-03 17:13:32 +0800 | [diff] [blame] | 53 | select SPL_BOARD_INIT if SPL |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 54 | select SUPPORT_SPL |
| 55 | select TEGRA_COMMON |
Stephen Warren | af974be | 2016-05-12 12:07:41 -0600 | [diff] [blame] | 56 | select TEGRA_GPIO |
Stephen Warren | 905752c | 2016-09-13 10:46:00 -0600 | [diff] [blame] | 57 | select TEGRA_NO_BPMP |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 58 | |
| 59 | config TEGRA_ARMV8_COMMON |
| 60 | bool "Tegra 64-bit common options" |
| 61 | select ARM64 |
| 62 | select TEGRA_COMMON |
Tom Warren | 7b5002e | 2015-07-17 08:12:51 -0700 | [diff] [blame] | 63 | |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 64 | choice |
| 65 | prompt "Tegra SoC select" |
Joe Hershberger | f069960 | 2015-05-12 14:46:23 -0500 | [diff] [blame] | 66 | optional |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 67 | |
| 68 | config TEGRA20 |
| 69 | bool "Tegra20 family" |
Tom Rini | bacb52c | 2017-03-07 07:13:42 -0500 | [diff] [blame] | 70 | select ARM_ERRATA_716044 |
| 71 | select ARM_ERRATA_742230 |
| 72 | select ARM_ERRATA_751472 |
Tom Warren | 7b5002e | 2015-07-17 08:12:51 -0700 | [diff] [blame] | 73 | select TEGRA_ARMV7_COMMON |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 74 | |
| 75 | config TEGRA30 |
| 76 | bool "Tegra30 family" |
Tom Rini | bacb52c | 2017-03-07 07:13:42 -0500 | [diff] [blame] | 77 | select ARM_ERRATA_743622 |
| 78 | select ARM_ERRATA_751472 |
Tom Warren | 7b5002e | 2015-07-17 08:12:51 -0700 | [diff] [blame] | 79 | select TEGRA_ARMV7_COMMON |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 80 | |
| 81 | config TEGRA114 |
| 82 | bool "Tegra114 family" |
Tom Warren | 7b5002e | 2015-07-17 08:12:51 -0700 | [diff] [blame] | 83 | select TEGRA_ARMV7_COMMON |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 84 | |
| 85 | config TEGRA124 |
| 86 | bool "Tegra124 family" |
Tom Warren | 7b5002e | 2015-07-17 08:12:51 -0700 | [diff] [blame] | 87 | select TEGRA_ARMV7_COMMON |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 88 | |
Tom Warren | ab0cc6b | 2015-03-04 16:36:00 -0700 | [diff] [blame] | 89 | config TEGRA210 |
| 90 | bool "Tegra210 family" |
Stephen Warren | af974be | 2016-05-12 12:07:41 -0600 | [diff] [blame] | 91 | select TEGRA_GPIO |
Stephen Warren | 8c29e65 | 2015-11-23 10:32:01 -0700 | [diff] [blame] | 92 | select TEGRA_ARMV8_COMMON |
Stephen Warren | 905752c | 2016-09-13 10:46:00 -0600 | [diff] [blame] | 93 | select TEGRA_NO_BPMP |
Tom Warren | ab0cc6b | 2015-03-04 16:36:00 -0700 | [diff] [blame] | 94 | |
Stephen Warren | 03667eb | 2016-05-12 13:32:55 -0600 | [diff] [blame] | 95 | config TEGRA186 |
| 96 | bool "Tegra186 family" |
Stephen Warren | e0e2b26 | 2016-06-17 09:43:57 -0600 | [diff] [blame] | 97 | select DM_MAILBOX |
Stephen Warren | a214892 | 2016-08-08 09:41:34 -0600 | [diff] [blame] | 98 | select TEGRA186_BPMP |
Stephen Warren | e8e3f20 | 2016-08-08 11:28:24 -0600 | [diff] [blame] | 99 | select TEGRA186_CLOCK |
Stephen Warren | 03667eb | 2016-05-12 13:32:55 -0600 | [diff] [blame] | 100 | select TEGRA186_GPIO |
Stephen Warren | fccc9c5 | 2016-08-08 11:28:25 -0600 | [diff] [blame] | 101 | select TEGRA186_RESET |
Stephen Warren | 03667eb | 2016-05-12 13:32:55 -0600 | [diff] [blame] | 102 | select TEGRA_ARMV8_COMMON |
Stephen Warren | e0e2b26 | 2016-06-17 09:43:57 -0600 | [diff] [blame] | 103 | select TEGRA_HSP |
Stephen Warren | adf3abd | 2016-07-18 12:17:11 -0600 | [diff] [blame] | 104 | select TEGRA_IVC |
Stephen Warren | 03667eb | 2016-05-12 13:32:55 -0600 | [diff] [blame] | 105 | |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 106 | endchoice |
| 107 | |
Stephen Warren | 5a44ab4 | 2016-01-26 10:59:42 -0700 | [diff] [blame] | 108 | config TEGRA_DISCONNECT_UDC_ON_BOOT |
| 109 | bool "Disconnect USB device mode controller on boot" |
| 110 | default y |
| 111 | help |
| 112 | When loading U-Boot into RAM over USB protocols using tools such as |
| 113 | tegrarcm or L4T's exec-uboot.sh/tegraflash.py, Tegra's USB device |
| 114 | mode controller is initialized and enumerated by the host PC running |
| 115 | the tool. Unfortunately, these tools do not shut down the USB |
| 116 | controller before executing the downloaded code, and so the host PC |
| 117 | does not "de-enumerate" the USB device. This option shuts down the |
| 118 | USB controller when U-Boot boots to avoid leaving a stale USB device |
| 119 | present. |
| 120 | |
Simon Glass | 838723b | 2015-02-11 16:32:59 -0700 | [diff] [blame] | 121 | config SYS_MALLOC_F_LEN |
| 122 | default 0x1800 |
| 123 | |
Masahiro Yamada | ed1632a | 2015-02-20 17:04:04 +0900 | [diff] [blame] | 124 | source "arch/arm/mach-tegra/tegra20/Kconfig" |
| 125 | source "arch/arm/mach-tegra/tegra30/Kconfig" |
| 126 | source "arch/arm/mach-tegra/tegra114/Kconfig" |
| 127 | source "arch/arm/mach-tegra/tegra124/Kconfig" |
Tom Warren | ab0cc6b | 2015-03-04 16:36:00 -0700 | [diff] [blame] | 128 | source "arch/arm/mach-tegra/tegra210/Kconfig" |
Stephen Warren | 03667eb | 2016-05-12 13:32:55 -0600 | [diff] [blame] | 129 | source "arch/arm/mach-tegra/tegra186/Kconfig" |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 130 | |
Simon Glass | bd74b03 | 2017-05-17 03:25:11 -0600 | [diff] [blame] | 131 | config CMD_ENTERRCM |
| 132 | bool "Enable 'enterrcm' command" |
| 133 | default y |
| 134 | help |
| 135 | Tegra's boot ROM supports a mode whereby code may be downloaded and |
| 136 | flash-programmed over a USB connection. On dev boards, this is |
| 137 | typically entered by holding down a "force recovery" button and |
| 138 | resetting the CPU. However, not all boards have such a button (one |
| 139 | example is the Compulab Trimslice), so a method to enter RCM from |
| 140 | software is useful. |
| 141 | |
| 142 | Even on boards other than Trimslice, controlling this over a UART |
| 143 | may be useful, e.g. to allow simple remote control without the need |
| 144 | for mechanical button actuators, or hooking up relays/... to the |
| 145 | button. |
| 146 | |
Masahiro Yamada | 73a5b1a | 2014-08-31 07:10:56 +0900 | [diff] [blame] | 147 | endif |