新建工程
输入STM32MP257DAK3

勾选第二个选项 - A35 Master with Cotex M33 TrustZone actived

保存工程

配置DDR_CTRL_PHY如下图所示,点击生成代码

配置串口USART2,用作输出串口调试信息

准备external-dt-6.0-r0
参考external-dt-6.0-r0目录下README.HOW_TO.txt.stm32mp2,非常重要!!!
!!!注意:如果是在当前的shell环境下面,则不需要重新声明TF-A的环境变量
export EXTDT_DIR=/home/niuke/develop/STM32MP2/Develop-Package/stm32mp-openstlinux-6.6-yocto-scarthgap-mpu-v25.08.27/sources/ostl-linux/external-dt-6.0-r0/external-dt-6.0
cd external-dt-6.0-r0/
vi test.sh
#在test.sh增加以下内容,参考README.HOW_TO.txt.stm32mp2的2.1,打补丁+git管理
tar xf external-dt-6.0-r0.tar.xz
cd external-dt-6.0
test -d .git || git init . && git add . && git commit -m "new dt" && git gc
git checkout -b WORKING
#end of test.sh
/bin/bash test.sh
建立软连接
cd external-dt-6.0/stm32mp2/a35-td/tf-a/
ln -sf ~/develop/STM32CubeMX/DEVELOP/CA35/DeviceTree/DEVELOP/tf-a/* ./
cd ../optee/
ln -sf ~/develop/STM32CubeMX/DEVELOP/CA35/DeviceTree/DEVELOP/optee-os/* ./
cd ../u-boot/
ln -sf ~/develop/STM32CubeMX/DEVELOP/CA35/DeviceTree/DEVELOP/u-boot/* ./
编译TF-A
source ~/sdk6.6_mp2
export FIP_DEPLOYDIR_ROOT=/home/niuke/develop/STM32MP2/test/stm32mp-openstlinux-6.6-yocto-scarthgap-mpu-v25.08.27/sources/ostl-linux/FIP_artifacts
export EXTDT_DIR=/home/niuke/develop/STM32MP2/test/stm32mp-openstlinux-6.6-yocto-scarthgap-mpu-v25.08.27/sources/ostl-linux/external-dt-6.0-r0/external-dt-6.0
export FWDDR_DIR=/home/niuke/develop/STM32MP2/test/stm32mp-openstlinux-6.6-yocto-scarthgap-mpu-v25.08.27/sources/ostl-linux/stm32mp-ddr-phy-A2022.11-r0/stm32mp-ddr-phy-A2022.11
export DEPLOYDIR=$FIP_DEPLOYDIR_ROOT/arm-trusted-firmware
#进入TF---A源码目录
cd tf-a-stm32mp-v2.10.13-stm32mp-r2/
make -f $PWD/../Makefile.sdk.stm32mp2 clean
#EMMC启动
make -f $PWD/../Makefile.sdk.stm32mp2 TF_A_DEVICETREE=stm32mp257d-develop-mx TF_A_CONFIG=optee-emmc ELF_DEBUG_ENABLE='1' stm32
#STM32CUbeMX USB下载
make -f $PWD/../Makefile.sdk.stm32mp2 TF_A_DEVICETREE=stm32mp257d-develop-mx TF_A_CONFIG=optee-programmer-usb ELF_DEBUG_ENABLE='1' stm32
make -f $PWD/../Makefile.sdk.stm32mp2 metadata
编译成功,如下图所示

编译optee
cd ../../optee-os-stm32mp-4.0.0-stm32mp-r2-r0/optee-os-stm32mp-4.0.0-stm32mp-r2/
export DEPLOYDIR=$FIP_DEPLOYDIR_ROOT/optee
make -f $PWD/../Makefile.sdk.stm32mp2 clean
make -f $PWD/../Makefile.sdk.stm32mp2 CFG_EMBED_DTB_SOURCE_FILE=stm32mp257d-develop-mx optee

编译uboot和生成fip文件
cd ../../u-boot-stm32mp-v2023.10-stm32mp-r2-r0/u-boot-stm32mp-v2023.10-stm32mp-r2/
export DEPLOYDIR=$FIP_DEPLOYDIR_ROOT/u-boot
make -f $PWD/../Makefile.sdk.stm32mp2 clean
make -f $PWD/../Makefile.sdk.stm32mp2 UBOOT_CONFIG=default FIP_CONFIG=optee-emmc UBOOT_DEFCONFIG=stm32mp25_defconfig UBOOT_BINARY=u-boot.dtb DEVICE_TREE=stm32mp257d-develop-mx all
make -f $PWD/../Makefile.sdk.stm32mp2 UBOOT_CONFIG=programmer FIP_CONFIG=optee-programmer-usb UBOOT_DEFCONFIG=stm32mp25_defconfig UBOOT_BINARY=u-boot.dtb DEVICE_TREE=stm32mp257d-develop-mx all

下一章
自制Flash.tsv文件
从零开始修改STM32CubeMX配置
使用STM32 Programmer烧录