blob: a75e60b9fa3028fe6d2f532c52536ac702b42cd3 [file] [log] [blame]
Jagan Teki338b86c2020-01-10 00:16:22 +05301.. SPDX-License-Identifier: GPL-2.0+
2.. Copyright (C) 2019 Jagan Teki <jagan@amarulasolutions.com>
3
4ROCKCHIP
5========
6
7About this
8----------
9
10This document describes the information about Rockchip supported boards
11and it's usage steps.
12
13Rockchip boards
14---------------
15
16Rockchip is SoC solutions provider for tablets & PCs, streaming media
17TV boxes, AI audio & vision, IoT hardware.
18
Johan Jonker3ad88ec2021-08-20 19:27:59 +020019A wide range of Rockchip SoCs with associated boards are supported in
Jagan Teki338b86c2020-01-10 00:16:22 +053020mainline U-Boot.
21
Johan Jonker3ad88ec2021-08-20 19:27:59 +020022List of mainline supported Rockchip boards:
Jagan Teki338b86c2020-01-10 00:16:22 +053023
Walter Lozanocbd75f62020-05-22 11:14:56 -030024* rk3036
25 - Rockchip Evb-RK3036 (evb-rk3036)
26 - Kylin (kylin_rk3036)
27* rk3128
28 - Rockchip Evb-RK3128 (evb-rk3128)
Johan Jonker734dcdc2021-08-20 19:27:58 +020029* rk3188
30 - Radxa Rock (rock)
Walter Lozanocbd75f62020-05-22 11:14:56 -030031* rk3229
32 - Rockchip Evb-RK3229 (evb-rk3229)
Jagan Teki338b86c2020-01-10 00:16:22 +053033* rk3288
Walter Lozano22186f32020-05-22 11:14:55 -030034 - Rockchip Evb-RK3288 (evb-rk3288)
35 - Firefly-RK3288 (firefly-rk3288)
36 - MQmaker MiQi (miqi-rk3288)
37 - Phytec RK3288 PCM-947 (phycore-rk3288)
38 - PopMetal-RK3288 (popmetal-rk3288)
39 - Radxa Rock 2 Square (rock2)
40 - Tinker-RK3288 (tinker-rk3288)
41 - Google Jerry (chromebook_jerry)
42 - Google Mickey (chromebook_mickey)
43 - Google Minnie (chromebook_minnie)
44 - Google Speedy (chromebook_speedy)
45 - Amarula Vyasa-RK3288 (vyasa-rk3288)
Walter Lozanocbd75f62020-05-22 11:14:56 -030046* rk3308
47 - Rockchip Evb-RK3308 (evb-rk3308)
48 - Roc-cc-RK3308 (roc-cc-rk3308)
Jagan Teki338b86c2020-01-10 00:16:22 +053049* rk3328
Walter Lozano22186f32020-05-22 11:14:55 -030050 - Rockchip Evb-RK3328 (evb-rk3328)
51 - Pine64 Rock64 (rock64-rk3328)
Walter Lozanocbd75f62020-05-22 11:14:56 -030052 - Firefly-RK3328 (roc-cc-rk3328)
b.l.huangd9c34172020-06-01 00:02:11 +080053 - Radxa Rockpi E (rock-pi-e-rk3328)
Jagan Teki338b86c2020-01-10 00:16:22 +053054* rk3368
Walter Lozano22186f32020-05-22 11:14:55 -030055 - GeekBox (geekbox)
56 - PX5 EVB (evb-px5)
57 - Rockchip Sheep (sheep-rk3368)
58 - Theobroma Systems RK3368-uQ7 SoM - Lion (lion-rk3368)
Jagan Teki338b86c2020-01-10 00:16:22 +053059* rk3399
Walter Lozano22186f32020-05-22 11:14:55 -030060 - 96boards RK3399 Ficus (ficus-rk3399)
61 - 96boards Rock960 (rock960-rk3399)
62 - Firefly-RK3399 (firefly_rk3399)
63 - Firefly ROC-RK3399-PC
64 - FriendlyElec NanoPC-T4 (nanopc-t4-rk3399)
65 - FriendlyElec NanoPi M4 (nanopi-m4-rk3399)
Alexandre Vicenzia99d70c2021-03-26 13:37:10 +010066 - FriendlyElec NanoPi M4B (nanopi-m4b-rk3399)
Walter Lozano22186f32020-05-22 11:14:55 -030067 - FriendlyARM NanoPi NEO4 (nanopi-neo4-rk3399)
68 - Google Bob (chromebook_bob)
Marty E. Plummer6d36e922021-12-24 16:43:46 +030069 - Google Kevin (chromebook_kevin)
Walter Lozano22186f32020-05-22 11:14:55 -030070 - Khadas Edge (khadas-edge-rk3399)
71 - Khadas Edge-Captain (khadas-edge-captain-rk3399)
72 - Khadas Edge-V (hadas-edge-v-rk3399)
73 - Orange Pi RK3399 (orangepi-rk3399)
74 - Pine64 RockPro64 (rockpro64-rk3399)
75 - Radxa ROCK Pi 4 (rock-pi-4-rk3399)
76 - Rockchip Evb-RK3399 (evb_rk3399)
77 - Theobroma Systems RK3399-Q7 SoM - Puma (puma_rk3399)
Walter Lozanocbd75f62020-05-22 11:14:56 -030078* rv1108
79 - Rockchip Evb-rv1108 (evb-rv1108)
80 - Elgin-R1 (elgin-rv1108)
Jagan Teki338b86c2020-01-10 00:16:22 +053081
82Building
83--------
84
85TF-A
86^^^^
87
88TF-A would require to build for ARM64 Rockchip SoCs platforms.
89
90To build TF-A::
91
92 git clone https://github.com/ARM-software/arm-trusted-firmware.git
93 cd arm-trusted-firmware
94 make realclean
95 make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399
96
Johan Jonker3ad88ec2021-08-20 19:27:59 +020097Specify the PLAT= with desired Rockchip platform to build TF-A for.
Jagan Teki338b86c2020-01-10 00:16:22 +053098
99U-Boot
100^^^^^^
101
102To build rk3328 boards::
103
104 export BL31=/path/to/arm-trusted-firmware/to/bl31.elf
105 make evb-rk3328_defconfig
106 make
107
108To build rk3288 boards::
109
110 make evb-rk3288_defconfig
111 make
112
113To build rk3368 boards::
114
115 export BL31=/path/to/arm-trusted-firmware/to/bl31.elf
116 make evb-px5_defconfig
117 make
118
119To build rk3399 boards::
120
121 export BL31=/path/to/arm-trusted-firmware/to/bl31.elf
122 make evb-rk3399_defconfig
123 make
124
125Flashing
126--------
127
Jagan Teki43ed7a02020-10-28 19:03:48 +05301281. Package the image with U-Boot TPL/SPL
129-----------------------------------------
130
Jagan Teki338b86c2020-01-10 00:16:22 +0530131SD Card
132^^^^^^^
133
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200134All Rockchip platforms, except rk3128 (which doesn't use SPL) are now
Jagan Teki338b86c2020-01-10 00:16:22 +0530135supporting single boot image using binman and pad_cat.
136
137To write an image that boots from an SD card (assumed to be /dev/sda)::
138
139 sudo dd if=u-boot-rockchip.bin of=/dev/sda seek=64
140 sync
141
Jagan Teki7e013632020-05-24 23:02:13 +0530142eMMC
143^^^^
144
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200145eMMC flash would probe on mmc0 in most of the Rockchip platforms.
Jagan Teki7e013632020-05-24 23:02:13 +0530146
147Create GPT partition layout as defined in configurations::
148
149 mmc dev 0
150 gpt write mmc 0 $partitions
151
152Connect the USB-OTG cable between host and target device.
153
154Launch fastboot at target::
155
156 fastboot 0
157
158Upon successful gadget connection,host show the USB device like::
159
160 lsusb
161 Bus 001 Device 020: ID 2207:330c Fuzhou Rockchip Electronics Company RK3399 in Mask ROM mode
162
163Program the flash::
164
165 sudo fastboot -i 0x2207 flash loader1 idbloader.img
166 sudo fastboot -i 0x2207 flash loader2 u-boot.itb
167
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200168Note: for Rockchip 32-bit platforms the U-Boot proper image
Jagan Teki7e013632020-05-24 23:02:13 +0530169is u-boot-dtb.img
170
Jagan Tekidd397602020-06-04 20:21:41 +0530171SPI
172^^^
173
174Generating idbloader for SPI boot would require to input a multi image
175image format to mkimage tool instead of concerting (like for MMC boot).
176
177SPL-alone SPI boot image::
178
179 ./tools/mkimage -n rk3399 -T rkspi -d spl/u-boot-spl.bin idbloader.img
180
181TPL+SPL SPI boot image::
182
183 ./tools/mkimage -n rk3399 -T rkspi -d tpl/u-boot-tpl.bin:spl/u-boot-spl.bin idbloader.img
184
185Copy SPI boot images into SD card and boot from SD::
186
187 sf probe
188 load mmc 1:1 $kernel_addr_r idbloader.img
189 sf erase 0 +$filesize
190 sf write $kernel_addr_r 0 ${filesize}
191 load mmc 1:1 ${kernel_addr_r} u-boot.itb
192 sf erase 0x60000 +$filesize
193 sf write $kernel_addr_r 0x60000 ${filesize}
194
Jagan Teki43ed7a02020-10-28 19:03:48 +05301952. Package the image with Rockchip miniloader
196---------------------------------------------
197
198Image package with Rockchip miniloader requires robin [1].
199
200Create idbloader.img
201
202.. code-block:: none
203
204 cd u-boot
205 ./tools/mkimage -n px30 -T rksd -d rkbin/bin/rk33/px30_ddr_333MHz_v1.15.bin idbloader.img
206 cat rkbin/bin/rk33/px30_miniloader_v1.22.bin >> idbloader.img
207 sudo dd if=idbloader.img of=/dev/sda seek=64
208
209Create trust.img
210
211.. code-block:: none
212
213 cd rkbin
214 ./tools/trust_merger RKTRUST/PX30TRUST.ini
215 sudo dd if=trust.img of=/dev/sda seek=24576
216
217Create uboot.img
218
219.. code-block:: none
220
221 rbink/tools/loaderimage --pack --uboot u-boot-dtb.bin uboot.img 0x200000
222 sudo dd if=uboot.img of=/dev/sda seek=16384
223
224Note:
2251. 0x200000 is load address and it's an optional in some platforms.
2262. rkbin binaries are kept on updating, so would recommend to use the latest versions.
227
Jagan Teki338b86c2020-01-10 00:16:22 +0530228TODO
229----
230
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200231- Add Rockchip idbloader image building
232- Add Rockchip TPL image building
Jagan Teki338b86c2020-01-10 00:16:22 +0530233- Document SPI flash boot
Jagan Teki338b86c2020-01-10 00:16:22 +0530234- Add missing SoC's with it boards list
235
Jagan Teki43ed7a02020-10-28 19:03:48 +0530236[1] https://github.com/rockchip-linux/rkbin
237
Jagan Teki338b86c2020-01-10 00:16:22 +0530238.. Jagan Teki <jagan@amarulasolutions.com>
Jagan Teki43ed7a02020-10-28 19:03:48 +0530239.. Wednesday 28 October 2020 06:47:26 PM IST