本帖最后由 thammer 于 2015-4-2 14:01 编辑
问题出现在MDK里面,编译KL16芯片程序时出现的。程序大概是:
unsigned char buf[4];
int main(void)
{
unsigned int devid = 0x12345678;
*((unsigned int *)buf) = devid;
return 0;
}
看上去程序无任何问题,我写了个测试程序在pc上跑了下没异常,但是到MCU里面就报:HardFault_Handler,也就是类似linux下的断错误,访问了非法的内存地址。
将buf改为局部变量,pc, MCU里面均运行正常,对buf赋初值或者不赋初始值效果一样。
|