dma子系统学习之struct dma_device

这篇具有很好参考价值的文章主要介绍了dma子系统学习之struct dma_device。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

struct dma_device 是 Linux 内核中定义的一个数据结构,用于表示一个 DMA 设备(Direct Memory Access,直接内存访问)。DMA 设备是计算机系统中的一种硬件设备,它可以绕过 CPU 直接与内存进行数据传输,提高数据传输效率。

1、定义

Dmaengine.h (kernel4.14\include\linux)

struct dma_device {

    unsigned int chancnt;//支持多少DMA通道
    unsigned int privatecnt;//DMA_request_channel请求了多少DMA通道
    struct list_head channels;//结构体dma_chan的链表
    struct list_head global_node;//用于全局dma_device_list
    struct dma_filter filter;//设备/从设备到过滤器函数的信息/param映射
    dma_cap_mask_t  cap_mask;//一个或多个dma_capability标志
    unsigned short max_xor;//xor源的最大数量,如果没有能力,则为0
    unsigned short max_pq;//pq源的最大数量和pq持续能力
    enum dmaengine_alignment copy_align;//memcpy操作的对齐偏移
    enum dmaengine_alignment xor_align;//xor操作的对齐移位
    enum dmaengine_alignment pq_align;//pq操作的对齐移位
    enum dmaengine_alignment fill_align;//memset操作的对齐移位
    #define DMA_HAS_PQ_CONTINUE (1 << 15)

    int dev_id;//唯一的设备id
    struct device *dev;//struct dma映射api的设备引用

    u32 src_addr_widths;//设备支持的src addr宽度的位掩码
    u32 dst_addr_widths;//设备支持的dst-addr宽度的位掩码
    u32 directions;//设备支持的从方向的位掩码,因为枚举dma_transfer_direction没有定义为每种类型方向的位,dma控制器应该填充(1<<type>),控制器也应该检查它
    u32 max_burst;//每次传输的最大突发能力
    bool descriptor_reuse;//
    enum dma_residue_granularity residue_granularity;//tx_status上报的传输残差的粒度

    int (*device_alloc_chan_resources)(struct dma_chan *chan);//分配资源并返回已分配描述符的数量

    void (*device_free_chan_resources)(struct dma_chan *chan);//释放DMA通道的资源

    struct dma_async_tx_descriptor *(*device_prep_dma_memcpy)(
        struct dma_chan *chan, dma_addr_t dst, dma_addr_t src,
        size_t len, unsigned long flags);//准备memcpy操作
    struct dma_async_tx_descriptor *(*device_prep_dma_xor)(
        struct dma_chan *chan, dma_addr_t dst, dma_addr_t *src,
        unsigned int src_cnt, size_t len, unsigned long flags);//准备xor操作
    struct dma_async_tx_descriptor *(*device_prep_dma_xor_val)(
        struct dma_chan *chan, dma_addr_t *src,    unsigned int src_cnt,
        size_t len, enum sum_check_flags *result, unsigned long flags);//准备xor验证操作
    struct dma_async_tx_descriptor *(*device_prep_dma_pq)(
        struct dma_chan *chan, dma_addr_t *dst, dma_addr_t *src,
        unsigned int src_cnt, const unsigned char *scf,
        size_t len, unsigned long flags);//准备pq操作
    struct dma_async_tx_descriptor *(*device_prep_dma_pq_val)(
        struct dma_chan *chan, dma_addr_t *pq, dma_addr_t *src,
        unsigned int src_cnt, const unsigned char *scf, size_t len,
        enum sum_check_flags *pqres, unsigned long flags);//准备pqzero_sum操作
    struct dma_async_tx_descriptor *(*device_prep_dma_memset)(
        struct dma_chan *chan, dma_addr_t dest, int value, size_t len,
        unsigned long flags);//准备memset操作
    struct dma_async_tx_descriptor *(*device_prep_dma_memset_sg)(
        struct dma_chan *chan, struct scatterlist *sg,
        unsigned int nents, int value, unsigned long flags);//准备对散点列表的memset操作
    struct dma_async_tx_descriptor *(*device_prep_dma_interrupt)(
        struct dma_chan *chan, unsigned long flags);//准备链结束中断操作

    struct dma_async_tx_descriptor *(*device_prep_slave_sg)(
        struct dma_chan *chan, struct scatterlist *sgl,
        unsigned int sg_len, enum dma_transfer_direction direction,
        unsigned long flags, void *context);//准备从dma操作
    struct dma_async_tx_descriptor *(*device_prep_dma_cyclic)(
        struct dma_chan *chan, dma_addr_t buf_addr, size_t buf_len,
        size_t period_len, enum dma_transfer_direction direction,
        unsigned long flags);//准备一个适合音频的循环dma操作。该函数使用大小为buf_len的缓冲区。在传输period_len字节之后,将调用回调函数。
    struct dma_async_tx_descriptor *(*device_prep_interleaved_dma)(
        struct dma_chan *chan, struct dma_interleaved_template *xt,
        unsigned long flags);//以通用方式传输表达式。
    struct dma_async_tx_descriptor *(*device_prep_dma_imm_data)(
        struct dma_chan *chan, dma_addr_t dst, u64 data,
        unsigned long flags);//dma到dst地址的8字节即时数据

