FLM算法文件工程代码需要特别注意什么吗?
STM32H7电源问题
请问一下STM32F103C8T6的Hardwar NSS Output ENABLE后cs持续拉低是为什么
串口+DMA发数据
STM32H723FDCANT通信
STM32H725内部FLASH读写问题
关于NAND FLASH加LittleFS的方案
STM32H7的双缓冲
STM32G0B1
cubeide登录不了,软件连不上网
微信公众号
手机版
你可以针对UART的接收buffer做Dcache的无效操作。
ALIGN_32BYTES(static uint32_t UART_BufferBUFFER_SIZE])={0};
SCB_InvalidateDCache_by_Addr (void * addr, uint32_t dsize);
或者针对接收缓冲区做MPU配置,配置其为device属性也可以。
储器区读取数据。相应的库函数代码是SCB_InvalidateDCache();
我用的DMA空闲中断读取,只能在读取后触发中断,如果是读取之前关闭
DCache,岂不是等于一直关闭DCache。读取完一帧数据后,是否还不能打开DCache,因为这样等于下一次读取之前还是打开的
SCB_InvalidateDCache_by_Addr填入的地址应该是哪里的地址?我试过了缓存数组的、还试了DMA的结构体,没有用
[md]UART接收缓冲的地址。
找到问题了,不应该是在DMA接收之前调用,应该在接收之后,这样清除Cache后,其中的数据会回到原始地址
[md]呵呵 OK