《linux 内核全然剖析》 chapter 2 微型计算机组成结构

《linux 内核全然剖析》 chapter 2 微型计算机组成结构

微型计算机组成结构

系统的基本组成:


<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>


            软件是一种控制硬件操作和动作的指令流。


2.1 微型计算机的组成原理



<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>

    当中CPU通过地址线,数据线,和控制信号线组成的内部总线与系统其它部分进行数据通信。地址线用于提供内存或者I/O设备的地址,即指明须要读写的数据的详细位置。数据线用于在CPU和内存的I/O设备之间提供传输数据的通道,而控制线则负责指挥运行的详细读写操作




          除了CPU以外,现代计算机PC主板主要由两个超大规模芯片构成的芯片组(chipsets):北桥(Northbrige)和南桥(Southbrige)芯片。北桥芯片用于与CPU,内存,和AGP视频接口,这些接口传输的速度快,北桥起着储存控制器的控制作用,于是Intel把该芯片标号为MCH(memory control chip)。南桥用来管理低中速芯片,被称为ICH(IO control hub)


<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>



2.2 I/Oport寻址和控制方式

2.2.1 I/Oport和寻址

          port地址的设置一般有两种方法:统一编址和独立遍址


          port统一编址的原理就是把IO控制器的port地址归入储存器寻址地址空间范围内。因此这样的编址方式也被称作储存器映像编址。




我的Ubuntu里面查看/proc/ioports 能够看到各个控制器设备或设置能够使用的地址范围:

0000-0cf7 : PCI Bus 0000:00
  0000-001f : dma1
  0020-0021 : pic1
  0040-0043 : timer0
  0050-0053 : timer1
  0060-0060 : keyboard
  0064-0064 : keyboard
  0070-0071 : rtc0
  0080-008f : dma page reg
  00a0-00a1 : pic2
  00c0-00df : dma2
  00f0-00ff : fpu
  0170-0177 : 0000:00:07.1
    0170-0177 : ata_piix
  01f0-01f7 : 0000:00:07.1
    01f0-01f7 : ata_piix
  02f8-02ff : serial
  0376-0376 : 0000:00:07.1
    0376-0376 : ata_piix
  0378-037a : parport0
  03c0-03df : vga+
  03f2-03f2 : floppy
  03f4-03f5 : floppy
  03f6-03f6 : 0000:00:07.1
    03f6-03f6 : ata_piix
  03f7-03f7 : floppy
  03f8-03ff : serial
  0cf0-0cf1 : pnp 00:00
0cf8-0cff : PCI conf1
0d00-feff : PCI Bus 0000:00
  1000-103f : 0000:00:07.3
    1000-103f : pnp 00:00
      1000-1003 : ACPI PM1a_EVT_BLK
      1004-1005 : ACPI PM1a_CNT_BLK
      1008-100b : ACPI PM_TMR
      100c-100f : ACPI GPE0_BLK
      1010-1015 : ACPI CPU throttle
  1040-104f : 0000:00:07.3
    1040-104f : pnp 00:00
  1060-107f : pnp 00:0c
  1080-10bf : 0000:00:07.7
  10c0-10cf : 0000:00:07.1
    10c0-10cf : ata_piix
  10d0-10df : 0000:00:0f.0
    10d0-10df : vmwgfx probe
  1400-14ff : 0000:00:10.0
  2000-3fff : PCI Bus 0000:02
    2000-203f : 0000:02:01.0
      2000-203f : e1000
    2040-207f : 0000:02:02.0
      2040-207f : Ensoniq AudioPCI
    2080-209f : 0000:02:00.0
      2080-209f : uhci_hcd
  4000-4fff : PCI Bus 0000:03
  5000-5fff : PCI Bus 0000:0b
  6000-6fff : PCI Bus 0000:13
  7000-7fff : PCI Bus 0000:1b
  8000-8fff : PCI Bus 0000:04
  9000-9fff : PCI Bus 0000:0c
  a000-afff : PCI Bus 0000:14
  b000-bfff : PCI Bus 0000:1c
  c000-cfff : PCI Bus 0000:05
  d000-dfff : PCI Bus 0000:0d
  e000-efff : PCI Bus 0000:15

2.2.2 接口訪问控制

三种方式:循环查询,中断处理,DMA传输


循环查询不须要过多的硬件支持,简单,可是耗费宝贵的CPU时间。

中断处理的方式须要有中断控制器的支持。linux 大多数都是採用这样的方式进行接口訪问。

直接存储器訪问,(Direct memory access),该方式用于IO设备与系统直接进行批量的传输数据,整个操作过程不须要CPU的插手。有专门的DMA控制器来进行。



2.3 主存储器,BIOS和CMOS储存器

2.3.1 主存储器

就是那个RAM。。。



<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>




2.3.2 基本输入输出程序BIOS

存放在ROM里面的系统BIOS程序主要用于计算机的开机运行系统各个部分的自检,建立起操作系统须要使用的各个配置表,如中断向量表,硬盘參数表 etc