    int (*device_config)(struct dma_chan *chan,
                 struct dma_slave_config *config);//将新配置推送到通道,返回0或错误代码
    int (*device_pause)(struct dma_chan *chan);//暂停频道上发生的任何传输。返回0或错误代码
    int (*device_resume)(struct dma_chan *chan);//在先前暂停的频道上恢复任何传输。返回0或错误代码
    int (*device_terminate_all)(struct dma_chan *chan);//中止通道上的所有传输。返回0或错误代码

    void (*device_synchronize)(struct dma_chan *chan);//将传输的终止同步到当前上下文

    enum dma_status (*device_tx_status)(struct dma_chan *chan,
                        dma_cookie_t cookie,
                        struct dma_tx_state *txstate);//轮询事务完成,可选的txstate参数可以提供一个指针,以获取具有辅助传输状态信息的结构,否则调用只返回一个简单的状态码
    void (*device_issue_pending)(struct dma_chan *chan);//将挂起的事务推送到硬件
};文章来源地址https://www.toymoban.com/news/detail-806186.html

到了这里,关于dma子系统学习之struct dma_device的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [JVM] 2. 类加载子系统(1)-- 内存结构、类加载子系统概述

    类加载子系统的职责是:加载class文件到内存中。 完整的内存结构如下: 类加载过程总体分为Loading(加载)、Linking(链接)、Initialization(初始化)三个环节,在Linking阶段又细分为Verification(验证)、Preparation(准备)、Resolution(解析)三个环节。 通过一个类的全限定名获

    2024年02月16日
    浏览(43)
  • Window10安装linux子系统及子系统安装1Panel面板

    原文地址:Window10安装linux子系统及子系统安装1Panel面板 - Stars-One的杂货小窝 最近看到halo博客发布了2.10.0,终于是新增了个备份功能,于是有了念头想要升级下 但是目前我还是使用halo1.5版本,所以跨版本迁移可能会有问题,官方提议还是先用个测试环境进行测试验证是否有问题 但

    2024年02月08日
    浏览(54)
  • 【智能家居项目】裸机版本——网卡设备接入输入子系统 | 业务子系统 | 整体效果展示

    🐱作者:一只大喵咪1201 🐱专栏:《智能家居项目》 🔥格言: 你只管努力,剩下的交给时间! 网络子系统实现了,在我们整个项目框架中,网络子系统也输入子系统中输入设备的之一,所以现在要做的就是网络子系统接入到输入子系统中。 如上图所示,在输入子系统中增

    2024年02月08日
    浏览(44)
  • Linux内核(十四)Input 子系统详解 I —— 子系统介绍以及相关结构体解析

    input子系统就是管理输入的子系统 ,和Linux其他子系统一样,都是Linux内核针对某一类设备而创建的框架。 鼠标、键盘、触摸屏等都属于输入设备,Linux将这些设备的共同特性抽象出来,这就形成了input子系统的框架。 Linux内核只需要通过input框架向用户层上报输入事件 (如:

    2024年02月05日
    浏览(47)
  • Win11系统安装安卓子系统教程

    随着Win11系统的不断普及,以及硬件设备的更新换代,我相信很多同学都已经更新并使用到了最新的Win11系统。那么,Win11系统最受期待的功能“Windows Subsystem for Android”(简称WSA),即《安卓子系统》。他可以让你在Win11 PC上直接安装运行各种安卓手机APP应用与游戏,无需安装

    2024年04月12日
    浏览(93)
  • spi 子系统

    spi 分为主机模式和从机模式,一般soc 自带的spi 控制器,我们都将它用作主机模式与外挂的从设备通信。从设备例如 oled芯片、flash芯片、陀螺仪芯片等等。 那么spi 驱动和设备,自然也就分为主机驱动、设备和从机驱动、设备。那么如何在Linux 下查看这些信息呢? 首先查看s

    2024年02月10日
    浏览(43)
  • gpio 子系统

    Linux的GPIO子系统驱动框架的组成部分 Linux的GPIO子系统驱动框架由三个主要部分组成: GPIO控制器驱动程序、平台驱动程序和GPIO字符设备驱动程序 。 GPIO控制器驱动程序 GPIO控制器驱动程序是与硬件相关的代码,用于处理GPIO控制器与系统总线之间的通信。该部分代码通常由芯片

    2024年02月10日
    浏览(47)
  • windows子系统安装

    软件经过不断的打磨和迭代,会变得越来越好。微软的windows,谷歌的安卓,会越来越好用。垄断带来了单一、标准和效率。 本文,简单记录下win11上WSL和安卓子系统的安装与使用。 WSL安装 安装wsl相关视频演示: How to Install WSL2 on Windows 11! - YouTube Windows10/11上安装图形用户界面

    2024年02月16日
    浏览(42)
  • 9.GPIO子系统

    目录 GPIO1节点 内核设备树新增rgb_led节点(使用gpio子系统) 常用的对外接口 头文件 of_find_node_by_path()函数 of_get_named_gpio()函数 gpio_request()函数 gpio_free()函数 gpio_direction_output()函数 gpio_direction_input()函数 gpio_get_value()函数 gpio_set_value()函数 GPIO子系统实验:IO引脚高低电平控制 修

    2024年02月11日
    浏览(40)
  • Windows系统开启Linux子系统(Ubuntu)

    Linux是一种开源的操作系统,它拥有强大的功能和稳定的性能,广受开发者和用户的喜爱。但是,如果我们的电脑是Windows系统,要使用Linux系统,我们通常需要安装虚拟机,这样会占用很多的资源和空间,而且也不够方便。 其实,对于大多数用户来说,只需要开启Windows系统自

    2024年04月15日
    浏览(57)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包