san*_*ala 3 c linux-device-driver linux-kernel embedded-linux dma
正如我们所知,分散列表收集了物理上分散在内存中的内存,但实际上是连续的.当与DMA通信时,它为DMA提供了一个抽象的内存视图,因为这是物理上连续的内存.
怎么scatterlist处理这个?它是一种保持在内的链表scatterlist吗?
例如,如果要使用DMA传输4000字节的数据,因为数据在物理上是连续的,分散列表如何使其连续?scatterlist实现将使用分配4000字节的数据Kmalloc来确保它获得物理上连续的内存?还是会创建一个链表?
注意:这里我的查询不是关于SG表,而是关于单个分散列表
让我们说我们想要保存4000字节物理上不连续的内存的数据
struct scatterlist sg,
sg_init_one(&sg,data,4000)
Run Code Online (Sandbox Code Playgroud)
现在,这个sg如何解决这个问题?
您似乎正在混合两个不同的分散列表,即struct scatterlist在Linux内核和分散列表中,可能由特定的DMA控制器支持.在这两种情况下,它们都不是连续的.这与第一种情况中的数组和第二种情况下的链表相似.当您调用dmaengine_prep_slave_sg()实际的DMA驱动程序时,将其转换为内部结构(可能是SG列表的副本),适合最大DMA长度边界的新SG列表,DMA hw链接列表等等.根据DMA驱动程序(让我们考虑最近添加的驱动程序/ dma/hsu/hsu.c),初始SG列表被复制并通过最多4个DMA hw描述符以块的形式提供给HW,在每个块完成后它获得一个中断并且如果初始数量的项目超过4,则继续发送/接收所有内容.