DMA controller driver & framework(3)

本文深入分析全志的DMA控制器驱动,探讨如何将其注册到DMA框架中。介绍了关键数据结构,如`dma_device`、`dma_chan`和`virt_dma_chan`,以及它们之间的关系。代码分析涉及设备树、probe函数以及初始化过程,强调了DMA_pool的初始化和控制器到全局链表的添加。
摘要由CSDN通过智能技术生成

前言

本章要分析 全志的DMA controller 驱动(sunxi-dma.c),进一步看一下是如何一步一步的注册到DMA framework里的。

重要的数据结构

从上一节的软件构图中,可知,DMA framework 需要3个比较重要的数据结构:

  • 一个DMA controller的抽象
    struct dma_device
  • 对应DMA物理通道的抽象
    struct dma_chan
  • 对应虚拟抽象的通道
    struct virt_dma_chan

结构体的对应如下:
在这里插入图片描述
我们可以但看到, vchan0与vchan1 对应 一个 dma_chan n(物理通道n),vchan2 对应dma_chan m(物理通道m), 另外, dma_device 结构体作为 DMA controller的抽象,其中的channels链表成员,将 dma_chan设备链接在一起。
实际上代码分析得知,vchan其实是被当做"dma_chan"来用的,即 vchan->dma_chan->实际的hw chan, 三者一一对应。

代码分析(DMA controller)

首先我们看一下设备树:

soc
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值