mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-25 19:35:17 +00:00
fe529e6597
This commit changes the size of the enviroment (for the RK3399-Q7) to 8kiB for all possible locations of the environment (i.e. even when the environment is saved to SD card). With the default of 32kiB, the environment overwrites the SPL stage which lives at 16kiB. Signed-off-by: Jakob Unterwurzacher <jakob.unterwurzacher@theobroma-systems.com> Acked-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com> Reviewed-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com> Tested-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com> [Reworked commit-message:] Signed-off-by: Philipp Tomsich <philipp.tomsich@theobroma-systems.com> |
||
---|---|---|
.. | ||
fit_spl_atf.its | ||
Kconfig | ||
MAINTAINERS | ||
Makefile | ||
puma-rk3399.c | ||
README |
Introduction ============ The RK3399-Q7 (Puma) is a system-on-module featuring the Rockchip RK3399 in a Qseven-compatible form-factor. RK3399-Q7 features: * CPU: ARMv8 64bit Big-Little architecture, * Big: dual-core Cortex-A72 * Little: quad-core Cortex-A53 * IRAM: 200KB * DRAM: 4GB-128MB dual-channel * eMMC: onboard eMMC * SD/MMC * GbE (onboard Micrel KSZ9031) Gigabit ethernet PHY * USB: * USB3.0 dual role port * 2x USB3.0 host, 1x USB2.0 host via onboard USB3.0 hub * Display: HDMI/eDP/MIPI * Camera: 2x CSI (one on the edge connector, one on the Q7 specified CSI ZIF) * NOR Flash: onboard SPI NOR * Companion Controller: onboard additional Cortex-M0 microcontroller * RTC * fan controller * CAN Here is the step-by-step to boot to U-Boot on rk3399. Get the Source and build ATF/Cortex-M0 binaries =============================================== > git clone git://git.theobroma-systems.com/arm-trusted-firmware.git > git clone git://git.theobroma-systems.com/rk3399-cortex-m0.git Compile the ATF =============== > cd arm-trusted-firmware > make CROSS_COMPILE=aarch64-linux-gnu- PLAT=rk3399 bl31 > cp build/rk3399/release/bl31.bin ../u-boot/bl31-rk3399.bin Compile the M0 firmware ======================= > cd ../rk3399-cortex-m0 > make CROSS_COMPILE=arm-cortex_m0-eabi- > cp rk3399m0.bin ../u-boot Compile the U-Boot ================== > cd ../u-boot > make CROSS_COMPILE=aarch64-linux-gnu- puma-rk3399_defconfig all Package the image ================= Creating a SPL image for SD-Card/eMMC > tools/mkimage -n rk3399 -T rksd -d spl/u-boot-spl.bin spl_mmc.img Creating a SPL image for SPI-NOR > tools/mkimage -n rk3399 -T rkspi -d spl/u-boot-spl.bin spl_nor.img Create the FIT image containing U-Boot proper, ATF, M0 Firmware, devicetree > make CROSS_COMPILE=aarch64-linux-gnu- u-boot.itb Flash the image =============== Copy the SPL to offset 32k for SD/eMMC, offset 0 for NOR-Flash and the FIT image to offset 256k card. SD-Card ------- > dd if=spl_mmc.img of=/dev/sdb seek=64 > dd if=u-boot.itb of=/dev/sdb seek=512 eMMC ---- rkdeveloptool allows to flash the on-board eMMC via the USB OTG interface with help of the Rockchip loader binary. > git clone https://github.com/rockchip-linux/rkdeveloptool > cd rkdeveloptool > autoreconf -i && ./configure && make > git clone https://github.com/rockchip-linux/rkbin.git > ./rkdeveloptool db rkbin/rk33/rk3399_loader_v1.08.106.bin > ./rkdeveloptool wl 64 ../spl_mmc.img > ./rkdeveloptool wl 512 ../u-boot.itb NOR-Flash --------- Writing the SPI NOR Flash requires a running U-Boot. For the sake of simplicity we assume you have a SD-Card with a partition containing the required files ready. > load mmc 1:1 ${kernel_addr_r} spl_nor.img > sf probe > sf erase 0 +$filesize > sf write $kernel_addr_r 0 ${filesize} > load mmc 1:1 ${kernel_addr_r} u-boot.itb > sf erase 0x40000 +$filesize > sf write $kernel_addr_r 0x40000 ${filesize} Reboot the system and you should see a U-Boot console on UART0 (115200n8).