by JHJ (jianghuijunj211@gmail.com)
ION如何实现buffer共享的思路倒是很清晰的,但是深入代码研究,发现ION是依赖于DMA Mapping的,而DMA mapping模块对我而言还是挺复杂的,看这个模块遇到的第一个问题就是cache。既然是DMA mapping,直接将申请的buffer设置为non-cacheable不就行了?这样就可以保证CPU通过DMA读写缓冲区的一致性了。为什么还有Consistent DMA mappings 和 Streaming DMA mappings一说呢?下面先介绍一下Cache的概念。
Cache
Cache写机制:Write-through与Write-back[5]
Cache写机制分为write through和write back两种。
- Write-through- Write is done synchronously both to the cache and to the backing store.
- Write-back (or Write-behind) – Writing is done only to the cache. A modified cache block is written back to the store, just before it is replaced.
Write-through(直写模式)在数据更新时,同时写入缓存Cache和后端存储。此模式的优点是操作简单;缺点是因为数据修改需要同时写入存储,数据写入速度较慢。
Write-back(回写模式)在数据更新时只

本文详细介绍了Cache的写机制,包括Write-through和Write-back模式,以及它们在数据一致性、性能上的优缺点。还探讨了Write-misses的处理方式,即Write allocate和No-write allocate策略,并讨论了在DMA操作中如何处理Cache,例如在以太网、无线、USB驱动中的应用。最后解释了Cache的Flush和Invalidate函数及其应用场景。
最低0.47元/天 解锁文章
1397

被折叠的 条评论
为什么被折叠?



