DMA方式的知识点笔记

                                                                            苏泽 

“弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家


目录

1. DMA基本概念

2. DMA传送过程

易错点

DMA控制器操作流程

3. DMA传送方式

这是单总线的结果 (CPU说了算 所以不会产生于CPU的冲突)

这是三总线的结构 (也就是主存下面另外接了一条线到DMA所以 有可能于CPU发生冲突)

5. DMA的组成

6. DMA与其他方式的比较

7. DMA的优缺点

8. DMA的应用场景

9. DMA的中断处理

10. DMA的实现方式


 

1. DMA基本概念

  • DMA(直接内存访问)是一种硬件实现的数据传输方式,允许外围设备直接与主存交换数据,而不需要CPU的干预。
  • DMA方式的基本单位是数据块,数据在I/O设备和内存之间直接传输。

2. DMA传送过程

  • 预处理:CPU完成一些必要的工作,如测试状态、启动设备等,然后继续执行其他任务。
  • 数据传送:DMA设备准备好后,会主动向DMA控制器(DMAC)发出DMA请求,DMAC向CPU发出总线请求。
  • 数据传送后处理:数据传送满一个块后,DMAC向CPU发出中断请求,CPU执行中断程序,进行数据校验、测试传送过程等。

易错点

其实题目问你 CPU 用于 DMA 处理的时间占比,本质上就是在问你 DMA 预处理 +后处理
时间占比
因为其他的部分根本不占时间!
如下

