使用 $Super$$ 和 $Sub$$ 覆盖符号定义

     在某些情况下,无法修改现有符号,例如,由于符号位于外部库或 ROM 代码中。可以使用 $Super$$$Sub$$ 模式来修补现有符号。

例如,要修补函数 foo() 的定义,请按如下方式使用 $Super$$foo()$Sub$$foo()

$Super$$foo

标识未修补的原始函数 foo()。 使用它可以直接调用原函数。

$Sub$$foo

标识调用的新函数,而不是原始函数 foo()。可以使用此模式在原始函数之前或之后添加处理。

$Sub$Super 机制只在静态链接时起作用,$Super$$ 引用无法导入或导出到动态符号表中。

例如:

extern void ExtraFunc(void);
extern void $Super$$foo(void):

/* this function is called instead of the original foo() */
void $Sub$$foo(void)
{
  ExtraFunc();    /* does some extra setup work */
  $Super$$foo();  /* calls the original foo() function */
}


  

 摘自<ELF for arm..>

  A symbol $Sub$$name is the sub-class version of name. A symbol $Super$$name is the super-class version of
name. In the presence of a defintion of both name and $Sub$$name:


1. A reference to name resovles to the definition of $Sub$$name.
2. A reference to $Super$$name resolves to the definition of name.


It is an error to refer to $Sub$$name, or to define $Super$$name, or to use $Sub$$… or $Super$$… recursively.
A platform standard may mandate support of sub- and super-class symbols.
There are outstanding defects for sub- and super-class symbols DE-316140.

<think>好的,我现在需要回答用户关于如何在Keil5中使用静态链接库的问题。首先,我得回忆一下Keil MDK的基本操作相关知识。用户提到了静态链接库,也就是通常的.lib文件。在Keil中,静态库的使用涉及项目配置链接设置。 首先,用户可能需要先创建一个静态库工程或者导入现有的库文件。根据引用[3],提到了符号无法修改时可以用$Super$$$Sub$$模式修补现有符号,这可能库的使用有关,但用户的问题更基础,是如何使用静态库。 接下来,步骤可能包括添加库文件到项目,设置头文件路径,以及在链接器选项中包含库。需要确保库的架构项目兼容,比如同为ARM Cortex-M系列。引用[2]提到安装Keil工具链,这可能影响库的兼容性,所以需要确认库是否用相同编译器生成。 另外,用户可能会遇到未定义符号的错误,这时需要检查库是否被正确链接,头文件是否包含,或者库是否匹配目标设备。引用[1]的错误是关于未定义的函数,可能类似库函数未找到的情况,需要确保库包含了所需的函数实现。 需要分步骤说明创建库使用库的过程。可能还需要提到如何生成静态库,因为用户可能不仅想使用现有的库,还想自己创建。例如,在Keil中创建库工程,编译生成.lib文件,然后在应用工程中添加该库。 最后,常见问题如路径设置、库版本兼容性、符号冲突等需要提及。引用[3]的修补符号方法可能在高级应用中用到,但基础使用可能不需要。</think>### Keil MDK中使用静态链接库的步骤 #### 一、创建静态库工程 1. **新建工程** 打开Keil5 → 点击Project → New μVision Project → 选择存储路径工程名 → 选择目标设备型号 → 勾选"Create Library"选项[^3]。 2. **添加源码** 右键"Source Group" → Add Existing Files → 选择需要编译成库的C/C++文件。 3. **配置编译选项** - 在Options for Target → Output中确认输出类型为`.LIB` - 设置优化等级(建议使用-O2平衡性能与体积) 4. **生成库文件** 点击Build按钮 → 生成的`.lib`文件默认在`Objects`文件夹中。 #### 二、在应用工程中使用静态库 1. **添加库文件到工程** 右键"Application"工程的Source Group → Add Existing Files → 选择`.lib`文件。 2. **包含头文件路径** 在Options for Target → C/C++ → Include Paths中添加库对应的头文件目录。 3. **配置链接器选项** - 在Options for Target → Linker → Misc controls添加`--library_type=libarm_cm3`(根据目标设备调整) - 在Scatter File中确保库代码段与应用程序内存布局兼容 4. **调用库函数** ```c #include "mylib.h" // 库提供的头文件 int main() { lib_function(); // 调用库函数 return 0; } ``` #### 三、常见问题解决方案 | 问题现象 | 原因分析 | 解决方法 | |---------|----------|----------| | `Undefined symbol`错误 | 1. 库未正确链接<br>2. 函数声明与实现不一致 | 1. 检查.lib文件是否添加<br>2. 使用`fromelf --text -c -v xxx.lib > lib.txt`反汇编验证符号存在性 | | 内存分配冲突 | 库与应用程序使用相同内存区域 | 修改Scatter File中的区域定义 | | 版本不兼容 | 库与编译器版本不匹配 | 使用相同ARMCC版本重新编译库 | #### 四、高级技巧 1. **符号覆盖技术** 当需要修改库函数时,使用`$Super$$func``$Sub$$func`模式: ```c extern void $Super$$func(void); void $Sub$$func(void) { // 新增预处理代码 $Super$$func(); // 调用原库函数 // 新增后处理代码 } ``` 2. **混合使用多个库** 在Linker → Input → Additional Libraries中添加多个库时,需注意链接顺序,基础库应放在最后。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值