Yocto Build U-Boot: Difference between revisions
From Variscite Wiki
(Simplify nested ifs into switch) |
Tag: Undo |
||
Line 157: | Line 157: | ||
}} | }} | ||
{{# | {{#ifeq: {{#var:SOC_FAMILY}}|imx8| | ||
| mx8qxp | {{#ifeq: {{#var:SOC}}|mx8qxp| | ||
Depending on i.MX8QXP SOC revision different instructions should be used to build boot image.<br> | Depending on i.MX8QXP SOC revision different instructions should be used to build boot image.<br> | ||
The SOC revision is printed by u-boot as follows | The SOC revision is printed by u-boot as follows | ||
Line 174: | Line 174: | ||
$ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} REV=C0 MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh flash_spl | $ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} REV=C0 MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh flash_spl | ||
$ mv flash.bin {{#var:U-BOOT_SD_IMAGE_NAME}} | $ mv flash.bin {{#var:U-BOOT_SD_IMAGE_NAME}} | ||
| | | | ||
Build boot image: | Build boot image: | ||
$ make -f soc.mak clean | $ make -f soc.mak clean | ||
Line 180: | Line 180: | ||
$ mv flash.bin {{#var:U-BOOT_SD_IMAGE_NAME}} | $ mv flash.bin {{#var:U-BOOT_SD_IMAGE_NAME}} | ||
}} | }} | ||
| mx8mq | | | ||
{{#ifeq: {{#var:SOC}}|mx8mq| | |||
Build boot image: | Build boot image: | ||
$ make -f soc.mak clean | $ make -f soc.mak clean | ||
$ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs={{#var:U-BOOT_DTB_FILE|{{#var:DEFAULT_DTB}}}} MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_evk | $ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs={{#var:U-BOOT_DTB_FILE|{{#var:DEFAULT_DTB}}}} MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_evk | ||
| mx8mm | | | ||
{{#ifeq: {{#var:SOC}}|mx8mm| | |||
{{#ifeq: {{#var:FSL_BSP_VERSION}}| L4.14.78-1.0.0_ga | | {{#ifeq: {{#var:FSL_BSP_VERSION}}| L4.14.78-1.0.0_ga | | ||
Build boot image: | Build boot image: | ||
Line 194: | Line 196: | ||
$ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs="{{#var:U-BOOT_DTB_DART}} {{#var:U-BOOT_DTB_SOM}} {{#var:U-BOOT_DTB_SOM_10}}" MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_lpddr4_ddr4_evk | $ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs="{{#var:U-BOOT_DTB_DART}} {{#var:U-BOOT_DTB_SOM}} {{#var:U-BOOT_DTB_SOM_10}}" MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_lpddr4_ddr4_evk | ||
}} | }} | ||
| mx8mn | | | ||
{{#ifeq: {{#var:SOC}}|mx8mn| | |||
Build boot image: | Build boot image: | ||
$ make -f soc.mak clean | $ make -f soc.mak clean | ||
$ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs="{{#var:U-BOOT_DTB_SOM}} {{#var:U-BOOT_DTB_SOM_10}}" MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_ddr4_evk | $ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs="{{#var:U-BOOT_DTB_SOM}} {{#var:U-BOOT_DTB_SOM_10}}" MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_ddr4_evk | ||
| mx8mp | | | ||
{{#ifeq: {{#var:SOC}}|mx8mp| | |||
Build boot image: | Build boot image: | ||
$ make -f soc.mak clean | $ make -f soc.mak clean | ||
$ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs="{{#var:U-BOOT_DTB_DART}} {{#var:U-BOOT_DTB_SOM}}" MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_evk | $ make -f soc.mak SOC={{#var:IMX_MKIMAGE_SOC}} dtbs="{{#var:U-BOOT_DTB_DART}} {{#var:U-BOOT_DTB_SOM}}" MKIMG=./mkimage_imx8 PAD_IMAGE=./pad_image.sh CC=gcc OUTIMG={{#var:U-BOOT_SD_IMAGE_NAME}} flash_evk | ||
}} | |}} }} }} }} }} }} | ||
= Install the built U-Boot on an SD card = | = Install the built U-Boot on an SD card = |
Revision as of 23:24, 6 January 2023
Yocto Build U-Boot from source code
Toolchain installation for out of Yocto builds
To install the toolchain, follow Yocto Toolchain installation.
Build U-Boot out of Yocto tree
Obtain sources:
$ git clone https://github.com/varigit/uboot-imx.git -b imx_v2015.04_4.1.15_1.1.0_ga_var03 $ cd uboot-imx
Configure compilation environment:
$ source /opt/fslc-x11/2.2.1/environment-setup-armv7at2hf-neon-fslc-linux-gnueabi
Cleanup everything:
$ make mrproper
Select one of the following configurations:
For booting from SD card/eMMC: $ make mx6var_som_sd_defconfig For booting from NAND flash: $ make mx6var_som_nand_defconfig
Build U-Boot:
$ make -j$(nproc)
Install the built U-Boot on an SD card
$ sudo dd if=SPL of=/dev/sdX bs=1K seek=1; sync $ sudo dd if=u-boot.img of=/dev/sdX bs=1K seek=69; sync (Replace /dev/sdX with the correct device)
If you want to use our recovery SD card to flash the built U-Boot to NAND flash/eMMC, then copy it to the appropriate location in the SD card:
$ sudo cp SPL /media/rootfs/opt/images/… $ sudo cp u-boot.img /media/rootfs/opt/images/…
And eject the SD card gracefully from host machine.
Note: If you manually upgrade an existing U-Boot, and you have an old environment saved, it is a good idea to reset your environment to the new default (see Environment handling commands)
Update your U-Boot out of Yocto tree
$ git pull