blob: a21399c88e1dda05608f301b639843b46647d0e7 [file] [log] [blame]
Jagan Tekid0a440c2020-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
Johan Jonker7937f522022-04-16 17:09:50 +020016Rockchip is a SoC solutions provider for tablets & PCs, streaming media
Jagan Tekid0a440c2020-01-10 00:16:22 +053017TV boxes, AI audio & vision, IoT hardware.
18
Johan Jonker5bf651e2021-08-20 19:27:59 +020019A wide range of Rockchip SoCs with associated boards are supported in
Jagan Tekid0a440c2020-01-10 00:16:22 +053020mainline U-Boot.
21
Johan Jonker5bf651e2021-08-20 19:27:59 +020022List of mainline supported Rockchip boards:
Jagan Tekid0a440c2020-01-10 00:16:22 +053023
Johan Jonker46d609b2022-04-16 17:09:51 +020024* px30
25 - Rockchip Evb-PX30 (evb-px30)
26 - Engicam PX30.Core C.TOUCH 2.0 (px30-core-ctouch2-px30)
27 - Engicam PX30.Core C.TOUCH 2.0 10.1 (px30-core-ctouch2-of10-px30)
28 - Engicam PX30.Core EDIMM2.2 Starter Kit (px30-core-edimm2.2-px30)
29 - Firefly Core-PX30-JD4 (firefly-px30)
Quentin Schulz00a6f602023-01-09 11:36:45 +010030 - Theobroma Systems PX30-µQ7 SoM - Ringneck (ringneck-px30)
Walter Lozanocddcd972020-05-22 11:14:56 -030031* rk3036
32 - Rockchip Evb-RK3036 (evb-rk3036)
33 - Kylin (kylin_rk3036)
Johan Jonker114b6ce2022-04-16 17:09:52 +020034* rk3066
35 - Rikomagic MK808 (mk808)
Walter Lozanocddcd972020-05-22 11:14:56 -030036* rk3128
37 - Rockchip Evb-RK3128 (evb-rk3128)
Johan Jonkere8a74732021-08-20 19:27:58 +020038* rk3188
39 - Radxa Rock (rock)
Walter Lozanocddcd972020-05-22 11:14:56 -030040* rk3229
41 - Rockchip Evb-RK3229 (evb-rk3229)
Jagan Tekid0a440c2020-01-10 00:16:22 +053042* rk3288
Walter Lozanocb17ffd2020-05-22 11:14:55 -030043 - Rockchip Evb-RK3288 (evb-rk3288)
44 - Firefly-RK3288 (firefly-rk3288)
45 - MQmaker MiQi (miqi-rk3288)
46 - Phytec RK3288 PCM-947 (phycore-rk3288)
47 - PopMetal-RK3288 (popmetal-rk3288)
48 - Radxa Rock 2 Square (rock2)
49 - Tinker-RK3288 (tinker-rk3288)
50 - Google Jerry (chromebook_jerry)
51 - Google Mickey (chromebook_mickey)
52 - Google Minnie (chromebook_minnie)
53 - Google Speedy (chromebook_speedy)
54 - Amarula Vyasa-RK3288 (vyasa-rk3288)
Walter Lozanocddcd972020-05-22 11:14:56 -030055* rk3308
56 - Rockchip Evb-RK3308 (evb-rk3308)
57 - Roc-cc-RK3308 (roc-cc-rk3308)
Johan Jonker46d609b2022-04-16 17:09:51 +020058* rk3326
59 - ODROID-GO Advance (odroid-go2)
Jagan Tekid0a440c2020-01-10 00:16:22 +053060* rk3328
Walter Lozanocb17ffd2020-05-22 11:14:55 -030061 - Rockchip Evb-RK3328 (evb-rk3328)
62 - Pine64 Rock64 (rock64-rk3328)
Walter Lozanocddcd972020-05-22 11:14:56 -030063 - Firefly-RK3328 (roc-cc-rk3328)
b.l.huanga2793c42020-06-01 00:02:11 +080064 - Radxa Rockpi E (rock-pi-e-rk3328)
Jagan Tekid0a440c2020-01-10 00:16:22 +053065* rk3368
Walter Lozanocb17ffd2020-05-22 11:14:55 -030066 - GeekBox (geekbox)
67 - PX5 EVB (evb-px5)
68 - Rockchip Sheep (sheep-rk3368)
69 - Theobroma Systems RK3368-uQ7 SoM - Lion (lion-rk3368)
Jagan Tekid0a440c2020-01-10 00:16:22 +053070* rk3399
Walter Lozanocb17ffd2020-05-22 11:14:55 -030071 - 96boards RK3399 Ficus (ficus-rk3399)
72 - 96boards Rock960 (rock960-rk3399)
73 - Firefly-RK3399 (firefly_rk3399)
74 - Firefly ROC-RK3399-PC
75 - FriendlyElec NanoPC-T4 (nanopc-t4-rk3399)
76 - FriendlyElec NanoPi M4 (nanopi-m4-rk3399)
Alexandre Vicenzibc592bd2021-03-26 13:37:10 +010077 - FriendlyElec NanoPi M4B (nanopi-m4b-rk3399)
Walter Lozanocb17ffd2020-05-22 11:14:55 -030078 - FriendlyARM NanoPi NEO4 (nanopi-neo4-rk3399)
79 - Google Bob (chromebook_bob)
Marty E. Plummerb20a8dac2021-12-24 16:43:46 +030080 - Google Kevin (chromebook_kevin)
Walter Lozanocb17ffd2020-05-22 11:14:55 -030081 - Khadas Edge (khadas-edge-rk3399)
82 - Khadas Edge-Captain (khadas-edge-captain-rk3399)
83 - Khadas Edge-V (hadas-edge-v-rk3399)
84 - Orange Pi RK3399 (orangepi-rk3399)
85 - Pine64 RockPro64 (rockpro64-rk3399)
86 - Radxa ROCK Pi 4 (rock-pi-4-rk3399)
87 - Rockchip Evb-RK3399 (evb_rk3399)
88 - Theobroma Systems RK3399-Q7 SoM - Puma (puma_rk3399)
Jagan Teki91dc9f62023-01-30 20:27:49 +053089
Chris Morgan8c4e3042023-04-21 10:59:19 -050090* rk3566
91 - Anbernic RGxx3 (rgxx3-rk3566)
92
Jonas Karlman38ad6c92023-02-25 19:01:34 +000093* rk3568
94 - Rockchip Evb-RK3568 (evb-rk3568)
Jagan Teki91dc9f62023-01-30 20:27:49 +053095
96* rk3588
Kever Yange25c0452023-03-02 15:12:57 +080097 - Rockchip EVB (evb-rk3588)
Jagan Teki91dc9f62023-01-30 20:27:49 +053098 - Edgeble Neural Compute Module 6 SoM - Neu6a (neu6a-io-rk3588)
Eugen Hristev32f36cf2023-02-22 11:05:12 +020099 - Radxa ROCK 5B (rock5b-rk3588)
Jagan Teki91dc9f62023-01-30 20:27:49 +0530100
Walter Lozanocddcd972020-05-22 11:14:56 -0300101* rv1108
102 - Rockchip Evb-rv1108 (evb-rv1108)
103 - Elgin-R1 (elgin-rv1108)
Jagan Tekid0a440c2020-01-10 00:16:22 +0530104
Jagan Teki1db421e2022-12-14 23:21:11 +0530105* rv1126
106 - Edgeble Neural Compute Module 2 SoM - Neu2/Neu2k (neu2-io-r1126)
107
Jagan Tekid0a440c2020-01-10 00:16:22 +0530108Building
109--------
110
111TF-A
112^^^^
113
Johan Jonker7937f522022-04-16 17:09:50 +0200114TF-A is required when building ARM64 Rockchip SoCs images.
Jagan Tekid0a440c2020-01-10 00:16:22 +0530115
Johan Jonker7937f522022-04-16 17:09:50 +0200116To build TF-A:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530117
Johan Jonker7937f522022-04-16 17:09:50 +0200118.. code-block:: bash
119
120 git clone --depth 1 https://github.com/ARM-software/arm-trusted-firmware.git
Jagan Tekid0a440c2020-01-10 00:16:22 +0530121 cd arm-trusted-firmware
122 make realclean
123 make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399
Johan Jonker7937f522022-04-16 17:09:50 +0200124 cd ..
Jagan Tekid0a440c2020-01-10 00:16:22 +0530125
Johan Jonker5bf651e2021-08-20 19:27:59 +0200126Specify the PLAT= with desired Rockchip platform to build TF-A for.
Jagan Tekid0a440c2020-01-10 00:16:22 +0530127
128U-Boot
129^^^^^^
130
Johan Jonker7937f522022-04-16 17:09:50 +0200131.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530132
Johan Jonker7937f522022-04-16 17:09:50 +0200133 git clone --depth 1 https://source.denx.de/u-boot/u-boot.git
134 cd u-boot
135
Johan Jonker46d609b2022-04-16 17:09:51 +0200136To build px30 boards:
137
138.. code-block:: bash
139
140 export BL31=../arm-trusted-firmware/build/px30/release/bl31/bl31.elf
141 make evb-px30_defconfig
142 make CROSS_COMPILE=aarch64-linux-gnu-
143
Johan Jonker114b6ce2022-04-16 17:09:52 +0200144To build rk3066 boards:
145
146.. code-block:: bash
147
148 make mk808_defconfig
149 make CROSS_COMPILE=arm-linux-gnueabihf-
150
Johan Jonker7937f522022-04-16 17:09:50 +0200151To build rk3288 boards:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530152
Johan Jonker7937f522022-04-16 17:09:50 +0200153.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530154
155 make evb-rk3288_defconfig
Johan Jonker7937f522022-04-16 17:09:50 +0200156 make CROSS_COMPILE=arm-linux-gnueabihf-
157
158To build rk3328 boards:
159
160.. code-block:: bash
161
162 export BL31=../arm-trusted-firmware/build/rk3328/release/bl31/bl31.elf
163 make evb-rk3328_defconfig
164 make CROSS_COMPILE=aarch64-linux-gnu-
165
166To build rk3368 boards:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530167
Johan Jonker7937f522022-04-16 17:09:50 +0200168.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530169
Johan Jonker7937f522022-04-16 17:09:50 +0200170 export BL31=../arm-trusted-firmware/build/rk3368/release/bl31/bl31.elf
Jagan Tekid0a440c2020-01-10 00:16:22 +0530171 make evb-px5_defconfig
Johan Jonker7937f522022-04-16 17:09:50 +0200172 make CROSS_COMPILE=aarch64-linux-gnu-
173
174To build rk3399 boards:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530175
Johan Jonker7937f522022-04-16 17:09:50 +0200176.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530177
Johan Jonker7937f522022-04-16 17:09:50 +0200178 export BL31=../arm-trusted-firmware/build/rk3399/release/bl31/bl31.elf
Jagan Tekid0a440c2020-01-10 00:16:22 +0530179 make evb-rk3399_defconfig
Johan Jonker7937f522022-04-16 17:09:50 +0200180 make CROSS_COMPILE=aarch64-linux-gnu-
Jagan Tekid0a440c2020-01-10 00:16:22 +0530181
Jonas Karlman38ad6c92023-02-25 19:01:34 +0000182To build rk3568 boards:
183
184.. code-block:: bash
185
Chris Morganf439d1b2023-02-13 16:27:42 -0600186 export BL31=../arm-trusted-firmware/build/rk3568/release/bl31/bl31.elf
187 [or]export BL31=../rkbin/bin/rk35/rk3568_bl31_v1.34.elf
Jonas Karlman38ad6c92023-02-25 19:01:34 +0000188 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3568_ddr_1560MHz_v1.13.bin
189 make evb-rk3568_defconfig
190 make CROSS_COMPILE=aarch64-linux-gnu-
191
Kever Yange25c0452023-03-02 15:12:57 +0800192To build rk3588 boards:
193
194.. code-block:: bash
195
196 export BL31=../rkbin/bin/rk35/rk3588_bl31_v1.33.elf
197 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3588_ddr_lp4_2112MHz_lp5_2736MHz_v1.09.bin
198 make evb-rk3588_defconfig
199 make CROSS_COMPILE=aarch64-linux-gnu-
200
Jagan Tekid0a440c2020-01-10 00:16:22 +0530201Flashing
202--------
203
Jagan Tekiefe8a882020-10-28 19:03:48 +05302041. Package the image with U-Boot TPL/SPL
205-----------------------------------------
206
Jagan Tekid0a440c2020-01-10 00:16:22 +0530207SD Card
208^^^^^^^
209
Johan Jonker7937f522022-04-16 17:09:50 +0200210All Rockchip platforms (except rk3128 which doesn't use SPL) are now
211supporting a single boot image using binman and pad_cat.
Jagan Tekid0a440c2020-01-10 00:16:22 +0530212
Johan Jonker7937f522022-04-16 17:09:50 +0200213To write an image that boots from a SD card (assumed to be /dev/sda):
214
215.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530216
217 sudo dd if=u-boot-rockchip.bin of=/dev/sda seek=64
218 sync
219
Jagan Teki48b9fb02020-05-24 23:02:13 +0530220eMMC
221^^^^
222
Johan Jonker5bf651e2021-08-20 19:27:59 +0200223eMMC flash would probe on mmc0 in most of the Rockchip platforms.
Jagan Teki48b9fb02020-05-24 23:02:13 +0530224
Johan Jonker7937f522022-04-16 17:09:50 +0200225Create GPT partition layout as defined in $partitions:
226
227.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530228
229 mmc dev 0
230 gpt write mmc 0 $partitions
231
Johan Jonker7937f522022-04-16 17:09:50 +0200232Connect the USB-OTG cable between the host and a target device.
Jagan Teki48b9fb02020-05-24 23:02:13 +0530233
Johan Jonker7937f522022-04-16 17:09:50 +0200234Launch fastboot on the target with:
235
236.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530237
238 fastboot 0
239
Johan Jonker7937f522022-04-16 17:09:50 +0200240Upon a successful gadget connection the host shows the USB device with:
241
242.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530243
244 lsusb
Johan Jonker7937f522022-04-16 17:09:50 +0200245 # Bus 001 Device 020: ID 2207:330c Fuzhou Rockchip Electronics Company RK3399 in Mask ROM mode
Jagan Teki48b9fb02020-05-24 23:02:13 +0530246
Johan Jonker7937f522022-04-16 17:09:50 +0200247Program the flash with:
248
249.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530250
251 sudo fastboot -i 0x2207 flash loader1 idbloader.img
252 sudo fastboot -i 0x2207 flash loader2 u-boot.itb
253
Johan Jonker7937f522022-04-16 17:09:50 +0200254Note:
255
256For Rockchip 32-bit platforms the U-Boot proper image
Jagan Teki48b9fb02020-05-24 23:02:13 +0530257is u-boot-dtb.img
258
Jagan Teki1a262832020-06-04 20:21:41 +0530259SPI
260^^^
261
Johan Jonker7937f522022-04-16 17:09:50 +0200262The SPI boot method requires the generation of idbloader.img with help of the mkimage tool.
Jagan Teki1a262832020-06-04 20:21:41 +0530263
Johan Jonker7937f522022-04-16 17:09:50 +0200264SPL-alone SPI boot image:
265
266.. code-block:: bash
Jagan Teki1a262832020-06-04 20:21:41 +0530267
268 ./tools/mkimage -n rk3399 -T rkspi -d spl/u-boot-spl.bin idbloader.img
269
Johan Jonker7937f522022-04-16 17:09:50 +0200270TPL+SPL SPI boot image:
271
272.. code-block:: bash
Jagan Teki1a262832020-06-04 20:21:41 +0530273
274 ./tools/mkimage -n rk3399 -T rkspi -d tpl/u-boot-tpl.bin:spl/u-boot-spl.bin idbloader.img
275
Johan Jonker7937f522022-04-16 17:09:50 +0200276Copy SPI boot images into SD card and boot from SD:
277
278.. code-block:: bash
Jagan Teki1a262832020-06-04 20:21:41 +0530279
280 sf probe
281 load mmc 1:1 $kernel_addr_r idbloader.img
282 sf erase 0 +$filesize
283 sf write $kernel_addr_r 0 ${filesize}
284 load mmc 1:1 ${kernel_addr_r} u-boot.itb
285 sf erase 0x60000 +$filesize
286 sf write $kernel_addr_r 0x60000 ${filesize}
287
Jagan Tekiefe8a882020-10-28 19:03:48 +05302882. Package the image with Rockchip miniloader
289---------------------------------------------
290
Johan Jonker7937f522022-04-16 17:09:50 +0200291Image package with Rockchip miniloader requires rkbin [1].
292
293.. code-block:: bash
Jagan Tekiefe8a882020-10-28 19:03:48 +0530294
Johan Jonker7937f522022-04-16 17:09:50 +0200295 cd ..
296 git clone --depth 1 https://github.com/rockchip-linux/rkbin
Jagan Tekiefe8a882020-10-28 19:03:48 +0530297
Johan Jonker7937f522022-04-16 17:09:50 +0200298Create idbloader.img:
Jagan Tekiefe8a882020-10-28 19:03:48 +0530299
Johan Jonker7937f522022-04-16 17:09:50 +0200300.. code-block:: bash
Jagan Tekiefe8a882020-10-28 19:03:48 +0530301
Johan Jonker7937f522022-04-16 17:09:50 +0200302 cd u-boot
303 ./tools/mkimage -n px30 -T rksd -d ../rkbin/bin/rk33/px30_ddr_333MHz_v1.16.bin idbloader.img
304 cat ../rkbin/bin/rk33/px30_miniloader_v1.31.bin >> idbloader.img
305 sudo dd if=idbloader.img of=/dev/sda seek=64
Jagan Tekiefe8a882020-10-28 19:03:48 +0530306
Johan Jonker7937f522022-04-16 17:09:50 +0200307Create trust.img:
Jagan Tekiefe8a882020-10-28 19:03:48 +0530308
Johan Jonker7937f522022-04-16 17:09:50 +0200309.. code-block:: bash
Jagan Tekiefe8a882020-10-28 19:03:48 +0530310
Johan Jonker7937f522022-04-16 17:09:50 +0200311 cd ../rkbin
312 ./tools/trust_merger RKTRUST/PX30TRUST.ini
313 sudo dd if=trust.img of=/dev/sda seek=24576
Jagan Tekiefe8a882020-10-28 19:03:48 +0530314
Johan Jonker7937f522022-04-16 17:09:50 +0200315Create uboot.img [2]:
Jagan Tekiefe8a882020-10-28 19:03:48 +0530316
Johan Jonker7937f522022-04-16 17:09:50 +0200317.. code-block:: bash
318
319 cd ../u-boot
320 ../rkbin/tools/loaderimage --pack --uboot u-boot-dtb.bin uboot.img 0x200000
321 sudo dd if=uboot.img of=/dev/sda seek=16384
Jagan Tekiefe8a882020-10-28 19:03:48 +0530322
323Note:
Johan Jonker7937f522022-04-16 17:09:50 +0200324
3251. rkbin binaries are regularly updated, so it would be recommended to use the latest version.
3262. 0x200000 is a load address and is an option for some platforms.
Jagan Tekiefe8a882020-10-28 19:03:48 +0530327
Johan Jonker114b6ce2022-04-16 17:09:52 +02003283. Package the RK3066 image with U-Boot TPL/SPL on NAND
329-------------------------------------------------------
330
331Unlike later SoC models the rk3066 BootROM doesn't have SDMMC support.
332If all other boot options fail then it enters into a BootROM mode on the USB OTG port.
333This method loads TPL/SPL on NAND with U-boot and kernel on SD card.
334
335SD Card
336^^^^^^^
337
338U-boot expects a GPT partition map and a boot directory structure with files on the SD card.
339
340.. code-block:: none
341
342 Partition Map for MMC device 0 -- Partition Type: EFI
343 Part Start LBA End LBA Name
344 1 0x00000040 0x00001f7f "loader1"
345 2 0x00004000 0x00005fff "loader2"
346 3 0x00006000 0x00007fff "trust"
347 4 0x00008000 0x0003ffff "boot"
348 5 0x00040000 0x00ed7fde "rootfs"
349
350Make sure boot and esp flag are set for the boot partition.
351Loader1 partition is not used by RK3066.
352
353Boot partition:
354
355.. code-block:: none
356
357 extlinux
358 extlinux.conf
359
360 zImage
361 rk3066a-mk808.dtb
362
363To write a U-boot image to the SD card (assumed to be /dev/sda):
364
365.. code-block:: bash
366
367 sudo dd if=u-boot-dtb.img of=/dev/sda seek=16384
368 sync
369
370NAND
371^^^^
372
373Bring device in BootROM mode:
374
375If bricked and no BootROM mode shows up then connect pin 8 and 9 of the NAND flash
376with a needle while reconnecting to the USB OTG port to a PC.
377
378Show connected devices with:
379
380.. code-block:: bash
381
382 lsusb
383 # Bus 001 Device 004: ID 2207:300a Fuzhou Rockchip Electronics Company RK3066 in Mask ROM mode
384
385
386Create NAND image:
387
388Size of SPL and TPL must be aligned to 2kb.
389
390Program with commands in a bash script ./flash.sh:
391
392.. code-block:: bash
393
394 #!/bin/sh
395
Johan Jonker7e0673d2023-03-19 16:06:11 +0100396 printf "RK30" | dd conv=notrunc bs=4 count=1 of=u-boot-tpl.bin
397 truncate -s %2048 u-boot-tpl.bin
Johan Jonker114b6ce2022-04-16 17:09:52 +0200398 truncate -s %2048 u-boot-spl.bin
399 ../tools/boot_merger --verbose config-flash.ini
400 ../tools/upgrade_tool ul ./RK30xxLoader_uboot.bin
401
402config-flash.ini:
403
404.. code-block:: none
405
406 [CHIP_NAME]
407 NAME=RK30
408 [VERSION]
409 MAJOR=2
410 MINOR=21
411 [CODE471_OPTION]
412 NUM=1
413 Path1=30_LPDDR2_300MHz_DD.bin
414 [CODE472_OPTION]
415 NUM=1
416 Path1=rk30usbplug.bin
417 [LOADER_OPTION]
418 NUM=2
419 LOADER1=FlashData
420 LOADER2=FlashBoot
Johan Jonker7e0673d2023-03-19 16:06:11 +0100421 FlashData=u-boot-tpl.bin
Johan Jonker114b6ce2022-04-16 17:09:52 +0200422 FlashBoot=u-boot-spl.bin
423 [OUTPUT]
424 PATH=RK30xxLoader_uboot.bin
425
Jagan Tekid0a440c2020-01-10 00:16:22 +0530426TODO
427----
428
Johan Jonker5bf651e2021-08-20 19:27:59 +0200429- Add Rockchip idbloader image building
430- Add Rockchip TPL image building
Jagan Tekid0a440c2020-01-10 00:16:22 +0530431- Document SPI flash boot
Jagan Tekid0a440c2020-01-10 00:16:22 +0530432- Add missing SoC's with it boards list
433
434.. Jagan Teki <jagan@amarulasolutions.com>
Jagan Tekiefe8a882020-10-28 19:03:48 +0530435.. Wednesday 28 October 2020 06:47:26 PM IST