您的位置:首页 > 其它

MDK ARM中__weak关键字的使用

2017-06-14 18:28 274 查看

1. 使用方法

__weak函数用于定义变量或者函数,常见于定义函数,在MDK ARM链接时优先链接定义为非weak的函数或变量,如果找不到则再链接weak函数。具体用法为:

file1.c

__weak void weakFunction(void){
//do something
return;
}

void someFunctionCall(void){
//do something
weakFunction();
//do something
return;
}


file2.c

void weakFunction(void){
//do something
return;
}


具体方法可以参考MDK ARM中的help,本文主要讲的是应用过程中遇到的一个问题。

2. 问题

测试环境为:

MDK-ARM version:5.21a

MCU: stm32L431RCT6

compiler cmd:–c99 -c –cpu Cortex-M4.fp -D__MICROLIB -g -O0 –apcs=interwork –split_sections

-IC:/Users/Administrator/Desktop/weakTest/RTE

创建一个工程如下:

在weakTest.c中定义一个weak函数,并且定义一个调用该weak函数的函数

__weak void weakFunctioin(void){    //定义为__weak类型的函数
logInfo("print weakFunction\r\n");
}

int weakFunctionTest(unsigned int tst){

logInfo("print A\r\n");
if (tst) {
logInfo("print B\r\n");
weakFunctioin();    //调用函数
logInfo("print C\r\n");
}else{
logInfo("print D\r\n");
}
logInfo("print E\r\n");
return 0;
}


在main.c文件中,定义main函数及weakFunctionTest函数:

void weakFunctioin(void){    //定义为正常的函数

logInfo("print nonWeakFunction\r\n");
return;
}

int main(void){

logInit(logLevelDebug);
logInfo("Build @ %s %s,system start\r\n", __DATE__, __TIME__);

weakFunctionTest(1);
logInfo("Build @ %s %s,system stop\r\n", __DATE__, __TIME__);
while(1);
return 0;
}


运行时打印为:

-I: Build @ Jun 12 2017 15:14:18,system start

-I: print A

-I: print B

-I: print nonWeakFunction

-I: print C

-I: print E

-I: Build @ Jun 12 2017 15:14:18,system stop

此时运行正常,但是如果我修改weakTest.c文件中weak类型的函数weakFunctioin,添加一个死循环:

__weak void weakFunction(void){
logInfo("print weakFunction\r\n");
while(1);
return;
}


此时打印为

-I: Build @ Jun 12 2017 15:14:46,system start

-I: print A

-I: print B

-I: print nonWeakFunction

-I: print D //ERROR ERROR ERROR

-I: print E

-I: Build @ Jun 12 2017 15:14:46,system stop

本应打印-I: print C的位置成了-I: print D,可见程序运行都已经错乱。而且看样子是编译工具出的问题。

3. 解决方法

将带有死循环的weak类型weakFunctionTest函数放在第三个文件中即可。官方论坛的回答是因为优化的原因。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  weak keil mdk