当前位置:首页 > 单片机 > 单片机
[导读]我写了一个函数,我要把它放到FLASH 的第31区,地址为0x0801F000 这个地方,我在网上搜了一个方法。虽然达到了效果网上说加个__at;且包含头文件#include "absacc.h"这种方法只适用于 数组的绝对定义。方法如下:u8 T

我写了一个函数,我要把它放到FLASH 的第31区,地址为0x0801F000 这个地方,我在网上搜了一个方法。
虽然达到了效果网上说加个__at;且包含头文件#include "absacc.h"
这种方法只适用于 数组的绝对定义。方法如下:
u8 TestBUF[8] __at(0x0801F000)={0X34,0X66,0X03,0X34,0X23,0X77,0X77,0X77};
但是呢。对于一个函数。比如void __at(0x0801F000) Test_ABC(void){...自己代码}; 这种方法是不行的。。
通过查看keil里的FLASH 发现是空的。说明他的代码就没放进去;
那么,网上还有个方法可行,但是不是我要的。共享出来。方法就是:
1、先为需要定位的函数设置节名,这里我以main主函数为例:
void__attribute__ ((section ("mymain-这里随便定义英文名,我以mymain为名")))main(void)

2、在分散加载文件中设定main存放地址:
APP_LOAD 0x00050000OVERLAY
{
MAIN_EXE +0
{
app.o(mymain);;app.o就是我的main主函数所在的C文件模块app.c
;;mymain就是刚才定义的一个节其实就是代表main主函数
;;这里可以看到mymain的节(也就是main函数)
;;被放在地址0x00050000处,这样就完成了函数地址定位的功能
}
APP_EXE +0
{
*(+RO)
}
};
还是拿我的函数为例子,
1.void__attribute__ ((section ("ABC_MY")))Test_ABC(void){...自己代码};
2.APP_LOAD0x0801F000OVERLAY
{
MAIN_EXE +0
{
Test.o(ABC_MY);;我的这个函数Test_ABC放在Test.c里,那么我这里改成TEST.O }
APP_EXE +0
{
*(+RO)
}
};

以上仿造人家的方法我也实现了。但是发现有问题2;
第一个问题,在我要放的地址0x0801F000啊,确实有了代码不是过去检测的FF FF FF 了,而且在keil 生成的一个后缀叫.map的文件里也找到了我的函数是放在了0x0801F000范围里。但是他放的位置 是0x0801F001;加了一位;这里这是我莫名其妙的第一个问题,
第二个问题,在后缀叫.map的文件里。这个文件是介绍本程序的所有涉及内容存放的一个文件。。我发现他身后排列的那些比如 usart_init()函数啊,还有各种函数,。都会随着我改这个0x0801F000 这个地址而顺序排列。,也就是说。我地址一改。其他函数。顺位不变且都跟到了这个地址身后顺序排列。说的还不清楚。举个例子,A是我的测试程序,A放0x01;那么其他程序BCDEFG排列分别是0x02;0x03;0x04;0x05;0x06;0x07; 当我把我的A 放到了0x21;那么我的其他程序。BCDEFG跟过来了。依次跟到了0x22,0x23,0x24,0x25,0x26,0x27; 这是第二个问题。比较头疼。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

ARM系统几乎都采用Linux的操作系统,而且几乎所有的硬件系统都要单独构建自己的系统,与其他系统不能兼容,这也导致其应用软件不能方便移植,这一点一直严重制约了ARM系统的发展和应用。GOOGLE开发了开放式的Andro...

关键字: Linux x86 ARM

随着计算需求的多样化,尤其是随着移动设备、嵌入式系统和云计算的兴起,ARM 和 x86 架构之间的争论变得更加突出。ARM(高级 RISC 机器)和 x86 代表两种不同类型的处理器架构,每种架构都针对不同的工作负载和用...

关键字: Linux x86 ARM

从画质优化 (NSS) 到帧率提升 (NFRU) 和光线追踪(NSSD),Arm 计划覆盖移动端图形处理的多个维度,推动边缘 AI 图形革命。而未来通过持续的技术迭代,Arm也将保持在移动计算领域的技术领先,满足手游、A...

关键字: ARM 神经图形技术 GPU AI ML

7月31日消息,据媒体报道,芯片架构提供商Arm Holdings首席执行官Rene Haas宣布,公司正加大投入开发自有芯片产品,此举标志着其从传统IP授权模式向提供实体芯片的战略重大转变。

关键字: ARM META

7月28日消息,2025年,中国AI硬件市场规模将首次突破万亿元大关。

关键字: AI ARM

受生成式 AI 驱动, RISC-V 芯片市场快速发展。预计到2030年,RISC-V SoC出货量将达到1618.1亿颗,营收将达到927亿美元。其中,用于AI加速器的RISC-V SoC出货量将达到41亿颗,营收将达...

关键字: RISC-V CPU AI CUDA ARM 推理
关闭