Building the MitySOM-AM62 U-Boot¶
- Table of contents
- Building the MitySOM-AM62 U-Boot
Before you begin¶
There are multiple ways to customize and compile the U-Boot for your project. Please try to build U-Boot as-is with no changes before you add your customizations. This will ensure your environment and toolchain are setup correctly.
- Docker Build - Build using a Docker image (as described in Docker Build Environment )
- Linux Manual Install - You can use a previously compiled ARM toolchain provided by ARM by installing it on a Linux system.
- Yocto Environment - If you are using the docker environment and Yocto for your filesystem, you can use its tools to customize and build U-Boot.
In most cases, you will use one of the first three options to build U-Boot for Critical Link development kit. Then, once you have everything working you can integrate your custom code into the U-Boot source.
Critical Link recommends using the mitysom-u-boot-2025.01 branch on our git server: https://support.criticallink.com/git/u-boot-ti.git.
Other MitySOM-AM62x U-Boot branches seen on the repository should not be considered stable, and are used for internal feature development.
U-Boot Build - Docker¶
See  Docker build environment for details on how to setup and install the Docker build environment. Once that is installed, you can build U-Boot using the following commands: 
git clone --branch mitysom-u-boot-2025.01 https://support.criticallink.com/git/u-boot-ti.git cd u-boot-ti docker run --rm --volume "$PWD:/work" --workdir=/work mitysom_ubuntu:22.04 ./62x-build.sh -i # Or ./62ax-build.sh -i Or ./62px-build.sh
Note that for the AM62a, please install the TI Processor SDK and mount the volume (--volume /home/tools/mitysom-62x:/home/tools/mitysom-62x) before running the build.
If the build is successful, subsequent use of the script can omit the -i option.
Please refer to the "Verifying Your U-Boot Output" section of this wiki page to verify your build and the next steps.
U-Boot Build - Linux Manual Install¶
Click here to view instructions...
U-Boot Build - Yocto¶
Verifying Your U-Boot Output¶
If successful, the build script lists the output binaries after completing the build:
-rw-r--r-- 1 user mitysom 298101 May 16 13:48 /work/build-mitysom_am62x_devkit/r5/tiboot3-am62x-gp-evm.bin -rw-r--r-- 1 user mitysom 331 May 16 13:48 /work/build-mitysom_am62x_devkit/r5/tiboot3-am62x-gp-evm.bin.map -rw-r--r-- 1 user mitysom 300690 May 16 13:48 /work/build-mitysom_am62x_devkit/r5/tiboot3-am62x-hs-evm.bin -rw-r--r-- 1 user mitysom 374 May 16 13:48 /work/build-mitysom_am62x_devkit/r5/tiboot3-am62x-hs-evm.bin.map -rw-r--r-- 1 user mitysom 300690 May 16 13:48 /work/build-mitysom_am62x_devkit/r5/tiboot3-am62x-hs-fs-evm.bin -rw-r--r-- 1 user mitysom 377 May 16 13:48 /work/build-mitysom_am62x_devkit/r5/tiboot3-am62x-hs-fs-evm.bin.map lrwxrwxrwx 1 user mitysom 29 May 16 13:48 /work/build-mitysom_am62x_devkit/r5/tiboot3.bin -> ./tiboot3-am62x-hs-fs-evm.bin -rw-r--r-- 1 user mitysom 1149851 May 16 13:48 /work/build-mitysom_am62x_devkit/a53/tispl.bin -rw-r--r-- 1 user mitysom 960075 May 16 13:48 /work/build-mitysom_am62x_devkit/a53/u-boot.img
Update Your Boot Media¶
You need to copy three files to your boot media (ex: SD card) to test your new build:- tispl.bin
- u-boot.img
- tiboot3.bin- you need to rename the .bin file that corresponds to your AM62x processor variant (GP or HS-FS)- If your SOM is using a GP variant, rename tiboot3-am62x-gp-evm.bintotiboot3.bin
- If your SOM is using a HS-FS variant, rename tiboot3-am62x-hs-evm.bintotiboot3.bin
 
- If your SOM is using a GP variant, rename 
The differences between GP, HS, and HS-FS, are discussed here.
Deploy Scripts/Helpful Scripts¶
Several additional scripts are provided to do helpful things.
62x-copy.sh - Copies the files to a locally mounted SD card (assumed to be at /media/$USER).62x-push.sh - Push the files to a SD card connected to a board over the network. You must supply a SSH connection string as the first argument (ex: root@<board ip address> ) or configure a ssh host target.
Note corresponding 62ax-copy.sh, 62ax-push.sh, 62px-copy.sh, and 62px-push.sh exist as well.
Verifying Your U-Boot Build¶
When U-Boot boots, it will display the build date and time. Please check this to make sure your new U-Boot files are being used.
For example, note the multiple dates, one for each stage of the boot process. If you are using the HS or HS-FS part, you will see additional messages relating to the secure boot process:
U-Boot SPL 2025.01-geb906e458577 (Jun 23 2025 - 13:43:32 +0000) SYSFW ABI: 4.0 (firmware rev 0x000b '11.0.7--v11.00.07 (Fancy Rat)') Configuring LPDDR4 for 4GB SPL initial stack usage: 17048 bytes Trying to boot from MMC2 ... U-Boot SPL 2025.01-geb906e458577 (Jun 23 2025 - 13:43:32 +0000) SYSFW ABI: 4.0 (firmware rev 0x000b '11.0.7--v11.00.07 (Fancy Rat)') SPL initial stack usage: 1808 bytes Trying to boot from MMC2 ... U-Boot 2025.01-geb906e458577 (Jun 23 2025 - 13:43:32 +0000) SoC: AM62X SR1.0 HS-FS Model: Critical Link MitySOM-AM62x MitySOM-62x - Model No: 6254-TX-X9E-RC Serial No: 25004268 Part Number: 80-001744RC-5A DRAM: 4 GiB Core: 105 devices, 32 uclasses, devicetree: separate MMC: mmc@fa10000: 0, mmc@fa00000: 1
Customizing U-Boot for your Application¶
Now that you can build U-Boot, you can customize the U-Boot source code for your specific application.
For most projects, you will want a custom defconfig and a custom pinmux. Example defconfigs can be found in the configs/ directory. It is recommended that you start with a similar board as a reference for your own configuration. You will need to update the build.sh script to use your custom defconfig files (search for defconfig to find the relevant strings).
An example pinmux for Critical Link's development board can be found in board/cl/mitysom-62x/mux_data.h.
Please contact Critical Link at info@criticallink.com if you need help with customizing your defconfig and pinmux for your application.
Saveenv note¶
Since SDK 09, the saveenv command has been removed from u-boot. Now environment settings must be done in uEnv.txt. To save variables to uEnv.txt within the bootloader, run the following commands (note that <list of variables> should be environment variables you want to be exported):
env export -t $loadaddr <list of variables>
fatwrite mmc ${mmcdev} ${loadaddr} ${bootenvfile} ${filesize}
	
Go to top
 
  
  