我正在尝试在Windows 7上使用JTAG ST-Link/V2写入STM32L476的闪存。无需上传软件,我只需将数据写入可读取和删除的非 volatile 位置。
作为一个硬件方面的新手,并且仅在对非嵌入式常规 C 进行编程时才有效,我担心我可能会损坏或不可挽回地修改闪存。另外,我不太确定我能做什么或不能做什么。
我已经想通了阅读manual在 0x08000000 内存位置写入似乎是个好主意。使用C代码调用ST-Link_Utility :
const char CMD_ACCESS_ST_UTILITY[] = "cd C:/Program Files (x86)/STMicroelectronics/STM32 ST-LINK Utility/ST-LINK Utility&&ST-LINK_CLI.exe ";
bool STLINKWriteSystemCalls(void)
{
char cmd[200] = "";
strcpy(cmd, CMD_ACCESS_ST_UTILITY); // cmd to access utility
strcat(cmd, "-c"); // Then connect with ST-Link
if (system(cmd) != 0)
return false; // If failed exit
strcpy(cmd, CMD_ACCESS_ST_UTILITY);
strcat(cmd, "-r8 0x08000000 0x100"); // Read to check if there is data already
// I haven't managed yet how I'll compare the result of read
// To FFFF but that's not the main issue
if (system(cmd) != 0)
return false; // If failed exit
strcpy(cmd, CMD_ACCESS_ST_UTILITY);
strcat(cmd, "-w8 0x08000000 0x00"); // Write data into 0x080000000
if (system(cmd) != 0)
return false; // If failed exit
return true;
}
关于在哪里编写以及如何编写,是否有更好的方法(错误检查、使用的资源等)?
最佳答案
有关闪存的主要知识:
- 闪存是页可删除的,在您的情况下,页大小为
2K
。这是什么意思?您必须确保您的代码不在页面的2k
范围内。 - 删除后,内存中所有字节的状态均为 0xFF。
- 写入闪存字节意味着,在原始级别,将设置为
1
的位修改为设置为0
的位。如果您想将0
修改为1
,您必须删除整个页面。
ST-Link_Utility
采用嵌入式方式,因此当您写入闪存时,它会删除整个扇区,然后写入数据。如果您的代码需要在使用数据后简化数据,则同样如此。
默认情况下,您的 MCU 在启动时使用 0x0000 0000
别名地址 0x0800 0000
。
第一个单词应包含重置 vector 和默认 vector 表。复位 vector 始终是要执行的第一条指令。此表中的复位 vector 将包含指向包含复位代码的地址的分支。
所以,换句话说,
上电时,处理器跳转到固定位置0x0,这意味着它跳转到0x0800 0000
。显然您选择的地址不正确;)
关于c - 用 C 语言写入 STM32L4x1 闪存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44109227/