数据传送是指数据在计算机内部或计算机之间或计算机系统与其他系统之间的传送操作[1]

。这里数据传送是指内存与外存和I/O设备之间的传送操作。批量数据传送是指内存与外存之间成批的传送数据,而不是一次传送一个字(节)。这有利于减少主机对 I/O 控制的干预,把主机从繁杂的 I/O 控制事务中解脱出来,以便更多地去完成数据处理任务。

中文名

批量数据传送

外文名

Batch data transfer

学    科

计算机目    的

解放主机、提高系统效率

定    义

成批传送数据

领    域

硬件设计、I/O控制

批量数据传送定义

编辑

语音

计算机与外设之间进行数据传送有三种基本控制方式:查询方式、中断方式和DMA方式。其中前两种方式都是以字(节)为传送单位。而DMA属于批量数据传送方式。批量数据传送是指内存与外存之间成批的传送数据,而不需要CPU的干预,这也是批量数据传送方式出现主要动力。在计算机中,CPU资源是十分宝贵的,而CPU与外设运行速度不在一个数量级,因此,在 I/O 控制方式的整个发展过程中,始终贯穿着这样一条宗旨,即尽量减少主机对 I/O 控制的干预,把主机从繁杂的 I/O 控制事务中解脱出来,以便更多地去完成数据处理任务,提高系统效率。

批量数据传送数据传送方式

编辑

语音

批量数据传送传送方式

DMAC中主要包括一个控制状态寄存器、一个地址寄存器和一个字节计数器,在传送开始前先要对这些寄存器进行初始化,一旦传送开始,整个过程便全部由硬件实现,所以数据传送速率非常高。

DMA数据传送(以数据输入为例)按以下步骤进行:

(1)外围设备发选通脉冲,把输入数据送入缓冲寄存器,并使DMA请求触发器置1;

(2)DMA请求触发器向控制/状态端口发准备就绪信号,同时向DMA控制器发DMA请求信号;

(3)DMA控制器向CPU发出总线请求信号(HOLD);

(4)CPU在完成了现行机器周期后,即响应DMA请求,发出总线允许(HLDA),并由DMA控制器发出DMA响应信号,使DMA请求触发器复位。此时,由DMA控制器接管系统总线;

(5)DMA控制器发出存储器地址,并在数据总线上给出数据,随后在读/写控制信号线上发出写的命令;

(6)来自外设的数据被写入相应存储单元;

(7)每传送一个字节,DMA控制器的地址寄存器加1,从而得到下一个地址,字节计数器减1。回到(5),传送下一个数据。如此循环,直到计数器的值为0,数据传送完毕。

DMA传送完毕,由DMAC撤消总线请求信号,从而结束DMA操作。CPU撤消总线允许信号,恢复对总线的控制。

批量数据传送通道控制方式

虽然 DMA 方式比起中断方式来已经显著地减少了 CPU 的干预,即已由以字(节)为单位的干预减少到以数据块为单位的干预,但 CPU 每发出一条 I/O 指令,也只能去读(或写)一个连续的数据块。而当我们需要一次去读多个数据块且将它们分别传送到不同的内存区域,或者相反时,则须由 CPU 分别发出多条 I/O 指令及进行多次中断处理才能完成。I/O 通道方式是 DMA 方式的发展, 它可进一步减少 CPU 的干预, 即把对一个数据块的读(或写)为单位的干预减少为对一组数据块的读(或写)及有关的控制和管理为单位的干预。同时,又可实现 CPU、通道和 I/O 设备三者的并行操作,从而更有效地提高整个系统的资源利用率。例如,当 CPU 要完成一组相关的读(或写)操作及有关控制时,只需向 I/O 通道发送一条 I/O 指令,以给出其所要执行的通道程序的首址和要访问的 I/O 设备,通道接到该指令后,通过执行通道程序便可完成 CPU 指定的 I/O 任务。[2]

批量数据传送查询传送

编辑

语音

批量数据传送查询方式

查询方式是通过执行输入/输出查询程序来完成数据传送的,工作原理是:当CPU启动外设工作后,不断地读取外设的状态信息进行测试,查询外设是否准备就绪,如外设准备好,则可以进行数据传送;否则,CPU继续读取外设的状态信息进行查询等待,直到外设准备好。

采用程序查询方式进行数据传送时,实际上在外设准备就绪之前,CPU一直处于等待状态,致使CPU的利用率较低。倘若CPU按这种方式与多个外设传送数据时,就需要周期性的依次查询每个外设的状态,浪费的时间就更多,CPU的利用率就更低。因此,这种方式适合于工作不太繁忙的系统。[3]

批量数据传送中断传送方式

中断传送方式是指当外设需要与CPU进行信息交换时,由外设向CPU发出请求信号,使CPU暂停正在执行的程序,转去执行数据的输入/输出操作,数据传送结束后,CPU再继续执行被暂停的程序。查询传送方式是由CPU来查询外设的状态,CPU处于主动地位,而外设处于被动地位。中断传送方式则是由外设主动向CPU发出请求,等候CPU处理,在没有发出请求时,CPU和外设都可以独立进行各自的工作。目前的微处理器都具有中断功能,而且已经不仅仅局限于数据的输入/输出,而是在更多的方面有重要的应用。例如实时控制、故障处理以及BIOS和DOS功能调用等。有关中断技术的具体内容将在下一节做介绍。

中断传送方式的优点是:CPU不必查询等待,工作效率高,CPU与外设可以并行工作;由于外设具有申请中断的主动权,故系统实时性比查询方式要好得多。但采用中断传送方式的接口电路相对复杂,而且,每进行一次数据传送就要中断一次CPU。CPU每次响应中断后,都要转去执行中断处理程序,都要进行断点和现场的保护和恢复,浪费了很多CPU的时间。故这种传送方式一般适合于少量的数据传送。对于大批量数据的输入/输出,可采用高速的直接存储器存取方式,即DMA方式。[4]

