
仔细读了N6的使用手册和例程手册后,了解了N6的使用过程。主要进行到GUI编程的时候,出现的困惑。想来先通过点灯的方式来了解外部存储器的使用。& G7 X" N6 s1 V3 Y 板载的外部存储器,如图1所示:- M* k( _& Z& A6 q3 C ![]() 图16 \4 S- L* O! [) Q9 w 阅读文档以后,基本是了解N6的使用流程的。比如boot模式,有两种启动模式,如图2所示: ![]() 图2 Dev boot是在内部Ram中启动,Flash boot是bootrom 程序尝试从外部flash 启动,应用程序需要下载到外部的flash。2 C5 |: v1 S( A7 _. x8 R1 e5 i 了解到这个以后,主要参考例程中的FSBL_LRUN 和FSBL_XIP。工程项目可以是FSBL的,也可以是FSBL+APPLI的。这两个项目模板介绍了连接到外部存储器的使用。 读Readme markdown文档后,会发现整个的启动过程。主要以LRUN项目为学习目标,APPLI烧写到外部Flash, FSBL 还在SRAM中使用,可以debug。以点灯为了解目标。/ R9 r) G0 @% G0 K/ c; q% m/ f( \ 在IDE中打开项目,分别编译FSBL和APPLI文件。使用0 @1 x' L+ v1 O D; E0 m- q$ S! w0 G STM32_SigningTool_CLI.exe -bin APPLI.bin -nk -of 0x80000000 -t fsbl -o FSBL-trusted.bin -hv 2.3 -dump APPLI-trusted.bin 在cmd 命令窗口中使用这条指令,需要注意.bin文件的路径也需要加入到命令中。编译成功后如图3所示:- h( U# g4 E* k7 Z( ~/ ]1 {" p ![]() 图3 这个过程主要是给bin文件加信息头(正确签名),毕竟要写入到外部存储器。看到debug文件夹里会有两个bin,一个是APPLI.bin,一个是APPLI-trusted.bin,这两文件都要通过Programmer烧入 到外部Flash中。$ K6 s J, {/ J$ P 打开STM32CubeProgrammer,connect到板卡,设置外部存储器,如图4所示:, T3 T# `' E' T0 y: W ![]() 图4: J& Q. U+ E4 ^ S; b0 H 下载设置如图5所示:* {; ~8 t# v9 t4 } ![]() 图5# E9 o7 ], }7 h8 t5 K0 A, M 将生成的appli.bin和appli-trust.bin分别下载到flash中,下载完成后,然后再IDE 中debug FSBL project,可以看到如预期所示,如图6所示: ![]() 图6 如果想上电就使用外部Flash启动,可以参考APPLI加签名的方式,也给FSBL加签名,也烧入外部Flash中,注意这两个项目的烧写地址不一样。将按键开关都拨到左边,重新上电,和预期一样。 |
Keil下的STM32N6之RAM运行工程配置说明
【STM32N6570-DK评测】5.驱动LCD
STM32N6坛友评测出炉,来围观(第二波预约继续)
【STM32N6570-DK评测】 烧写程序到外部存储器
【STM32N6570-DK评测】移植FreeRTOS系统
【STM32N6570-DK评测】5.STM32N6的FSBL介绍
【STM32N6570-DK评测】 4. 使用TouchGFX 生成CubeMX文件的Bug
【STM32N6570-DK评测】摄像头video encoder
STM32N6570 OTP配置
【STM32N6570-DK评测】3.CubeMX关于DCMIPP和CSI的BUG整理及摄像头使用
是不是只要程序不大于FSBL的空间,就不用APP跳转的事?
嗯,我是这么理解的