Linux on the i.MX6 sabre sd platform in a few commands

Document created by Vincent Stehle Employee on Jun 21, 2013Last modified by Vincent Stehle Employee on Mar 26, 2015
Version 19Show Document
  • View in full screen mode


Here is a quick summary at booting Linux on the i.MX 6 sabre sd platform.


This assumes you already have u-boot working on your platform as described here. This implies you already have a "working" Linux development environment with some ARM cross-compilers at hand (e.g. Debian + Emdebian).


Get Linux sources


We will use git to fetch Linux sources:

  $ git clone git://

This should create a linux directory with all the latest sources (after a while).

Note that for more stability you might want to checkout a release instead of the latest version; to do so, list the available release tags with e.g. git tag -l 'v*', and git checkout <the-desired-tag>.




Assuming your cross compiler is called e.g. arm-linux-gnueabihf-gcc, you can compile by doing:


  $ cd linux

  $ export ARCH=arm

  $ export CROSS_COMPILE=arm-linux-gnueabihf-

  $ make imx_v6_v7_defconfig

  $ make

You then need to supply a LOADADDR (as JooWon Kim pointed out); do:

  $ make uImage LOADADDR=0x10008000

This should create a number of files, including arch/arm/boot/uImage and arch/arm/boot/dts/imx6q-sabresd.dtb.


Put on SD

We need a proper FAT partition on the SD card, from which u-boot will be able to load the kernel and dtb. Also, we need to make sure we leave some space for u-boot starting from offset 1024B. Here is an example SD card layout:



  | MBR |  ... | u-boot | ... | FAT partition ...


  0     512    1024           1M


(offsets in bytes)


Here is an example SD card layout, as displayed by fdisk:


  Device    Boot      Start         End      Blocks   Id  System

  /dev/sdc1            2048     8054783     4026368    c  W95 FAT32 (LBA)


(units: 512B sectors)


You can format the FAT partition, mount, copy and unmount with:

  $ mkfs.vfat /dev/<your-sd-card-first-partition>

  $ mount /dev/<your-sd-card-first-partition> /mnt

  $ cp arch/arm/boot/uImage arch/arm/boot/dts/imx6q-sabresd.dtb /mnt/

  $ umount /mnt

Your SD card first partition is typically something in /dev/sd<X>1 or /dev/mmcblk<X>p1. Note that you need write permissions on the SD card for the command to succeed, so you might need to su - as root, or use sudo, or do a chmod a+w as root on the SD card device node to grant permissions to users.

Also, be sure to have u-boot on the SD card as explained in this post.




That's it; u-boot already knows how to deal with your kernel by default so you are good to go. Insert the SD card into the SD card slot of your i.MX6 sabre sd platform, connect to the USB to UART port with a serial terminal set to 115200 baud, no parity, 8bit data and power up the platform. You should see u-boot messages:


  U-Boot 2013.07-rc1-00014-g74771f4 (Jun 21 2013 - 16:27:39)

u-boot should load the uImage and dtb from SD card and boot the kernel:


  reading uImage

  4215344 bytes read in 449 ms (9 MiB/s)

  Booting from mmc ...

  reading imx6q-sabresd.dtb

  22818 bytes read in 22 ms (1012.7 KiB/s)

  ## Booting kernel from Legacy Image at 12000000 ...

     Image Name:   Linux-3.10.0-rc6

     Image Type:   ARM Linux Kernel Image (uncompressed)

     Data Size:    4215280 Bytes = 4 MiB

     Load Address: 10008000

     Entry Point:  10008000

     Verifying Checksum ... OK

  ## Flattened Device Tree blob at 11000000

     Booting using the fdt blob at 0x11000000

     Loading Kernel Image ... OK


     Using Device Tree in place at 11000000, end 11008921



  Starting kernel ...


The kernel should boot:


  Booting Linux on physical CPU 0x0

  Linux version 3.10.0-rc6 (vstehle@debian) (gcc version 4.7.2 (Debian 4.7.2-5) ) #1 SMP Fri Jun 21 18:09:26 CEST 2013

By default, the kernel will try to mount a root filesystem from the SD card second partition, as can be read in the default kernel command line:


  Kernel command line: console=ttymxc0,115200 root=/dev/mmcblk1p2 rootwait rw


...but we did not prepare a root filesystem partition, so after a number of boot messages the kernel will wait indefinitely:



  mmc1: new SDHC card at address b368


   mmcblk0: p1


  Waiting for root device /dev/mmcblk1p2...


We will see in another post how to prepare this root filesystem on the second SD card partition. Enjoy!


See also...


  • If you plan to compile Linux often, you might want to use a C compiler cache; see this post.
  • Once you have Linux booting on your platform the next step is to give it a root filesystem. See this post for a Debian root filesystem, this post for a minimal busybox filesystem and this post for generating a root filesystem with buildroot.
6 people found this helpful