If the bootloader has been erased from the storage media (or written with an invalid image) and the target does not boot, you can boot the target from a microSD card, or from USB debug mode.

Boot U-Boot from the microSD card

Requirements

  • Root/administrator permissions in your development computer

  • A microSD card with a minimum capacity of 2 GB

The following procedure will destroy existing data in the microSD card.

Create a bootable microSD

  1. Download the U-Boot bootloader binary image file from:

    See Hardware variants to verify which U-Boot binary you need.
  2. Copy the U-Boot file into a folder of your choice.

  3. Insert the microSD card into your computer and check the node Linux assigns to it (/dev/<sdcard>) using dmesg:

    $ dmesg
    [1413652.901270] sd 41:0:0:0: [sdc] 7744512 512-byte logical blocks: (3.96 GB/3.69 GiB)
    [1413652.903140] sd 41:0:0:0: [sdc] No Caching mode page present
    [1413652.903144] sd 41:0:0:0: [sdc] Assuming drive cache: write through
    [1413652.905638] sd 41:0:0:0: [sdc] No Caching mode page present
    [1413652.905642] sd 41:0:0:0: [sdc] Assuming drive cache: write through
    [1413652.915154] sdc: sdc1

    Do not mount any partitions the card might contain (or unmount any partition if automatically mounted), as you will be writing to the entire block device.

    Using an incorrect device node in the next step might destroy all data on your computer hard drive.
  4. Raw write the image file to the microSD card with this command:

    ~$ sudo dd if=<path/filename.imx> of=/dev/<sdcard> bs=512 seek=2 oflag=sync
    • <path/filename.imx> must be substituted with the path and filename to the U-Boot image.

    • <sdcard> must be substituted with the device node that Linux assigns to your microSD card.

The microSD card is now ready.

Instructions

  1. Power off the device.

  2. Insert the microSD card into the microSD card holder (bottom side of the board).

  3. Change the boot source configuration to boot from the microSD card. To do so, set the boot mode micro-switches as follows:

    • BOOT.1 OFF

    • BOOT.2 ON

      microSD boot
  4. Power on the device.

Boot U-Boot in USB debug mode

Requirements

  • Linux host computer.

  • Root/administrator permissions on your development computer

  • The Digi Embedded Yocto SDK already installed. For installation instructions, see Application development.

  • Serial console cable.

  • A micro USB cable.

Instructions

  1. Connect the micro USB cable to the USB device port of the SBC (bottom side, under the USB host connectors) and the other end to the development computer.

  2. Change the boot mode configuration to boot from USB. To do so, set the boot mode micro-switches as follows:

    • BOOT.1 ON

    • BOOT.2 ON

      USB boot
  3. Open a serial terminal at 115200/8/n/1.

  4. Power up the board.

  5. On the host computer run the imx_usb tool from the SDK directory as root with the U-Boot file to boot as parameter. For example:

    ~$ sudo /opt/dey/2.6-r3/ccimx6qpsbc/sysroots/x86_64-deysdk-linux/usr/bin/imx_usb </path/to/u-boot-file>

The serial terminal shows the device starting U-Boot.

If you installed the Digi Embedded Yocto SDK in a location other than the default location, you must use the -c parameter to specify the directory containing the configuration files.

Use the following syntax, replacing ${SDK_FOLDER} with the name of the non-standard folder where the SDK was installed:

${SDK_FOLDER}/sysroots/x86_64-deysdk-linux/usr/bin/imx_usb -c ${SDK_FOLDER}/sysroots/x86_64-deysdk-linux/etc/imx-loader.d/

Instructions for closed devices

With TrustFence enabled, signed U-Boot images are created. To boot signed U-Boot images on a closed device, you must configure the imx_usb application provided with Digi Embedded Yocto as follows:

  • Modify the mx6_usb_work.conf configuration under /opt/dey/2.6-r3/ccimx6qpsbc/sysroots/x86_64-deysdk-linux/etc/imx-loader.d/, adding the following lines:

    /path/to/u-boot.imx:dcd
    /path/to/u-boot-usb-signed.imx:no_clear_boot_data,jump header

    Replace /path/to/u-boot.imx with the path to the unsigned u-boot image and /path/to/u-boot-signed-usb.imx with the path to the signed USB bootable image.

  • Execute the imx_usb_loader tool without a U-Boot image argument:

    ~$ sudo /opt/dey/2.6-r3/ccimx6qpsbc/sysroots/x86_64-deysdk-linux/usr/bin/imx_usb

Update U-Boot in the eMMC

Once U-Boot is running, you can use it to update the bootloader in the eMMC:

Update bootloader from Ethernet (TFTP)

  1. Place the U-Boot binary inside your host computer TFTP exported folder.

  2. On the target, configure your network settings (IP of the device, IP of the host/server):

    => setenv ipaddr <your-ip>
    => setenv serverip <server-ip>
  3. Connect an Ethernet cable to the Ethernet port.

  4. Run the following command to update U-Boot into the eMMC:

    => update uboot tftp <u-boot-filename>.imx
  5. Change the boot source configuration to boot from the internal eMMC.

    To do so, set the boot mode micro-switches as follows:

    • BOOT.1 OFF

    • BOOT.2 OFF

      eMMC boot
  6. Power-cycle the board. The target now boots from the eMMC.

Update bootloader from microSD card

  1. Place the U-Boot binary inside a FAT-formatted microSD card.

  2. Insert the microSD card in the board.

  3. Run the following command to update U-Boot into the eMMC:

    => update uboot mmc 1 fat <u-boot-filename>.imx
  4. Change the boot source configuration to boot from the internal eMMC.

    To do so, set the boot mode micro-switches as follows:

    • BOOT.1 OFF

    • BOOT.2 OFF

      eMMC boot
  5. Power-cycle the board. The target now boots from the eMMC.