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 问题解决

相关推荐
杰克逊的日记9 天前
MCU编程
单片机·嵌入式硬件
Python小老六9 天前
单片机测ntc热敏电阻的几种方法(软件)
数据库·单片机·嵌入式硬件
懒惰的bit9 天前
STM32F103C8T6 学习笔记摘要(四)
笔记·stm32·学习
HX科技9 天前
STM32给FPGA的外挂FLASH进行升级
stm32·嵌入式硬件·fpga开发·flash·fpga升级
Suagrhaha9 天前
驱动入门的进一步深入
linux·嵌入式硬件·驱动
国科安芯9 天前
基于ASP4644多通道降压技术在电力监测系统中集成应用与发展前景
嵌入式硬件·硬件架构·硬件工程
Li Zi9 天前
STM32 ADC(DMA)双缓冲采集+串口USART(DMA)直接传输12位原始数据到上位机显示并保存WAV格式音频文件 收藏住绝对实用!!!
经验分享·stm32·单片机·嵌入式硬件
进击的程序汪9 天前
触摸屏(典型 I2C + Input 子系统设备)从设备树解析到触摸事件上报
linux·网络·嵌入式硬件
damo王9 天前
Zephyr 系统深入解析:SoC 支持包结构与中断调度器调优实践
单片机·嵌入式硬件·zephyr
逼子格9 天前
硬件工程师笔试面试高频考点汇总——(2025版)
单片机·嵌入式硬件·面试·硬件工程·硬件工程师·硬件工程师真题·硬件工程师面试