了解一下IO控制器与控制方式

IO控制器

CPU无法直接控制IO设备的机械部件,因此IO设备还要有个电子部件作为CPU和IO设备机械部件之间的“中介”,用于实现CPU对设备的控制。
这个电子部件就是IO控制器,又称为设备控制器。CPU可控制IO控制器,IO控制器来控制设备的机械部件。

IO控制器的功能

  • 接收设备CPU指令:CPU的读写指令和参数存储在控制寄存器中
  • 向CPU报告设备的状态:IO控制器中会有相应的状态寄存器,用于记录IO设备的当前状态。(比如1代表设备忙碌,0代表设备就绪)
  • 数据交换:数据寄存器,暂存CPU发来的数据和设备发来的数据,之后将数据发给控制寄存器或CPU。
  • 地址识别:类似于内存的地址,为了区分设备控制器中的各个寄存器,需要给各个寄存器设置一个特定的地址。IO控制器通过CPU提供的地址来判断CPU要读写的是哪个寄存器。

IO控制器的组成

CPU控制器之间的接口(实现控制器与CPU之间的通信),IO逻辑(负责识别CPU发出的命令,并向设备发出命令),控制器与设备之间的接口(实现控制器与设备之间的通信)
两种寄存器编址方式
**内存映射IO:**控制器中的寄存器与内存统一编制,可以采用对内存进行操作的指令来对控制器进行操作。
寄存器独立编制:控制器中的寄存器独立编制。需要设置专门的指令来操作控制器。

I/O控制方式

程序直接控制方式

CPU向IO模块发出读指令,CPU会从状态寄存器中读取IO设备的状态,如果是忙碌状态就继续轮询检查状态,如果是已就绪,就代表IO设备已经准备好,可以从中读取数据到CPU寄存器中(IO->CPU)读到CPU后,CPU还要往存储器(内存)中写入数据。写完后,再执行下一套指令。
在这里插入图片描述

CPU干预的频率:很频繁,IO操作开始之前、完成之后需要CPU的介入,并且在等待IO完成的过程中CPU需要不断的轮询检查。
数据流向

  • 读操作(数据的输入):IO设备->CPU->内存
  • 写操作(数据的输出):内存->CPU->IO设备
    每个字的读写都需要CPU的帮助。
    主要缺点和主要优点
    优点:实现简单。在读写指令之后,加上实现循环检查的一些列指令即可。
    缺点:CPU和IO设备只能串行化工作,CPU需要一直轮询检查,长期处于忙等状态,CPU利用率很低。
中断驱动方式

因为IO设备速度很快,CPU处理速度很快,因此在CPU发出读写命令后,可将等待IO的进程阻塞,先切换到别的进程执行。当IO完成后控制器会向CPU发出一个中断信号,CPU检测到中断信号后,会保存当前进程的运行环境信息,转去执行中断处理程序。这样就使得CPU与IO设备能够并行工作。

优点:与程序直接控制方式相比,在中断驱动方式中,IO控制器会通过中断信号主动报告IO已完成,CPU不再需要不停的轮询。CPU和IO设备可并行工作,CPU利用率得到明显提升。
缺点:每个字在IO设备与内存之间的传输,都需要经过CPU。而频繁的中断处理会消耗很多的CPU时间。

在这里插入图片描述

DMA(直接存储方式)

与中断驱动方式相比,DMA方式有以下改进。

  1. 数据的传送单位是“块”。
  2. 数据的流向是从设备直接放入内存,或者是从内存直接到设备。不在使用CPU作中间者。
  3. 仅仅在传送一个或多个数据块的开始和结束时,才需要CPU的干预。
    CPU在读写之前要指明要读入多少数据、数据要存放在内存中的什么位置、数据放在外部磁盘的什么位置。
    DMA控制器会根据CPU踢出的要求完成数据的读写操作,整块数据的传输完成后,才像CPU发出中断信号。

在这里插入图片描述

  • DR:暂存从设备到内存,或从内存到设备的数据。

  • MAR(内存地址寄存器):再输入时,MAR表示数据应放在内存中的什么地方,输出时MAR表示要输出的数据放在内存中的什么位置。

  • DC(数据计数器):表示剩余要读/写的字节数

  • CR(命令/状态寄存器):用于存放CPU发来的IO命令,或设备的状态信息。

  • CPU干预的频率:仅在传送一个或多个数据块的开始和结束时,才需要CPU的干预。

数据传送单位是以为单位,每次读写一个或多个块(需要注意的是读写的只能是连续的块,且这些块读入内存后在内存中也必须是连续的)
数据的流向也不再需要CPU干预。

