2020-01-09 18:46:22 +00:00
|
|
|
.. SPDX-License-Identifier: GPL-2.0+
|
|
|
|
.. Copyright (C) 2019 Jagan Teki <jagan@amarulasolutions.com>
|
|
|
|
|
|
|
|
ROCKCHIP
|
|
|
|
========
|
|
|
|
|
|
|
|
About this
|
|
|
|
----------
|
|
|
|
|
|
|
|
This document describes the information about Rockchip supported boards
|
|
|
|
and it's usage steps.
|
|
|
|
|
|
|
|
Rockchip boards
|
|
|
|
---------------
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Rockchip is a SoC solutions provider for tablets & PCs, streaming media
|
2020-01-09 18:46:22 +00:00
|
|
|
TV boxes, AI audio & vision, IoT hardware.
|
|
|
|
|
2021-08-20 17:27:59 +00:00
|
|
|
A wide range of Rockchip SoCs with associated boards are supported in
|
2020-01-09 18:46:22 +00:00
|
|
|
mainline U-Boot.
|
|
|
|
|
2021-08-20 17:27:59 +00:00
|
|
|
List of mainline supported Rockchip boards:
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2020-05-22 14:14:56 +00:00
|
|
|
* rk3036
|
|
|
|
- Rockchip Evb-RK3036 (evb-rk3036)
|
|
|
|
- Kylin (kylin_rk3036)
|
|
|
|
* rk3128
|
|
|
|
- Rockchip Evb-RK3128 (evb-rk3128)
|
2021-08-20 17:27:58 +00:00
|
|
|
* rk3188
|
|
|
|
- Radxa Rock (rock)
|
2020-05-22 14:14:56 +00:00
|
|
|
* rk3229
|
|
|
|
- Rockchip Evb-RK3229 (evb-rk3229)
|
2020-01-09 18:46:22 +00:00
|
|
|
* rk3288
|
2020-05-22 14:14:55 +00:00
|
|
|
- Rockchip Evb-RK3288 (evb-rk3288)
|
|
|
|
- Firefly-RK3288 (firefly-rk3288)
|
|
|
|
- MQmaker MiQi (miqi-rk3288)
|
|
|
|
- Phytec RK3288 PCM-947 (phycore-rk3288)
|
|
|
|
- PopMetal-RK3288 (popmetal-rk3288)
|
|
|
|
- Radxa Rock 2 Square (rock2)
|
|
|
|
- Tinker-RK3288 (tinker-rk3288)
|
|
|
|
- Google Jerry (chromebook_jerry)
|
|
|
|
- Google Mickey (chromebook_mickey)
|
|
|
|
- Google Minnie (chromebook_minnie)
|
|
|
|
- Google Speedy (chromebook_speedy)
|
|
|
|
- Amarula Vyasa-RK3288 (vyasa-rk3288)
|
2020-05-22 14:14:56 +00:00
|
|
|
* rk3308
|
|
|
|
- Rockchip Evb-RK3308 (evb-rk3308)
|
|
|
|
- Roc-cc-RK3308 (roc-cc-rk3308)
|
2020-01-09 18:46:22 +00:00
|
|
|
* rk3328
|
2020-05-22 14:14:55 +00:00
|
|
|
- Rockchip Evb-RK3328 (evb-rk3328)
|
|
|
|
- Pine64 Rock64 (rock64-rk3328)
|
2020-05-22 14:14:56 +00:00
|
|
|
- Firefly-RK3328 (roc-cc-rk3328)
|
2020-05-31 16:02:11 +00:00
|
|
|
- Radxa Rockpi E (rock-pi-e-rk3328)
|
2020-01-09 18:46:22 +00:00
|
|
|
* rk3368
|
2020-05-22 14:14:55 +00:00
|
|
|
- GeekBox (geekbox)
|
|
|
|
- PX5 EVB (evb-px5)
|
|
|
|
- Rockchip Sheep (sheep-rk3368)
|
|
|
|
- Theobroma Systems RK3368-uQ7 SoM - Lion (lion-rk3368)
|
2020-01-09 18:46:22 +00:00
|
|
|
* rk3399
|
2020-05-22 14:14:55 +00:00
|
|
|
- 96boards RK3399 Ficus (ficus-rk3399)
|
|
|
|
- 96boards Rock960 (rock960-rk3399)
|
|
|
|
- Firefly-RK3399 (firefly_rk3399)
|
|
|
|
- Firefly ROC-RK3399-PC
|
|
|
|
- FriendlyElec NanoPC-T4 (nanopc-t4-rk3399)
|
|
|
|
- FriendlyElec NanoPi M4 (nanopi-m4-rk3399)
|
2021-03-26 12:37:10 +00:00
|
|
|
- FriendlyElec NanoPi M4B (nanopi-m4b-rk3399)
|
2020-05-22 14:14:55 +00:00
|
|
|
- FriendlyARM NanoPi NEO4 (nanopi-neo4-rk3399)
|
|
|
|
- Google Bob (chromebook_bob)
|
rockchip: rk3399: Add support for chromebook_kevin
Add support for Kevin, an RK3399-based convertible chromebook that is
very similar to Bob. This patch is mostly based on existing support for
Bob, with only minor changes for Kevin-specific things.
Unlike other Gru boards, coreboot sets Kevin's center logic to 925 mV,
so adjust it here in the dts as well. The rk3399-gru-kevin devicetree
has an unknown event code reference which has to be defined, set it
to the Linux counterpart. The new defconfig is copied from Bob with the
diffconfig:
DEFAULT_DEVICE_TREE "rk3399-gru-bob" -> "rk3399-gru-kevin"
DEFAULT_FDT_FILE "rockchip/rk3399-gru-bob.dtb" -> "rockchip/rk3399-gru-kevin.dtb"
VIDEO_ROCKCHIP_MAX_XRES 1280 -> 2400
VIDEO_ROCKCHIP_MAX_YRES 800 -> 1600
+TARGET_CHROMEBOOK_KEVIN y
With this Kevin can boot from SPI flash to a usable U-Boot prompt on the
display with the keyboard working, but cannot boot into Linux for
unknown reasons.
eMMC starts in a working state but fails to re-init, microSD card works
but at a lower-than-expected speed, USB works but causes a hang on
de-init. There are known workarounds to solve eMMC and USB issues.
Cc: Marty E. Plummer <hanetzer@startmail.com>
Cc: Simon Glass <sjg@chromium.org>
[Alper: commit message, resync config with Bob, update MAINTAINERS,
add to Rockchip doc, add Kconfig help message, set regulator]
Co-developed-by: Alper Nebi Yasak <alpernebiyasak@gmail.com>
Signed-off-by: Alper Nebi Yasak <alpernebiyasak@gmail.com>
Reviewed-by: Kever Yang <kever.yang@rock-chips.com>
Reviewed-by: Simon Glass <sjg@chromium.org>
Tested-by: Simon Glass <sjg@chromium.org>
2021-12-24 13:43:46 +00:00
|
|
|
- Google Kevin (chromebook_kevin)
|
2020-05-22 14:14:55 +00:00
|
|
|
- Khadas Edge (khadas-edge-rk3399)
|
|
|
|
- Khadas Edge-Captain (khadas-edge-captain-rk3399)
|
|
|
|
- Khadas Edge-V (hadas-edge-v-rk3399)
|
|
|
|
- Orange Pi RK3399 (orangepi-rk3399)
|
|
|
|
- Pine64 RockPro64 (rockpro64-rk3399)
|
|
|
|
- Radxa ROCK Pi 4 (rock-pi-4-rk3399)
|
|
|
|
- Rockchip Evb-RK3399 (evb_rk3399)
|
|
|
|
- Theobroma Systems RK3399-Q7 SoM - Puma (puma_rk3399)
|
2020-05-22 14:14:56 +00:00
|
|
|
* rv1108
|
|
|
|
- Rockchip Evb-rv1108 (evb-rv1108)
|
|
|
|
- Elgin-R1 (elgin-rv1108)
|
2020-01-09 18:46:22 +00:00
|
|
|
|
|
|
|
Building
|
|
|
|
--------
|
|
|
|
|
|
|
|
TF-A
|
|
|
|
^^^^
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
TF-A is required when building ARM64 Rockchip SoCs images.
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
To build TF-A:
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
git clone --depth 1 https://github.com/ARM-software/arm-trusted-firmware.git
|
2020-01-09 18:46:22 +00:00
|
|
|
cd arm-trusted-firmware
|
|
|
|
make realclean
|
|
|
|
make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399
|
2022-04-16 15:09:50 +00:00
|
|
|
cd ..
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2021-08-20 17:27:59 +00:00
|
|
|
Specify the PLAT= with desired Rockchip platform to build TF-A for.
|
2020-01-09 18:46:22 +00:00
|
|
|
|
|
|
|
U-Boot
|
|
|
|
^^^^^^
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
git clone --depth 1 https://source.denx.de/u-boot/u-boot.git
|
|
|
|
cd u-boot
|
|
|
|
|
|
|
|
To build rk3288 boards:
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-01-09 18:46:22 +00:00
|
|
|
|
|
|
|
make evb-rk3288_defconfig
|
2022-04-16 15:09:50 +00:00
|
|
|
make CROSS_COMPILE=arm-linux-gnueabihf-
|
|
|
|
|
|
|
|
To build rk3328 boards:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
export BL31=../arm-trusted-firmware/build/rk3328/release/bl31/bl31.elf
|
|
|
|
make evb-rk3328_defconfig
|
|
|
|
make CROSS_COMPILE=aarch64-linux-gnu-
|
|
|
|
|
|
|
|
To build rk3368 boards:
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
export BL31=../arm-trusted-firmware/build/rk3368/release/bl31/bl31.elf
|
2020-01-09 18:46:22 +00:00
|
|
|
make evb-px5_defconfig
|
2022-04-16 15:09:50 +00:00
|
|
|
make CROSS_COMPILE=aarch64-linux-gnu-
|
|
|
|
|
|
|
|
To build rk3399 boards:
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
export BL31=../arm-trusted-firmware/build/rk3399/release/bl31/bl31.elf
|
2020-01-09 18:46:22 +00:00
|
|
|
make evb-rk3399_defconfig
|
2022-04-16 15:09:50 +00:00
|
|
|
make CROSS_COMPILE=aarch64-linux-gnu-
|
2020-01-09 18:46:22 +00:00
|
|
|
|
|
|
|
Flashing
|
|
|
|
--------
|
|
|
|
|
2020-10-28 13:33:48 +00:00
|
|
|
1. Package the image with U-Boot TPL/SPL
|
|
|
|
-----------------------------------------
|
|
|
|
|
2020-01-09 18:46:22 +00:00
|
|
|
SD Card
|
|
|
|
^^^^^^^
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
All Rockchip platforms (except rk3128 which doesn't use SPL) are now
|
|
|
|
supporting a single boot image using binman and pad_cat.
|
2020-01-09 18:46:22 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
To write an image that boots from a SD card (assumed to be /dev/sda):
|
|
|
|
|
|
|
|
.. code-block:: bash
|
2020-01-09 18:46:22 +00:00
|
|
|
|
|
|
|
sudo dd if=u-boot-rockchip.bin of=/dev/sda seek=64
|
|
|
|
sync
|
|
|
|
|
2020-05-24 17:32:13 +00:00
|
|
|
eMMC
|
|
|
|
^^^^
|
|
|
|
|
2021-08-20 17:27:59 +00:00
|
|
|
eMMC flash would probe on mmc0 in most of the Rockchip platforms.
|
2020-05-24 17:32:13 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Create GPT partition layout as defined in $partitions:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
2020-05-24 17:32:13 +00:00
|
|
|
|
|
|
|
mmc dev 0
|
|
|
|
gpt write mmc 0 $partitions
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Connect the USB-OTG cable between the host and a target device.
|
|
|
|
|
|
|
|
Launch fastboot on the target with:
|
2020-05-24 17:32:13 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-05-24 17:32:13 +00:00
|
|
|
|
|
|
|
fastboot 0
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Upon a successful gadget connection the host shows the USB device with:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
2020-05-24 17:32:13 +00:00
|
|
|
|
|
|
|
lsusb
|
2022-04-16 15:09:50 +00:00
|
|
|
# Bus 001 Device 020: ID 2207:330c Fuzhou Rockchip Electronics Company RK3399 in Mask ROM mode
|
|
|
|
|
|
|
|
Program the flash with:
|
2020-05-24 17:32:13 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-05-24 17:32:13 +00:00
|
|
|
|
|
|
|
sudo fastboot -i 0x2207 flash loader1 idbloader.img
|
|
|
|
sudo fastboot -i 0x2207 flash loader2 u-boot.itb
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Note:
|
|
|
|
|
|
|
|
For Rockchip 32-bit platforms the U-Boot proper image
|
2020-05-24 17:32:13 +00:00
|
|
|
is u-boot-dtb.img
|
|
|
|
|
2020-06-04 14:51:41 +00:00
|
|
|
SPI
|
|
|
|
^^^
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
The SPI boot method requires the generation of idbloader.img with help of the mkimage tool.
|
|
|
|
|
|
|
|
SPL-alone SPI boot image:
|
2020-06-04 14:51:41 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-06-04 14:51:41 +00:00
|
|
|
|
|
|
|
./tools/mkimage -n rk3399 -T rkspi -d spl/u-boot-spl.bin idbloader.img
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
TPL+SPL SPI boot image:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
2020-06-04 14:51:41 +00:00
|
|
|
|
|
|
|
./tools/mkimage -n rk3399 -T rkspi -d tpl/u-boot-tpl.bin:spl/u-boot-spl.bin idbloader.img
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Copy SPI boot images into SD card and boot from SD:
|
|
|
|
|
|
|
|
.. code-block:: bash
|
2020-06-04 14:51:41 +00:00
|
|
|
|
|
|
|
sf probe
|
|
|
|
load mmc 1:1 $kernel_addr_r idbloader.img
|
|
|
|
sf erase 0 +$filesize
|
|
|
|
sf write $kernel_addr_r 0 ${filesize}
|
|
|
|
load mmc 1:1 ${kernel_addr_r} u-boot.itb
|
|
|
|
sf erase 0x60000 +$filesize
|
|
|
|
sf write $kernel_addr_r 0x60000 ${filesize}
|
|
|
|
|
2020-10-28 13:33:48 +00:00
|
|
|
2. Package the image with Rockchip miniloader
|
|
|
|
---------------------------------------------
|
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Image package with Rockchip miniloader requires rkbin [1].
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
cd ..
|
|
|
|
git clone --depth 1 https://github.com/rockchip-linux/rkbin
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Create idbloader.img:
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
cd u-boot
|
|
|
|
./tools/mkimage -n px30 -T rksd -d ../rkbin/bin/rk33/px30_ddr_333MHz_v1.16.bin idbloader.img
|
|
|
|
cat ../rkbin/bin/rk33/px30_miniloader_v1.31.bin >> idbloader.img
|
|
|
|
sudo dd if=idbloader.img of=/dev/sda seek=64
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Create trust.img:
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
cd ../rkbin
|
|
|
|
./tools/trust_merger RKTRUST/PX30TRUST.ini
|
|
|
|
sudo dd if=trust.img of=/dev/sda seek=24576
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
Create uboot.img [2]:
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
.. code-block:: bash
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2022-04-16 15:09:50 +00:00
|
|
|
cd ../u-boot
|
|
|
|
../rkbin/tools/loaderimage --pack --uboot u-boot-dtb.bin uboot.img 0x200000
|
|
|
|
sudo dd if=uboot.img of=/dev/sda seek=16384
|
2020-10-28 13:33:48 +00:00
|
|
|
|
|
|
|
Note:
|
2022-04-16 15:09:50 +00:00
|
|
|
|
|
|
|
1. rkbin binaries are regularly updated, so it would be recommended to use the latest version.
|
|
|
|
2. 0x200000 is a load address and is an option for some platforms.
|
2020-10-28 13:33:48 +00:00
|
|
|
|
2020-01-09 18:46:22 +00:00
|
|
|
TODO
|
|
|
|
----
|
|
|
|
|
2021-08-20 17:27:59 +00:00
|
|
|
- Add Rockchip idbloader image building
|
|
|
|
- Add Rockchip TPL image building
|
2020-01-09 18:46:22 +00:00
|
|
|
- Document SPI flash boot
|
|
|
|
- Add missing SoC's with it boards list
|
|
|
|
|
|
|
|
.. Jagan Teki <jagan@amarulasolutions.com>
|
2020-10-28 13:33:48 +00:00
|
|
|
.. Wednesday 28 October 2020 06:47:26 PM IST
|