首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >UART上的STM32 DFU写入不正确的数据

UART上的STM32 DFU写入不正确的数据
EN

Stack Overflow用户
提问于 2018-10-24 20:25:20
回答 1查看 458关注 0票数 1

我正在开发固件更新程序,这样系统中的主控制器就可以对其他STM32芯片进行编程。我使用115200 bps的UART和8E1,如应用程序注释AN2606AN3155中所写。目前,我正在尝试闪存一个STM32F429。我可以毫无问题地阅读闪光灯。

为了测试写入功能,我编写了8个字节到地址,这些地址是AN3155中建议的4的倍数。我用逻辑分析器检查了数据线,一切都正确地发送,STM响应ACK。

当我试着把它读回来时,我会得到那些位置的随机值。当写入相同的基址时,值总是相同的,但在其他地方写入时它们会发生变化。

我已经将电压范围配置寄存器(AN2606页面30)设置为0x03,因为我的电源是3.3V。对这个寄存器的解释非常混乱,所以我甚至不确定这个设置是否正确,也找不到任何可能出错的地方。

更新:

我试着写到所有4字节对齐的地址,然后把它读回来进行比较。我用不同的数据大小做了这件事。对于扇区的基地址,所有写入都是不正确的。失败的地址有以下模式:

代码语言:javascript
复制
Bytes   Incorrect write addresses
  4     0, 10, 20, 30, ...
  8     0, 0C, 1C, 2C, 3C, ...
 12     0, 08, 18, 28, 38, ...
 16     0, 04, 14, 24, 34, ...
 32     0  04, 14, 24, 34, ...
 64     0, 04, 08, 0C, 14, 18, 1C, 24, ...
128     all 
256     all 

解决方案:

哈!闪光灯擦除有一个问题,我没有注意到。

EN

回答 1

Stack Overflow用户

发布于 2018-10-25 15:33:17

最初的STM引导加载程序在实际开发中并不是很好,因为它没有提供两个基本功能。

  • 它不提供任何解密,而且您的固件可能被任何人窃取(因此保护设备没有任何意义,因为您必须发布“普通”而不是加密的二进制图像)。
  • 它不会在闪存中检查应用程序的完整性。
  • 它不适用于受保护的设备。

最简单的方法是编写自己的引导加载程序并实现所有这些函数。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52977428

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档