keil For ARM 函數(shù)絕對(duì)定義
我寫了一個(gè)函數(shù),我要把它放到FLASH 的第31區(qū),地址為0x0801F000 這個(gè)地方,我在網(wǎng)上搜了一個(gè)方法。
雖然達(dá)到了效果網(wǎng)上說(shuō)加個(gè)__at;且包含頭文件#include "absacc.h"
這種方法只適用于 數(shù)組的絕對(duì)定義。方法如下:
u8 TestBUF[8] __at(0x0801F000)={0X34,0X66,0X03,0X34,0X23,0X77,0X77,0X77};
但是呢。對(duì)于一個(gè)函數(shù)。比如void __at(0x0801F000) Test_ABC(void){...自己代碼}; 這種方法是不行的。。
通過(guò)查看keil里的FLASH 發(fā)現(xiàn)是空的。說(shuō)明他的代碼就沒(méi)放進(jìn)去;
那么,網(wǎng)上還有個(gè)方法可行,但是不是我要的。共享出來(lái)。方法就是:
1、先為需要定位的函數(shù)設(shè)置節(jié)名,這里我以main主函數(shù)為例:
void__attribute__ ((section ("mymain-這里隨便定義英文名,我以mymain為名")))main(void)
2、在分散加載文件中設(shè)定main存放地址:
APP_LOAD 0x00050000OVERLAY
{
MAIN_EXE +0
{
app.o(mymain);;app.o就是我的main主函數(shù)所在的C文件模塊app.c
;;mymain就是剛才定義的一個(gè)節(jié)其實(shí)就是代表main主函數(shù)
;;這里可以看到mymain的節(jié)(也就是main函數(shù))
;;被放在地址0x00050000處,這樣就完成了函數(shù)地址定位的功能
}
APP_EXE +0
{
*(+RO)
}
};
還是拿我的函數(shù)為例子,
1.void__attribute__ ((section ("ABC_MY")))Test_ABC(void){...自己代碼};
2.APP_LOAD0x0801F000OVERLAY
{
MAIN_EXE +0
{
Test.o(ABC_MY);;我的這個(gè)函數(shù)Test_ABC放在Test.c里,那么我這里改成TEST.O }
APP_EXE +0
{
*(+RO)
}
};
以上仿造人家的方法我也實(shí)現(xiàn)了。但是發(fā)現(xiàn)有問(wèn)題2;
第一個(gè)問(wèn)題,在我要放的地址0x0801F000啊,確實(shí)有了代碼不是過(guò)去檢測(cè)的FF FF FF 了,而且在keil 生成的一個(gè)后綴叫.map的文件里也找到了我的函數(shù)是放在了0x0801F000范圍里。但是他放的位置 是0x0801F001;加了一位;這里這是我莫名其妙的第一個(gè)問(wèn)題,
第二個(gè)問(wèn)題,在后綴叫.map的文件里。這個(gè)文件是介紹本程序的所有涉及內(nèi)容存放的一個(gè)文件。。我發(fā)現(xiàn)他身后排列的那些比如 usart_init()函數(shù)啊,還有各種函數(shù),。都會(huì)隨著我改這個(gè)0x0801F000 這個(gè)地址而順序排列。,也就是說(shuō)。我地址一改。其他函數(shù)。順位不變且都跟到了這個(gè)地址身后順序排列。說(shuō)的還不清楚。舉個(gè)例子,A是我的測(cè)試程序,A放0x01;那么其他程序BCDEFG排列分別是0x02;0x03;0x04;0x05;0x06;0x07; 當(dāng)我把我的A 放到了0x21;那么我的其他程序。BCDEFG跟過(guò)來(lái)了。依次跟到了0x22,0x23,0x24,0x25,0x26,0x27; 這是第二個(gè)問(wèn)題。比較頭疼。