joe*_*ski 2 arm openocd stm32l152 cortex-m
我正在尝试将我的固件刷新到 STM32L152,但我有:
打开片上调试器 0.10.0+dev-00312-g1a3cbbf3 (2018-03-02-20:11)
根据 GNU GPL v2 授权
有关错误报告,请阅读
http://openocd.org/doc/doxygen/bugs.html
适配器速度:300 kHz
适配器_nsrst_延迟:100
信息:选定的传输接管了低级目标控制。与普通 JTAG/SWD 相比,结果可能有所不同
没有单独的
信息:无法匹配请求的速度 300 kHz,使用 240 kHz
信息:无法匹配请求的速度 300 kHz,使用 240 kHz
信息:时钟速度 240 kHz
信息:STLINK v2 JTAG v28 API v2 SWIM v6 VID 0x0483 PID 0x3748
信息:使用 stlink api v2
信息:目标电压:1.769170
信息:stm32l1.cpu:硬件有 6 个断点,4 个观察点
信息:在端口 3333 上侦听 gdb 连接
信息:无法匹配请求的速度 300 kHz,使用 240 kHz
信息:无法匹配请求的速度 300 kHz,使用 240 kHz
适配器速度:240 kHz
目标由于调试请求而停止,当前模式:线程
xPSR:0x01000000 PC:0x0800b324 msp:0x20007ffc
STM32L:启用HSI
信息:无法匹配请求的速度 2000 kHz,使用 1800 kHz
信息:无法匹配请求的速度 2000 kHz,使用 1800 kHz
适配器速度:1800 kHz
** 编程开始 **
自动擦除已启用
信息:设备:STM32L1xx(Cat.3 - 中等+密度)
信息:STM32L闪存大小为256kb,基地址为0x8000000
警告:未找到地址 0x00000000 的闪存组
在 0.003700 秒(0.000 KiB/秒)内从文件 build/firmware.bin 写入 0 个字节
** 编程完成 **
** 验证已开始 **
目标由于断点而停止,当前模式:线程
xPSR:0x61000000 PC:0x2000002e msp:0x20007ffc
错误:校验和不匹配 - 尝试二进制比较
差异 0 地址 0x00000004。是 0x25 而不是 0xb5
差异 1 地址 0x00000005。是 0xb3 而不是 0xa7
~~~~~有很多~~
超过128个错误,其余不打印。
** 验证失败 **
调用关闭命令
固件配置文件
来源[查找接口/stlink.cfg] 设置 WORKAREASIZE 0x8000 传输选择 hla_swd 源[查找目标/stm32l1.cfg] 初始化重置停止 程序 build/firmware.bin 验证重置退出
有趣的是,当尝试编程时firmware.elf,一切都很好。当然,firmware.bin是从 生成的firmware.elf,因此它们共享相同的链接器脚本(或者我在这部分上错了?):
MEMORY
{
FLASH (rx) : ORIGIN = 0x08000000, LENGTH = 256K
RAM (xrw) : ORIGIN = 0x20000000, LENGTH = 32K
}
...
我也尝试过 OpenOCD0.10.0和0.9.0.
从文件 build/firmware.bin 写入 0 个字节
firmware.bin 丢失了其偏移信息,因为它是原始二进制格式。您最好尝试直接刷新firmware.elf 文件。
或者,您可以尝试将正确的闪存偏移量放入 OpenOCD 命令中:
program build/firmware.bin 0x08000000 verify reset exit
Run Code Online (Sandbox Code Playgroud)