Keil5报错:Error: L6218E: Undefined symbol __initial_sp (referred from entry2.o).

项目场景:

Keil5 在魔术棒里勾选 "Use MicroLIB"
图1 勾选 "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).

图2 编译报错


原因分析:

  • 关于 __use_two_region_memory 错误
    • 当勾选**"Use MicroLIB"** 后,库的环境发生了变化。__use_two_region_memory 这个符号找不到定义可能是因为 MicroLIB库与原来的标准库在内存配置方面的处理有所不同。在标准库下可能有一些默认的内存配置相关的定义,但 MicroLIB 可能没有提供或者改变了这些定义的方式。
    • 启动文件(startup_stm32wle5xx.o )期望这些内存配置相关的符号(如**__use_two_region_memory**)被正确定义,用于初始化芯片的内存映射等操作,现在找不到定义就导致了错误。
  • 关于 __initial_sp 错误
    • __initial_sp 是用于定义初始堆栈指针(Stack Pointer )的符号。在正常的编译环境下,这个符号是由启动文件正确生成和定义的。当使用 MicroLIB 后,可能由于库的改变或者链接过程的变化,导致链接器无法找到**__initial_sp** 的定义(在**entry2.o**中引用了这个符号)。
    • 这可能是因为 MicroLIB的链接脚本或者库文件没有正确处理与堆栈指针初始化相关的内容,或者与项目中其他自定义的链接设置冲突。

解决方案:

(1)切换编译器

1️⃣打开魔术棒,把 "ARM Compiler" 更改为 V5版本;

2️⃣重新编译,错误消失;

3️⃣再把**"ARM Compiler"** 还原为 V6版本;

4️⃣重新编译,问题解决;
图3 编译器切换

(2)汇编文件修改

1️⃣键盘ctrl + F ,在 "Find in Files" 栏里检索 initial_sp
图4 寻找 initial_sp

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

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

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

相关推荐
壹~39 分钟前
详解开漏输出和推挽输出
单片机·嵌入式硬件
czhaii3 小时前
轴承排列自动运行 定时器 外中断 PWM部分程序
嵌入式硬件
湮雨塵飛15 小时前
ESP32开发之LED闪烁和呼吸的实现
vscode·嵌入式硬件·esp32·freertos·呼吸灯
iCxhust16 小时前
Deepseek给出的8255显示例程
c语言·开发语言·c++·单片机·嵌入式硬件
小智学长 | 嵌入式16 小时前
SOC-ESP32S3部分:28-BLE低功耗蓝牙
网络·单片机·esp32
RFID舜识物联网17 小时前
RFID测温芯片助力新能源产业安全与能效提升
大数据·人工智能·嵌入式硬件·物联网·安全
InJre17 小时前
STM32通过rt_hw_hard_fault_exception中的LR寄存器追溯程序问题
java·stm32·嵌入式硬件
逼子格18 小时前
硬件工程师笔记——555定时器应用Multisim电路仿真实验汇总
笔记·单片机·嵌入式硬件·multisim·电路仿真·信号发生器·555定时器
xiaobobo333019 小时前
解决vscode打开一个单片机工程文件(IAR/keil MDK)因无法找到头文件导致的结构体成员不自动补全问题。
vscode·stm32·无法找到头文件·结构体成员不补全
夜月yeyue19 小时前
高性能MCU的MPU与Cache优化详解
linux·开发语言·stm32·单片机·嵌入式硬件