Skip to main content
Version: BSP 6.x.y

Specifics: Build U-Boot for NXP i.MX 6/6ULL/7-based SoMs

Introduction

This article describes additional specific steps about the compilation and the configuration of the boot container of the Toradex NXP i.MX 6ULL/7-based System on Modules with NAND. It also brings information on how to proceed with the Toradex NXP i.MX6/6ULL/7-based System on Modules with eMMC.

Prerequisites

Before continuing with this article, one must follow the steps in the article Build U-Boot From Source Code.

i.MX6/6ULL/7-based Modules with eMMC

In case of using a Colibri iMX6, Colibri iMX6ULL eMMC version, or Colibri iMX7 eMMC version, please, go to the Deploy the U-Boot binary to an Image section in the Build U-Boot From Source Code article. If you do not know which Toradex NXP i.MX 6ULL/7-based System on Module you are using, please, find the information in the Memory field of the Colibri iMX6ULL product page or the Colibri iMX7 product page.

i.MX6ULL/7-based Modules with NAND

The following procedures are only necessary when using the NAND version of Colibri iMX6ULL or Colibri iMX7.

Build U-Boot: SoC-specific Steps

After the build succeeds, you will obtain a final u-boot-dtb.imx IMX specific image, ready for flashing (however, check the next section for additional adjustments).

The final IMX program image includes (section 6.6.7 from IMX7DRM):

  • Image Vector Table (IVT) for BootROM.
  • Boot data - indicates the program image location, program image size in bytes, and the plugin flag.
  • Device configuration data.
  • User image: U-Boot image (u-boot-dtb.bin).

IMX Image Adjustments prior to Flashing

  1. U-Boot for Colibri iMX7 NAND version is built with HABv4 support (AN4581.pdf) enabled by default, which requires to generate a proper Command Sequence File (CSF) by srktool from NXP (not included in the U-Boot tree) and to concatenate it to the final u-boot-dtb.imx. In case there is no need to generate a proper CSF, it is still necessary to pad the IMX image so it has the same size as specified in the Boot Data section of the IMX image. To obtain this size value, run:

    $ od -X -N 0x30 u-boot-dtb.imx

    The output should be similar to the following:

    0000000 402000d1 87800000 00000000 877ff42c
    0000020 877ff420 **877ff400** 878b3000 00000000
    0000040 **877ff000** **000b6060** 00000000 40b401d2
    0000060

    Where, in this:

    • 877ff400 is the IVT self address.
    • 877ff000 is the program image address.
    • 000b6060 is the program image size.
  2. Pad the image:

    2.1 To calculate the padding, use your output values following the example of this case:

    • IVT offset = 0x877ff400 - 0x877ff000 = 0x400
    • Padding = 0xb6060 - 0x400 = 0xb5c60

    2.2 Then, pad the image:

    $ objcopy -I binary -O binary --pad-to 0xb5c60 --gap-fill=0x00 u-boot-dtb.imx u-boot-dtb.imx.zero-padded
  3. Also, according to the requirement from 6.6.7.1, the final image should have a 0x400 offset for the initial IVT table. For the eMMC setup, we handle this by flashing it to 0x400. However, for the NAND setup, we adjust the image prior to flashing, adding padding at the beginning of the image.

    $ dd bs=1024 count=1 if=/dev/zero | cat - u-boot-dtb.imx.zero-padded > u-boot-dtb.imx

    Changing the final U-Boot specific image name is possible by replacing u-boot-dtb.imx in the command line above with another name of your preference, such as u-boot-dtb.imx.ready. In any case, on step 3 of Deploy the U-Boot binary to an Image, you will have to change u-boot-nand.imx to the name of the final U-Boot specific image in the image.json file. For this, press CTRL+F, search for u-boot-nand.imx, and replace it in all occurences.

Deploy the U-Boot binary to an Image

Now that the adjustments were made, return to the Build U-Boot From Source Code article to deploy the U-Boot binary to an image.



Send Feedback!