项目场景:
Keil5在魔术棒里勾选 "Use MicroLIB";

问题描述
Keil5在魔术棒里勾选 "Use MicroLIB"后编译报错:
- Error: L6218E: Undefined symbol __use_two_region_memory (referred from startup_stm32wle5xx.o).
- Error: L6218E: Undefined symbol __initial_sp (referred from entry2.o).

原因分析:
- 关于
__use_two_region_memory
错误- 当勾选 “Use MicroLIB” 后,库的环境发生了变化。
__use_two_region_memory
这个符号找不到定义可能是因为 MicroLIB 库与原来的标准库在内存配置方面的处理有所不同。在标准库下可能有一些默认的内存配置相关的定义,但 MicroLIB 可能没有提供或者改变了这些定义的方式。 - 启动文件(
startup_stm32wle5xx.o
)期望这些内存配置相关的符号(如__use_two_region_memory
)被正确定义,用于初始化芯片的内存映射等操作,现在找不到定义就导致了错误。
- 当勾选 “Use MicroLIB” 后,库的环境发生了变化。
- 关于
__initial_sp
错误__initial_sp
是用于定义初始堆栈指针(Stack Pointer)的符号。在正常的编译环境下,这个符号是由启动文件正确生成和定义的。当使用 MicroLIB 后,可能由于库的改变或者链接过程的变化,导致链接器无法找到__initial_sp
的定义(在entry2.o
中引用了这个符号)。- 这可能是因为 MicroLIB 的链接脚本或者库文件没有正确处理与堆栈指针初始化相关的内容,或者与项目中其他自定义的链接设置冲突。
解决方案:
(1)切换编译器
1️⃣打开魔术棒,把 "ARM Compiler" 更改为 V5 版本;
2️⃣重新编译,错误消失;
3️⃣再把 "ARM Compiler” 还原为 V6 版本;
4️⃣重新编译,问题解决;

(2)汇编文件修改
1️⃣键盘 ctrl + F,在 "Find in Files" 栏里检索 initial_sp;

2️⃣在汇编文件中找到 "__initial_sp",注释掉;

3️⃣重新编译,报新的错误;

4️⃣取消注释,重新编译,问题解决;
