ZYNQ7 DACHE的重要操作

59 篇文章 4 订阅
46 篇文章 8 订阅



        /* Flush the SrcBuffer before the DMA transfer, in case the Data Cache

* is enabled
*/
Xil_DCacheFlushRange((u32)TxPacket, MAX_PKT_LEN);
//确保从CACHE里面写回到MM里




/* Invalidate the DestBuffer before receiving the data, in case the
* Data Cache is enabled
*/
Xil_DCacheInvalidateRange((u32)RxPacket, MAX_PKT_LEN);

//此CACHE区域的数据作废,再次读数的话,直接从MEMORY读取。




其实就是牵扯MEMORY和CACHE的更细问题:

将CACHE数据更新到MEMORY,用Xil_DCacheFlushRange。

将MEMORY的数据更新到CACHE(当然不是说立即更新,是在后续的访问中需要的时候更新),用Xil_DCacheInvalidateRange。



看到这些文字的,有什么不明白的可以在后面的评论里面问我。






 
 
  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值