<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>




2.3.3 CMOS 储存器

这家伙用的太少了。值得一提的是CMOS内存的地址空间在基本内存地址之外,须要仅仅用IO指令来訪问。



2.4 控制器和控制卡


2.4.1 中断控制器



<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>



2.4.2 DMA控制器

DMA控制器主要是通过外部设备直接与内存数据传输来增强系统的性能。

DMA数据传输能够不受CPU控制,所以CPU能够做其它事情。


2.4.4键盘控制器


当一个键被按下的时候,键盘发送扫描码被称为接通码(Make code),当一个键放开时发送的扫描码称为断开码(Break code)。


2.4.5串行控制卡

1.原理

<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>

      串行通信是指在线路上以位数据流一次一个的进行传输的通信方式。串行通信能够分为同步串行通信和异步串行通信。它们之间的主要差别在于,传输时同步的通信单位或帧的长度不同。异步串行通信以一个字符作为通信单位或一帧进行传输,而同步串行通信则以多个字符或字节组成的序列作为一帧数据进行传输。


2.串行通信的传输格式



<span>《linux 内核全然剖析》 chapter 2 微型计算机组成结构</span>

        当无数据传输时,发送方处于传号(Mark)状态,持续发送1.若须要发送数据,则发送方须要首先发送一个位间隔时间的空号起始位。接收方收到空号之后,就開始与发送方同步,然后接受随后的数据。若程序中设置奇偶校验位,那么在数据传输完毕之后,还须要接收奇偶校验位。






版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119116.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 计算机3级数据库技术考哪些内容,计算机考试三级数据库技术考试大纲[通俗易懂]

    计算机3级数据库技术考哪些内容,计算机考试三级数据库技术考试大纲[通俗易懂]全国计算机等级考试采用全国统一命题,统一考试的形式。所有科目每年开考两次。下面是小编整理的计算机考试三级数据库技术考试大纲,欢迎大家参考!基本要求1.掌握数据库技术的基本概念、原理、方法和技术。2.能够使用SQL语言实现数据库操作。3.具备数据库系统安装、配置及数据库管理与维护的基本技能。4.掌握数据库管理与维护的`基本方法。5.掌握数据库性能优化的基本方法。6.了解数据库应用系统的生命周期及其设…

    2022年6月21日
    31
  • TCP/IP三次握手与四次挥手学习笔记(二)

    TCP/IP三次握手与四次挥手学习笔记(二)

    2022年2月14日
    144
  • k8s 资源管理_pod容器间调用命令

    k8s 资源管理_pod容器间调用命令k8s管理器介绍yaml资源管理器介绍管理器介绍在Kubernetes中,所有的内容都抽象为资源,用户需要通过操作资源来管理Kubernetes。Kubernetes的本质就是一个集群系统,用户可以在集群中部署各种服务。所谓的部署服务,其实就是在Kubernetes集群中运行一个个的容器,并将指定的程序跑在容器中。Kubernetes的最小管理单元是Pod而不是容器,所以只能将容器放在Pod中,而Kubernetes一般也不会直接管理Pod,而是通过Pod控制器来管理Pod的。Pod提供服务之后

    2022年8月9日
    5
  • 项目范围管理:项目范围管理的概念是什么_项目范围管理规划案例

    项目范围管理:项目范围管理的概念是什么_项目范围管理规划案例项目范围管理包括确保项目做且只做所需的全部工作,以成功完成项目的各个过程。 项目范围管理关注的焦点是:什么是包括在项目之内的,什么是不包括在项目之内的,即为项目工作明确划定边界。 对项目范围管理和控制的有效性,是衡量项目是否达到成功的一个必要标准,项目范围的管理不仅仅是项目整体管理的一个主要部分,同时在项目中不断地重申项目工作范围,有利于项目不偏离轨道,是项目中实施控制管理的一个主要手段。 项目范围是项目其他各方面管理的基础。如果范围都弄不清楚,成本、进度和质量等就无从谈起。确认项目范围对项目管理有如

    2022年9月22日
    2
  • IDOR漏洞接管Facebook页面,获1万6千美金奖励「建议收藏」

    IDOR漏洞接管Facebook页面,获1万6千美金奖励「建议收藏」印度小哥的自拍有点曝光过度了啊 Facebook能给出这么高的奖励,好棒啊发现Facebook零日漏洞,获得10万7千元人民币奖励安全研究人员发现Facebook存在零日漏洞!可以接管Facebook的任何页面。Facebook几乎是中小企业推广自家产品的最高效又低成本的平台。合理借用Facebook的关键在于装帧好某项产品或服务的Facebook页面,品牌、企业、组织和

    2022年6月11日
    34
  • 浅谈QFile

    浅谈QFileQFile是QT中用来处理文件方面的类,对于普通的文件读取,写入,都需要用上的。 简单的一个实例:#include”widget.h”#include”ui_widget.h”#include#include#includeWidget::Widget(QWidget*parent):QWidget(parent),

    2022年5月29日
    43

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号