词条图册

更多图册

参考资料

1.

张效祥.计算机科学技术百科全书:清华大学出版社,2005

2.

汤子瀛.计算机操作系统:西安电子科技大学出版社,2010

3.

输入/输出的控制方式

..tyut.edu.cn/[引用日期2017-06-18]

4.

CPU与外设之间数据传送的方式

.csxupt[引用日期2017-06-18]

计算机系统通过执行通道程序完成数据,批量数据传送相关推荐

  1. 你好,C++(23) 4.4.2 工资程序成长记:用数组处理批量数据,用循环结构执行重复动作...

    4.4  从语句到程序 了解了各种表达式和语句之后,就相当于掌握了写作文要用到的词语和句子,但是,仅有词语和句子是无法构成一篇有意义的文章的.要完成一篇文章,先需要确定这篇文章的结构,是先分述再总述, ...

  2. (转载)你好,C++(23) 4.4.2 工资程序成长记:用数组处理批量数据,用循环结构执行重复动作...

    你好,C++(23) 4.4.2 工资程序成长记:用数组处理批量数据,用循环结构执行重复动作 4.4  从语句到程序 了解了各种表达式和语句之后,就相当于掌握了写作文要用到的词语和句子,但是,仅有词语 ...

  3. 将表里的数据批量生成INSERT语句的存储过程 增强版

    原文:将表里的数据批量生成INSERT语句的存储过程 增强版 将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的 ...

  4. word录入表单数据 java 导入系统,java导入excel | 怎么把excel中的数据批量导入到word中的表格中...

    用javascript怎么实现把excel中的数据批量导入到数据库表中 这个js不能直接实现吧 我们程序用到 先读取excel内容转换成数组 然后放到页面上 再提交表单 储存 MySql如何批量添加数 ...

  5. 《从0到1学习Flink》—— Flink 读取 Kafka 数据批量写入到 MySQL

    <!-- more --> 前言 之前其实在 <从0到1学习Flink>-- 如何自定义 Data Sink ? 文章中其实已经写了点将数据写入到 MySQL,但是一些配置化的 ...

  6. oracle批量加载,Oracle教程:使用SQL*Loader高速批量数据加载工具

    Oracle教程:使用SQL*Loader高速批量数据加载工具 1.控制文件中包含要加载的数据 首先创建一张测试表 然后创建一个控制文件(其中包含被加载的数据) 然后在命令行执行加载 查看dept表 ...

  7. bulkwrite 批量插入_SQL SERVER 使用BULK Insert将txt文件中的数据批量插入表中(1)

    1/首先建立数据表 CREATE TABLE BasicMsg ( RecvTime FLOAT NOT NULL , --接收时间,不存在时间相同的数据 AA INT NOT NULL, --24位 ...

  8. [整理]MySql批量数据导入Load data infile解决方案

    有时候我们需要将大量数据批量写入数据库,直接使用程序语言和Sql写入往往很耗时间,其中有一种方案就是使用MySql Load data infile导入文件的形式导入数据,这样可大大缩短数据导入时间. ...

  9. 性能测试中批量数据制作实例的多种方法讨论

    摘 要: JAVA编程批量制造数据,UNIX SHELL脚本批量制造数据,ULTRAEDIT结合EXCEL批量制造数据         关键词: 批量制作数据,ULTRAEDIT,EXCEL,JAVA ...

最新文章

  1. 【map】【HDOJ】5233 Gunner II
  2. opa847方波放大电路_电子设计竞赛教程-信号发生电路
  3. semihost/ITM机制浅析以及使用JLINK通过ITM调试stm32单片机
  4. 汇编语言实现led灯的跑马灯
  5. 关于线程池的一段代码
  6. android实体键盘输入法,推荐一个实体键盘专用输入法,是对 autotext的改进
  7. ICCV7 For AVR 使用教程 Atmega16 单片机
  8. 嵌入式软件开发与互联网软件开发模式差异
  9. 小程序跳转样式布局错乱_微信小程序页面布局问题
  10. 服务器性能监控之WMI
  11. epsfallback_EPS网络CS Fallback技术研究
  12. 【帝国CMS】灵动标签调用标题图片没有图片时显示默认图片
  13. 什么是失血模型和充血模型?(DDD)
  14. 海思对接索尼ECX334 RGB OLED屏总结
  15. 天平游码读数例题_天平使用练习题
  16. 我的世界java版1.7.10咋刷物品,1.7指令方块刷自定义药水教程
  17. 前装ADAS单月搭载量创11个月以来新低,“缺芯”背后暗潮涌动
  18. JAVA接入讯飞离线合成语音
  19. 北电破产意味着电信业贵族时代的结束
  20. 以全能之力造非凡旗舰:荣耀Magic3系列新品发布

热门文章

  1. bitmap设置图片尺寸缩小,避免内存溢出/OutOfMemoryError的优化方法
  2. Intent打开各种类型的文件
  3. juniper srx解决内网不能telnet公网IP的方法
  4. Python3 对于中文文件的读写处理
  5. ibatis 中isNull, isNotNull与isEmpty, isNotEmpty区别
  6. ORACLE SELECT INTO NO_DATA_FOUND问题
  7. 在VS2010里可以给JS函数添加代码提示\注释
  8. Extjs 动态生成表格
  9. MySql数据库连接池
  10. CentOS 6.2编译安装Nginx1.2.0+MySQL5.5.25+PHP5.3.13+博客系统WordPress3.3.2