在代码维护中,发现一个指针的初始值是0,在没有走到正常分支处该指针是不会被赋值的,而在软件的启动阶段,恰恰该指针不会走到正常分支,所以在后面使用该指针的时候,并没有判断指针值是否为空,所以CPU使用空指针访问,就会出现问题,并在L1内存控制器中被检测到,通过event 122=0x7A上报。
根据下图CPU通过空指针访问0x48的地址,是因为空指针指向一个结构体,在用指针去访问结构体中某个变量,而该变量在结构体中的offset就是0x48,所以这里寄存器记录了FaultingAddress = 0x48,因为该地址在TI C66x DSP中是不存在的。寄存器L1DMPFSR = 0x120,LOCAL位等于1,表明是CPU在访问。
常见的CPU访问引起的内存保护问题为什么只用event_122上报 - 举例1
时间: 2024-10-19 14:07:13