Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 1 | Introduction |
| 2 | ============ |
| 3 | |
| 4 | The RK3399-Q7 (Puma) is a system-on-module featuring the Rockchip |
| 5 | RK3399 in a Qseven-compatible form-factor. |
| 6 | |
| 7 | RK3399-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 | |
| 27 | Here is the step-by-step to boot to U-Boot on rk3399. |
| 28 | |
Quentin Schulz | d1b9339 | 2021-11-12 15:15:50 +0100 | [diff] [blame] | 29 | Get the Source and build ATF binary |
| 30 | =================================== |
Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 31 | |
Quentin Schulz | d1b9339 | 2021-11-12 15:15:50 +0100 | [diff] [blame] | 32 | > git clone https://git.trustedfirmware.org/TF-A/trusted-firmware-a.git |
Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 33 | |
| 34 | Compile the ATF |
| 35 | =============== |
| 36 | |
Quentin Schulz | d1b9339 | 2021-11-12 15:15:50 +0100 | [diff] [blame] | 37 | > cd trusted-firmware-a |
Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 38 | > make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399 bl31 |
Quentin Schulz | d1b9339 | 2021-11-12 15:15:50 +0100 | [diff] [blame] | 39 | > cp build/rk3399/release/bl31/bl31.elf ../u-boot/bl31.elf |
Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 40 | |
| 41 | Compile the U-Boot |
| 42 | ================== |
| 43 | |
| 44 | > cd ../u-boot |
| 45 | > make CROSS_COMPILE=aarch64-linux-gnu- puma-rk3399_defconfig all |
| 46 | |
Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 47 | Flash the image |
| 48 | =============== |
| 49 | |
Quentin Schulz | d7bd815 | 2022-09-15 11:14:30 +0200 | [diff] [blame] | 50 | Copy u-boot-rockchip.bin to offset 32k for SD/eMMC. |
Quentin Schulz | 744fc43 | 2022-09-15 11:14:32 +0200 | [diff] [blame] | 51 | Copy u-boot-rockchip-spi.bin to offset 0 for NOR-flash. |
Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 52 | |
Klaus Goger | 5f49bc4 | 2017-09-11 21:05:00 +0200 | [diff] [blame] | 53 | SD-Card |
| 54 | ------- |
| 55 | |
Quentin Schulz | d7bd815 | 2022-09-15 11:14:30 +0200 | [diff] [blame] | 56 | > dd if=u-boot-rockchip.bin of=/dev/sdb seek=64 |
Klaus Goger | 8103993 | 2017-04-07 19:13:38 +0200 | [diff] [blame] | 57 | |
Klaus Goger | 5f49bc4 | 2017-09-11 21:05:00 +0200 | [diff] [blame] | 58 | eMMC |
| 59 | ---- |
| 60 | |
| 61 | rkdeveloptool allows to flash the on-board eMMC via the USB OTG interface with |
| 62 | help of the Rockchip loader binary. |
| 63 | |
| 64 | > git clone https://github.com/rockchip-linux/rkdeveloptool |
| 65 | > cd rkdeveloptool |
| 66 | > autoreconf -i && ./configure && make |
| 67 | > git clone https://github.com/rockchip-linux/rkbin.git |
Quentin Schulz | d1b9339 | 2021-11-12 15:15:50 +0100 | [diff] [blame] | 68 | > cd rkbin |
| 69 | > ./tools/boot_merger RKBOOT/RK3399MINIALL.ini |
| 70 | > cd .. |
| 71 | > ./rkdeveloptool db rkbin/rk3399_loader_v1.25.126.bin |
Quentin Schulz | d7bd815 | 2022-09-15 11:14:30 +0200 | [diff] [blame] | 72 | > ./rkdeveloptool wl 64 ../u-boot-rockchip.bin |
Klaus Goger | 5f49bc4 | 2017-09-11 21:05:00 +0200 | [diff] [blame] | 73 | |
| 74 | NOR-Flash |
| 75 | --------- |
| 76 | |
Quentin Schulz | d1b9339 | 2021-11-12 15:15:50 +0100 | [diff] [blame] | 77 | rkdeveloptool allows to flash the on-board SPI via the USB OTG interface with |
| 78 | help of the Rockchip loader binary. |
Klaus Goger | 5f49bc4 | 2017-09-11 21:05:00 +0200 | [diff] [blame] | 79 | |
Quentin Schulz | d1b9339 | 2021-11-12 15:15:50 +0100 | [diff] [blame] | 80 | > git clone https://github.com/rockchip-linux/rkdeveloptool |
| 81 | > cd rkdeveloptool |
| 82 | > autoreconf -i && ./configure && make |
| 83 | > git clone https://github.com/rockchip-linux/rkbin.git |
| 84 | > cd rkbin |
| 85 | > ./tools/boot_merger RKBOOT/RK3399MINIALL_SPINOR.ini |
| 86 | > cd .. |
| 87 | > ./rkdeveloptool db rkbin/rk3399_loader_spinor_v1.25.114.bin |
| 88 | > ./rkdeveloptool ef |
Quentin Schulz | 744fc43 | 2022-09-15 11:14:32 +0200 | [diff] [blame] | 89 | > ./rkdeveloptool wl 0 ../u-boot-rockchip-spi.bin |