摘要: 今天调试出了特别奇怪的问题,经常用的串口发送居然都不好使了,代码大约是这样的:if( flag in memory mapped reg) { write char to transmit reg}从串口发出去的东西总是不对,用jtag调试发现,单步的时候是正确的,但是只要全速运行就出错。思考之后,感觉只可能是flag读回来是不对的,但怎么可能呢??仔细思考后,发现一个问题,ARM如何知道每次都要通过读这个地址来获得flag呢?虽然已经将memory-mapped reg 的地址定义为 volatile,但是这只是告诉gcc不优化进寄存器,但是ARM还可以从Cache中读啊,ARM没有专用的I 阅读全文
posted @ 2011-06-10 23:03 windtail 阅读(1661) 评论(0) 推荐(0) 编辑