u-boot/board/liebherr/xea
Lukasz Majewski 9c2eefaf0d spl: xea: Provide stub DM driver for imx28 clocks
This code fixes following WARNING:
  DTOC    spl/dts/dt-plat.c
fsl_imx28_clkctrl: WARNING: the driver fsl_imx28_clkctrl was not found in the driver list

As imx28 doesn't yet support common clock framework, this prevents from
DTOC warnings during SPL build.

Signed-off-by: Lukasz Majewski <lukma@denx.de>
2023-07-11 14:40:04 +02:00
..
Kconfig imx: Add support for i.MX28 based XEA board 2020-01-07 10:26:56 +01:00
MAINTAINERS arm: xea: config: Provide special defconfig for a single binary u-boot 2022-02-05 13:38:39 +01:00
Makefile imx: Add support for i.MX28 based XEA board 2020-01-07 10:26:56 +01:00
README imx: Add support for i.MX28 based XEA board 2020-01-07 10:26:56 +01:00
spl_xea.c arm: xea: Modify board code to generate single binary u-boot 2022-02-05 13:38:39 +01:00
xea.c spl: xea: Provide stub DM driver for imx28 clocks 2023-07-11 14:40:04 +02:00

Building SPL/U-Boot for xea board
=================================

Setup environment, configure and build, e.g. by:

 $ make imx28_xea_defconfig
 $ make -j4 u-boot.sb u-boot.img

Now you should see u-boot.sb and u-boot.img files in the build directory.


Booting
=======

The boot ROM loads SPL from SPI NOR flash into SRAM.  SPL configures
DRAM and loads either a Linux kernel (falcon mode) or, if the rescue
pin is asserted, the main U-Boot.  Both kernel and U-Boot reside in
eMMC boot partition 0.  For redundancy, a copy of U-Boot is also
stored in SPI flash.  If a valid kernel image is not found, U-Boot is
loaded from eMMC or, if this fails, SPI flash.

Boot area layout
----------------

SPI NOR
Offset          Function        File
------------------------------------------
0x00000000      SPL             u-boot.sb
0x00010000      U-Boot          u-boot.img
0x00080000      Environment

eMMC
Offset          Function        File
------------------------------------------
0x00000000      U-Boot          u-boot.img
0x00080000      Devicetree      imx28-bttc.dtb
0x00100000      Kernel          uImage


Falcon mode
===========

In falcon mode, the default, SPL loads the kernel and devicetree
directly.  For this to work, the stored devicetree must include
correct "memory" and "chosen" nodes as these are not updated by SPL
before booting the kernel.


Updating from U-Boot
====================

The default U-Boot environment includes command sequences to update
SPL, U-Boot, and kernel over TFTP.  These are as follows:

- update_spl: writes u-boot.sb to SPI NOR
- update_uboot: writes u-boot.img to eMMC and SPI NOR
- update_kernel: writes kernel and devicetree to eMMC

They can be invoked at the U-Boot prompt using the "run" command,
e.g. "run update_spl" to update the SPL.

These update commands download the above-named files from the
${hostname} directory on the server provided by DHCP.