|  | 
 
 
| 
操作系统的硬件支持   7 W! v/ W: I9 D 任何系统软件都是硬件功能的延伸,并且都是建立在硬件基础之上的。操作系统是对裸机的第一次扩充和延伸,它直接与硬件打交道,更需要硬件的支持。这种硬件支持包括CPU接口、中断接口和系统时钟。 * \5 t) {% `) g2 x: @" a% w* Z
 * a4 Z- \3 O6 I- G
 1. CPU接口
 + v7 f, w: {* S, r. a3 C4 x- D3 t. s3 t5 w. t: E  ~
 CPU接口是向操作系统提供控制硬件的界面。为了使用户程序正常工作,又要保护操作系统不被破坏,就要对硬件实施有效的控制,操作系统的CPU接口中包含特权指令、对处理机执行状态的控制、对某些专用寄存器的控制等控制硬件的功能。
 6 a6 X' ?, K% W# \
 4 w, h, U" Z9 i0 T. U6 H(1)特权指令 , G# ]9 v1 N$ c, y
 
 - g& p' U# e! R! U  j: S8 j) _处理机的指令系统被分成两部分:一部分是特权指令,只允许操作系统使用,如停机指令、启动外设指令、清内存指令、设置时钟、修改程序状态字等;另一部分是非特权指令,允许用户使用,如取数指令、访管指令等。用户不能使用特权指令,这样可以避免系统陷入混乱,而使用非特权指令不会影响其他用户及系统本身。
 / p! k' ?& z9 h/ G1 c* b6 @& S- G9 b' l- p3 r4 y- e$ n, S' S. {
 (2)处理机状态和程序状态字
 B0 Z3 C: s4 h; `" ?3 o# @# e9 T( H, q; U" B/ N
 CPU交替执行操作系统程序和用户程序,在执行不同程序时,根据运行的程序对机器指令的使用权限将处理机设置为不同的状态。大多数计算机都为CPU设置了至少两种状态:管理态(又称核心态、管态、特权态等)和用户态(又称目标态、目态、常态、普通态、问题态等)。程序在用户态下运行时,只能执行非特权指令、访问有限的存储空间和指定的寄存器;而在管理态下运行时,程序则不受限制,可执行操作系统的全集,可访问全部存储器和寄存器。通常,操作系统在管理态下运行,用户程序则在用户态下运行。 - V% X1 n* r6 N* R, J
 7 C* ~+ Q( m$ n: Y
 用一种称为程序状态字(PSW)的专用寄存器来标识处理机的不同状态,例如CPU的执行状态是管态还是目态、指令执行后的结果特征(条件码)、是否允许中断(中断屏蔽码)、发生了什么中断(中断字)以及中断优先级等。PSW寄存器只有CPU处在管态下才可以访问。操作系统可以通过对PSW的修改来控制系统的运行。 : z7 K% r: e( X& N, x4 G5 ^
 $ k: k5 U  d& L! G: h$ ^! g4 R
 2. 中断接口 ; g* X& Q1 x# n( t+ ^! P, T9 C
 
 " N3 u) e& c: _" Y  nCPU可以暂时终止执行现行程序而转去执行其他程序。当条件具备时,被打断的程序根据操作系统的安排又恢复执行,这样一个过程称为中断。中断接口是CPU与操作系统通信的手段,它能迫使CPU去执行各中断处理程序。中断处理程序对操作系统完成其管理任务十分重要,例如,CPU从目态转换为管态的惟一途径就是中断。只要设计好各个中断处理程序,就能使系统具有完善的功能。中断接口是由中断机构完成的,它的作用主要有两条:一是用于多道程序设计,使CPU能并行执行多道程序,从而充分发挥CPU的效率;二是用于外部设备,使CPU能与外设并行工作,解决快速CPU与慢速外设之间的矛盾。 0 |: x1 ~% Y; R, G) b% K( A# a1 b
 
 2 G) D0 ^% V9 p3 l7 M(1)中断流程及其类型 0 z+ l6 X' e% l% k1 m- t- A* s
 
 % I) u! s! G( _4 C$ {% [当中断发生时,CPU暂停正在执行的程序,保留现场后自动转去执行相应的中断处理程序,然后再返回断点继续执行被中断的程序。中断的流程如图1.4所示。 2 I5 y7 C% v8 [( V0 P
 # _8 R: B  X+ X8 g  E$ J( P& t
 引起中断的原因,或能发出中断申请的来源称为中断源。中断源通常有以下几种:输入输出设备、数据通道、实时时钟、故障源、程序中设置的中断源。
 , w# A  F3 c3 ?7 H: v5 R6 e" l& y
 * ]4 B) m, k. n' _/ ^7 h0 D' g7 P一般将中断分为两大类:强迫性中断和自愿性中断。不同的中断源引发不同的中断。强迫性中断是正在运行的程序所不期望的,发生的时间和位置也是不确定的。这类中断包括: , z$ V0 s. Y! K% z2 J
 
 u6 I! \( s& p8 l! g●     I/O中断 由输入输出完成或出错引起 3 n. @+ M& ^; o. S
 * m$ O$ A/ `% B  P1 `9 U
 ●     时钟中断 实时时钟到时引起
 ! [) b8 w! c: h: p+ M
 % e/ a3 x3 `' \6 x4 T, O4 s●     硬件故障中断 由机器硬件故障(如掉电、内存单元奇偶校验错)引起 7 H2 r8 c& C, x/ j
 7 V, \+ o% y4 t9 a1 s
 ●     数据通道中断 由磁盘磁带等数据通道传输完成或出错引起 * y) O# F; y: j5 H$ M; K
 + ]# x8 U8 z8 I5 u, Q4 l
 ●     程序中断 也叫软件中断,由程序运行中的错误(如数据溢出、地址越界、缺页、缺段等)引起
 . L' ]+ D' D0 x9 |
 2 n( G8 p0 B' }: T1 s0 }自愿性中断是为了程序调试的目的以及程序中需要使用访管指令或系统调用而在程序中有意安排的中断。这类中断的发生具有必然性,发生的位置也是确定的。
 " N9 J( ~7 f# g+ F5 H! X# y
 6 S; s- {# `+ o. O/ A- S9 @1 ?+ L(2)中断向量、中断优先级和中断屏蔽
 2 N# q2 X7 s: ~3 G: E3 v6 Q0 `+ c6 H0 L/ C2 c; G8 K
 处理中断是由硬件和软件共同完成的,其中,硬件部分称为中断机构或中断装置,软件部分称为中断处理程序。系统为每类中断设置一个中断处理程序,它们的入口地址及运行环境的程序状态字保存在内存的固定存储单元中,称为中断向量。当中断发生时,中断机构根据中断类别将对应的中断向量送到程序状态字PSW和程序计数器PC中,使中断处理程序得以执行。在计算机执行的任一时刻,可能有几个中断同时发生,为使系统能及时响应并处理发生的所有中断,在设计中断机构时,就必须根据各类中断的轻重缓急安排好中断响应的次序,给不同的中断赋予不同的优先级,以便中断机构能首先响应优先级高的中断。 ; h+ n: C$ d" y7 g* ^# P
 / x8 Y: e+ D$ x* Y* d% {4 T
 中断屏蔽是指中断源发出中断请求之后,CPU不予响应的状态。通过中断屏蔽可以改变本来由硬件规定好了的中断优先级。 9 E) U4 C  [6 D' l# @
 - `$ c# B3 \+ E$ G# j0 s4 ]
 (3)中断响应 2 I7 o, r9 ?( _
 
 & t  n: m! S: Y! s' z/ f中断响应的目的是发现和接收中断。CPU一旦响应中断就进行以下工作:
 7 [9 |4 O' ^; D' _% b$ r5 a0 z4 B" y
 ●     保护断点保留现场 CPU封锁程序计数器PC即使之加1不再往下执行,同时把PC的内容及断点处的现场信息(如各寄存器的内容、PSW等)压入堆栈保护起来,称为保护断点。
 , X" F# q6 H- y( y0 K
 - A# i# A- M! ]●     分析中断源,确定中断原因和优先级。 - b; ]5 n& ~; w2 h9 l
 4 b, j, _! ~! z$ j$ R  m* i5 y
 ●     中断服务 给出中断服务程序的入口地址,转去执行相应的中断服务程序。
 \, q& X" X! w2 |
 . M1 b4 I, H5 w( J●     中断返回 恢复被中断的现场,从断点处继续执行被中断的程序。
 8 z( |: S- _7 `/ c1 n# t- h+ C  M- a% x
 % F# J7 C0 \! L; O' q1 @3. 时钟 , q3 o9 M* W+ n
 
 $ S5 K: u  e7 t: D  t1 w+ S: A时钟是操作系统运行必不可少的硬件设施,时钟是一个寄存器,按时钟电路产生的脉冲数,自动进行加1或减1的操作,从而实现计时和定时功能。时钟决定了计算机工作的节奏。
 : I+ e4 O  l3 c( w. Y' U1 F9 _9 Z" |- J8 X- R; T; J# U. \, o
 硬件时钟通常分为绝对时钟和相对时钟两类。
 9 n6 h# A: J) h; z. m. B$ H/ O, O4 x- E" A+ O3 r( M$ b( _
 绝对时钟用来记录当时的时间(包括年、月、日、时、分、秒)。操作系统可以用绝对时钟来记录作业进入系统、开始处理及退出系统的时间,记录各种资源的使用时间,并为用户提供当前时间等。 - N% K5 `1 y! g7 a$ a
 
 $ H. B2 p" E$ n, \8 r8 b% F相对时钟也叫间隔时钟,用来每隔一定的时间产生一次中断,使操作系统获得控制权,以便运行系统管理和维护程序。例如,批处理系统用相对时钟发现程序中的死循环,以免浪费机时;分时系统用相对时钟使分时时间片轮转;实时系统更需要按照时间间隔输出正确的时间信息,使控制设备能准时施加控制。
 ( x! G& v. C8 y! L" O. ~/ K/ K) }
 * h9 b! m9 j/ I3 v: N  C重点
 , _1 [+ C2 Y, [' J: a9 t7 a' u; c  z
 ' `- M& z& y+ k" y8 F( t× 特权指令是操作系统的专用指令,不允许用户使用,如启动设备指令、设置时钟指令、清内存指令等;CPU执行不同的指令时,就会处于不同的状态,这些状态由程序状态字标识,状态字包括执行状态字、中断字、中断屏蔽码、中断优先级等。
 . U. U8 w% f2 ]- E/ e7 |
 2 R. a' S2 t: `$ e1 C× 中断是CPU对系统发生的某个事件做出的反应,它是操作系统实现并发运行的基础。中断由中断源提出,由中断机构执行。有五种中断源,它们是输入输出设备、数据通道、故障、时钟和程序本身的原因。中断可分为强迫性中断和自愿性中断,不同的中断源引发不同类型的中断。
 0 E; ]; K" ^( o" N9 N* H. d
 , H" _+ w: c! z9 `- z× CPU响应中断的过程大体可分为四个阶段,即保护断点保留现场;分析中断源,确定中断原因和优先级;中断服务;中断返回。 ) K+ m: [% \! x& U9 J
 
 1 v: C' ~) l/ o; q  U5 y6 P× 时钟是硬件系统提供的计时和定时装置。操作系统利用时钟来运行管理和维护程序。时钟分为绝对时钟和相对时钟。绝对时钟能提供当前的时间,相对时钟提供一定的时间间隔。绝对时钟比相对时钟准确。
 | 
 |