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

相关推荐
Ronin-Lotus3 小时前
嵌入式硬件篇---有线串口通信问题解决
单片机·嵌入式硬件·ttl·rs232·rs485·有线串口
Ronin-Lotus4 小时前
嵌入式硬件篇---zigbee无线串口通信问题
嵌入式硬件·zigbee·无线串口
GalaxySinCos5 小时前
08 51单片机之串口通信
单片机·嵌入式硬件·51单片机
悠哉悠哉愿意5 小时前
【电赛学习笔记】MaxiCAM 项目实践——与单片机的串口通信
笔记·python·单片机·嵌入式硬件·学习·视觉检测
李某学编程7 小时前
Cortex-M内核SysTick定时器介绍
stm32·单片机
李永奉7 小时前
STM32-定时器的基本定时/计数功能实现配置教程(寄存器版)
c语言·开发语言·stm32·单片机·嵌入式硬件
糖糖单片机设计8 小时前
硬件开发_基于STM32单片机的电脑底座系统
stm32·单片机·嵌入式硬件·物联网·51单片机
IT项目分享11 小时前
ESP32入门实战:PC远程控制LED灯完整指南
单片机·嵌入式硬件·micropython·it项目网
Electrical_IT13 小时前
STM32-PWM输入捕获的配置
stm32·单片机
风吹花中花吹风14 小时前
原创-锐能微82xx系列电能计量芯片软件驱动开发与精度校准流程完全指南
驱动开发·单片机·嵌入式硬件·锐能微·计量芯片·精度校准·电能表校准