ARM DMA使用整理

  • Direct Memory Access, 直接存储访问。同SPI,IIC,USART等一样,属于MCU的一个外设,用于在不需要MCU介入的情况下进行数据传输。可以将数据从外设传输到flash,也可以将数据从flash传输到外设,或者flash内部数据移动。

  • 它的使用和其他外设一样,需要通过寄存器进行配置。配置过后,每次DMA传送由3个操作组成:

    1. 从外设数据寄存器或者从当前外设/存储器地址寄存器指示的存储器地址取数据,第一次传输时的开始地址是DMA_CPARx或DMA_CMARx寄存器指定的外设基地址或存储器单元。
    2. 存数据到外设数据寄存器或者当前外设/存储器地址寄存器指示的存储器地址,第一次传输
      时的开始地址是DMA_CPARx或DMA_CMARx寄存器指定的外设基地址或存储器单元。
    3. 执行一次DMA_CNDTRx寄存器的递减操作,该寄存器包含未完成的操作数目。
  • 传输完成或者错误时,会产生中断,用户可以进行处理。该中断的发生也需要寄存器配置。

  • 启用流程一般为:

    • 使能时钟
    • 配置参数,可参考相关芯片的datasheet
      • 定义DMA通道及时钟
      • 定义传输完成标志
      • 定义要发送的数据大小
      • 定义DMA传输数据源
      • 定义DMA传输目标存储器
    • 配置DMA中断,并使能
    • 当有数据进入时,外设会发送请求,进行DMA传输,传输过半,完成或者异常时,会触发DMA中断
  • 当DMA和CPU同时访问相同目标时,DMA会暂停,CPU访问若干个周期后,总线仲裁器执行循环调度。

  • DMA一次只能有一个通道进行数据传输,当多个DMA同时进行数据传输时,需要根据寄存器中配置的优先级进行,当优先级相同时,一般DMA通道编号较低的优先级高。

相关推荐

  1. ARM DMA使用整理

    2024-01-06 07:08:02       59 阅读
  2. electron-updater使用整理

    2024-01-06 07:08:02       64 阅读
  3. Ipython使用技巧整理

    2024-01-06 07:08:02       26 阅读
  4. IPython的使用技巧整理

    2024-01-06 07:08:02       26 阅读
  5. Qt 容器类整理使用

    2024-01-06 07:08:02       26 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-06 07:08:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-06 07:08:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-06 07:08:02       82 阅读
  4. Python语言-面向对象

    2024-01-06 07:08:02       91 阅读

热门阅读

  1. uniapp使用tcp和udp的区别和例子

    2024-01-06 07:08:02       48 阅读
  2. 【深度学习程序实例】

    2024-01-06 07:08:02       51 阅读
  3. Vue_00001_CLI

    2024-01-06 07:08:02       47 阅读
  4. OSG显示模型的线程问题

    2024-01-06 07:08:02       55 阅读
  5. django related_query_name和related_name的区别

    2024-01-06 07:08:02       49 阅读
  6. Django文章标签推荐

    2024-01-06 07:08:02       50 阅读
  7. 左旋字符串与判断字符串左旋编程题

    2024-01-06 07:08:02       56 阅读
  8. 阿里云配置服务器详细指南

    2024-01-06 07:08:02       68 阅读