news 2026/5/14 16:09:01

理解DMA双缓冲的原理和意义(CPU和DMA:并发并行和回调函数)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
理解DMA双缓冲的原理和意义(CPU和DMA:并发并行和回调函数)

这篇文章弄懂了 , 对计算机硬件包括软件编程会上一个很大的台阶

引子

回调函数在函数调用时 , 是并行计算吗?计算单元

这个系统里有很多个计算单元 , CPU 、 FPU 、 ADC 都是计算单元 , 计算单元的本质就是些门电路 , 或者晶闸管之类的东西凑成的触发器, 后来用的是mos管 ,但这些本质都是门电路 , 本质上都是用于计算的 ,除此之外 , MPU 、ETM、 DMA也都具备计算能力

ADC

ADC 本质上也相当于一个CPU ,它也是一个可以参与计算的 , 其原理就是通过电压逐次比较 , 然后计算出来一个字节

并行

前面铺垫了这么多 , 究竟什么是并行, 比方说CPU从ADC里面取数据搬运到SRAM里面 , 但是系统其他计算单元不工作岂不是浪费了 , 我们是不是可以尝试在不冲突的前提下多线运行 , 这时可以让DMA去SRAM里面搬运数据 , 将片1的内存搬运到片2 ,所以CPU在跟ADC搬运前 , 它可以跟DMA” 说句话 “ ,让他在SRAM上将地址片一搬运到地址片2 , 这样在ADC和CPU工作的时候 , DMA也在同时工作

它在干活 , 它也在干活 , 这个就是并行

并发

在一个很短的时间内 , 假如说1ms的时间内, CPU与ADC通信这件事跟DMA搬运SRAM这件事 , 顺序的发生了 , 就叫并发 , 这个时间并不限制与1ms , 只是举个例子 , 也可以是0.5ms

同一个时刻在干两件事情 叫做并行

回调函数在函数调用时 , 是并行计算吗?

情况一:有DMA&并行

这个函数就是回调函数的一种, 在ADC数据搬运完之后 ,怎么告诉CPU呢?

就是通过这个函数 , 进入一个中断

在HAL_ADC_Start_DMA这个函数里,他会把一个回调函数注册给DMA的一个函数指针 , 作为这个回调函数的接口

也就是说ADC的数据传输完成了,DMA就会让CPU来处理这个回调函数 , 来处理ADC

所以这样的话 , 整个系统 , 就是在并行的

情况二:并发

假设在5ms内, 系统有 task1 , task2, task3 几个任务

task1 假设就是HAL_ADC_Start_DMA , 但是没有用DMA

task2 假设是save_ADC

task3 假设是decode_ADC

假设有三个ADC , ADC(1-3)

并没有依次启动1-3 , 当启动到ADC3的时候 , 12其实已经好了 , 但是因为程序流程的问题只能从上执行到下 , 在一个task里面 , 这时就可以用回调函数去解决一个事情 ,假设startADC1执行完以后 , save ADC 1 也完成了 , 就可以发送一个信号量给回调函数 , 告诉他有数据可以进行解包了 ,这个时候decode函数就可进行解码了

这个回调函数的作用就是:启动解包

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/10 12:00:48

插入排序与冒泡排序

排序的介绍排序指的就是将一组无序的数据按特定规则(升序或降序)重新排列为有序序列的过程。按是否占用额外空间分类内部排序:待排序的数据在内存中完成排序。外部排序:带排序的数据量极大,须借助外部存储设备存放。按排序的稳定性分类稳定排…

作者头像 李华
网站建设 2026/5/12 2:22:58

“整车十四自由度simulink模型:仿真、说明文档与参考文献”

整车十四自由度simulink模型(仿真+说明文档参考文献) 资料:仿真+说明文档参考文献 数据齐全,含说明文档,建模清晰可用,其中十四自由度模型可以控制四个车轮转向和转矩,包括纵向&…

作者头像 李华
网站建设 2026/5/11 23:46:15

毕设开源 基于深度学习二维码检测识别系统

文章目录 0 简介1 二维码基础概念1.1 二维码介绍1.2 QRCode1.3 QRCode 特点 2 机器视觉二维码识别技术2.1 二维码的识别流程2.2 二维码定位2.3 常用的扫描方法 4 深度学习二维码识别4.1 部分关键代码 最后 0 简介 今天学长向大家分享一个毕业设计项目 **毕业设计 基于深度学习…

作者头像 李华