【问题标题】:STM32 DFU over UART writes incorrect dataSTM32 DFU over UART 写入不正确的数据
【发布时间】:2019-03-29 08:48:11
【问题描述】:

我正在开发固件更新程序,以便系统中的主控制器可以对其他 STM32 芯片进行编程。如应用笔记AN2606AN3155 中所写,我正在以115200 bps 和8E1 使用UART。目前我正在尝试刷新 STM32F429。我可以毫无问题地读取闪存。

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

当我尝试回读它时,我会在这些位置获得随机值。写入相同的基地址时值始终相同,但写入其他位置时它们会发生变化。

我已将电压范围配置寄存器(AN2606 第 30 页)设置为 0x03,因为我的电源是 3.3V。这个寄存器的解释很混乱,所以我什至不确定这个设置是否正确,我找不到其他可能出错的地方。

更新:

我已尝试写入所有 4 字节对齐的地址,然后将其读回以进行比较。我用各种数据大小做到了这一点。所有写入对扇区的基地址都不正确。失败的地址具有以下模式:

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 

解决方案:

哇!闪存擦除存在一个我没有注意到的问题。

【问题讨论】:

  • 闪存没有保护吗?
  • @vlk 不应该,但我会检查一下。但如果它受到保护,那它怎么能在那里写任何东西呢?
  • 您是否尝试过从 PC 上烧写 MCU(使用经过验证的工具)?
  • 是的。我使用ULINK2进行调试,已经验证通过DFU读取的随机数据与ULINK读取的flash内容匹配。

标签: stm32 uart bootloader stm32f4 dfu


【解决方案1】:

原来的STM bootloader没有提供两个基本功能,在实际开发中效果不佳。

  • 它不提供任何解密,任何人都可以窃取您的固件(因此保护设备没有任何意义,因为您必须发布“普通”未加密的二进制映像)

  • 它不检查闪存中应用程序的完整性

  • 它不适用于受保护的设备

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

【讨论】:

  • 我将在未来某个时候这样做,但现在我必须完成这项工作。
猜你喜欢
  • 2015-08-16
  • 2021-06-06
  • 1970-01-01
  • 2020-04-29
  • 1970-01-01
  • 2022-12-18
  • 2018-09-24
  • 1970-01-01
  • 2017-11-16
相关资源
最近更新 更多