2015-08-30 22:55:38 +00:00
|
|
|
if ARCH_ROCKCHIP
|
|
|
|
|
2016-07-15 22:17:15 +00:00
|
|
|
config ROCKCHIP_RK3036
|
|
|
|
bool "Support Rockchip RK3036"
|
2018-04-26 12:51:26 +00:00
|
|
|
select CPU_V7A
|
2016-07-19 13:16:59 +00:00
|
|
|
select SUPPORT_SPL
|
|
|
|
select SPL
|
2018-01-17 01:51:41 +00:00
|
|
|
imply USB_FUNCTION_ROCKUSB
|
|
|
|
imply CMD_ROCKUSB
|
2016-07-15 22:17:15 +00:00
|
|
|
help
|
|
|
|
The Rockchip RK3036 is a ARM-based SoC with a dual-core Cortex-A7
|
|
|
|
including NEON and GPU, Mali-400 graphics, several DDR3 options
|
|
|
|
and video codec support. Peripherals include Gigabit Ethernet,
|
|
|
|
USB2 host and OTG, SDIO, I2S, UART, SPI, I2C and PWMs.
|
|
|
|
|
2017-11-28 08:04:16 +00:00
|
|
|
config ROCKCHIP_RK3128
|
|
|
|
bool "Support Rockchip RK3128"
|
2018-04-26 12:51:26 +00:00
|
|
|
select CPU_V7A
|
2017-11-28 08:04:16 +00:00
|
|
|
help
|
|
|
|
The Rockchip RK3128 is a ARM-based SoC with a quad-core Cortex-A7
|
|
|
|
including NEON and GPU, Mali-400 graphics, several DDR3 options
|
|
|
|
and video codec support. Peripherals include Gigabit Ethernet,
|
|
|
|
USB2 host and OTG, SDIO, I2S, UART, SPI, I2C and PWMs.
|
|
|
|
|
2017-02-18 18:46:36 +00:00
|
|
|
config ROCKCHIP_RK3188
|
|
|
|
bool "Support Rockchip RK3188"
|
2018-04-26 12:51:26 +00:00
|
|
|
select CPU_V7A
|
2017-05-03 09:13:32 +00:00
|
|
|
select SPL_BOARD_INIT if SPL
|
2017-02-18 18:46:36 +00:00
|
|
|
select SUPPORT_SPL
|
|
|
|
select SPL
|
2017-10-10 14:21:17 +00:00
|
|
|
select SPL_CLK
|
|
|
|
select SPL_REGMAP
|
|
|
|
select SPL_SYSCON
|
|
|
|
select SPL_RAM
|
|
|
|
select SPL_DRIVERS_MISC_SUPPORT
|
2017-10-10 14:21:15 +00:00
|
|
|
select SPL_ROCKCHIP_EARLYRETURN_TO_BROM
|
2017-04-05 22:19:36 +00:00
|
|
|
select BOARD_LATE_INIT
|
2017-02-18 18:46:36 +00:00
|
|
|
select ROCKCHIP_BROM_HELPER
|
|
|
|
help
|
|
|
|
The Rockchip RK3188 is a ARM-based SoC with a quad-core Cortex-A9
|
|
|
|
including NEON and GPU, 512KB L2 cache, Mali-400 graphics, two
|
|
|
|
video interfaces, several memory options and video codec support.
|
|
|
|
Peripherals include Fast Ethernet, USB2 host and OTG, SDIO, I2S,
|
|
|
|
UART, SPI, I2C and PWMs.
|
2017-06-23 09:17:52 +00:00
|
|
|
|
|
|
|
config ROCKCHIP_RK322X
|
|
|
|
bool "Support Rockchip RK3228/RK3229"
|
2018-04-26 12:51:26 +00:00
|
|
|
select CPU_V7A
|
2017-06-23 09:17:52 +00:00
|
|
|
select SUPPORT_SPL
|
2019-04-02 12:41:24 +00:00
|
|
|
select SUPPORT_TPL
|
2017-06-23 09:17:52 +00:00
|
|
|
select SPL
|
2019-04-02 12:41:24 +00:00
|
|
|
select SPL_DM
|
|
|
|
select SPL_OF_LIBFDT
|
|
|
|
select TPL
|
|
|
|
select TPL_DM
|
|
|
|
select TPL_OF_LIBFDT
|
|
|
|
select TPL_NEEDS_SEPARATE_TEXT_BASE if SPL
|
|
|
|
select TPL_NEEDS_SEPARATE_STACK if TPL
|
|
|
|
select SPL_DRIVERS_MISC_SUPPORT
|
|
|
|
imply SPL_SERIAL_SUPPORT
|
|
|
|
imply TPL_SERIAL_SUPPORT
|
2017-06-23 09:17:52 +00:00
|
|
|
select ROCKCHIP_BROM_HELPER
|
2019-04-02 12:41:24 +00:00
|
|
|
select TPL_LIBCOMMON_SUPPORT
|
|
|
|
select TPL_LIBGENERIC_SUPPORT
|
2017-06-23 09:17:52 +00:00
|
|
|
help
|
|
|
|
The Rockchip RK3229 is a ARM-based SoC with a dual-core Cortex-A7
|
|
|
|
including NEON and GPU, Mali-400 graphics, several DDR3 options
|
|
|
|
and video codec support. Peripherals include Gigabit Ethernet,
|
|
|
|
USB2 host and OTG, SDIO, I2S, UART, SPI, I2C and PWMs.
|
2017-02-18 18:46:36 +00:00
|
|
|
|
2019-04-02 12:41:24 +00:00
|
|
|
if ROCKCHIP_RK322X
|
|
|
|
|
|
|
|
config TPL_TEXT_BASE
|
|
|
|
default 0x10081000
|
|
|
|
|
|
|
|
config TPL_MAX_SIZE
|
|
|
|
default 28672
|
|
|
|
|
|
|
|
config TPL_STACK
|
|
|
|
default 0x10088000
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
2015-08-30 22:55:38 +00:00
|
|
|
config ROCKCHIP_RK3288
|
|
|
|
bool "Support Rockchip RK3288"
|
2018-04-26 12:51:26 +00:00
|
|
|
select CPU_V7A
|
2017-05-03 09:13:32 +00:00
|
|
|
select SPL_BOARD_INIT if SPL
|
2016-07-19 13:16:59 +00:00
|
|
|
select SUPPORT_SPL
|
|
|
|
select SPL
|
2017-12-15 00:17:13 +00:00
|
|
|
imply USB_FUNCTION_ROCKUSB
|
|
|
|
imply CMD_ROCKUSB
|
2015-08-30 22:55:38 +00:00
|
|
|
help
|
|
|
|
The Rockchip RK3288 is a ARM-based SoC with a quad-core Cortex-A17
|
|
|
|
including NEON and GPU, 1MB L2 cache, Mali-T7 graphics, two
|
|
|
|
video interfaces supporting HDMI and eDP, several DDR3 options
|
|
|
|
and video codec support. Peripherals include Gigabit Ethernet,
|
2016-11-02 17:03:01 +00:00
|
|
|
USB2 host and OTG, SDIO, I2S, UARTs, SPI, I2C and PWMs.
|
2015-08-30 22:55:38 +00:00
|
|
|
|
2018-02-23 07:43:10 +00:00
|
|
|
if ROCKCHIP_RK3288
|
|
|
|
|
2018-02-23 07:43:11 +00:00
|
|
|
config TPL_TEXT_BASE
|
|
|
|
default 0xff704000
|
|
|
|
|
2019-01-22 22:09:25 +00:00
|
|
|
config TPL_MAX_SIZE
|
|
|
|
default 32768
|
|
|
|
|
2018-02-23 07:43:10 +00:00
|
|
|
endif
|
|
|
|
|
2017-02-23 07:37:51 +00:00
|
|
|
config ROCKCHIP_RK3328
|
|
|
|
bool "Support Rockchip RK3328"
|
|
|
|
select ARM64
|
|
|
|
help
|
|
|
|
The Rockchip RK3328 is a ARM-based SoC with a quad-core Cortex-A53.
|
|
|
|
including NEON and GPU, 1MB L2 cache, Mali-T7 graphics, two
|
|
|
|
video interfaces supporting HDMI and eDP, several DDR3 options
|
|
|
|
and video codec support. Peripherals include Gigabit Ethernet,
|
|
|
|
USB2 host and OTG, SDIO, I2S, UARTs, SPI, I2C and PWMs.
|
|
|
|
|
2017-05-15 09:51:18 +00:00
|
|
|
config ROCKCHIP_RK3368
|
|
|
|
bool "Support Rockchip RK3368"
|
|
|
|
select ARM64
|
2017-06-11 21:46:25 +00:00
|
|
|
select SUPPORT_SPL
|
|
|
|
select SUPPORT_TPL
|
2017-07-28 18:03:07 +00:00
|
|
|
select TPL_NEEDS_SEPARATE_TEXT_BASE if SPL
|
|
|
|
select TPL_NEEDS_SEPARATE_STACK if TPL
|
2017-06-11 21:46:25 +00:00
|
|
|
imply SPL_SEPARATE_BSS
|
|
|
|
imply SPL_SERIAL_SUPPORT
|
|
|
|
imply TPL_SERIAL_SUPPORT
|
2017-05-15 09:51:18 +00:00
|
|
|
help
|
2017-06-09 22:47:53 +00:00
|
|
|
The Rockchip RK3368 is a ARM-based SoC with a octa-core (organised
|
|
|
|
into a big and little cluster with 4 cores each) Cortex-A53 including
|
|
|
|
AdvSIMD, 512KB L2 cache (for the big cluster) and 256 KB L2 cache
|
|
|
|
(for the little cluster), PowerVR G6110 based graphics, one video
|
|
|
|
output processor supporting LVDS/HDMI/eDP, several DDR3 options and
|
|
|
|
video codec support.
|
|
|
|
|
|
|
|
On-chip peripherals include Gigabit Ethernet, USB2 host and OTG, SDIO,
|
|
|
|
I2S, UARTs, SPI, I2C and PWMs.
|
2017-05-15 09:51:18 +00:00
|
|
|
|
2017-08-02 19:26:18 +00:00
|
|
|
if ROCKCHIP_RK3368
|
|
|
|
|
2017-07-28 18:20:41 +00:00
|
|
|
config TPL_TEXT_BASE
|
|
|
|
default 0xff8c1000
|
|
|
|
|
|
|
|
config TPL_MAX_SIZE
|
|
|
|
default 28672
|
|
|
|
|
|
|
|
config TPL_STACK
|
|
|
|
default 0xff8cffff
|
|
|
|
|
2017-08-02 19:26:18 +00:00
|
|
|
endif
|
|
|
|
|
2016-07-19 13:16:59 +00:00
|
|
|
config ROCKCHIP_RK3399
|
|
|
|
bool "Support Rockchip RK3399"
|
|
|
|
select ARM64
|
2017-02-22 08:56:38 +00:00
|
|
|
select SUPPORT_SPL
|
2018-11-09 03:18:15 +00:00
|
|
|
select SUPPORT_TPL
|
2017-02-22 08:56:38 +00:00
|
|
|
select SPL
|
2018-11-09 03:18:15 +00:00
|
|
|
select TPL_NEEDS_SEPARATE_TEXT_BASE if TPL
|
|
|
|
select TPL_NEEDS_SEPARATE_STACK if TPL
|
2017-02-22 08:56:38 +00:00
|
|
|
select SPL_SEPARATE_BSS
|
2017-07-26 10:29:01 +00:00
|
|
|
select SPL_SERIAL_SUPPORT
|
|
|
|
select SPL_DRIVERS_MISC_SUPPORT
|
2017-10-11 07:00:16 +00:00
|
|
|
select BOARD_LATE_INIT
|
2017-10-11 07:00:49 +00:00
|
|
|
select ROCKCHIP_BROM_HELPER
|
2018-11-09 03:18:15 +00:00
|
|
|
imply TPL_SERIAL_SUPPORT
|
|
|
|
imply TPL_LIBCOMMON_SUPPORT
|
|
|
|
imply TPL_LIBGENERIC_SUPPORT
|
|
|
|
imply TPL_SYS_MALLOC_SIMPLE
|
|
|
|
imply TPL_BOOTROM_SUPPORT
|
|
|
|
imply TPL_DRIVERS_MISC_SUPPORT
|
|
|
|
imply TPL_OF_CONTROL
|
|
|
|
imply TPL_DM
|
|
|
|
imply TPL_REGMAP
|
|
|
|
imply TPL_SYSCON
|
|
|
|
imply TPL_RAM
|
|
|
|
imply TPL_CLK
|
|
|
|
imply TPL_TINY_MEMSET
|
2016-07-19 13:16:59 +00:00
|
|
|
help
|
|
|
|
The Rockchip RK3399 is a ARM-based SoC with a dual-core Cortex-A72
|
|
|
|
and quad-core Cortex-A53.
|
|
|
|
including NEON and GPU, 1MB L2 cache, Mali-T7 graphics, two
|
|
|
|
video interfaces supporting HDMI and eDP, several DDR3 options
|
|
|
|
and video codec support. Peripherals include Gigabit Ethernet,
|
|
|
|
USB2 host and OTG, SDIO, I2S, UARTs, SPI, I2C and PWMs.
|
|
|
|
|
2018-11-09 03:18:15 +00:00
|
|
|
if ROCKCHIP_RK3399
|
|
|
|
|
|
|
|
config TPL_LDSCRIPT
|
|
|
|
default "arch/arm/mach-rockchip/u-boot-tpl-v8.lds"
|
|
|
|
|
|
|
|
config TPL_TEXT_BASE
|
|
|
|
default 0xff8c2000
|
|
|
|
|
|
|
|
config TPL_MAX_SIZE
|
|
|
|
default 188416
|
|
|
|
|
|
|
|
config TPL_STACK
|
|
|
|
default 0xff8effff
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
2017-06-01 10:00:55 +00:00
|
|
|
config ROCKCHIP_RV1108
|
|
|
|
bool "Support Rockchip RV1108"
|
2018-04-26 12:51:26 +00:00
|
|
|
select CPU_V7A
|
2017-06-01 10:00:55 +00:00
|
|
|
help
|
|
|
|
The Rockchip RV1108 is a ARM-based SoC with a single-core Cortex-A7
|
|
|
|
and a DSP.
|
|
|
|
|
2018-10-08 11:01:56 +00:00
|
|
|
config ROCKCHIP_USB_UART
|
|
|
|
bool "Route uart output to usb pins"
|
|
|
|
help
|
|
|
|
Rockchip SoCs have the ability to route the signals of the debug
|
|
|
|
uart through the d+ and d- pins of a specific usb phy to enable
|
|
|
|
some form of closed-case debugging. With this option supported
|
|
|
|
SoCs will enable this routing as a debug measure.
|
|
|
|
|
2017-06-29 09:21:15 +00:00
|
|
|
config SPL_ROCKCHIP_BACK_TO_BROM
|
2016-07-12 11:09:49 +00:00
|
|
|
bool "SPL returns to bootrom"
|
|
|
|
default y if ROCKCHIP_RK3036
|
2017-02-18 18:46:25 +00:00
|
|
|
select ROCKCHIP_BROM_HELPER
|
2017-06-29 09:21:15 +00:00
|
|
|
depends on SPL
|
|
|
|
help
|
|
|
|
Rockchip SoCs have ability to load SPL & U-Boot binary. If enabled,
|
|
|
|
SPL will return to the boot rom, which will then load the U-Boot
|
|
|
|
binary to keep going on.
|
|
|
|
|
|
|
|
config TPL_ROCKCHIP_BACK_TO_BROM
|
|
|
|
bool "TPL returns to bootrom"
|
2018-11-09 03:18:15 +00:00
|
|
|
default y
|
2017-06-29 09:21:15 +00:00
|
|
|
select ROCKCHIP_BROM_HELPER
|
|
|
|
depends on TPL
|
2016-07-12 11:09:49 +00:00
|
|
|
help
|
|
|
|
Rockchip SoCs have ability to load SPL & U-Boot binary. If enabled,
|
|
|
|
SPL will return to the boot rom, which will then load the U-Boot
|
|
|
|
binary to keep going on.
|
|
|
|
|
2017-10-11 07:00:16 +00:00
|
|
|
config ROCKCHIP_BOOT_MODE_REG
|
|
|
|
hex "Rockchip boot mode flag register address"
|
|
|
|
default 0x200081c8 if ROCKCHIP_RK3036
|
|
|
|
default 0x20004040 if ROCKCHIP_RK3188
|
|
|
|
default 0x110005c8 if ROCKCHIP_RK322X
|
|
|
|
default 0xff730094 if ROCKCHIP_RK3288
|
|
|
|
default 0xff738200 if ROCKCHIP_RK3368
|
|
|
|
default 0xff320300 if ROCKCHIP_RK3399
|
|
|
|
default 0x10300580 if ROCKCHIP_RV1108
|
|
|
|
default 0
|
|
|
|
help
|
2019-03-28 03:01:23 +00:00
|
|
|
The Soc will enter to different boot mode(defined in asm/arch-rockchip/boot_mode.h)
|
2017-10-11 07:00:16 +00:00
|
|
|
according to the value from this register.
|
|
|
|
|
2017-04-20 09:03:46 +00:00
|
|
|
config ROCKCHIP_SPL_RESERVE_IRAM
|
|
|
|
hex "Size of IRAM reserved in SPL"
|
2017-12-18 07:13:19 +00:00
|
|
|
default 0
|
2017-04-20 09:03:46 +00:00
|
|
|
help
|
|
|
|
SPL may need reserve memory for firmware loaded by SPL, whose load
|
|
|
|
address is in IRAM and may overlay with SPL text area if not
|
|
|
|
reserved.
|
|
|
|
|
2017-02-18 18:46:25 +00:00
|
|
|
config ROCKCHIP_BROM_HELPER
|
|
|
|
bool
|
|
|
|
|
2017-10-10 14:21:10 +00:00
|
|
|
config SPL_ROCKCHIP_EARLYRETURN_TO_BROM
|
|
|
|
bool "SPL requires early-return (for RK3188-style BROM) to BROM"
|
|
|
|
depends on SPL && ENABLE_ARM_SOC_BOOT0_HOOK
|
|
|
|
help
|
|
|
|
Some Rockchip BROM variants (e.g. on the RK3188) load the
|
|
|
|
first stage in segments and enter multiple times. E.g. on
|
|
|
|
the RK3188, the first 1KB of the first stage are loaded
|
|
|
|
first and entered; after returning to the BROM, the
|
|
|
|
remainder of the first stage is loaded, but the BROM
|
|
|
|
re-enters at the same address/to the same code as previously.
|
|
|
|
|
|
|
|
This enables support code in the BOOT0 hook for the SPL stage
|
|
|
|
to allow multiple entries.
|
|
|
|
|
|
|
|
config TPL_ROCKCHIP_EARLYRETURN_TO_BROM
|
|
|
|
bool "TPL requires early-return (for RK3188-style BROM) to BROM"
|
|
|
|
depends on TPL && ENABLE_ARM_SOC_BOOT0_HOOK
|
|
|
|
help
|
|
|
|
Some Rockchip BROM variants (e.g. on the RK3188) load the
|
|
|
|
first stage in segments and enter multiple times. E.g. on
|
|
|
|
the RK3188, the first 1KB of the first stage are loaded
|
|
|
|
first and entered; after returning to the BROM, the
|
|
|
|
remainder of the first stage is loaded, but the BROM
|
|
|
|
re-enters at the same address/to the same code as previously.
|
|
|
|
|
|
|
|
This enables support code in the BOOT0 hook for the TPL stage
|
|
|
|
to allow multiple entries.
|
|
|
|
|
2016-08-29 11:31:16 +00:00
|
|
|
config SPL_MMC_SUPPORT
|
2017-06-29 09:21:15 +00:00
|
|
|
default y if !SPL_ROCKCHIP_BACK_TO_BROM
|
2016-08-29 11:31:16 +00:00
|
|
|
|
2015-11-17 06:20:27 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk3036/Kconfig"
|
2017-11-28 08:04:16 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk3128/Kconfig"
|
2017-02-18 18:46:36 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk3188/Kconfig"
|
2017-06-23 09:17:54 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk322x/Kconfig"
|
2016-07-15 22:17:15 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk3288/Kconfig"
|
2017-02-23 07:37:51 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk3328/Kconfig"
|
2017-05-15 09:51:18 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk3368/Kconfig"
|
2016-07-19 13:16:59 +00:00
|
|
|
source "arch/arm/mach-rockchip/rk3399/Kconfig"
|
2017-06-01 10:00:55 +00:00
|
|
|
source "arch/arm/mach-rockchip/rv1108/Kconfig"
|
2015-08-30 22:55:38 +00:00
|
|
|
endif
|