blob: 2e3785c9860f4eec5e4f5870fd325534e383b5ec [file] [log] [blame]
Klaus Goger81039932017-04-07 19:13:38 +02001Introduction
2============
3
4The RK3399-Q7 (Puma) is a system-on-module featuring the Rockchip
5RK3399 in a Qseven-compatible form-factor.
6
7RK3399-Q7 features:
8 * CPU: ARMv8 64bit Big-Little architecture,
9 * Big: dual-core Cortex-A72
10 * Little: quad-core Cortex-A53
11 * IRAM: 200KB
12 * DRAM: 4GB-128MB dual-channel
13 * eMMC: onboard eMMC
14 * SD/MMC
15 * GbE (onboard Micrel KSZ9031) Gigabit ethernet PHY
16 * USB:
17 * USB3.0 dual role port
18 * 2x USB3.0 host, 1x USB2.0 host via onboard USB3.0 hub
19 * Display: HDMI/eDP/MIPI
20 * Camera: 2x CSI (one on the edge connector, one on the Q7 specified CSI ZIF)
21 * NOR Flash: onboard SPI NOR
22 * Companion Controller: onboard additional Cortex-M0 microcontroller
23 * RTC
24 * fan controller
25 * CAN
26
27Here is the step-by-step to boot to U-Boot on rk3399.
28
Quentin Schulzd1b93392021-11-12 15:15:50 +010029Get the Source and build ATF binary
30===================================
Klaus Goger81039932017-04-07 19:13:38 +020031
Quentin Schulzd1b93392021-11-12 15:15:50 +010032 > git clone https://git.trustedfirmware.org/TF-A/trusted-firmware-a.git
Klaus Goger81039932017-04-07 19:13:38 +020033
34Compile the ATF
35===============
36
Quentin Schulzd1b93392021-11-12 15:15:50 +010037 > cd trusted-firmware-a
Klaus Goger81039932017-04-07 19:13:38 +020038 > make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399 bl31
Quentin Schulzd1b93392021-11-12 15:15:50 +010039 > cp build/rk3399/release/bl31/bl31.elf ../u-boot/bl31.elf
Klaus Goger81039932017-04-07 19:13:38 +020040
41Compile the U-Boot
42==================
43
44 > cd ../u-boot
45 > make CROSS_COMPILE=aarch64-linux-gnu- puma-rk3399_defconfig all
46
47Package the image
48=================
49
Quentin Schulzd1b93392021-11-12 15:15:50 +010050Creating an SPL image for SPI-NOR:
Quentin Schulz0088ca42022-09-15 11:14:29 +020051 > tools/mkimage -n rk3399 -T rkspi -d tpl/u-boot-tpl.bin:spl/u-boot-spl.bin idbloader-spi.img
Klaus Goger81039932017-04-07 19:13:38 +020052
53Flash the image
54===============
55
Quentin Schulzd7bd8152022-09-15 11:14:30 +020056Copy u-boot-rockchip.bin to offset 32k for SD/eMMC.
Quentin Schulz0088ca42022-09-15 11:14:29 +020057Copy the SPL to offset 0 and the FIT image to offset 512k for NOR-Flash.
Klaus Goger81039932017-04-07 19:13:38 +020058
Klaus Goger5f49bc42017-09-11 21:05:00 +020059SD-Card
60-------
61
Quentin Schulzd7bd8152022-09-15 11:14:30 +020062 > dd if=u-boot-rockchip.bin of=/dev/sdb seek=64
Klaus Goger81039932017-04-07 19:13:38 +020063
Klaus Goger5f49bc42017-09-11 21:05:00 +020064eMMC
65----
66
67rkdeveloptool allows to flash the on-board eMMC via the USB OTG interface with
68help of the Rockchip loader binary.
69
70 > git clone https://github.com/rockchip-linux/rkdeveloptool
71 > cd rkdeveloptool
72 > autoreconf -i && ./configure && make
73 > git clone https://github.com/rockchip-linux/rkbin.git
Quentin Schulzd1b93392021-11-12 15:15:50 +010074 > cd rkbin
75 > ./tools/boot_merger RKBOOT/RK3399MINIALL.ini
76 > cd ..
77 > ./rkdeveloptool db rkbin/rk3399_loader_v1.25.126.bin
Quentin Schulzd7bd8152022-09-15 11:14:30 +020078 > ./rkdeveloptool wl 64 ../u-boot-rockchip.bin
Klaus Goger5f49bc42017-09-11 21:05:00 +020079
80NOR-Flash
81---------
82
Quentin Schulzd1b93392021-11-12 15:15:50 +010083rkdeveloptool allows to flash the on-board SPI via the USB OTG interface with
84help of the Rockchip loader binary.
Klaus Goger5f49bc42017-09-11 21:05:00 +020085
Quentin Schulzd1b93392021-11-12 15:15:50 +010086 > git clone https://github.com/rockchip-linux/rkdeveloptool
87 > cd rkdeveloptool
88 > autoreconf -i && ./configure && make
89 > git clone https://github.com/rockchip-linux/rkbin.git
90 > cd rkbin
91 > ./tools/boot_merger RKBOOT/RK3399MINIALL_SPINOR.ini
92 > cd ..
93 > ./rkdeveloptool db rkbin/rk3399_loader_spinor_v1.25.114.bin
94 > ./rkdeveloptool ef
95 > ./rkdeveloptool wl 0 ../idbloader-spi.img
Quentin Schulz0088ca42022-09-15 11:14:29 +020096 > ./rkdeveloptool wl 1024 ../u-boot.itb