最近生产了一批3000块ARM Cortex M0芯片的板子,生产上反映有近20%的板子读不出格雷码,这肯定不对,检查了格雷码测试程序,分析问题可能是其中对flash的测试部分,flash的测试比较简单,先写入0x55,再写入0xaa,最后比较写入的数值是否为0xaa,通过示波器抓取测试脉冲发现程序在写入0xaa的时候,在擦除flash的时候出错,示波器抓取不到测试脉冲了,虽然通过在连续的两次写flash中加了300ms的延时解决了问题,但这并不是问题的根本。
通过测试发现在擦除flash的时候,单片机的3.3v电源被拉低,相当于单片机复位由于单片机电源是tss721提供的,而M0中flash是采用电荷泵的原理,flash电荷泵在充电的时候会消耗tss721的电流,因此在连续擦除的时候中间要预留电荷泵充电补充能量的时间。由于721提供的电流较小,flash电荷泵充电相当于一个大的负载,很容易将单片机电压拉低,导致复位,程序测试失败,因此连续擦除要加点flash电荷泵充电延时。
总结:1、理解硬件工作原理,是写好驱动的关键。
2、有些问题在单步调试的时候不出现,但在运行的时候出现,就如上面的flash问题,这个时候就要转换调试的方法,比如上面的通过示波器实时显示脉冲的调试方法。