优点:数据传输效率以块为单位,CPU的介入性进一步降低。CPU和IO设备的并行性进一步提升。
缺点:CPU发出一条指令,只能读或写一个或多个连续的数据块。如果读或写的数据块不是连续存放的而是离散的,那么CPU要分别发出多条IO指令,进行多次中断处理才能完成。

通道控制方式

通道是一种硬件,可以理解为“弱鸡版的CPU”。通道只能执行一类通道指令。
因为通道与CPU相比的话,CPU能够处理的指令的种类比通道多,也就是说通道执行的指令单一,他与CPU共用主机的内存。

具体处理过程:
CPU将操作步骤告诉通道,通道程序会把操作的指令列在一个类似于“任务清单上”。然后剩下的事CPU就不参与了,等到通道把指令执行完后,发出一个中断,告诉CPU我处理完了,然后CPU在处理后续操作。

这时候的CPU就像一个每天忙碌的大老板,通道就是小组的组长之类的,老板很忙,把一些任务交给组长去做,做完后得汇报给老板。

使用这种方式CPU干涉的频率极低,通道会根据CPU的指示执行响应的通道程序,只有完成一组数据块的读写后才需要发出中断信号让CPU干预。

每次读写一组数据块。

优点:CPU 通道、IO设备可并行工作,资源利用率极高。
缺点:实现复杂,需要专门的通道硬件支持。

总结

在这里插入图片描述

  • 7
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: FPGA是现场可编程门阵列的缩写,是一种集成电路芯片,可以通过编程来实现特定功能。LVDS(低压差分信号)是一种高速的数字信号传输技术,常用于视频、音频和数据传输。LCD控制器控制液晶显示屏的电子设备。 要使用FPGA实现LVDS信号输出LCD控制器,我们可以使用Verilog语言进行编程。 首先,我们需要了解所使用的FPGA芯片和LCD控制器的规格和接口要求。然后,根据LCD控制器的输入信号和时序,设计和实现相应的Verilog模块。 在Verilog中,我们可以使用模块化的方式构建设计,将各个功能模块分离开来。例如,我们可以设计一个模块来生成LVDS信号,并将其连接到LCD控制器模块的输出端口。我们还可以设计一个模块来处理LCD控制器的输入信号,并将其连接到FPGA芯片的其他功能模块。 在设计中,我们需要考虑时序和同步问题,以确保数据的准确传输和显示。我们可以使用时钟信号和状态机来控制数据的发送和接收。 实现过程中,我们需要根据FPGA芯片的规格和开发环境的要求进行编程和调试。在完成编程后,我们可以使用仿真工具来验证设计的正确性和功能性,确保它能够正确地输出LVDS信号并控制LCD显示屏。 总之,使用FPGA实现LVDS信号输出LCD控制器涉及Verilog编程和设计模块化的过程。通过正确的设计和调试,我们可以实现高质量的LVDS信号输出,并成功控制LCD显示屏的功能。 ### 回答2: FPGA是一种可编程逻辑器件,可用于实现各种数字电路功能。LVDS(Low Voltage Differential Signaling)是一种高速差分信号传输技术,常用于视频信号传输和LCD控制器中。而Verilog是一种硬件描述语言,可以用来描述和设计数字电路。 对于使用FPGA实现LVDS信号输出LCD控制器,首先需要对LCD的驱动进行了解,包括时序和信号特性等。然后,我们可以使用Verilog语言来编写LCD控制器的逻辑电路。 要实现LVDS信号输出,我们需要利用FPGA的高速差分信号IO资源和LVDS驱动器。在Verilog代码中,我们可以使用FPGA的差分信号IO接口来定义LVDS信号输出引脚,并使用相应的差分信号输出的IP核接口。 在编写Verilog代码时,我们需要考虑时钟和数据的同步问题。通常,LCD控制器使用一个时钟信号来进行数据传输和控制。我们可以使用FPGA内部的时钟网进行时钟分频和同步控制。同时,我们还需要定义和实现数据线与LVDS的转换逻辑,以将图像数据转换为LVDS格式的数据。 为了验证我们的设计,我们可以通过仿真或硬件验证的方式进行测试。在仿真过程中,我们可以使用Verilog仿真软件对我们编写的代码进行功能验证。在硬件验证过程中,我们可以将设计烧录到FPGA芯片中,并连接FPGA芯片和LCD显示屏进行实际测试。 总而言之,通过使用FPGA来实现LVDS信号输出LCD控制器,我们可以通过Verilog代码对LCD的驱动逻辑进行描述和实现,并利用FPGA的差分信号IO资源和LVDS驱动器来实现高速差分信号输出。这种方法可以实现LCD控制器的灵活性和可编程性,以满足不同应用场景的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值