blob: ffbebd0bb3da6ba2c9ca4ed9d67a6a4e342d1057 [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)
Quentin Schulzc925be72023-01-09 11:36:45 +010030 - Theobroma Systems PX30-µQ7 SoM - Ringneck (ringneck-px30)
Walter Lozanocbd75f62020-05-22 11:14:56 -030031* rk3036
32 - Rockchip Evb-RK3036 (evb-rk3036)
33 - Kylin (kylin_rk3036)
Johan Jonkerc57677b2022-04-16 17:09:52 +020034* rk3066
35 - Rikomagic MK808 (mk808)
Walter Lozanocbd75f62020-05-22 11:14:56 -030036* rk3128
37 - Rockchip Evb-RK3128 (evb-rk3128)
Johan Jonker734dcdc2021-08-20 19:27:58 +020038* rk3188
39 - Radxa Rock (rock)
Walter Lozanocbd75f62020-05-22 11:14:56 -030040* rk3229
41 - Rockchip Evb-RK3229 (evb-rk3229)
Jagan Teki338b86c2020-01-10 00:16:22 +053042* rk3288
Walter Lozano22186f32020-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 Lozanocbd75f62020-05-22 11:14:56 -030055* rk3308
Massimo Pegorer9841fe22023-09-09 11:33:33 +020056 - Radxa ROCK Pi S (rock-pi-s-rk3308)
Walter Lozanocbd75f62020-05-22 11:14:56 -030057 - Rockchip Evb-RK3308 (evb-rk3308)
58 - Roc-cc-RK3308 (roc-cc-rk3308)
Johan Jonker0c99c6e2022-04-16 17:09:51 +020059* rk3326
60 - ODROID-GO Advance (odroid-go2)
Jagan Teki338b86c2020-01-10 00:16:22 +053061* rk3328
Walter Lozano22186f32020-05-22 11:14:55 -030062 - Rockchip Evb-RK3328 (evb-rk3328)
63 - Pine64 Rock64 (rock64-rk3328)
Walter Lozanocbd75f62020-05-22 11:14:56 -030064 - Firefly-RK3328 (roc-cc-rk3328)
b.l.huangd9c34172020-06-01 00:02:11 +080065 - Radxa Rockpi E (rock-pi-e-rk3328)
Jagan Teki338b86c2020-01-10 00:16:22 +053066* rk3368
Walter Lozano22186f32020-05-22 11:14:55 -030067 - GeekBox (geekbox)
68 - PX5 EVB (evb-px5)
69 - Rockchip Sheep (sheep-rk3368)
70 - Theobroma Systems RK3368-uQ7 SoM - Lion (lion-rk3368)
Jagan Teki338b86c2020-01-10 00:16:22 +053071* rk3399
Walter Lozano22186f32020-05-22 11:14:55 -030072 - 96boards RK3399 Ficus (ficus-rk3399)
73 - 96boards Rock960 (rock960-rk3399)
74 - Firefly-RK3399 (firefly_rk3399)
75 - Firefly ROC-RK3399-PC
76 - FriendlyElec NanoPC-T4 (nanopc-t4-rk3399)
77 - FriendlyElec NanoPi M4 (nanopi-m4-rk3399)
Alexandre Vicenzia99d70c2021-03-26 13:37:10 +010078 - FriendlyElec NanoPi M4B (nanopi-m4b-rk3399)
Walter Lozano22186f32020-05-22 11:14:55 -030079 - FriendlyARM NanoPi NEO4 (nanopi-neo4-rk3399)
80 - Google Bob (chromebook_bob)
Marty E. Plummer6d36e922021-12-24 16:43:46 +030081 - Google Kevin (chromebook_kevin)
Walter Lozano22186f32020-05-22 11:14:55 -030082 - Khadas Edge (khadas-edge-rk3399)
83 - Khadas Edge-Captain (khadas-edge-captain-rk3399)
84 - Khadas Edge-V (hadas-edge-v-rk3399)
85 - Orange Pi RK3399 (orangepi-rk3399)
86 - Pine64 RockPro64 (rockpro64-rk3399)
FUKAUMI Naokie62ba902023-04-26 02:23:56 +000087 - Radxa ROCK 4C+ (rock-4c-plus-rk3399)
Christopher Obbard00224612023-07-19 17:33:57 +010088 - Radxa ROCK 4SE (rock-4se-rk3399)
FUKAUMI Naokie62ba902023-04-26 02:23:56 +000089 - Radxa ROCK Pi 4A/B/A+/B+ (rock-pi-4-rk3399)
90 - Radxa ROCK Pi 4C (rock-pi-4c-rk3399)
Walter Lozano22186f32020-05-22 11:14:55 -030091 - Rockchip Evb-RK3399 (evb_rk3399)
92 - Theobroma Systems RK3399-Q7 SoM - Puma (puma_rk3399)
Jagan Teki15b2d1f2023-01-30 20:27:49 +053093
Chris Morgan6cf6fe22023-04-21 10:59:19 -050094* rk3566
Jonas Karlmane34efcf2023-08-17 21:52:48 +000095 - Anbernic RGxx3 (anbernic-rgxx3-rk3566)
Jonas Karlman11bb3c72023-08-17 06:04:34 +000096 - Pine64 Quartz64-A Board (quartz64-a-rk3566)
97 - Pine64 Quartz64-B Board (quartz64-b-rk3566)
98 - Pine64 SOQuartz on Blade (soquartz-blade-rk3566)
99 - Pine64 SOQuartz on CM4-IO (soquartz-cm4-rk3566)
100 - Pine64 SOQuartz on Model A (soquartz-model-a-rk3566)
101 - Radxa CM3 IO Board (radxa-cm3-io-rk3566)
Chris Morgan6cf6fe22023-04-21 10:59:19 -0500102
Jonas Karlman4773e9d2023-02-25 19:01:34 +0000103* rk3568
104 - Rockchip Evb-RK3568 (evb-rk3568)
Frank Wunderlich3d96c3f2023-10-04 21:04:34 +0200105 - Banana Pi BPI-R2 Pro (bpi-r2-pro-rk3568)
Jonas Karlman11bb3c72023-08-17 06:04:34 +0000106 - EmbedFire LubanCat 2 (lubancat-2-rk3568)
107 - FriendlyElec NanoPi R5C (nanopi-r5c-rk3568)
108 - FriendlyElec NanoPi R5S (nanopi-r5s-rk3568)
Jonas Karlman683f61a2023-08-21 22:30:29 +0000109 - Generic RK3566/RK3568 (generic-rk3568)
Jonas Karlman94da9292023-07-22 14:02:15 +0000110 - Hardkernel ODROID-M1 (odroid-m1-rk3568)
Jonas Karlman11bb3c72023-08-17 06:04:34 +0000111 - Radxa E25 Carrier Board (radxa-e25-rk3568)
112 - Radxa ROCK 3 Model A (rock-3a-rk3568)
Jagan Teki15b2d1f2023-01-30 20:27:49 +0530113
114* rk3588
Kever Yangcf8658c2023-03-02 15:12:57 +0800115 - Rockchip EVB (evb-rk3588)
Jagan Teki6b9fc192023-06-11 12:27:09 +0530116 - Edgeble Neural Compute Module 6A SoM - Neu6a (neu6a-io-rk3588)
Jagan Teki0a3a5742023-06-11 12:27:13 +0530117 - Edgeble Neural Compute Module 6B SoM - Neu6b (neu6b-io-rk3588)
John Clarkb0b80862023-10-13 01:19:22 +0000118 - FriendlyElec NanoPC-T6 (nanopc-t6-rk3588)
Eugen Hristevb8fc6542023-07-04 22:05:12 +0300119 - Radxa ROCK 5A (rock5a-rk3588s)
Eugen Hristev3bf8e402023-02-22 11:05:12 +0200120 - Radxa ROCK 5B (rock5b-rk3588)
Jonas Karlman28c5f942023-10-17 21:40:21 +0000121 - Xunlong Orange Pi 5 (orangepi-5-rk3588s)
Jonas Karlmanb51cf8b2023-10-17 21:40:22 +0000122 - Xunlong Orange Pi 5 Plus (orangepi-5-plus-rk3588)
Jagan Teki15b2d1f2023-01-30 20:27:49 +0530123
Walter Lozanocbd75f62020-05-22 11:14:56 -0300124* rv1108
125 - Rockchip Evb-rv1108 (evb-rv1108)
126 - Elgin-R1 (elgin-rv1108)
Jagan Teki338b86c2020-01-10 00:16:22 +0530127
Jagan Tekib8f1ca92022-12-14 23:21:11 +0530128* rv1126
129 - Edgeble Neural Compute Module 2 SoM - Neu2/Neu2k (neu2-io-r1126)
130
Jagan Teki338b86c2020-01-10 00:16:22 +0530131Building
132--------
133
134TF-A
135^^^^
136
Johan Jonkered33f8c2022-04-16 17:09:50 +0200137TF-A is required when building ARM64 Rockchip SoCs images.
Jagan Teki338b86c2020-01-10 00:16:22 +0530138
Johan Jonkered33f8c2022-04-16 17:09:50 +0200139To build TF-A:
Jagan Teki338b86c2020-01-10 00:16:22 +0530140
Johan Jonkered33f8c2022-04-16 17:09:50 +0200141.. code-block:: bash
142
143 git clone --depth 1 https://github.com/ARM-software/arm-trusted-firmware.git
Jagan Teki338b86c2020-01-10 00:16:22 +0530144 cd arm-trusted-firmware
145 make realclean
146 make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399
Johan Jonkered33f8c2022-04-16 17:09:50 +0200147 cd ..
Jagan Teki338b86c2020-01-10 00:16:22 +0530148
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200149Specify the PLAT= with desired Rockchip platform to build TF-A for.
Jagan Teki338b86c2020-01-10 00:16:22 +0530150
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200151For SoCs whose TF-A code is not available as open source, use BL31 binary provided by Rockchip:
152
153.. code-block:: bash
154
155 git clone --depth 1 https://github.com/rockchip-linux/rkbin
156
157TPL
158^^^
159
160For some SoCs U-Boot sources lack of support to inizialize DRAM.
161In these cases, to get a fully functional image following :ref:`PackageWithTPLandSPL`, use DDR binary provided by Rockchip rkbin repository as ROCKCHIP_TPL when building U-Boot.
162Otherwise, follow :ref:`PackageWithRockchipMiniloader`.
163
Jagan Teki338b86c2020-01-10 00:16:22 +0530164U-Boot
165^^^^^^
166
Johan Jonkered33f8c2022-04-16 17:09:50 +0200167.. code-block:: bash
Jagan Teki338b86c2020-01-10 00:16:22 +0530168
Johan Jonkered33f8c2022-04-16 17:09:50 +0200169 git clone --depth 1 https://source.denx.de/u-boot/u-boot.git
170 cd u-boot
Jagan Teki338b86c2020-01-10 00:16:22 +0530171
Johan Jonker0c99c6e2022-04-16 17:09:51 +0200172To build px30 boards:
173
174.. code-block:: bash
175
176 export BL31=../arm-trusted-firmware/build/px30/release/bl31/bl31.elf
177 make evb-px30_defconfig
178 make CROSS_COMPILE=aarch64-linux-gnu-
179
Johan Jonkerc57677b2022-04-16 17:09:52 +0200180To build rk3066 boards:
181
182.. code-block:: bash
183
184 make mk808_defconfig
185 make CROSS_COMPILE=arm-linux-gnueabihf-
186
Johan Jonkered33f8c2022-04-16 17:09:50 +0200187To build rk3288 boards:
188
189.. code-block:: bash
Jagan Teki338b86c2020-01-10 00:16:22 +0530190
191 make evb-rk3288_defconfig
Johan Jonkered33f8c2022-04-16 17:09:50 +0200192 make CROSS_COMPILE=arm-linux-gnueabihf-
Jagan Teki338b86c2020-01-10 00:16:22 +0530193
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200194To build rk3308 boards:
195
196.. code-block:: bash
197
198 export BL31=../rkbin/bin/rk33/rk3308_bl31_v2.26.elf
199 export ROCKCHIP_TPL=../rkbin/bin/rk33/rk3308_ddr_589MHz_uartX_mY_v2.07.bin
200 make evb-rk3308_defconfig
201 make CROSS_COMPILE=aarch64-linux-gnu-
202
Johan Jonkered33f8c2022-04-16 17:09:50 +0200203To build rk3328 boards:
Jagan Teki338b86c2020-01-10 00:16:22 +0530204
Johan Jonkered33f8c2022-04-16 17:09:50 +0200205.. code-block:: bash
206
207 export BL31=../arm-trusted-firmware/build/rk3328/release/bl31/bl31.elf
208 make evb-rk3328_defconfig
209 make CROSS_COMPILE=aarch64-linux-gnu-
210
211To build rk3368 boards:
212
213.. code-block:: bash
214
215 export BL31=../arm-trusted-firmware/build/rk3368/release/bl31/bl31.elf
Jagan Teki338b86c2020-01-10 00:16:22 +0530216 make evb-px5_defconfig
Johan Jonkered33f8c2022-04-16 17:09:50 +0200217 make CROSS_COMPILE=aarch64-linux-gnu-
Jagan Teki338b86c2020-01-10 00:16:22 +0530218
Johan Jonkered33f8c2022-04-16 17:09:50 +0200219To build rk3399 boards:
Jagan Teki338b86c2020-01-10 00:16:22 +0530220
Johan Jonkered33f8c2022-04-16 17:09:50 +0200221.. code-block:: bash
222
223 export BL31=../arm-trusted-firmware/build/rk3399/release/bl31/bl31.elf
Jagan Teki338b86c2020-01-10 00:16:22 +0530224 make evb-rk3399_defconfig
Johan Jonkered33f8c2022-04-16 17:09:50 +0200225 make CROSS_COMPILE=aarch64-linux-gnu-
Jagan Teki338b86c2020-01-10 00:16:22 +0530226
Jonas Karlman4773e9d2023-02-25 19:01:34 +0000227To build rk3568 boards:
228
229.. code-block:: bash
230
Chris Morgan9b78a982023-02-13 16:27:42 -0600231 export BL31=../arm-trusted-firmware/build/rk3568/release/bl31/bl31.elf
232 [or]export BL31=../rkbin/bin/rk35/rk3568_bl31_v1.34.elf
Jonas Karlman4773e9d2023-02-25 19:01:34 +0000233 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3568_ddr_1560MHz_v1.13.bin
234 make evb-rk3568_defconfig
235 make CROSS_COMPILE=aarch64-linux-gnu-
236
Kever Yangcf8658c2023-03-02 15:12:57 +0800237To build rk3588 boards:
238
239.. code-block:: bash
240
241 export BL31=../rkbin/bin/rk35/rk3588_bl31_v1.33.elf
242 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3588_ddr_lp4_2112MHz_lp5_2736MHz_v1.09.bin
243 make evb-rk3588_defconfig
244 make CROSS_COMPILE=aarch64-linux-gnu-
245
Jagan Teki338b86c2020-01-10 00:16:22 +0530246Flashing
247--------
248
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200249.. _`PackageWithTPLandSPL`:
250
Jagan Teki43ed7a02020-10-28 19:03:48 +05302511. Package the image with U-Boot TPL/SPL
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200252^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Jagan Teki43ed7a02020-10-28 19:03:48 +0530253
Jagan Teki338b86c2020-01-10 00:16:22 +0530254SD Card
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200255"""""""
Jagan Teki338b86c2020-01-10 00:16:22 +0530256
Johan Jonkered33f8c2022-04-16 17:09:50 +0200257All Rockchip platforms (except rk3128 which doesn't use SPL) are now
Jonas Karlman6ed39522023-07-28 11:38:40 +0000258supporting a single boot image using binman.
Jagan Teki338b86c2020-01-10 00:16:22 +0530259
Johan Jonkered33f8c2022-04-16 17:09:50 +0200260To write an image that boots from a SD card (assumed to be /dev/sda):
261
262.. code-block:: bash
Jagan Teki338b86c2020-01-10 00:16:22 +0530263
264 sudo dd if=u-boot-rockchip.bin of=/dev/sda seek=64
265 sync
266
Jagan Teki7e013632020-05-24 23:02:13 +0530267eMMC
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200268""""
Jagan Teki7e013632020-05-24 23:02:13 +0530269
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200270eMMC flash would probe on mmc0 in most of the Rockchip platforms.
Jagan Teki7e013632020-05-24 23:02:13 +0530271
Johan Jonkered33f8c2022-04-16 17:09:50 +0200272Create GPT partition layout as defined in $partitions:
273
274.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530275
276 mmc dev 0
277 gpt write mmc 0 $partitions
278
Johan Jonkered33f8c2022-04-16 17:09:50 +0200279Connect the USB-OTG cable between the host and a target device.
Jagan Teki7e013632020-05-24 23:02:13 +0530280
Johan Jonkered33f8c2022-04-16 17:09:50 +0200281Launch fastboot on the target with:
282
283.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530284
285 fastboot 0
286
Johan Jonkered33f8c2022-04-16 17:09:50 +0200287Upon a successful gadget connection the host shows the USB device with:
288
289.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530290
291 lsusb
Johan Jonkered33f8c2022-04-16 17:09:50 +0200292 # Bus 001 Device 020: ID 2207:330c Fuzhou Rockchip Electronics Company RK3399 in Mask ROM mode
Jagan Teki7e013632020-05-24 23:02:13 +0530293
Johan Jonkered33f8c2022-04-16 17:09:50 +0200294Program the flash with:
295
296.. code-block:: bash
Jagan Teki7e013632020-05-24 23:02:13 +0530297
298 sudo fastboot -i 0x2207 flash loader1 idbloader.img
299 sudo fastboot -i 0x2207 flash loader2 u-boot.itb
300
Johan Jonkered33f8c2022-04-16 17:09:50 +0200301Note:
302
303For Rockchip 32-bit platforms the U-Boot proper image
Jagan Teki7e013632020-05-24 23:02:13 +0530304is u-boot-dtb.img
305
Jagan Tekidd397602020-06-04 20:21:41 +0530306SPI
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200307"""
Jagan Tekidd397602020-06-04 20:21:41 +0530308
Jonas Karlman6ed39522023-07-28 11:38:40 +0000309Write u-boot-rockchip-spi.bin to offset 0 of SPI flash.
Jagan Tekidd397602020-06-04 20:21:41 +0530310
Jonas Karlman6ed39522023-07-28 11:38:40 +0000311Copy u-boot-rockchip-spi.bin into SD card and boot from SD:
Johan Jonkered33f8c2022-04-16 17:09:50 +0200312
313.. code-block:: bash
Jagan Tekidd397602020-06-04 20:21:41 +0530314
315 sf probe
Jonas Karlman6ed39522023-07-28 11:38:40 +0000316 load mmc 1:1 $kernel_addr_r u-boot-rockchip-spi.bin
317 sf update $fileaddr 0 $filesize
Jagan Tekidd397602020-06-04 20:21:41 +0530318
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200319.. _`PackageWithRockchipMiniloader`:
320
Jagan Teki43ed7a02020-10-28 19:03:48 +05303212. Package the image with Rockchip miniloader
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200322^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Jagan Teki43ed7a02020-10-28 19:03:48 +0530323
Johan Jonkered33f8c2022-04-16 17:09:50 +0200324Image package with Rockchip miniloader requires rkbin [1].
Jagan Teki43ed7a02020-10-28 19:03:48 +0530325
Johan Jonkered33f8c2022-04-16 17:09:50 +0200326.. code-block:: bash
Jagan Teki43ed7a02020-10-28 19:03:48 +0530327
Johan Jonkered33f8c2022-04-16 17:09:50 +0200328 cd ..
329 git clone --depth 1 https://github.com/rockchip-linux/rkbin
Jagan Teki43ed7a02020-10-28 19:03:48 +0530330
Johan Jonkered33f8c2022-04-16 17:09:50 +0200331Create idbloader.img:
Jagan Teki43ed7a02020-10-28 19:03:48 +0530332
Johan Jonkered33f8c2022-04-16 17:09:50 +0200333.. code-block:: bash
Jagan Teki43ed7a02020-10-28 19:03:48 +0530334
Johan Jonkered33f8c2022-04-16 17:09:50 +0200335 cd u-boot
336 ./tools/mkimage -n px30 -T rksd -d ../rkbin/bin/rk33/px30_ddr_333MHz_v1.16.bin idbloader.img
337 cat ../rkbin/bin/rk33/px30_miniloader_v1.31.bin >> idbloader.img
338 sudo dd if=idbloader.img of=/dev/sda seek=64
Jagan Teki43ed7a02020-10-28 19:03:48 +0530339
Johan Jonkered33f8c2022-04-16 17:09:50 +0200340Create trust.img:
Jagan Teki43ed7a02020-10-28 19:03:48 +0530341
Johan Jonkered33f8c2022-04-16 17:09:50 +0200342.. code-block:: bash
Jagan Teki43ed7a02020-10-28 19:03:48 +0530343
Johan Jonkered33f8c2022-04-16 17:09:50 +0200344 cd ../rkbin
345 ./tools/trust_merger RKTRUST/PX30TRUST.ini
346 sudo dd if=trust.img of=/dev/sda seek=24576
Jagan Teki43ed7a02020-10-28 19:03:48 +0530347
Johan Jonkered33f8c2022-04-16 17:09:50 +0200348Create uboot.img [2]:
349
350.. code-block:: bash
351
352 cd ../u-boot
353 ../rkbin/tools/loaderimage --pack --uboot u-boot-dtb.bin uboot.img 0x200000
354 sudo dd if=uboot.img of=/dev/sda seek=16384
Jagan Teki43ed7a02020-10-28 19:03:48 +0530355
356Note:
Johan Jonkered33f8c2022-04-16 17:09:50 +0200357
3581. rkbin binaries are regularly updated, so it would be recommended to use the latest version.
3592. 0x200000 is a load address and is an option for some platforms.
Jagan Teki43ed7a02020-10-28 19:03:48 +0530360
Johan Jonkerc57677b2022-04-16 17:09:52 +02003613. Package the RK3066 image with U-Boot TPL/SPL on NAND
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200362^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Johan Jonkerc57677b2022-04-16 17:09:52 +0200363
364Unlike later SoC models the rk3066 BootROM doesn't have SDMMC support.
365If all other boot options fail then it enters into a BootROM mode on the USB OTG port.
Michal Simek1be82af2023-05-17 09:17:16 +0200366This method loads TPL/SPL on NAND with U-Boot and kernel on SD card.
Johan Jonkerc57677b2022-04-16 17:09:52 +0200367
368SD Card
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200369"""""""
Johan Jonkerc57677b2022-04-16 17:09:52 +0200370
Michal Simek1be82af2023-05-17 09:17:16 +0200371U-Boot expects a GPT partition map and a boot directory structure with files on the SD card.
Johan Jonkerc57677b2022-04-16 17:09:52 +0200372
373.. code-block:: none
374
375 Partition Map for MMC device 0 -- Partition Type: EFI
376 Part Start LBA End LBA Name
377 1 0x00000040 0x00001f7f "loader1"
378 2 0x00004000 0x00005fff "loader2"
379 3 0x00006000 0x00007fff "trust"
380 4 0x00008000 0x0003ffff "boot"
381 5 0x00040000 0x00ed7fde "rootfs"
382
383Make sure boot and esp flag are set for the boot partition.
384Loader1 partition is not used by RK3066.
385
386Boot partition:
387
388.. code-block:: none
389
390 extlinux
391 extlinux.conf
392
393 zImage
394 rk3066a-mk808.dtb
395
Michal Simek1be82af2023-05-17 09:17:16 +0200396To write a U-Boot image to the SD card (assumed to be /dev/sda):
Johan Jonkerc57677b2022-04-16 17:09:52 +0200397
398.. code-block:: bash
399
400 sudo dd if=u-boot-dtb.img of=/dev/sda seek=16384
401 sync
402
403NAND
Massimo Pegorer9841fe22023-09-09 11:33:33 +0200404""""
Johan Jonkerc57677b2022-04-16 17:09:52 +0200405
406Bring device in BootROM mode:
407
408If bricked and no BootROM mode shows up then connect pin 8 and 9 of the NAND flash
409with a needle while reconnecting to the USB OTG port to a PC.
410
411Show connected devices with:
412
413.. code-block:: bash
414
415 lsusb
416 # Bus 001 Device 004: ID 2207:300a Fuzhou Rockchip Electronics Company RK3066 in Mask ROM mode
417
418
419Create NAND image:
420
421Size of SPL and TPL must be aligned to 2kb.
422
423Program with commands in a bash script ./flash.sh:
424
425.. code-block:: bash
426
427 #!/bin/sh
428
Johan Jonkerf1088af2023-03-19 16:06:11 +0100429 printf "RK30" | dd conv=notrunc bs=4 count=1 of=u-boot-tpl.bin
430 truncate -s %2048 u-boot-tpl.bin
Johan Jonkerc57677b2022-04-16 17:09:52 +0200431 truncate -s %2048 u-boot-spl.bin
432 ../tools/boot_merger --verbose config-flash.ini
433 ../tools/upgrade_tool ul ./RK30xxLoader_uboot.bin
434
435config-flash.ini:
436
437.. code-block:: none
438
439 [CHIP_NAME]
440 NAME=RK30
441 [VERSION]
442 MAJOR=2
443 MINOR=21
444 [CODE471_OPTION]
445 NUM=1
446 Path1=30_LPDDR2_300MHz_DD.bin
447 [CODE472_OPTION]
448 NUM=1
449 Path1=rk30usbplug.bin
450 [LOADER_OPTION]
451 NUM=2
452 LOADER1=FlashData
453 LOADER2=FlashBoot
Johan Jonkerf1088af2023-03-19 16:06:11 +0100454 FlashData=u-boot-tpl.bin
Johan Jonkerc57677b2022-04-16 17:09:52 +0200455 FlashBoot=u-boot-spl.bin
456 [OUTPUT]
457 PATH=RK30xxLoader_uboot.bin
458
Jagan Teki338b86c2020-01-10 00:16:22 +0530459TODO
460----
461
Johan Jonker3ad88ec2021-08-20 19:27:59 +0200462- Add Rockchip idbloader image building
463- Add Rockchip TPL image building
Jagan Teki338b86c2020-01-10 00:16:22 +0530464- Document SPI flash boot
Jagan Teki338b86c2020-01-10 00:16:22 +0530465- Add missing SoC's with it boards list
466
467.. Jagan Teki <jagan@amarulasolutions.com>
Jagan Teki43ed7a02020-10-28 19:03:48 +0530468.. Wednesday 28 October 2020 06:47:26 PM IST