blob: b88299cbba2342851635cf2dc1656586dcc33598 [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
Massimo Pegoreredf10aa2023-09-09 11:33:33 +020056 - Radxa ROCK Pi S (rock-pi-s-rk3308)
Jonas Karlman3026cf62024-07-30 19:48:37 +000057 - Radxa ROCK S0 (rock-s0-rk3308)
Walter Lozanocddcd972020-05-22 11:14:56 -030058 - Rockchip Evb-RK3308 (evb-rk3308)
59 - Roc-cc-RK3308 (roc-cc-rk3308)
Johan Jonker46d609b2022-04-16 17:09:51 +020060* rk3326
61 - ODROID-GO Advance (odroid-go2)
Jagan Tekid0a440c2020-01-10 00:16:22 +053062* rk3328
Walter Lozanocb17ffd2020-05-22 11:14:55 -030063 - Rockchip Evb-RK3328 (evb-rk3328)
Jonas Karlman4ac67eb2024-02-17 00:22:30 +000064 - Firefly ROC-RK3328-CC (roc-cc-rk3328)
Jonas Karlmanb03dfd12024-02-17 00:22:32 +000065 - FriendlyElec NanoPi R2C (nanopi-r2c-rk3328)
66 - FriendlyElec NanoPi R2C Plus (nanopi-r2c-plus-rk3328)
67 - FriendlyElec NanoPi R2S (nanopi-r2s-rk3328)
Jonas Karlman04573b82024-11-01 22:21:30 +000068 - FriendlyElec NanoPi R2S Plus (nanopi-r2s-plus-rk3328)
Jonas Karlman315477f2025-03-30 17:20:34 +000069 - Generic RK3328 (generic-rk3328)
Walter Lozanocb17ffd2020-05-22 11:14:55 -030070 - Pine64 Rock64 (rock64-rk3328)
Jonas Karlmana44e0572024-02-17 00:22:31 +000071 - Radxa ROCK Pi E (rock-pi-e-rk3328)
Jonas Karlmandc23df72024-02-17 00:22:33 +000072 - Xunlong Orange Pi R1 Plus (orangepi-r1-plus-rk3328)
73 - Xunlong Orange Pi R1 Plus LTS (orangepi-r1-plus-lts-rk3328)
Jagan Tekid0a440c2020-01-10 00:16:22 +053074* rk3368
Walter Lozanocb17ffd2020-05-22 11:14:55 -030075 - GeekBox (geekbox)
76 - PX5 EVB (evb-px5)
77 - Rockchip Sheep (sheep-rk3368)
Jagan Tekid0a440c2020-01-10 00:16:22 +053078* rk3399
Walter Lozanocb17ffd2020-05-22 11:14:55 -030079 - 96boards RK3399 Ficus (ficus-rk3399)
80 - 96boards Rock960 (rock960-rk3399)
81 - Firefly-RK3399 (firefly_rk3399)
82 - Firefly ROC-RK3399-PC
83 - FriendlyElec NanoPC-T4 (nanopc-t4-rk3399)
84 - FriendlyElec NanoPi M4 (nanopi-m4-rk3399)
Alexandre Vicenzibc592bd2021-03-26 13:37:10 +010085 - FriendlyElec NanoPi M4B (nanopi-m4b-rk3399)
Walter Lozanocb17ffd2020-05-22 11:14:55 -030086 - FriendlyARM NanoPi NEO4 (nanopi-neo4-rk3399)
Jonas Karlmanc03b03d2025-03-30 17:20:35 +000087 - Generic RK3399 (generic-rk3399)
Walter Lozanocb17ffd2020-05-22 11:14:55 -030088 - Google Bob (chromebook_bob)
Marty E. Plummerb20a8dac2021-12-24 16:43:46 +030089 - Google Kevin (chromebook_kevin)
Walter Lozanocb17ffd2020-05-22 11:14:55 -030090 - Khadas Edge (khadas-edge-rk3399)
91 - Khadas Edge-Captain (khadas-edge-captain-rk3399)
92 - Khadas Edge-V (hadas-edge-v-rk3399)
93 - Orange Pi RK3399 (orangepi-rk3399)
94 - Pine64 RockPro64 (rockpro64-rk3399)
FUKAUMI Naoki857728c2023-04-26 02:23:56 +000095 - Radxa ROCK 4C+ (rock-4c-plus-rk3399)
Christopher Obbard76c7c372023-07-19 17:33:57 +010096 - Radxa ROCK 4SE (rock-4se-rk3399)
FUKAUMI Naoki857728c2023-04-26 02:23:56 +000097 - Radxa ROCK Pi 4A/B/A+/B+ (rock-pi-4-rk3399)
98 - Radxa ROCK Pi 4C (rock-pi-4c-rk3399)
Walter Lozanocb17ffd2020-05-22 11:14:55 -030099 - Rockchip Evb-RK3399 (evb_rk3399)
100 - Theobroma Systems RK3399-Q7 SoM - Puma (puma_rk3399)
Jagan Teki91dc9f62023-01-30 20:27:49 +0530101
Jonas Karlman46436262025-04-07 22:47:02 +0000102* rk3528
103 - Generic RK3528 (generic-rk3528)
Jonas Karlmanc0e9bab2025-04-07 22:47:03 +0000104 - Radxa E20C (radxa-e20c-rk3528)
Jonas Karlman46436262025-04-07 22:47:02 +0000105
Chris Morgan8c4e3042023-04-21 10:59:19 -0500106* rk3566
Jonas Karlman91b6ca62023-08-17 21:52:48 +0000107 - Anbernic RGxx3 (anbernic-rgxx3-rk3566)
Tianling Sheneb985d32024-12-26 17:20:43 +0800108 - FriendlyElec NanoPi R3S (nanopi-r3s-rk3566)
Jonas Karlman062572c2024-10-08 20:06:35 +0000109 - Hardkernel ODROID-M1S (odroid-m1s-rk3566)
Jiehui Heca7aa7b2025-04-15 03:36:50 -0400110 - LCKFB TaishanPi (lckfb-tspi-rk3566)
Jonas Karlmane256c0f2024-02-04 17:30:35 +0000111 - Pine64 PineTab2 (pinetab2-rk3566)
Jonas Karlmanefb0b692023-08-17 06:04:34 +0000112 - Pine64 Quartz64-A Board (quartz64-a-rk3566)
113 - Pine64 Quartz64-B Board (quartz64-b-rk3566)
114 - Pine64 SOQuartz on Blade (soquartz-blade-rk3566)
115 - Pine64 SOQuartz on CM4-IO (soquartz-cm4-rk3566)
116 - Pine64 SOQuartz on Model A (soquartz-model-a-rk3566)
Chris Morganc56a7b22024-05-21 10:25:33 -0500117 - Powkiddy X55 (powkiddy-x55-rk3566)
Jonas Karlmanefb0b692023-08-17 06:04:34 +0000118 - Radxa CM3 IO Board (radxa-cm3-io-rk3566)
Maxim Moskalets6bb0c9e2024-08-08 22:37:10 +0300119 - Radxa ROCK 3C (rock-3c-rk3566)
Jonas Karlmancf865ff2024-08-02 22:12:23 +0000120 - Radxa ZERO 3W/3E (radxa-zero-3-rk3566)
Ricardo Pardini7cfbe202024-07-31 09:03:31 +0000121 - Xunlong Orange Pi 3B (orangepi-3b-rk3566)
Chris Morgan8c4e3042023-04-21 10:59:19 -0500122
Jonas Karlman38ad6c92023-02-25 19:01:34 +0000123* rk3568
124 - Rockchip Evb-RK3568 (evb-rk3568)
Frank Wunderlich2dd669f2023-10-04 21:04:34 +0200125 - Banana Pi BPI-R2 Pro (bpi-r2-pro-rk3568)
Jonas Karlmanefb0b692023-08-17 06:04:34 +0000126 - EmbedFire LubanCat 2 (lubancat-2-rk3568)
127 - FriendlyElec NanoPi R5C (nanopi-r5c-rk3568)
128 - FriendlyElec NanoPi R5S (nanopi-r5s-rk3568)
Jonas Karlmanf68c63d2023-08-21 22:30:29 +0000129 - Generic RK3566/RK3568 (generic-rk3568)
Jonas Karlman12e2e7e2023-07-22 14:02:15 +0000130 - Hardkernel ODROID-M1 (odroid-m1-rk3568)
Heiko Stuebner0ea9f8a2024-10-28 20:00:34 +0100131 - QNAP TS-433 (qnap-ts433-rk3568)
Jonas Karlmanefb0b692023-08-17 06:04:34 +0000132 - Radxa E25 Carrier Board (radxa-e25-rk3568)
Jonas Karlman663042f2024-07-31 07:28:54 +0000133 - Radxa ROCK 3A (rock-3a-rk3568)
134 - Radxa ROCK 3B (rock-3b-rk3568)
Jagan Teki91dc9f62023-01-30 20:27:49 +0530135
Heiko Stuebnerb68b1c02025-04-15 23:51:28 +0200136* rk3576
137 - Firefly ROC-RK3576-PC (roc-pc-rk3576)
138
Jagan Teki91dc9f62023-01-30 20:27:49 +0530139* rk3588
Jianfeng Liue415a8a2024-05-29 01:04:06 +0800140 - ArmSoM Sige7 (sige7-rk3588)
Kever Yange25c0452023-03-02 15:12:57 +0800141 - Rockchip EVB (evb-rk3588)
Jagan Teki8b7bb772023-06-11 12:27:09 +0530142 - Edgeble Neural Compute Module 6A SoM - Neu6a (neu6a-io-rk3588)
Jagan Tekifd9e57f2023-06-11 12:27:13 +0530143 - Edgeble Neural Compute Module 6B SoM - Neu6b (neu6b-io-rk3588)
Jonas Karlman1dcdff62024-07-31 21:12:16 +0000144 - FriendlyElec CM3588 NAS (cm3588-nas-rk3588)
John Clarkd88366e2023-10-13 01:19:22 +0000145 - FriendlyElec NanoPC-T6 (nanopc-t6-rk3588)
Sebastian Kropatsche4297532024-07-11 12:15:17 +0200146 - FriendlyElec NanoPi R6C (nanopi-r6c-rk3588s)
Sebastian Kropatsch54a41022024-07-11 12:15:18 +0200147 - FriendlyElec NanoPi R6S (nanopi-r6s-rk3588s)
Jonas Karlmanb4640442024-01-31 22:08:51 +0000148 - Generic RK3588S/RK3588 (generic-rk3588)
Jonas Karlman89ff6bc2024-10-03 19:59:34 +0000149 - Hardkernel ODROID-M2 (odroid-m2-rk3588s)
Chris Morgan1ad2f512024-05-24 11:48:00 -0500150 - Indiedroid Nova (nova-rk3588s)
Jacobe Zang49226032024-11-19 15:46:47 +0800151 - Khadas Edge2 (khadas-edge2-rk3588s)
Tom Fitzhenry1463ea42023-10-24 01:22:22 +1100152 - Pine64 QuartzPro64 (quartzpro64-rk3588)
Heiko Stuebnerd94e57b2024-08-02 23:00:28 +0200153 - Radxa ROCK 5 ITX (rock-5-itx-rk3588)
Eugen Hristevaca4ec02023-07-04 22:05:12 +0300154 - Radxa ROCK 5A (rock5a-rk3588s)
Eugen Hristev32f36cf2023-02-22 11:05:12 +0200155 - Radxa ROCK 5B (rock5b-rk3588)
FUKAUMI Naoki93e83532025-01-04 01:57:04 +0000156 - Radxa ROCK 5C (rock-5c-rk3588s)
Elon Zhang7efb63e2024-03-11 11:57:33 +0800157 - Rockchip Toybrick TB-RK3588X (toybrick-rk3588)
Quentin Schulz14f731e2024-03-11 13:01:59 +0100158 - Theobroma Systems RK3588-SBC Jaguar (jaguar-rk3588)
Quentin Schulz220800a2024-06-10 15:13:38 +0200159 - Theobroma Systems SOM-RK3588-Q7 - Tiger (tiger-rk3588)
Jonas Karlmanb4640442024-01-31 22:08:51 +0000160 - Turing Machines RK1 (turing-rk1-rk3588)
Jonas Karlman371b31f2023-10-17 21:40:21 +0000161 - Xunlong Orange Pi 5 (orangepi-5-rk3588s)
Ilya Katsnelson926257c2025-04-23 18:36:40 +0300162 - Xunlong Orange Pi 5 Max (orangepi-5-max-rk3588)
Jonas Karlmana5890ff2023-10-17 21:40:22 +0000163 - Xunlong Orange Pi 5 Plus (orangepi-5-plus-rk3588)
Jonas Karlmanb10cf232024-04-22 06:28:54 +0000164 - Yanyi Tech CoolPi 4 Model B (coolpi-4b-rk3588s)
165 - Yanyi Tech CoolPi CM5 EVB (coolpi-cm5-evb-rk3588)
Andy Yan43273f52024-11-04 20:23:00 +0800166 - Yanyi Tech CoolPi CM5 GenBook (coolpi-cm5-genbook-rk3588)
Jagan Teki91dc9f62023-01-30 20:27:49 +0530167
Walter Lozanocddcd972020-05-22 11:14:56 -0300168* rv1108
169 - Rockchip Evb-rv1108 (evb-rv1108)
170 - Elgin-R1 (elgin-rv1108)
Jagan Tekid0a440c2020-01-10 00:16:22 +0530171
Jagan Teki1db421e2022-12-14 23:21:11 +0530172* rv1126
173 - Edgeble Neural Compute Module 2 SoM - Neu2/Neu2k (neu2-io-r1126)
Tim Lunn5a34e6a2024-01-24 14:26:00 +1100174 - Itead Sonoff iHost (sonoff-ihost-rv1126)
Jagan Teki1db421e2022-12-14 23:21:11 +0530175
Jagan Tekid0a440c2020-01-10 00:16:22 +0530176Building
177--------
178
179TF-A
180^^^^
181
Johan Jonker7937f522022-04-16 17:09:50 +0200182TF-A is required when building ARM64 Rockchip SoCs images.
Jagan Tekid0a440c2020-01-10 00:16:22 +0530183
Johan Jonker7937f522022-04-16 17:09:50 +0200184To build TF-A:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530185
Johan Jonker7937f522022-04-16 17:09:50 +0200186.. code-block:: bash
187
Peter Robinson32d26c72024-10-02 19:08:49 +0100188 git clone --depth 1 https://github.com/TrustedFirmware-A/trusted-firmware-a.git
Peter Robinsonb52fd3b2024-10-04 11:40:44 +0100189 cd trusted-firmware-a
Jagan Tekid0a440c2020-01-10 00:16:22 +0530190 make realclean
191 make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399
Johan Jonker7937f522022-04-16 17:09:50 +0200192 cd ..
Jagan Tekid0a440c2020-01-10 00:16:22 +0530193
Johan Jonker5bf651e2021-08-20 19:27:59 +0200194Specify the PLAT= with desired Rockchip platform to build TF-A for.
Jagan Tekid0a440c2020-01-10 00:16:22 +0530195
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200196For SoCs whose TF-A code is not available as open source, use BL31 binary provided by Rockchip:
197
198.. code-block:: bash
199
200 git clone --depth 1 https://github.com/rockchip-linux/rkbin
201
202TPL
203^^^
204
205For some SoCs U-Boot sources lack of support to inizialize DRAM.
206In 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.
207Otherwise, follow :ref:`PackageWithRockchipMiniloader`.
208
Jagan Tekid0a440c2020-01-10 00:16:22 +0530209U-Boot
210^^^^^^
211
Johan Jonker7937f522022-04-16 17:09:50 +0200212.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530213
Johan Jonker7937f522022-04-16 17:09:50 +0200214 git clone --depth 1 https://source.denx.de/u-boot/u-boot.git
215 cd u-boot
216
Johan Jonker46d609b2022-04-16 17:09:51 +0200217To build px30 boards:
218
219.. code-block:: bash
220
Peter Robinsonb52fd3b2024-10-04 11:40:44 +0100221 export BL31=../trusted-firmware-a/build/px30/release/bl31/bl31.elf
Johan Jonker46d609b2022-04-16 17:09:51 +0200222 make evb-px30_defconfig
223 make CROSS_COMPILE=aarch64-linux-gnu-
224
Johan Jonker114b6ce2022-04-16 17:09:52 +0200225To build rk3066 boards:
226
227.. code-block:: bash
228
229 make mk808_defconfig
230 make CROSS_COMPILE=arm-linux-gnueabihf-
231
Johan Jonker7937f522022-04-16 17:09:50 +0200232To build rk3288 boards:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530233
Johan Jonker7937f522022-04-16 17:09:50 +0200234.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530235
236 make evb-rk3288_defconfig
Johan Jonker7937f522022-04-16 17:09:50 +0200237 make CROSS_COMPILE=arm-linux-gnueabihf-
238
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200239To build rk3308 boards:
240
241.. code-block:: bash
242
243 export BL31=../rkbin/bin/rk33/rk3308_bl31_v2.26.elf
244 export ROCKCHIP_TPL=../rkbin/bin/rk33/rk3308_ddr_589MHz_uartX_mY_v2.07.bin
245 make evb-rk3308_defconfig
246 make CROSS_COMPILE=aarch64-linux-gnu-
247
Johan Jonker7937f522022-04-16 17:09:50 +0200248To build rk3328 boards:
249
250.. code-block:: bash
251
Peter Robinsonb52fd3b2024-10-04 11:40:44 +0100252 export BL31=../trusted-firmware-a/build/rk3328/release/bl31/bl31.elf
Johan Jonker7937f522022-04-16 17:09:50 +0200253 make evb-rk3328_defconfig
254 make CROSS_COMPILE=aarch64-linux-gnu-
255
256To build rk3368 boards:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530257
Johan Jonker7937f522022-04-16 17:09:50 +0200258.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530259
Peter Robinsonb52fd3b2024-10-04 11:40:44 +0100260 export BL31=../trusted-firmware-a/build/rk3368/release/bl31/bl31.elf
Jagan Tekid0a440c2020-01-10 00:16:22 +0530261 make evb-px5_defconfig
Johan Jonker7937f522022-04-16 17:09:50 +0200262 make CROSS_COMPILE=aarch64-linux-gnu-
263
264To build rk3399 boards:
Jagan Tekid0a440c2020-01-10 00:16:22 +0530265
Johan Jonker7937f522022-04-16 17:09:50 +0200266.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530267
Peter Robinsonb52fd3b2024-10-04 11:40:44 +0100268 export BL31=../trusted-firmware-a/build/rk3399/release/bl31/bl31.elf
Jagan Tekid0a440c2020-01-10 00:16:22 +0530269 make evb-rk3399_defconfig
Johan Jonker7937f522022-04-16 17:09:50 +0200270 make CROSS_COMPILE=aarch64-linux-gnu-
Jagan Tekid0a440c2020-01-10 00:16:22 +0530271
Jonas Karlman46436262025-04-07 22:47:02 +0000272To build rk3528 boards:
273
274.. code-block:: bash
275
276 export BL31=../rkbin/bin/rk35/rk3528_bl31_v1.18.elf
277 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3528_ddr_1056MHz_v1.10.bin
278 make generic-rk3528_defconfig
279 make CROSS_COMPILE=aarch64-linux-gnu-
280
Jonas Karlman38ad6c92023-02-25 19:01:34 +0000281To build rk3568 boards:
282
283.. code-block:: bash
284
Peter Robinsonb52fd3b2024-10-04 11:40:44 +0100285 export BL31=../trusted-firmware-a/build/rk3568/release/bl31/bl31.elf
Chris Morganf439d1b2023-02-13 16:27:42 -0600286 [or]export BL31=../rkbin/bin/rk35/rk3568_bl31_v1.34.elf
Jonas Karlman38ad6c92023-02-25 19:01:34 +0000287 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3568_ddr_1560MHz_v1.13.bin
288 make evb-rk3568_defconfig
289 make CROSS_COMPILE=aarch64-linux-gnu-
290
Xuhui Lin43623c22025-04-15 23:51:16 +0200291To build rk3576 boards:
292
293.. code-block:: bash
294
295 export BL31=../rkbin/bin/rk35/rk3576_bl31_v1.04.elf
296 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3576_ddr_lp4_2112MHz_lp5_2736MHz_v1.03.bin
297 make roc-pc-rk3576_defconfig
298 make CROSS_COMPILE=aarch64-linux-gnu-
299
Kever Yange25c0452023-03-02 15:12:57 +0800300To build rk3588 boards:
301
302.. code-block:: bash
303
304 export BL31=../rkbin/bin/rk35/rk3588_bl31_v1.33.elf
305 export ROCKCHIP_TPL=../rkbin/bin/rk35/rk3588_ddr_lp4_2112MHz_lp5_2736MHz_v1.09.bin
306 make evb-rk3588_defconfig
307 make CROSS_COMPILE=aarch64-linux-gnu-
308
Jagan Tekid0a440c2020-01-10 00:16:22 +0530309Flashing
310--------
311
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200312.. _`PackageWithTPLandSPL`:
313
Jagan Tekiefe8a882020-10-28 19:03:48 +05303141. Package the image with U-Boot TPL/SPL
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200315^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Jagan Tekiefe8a882020-10-28 19:03:48 +0530316
Jagan Tekid0a440c2020-01-10 00:16:22 +0530317SD Card
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200318"""""""
Jagan Tekid0a440c2020-01-10 00:16:22 +0530319
Johan Jonker7937f522022-04-16 17:09:50 +0200320All Rockchip platforms (except rk3128 which doesn't use SPL) are now
Jonas Karlman4a7ebed2023-07-28 11:38:40 +0000321supporting a single boot image using binman.
Jagan Tekid0a440c2020-01-10 00:16:22 +0530322
Johan Jonker7937f522022-04-16 17:09:50 +0200323To write an image that boots from a SD card (assumed to be /dev/sda):
324
325.. code-block:: bash
Jagan Tekid0a440c2020-01-10 00:16:22 +0530326
327 sudo dd if=u-boot-rockchip.bin of=/dev/sda seek=64
328 sync
329
Jagan Teki48b9fb02020-05-24 23:02:13 +0530330eMMC
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200331""""
Jagan Teki48b9fb02020-05-24 23:02:13 +0530332
Johan Jonker5bf651e2021-08-20 19:27:59 +0200333eMMC flash would probe on mmc0 in most of the Rockchip platforms.
Jagan Teki48b9fb02020-05-24 23:02:13 +0530334
Johan Jonker7937f522022-04-16 17:09:50 +0200335Create GPT partition layout as defined in $partitions:
336
337.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530338
339 mmc dev 0
340 gpt write mmc 0 $partitions
341
Johan Jonker7937f522022-04-16 17:09:50 +0200342Connect the USB-OTG cable between the host and a target device.
Jagan Teki48b9fb02020-05-24 23:02:13 +0530343
Johan Jonker7937f522022-04-16 17:09:50 +0200344Launch fastboot on the target with:
345
346.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530347
348 fastboot 0
349
Johan Jonker7937f522022-04-16 17:09:50 +0200350Upon a successful gadget connection the host shows the USB device with:
351
352.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530353
354 lsusb
Johan Jonker7937f522022-04-16 17:09:50 +0200355 # Bus 001 Device 020: ID 2207:330c Fuzhou Rockchip Electronics Company RK3399 in Mask ROM mode
Jagan Teki48b9fb02020-05-24 23:02:13 +0530356
Johan Jonker7937f522022-04-16 17:09:50 +0200357Program the flash with:
358
359.. code-block:: bash
Jagan Teki48b9fb02020-05-24 23:02:13 +0530360
361 sudo fastboot -i 0x2207 flash loader1 idbloader.img
362 sudo fastboot -i 0x2207 flash loader2 u-boot.itb
363
Johan Jonker7937f522022-04-16 17:09:50 +0200364Note:
365
366For Rockchip 32-bit platforms the U-Boot proper image
Jagan Teki48b9fb02020-05-24 23:02:13 +0530367is u-boot-dtb.img
368
Jagan Teki1a262832020-06-04 20:21:41 +0530369SPI
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200370"""
Jagan Teki1a262832020-06-04 20:21:41 +0530371
Jonas Karlman4a7ebed2023-07-28 11:38:40 +0000372Write u-boot-rockchip-spi.bin to offset 0 of SPI flash.
Jagan Teki1a262832020-06-04 20:21:41 +0530373
Jonas Karlman4a7ebed2023-07-28 11:38:40 +0000374Copy u-boot-rockchip-spi.bin into SD card and boot from SD:
Johan Jonker7937f522022-04-16 17:09:50 +0200375
376.. code-block:: bash
Jagan Teki1a262832020-06-04 20:21:41 +0530377
Jagan Teki1a262832020-06-04 20:21:41 +0530378 sf probe
Jonas Karlman4a7ebed2023-07-28 11:38:40 +0000379 load mmc 1:1 $kernel_addr_r u-boot-rockchip-spi.bin
380 sf update $fileaddr 0 $filesize
Jagan Teki1a262832020-06-04 20:21:41 +0530381
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200382.. _`PackageWithRockchipMiniloader`:
383
Jagan Tekiefe8a882020-10-28 19:03:48 +05303842. Package the image with Rockchip miniloader
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200385^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Jagan Tekiefe8a882020-10-28 19:03:48 +0530386
Johan Jonker7937f522022-04-16 17:09:50 +0200387Image package with Rockchip miniloader requires rkbin [1].
388
389.. code-block:: bash
Jagan Tekiefe8a882020-10-28 19:03:48 +0530390
Johan Jonker7937f522022-04-16 17:09:50 +0200391 cd ..
392 git clone --depth 1 https://github.com/rockchip-linux/rkbin
Jagan Tekiefe8a882020-10-28 19:03:48 +0530393
Johan Jonker7937f522022-04-16 17:09:50 +0200394Create idbloader.img:
Jagan Tekiefe8a882020-10-28 19:03:48 +0530395
Johan Jonker7937f522022-04-16 17:09:50 +0200396.. code-block:: bash
Jagan Tekiefe8a882020-10-28 19:03:48 +0530397
Johan Jonker7937f522022-04-16 17:09:50 +0200398 cd u-boot
399 ./tools/mkimage -n px30 -T rksd -d ../rkbin/bin/rk33/px30_ddr_333MHz_v1.16.bin idbloader.img
400 cat ../rkbin/bin/rk33/px30_miniloader_v1.31.bin >> idbloader.img
401 sudo dd if=idbloader.img of=/dev/sda seek=64
Jagan Tekiefe8a882020-10-28 19:03:48 +0530402
Johan Jonker7937f522022-04-16 17:09:50 +0200403Create trust.img:
Jagan Tekiefe8a882020-10-28 19:03:48 +0530404
Johan Jonker7937f522022-04-16 17:09:50 +0200405.. code-block:: bash
Jagan Tekiefe8a882020-10-28 19:03:48 +0530406
Johan Jonker7937f522022-04-16 17:09:50 +0200407 cd ../rkbin
408 ./tools/trust_merger RKTRUST/PX30TRUST.ini
409 sudo dd if=trust.img of=/dev/sda seek=24576
Jagan Tekiefe8a882020-10-28 19:03:48 +0530410
Johan Jonker7937f522022-04-16 17:09:50 +0200411Create uboot.img [2]:
Jagan Tekiefe8a882020-10-28 19:03:48 +0530412
Johan Jonker7937f522022-04-16 17:09:50 +0200413.. code-block:: bash
414
415 cd ../u-boot
416 ../rkbin/tools/loaderimage --pack --uboot u-boot-dtb.bin uboot.img 0x200000
417 sudo dd if=uboot.img of=/dev/sda seek=16384
Jagan Tekiefe8a882020-10-28 19:03:48 +0530418
419Note:
Johan Jonker7937f522022-04-16 17:09:50 +0200420
4211. rkbin binaries are regularly updated, so it would be recommended to use the latest version.
4222. 0x200000 is a load address and is an option for some platforms.
Jagan Tekiefe8a882020-10-28 19:03:48 +0530423
Johan Jonker114b6ce2022-04-16 17:09:52 +02004243. Package the RK3066 image with U-Boot TPL/SPL on NAND
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200425^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Johan Jonker114b6ce2022-04-16 17:09:52 +0200426
427Unlike later SoC models the rk3066 BootROM doesn't have SDMMC support.
428If all other boot options fail then it enters into a BootROM mode on the USB OTG port.
Michal Simek50fa1182023-05-17 09:17:16 +0200429This method loads TPL/SPL on NAND with U-Boot and kernel on SD card.
Johan Jonker114b6ce2022-04-16 17:09:52 +0200430
431SD Card
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200432"""""""
Johan Jonker114b6ce2022-04-16 17:09:52 +0200433
Michal Simek50fa1182023-05-17 09:17:16 +0200434U-Boot expects a GPT partition map and a boot directory structure with files on the SD card.
Johan Jonker114b6ce2022-04-16 17:09:52 +0200435
436.. code-block:: none
437
438 Partition Map for MMC device 0 -- Partition Type: EFI
439 Part Start LBA End LBA Name
440 1 0x00000040 0x00001f7f "loader1"
441 2 0x00004000 0x00005fff "loader2"
442 3 0x00006000 0x00007fff "trust"
443 4 0x00008000 0x0003ffff "boot"
444 5 0x00040000 0x00ed7fde "rootfs"
445
446Make sure boot and esp flag are set for the boot partition.
447Loader1 partition is not used by RK3066.
448
449Boot partition:
450
451.. code-block:: none
452
453 extlinux
454 extlinux.conf
455
456 zImage
457 rk3066a-mk808.dtb
458
Michal Simek50fa1182023-05-17 09:17:16 +0200459To write a U-Boot image to the SD card (assumed to be /dev/sda):
Johan Jonker114b6ce2022-04-16 17:09:52 +0200460
461.. code-block:: bash
462
463 sudo dd if=u-boot-dtb.img of=/dev/sda seek=16384
464 sync
465
466NAND
Massimo Pegoreredf10aa2023-09-09 11:33:33 +0200467""""
Johan Jonker114b6ce2022-04-16 17:09:52 +0200468
469Bring device in BootROM mode:
470
471If bricked and no BootROM mode shows up then connect pin 8 and 9 of the NAND flash
472with a needle while reconnecting to the USB OTG port to a PC.
473
474Show connected devices with:
475
476.. code-block:: bash
477
478 lsusb
479 # Bus 001 Device 004: ID 2207:300a Fuzhou Rockchip Electronics Company RK3066 in Mask ROM mode
480
481
482Create NAND image:
483
484Size of SPL and TPL must be aligned to 2kb.
485
486Program with commands in a bash script ./flash.sh:
487
488.. code-block:: bash
489
490 #!/bin/sh
491
Johan Jonker7e0673d2023-03-19 16:06:11 +0100492 printf "RK30" | dd conv=notrunc bs=4 count=1 of=u-boot-tpl.bin
493 truncate -s %2048 u-boot-tpl.bin
Johan Jonker114b6ce2022-04-16 17:09:52 +0200494 truncate -s %2048 u-boot-spl.bin
495 ../tools/boot_merger --verbose config-flash.ini
496 ../tools/upgrade_tool ul ./RK30xxLoader_uboot.bin
497
498config-flash.ini:
499
500.. code-block:: none
501
502 [CHIP_NAME]
503 NAME=RK30
504 [VERSION]
505 MAJOR=2
506 MINOR=21
507 [CODE471_OPTION]
508 NUM=1
509 Path1=30_LPDDR2_300MHz_DD.bin
510 [CODE472_OPTION]
511 NUM=1
512 Path1=rk30usbplug.bin
513 [LOADER_OPTION]
514 NUM=2
515 LOADER1=FlashData
516 LOADER2=FlashBoot
Johan Jonker7e0673d2023-03-19 16:06:11 +0100517 FlashData=u-boot-tpl.bin
Johan Jonker114b6ce2022-04-16 17:09:52 +0200518 FlashBoot=u-boot-spl.bin
519 [OUTPUT]
520 PATH=RK30xxLoader_uboot.bin
521
Jagan Tekid0a440c2020-01-10 00:16:22 +0530522TODO
523----
524
Johan Jonker5bf651e2021-08-20 19:27:59 +0200525- Add Rockchip idbloader image building
526- Add Rockchip TPL image building
Jagan Tekid0a440c2020-01-10 00:16:22 +0530527- Document SPI flash boot
Jagan Tekid0a440c2020-01-10 00:16:22 +0530528- Add missing SoC's with it boards list
529
530.. Jagan Teki <jagan@amarulasolutions.com>
Jagan Tekiefe8a882020-10-28 19:03:48 +0530531.. Wednesday 28 October 2020 06:47:26 PM IST