Compilation of U-Boot: 1. Pre-requisite 2. Initialise cross-compilation via SDK 3. Prepare U-Boot source code 4. Management of U-Boot source code 5. Compile U-Boot source code 6. Update software on board 1. Pre-requisite: ----------------- OpenSTLinux SDK must be installed. For U-Boot build you need to install: * libncurses and libncursesw dev package - Ubuntu: sudo apt-get install libncurses5-dev libncursesw5-dev - Fedora: sudo yum install ncurses-devel * git: - Ubuntu: sudo apt-get install git-core gitk - Fedora: sudo yum install git If you have never configured you git configuration: $ git config --global user.name "your_name" $ git config --global user.email "your_email@example.com" 2. Initialize cross-compilation via SDK: --------------------------------------- * Source SDK environment: $ source /environment-setup-cortexa7t2hf-neon-vfpv4-ostl-linux-gnueabi * To verify if you cross-compilation environment are put in place: $ set | grep CROSS CROSS_COMPILE=arm-ostl-linux-gnueabi- Warning: the environment are valid only on the shell session where you have sourced the sdk environment. 3. Prepare U-Boot source: ------------------------ Extract the sources from tarball, for example: $ tar xfJ SOURCES-st-image-weston-openstlinux-weston-stm32mp1-*.tar.xz In the U-Boot source directory (sources/*/##BP##-##PR##), you have one U-Boot source tarball, the patches and one Makefile: - ##BP##-##PR##.tar.gz - 000*.patch - Makefile.sdk NB: if you would like to have a git management on the code see section 4 [Management of U-Boot source code with GIT] Then you must extract the tarball and apply the patch: $> tar xfz ##BP##-##PR##.tar.gz $> cd ##BP## $> for p in `ls -1 ../*.patch`; do patch -p1 < $p; done 4. Management of U-Boot source code with GIT -------------------------------------------- If you like to have a better management of change made on U-Boot source, you have 3 solutions to use git 4.1 Get STMicroelectronics U-Boot source from GitHub URL: https://github.com/STMicroelectronics/u-boot.git Branch: v##PV##-stm32mp Revision: v##PV##-stm32mp-##PR## $ git clone https://github.com/STMicroelectronics/u-boot.git $ git checkout -b WORKING v##PV##-stm32mp-##PR## 4.2 Create Git from tarball $ tar xfz ##BP##-##PR##.tar.gz $ cd ##BP## $ test -d .git || git init . && git add . && git commit -m "U-Boot source code" && git gc $ git checkout -b WORKING $ for p in `ls -1 ../*.patch`; do git am $p; done 4.3 Get Git from community and apply STMicroelectronics patches URL: git://git.denx.de/u-boot.git Branch: master Revision: v##PV## $ git clone git://git.denx.de/u-boot.git or $ git clone http://git.denx.de/u-boot.git $ cd u-boot $ git checkout -b WORKING v##PV## $ for p in `ls -1 ../*.patch`; do git am $p; done 5. Compilation U-Boot source code: ---------------------------------- To compile U-Boot source code, first move to U-Boot source: $ cd ##BP## or $ cd u-boot 5.1 Compilation for one target (one defconfig, one device tree) - and no FIP see /board/st/stm32mp1/README for details $ make stm32mp15__defconfig $ make DEVICE_TREE= all example: a) trusted boot on ev1 $ make stm32mp15_trusted_defconfig $ make DEVICE_TREE=stm32mp157c-ev1 all b) basic boot on dk2 $ make stm32mp15_basic_defconfig $ make DEVICE_TREE=stm32mp157c-dk2 all 5.2 Compilation for several targets: use Makefile.sdk (with FIP) Calls the specific 'Makefile.sdk' provided to compile U-Boot: - Display 'Makefile.sdk' file default configuration and targets: $ make -f $PWD/../Makefile.sdk help As mentionned in help, OpenSTLinux has activated FIP by default, so the FIP_artifacts should be specified - In case of using SOURCES-xxxx.tar.gz of Developer package the FIP_DEPLOYDIR_ROOT should be set as below: $> export FIP_DEPLOYDIR_ROOT=$PWD/../../FIP_artifacts - Compile default U-Boot configuration: $> make -f $PWD/../Makefile.sdk all Default U-Boot configuration is done in 'Makefile.sdk' file through two specific variables 'DEVICE_TREE' and 'UBOOT_CONFIGS': - 'DEVICE_TREE' is a list of device tree to build, using 'space' as separator. ex: DEVICE_TREE=" " - 'UBOOT_CONFIGS' is a list of ',,' configurations, is the u-boot defconfig to use to build is the name append to u-boot binaries (ex: 'trusted', 'basic', etc) is the u-boot binary to export (ex: 'u-boot.bin', 'u-boot.stm32', etc) ex: UBOOT_CONFIGS=",basic,u-boot.bin ,trusted,u-boot.stm32" The generated FIP images are available in $FIP_DEPLOYDIR_ROOT/fip You can override the default U-Boot configuration if you specify these variables: - Compile default U-Boot configuration but applying specific devicetree(s): $ make -f $PWD/../Makefile.sdk all DEVICE_TREE=" " - Compile for a specific U-Boot configuration: $ make -f $PWD/../Makefile.sdk all UBOOT_CONFIGS=,, - Compile for a specific U-Boot configuration and applying specific devicetree(s): $ make -f $PWD/../Makefile.sdk all UBOOT_CONFIGS=,, DEVICE_TREE=" " 6. Update software on board: ---------------------------- Please use STM32CubeProgrammer and only tick the ssbl-boot and fip partition (more informations on the wiki website http://wiki.st.com/stm32mpu)