最近测试程序代码时发现uart+dma打印突然卡顿了,具体现象就是只有在dma缓冲区满的情况下,数据才会发送到串口打印出来。
如dma发送缓冲区设为256时,我在while循环里打印“uart1 test print time.\r\n”这条语句,并不是执行一次send打印语句串口就显示打印一次,而是缓冲区满,也就是攒满256个字节才会进行打印处来。以前都是很正常的,最近测试突然就出现这种情况。
一条一条的查找语句,发现dma缓冲区前面的static __IO不知道什么时候去掉了,加上之后,就会快速的打印了,即发送什么串口就立马显示什么。
通过这个问题说明,DMA的缓冲区必须是__IO,也就是不被处理器优化的才可以。static没有不会影响,但是因为这个数组只在当前文件使用,所以定义成static。
#define __IO volatile /*!< Defines 'read / write' permissions */