DMA控制器操作流程

  1. CPU响应DMA请求(传送前

    • 当DMA控制器发出总线请求后,CPU响应此请求,并发出总线响应信号。
  2. 接管总线控制权(传送前

    • CPU接管系统总线控制权,准备进入DMA操作周期。
  3. DMA操作周期

    • CPU进入DMA操作周期,此时DMA控制器可以独立进行数据传输。
  4. 数据传送方向与控制信号

    • DMA控制器规定数据在主存和外设之间的传送方向。
    • 发出读写等控制信号,以执行数据传送操作。
  5. 数据传送完成

    • 数据传送完成后,DMA控制器将向CPU报告操作的结束。
  6. 操作结束报告 (传送后

    • DMA操作结束后,DMA控制器会通知CPU,以便CPU可以继续执行其他任务。

3. DMA传送方式

这是单总线的结果 (CPU说了算 所以不会产生于CPU的冲突)

这是三总线的结构 (也就是主存下面另外接了一条线到DMA所以 有可能于CPU发生冲突)

  1. 停止CPU访问主存

    • 目的:在DMA传输期间,完全控制主存,避免与CPU的访问冲突。
    • 操作:在DMA传输期间,暂停CPU对主存的访问。
    • 优点
      • 控制简单,易于实现。
      • DMA可以完全控制主存,提高数据传输效率。
    • 缺点
      • CPU在传输期间不执行程序,导致CPU资源未被充分利用。
  2. DMA与CPU交替访存

    • 目的:允许CPU和DMA控制器交替访问主存,提高资源利用率。
    • 操作
      • 将CPU周期分为两个部分,C1周期专供CPU访存,C2周期专供DMA访存。
      • DMA控制器和CPU交替进行访存操作,无需申请总线使用权。
    • 优点
      • 有效利用CPU和DMA资源,提高系统效率。
    • 缺点
      • 硬件逻辑更为复杂,需要精确控制访问时间。
  3. 周期挪用(周期窃取)

    • 目的:在CPU未使用总线时,允许DMA控制器访问主存。
    • 操作
      • DMA控制器检测CPU的访存周期,当CPU不访存时,DMA控制器利用这个周期进行数据传输。
      • 如果CPU和DMA同时请求访存,根据优先级决定谁先访问主存。
    • 优点
      • 最大限度减少对CPU性能的影响,提高主存的利用率。
    • 缺点
      • 实现较为复杂,需要高级的硬件支持来检测和响应访问请求。
  • DMA请求:表示要向主存传送一个字的数据。
  • DMA中断请求:表示一整块的数据已经传送完成。

5. DMA的组成

  • 主存地址计数器:存放要交换的主存地址。
  • 传送长度计数器:记录传送数据的长度。
  • 数据缓存寄存器:暂存每次传送的数据。
  • DMA请求触发器:I/O设备准备好数据后使触发器置位。
  • 控制/状态逻辑:完成中断机构,数据块传送完毕后触发中断。

6. DMA与其他方式的比较

  • 中断驱动方式:I/O设备主动打断CPU运行请求服务,但每个数据传输需经过CPU。
  • 通道控制方式:专门负责输入/输出的处理机,进一步减少CPU干预,实现并行操作。

7. DMA的优缺点

  • 优点:减少了CPU的干预,提高了数据传输效率。
  • 缺点:在数据块传送的开始和结束时需要CPU干预。

8. DMA的应用场景

  • DMA适用于大量数据的快速传输,如磁盘读写操作。

9. DMA的中断处理

  • 中断服务程序中,CPU需要处理数据校验、传送过程测试等任务,并决定是否继续使用DMA传送。

10. DMA的实现方式

  • DMA的实现依赖于硬件电路,不需要程序干预,是一种纯硬件实现的数据传输方式。


另外,利用了工作之余的一点点时间,整理了一套考研408的知识图谱,

我根据这一套知识图谱打造了这样一个408知识图谱问答系统

里面的每一个回答都是根据考研408的考点回复的

目前暂时只接入了微信,如果大家对这个问答系统感兴趣的话可以在我的主页里找到我的微信号

找我拉进测试群免费体验哦


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3224050.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

新闻资讯整合平台:一站式满足企业信息需求

摘要: 面对信息爆炸的时代,企业如何在海量数据中快速获取有价值资讯,成为提升竞争力的关键。本文将探讨如何通过一站式新闻资讯整合平台,实现企业信息需求的全面满足,提升决策效率,同时介绍实用工具推荐&a…

Transformer中的编码器和解码器结构有什么不同?

Transformer背后的核心概念:注意力机制;编码器-解码器结构;多头注意力等; 例如:The cat sat on the mat; 1、嵌入: 首先,模型将输入序列中的每个单词嵌入到一个高维向量中表示&…

Vuforia AR篇(八)— AR塔防上篇

目录 前言一、设置Vuforia AR环境1. 添加AR Camera2. 设置目标图像 二、创建塔防游戏基础1. 导入素材2. 搭建场景3. 创建敌人4. 创建脚本 前言 在增强现实(AR)技术快速发展的今天,Vuforia作为一个强大的AR开发平台,为开发者提供了…

工业机床CNC设备如何上云?

工业机床CNC设备如何上云? 工业机床的计算机数控(CNC)设备实现远程监控数据上云,是现代制造业智能化转型的关键一环。这一过程不仅能够实时监测设备状态、优化生产流程,还能通过大数据分析提升生产效率与产品质量&…

数据结构--二叉树相关习题5(判断二叉树是否是完全二叉树 )

1.判断二叉树是否是完全二叉树 辨别: 不能使用递归或者算节点个数和高度来判断。 满二叉树可以用高度和节点来判断,因为是完整的。 但是完全二叉树前面是满的,但是最后一层是从左到右连续这种 如果仍然用这种方法的话,如下图…

Chromium编译指南2024 Linux篇-同步Chromium第三方库(四)

1.引言 在成功拉取Chromium源码并创建新分支后,我们需要进一步配置开发环境。这包括拉取必要的第三方库以及设置hooks,以确保我们能够顺利进行编译和开发工作。以下步骤将详细介绍如何进行这些配置。 2.拉取第三方库以及hooks Chromium 使用了大量的第…

WSL2编译使用6.6版本内核

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、有什么变化二、下载6.6内核三、开始编译1.安装环境2.开始编译 四、使用1.杀死虚拟机2.防止内核文件3.修改配置文件 总结 前言 最近出了一件不大不小的事&a…

【前端速通系列|第二篇】Vue3前置知识

文章目录 1.前言2.包管理工具npm2.1下载node.js2.2配置 npm 镜像源2.3 npm 常用命令 3.Vite构建工具4.Vue3组件化5.Vue3运行原理 1.前言 本系列文章旨在帮助大家快速上手前端开发。 2.包管理工具npm npm 是 node.js中进行 包管理 的工具. 类似于Java中的Maven。 2.1下载nod…

C++之goto陈述

关键字 goto用于控制程式执行的顺序&#xff0c;使程式直接跳到指定标签(lable) 的地方继续执行。 形式如下 标签可以是任意的识别字&#xff0c;后面接一个冒号。 举例如下 #include <iostream>int main() {goto label_one;label_one: {std::cout << "Lab…

第241题| 确定极限中参数问题 | 武忠祥老师每日一题

解题思路&#xff1a;确定极限中的参数的方法是求这个极限&#xff1b;求极限根据类型选方法。 形可以用到三种方法&#xff1a;洛必达&#xff0c;等价&#xff0c;泰勒。 先观察题目&#xff0c;将看成一个整体&#xff0c;同时,并令,整理之后如下&#xff1a; 这里也要想办…

如何使用uer做多分类任务

如何使用uer做多分类任务 语料集下载 找到这里点击即可 里面是这有json文件的 因此我们对此要做一些处理&#xff0c;将其转为tsv格式 # -*- coding: utf-8 -*- import json import csv import chardet# 检测文件编码 def detect_encoding(file_path):with open(file_path,…

16:9横屏短视频素材库有哪些?横屏短视频素材网站分享

在这个视觉内容至关重要的时代&#xff0c;16:9横屏视频因其宽广的画面和优越的观赏体验&#xff0c;已经成为无数创作者和营销专家的首选格式。但要创造出吸引人的横屏视频&#xff0c;高质量的视频素材库是不可或缺的。不管你是资深视频制作人还是刚入行的新手&#xff0c;下…

13 - matlab m_map地学绘图工具基础函数 - 介绍创建管理颜色映射的函数m_colmap和轮廓图绘制颜色条的函数m_contfbar

13 - matlab m_map地学绘图工具基础函数 - 介绍创建管理颜色映射的函数m_colmap和轮廓图绘制颜色条的函数m_contfbar 0. 引言1. 关于m_colmap2. 关于m_contfbar3. 结语 0. 引言 本篇介绍下m_map中用于创建和管理颜色映射函数&#xff08;m_colmap&#xff09;和 为轮廓图绘制颜…

JFlash读取和烧录加密stm32程序

JFlash读取和烧录加密stm32程序 安装后JFlash所在的目录&#xff1a;C:\Program Files\SEGGER\JLink 一、烧写加密程序 1、打开C:\Program Files\SEGGER\JLink目录&#xff0c;找到JFlash.exe,双击它&#xff0c;就可以打开该执行程序。见下图&#xff1a; 2、选择“Create …

微信小程序毕业设计-书店系统项目开发实战(附源码+论文)

大家好&#xff01;我是程序猿老A&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f49e;当前专栏&#xff1a;微信小程序毕业设计 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; &#x1f380; Python毕业设计…

骏网一卡通之类的游戏卡有什么用?

感觉现在打端游的人越来越少了 而且游戏充值卡显得就很鸡肋&#xff0c;在家里整理东西&#xff0c;翻出来好多骏网一卡通&#xff0c;但是我又不打游戏 想着把这卡送给有需要的朋友&#xff0c;不然也是浪费&#xff0c;问了一圈送不出去 还好最后在收卡云上卖掉了&#xf…

【QT中实现摄像头播放、以及视频录制】

学习分享 1、效果图2、camerathread.h3、camerathread.cpp4、mainwindow.h5、mainwindow.cpp6、main.cpp 1、效果图 2、camerathread.h #ifndef CAMERATHREAD_H #define CAMERATHREAD_H#include <QObject> #include <QThread> #include <QDebug> #include &…

mysql 5.7.44 32位 zip安装

前言 因为研究别人代码&#xff0c;他使用了5.7的 32位 mysql &#xff0c;同时最新的 8.4 64位 mysql 不能用官方lib连接。所以安装这个版本使用&#xff0c;期间有些坑&#xff0c;在这里记录一下。 下载路径 mysql官方路径&#xff1a;https://downloads.mysql.com/archi…

c++ primer plus 第15章友,异常和其他:15.1.2 友元成员函数

#c primer plus 第15章友&#xff0c;异常和其他&#xff1a;15.1.2 友元成员函数 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 例如&#xff1a;15.1.2 友元成员函数 提示&#xff1a;写完文章后&#xff0c;目录可以自动生成&am…

01:简易的电动车防盗报警器

简易的电动车防盗报警器 1、震动传感器模块的使用2、使用震动传感器模块控制继电器开关3、433M无线发射接收模块的使用 需要材料&#xff1a; 1、51单片机 2、震动传感器模块 3、继电器模块 4、高功率喇叭 5、433M无线发射接收模块 6、弱干杜邦线 1、震动传感器模块的使用 接好…