• 第一章: 微型计算机组成结构



    引言

    操作系统与所运行的硬件环境密切相关。如果想彻底理解操作系统运行全过程,那么就需要了解它的运行硬件环境。本章基于传统微机系统的硬件组成框图,介绍了微机中各个主要部分的功能。这些内容已基本能够建立起阅读Linux 0.11内核的硬件基础。为了便于说明,术语PC/AT将用来指示具有80386或以上CPU的IBMPC及其兼容微机,而PC则用来泛指所有微机,包括IBMPC/XT及其兼容微机。


    微型计算机组成原理

    我们从俯瞰的角度来说明采用80386或以上CPU的PC机系统组成结构。一个传统微型计算机硬件组成结构见图2-2所示。
    在这里插入图片描述

    其中,CPU通过地址线、数据线和控制信号线组成的本地总线(或称为内部总线)与系统其他部分进行数据通信。

    • 地址线用于提供内存或I/O设备的地址,即指明需要读/写数据的具体位置。
    • 数据线用于在CPU和内存或I/O设备之间提供数据传输的通道
    • 控制线则负责指挥执行的具体读/写操作

    对于使用80386CPU的PC机,其内部地址线和数据线都分别有32根,即都是32位的。因此地址寻址空间范围有232字节,从0到4GB。

    图中上部控制器和存储器接口通常都集成在计算机主板上,这些控制器分别都是以一块大规模集成电路芯片为主组成的功能电路。

    例如,中断控制器由 Intel 8259A 或其兼容芯片构成;DMA控制器通常采用Intel 8237A芯片构成;定时计数器的核心则是Intel 8253/8254定时芯片;键盘控制器使用的是Intel 8042芯片来与键盘中的扫描电路进行通信。

    图中下方的控制卡(或者称为适配器)则是通过扩展插槽与主板上系统总线连接。总线插槽是系统地址总线、数据总线和控制线的与扩展设备控制器的标准连接接口。

    这些总线接口标准通常有工业标准结构ISA (Industry Standard Architecture)总线、扩展工业标准结构总线EISA(Extented ISA)、外围组件互连 PCI(Peripheral Component Interconnect)总线、加速图形端口AGP(Accelerated Graphics Port)视频总线等。这些总线接口的主要区别在于数据传输速率和控制灵活性方面。随着计算机硬件的发展,传输速率更高、控制更灵活的总线接口还在不断推出,例如采用串行通信点对点技术的高速PCIE(PCI Express)总线。最初的80386机器上只有ISA总线,因此系统与外部I/O设备最多只能使用16位数据线进行数据传输。

    随着计算机技术的发展,很多原来使用控制卡来完成的功能(例如硬盘控制器功能)都已经集成在计算机主机板上少数几个超大规模集成电路芯片中,几个甚至是一个这样的芯片就确定了主机板的主要特性和功能,并且为了让系统的不同部分都能达到其最高传输速率,总线结构也发生了很大变化。现代PC机的组成结构通常可以使用图2—3来描述。除了CPU以外,现代PC机主板主要使用2个超大规模芯片构成的芯片组或芯片集(Chipsets)组成:北桥(Northbridge)芯片和南桥(Southbridge)芯片。北桥芯片用于与CPU、内存和AGP视频接口,这些接口具有很高的传输速率。北桥芯片还起着存储器控制作用,因此Intel 把该芯片标号为MCH(Memory Controller Hub)芯片。南桥芯片用来管理低、中速的组件,例如, PCI总线、IDE硬盘接口、USB端口等,因此南桥芯片的名称为ICH(I/O Controller Hub)。之所以用“南、 北”桥来分别统称这两个芯片,是由于在Intel公司公布的典型PC机主板上,它们分别位于主版的下端和上端(即地图上的南部和北部)位置,并起着与CPU进行通道桥接的作用。

    在这里插入图片描述
    虽然总线接口发生了很大变化,甚至今后北桥和南桥芯片都将会合二为一,但是对于我们编程人员来说,这些变化仍然与传统的PC 机结构兼容。因此为传统PC机硬件结构编制的程序仍然能运行于现在的PC机上。这从Intel的开发手册上可以证实这个结论。

    所以为了便于入门学习,我们仍然以传统PC 机结构为框架来讨论和学习PC的组成和编程方法,当然这些方法仍然适合于现代PC机结构。下面我们概要说明图2—2中各个主要控制器和控制卡的工作原理,而它们的实际编程方法则推迟到阅读内核相应源代码时再作详细介绍。


    I/O端口寻址和访问控制方式

    I/O端口和寻址

    CPU为了访问I/O接口控制器或控制卡上的数据和状态信息,需要首先指定它们的地址。这种地址就称为I/O端口地址或者简称端口。通常一个I/O控制器包含访问数据的数据端口、输出命令的命令端口和访问控制器执行状态的状态端口。端口地址的设置方法一般有两种:统一编址和独立编址。

    端口统一编址的原理是把I/O控制器中的端口地址归入存储器寻址地址空间范围内。因此这种编址方式也成为存储器映像编址。

    • CPU访问一个端口的操作与访问内存的操作一样,也使用访问内存的指令。

    端口独立编址的方法是把I/O控制器和控制卡的寻址空间单独作为一个独立的地址空间对待,称为I/O地址空间。

    • 每个端口有一个I/O地址与之对应,并且使用专门的I/O指令来访问端口。

    IBM PC 及其兼容微机主要使用独立编址方式,采用了一个独立的I/O地址空间对控制设备中的寄存器进行寻址和访问。使用ISA总线结构的传统PC机其I/O地址空间范围是0x000——0x3FF,有1024个I/O端口地址可供使用。各个控制器和控制卡所默认分配使用的端口地址范围见表2—1所示。关于这些端口的使用和编程方法将在后面具体涉及相关硬件时再详细进行说明。

    另外,IBMPC机也部分地使用了统一编址方式。例如,CGA显示卡上显示内存的地址就直接占用了存储器地址空间0xB800——0xBC00范围。因此若要让一个字符显示在屏幕上,可以直接使用内存操作指令往这个内存区域执行写操作。

    在这里插入图片描述
    对于使用EISA或PCI等总线结构的现代PC机,有64KB的I/O地址空间可供使用。在普通Linux系统下通过查看/proc/ioports 文件可以得到相关控制器或设置使用的I/O地址范围,见如下所示。
    在这里插入图片描述


    接口访问控制

    PC机I/O接口数据传输控制方式一般可采用程序循环查询方式、中断处理方式和DMA传输方式。

    循环查询方式是指CPU 通过在程序中循环查询指定设备控制器中的状态来判断是否可以与设备进行数据交换。这种方式不需要过多硬件支持,使用和编程都比较简单,但是特别耗费CPU宝贵时间。因此在多任务操作系统中除非等待时间极短或必须,否则就不应该使用这种方式。在Linux操作系统中,只有在设备或控制器能够立刻返回信息时才会在很少的几个地方采用这种方式。

    中断处理控制方式需要有中断控制器的支持。在这种控制方式下,只有当I/O设备通过中断向CPU提出处理请求时,CPU才会暂时中断当前执行的程序转而去执行相应的I/O中断处理服务过程。当执行完该中断处理服务过程后,CPU又会继续执行刚才被中断的程序。在I/O控制器或设备发出中断请求时,CPU通过使用中断向量表(或中断描述符表)来寻址相应的中断处理服务过程的入口地址。因此采用中断控制方式时需要首先设置好中断向量表,并编制好相应的中断处理服务过程。Linux操作系统中大多数设备I/O控制都采用中断处理方式。

    直接存储器访问DMA(Direct Memory Access)方式用于I/O设备与系统内存之间进行批量数据传送,整个操作过程需要使用专门的DMA控制器来进行而无需CPU插手。由于在传输过程中无须软件介入,因此操作效率很高。在Linux操作系统中,软盘驱动程序使用中断和DMA方式配合来实现数据的传输工作。


    主存储器,BIOS和CMOS存储器

    主存储器

    1981年IBMPC机刚推出时系统只带有640KB的RAM主存储器(简称内存)。由于所采用的8088/8086CPU只有20根地址线,因此内存寻址范围最高为1024KB(1MB)。在当时DOS操作系统流行年代,640K或1MB 内存容量基本上能满足普通应用程序的运行。随着计算机软件和硬件技术的高速发展,目前的计算机通常都配置有512MB或者更多的物理内存容量,并且都采用Intel 32位CPU,即都是PC/AT计算机。因此CPU的物理内存寻址范围已经高达4GB(通过采用CPU的新特性,系统甚至可以寻址64GB的物理内存容量)。但是为了与原来的PC机在软件上兼容,系统1MB以下物理内存使用分配上仍然保持与原来的PC机基本一致,只是原来系统ROM中的基本输入输出程序BIOS一直处于CPU能寻址的内存最高端位置处,而BIOS原来所在的位置将在计算机开机初始化时被用作BIOS的影子(Shadow)区域,即BIOS代码仍然会被复制到这个区域中。见图2—4所示。

    当计算机上电初始化时,物理内存被设置成从地址0开始的连续区域。除了地址从0xA0000到0xFFFFF(640K到1M共384K)和0XFFFE0000到0XFFFFFFFF(4G处的最后一64K)范围以外的所有内存都可以用作系统内存。

    这两个特定范围被用于I/O设备和BIOS程序。假如我们的计算机中有16MB的物理内存,那么在Linux 0.1x系统中,0-640K将被用作存放内核代码和数据。Linux内核不使用BIOS功能,也不使用BIOS 设置的中断向量表。640K-1M之间的384K仍然保留用作图中指明的用途。其中地址 0xA0000开始的128K用作显示内存缓冲区,随后部分用于其他控制卡的ROM BIOS或其映射区域,而0xF0000到1M范围用于高端系统ROM BIOS的映射区。1M—16M将被内核用于作为可分配的主内存区。另外高速缓冲区和内存虚拟盘也会占用内核代码和数据后面的一部分内存区域,该区域通常会跨越640K——1M的区域。
    在这里插入图片描述


    基本输入/输出程序BIOS

    存放在 ROM中的系统BIOS程序主要用于计算机开机时执行系统各部分的自检,建立起操作系统需要使用的各种配置表,例如中断向量表、硬盘参数表。并且把处理器和系统其余部分初始化到一个已知状态,而且还为DOS等操作系统提供硬件设备接口服务。但是由于BIOS提供的这些服务不具备可重入性(即其中程序不可并发运行),并且从访问效率方面考虑,因此除了在初始化时会利用BIOS提供一些系统参数以外,Linux操作系统在运行时并不使用BIOS中的功能。

    当计算机系统上电开机或者按了机箱上的复位按钮时,CPU会自动把代码段寄存器CS设置为0xF000,其段基地址则被设置为0xFFFF0000,段长度设置为64KB。而IP被设置为0xFFF0,因此此时CPU代码指针指向0xFFFFFFF0处,即4G空间最后一个64K的最后16字节处。由上图可知,这里正是系统ROM BIOS存放的位置。并且BIOS会在这里存放一条跳转指令JMP跳转到BIOS代码中64KB范围内的某一条指令开始执行。

    由于目前PC/AT微机中BIOS容量大多有1MB到2MB,并存储在闪存(Flash Memory) ROM 中,因此为了能够执行或访问BIOS中超过64KB范围并且又远远不在0——1M地址空间中的其他BIOS代码或数据,BIOS程序会首先使用一种称为32位大模式(Big Mode)技术把数据段寄存器的访问范围设置成4G(而非原来的64K),这样就可以在0到4G范围内执行和操作数据。此后,BIOS在执行了一些列硬件检测和初始化操作之后,就会把与原来PC机兼容的64KB BIOS代码和数据复制到内存低端1M末端的64K处,然后跳转到这个地方并且让CPU进入真正的实地址模式工作,见图2—5所示。最后BIOS就会从硬盘或其他块设备把操作系统引导程序加载到内存0x7c00处,并跳转到这个地方继续执行引导程序。

    在这里插入图片描述


    CMOS存储器

    在PC/AT机中,除需要使用内存和ROMBIOS以外,还使用只有很少存储容量的(只有64或128字节)CMOS(Complementary Metal Oxide Semiconductor,互补金属氧化物半导体)存储器来存放计算机的 实时时钟信息和系统硬件配置信息。这部分内存通常和实时时钟芯片(Real Time Chip)做在一块集成块中。CMOS内存的地址空间在基本内存地址空间之外,需要使用I/O指令来访问。


    控制器和控制卡

    中断控制器

    IBM PC/AT 80X86兼容微机使用两片级联的8259A可编程中断控制芯片组成一个中断控制器,用于实现I/O设备的中断控制数据存取方式,并且能为15个设备提供独立的中断控制功能,见图2—6所示。

    在计算机刚开机初始化期间,ROM BIOS会分别对两片8259A芯片进行初始化,并分别把15级中断优先级分配给时钟定时器、键盘、串行口、打印口、软盘控制、协处理器和硬盘等设备或控制器使用。同时在内存开始处0x000—0xFFF区域内建立一个中断向量表。但是由于这些设置违背了Intel公司的要求(后面章节将会详细说明),因此Linux 操作系统在内核初始化期间又重新对8259A进行了设置。有关中断控制器工作原理和编程方法的详细说明请参见后续章节。

    在这里插入图片描述
    当一台PC计算机刚上电开机时,上图中的硬件中断请求号会被ROM BIOS 设置成表2—2中列出的对应中断向量号。Linux操作系统并不直接使用这些PC机默认设置好的中断向量号,当Linux系统执行初始化操作时,它会重新设置中断请求号与中断向量号的对应关系。

    在这里插入图片描述


    DMA 控制器

    如前所述,DMA 控制器的主要功能是通过让外部设备直接与内存传输数据来增强系统的性能。通常它由机器上的Intel 8237芯片或其兼容芯片实现。通过对DMA控制器进行编程,外设与内存之间的数据传输能在不受CPU控制的条件下进行。因此在数据传输期间,CPU可以做其他事情。

    在PC/AT机中,使用了两片8237芯片,因此DMA控制器有8个独立的通道可使用。其中后4个是16位通道。软盘控制器被专门指定使用DMA通道2。在使用一个通道之前必须首先对其设置。这牵涉到对三个端口的操作,分别是页面寄存器端口、(偏移)地址寄存器端口和数据计数寄存器端口。由于DMA寄存器是8位的,而地址和计数值是16位值,因此各自需要发送两次。


    定时/计数器

    Intel 8253/8254是一个可编程定时/计数器(PIT-Programmable Interval Timer)芯片,用于处理计算机 中的精确时间延迟。该芯片提供了3个独立的16位计数器通道。每个通道可工作在不同的工作方式下,并且这些工作方式均可以使用软件来设置。在软件中进行延时的一种方法是执行循环操作语句,但这样做很耗CPU时间。若机器中采用了8253/8254芯片,那么程序员就可以配置8253以满足自己的要求并且使用其中一个计数器通道达到所期望的延时。在延时到后,8253/8254将会向CPU发送一个中断信号。

    对于PC/AT及其兼容微机系统采用的是8254芯片。3个定时/计数器通道被分别用于日时钟计时中断信号、动态内存DRAM刷新定时电路和主机扬声器音调合成。Linux 0.11操作系统只对通道0进行了重新设置,使得该计数器工作在方式3下,并且每间隔10毫秒发出一个信号以产生中断请求信号(IRQO)。这个间隔定时产生的中断请求就是Linux 0.11内核工作的脉搏,它用于定时切换当前执行的任务和统计每个任务使用的系统资源量(时间)。


    键盘控制器

    我们现在使用的键盘是IBM公司于1984年PC/AT微机的兼容键盘,通常称为AT—PS/2兼容键盘并具有101到104个按键。键盘上有一个称为键盘编码器的处理器(Intel 8048或兼容芯片)专门用来扫描收集所有按键按下和松开的状态信息(即扫描码),并发送到主机主板上键盘控制器中。当一个键被按下时,键盘发送的扫描码称为接通扫描码(Make code),或简称为接通码;当一个被按下的键放开时发送的扫描码被称为断开扫描码(Break code),或简称为断开码。

    主机键盘控制器专门用来对接收到的键盘扫描码进行解码,并把解码后的数据发送到操作系统的键盘数据队列中。因为每个按键的接通和断开码都是不同的,所以键盘控制器根据扫描码就可以确定用户在操作哪个键。整个键盘上所有按键的接通和断开码就组成了键盘的一个扫描码集(Scan Code Set)。根据计算机的发展,目前已有三套扫描码集可供使用,它们分别是:

    • 第一套扫描码集——原始XT键盘扫描码集。目前的键盘已经很少发送这类扫描码;
    • 第二套扫描码集——现代键盘默认使用的扫描码集,通常称为AT键盘扫描码集;
    • 第三套扫描码集——PS/2键盘扫描码集。原IBM推出PS/2微机时使用的扫描码集,已很少使用。

    AT键盘默认发送的是第二套扫描码集。虽然如此,主机键盘控制器为了与PC/XT机的软件兼容起见,仍然会把所有接收到的第二套键盘扫描码转换成第一套扫描码,见图2—7所示。因此,我们在为键盘控制器进行编程时通常只需要了解第一套扫描码集即可。这也是后面涉及键盘编程内容时只给出XT键盘扫描码集的原因。

    在这里插入图片描述

    键盘控制器通常采用Intel 8042单片微处理器芯片或其兼容电路。现在的PC机都已经将键盘控制器集成在主板芯片组中,但是功能仍然与使用8042芯片的控制器相兼容。键盘控制器接收键盘发送来的11位串行格式数据。其中第1位是起始位,第2—9位是8位键盘扫描码,第10位是奇校验校验位,第11位是停止位。参见下节对串行控制卡的说明。键盘控制器在收到11位的串行数据后就将键盘扫描码转换成PC/XT标准键盘兼容的系统扫描码,然后通过中断控制器IRQ1引脚向CPU发送中断请求。当CPU响应该中断请求后,就会调用键盘中断处理程序来读取控制器中的XT键盘扫描码。

    当一个键被按下时,我们可以从键盘控制器端口接收到一个XT键盘接通码。这个扫描码仅表示键盘上某个位置处的键被按下,但还没有对应到某个字符代码上。接通码通常都是一个字节宽度。例如,按下键“A”的接通码是30 (Ox1E)。当一个按下的键被松开时,从键盘控制器端口收到的就是一个断开码。对于XT 键盘(即键盘控制器编程端口收到的扫描码),断开码是其接通码加上0x80,即最高有效位(位7)置位时的接通码。例如,上述“A”键的断开码就是0x80+ 0x1E = 0x9E。

    但是对于那些PC/XT标准83键键盘以后新添加的(“扩展的”)AT 键盘上的按键(例如右边的Ctrl键和右边的Alt键等),则其接通和断开扫描码通常有2到4个字节,并且第1个字节一定是0xE0。例如,按下左边的非扩展Ctrl键时会产生1字节接通码Ox1D,而按下右边的Ctrl键时就会产生扩展的2字节接通码0xE0、Ox1D。对应的断开码是OxE0、Ox9D。表2—3中是几个接通和断开扫描码的例子。另外,附录中还给出了完整的第一套扫描码集,

    在这里插入图片描述
    另外,键盘控制器8042的输出端口P2用于其他目的。其P20引脚用于实现CPU的复位操作,P21引脚用于控制A20信号线的开启与否。当该输出端口位1(P21)为1时就开启(选通)了A20信号线,为0则禁止A20信号线。现今的主板上已经不再包括独立的8042芯片了,但是主板上其他集成电路会为兼容目的而模拟8042芯片的功能。因此现在键盘的编程仍然采用8042的编程方法。


    串行控制卡

    1.异步串行通信原理

    两台计算机/设备进行数据交换,即通信,必须像人们对话一样使用同一种语言。在计算机通信术语中,我们把计算机/设备与计算机/设备之间的“语言”称为通信协议。通信协议规定了传送一个有效数据长度单位的格式。通常我们使用术语“帧”来形容这种格式。为了能让通信双方确定收/发的顺序和进行一些错误检测操作,除了必要的数据以外,在传输的一帧信息中还包含起同步和错误检测作用的其它信息。

    例如: 在开始传输数据信息之前先发送起始/同步或通信控制信息,并且在发送完需要的数据信息之后再传输一些校验信息等,见图2—8所示。
    在这里插入图片描述

    串行通信是指在线路上以比特位数据流一次一个比特进行传输的通信方式。

    串行通信可分为异步和同步串行通信两种类型。它们之间的主要区别在于传输时同步的通信单位或帧的长度不同。异步串行通信以一个字符作为一个通信单位或一帧进行传输,而同步串行通信则以多个字符或字节组成的序列作为一帧数据进行传输。

    若再以人们之间的对话作比喻,那么异步通信如同对话双方讲话速度很慢,说话时一个字(word)一个字地“蹦”出来,在说出每个字后可以停顿任意长时间。而同步通信则如同通信双方以连贯的一句话作为对话单位。可以看出,实际上如果我们把传输单位缩小到一个比特位时(对话时用字母!),那么以一个字符进行传输的异步串行通信也可以看作是一种同步传输通信方式。因此异步和同步通信的区分主要是一种习惯或惯例上的划分。


    2.异步串行传输格式

    异步串行通信传输的帧格式见图2—9所示。传输一个字符由起始位、数据位、奇偶校验位和停止位构成。其中起始位起同步作用,值恒为0。数据位是传输的实际数据,即一个字符的代码。其长度可以是5-8个比特。奇偶校验位可有可无,由程序设定。停止位恒为1,可由程序设定为1、1.5或2个比特位。在通信开始发送信息之前,双方必须设置成相同的格式。如具有相同数量的数据比特位和停止位。在异步通信规范中,把传送1称为传号(MARK),传送0称为空号(SPACE)。因此在下面描述中我们就使用这两个术语。

    在这里插入图片描述
    当无数据传输时,发送方处于传号(MARK)状态,持续发送1。若需要发送数据,则发送方需要首先发送一个比特位间隔时间的空号起始位。接收方收到空号后,就开始与发送方同步,然后接收随后的数据。若程序中设置了奇偶校验位,那么在数据传输完之后还需要接收奇偶校验位。最后是停止位。在一个字符帧发送完后可以立刻发送下一个字符帧,也可以暂时发送传号,等一会再发送字符帧。

    在接收一字符帧时,接收方可能会检测到三种错误之一:①奇偶校验错误。此时程序应该要求对方重新发送该字符;②过速错误。由于程序取字符速度慢于接收速度,就会发生这种错误。此时应该修改程序加快取字符频率;③帧格式错误。在要求接收的格式信息不正确时会发生这种错误。例如在应该收到停止位时却收到了空号。通常造成这种错误的情况除了线路干扰以外,很可能是通信双方的帧格式设置的不同。


    3.串行控制器

    为实现串行通信,PC机上通常都带有2个符合RS—232C标准的串行接口,并使用通用异步接收/发送器控制芯片 UART(Universal Asyncronous Receiver/Transmitter)组成的串行控制器来处理串行数据的收发 工作。PC机上的串行接口通常使用25芯或9芯的DB—25或DB—9连接器,主要用来连接MODEM设备进行工作,因此RS—232C标准规定了很多MODEM专用接口引线。

    以前的PC机都使用国家半导体公司的NS8250或NS16450 UART芯片,现在的PC机则使用了16650A及其兼容芯片,但都与NS8250/16450芯片兼容。NS8250/16450与16650A芯片的主要区别在于16650A芯片还另外支持FIFO传输方式。在这种方式下,UART可以在接收或发送了最多16个字符后才引发一次中断,从而可以减轻系统和CPU的负担。当PC机上电启动时,系统RESET信号通过NS8250的MR引脚使得UART 内部寄存器和控制逻辑复位。此后若要使用UART 就需要对其进行初始化编程操作,以设置UART的工作波特率、数据位数以及工作方式等。


    显示控制

    对于IBMPC/AT及其兼容计算机而言,可以使用彩色和单色显示卡。IBM最早推出的PC机视频系统标准有单色MDA标准和彩色CGA标准以及EGA和VGA标准。以后推出的所有高级显示卡(包括现在的AGP显示卡)虽然都具有极高的图形处理速度和智能加速处理功能,但它们还是都支持这几种标准。Linux 0.1x操作系统仅使用了这几种标准都支持的文本显示方式。


    1.MDA 显示标准

    单色显示适配器 MDA(Monochrome Display Adapter)仅支持黑白两色显示。并且只支持独有的文本字符显示方式(BIOS 显示方式7)。

    其屏幕显示规格是80列X25行(列号x=0…79 ;行号 y=0…24), 共可显示2000个字符。每个字符还带有1个属性字节,因此显示一屏(一帧)内容需要占4KB字节。其中偶地址字节存放字符代码,奇地址字节存放显示属性。MDA卡配置有8KB显示内存。在PC机内存寻址范围中占用从0xb0000开始的8KB空间(0xb0000—0xb2000)。如果显示屏行数是vilines=25 列数是 video_num_colums=80,那么位于屏幕列行值x、y处的字符和属性在内存中的位置是:

    在这里插入图片描述
    在MDA单色文本显示方式中,每个字符的属性字节格式见表2—4所示。其中,D7置1会使字符闪烁;D3置1使字符高亮度显示。它与图2—10中的彩色文本字符的属性字节基本一致,但只有两种颜色:白色(0x111)和黑色(0x000)。它们的组合效果见表所示。

    在这里插入图片描述


    2.CGA 显示标准

    彩色图形适配器CGA(Color Graphics Adapter)支持7种彩色和图形显示方式(BIOS显示方式0–6)。 在80列X25列的文本字符显示方式下,有单色和16色彩色两种显示方式(BIOS 显示方式2—3)。CGA卡标配有16KB显示内存(占用内存地址范围Oxb8000—— Oxbc000),因此其中共可存放4帧显示信息。同样,在每一帧4KB显示内存中,偶地址字节存放字符代码,奇地址字节存放字符显示属性。但在console.c程序中只使用了其中8KB显示内存(Oxb8000 —— Oxba000)。在CGA彩色文本显示方式中,每个显示字符的属性字节格式定义见图2—10所示。

    在这里插入图片描述
    与单色显示一样,图中D7置1用于让显示字符闪烁;D3置1让字符高亮度显示;比特位D6、D5、D4和D2、D1、D0可以分别组合出8种颜色。前景色与高亮度比特位组合可以显示另外8种字符颜色。这些组合的颜色见表2—5所示。

    在这里插入图片描述


    3. EGA/VGA 显示标准

    增强型图形适配器EGA(Enhanced Grpahics Adapter)和视频图形阵列VGA(Video Graphics Adapter) 除兼容或支持MDA和CGA的显示方式以外,还支持其他在图形显示方面的增强显示方式。在与MDA和CGA兼容的显示方式下,占用的内存地址起始位置和范围都分别相同。但EGA/VGA 都标配有起码 32KB的显示内存。在图形方式下占用从0xa0000开始的物理内存地址空间。


    软盘和硬盘控制器

    PC机的软盘控制子系统由软盘片和软盘驱动器组成。由于软盘可以存储程序和数据并且携带方便,因此长期以来软盘驱动器是PC机上的标准配置设备之一。

    硬盘也是由盘片和驱动器组成,但是通常硬盘的金属盘片固定在驱动器中,不可拆卸。由于硬盘具有很大的存储容量,并且读写速度很快,因此它是PC机中最大容量的外部存储设备,通常也被称为外存。

    软盘和硬盘都是利用磁性介质保存信息,具有类似的存储工作方式。因此这里我们以硬盘为例来简要说明它们的工作原理。

    在盘片上存储数据的基本方式是利用盘片表面上的一层磁性介质在磁化后的剩磁状态。软盘通常使用聚酯薄膜作基片,而硬盘片则通常使用金属铝合金作基片。一张软盘中含有一张聚酯薄膜圆盘片,使用上下两个磁头在盘片两面读写数据,盘片旋转速率大约在300转/分钟。

    硬盘中通常起码包括2张或者更多张金属盘片,因此具有多个读写磁头。例如,对于包含2个盘片的硬盘中就具有4个物理磁头,含有4个盘
    片的硬盘中有8个读写磁头。

    见图2-11所示。硬盘旋转速率很快通常在4500转/分钟到10000转/分钟,因此硬盘数据的传输速度通常可达几十兆比特/秒。

    在这里插入图片描述
    位于磁盘表面的磁头上有分别有一个读线圈和写线圈。在读数据操作过程中,磁头首先移动到旋转着的磁盘某个位置上。

    由于磁盘在旋转,磁介质相对磁头作匀速运动,因此磁头实际上在切割磁介质上的磁力线。从而在读线圈中因感应而产生电流。根据磁盘表面剩磁状态方向的不同,在线圈中感应产生的电流方向也不同,因此磁盘上记录着的0和1数据就被读出,从而可从磁盘上顺序读出比特数据流。

    由于磁头读取的每个磁道上都有存放信息的特定格式,因此通过识别所读比特数据流中的格式,磁盘电路就可以区分并读取磁道上各扇区中的数据,见图2-12所示。其中,GAP是间隔字段,用于起隔离作用。通常GAP是12字节的0。每个扇区地址场的地址字段存放着相关扇区的柱面号、磁头号(面号)和扇区号,因此通过读取地址场中的地址信息就可以唯一地确定一个扇区。

    在这里插入图片描述
    为了读写磁盘(软盘和硬盘)上的数据,就必须使用磁盘控制器。

    磁盘控制器是CPU与驱动器之间的逻辑接口电路,它从CPU接收请求命令,向驱动器发送寻道、读/写和控制信号,并且控制和转换数据
    流形式。

    控制器与驱动器之间传输的数据包括图2-12中的扇区地址信息以及定时和时钟信息。控制器必须从实际读/写数据中分离出这些地址信息和一些编码、解码等控制信息。

    另外,与驱动器之间的数据传输是串行比特数据流,因此控制器需要在并行字节数据和串行比特流数据之间进行转换。

    PC/AT机中软盘驱动控制器FDC(Floppy Disk Controller).采用的是NECμPD765或其兼容芯片。它主要用于接收CPU发出的命令,并根据命令要求向驱动器输出各种硬件控制信号,见图2-13所示。在执行读/写操作时,它需要完成数据的转换(串-并)、编码和校验操作,并且时刻监视驱动器的运行状态。

    在这里插入图片描述
    对磁盘控制器的编程过程就是通过I/O端口设置控制器中的相关寄存器内容,并通过寄存器获取操作的结果信息。至于扇区数据的传输,则软盘控制器与PC/AT硬盘控制器不同。

    软盘控制器电路采用DMA信号,因此需要使用DMA控制器实施数据传输。而AT硬盘控制器采用高速数据块进行传输,不需要DMA
    控制器的介入。

    由于软盘片比较容易遭到损坏(发霉或划伤),因此目前计算机中己经逐渐开始不配置软盘驱动器,起而代之的是使用容量较大并且更容易携带的U盘存储器。


    小结

    硬件是操作系统运行的基础平台。了解操作系统运行的硬件环境是深入理解运行其上操作系统的必要条件。本章根据传统微机的硬件组成结构,简单介绍了微机中各个主要部分。下一章我们从软件角度出发介绍编制Linux内核所使用的两种汇编语言语法和相关编译器,同时也介绍了编制内核使用的GNU gcc语法扩展部分的内容。

  • 相关阅读:
    python实现处理swagger接口文档,转换为yaml格式的自动化用例
    库存三层模型概述
    项目:【Boost搜索引擎】
    用HTML、CSS技术设计的个人网页与实现制作(web前端期末大作业)
    【教学类-15-01】20221115《学号(姓名)描字帖-A4横版-竖切》(中班)
    C#,图颜色问题(MCP,M-coloring problem)的回溯(Backtracking)算法与源代码
    如何优雅的备份MySQL数据?看这篇文章就够了
    研究一下 JSON.parse(JSON.stringify(obj))
    如何基于RDD方式完成DataFrame的代码构建?
    nginx反向代理tcp网络访问
  • 原文地址:https://blog.csdn.net/m0_53157173/article/details/126316974