1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
|
Contents
========
1. Introduction
2. Get the Source and prebuild binary
3. Compile the U-Boot
4. Compile the rkdeveloptool
5. Package the image
5.1. Package the image for U-Boot SPL(option 1)
5.2. Package the image for Rockchip miniloader(option 2)
6. Bootloader storage options
7. Flash the image to eMMC
7.1. Flash the image with U-Boot SPL(option 1)
7.2. Flash the image with Rockchip miniloader(option 2)
8. Create a bootable SD/MMC
9. And that is it
Introduction
============
Rock960 board family consists of Rock960 (Consumer Edition) and
Ficus (Enterprise Edition) 96Boards featuring Rockchip RK3399 SoC.
Common features implemented on both boards:
* CPU: ARMv8 64bit Big-Little architecture,
* Big: dual-core Cortex-A72
* Little: quad-core Cortex-A53
* IRAM: 200KB
* eMMC: 16/32GB eMMC 5.1
* PMU: RK808
* SD/MMC
* Display: HDMI/DP/MIPI
* Low Speed Expansion Connector
* High Speed Expansion Connector
Additional features of Rock960:
* DRAM: 2GB/4GB LPDDR3 @ 1866MHz
* 1x USB 3.0 type A, 1x USB 2.0 type A (host mode only),
1x USB 3.0 type C OTG
Additional features of Ficus:
* DRAM: 2GB/4GB DDR3 @ 1600MHz
* Ethernet
* 2x USB 3.0 type A, 2x USB 2.0 type A (host mode only),
1x USB 3.0 type C OTG
Here is the step-by-step to boot to U-Boot on Rock960 boards.
Get the Source and prebuild binary
==================================
> git clone https://github.com/96rocks/rkbin.git
> git clone https://github.com/rockchip-linux/rkdeveloptool.git
Compile the U-Boot
==================
> cd ../u-boot
> cp ../rkbin/rk33/rk3399_bl31_v1.00.elf ./bl31.elf
> export CROSS_COMPILE=aarch64-linux-gnu-
> make rock960-rk3399_defconfig
> make
Compile the rkdeveloptool
=========================
Follow instructions in latest README
> cd ../rkdeveloptool
> autoreconf -i
> ./configure
> make
> sudo make install
Package the image
=================
Package the image for U-Boot SPL(option 1)
--------------------------------
> cd ..
> tools/mkimage -n rk3399 -T rksd -d spl/u-boot-spl.bin idbspl.img
Get idbspl.img in this step.
Package the image for Rockchip miniloader(option 2)
------------------------------------------
> cd ../rkbin
> ./tools/loaderimage --pack --uboot u-boot/u-boot-dtb.bin uboot.img 0x200000
> ../u-boot/tools/mkimage -n rk3399 -T rksd -d rk3399_ddr_933MHz_v1.08.bin idbloader.img
> cat ./rk33/rk3399_miniloader_v1.06.bin >> idbloader.img
Get uboot.img and idbloader.img in this step.
Bootloader storage options
==========================
There are a few different storage options for the bootloader.
This document explores two of these: eMMC and removable SD/MMC.
Flash the image to eMMC
=======================
Flash the image with U-Boot SPL(option 1)
-------------------------------
Power on(or reset with RESET KEY) with MASKROM KEY preesed, and then:
> rkdeveloptool db rkbin/rk33/rk3399_loader_v1.08.106.bin
> rkdeveloptool wl 64 u-boot/idbspl.img
> rkdeveloptool wl 0x4000 u-boot/u-boot.itb
> rkdeveloptool rd
Flash the image with Rockchip miniloader(option 2)
----------------------------------------
Power on(or reset with RESET KEY) with MASKROM KEY preesed, and then:
> rkdeveloptool db rkbin/rk33/rk3399_loader_v1.08.106.bin
> rkdeveloptool wl 0x40 idbloader.img
> rkdeveloptool wl 0x4000 uboot.img
> rkdeveloptool wl 0x6000 ./img/rk3399/trust.img
> rkdeveloptool rd
Create a bootable SD/MMC
========================
The idbspl.img contains the first stage, and the u-boot.img the second stage.
As explained in the Rockchip partition table reference [1], the first stage
(aka loader1) start sector is 64, and the second stage start sector is 16384.
Each sector is 512 bytes, which means the first stage offset is 32 KiB,
and the second stage offset is 8 MiB.
Note: the second stage location is actually not as per the spec,
but defined by the SPL. Mainline SPL defines an 8 MiB offset for the second
stage.
Assuming the SD card is exposed by device /dev/mmcblk0, the commands
to write the two stages are:
> dd if=idbspl.img of=/dev/mmcblk0 bs=1k seek=32
> dd if=u-boot.itb of=/dev/mmcblk0 bs=1k seek=8192
Setting up the kernel and rootfs is beyond the scope of this document.
And that is it
==============
You should be able to get U-Boot log in console/UART2(baurdrate 1500000)
For more detail, please reference [2].
[1] http://opensource.rock-chips.com/wiki_Partitions
[2] http://opensource.rock-chips.com/wiki_Boot_option
|