欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

ARM-CortexM0固件中函数实际在Flash中的存储地址与调用地址(引用地址)不一致

程序员文章站 2022-03-15 13:49:12
ARM-CortexM0实际项目中发现, Keil编译后函数的实际存放地址是按4字节对齐的, 函数的起始地址为偶数. 但仿真时发现调用函数时往PC寄存器写入的都是奇数(函数实际存放地址 + 1)。为了验证, 写了一段函数, 执行的操作是以函数名的方式将函数地址给一个变量, 查看变量的值,仿真截图如下:发现我们如果如上面的代码一样引用这个函数地址的时候, 传递过来的地址也是函数的实际存放地址+1.原因分析:ARM-CortexM0的内核运行规定调用函数时传入的函数地址必须为奇数, 否则就会产....

ARM-CortexM0实际项目中发现, Keil编译后函数的实际存放地址是按4字节对齐的, 函数的起始地址为偶数. 但仿真时发现调用函数时往PC寄存器写入的都是奇数(函数实际存放地址 + 1)。为了验证, 写了一段函数, 执行的操作是以函数名的方式将函数地址给一个变量, 查看变量的值,仿真截图如下:

ARM-CortexM0固件中函数实际在Flash中的存储地址与调用地址(引用地址)不一致

发现我们如果如上面的代码一样引用这个函数地址的时候, 传递过来的地址也是函数的实际存放地址+1. 

原因分析:

ARM-CortexM0的内核运行规定调用函数时传入的函数地址必须为奇数, 否则就会产生硬件错误。因此编译器在编译的时候会自动在引用函数地址的地方将函数地址+1再传递。函数调用的地方, 编译器编译出来的代码也是会将函数地址+1写入PC寄存器来调用。截图所示两个地址虽然不一样, 但都是符合规则的。

本文地址:https://blog.csdn.net/chentianveiko/article/details/109247564