blob: 8b332c2e77c2ea9c72ac2c86e186b6e1a4861fc7 [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
Johan Jonkered33f8c2022-04-16 17:09:50 +020016Rockchip is a SoC solutions provider for tablets & PCs, streaming media
Jagan Teki338b86c2020-01-10 00:16:22 +053017TV 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
Johan Jonker0c99c6e2022-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)
Walter Lozanocbd75f62020-05-22 11:14:56 -030030* rk3036
31 - Rockchip Evb-RK3036 (evb-rk3036)
32 - Kylin (kylin_rk3036)
Johan Jonkerc57677b2022-04-16 17:09:52 +020033* rk3066
34 - Rikomagic MK808 (mk808)
Walter Lozanocbd75f62020-05-22 11:14:56 -030035* rk3128
36 - Rockchip Evb-RK3128 (evb-rk3128)
Johan Jonker734dcdc2021-08-20 19:27:58 +020037* rk3188
38 - Radxa Rock (rock)
Walter Lozanocbd75f62020-05-22 11:14:56 -030039* rk3229
40 - Rockchip Evb-RK3229 (evb-rk3229)
Jagan Teki338b86c2020-01-10 00:16:22 +053041* rk3288
Walter Lozano22186f32020-05-22 11:14:55 -030042 - Rockchip Evb-RK3288 (evb-rk3288)
43 - Firefly-RK3288 (firefly-rk3288)
44 - MQmaker MiQi (miqi-rk3288)
45 - Phytec RK3288 PCM-947 (phycore-rk3288)
46 - PopMetal-RK3288 (popmetal-rk3288)
47 - Radxa Rock 2 Square (rock2)
48 - Tinker-RK3288 (tinker-rk3288)
49 - Google Jerry (chromebook_jerry)
50 - Google Mickey (chromebook_mickey)
51 - Google Minnie (chromebook_minnie)
52 - Google Speedy (chromebook_speedy)
53 - Amarula Vyasa-RK3288 (vyasa-rk3288)
Walter Lozanocbd75f62020-05-22 11:14:56 -030054* rk3308
55 - Rockchip Evb-RK3308 (evb-rk3308)
56 - Roc-cc-RK3308 (roc-cc-rk3308)
Johan Jonker0c99c6e2022-04-16 17:09:51 +020057* rk3326
58 - ODROID-GO Advance (odroid-go2)
Jagan Teki338b86c2020-01-10 00:16:22 +053059* rk3328
Walter Lozano22186f32020-05-22 11:14:55 -030060 - Rockchip Evb-RK3328 (evb-rk3328)
61 - Pine64 Rock64 (rock64-rk3328)
Walter Lozanocbd75f62020-05-22 11:14:56 -030062 - Firefly-RK3328 (roc-cc-rk3328)
b.l.huangd9c34172020-06-01 00:02:11 +080063 - Radxa Rockpi E (rock-pi-e-rk3328)
Jagan Teki338b86c2020-01-10 00:16:22 +053064* rk3368
Walter Lozano22186f32020-05-22 11:14:55 -030065 - GeekBox (geekbox)
66 - PX5 EVB (evb-px5)
67 - Rockchip Sheep (sheep-rk3368)
68 - Theobroma Systems RK3368-uQ7 SoM - Lion (lion-rk3368)
Jagan Teki338b86c2020-01-10 00:16:22 +053069* rk3399
Walter Lozano22186f32020-05-22 11:14:55 -030070 - 96boards RK3399 Ficus (ficus-rk3399)
71 - 96boards Rock960 (rock960-rk3399)
72 - Firefly-RK3399 (firefly_rk3399)
73 - Firefly ROC-RK3399-PC
74 - FriendlyElec NanoPC-T4 (nanopc-t4-rk3399)
75 - FriendlyElec NanoPi M4 (nanopi-m4-rk3399)
Alexandre Vicenzia99d70c2021-03-26 13:37:10 +010076 - FriendlyElec NanoPi M4B (nanopi-m4b-rk3399)
Walter Lozano22186f32020-05-22 11:14:55 -030077 - FriendlyARM NanoPi NEO4 (nanopi-neo4-rk3399)
78 - Google Bob (chromebook_bob)
Marty E. Plummer6d36e922021-12-24 16:43:46 +030079 - Google Kevin (chromebook_kevin)
Walter Lozano22186f32020-05-22 11:14:55 -030080 - Khadas Edge (khadas-edge-rk3399)
81 - Khadas Edge-Captain (khadas-edge-captain-rk3399)
82 - Khadas Edge-V (hadas-edge-v-rk3399)
83 - Orange Pi RK3399 (orangepi-rk3399)
84 - Pine64 RockPro64 (rockpro64-rk3399)
85 - Radxa ROCK Pi 4 (rock-pi-4-rk3399)
86 - Rockchip Evb-RK3399 (evb_rk3399)
87 - Theobroma Systems RK3399-Q7 SoM - Puma (puma_rk3399)
Walter Lozanocbd75f62020-05-22 11:14:56 -030088* rv1108
89 - Rockchip Evb-rv1108 (evb-rv1108)
90 - Elgin-R1 (elgin-rv1108)
Jagan Teki338b86c2020-01-10 00:16:22 +053091
Jagan Tekib8f1ca92022-12-14 23:21:11 +053092* rv1126
93 - Edgeble Neural Compute Module 2 SoM - Neu2/Neu2k (neu2-io-r1126)
94
Jagan Teki338b86c2020-01-10 00:16:22 +053095Building
96--------
97
98TF-A
99^^^^
100
Johan Jonkered33f8c2022-04-16 17:09:50 +0200101TF-A is required when building ARM64 Rockchip SoCs images.
Jagan Teki338b86c2020-01-10 00:16:22 +0530102
Johan Jonkered33f8c2022-04-16 17:09:50 +0200103To build TF-A:
Jagan Teki338b86c2020-01-10 00:16:22 +0530104
Johan Jonkered33f8c2022-04-16 17:09:50 +0200105.. code-block:: bash
106
107 git clone --depth 1 https://github.com/ARM-software/arm-trusted-firmware.git
Jagan Teki338b86c2020-01-10 00:16:22 +0530108 cd arm-trusted-firmware
109 make realclean
110 make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399
Johan Jonkered33f8c2022-04-16 17:09:50 +0200111 cd ..
Jagan Teki338b86c2020-01-10 00:16:22 +0530112
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200113Specify the PLAT= with desired Rockchip platform to build TF-A for.
Jagan Teki338b86c2020-01-10 00:16:22 +0530114
115U-Boot
116^^^^^^
117
Johan Jonkered33f8c2022-04-16 17:09:50 +0200118.. code-block:: bash
Jagan Teki338b86c2020-01-10 00:16:22 +0530119
Johan Jonkered33f8c2022-04-16 17:09:50 +0200120 git clone --depth 1 https://source.denx.de/u-boot/u-boot.git
121 cd u-boot
Jagan Teki338b86c2020-01-10 00:16:22 +0530122
Johan Jonker0c99c6e2022-04-16 17:09:51 +0200123To build px30 boards:
124
125.. code-block:: bash
126
127 export BL31=../arm-trusted-firmware/build/px30/release/bl31/bl31.elf
128 make evb-px30_defconfig
129 make CROSS_COMPILE=aarch64-linux-gnu-
130
Johan Jonkerc57677b2022-04-16 17:09:52 +0200131To build rk3066 boards:
132
133.. code-block:: bash
134
135 make mk808_defconfig
136 make CROSS_COMPILE=arm-linux-gnueabihf-
137
Johan Jonkered33f8c2022-04-16 17:09:50 +0200138To build rk3288 boards:
139
140.. code-block:: bash
Jagan Teki338b86c2020-01-10 00:16:22 +0530141
142 make evb-rk3288_defconfig
Johan Jonkered33f8c2022-04-16 17:09:50 +0200143 make CROSS_COMPILE=arm-linux-gnueabihf-
Jagan Teki338b86c2020-01-10 00:16:22 +0530144
Johan Jonkered33f8c2022-04-16 17:09:50 +0200145To build rk3328 boards:
Jagan Teki338b86c2020-01-10 00:16:22 +0530146
Johan Jonkered33f8c2022-04-16 17:09:50 +0200147.. code-block:: bash
148
149 export BL31=../arm-trusted-firmware/build/rk3328/release/bl31/bl31.elf
150 make evb-rk3328_defconfig
151 make CROSS_COMPILE=aarch64-linux-gnu-
152
153To build rk3368 boards:
154
155.. code-block:: bash
156
157 export BL31=../arm-trusted-firmware/build/rk3368/release/bl31/bl31.elf
Jagan Teki338b86c2020-01-10 00:16:22 +0530158 make evb-px5_defconfig
Johan Jonkered33f8c2022-04-16 17:09:50 +0200159 make CROSS_COMPILE=aarch64-linux-gnu-
Jagan Teki338b86c2020-01-10 00:16:22 +0530160
Johan Jonkered33f8c2022-04-16 17:09:50 +0200161To build rk3399 boards:
Jagan Teki338b86c2020-01-10 00:16:22 +0530162
Johan Jonkered33f8c2022-04-16 17:09:50 +0200163.. code-block:: bash
164
165 export BL31=../arm-trusted-firmware/build/rk3399/release/bl31/bl31.elf
Jagan Teki338b86c2020-01-10 00:16:22 +0530166 make evb-rk3399_defconfig
Johan Jonkered33f8c2022-04-16 17:09:50 +0200167 make CROSS_COMPILE=aarch64-linux-gnu-
Jagan Teki338b86c2020-01-10 00:16:22 +0530168
169Flashing
170--------
171
Jagan Teki43ed7a02020-10-28 19:03:48 +05301721. Package the image with U-Boot TPL/SPL
173-----------------------------------------
174
Jagan Teki338b86c2020-01-10 00:16:22 +0530175SD Card
176^^^^^^^
177
Johan Jonkered33f8c2022-04-16 17:09:50 +0200178All Rockchip platforms (except rk3128 which doesn't use SPL) are now
179supporting a single boot image using binman and pad_cat.
Jagan Teki338b86c2020-01-10 00:16:22 +0530180
Johan Jonkered33f8c2022-04-16 17:09:50 +0200181To write an image that boots from a SD card (assumed to be /dev/sda):
182
183.. code-block:: bash
Jagan Teki338b86c2020-01-10 00:16:22 +0530184
185 sudo dd if=u-boot-rockchip.bin of=/dev/sda seek=64
186 sync
187
Jagan Teki7e013632020-05-24 23:02:13 +0530188eMMC
189^^^^
190
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200191eMMC flash would probe on mmc0 in most of the Rockchip platforms.
Jagan Teki7e013632020-05-24 23:02:13 +0530192
Johan Jonkered33f8c2022-04-16 17:09:50 +0200193Create GPT partition layout as defined in $partitions:
194
195.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530196
197 mmc dev 0
198 gpt write mmc 0 $partitions
199
Johan Jonkered33f8c2022-04-16 17:09:50 +0200200Connect the USB-OTG cable between the host and a target device.
Jagan Teki7e013632020-05-24 23:02:13 +0530201
Johan Jonkered33f8c2022-04-16 17:09:50 +0200202Launch fastboot on the target with:
203
204.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530205
206 fastboot 0
207
Johan Jonkered33f8c2022-04-16 17:09:50 +0200208Upon a successful gadget connection the host shows the USB device with:
209
210.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530211
212 lsusb
Johan Jonkered33f8c2022-04-16 17:09:50 +0200213 # Bus 001 Device 020: ID 2207:330c Fuzhou Rockchip Electronics Company RK3399 in Mask ROM mode
Jagan Teki7e013632020-05-24 23:02:13 +0530214
Johan Jonkered33f8c2022-04-16 17:09:50 +0200215Program the flash with:
216
217.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530218
219 sudo fastboot -i 0x2207 flash loader1 idbloader.img
220 sudo fastboot -i 0x2207 flash loader2 u-boot.itb
221
Johan Jonkered33f8c2022-04-16 17:09:50 +0200222Note:
223
224For Rockchip 32-bit platforms the U-Boot proper image
Jagan Teki7e013632020-05-24 23:02:13 +0530225is u-boot-dtb.img
226
Jagan Tekidd397602020-06-04 20:21:41 +0530227SPI
228^^^
229
Johan Jonkered33f8c2022-04-16 17:09:50 +0200230The SPI boot method requires the generation of idbloader.img with help of the mkimage tool.
Jagan Tekidd397602020-06-04 20:21:41 +0530231
Johan Jonkered33f8c2022-04-16 17:09:50 +0200232SPL-alone SPI boot image:
233
234.. code-block:: bash
Jagan Tekidd397602020-06-04 20:21:41 +0530235
236 ./tools/mkimage -n rk3399 -T rkspi -d spl/u-boot-spl.bin idbloader.img
237
Johan Jonkered33f8c2022-04-16 17:09:50 +0200238TPL+SPL SPI boot image:
239
240.. code-block:: bash
Jagan Tekidd397602020-06-04 20:21:41 +0530241
242 ./tools/mkimage -n rk3399 -T rkspi -d tpl/u-boot-tpl.bin:spl/u-boot-spl.bin idbloader.img
243
Johan Jonkered33f8c2022-04-16 17:09:50 +0200244Copy SPI boot images into SD card and boot from SD:
245
246.. code-block:: bash
Jagan Tekidd397602020-06-04 20:21:41 +0530247
248 sf probe
249 load mmc 1:1 $kernel_addr_r idbloader.img
250 sf erase 0 +$filesize
251 sf write $kernel_addr_r 0 ${filesize}
252 load mmc 1:1 ${kernel_addr_r} u-boot.itb
253 sf erase 0x60000 +$filesize
254 sf write $kernel_addr_r 0x60000 ${filesize}
255
Jagan Teki43ed7a02020-10-28 19:03:48 +05302562. Package the image with Rockchip miniloader
257---------------------------------------------
258
Johan Jonkered33f8c2022-04-16 17:09:50 +0200259Image package with Rockchip miniloader requires rkbin [1].
Jagan Teki43ed7a02020-10-28 19:03:48 +0530260
Johan Jonkered33f8c2022-04-16 17:09:50 +0200261.. code-block:: bash
Jagan Teki43ed7a02020-10-28 19:03:48 +0530262
Johan Jonkered33f8c2022-04-16 17:09:50 +0200263 cd ..
264 git clone --depth 1 https://github.com/rockchip-linux/rkbin
Jagan Teki43ed7a02020-10-28 19:03:48 +0530265
Johan Jonkered33f8c2022-04-16 17:09:50 +0200266Create idbloader.img:
Jagan Teki43ed7a02020-10-28 19:03:48 +0530267
Johan Jonkered33f8c2022-04-16 17:09:50 +0200268.. code-block:: bash
Jagan Teki43ed7a02020-10-28 19:03:48 +0530269
Johan Jonkered33f8c2022-04-16 17:09:50 +0200270 cd u-boot
271 ./tools/mkimage -n px30 -T rksd -d ../rkbin/bin/rk33/px30_ddr_333MHz_v1.16.bin idbloader.img
272 cat ../rkbin/bin/rk33/px30_miniloader_v1.31.bin >> idbloader.img
273 sudo dd if=idbloader.img of=/dev/sda seek=64
Jagan Teki43ed7a02020-10-28 19:03:48 +0530274
Johan Jonkered33f8c2022-04-16 17:09:50 +0200275Create trust.img:
Jagan Teki43ed7a02020-10-28 19:03:48 +0530276
Johan Jonkered33f8c2022-04-16 17:09:50 +0200277.. code-block:: bash
Jagan Teki43ed7a02020-10-28 19:03:48 +0530278
Johan Jonkered33f8c2022-04-16 17:09:50 +0200279 cd ../rkbin
280 ./tools/trust_merger RKTRUST/PX30TRUST.ini
281 sudo dd if=trust.img of=/dev/sda seek=24576
Jagan Teki43ed7a02020-10-28 19:03:48 +0530282
Johan Jonkered33f8c2022-04-16 17:09:50 +0200283Create uboot.img [2]:
284
285.. code-block:: bash
286
287 cd ../u-boot
288 ../rkbin/tools/loaderimage --pack --uboot u-boot-dtb.bin uboot.img 0x200000
289 sudo dd if=uboot.img of=/dev/sda seek=16384
Jagan Teki43ed7a02020-10-28 19:03:48 +0530290
291Note:
Johan Jonkered33f8c2022-04-16 17:09:50 +0200292
2931. rkbin binaries are regularly updated, so it would be recommended to use the latest version.
2942. 0x200000 is a load address and is an option for some platforms.
Jagan Teki43ed7a02020-10-28 19:03:48 +0530295
Johan Jonkerc57677b2022-04-16 17:09:52 +02002963. Package the RK3066 image with U-Boot TPL/SPL on NAND
297-------------------------------------------------------
298
299Unlike later SoC models the rk3066 BootROM doesn't have SDMMC support.
300If all other boot options fail then it enters into a BootROM mode on the USB OTG port.
301This method loads TPL/SPL on NAND with U-boot and kernel on SD card.
302
303SD Card
304^^^^^^^
305
306U-boot expects a GPT partition map and a boot directory structure with files on the SD card.
307
308.. code-block:: none
309
310 Partition Map for MMC device 0 -- Partition Type: EFI
311 Part Start LBA End LBA Name
312 1 0x00000040 0x00001f7f "loader1"
313 2 0x00004000 0x00005fff "loader2"
314 3 0x00006000 0x00007fff "trust"
315 4 0x00008000 0x0003ffff "boot"
316 5 0x00040000 0x00ed7fde "rootfs"
317
318Make sure boot and esp flag are set for the boot partition.
319Loader1 partition is not used by RK3066.
320
321Boot partition:
322
323.. code-block:: none
324
325 extlinux
326 extlinux.conf
327
328 zImage
329 rk3066a-mk808.dtb
330
331To write a U-boot image to the SD card (assumed to be /dev/sda):
332
333.. code-block:: bash
334
335 sudo dd if=u-boot-dtb.img of=/dev/sda seek=16384
336 sync
337
338NAND
339^^^^
340
341Bring device in BootROM mode:
342
343If bricked and no BootROM mode shows up then connect pin 8 and 9 of the NAND flash
344with a needle while reconnecting to the USB OTG port to a PC.
345
346Show connected devices with:
347
348.. code-block:: bash
349
350 lsusb
351 # Bus 001 Device 004: ID 2207:300a Fuzhou Rockchip Electronics Company RK3066 in Mask ROM mode
352
353
354Create NAND image:
355
356Size of SPL and TPL must be aligned to 2kb.
357
358Program with commands in a bash script ./flash.sh:
359
360.. code-block:: bash
361
362 #!/bin/sh
363
364 printf "RK30" > tplspl.bin
365 dd if=u-boot-tpl.bin >> tplspl.bin
366 truncate -s %2048 tplspl.bin
367 truncate -s %2048 u-boot-spl.bin
368 ../tools/boot_merger --verbose config-flash.ini
369 ../tools/upgrade_tool ul ./RK30xxLoader_uboot.bin
370
371config-flash.ini:
372
373.. code-block:: none
374
375 [CHIP_NAME]
376 NAME=RK30
377 [VERSION]
378 MAJOR=2
379 MINOR=21
380 [CODE471_OPTION]
381 NUM=1
382 Path1=30_LPDDR2_300MHz_DD.bin
383 [CODE472_OPTION]
384 NUM=1
385 Path1=rk30usbplug.bin
386 [LOADER_OPTION]
387 NUM=2
388 LOADER1=FlashData
389 LOADER2=FlashBoot
390 FlashData=tplspl.bin
391 FlashBoot=u-boot-spl.bin
392 [OUTPUT]
393 PATH=RK30xxLoader_uboot.bin
394
Jagan Teki338b86c2020-01-10 00:16:22 +0530395TODO
396----
397
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200398- Add Rockchip idbloader image building
399- Add Rockchip TPL image building
Jagan Teki338b86c2020-01-10 00:16:22 +0530400- Document SPI flash boot
Jagan Teki338b86c2020-01-10 00:16:22 +0530401- Add missing SoC's with it boards list
402
403.. Jagan Teki <jagan@amarulasolutions.com>
Jagan Teki43ed7a02020-10-28 19:03:48 +0530404.. Wednesday 28 October 2020 06:47:26 PM IST