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

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

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

原因分析:

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