“使用直接内存访问(DMA)模块,在不需要CPU干预的情况下实现外设与内存之间的数据传输”和“中断路径分为3个阶段:外设中断、PIE中断、CPU中断”这两句话是否冲突?DMA 的数据搬运(从AD采样结果寄存器到SDRAM)是否会占用CPU的资源?是否需要CPU停下
这两句话并不冲突。DMA可以在不需要CPU干预的情况下实现外设与内存之间的数据传输,即DMA可以独立完成数据传输的操作,而CPU可以继续执行其他任务。而中断是一种CPU资源的利用方式,当外设出现中断时,CPU需要从当前任务中断下来,处理中断请求,这个过程需要CPU的干预。
在数据搬运的过程中,DMA会占用一定的CPU资源,但是DMA的操作是并行的,因此相对于CPU而言,DMA的占用时间是很短的。在DMA操作期间,CPU不需要停下,可以继续执行其他任务。但是在DMA操作开始之前,需要先进行一些配置和初始化工作,这个过程可能需要CPU的干预。因此,DMA的数据搬运不会长时间占用CPU的资源,但是在DMA操作开始之前需要进行一些CPU的干预操作。
既然是dma,那么就io控制器直接将数据写入内存了,不需要cpu
不知道你这个问题是否已经解决, 如果还没有解决的话: