第六章湯小丹,計算機操作系統(tǒng),官方,第四版,計算機,操作系統(tǒng)PPT課件_第1頁
第六章湯小丹,計算機操作系統(tǒng),官方,第四版,計算機,操作系統(tǒng)PPT課件_第2頁
第六章湯小丹,計算機操作系統(tǒng),官方,第四版,計算機,操作系統(tǒng)PPT課件_第3頁
第六章湯小丹,計算機操作系統(tǒng),官方,第四版,計算機,操作系統(tǒng)PPT課件_第4頁
第六章湯小丹,計算機操作系統(tǒng),官方,第四版,計算機,操作系統(tǒng)PPT課件_第5頁
已閱讀5頁,還剩126頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、6.1 I/O6.1 I/O系統(tǒng)的功能、模型和接口系統(tǒng)的功能、模型和接口I/O系統(tǒng)管理的主要對象是I/O設(shè)備和相應(yīng)的設(shè)備控制器。其最主要的任務(wù)是,完成用戶提出的I/O請求,提高I/O速率,以及提高設(shè)備的利用率,并能為更高層的進程方便地使用這些設(shè)備提供手段。第1頁/共131頁系統(tǒng)的基本功能系統(tǒng)的基本功能1. 1. 隱藏物理設(shè)備的細節(jié)隱藏物理設(shè)備的細節(jié)I/O設(shè)備的類型非常多,且彼此間在多方面都有差異,諸如它們接收和產(chǎn)生數(shù)據(jù)的速度,傳輸方向、粒度、數(shù)據(jù)的表示形式及可靠性等方面。 第2頁/共131頁2. 2. 與設(shè)備的無關(guān)性與設(shè)備的無關(guān)性隱藏物理設(shè)備的細節(jié),在早期的OS中就已實現(xiàn),它可方便用戶對設(shè)備的

2、使用。與設(shè)備的無關(guān)性是在較晚時才實現(xiàn)的,這是在隱藏物理設(shè)備細節(jié)的基礎(chǔ)上實現(xiàn)的。 第3頁/共131頁3. 3. 提高處理機和提高處理機和I/OI/O設(shè)備的利用率設(shè)備的利用率在一般的系統(tǒng)中,許多I/O設(shè)備間是相互獨立的,能夠并行操作,在處理機與設(shè)備之間也能并行操作。因此,I/O系統(tǒng)的第三個功能是要盡可能地讓處理機和I/O設(shè)備并行操作,以提高它們的利用率。為此,一方面要求處理機能快速響應(yīng)用戶的I/O請求,使I/O設(shè)備盡快地運行起來;另一方面也應(yīng)盡量減少在每個I/O設(shè)備運行時處理機的干預(yù)時間。 第4頁/共131頁4. 4. 對對I/OI/O設(shè)備進行控制設(shè)備進行控制對I/O設(shè)備進行控制是驅(qū)動程序的功能。

3、目前對I/O設(shè)備有四種控制方式: 采用輪詢的可編程I/O方式; 采用中斷的可編程I/O方式; 直接存儲器訪問方式; I/O通道方式。 第5頁/共131頁5. 5. 確保對設(shè)備的正確共享確保對設(shè)備的正確共享從設(shè)備的共享屬性上,可將系統(tǒng)中的設(shè)備分為如下兩類:(1) 獨占設(shè)備,進程應(yīng)互斥地訪問這類設(shè)備,即系統(tǒng)一旦把這類設(shè)備分配給了某進程后,便由該進程獨占,直至用完釋放。典型的獨占設(shè)備有打印機、磁帶機等。系統(tǒng)在對獨占設(shè)備進行分配時,還應(yīng)考慮到分配的安全性。(2) 共享設(shè)備,是指在一段時間內(nèi)允許多個進程同時訪問的設(shè)備。典型的共享設(shè)備是磁盤,當有多個進程需對磁盤執(zhí)行讀、寫操作時,可以交叉進行,不會影響到讀

4、、寫的正確性。第6頁/共131頁6. 6. 錯誤處理錯誤處理大多數(shù)的設(shè)備都包括了較多的機械和電氣部分,運行時容易出現(xiàn)錯誤和故障。從處理的角度,可將錯誤分為臨時性錯誤和持久性錯誤。對于臨時性錯誤,可通過重試操作來糾正,只有在發(fā)生了持久性錯誤時,才需要向上層報告。 第7頁/共131頁系統(tǒng)的層次結(jié)構(gòu)和模型系統(tǒng)的層次結(jié)構(gòu)和模型 1.1. I/O I/O軟件的層次結(jié)構(gòu)軟件的層次結(jié)構(gòu)通常把I/O 軟件組織成四個層次,如圖6-1所示。第8頁/共131頁 圖6-1 I/O系統(tǒng)的層次結(jié)構(gòu)第9頁/共131頁2. I/O2. I/O系統(tǒng)中各種模塊之間的層次視圖系統(tǒng)中各種模塊之間的層次視圖為了能更清晰地描述I/O系統(tǒng)

5、中主要模塊之間的關(guān)系,我們進一步介紹I/O系統(tǒng)中各種I/O模塊之間的層次視圖。見圖6-2所示。1) I/O系統(tǒng)的上、下接口(1) I/O系統(tǒng)接口。(2) 軟件/硬件(RW/HW)接口。第10頁/共131頁 圖6-2 I/O系統(tǒng)中各種模塊之間的層次視圖第11頁/共131頁2) I/O系統(tǒng)的分層與前面所述的I/O軟件組織的層次結(jié)構(gòu)相對應(yīng),I/O系統(tǒng)本身也可分為如下三個層次:(1) 中斷處理程序。(2) 設(shè)備驅(qū)動程序。(3) 設(shè)備獨立性軟件。 第12頁/共131頁系統(tǒng)接口系統(tǒng)接口 在I/O系統(tǒng)與高層之間的接口中,根據(jù)設(shè)備類型的不同,又進一步分為若干個接口。在圖6-2中示出了塊設(shè)備接口、流設(shè)備接口和網(wǎng)

6、絡(luò)接口。1. 1. 塊設(shè)備接口塊設(shè)備接口(1) 塊設(shè)備。 (2) 隱藏了磁盤的二維結(jié)構(gòu)。(3) 將抽象命令映射為低層操作。 第13頁/共131頁2. 2. 流設(shè)備接口流設(shè)備接口流設(shè)備接口是流設(shè)備管理程序與高層之間的接口。該接口又稱為字符設(shè)備接口,它反映了大部分字符設(shè)備的本質(zhì)特征,用于控制字符設(shè)備的輸入或輸出。(1) 字符設(shè)備。(2) get和put操作。(3) in-control指令。 第14頁/共131頁3. 3. 網(wǎng)絡(luò)通信接口網(wǎng)絡(luò)通信接口在現(xiàn)代OS中,都提供了面向網(wǎng)絡(luò)的功能。但首先還需要通過某種方式把計算機連接到網(wǎng)絡(luò)上。同時操作系統(tǒng)也必須提供相應(yīng)的網(wǎng)絡(luò)軟件和網(wǎng)絡(luò)通信接口,使計算機能通過網(wǎng)

7、絡(luò)與網(wǎng)絡(luò)上的其它計算機進行通信或上網(wǎng)瀏覽。 第15頁/共131頁6.2 I/O6.2 I/O設(shè)備和設(shè)備控制器設(shè)備和設(shè)備控制器I/O設(shè)備一般是由執(zhí)行I/O操作的機械部分和執(zhí)行控制I/O的電子部件組成。通常將這兩部分分開,執(zhí)行I/O操作的機械部分就是一般的I/O設(shè)備,而執(zhí)行控制I/O的電子部件則稱為設(shè)備控制器或適配器(adapter)。在微型機和小型機中的控制器常做成印刷電路卡形式,因而也常稱為控制卡、接口卡或網(wǎng)卡,可將它插入計算機的擴展槽中。在有的大、中型計算機系統(tǒng)中,還配置了I/O通道或I/O處理機。第16頁/共131頁設(shè)備設(shè)備 1. 1. I/OI/O設(shè)備的類型設(shè)備的類型1) 按使用特性分類

8、2) 按傳輸速率分類第17頁/共131頁2. 2. 設(shè)備與控制器之間的接口設(shè)備與控制器之間的接口通常,設(shè)備并不是直接與CPU進行通信,而是與設(shè)備控制器通信,因此,在I/O設(shè)備中應(yīng)含有與設(shè)備控制器間的接口,在該接口中有三種類型的信號(見圖6-3所示),各對應(yīng)一條信號線。(1) 數(shù)據(jù)信號線。(2) 控制信號線。(3) 狀態(tài)信號線。第18頁/共131頁 圖6-3設(shè)備與控制器間的接口第19頁/共131頁設(shè)備控制器設(shè)備控制器1. 1. 設(shè)備控制器的基本功能設(shè)備控制器的基本功能(1) 接收和識別命令。(2) 數(shù)據(jù)交換。(3) 標識和報告設(shè)備的狀態(tài)。(4) 地址識別。(5) 數(shù)據(jù)緩沖區(qū)。(6) 差錯控制。

9、第20頁/共131頁2. 2. 設(shè)備控制器的組成設(shè)備控制器的組成由于設(shè)備控制器位于CPU與設(shè)備之間,它既要與CPU通信,又要與設(shè)備通信,還應(yīng)具有按照CPU所發(fā)來的命令去控制設(shè)備工作的功能,因此,現(xiàn)有的大多數(shù)控制器都是由以下三部分組成:(1) 設(shè)備控制器與處理機的接口。(2) 設(shè)備控制器與設(shè)備的接口。(3) I/O邏輯。 第21頁/共131頁 圖6-4 設(shè)備控制器的組成 第22頁/共131頁內(nèi)存映像內(nèi)存映像I/O I/O 1. 1. 利用特定的利用特定的I/OI/O指令指令在早期的計算機中,包括大型計算機,為實現(xiàn)CPU和設(shè)備控制器之間的通信,為每個控制寄存器分配一個I/O端口,這是一個8位或16

10、位的整數(shù),如圖6-5(a)所示。另外還設(shè)置了一些特定的I/O指令。 第23頁/共131頁2. 2. 內(nèi)存映像內(nèi)存映像I/OI/O在這種方式中,在編址上不再區(qū)分內(nèi)存單元地址和設(shè)備控制器中的寄存器地址,都采用k。當k值處于0n-1范圍時,被認為是內(nèi)存地址,若k大于等于n時,被認為是某個控制器的寄存器地址。 第24頁/共131頁 圖6-5 設(shè)備尋址形式第25頁/共131頁I/OI/O通道通道1. 1. I/OI/O通道設(shè)備的引入通道設(shè)備的引入雖然在CPU與I/O設(shè)備之間增加了設(shè)備控制器后,已能大大減少CPU對I/O的干預(yù),但當主機所配置的外設(shè)很多時,CPU的負擔仍然很重。為此,在CPU和設(shè)備控制器之

11、間又增設(shè)了I/O通道(I/O Channel)。 第26頁/共131頁2. 2. 通道類型通道類型1) 字節(jié)多路通道(Byte Multiplexor Channel)這是一種按字節(jié)交叉方式工作的通道。它通常都含有許多非分配型子通道,其數(shù)量可從幾十到數(shù)百個,每一個子通道連接一臺I/O設(shè)備,并控制該設(shè)備的I/O操作。這些子通道按時間片輪轉(zhuǎn)方式共享主通道。 第27頁/共131頁 圖6-6 字節(jié)多路通道的工作原理第28頁/共131頁 2) 數(shù)組選擇通道(Block Selector Channel)字節(jié)多路通道不適于連接高速設(shè)備,這推動了按數(shù)組方式進行數(shù)據(jù)傳送的數(shù)組選擇通道的形成。 第29頁/共13

12、1頁3) 數(shù)組多路通道(Block Multiplexor Channel)數(shù)組選擇通道雖有很高的傳輸速率,但它卻每次只允許一個設(shè)備傳輸數(shù)據(jù)。數(shù)組多路通道是將數(shù)組選擇通道傳輸速率高和字節(jié)多路通道能使各子通道(設(shè)備)分時并行操作的優(yōu)點相結(jié)合而形成的一種新通道。 第30頁/共131頁3. 3. “瓶頸瓶頸”問題問題由于通道價格昂貴,致使機器中所設(shè)置的通道數(shù)量勢必較少,這往往又使它成了I/O的瓶頸,進而造成整個系統(tǒng)吞吐量的下降。 第31頁/共131頁 圖6-7單通路I/O系統(tǒng)第32頁/共131頁 圖6-8多通路I/O系統(tǒng)第33頁/共131頁6.36.3中斷機構(gòu)和中斷處理程序中斷機構(gòu)和中斷處理程序?qū)τ?/p>

13、操作系統(tǒng)中的I/O系統(tǒng),本章采取從低層向高層的介紹方法,從本節(jié)開始首先介紹中斷處理程序。中斷在操作系統(tǒng)中有著特殊重要的地位,它是多道程序得以實現(xiàn)的基礎(chǔ),沒有中斷,就不可能實現(xiàn)多道程序,因為進程之間的切換是通過中斷來完成的。另一方面,中斷也是設(shè)備管理的基礎(chǔ),為了提高處理機的利用率和實現(xiàn)CPU與I/O設(shè)備并行執(zhí)行,也必需有中斷的支持。中斷處理程序是I/O系統(tǒng)中最低的一層,它是整個I/O系統(tǒng)的基礎(chǔ)。第34頁/共131頁中斷簡介中斷簡介 1. 1. 中斷和陷入中斷和陷入1) 中斷2) 陷入第35頁/共131頁2. 2. 中斷向量表和中斷優(yōu)先級中斷向量表和中斷優(yōu)先級1) 中斷向量表2) 中斷優(yōu)先級第36

14、頁/共131頁3. 3. 對多中斷源的處理方式對多中斷源的處理方式 1) 屏蔽(禁止)中斷2) 嵌套中斷第37頁/共131頁 圖6-9 對多中斷的處理方式第38頁/共131頁中斷處理程序中斷處理程序 當一個進程請求I/O 操作時,該進程將被掛起,直到I/O設(shè)備完成I/O操作后,設(shè)備控制器便向CPU發(fā)送一個中斷請求,CPU響應(yīng)后便轉(zhuǎn)向中斷處理程序,中斷處理程序執(zhí)行相應(yīng)的處理,處理完后解除相應(yīng)進程的阻塞狀態(tài)。第39頁/共131頁 圖6-10 中斷現(xiàn)場保護示意圖第40頁/共131頁 圖6-11 中斷處理流程第41頁/共131頁6.4 6.4 設(shè)備驅(qū)動程序設(shè)備驅(qū)動程序設(shè)備處理程序通常又稱為設(shè)備驅(qū)動程序

15、,它是I/O系統(tǒng)的高層與設(shè)備控制器之間的通信程序,其主要任務(wù)是接收上層軟件發(fā)來的抽象I/O要求,如read或write命令,再把它轉(zhuǎn)換為具體要求后,發(fā)送給設(shè)備控制器,啟動設(shè)備去執(zhí)行;反之,它也將由設(shè)備控制器發(fā)來的信號傳送給上層軟件。由于驅(qū)動程序與硬件密切相關(guān),故通常應(yīng)為每一類設(shè)備配置一種驅(qū)動程序。例如,打印機和顯示器需要不同的驅(qū)動程序。第42頁/共131頁設(shè)備驅(qū)動程序概述設(shè)備驅(qū)動程序概述 1. 1. 設(shè)備驅(qū)動程序的功能設(shè)備驅(qū)動程序的功能 (1) 接收由與設(shè)備無關(guān)的軟件發(fā)來的命令和參數(shù),并將命令中的抽象要求轉(zhuǎn)換為與設(shè)備相關(guān)的低層操作序列。(2) 檢查用戶I/O請求的合法性,了解I/O設(shè)備的工作狀

16、態(tài),傳遞與I/O設(shè)備操作有關(guān)的參數(shù),設(shè)置設(shè)備的工作方式。(3) 發(fā)出I/O命令,如果設(shè)備空閑,便立即啟動I/O設(shè)備,完成指定的I/O操作;如果設(shè)備忙碌,則將請求者的請求塊掛在設(shè)備隊列上等待。(4) 及時響應(yīng)由設(shè)備控制器發(fā)來的中斷請求,并根據(jù)其中斷類型,調(diào)用相應(yīng)的中斷處理程序進行處理。第43頁/共131頁2. 2. 設(shè)備驅(qū)動程序的特點設(shè)備驅(qū)動程序的特點 設(shè)備驅(qū)動程序?qū)儆诘图壍南到y(tǒng)例程,它與一般的應(yīng)用程序及系統(tǒng)程序之間有下述明顯差異:(1) 驅(qū)動程序是實現(xiàn)在與設(shè)備無關(guān)的軟件和設(shè)備控制器之間通信和轉(zhuǎn)換的程序,具體說,它將抽象的I/O請求轉(zhuǎn)換成具體的I/O操作后傳送給控制器。又把控制器中所記錄的設(shè)備狀

17、態(tài)和I/O操作完成情況,及時地反映給請求I/O的進程。(2) 驅(qū)動程序與設(shè)備控制器以及I/O設(shè)備的硬件特性緊密相關(guān),對于不同類型的設(shè)備,應(yīng)配置不同的驅(qū)動程序。但可以為相同的多個終端設(shè)置一個終端驅(qū)動程序。第44頁/共131頁(3) 驅(qū)動程序與I/O設(shè)備所采用的I/O控制方式緊密相關(guān),常用的I/O控制方式是中斷驅(qū)動和DMA方式。(4) 由于驅(qū)動程序與硬件緊密相關(guān),因而其中的一部分必須用匯編語言書寫。目前有很多驅(qū)動程序的基本部分已經(jīng)固化在ROM中。(5) 驅(qū)動程序應(yīng)允許可重入。一個正在運行的驅(qū)動程序常會在一次調(diào)用完成前被再次調(diào)用。第45頁/共131頁3. 3. 設(shè)備處理方式設(shè)備處理方式 在不同的操作

18、系統(tǒng)中,所采用的設(shè)備處理方式并不完全相同。 第46頁/共131頁設(shè)備驅(qū)動程序的處理過程設(shè)備驅(qū)動程序的處理過程設(shè)備驅(qū)動程序的主要任務(wù)是啟動指定設(shè)備,完成上層指定的I/O工作。但在啟動之前,應(yīng)先完成必要的準備工作,如檢測設(shè)備狀態(tài)是否為“忙”等。在完成所有的準備工作后,才向設(shè)備控制器發(fā)送一條啟動命令。 第47頁/共131頁 圖6-12 狀態(tài)寄存器中的格式第48頁/共131頁對對I/OI/O設(shè)備的控制方式設(shè)備的控制方式對設(shè)備的控制,早期是使用輪詢的可編程I/O方式,后來發(fā)展為使用中斷的可編程I/O方式。 第49頁/共131頁1. 1. 使用輪詢的可編程使用輪詢的可編程I/OI/O方式方式處理機對I/O

19、設(shè)備的控制采取輪詢的可編程I/O方式,即在處理機向控制器發(fā)出一條I/O指令,啟動輸入設(shè)備輸入數(shù)據(jù)時,要同時把狀態(tài)寄存器中的忙/閑標志busy置為1,然后便不斷地循環(huán)測試busy(稱為輪詢)。當busy=1時,表示輸入機尚未輸完一個字(符),處理機應(yīng)繼續(xù)對該標志進行測試,直至busy=0,表明輸入機已將輸入數(shù)據(jù)送入控制器的數(shù)據(jù)寄存器中。于是處理機將數(shù)據(jù)寄存器中的數(shù)據(jù)取出,送入內(nèi)存指定單元中,這樣便完成了一個字(符)的I/O。接著再去啟動讀下一個數(shù)據(jù),并置busy=1。 第50頁/共131頁 圖6-13 程序I/O和中斷驅(qū)動方式的流程第51頁/共131頁2. 2. 使用中斷的可編程使用中斷的可編程

20、I/OI/O方式方式當前,對I/O設(shè)備的控制,廣泛采用中斷的可編程I/O方式,即當某進程要啟動某個I/O設(shè)備工作時,便由CPU向相應(yīng)的設(shè)備控制器發(fā)出一條I/O命令,然后立即返回繼續(xù)執(zhí)行原來的任務(wù)。設(shè)備控制器于是按照該命令的要求去控制指定I/O設(shè)備。此時,CPU與I/O設(shè)備并行操作。 第52頁/共131頁3. 3. 直接存儲器訪問方式直接存儲器訪問方式1) 接存儲器訪問方式的引入雖然中斷驅(qū)動I/O比程序I/O方式更有效,但它仍是以字(節(jié))為單位進行I/O的。每當完成一個字(節(jié))的I/O時,控制器便要向CPU請求一次中斷。 第53頁/共131頁該方式的特點是:(1) 數(shù)據(jù)傳輸?shù)幕締挝皇菙?shù)據(jù)塊,即

21、在CPU與I/O設(shè)備之間,每次傳送至少一個數(shù)據(jù)塊。(2) 所傳送的數(shù)據(jù)是從設(shè)備直接送入內(nèi)存的,或者相反。(3) 僅在傳送一個或多個數(shù)據(jù)塊的開始和結(jié)束時,才需CPU干預(yù),整塊數(shù)據(jù)的傳送是在控制器的控制下完成的。可見,DMA方式較之中斷驅(qū)動方式又進一步提高了CPU與I/O設(shè)備的并行操作程度。第54頁/共131頁2) DMA控制器的組成DMA控制器由三部分組成:主機與DMA控制器的接口;DMA控制器與塊設(shè)備的接口;I/O控制邏輯。圖6-14示出了DMA控制器的組成。這里主要介紹主機與控制器之間的接口。第55頁/共131頁 圖6-14 DMA控制器的組成第56頁/共131頁3) DMA工作過程當CPU

22、要從磁盤讀入一數(shù)據(jù)塊時,便向磁盤控制器發(fā)送一條讀命令。該命令被送入命令寄存器CR中。同時,需要將本次要讀入數(shù)據(jù)在內(nèi)存的起始目標地址送入內(nèi)存地址寄存器MAR中。 第57頁/共131頁 圖6-15 DMA方式的工作流程圖第58頁/共131頁4.4. I/O I/O通道控制方式通道控制方式1) I/O通道控制方式的引入雖然DMA方式比起中斷方式來已經(jīng)顯著地減少了CPU的干預(yù),即已由以字(節(jié))為單位的干預(yù)減少到以數(shù)據(jù)塊為單位的干預(yù),但CPU每發(fā)出一條I/O指令,也只能去讀(或?qū)?一個連續(xù)的數(shù)據(jù)塊。而當我們需要一次去讀多個數(shù)據(jù)塊且將它們分別傳送到不同的內(nèi)存區(qū)域,或者相反時,則須由CPU分別發(fā)出多條I/O

23、指令及進行多次中斷處理才能完成。第59頁/共131頁2) 通道程序通道是通過執(zhí)行通道程序并與設(shè)備控制器共同實現(xiàn)對I/O設(shè)備的控制的。通道程序是由一系列通道指令(或稱為通道命令)所構(gòu)成的。 第60頁/共131頁下面示出了一個由六條通道指令所構(gòu)成的簡單的通道程序。該程序的功能是將內(nèi)存中不同地址的數(shù)據(jù)寫成多個記錄。 第61頁/共131頁6.5 6.5 與設(shè)備無關(guān)的與設(shè)備無關(guān)的I/OI/O軟件軟件為了方便用戶和提高OS的可適應(yīng)性與可擴展性,在現(xiàn)代OS的I/O系統(tǒng)中,都無一例外地增加了與設(shè)備無關(guān)的I/O軟件,以實現(xiàn)設(shè)備獨立性,也稱為設(shè)備無關(guān)性。其基本含義是:應(yīng)用程序中所用的設(shè)備,不局限于使用某個具體的物

24、理設(shè)備。為每個設(shè)備所配置的設(shè)備驅(qū)動程序是與硬件緊密相關(guān)的軟件。 第62頁/共131頁與設(shè)備無關(guān)與設(shè)備無關(guān)(Device Independence)(Device Independence)軟件的基本概念軟件的基本概念 1. 1. 以物理設(shè)備名使用設(shè)備以物理設(shè)備名使用設(shè)備在早期OS中,應(yīng)用程序在使用I/O設(shè)備時,都使用設(shè)備的物理名稱,這使應(yīng)用程序與系統(tǒng)中的物理設(shè)備直接相關(guān)。 第63頁/共131頁2. 2. 引入了邏輯設(shè)備名引入了邏輯設(shè)備名為了實現(xiàn)與設(shè)備的無關(guān)性而引入了邏輯設(shè)備和物理設(shè)備兩個概念。邏輯設(shè)備是抽象的設(shè)備名。 第64頁/共131頁3. 3. 邏輯設(shè)備名稱到物理設(shè)備名稱的轉(zhuǎn)換邏輯設(shè)備名稱

25、到物理設(shè)備名稱的轉(zhuǎn)換在應(yīng)用程序中,用邏輯設(shè)備名稱使用設(shè)備雖然方便了用戶,但系統(tǒng)卻只識別物理設(shè)備名稱,因此在實際執(zhí)行時,還必須使用物理名稱。為此,在系統(tǒng)中,必須具有將邏輯設(shè)備名稱轉(zhuǎn)換為某物理設(shè)備名稱的功能。 第65頁/共131頁與設(shè)備無關(guān)的軟件與設(shè)備無關(guān)的軟件1. 1. 設(shè)備驅(qū)動程序的統(tǒng)一接口設(shè)備驅(qū)動程序的統(tǒng)一接口為了使所有的設(shè)備驅(qū)動程序有著統(tǒng)一的接口,一方面,要求每個設(shè)備驅(qū)動程序與OS之間都有著相同的接口,或者相近的接口,這樣會使添加一個新的設(shè)備驅(qū)動程序變得很容易,同時在很大程度上方便了開發(fā)人員對設(shè)備驅(qū)動程序的編制。另一方面,要將抽象的設(shè)備名映射到適當?shù)尿?qū)動程序上,或者說,將抽象的設(shè)備名轉(zhuǎn)換為

26、具體的物理設(shè)備名,并進一步可以找到相應(yīng)物理設(shè)備的驅(qū)動程序入口。此外,還應(yīng)對設(shè)備進行保護,禁止用戶直接訪問設(shè)備,以防止無權(quán)訪問的用戶使用。第66頁/共131頁2. 2. 緩沖管理緩沖管理無論是字符設(shè)備還是塊設(shè)備,它們的運行速度都遠低于CPU的速度。為了緩和CPU和I/O設(shè)備之間的矛盾、提高CPU的利用率,在現(xiàn)代OS中都無一例外地分別為字符設(shè)備和塊設(shè)備配置了相應(yīng)的緩沖區(qū)。緩沖區(qū)有著多種形式,如單緩沖區(qū)、雙緩沖區(qū)、循環(huán)緩沖區(qū)、公用緩沖池等,以滿足不同情況的需要。 第67頁/共131頁3. 3. 差錯控制差錯控制由于設(shè)備中有著許多的機械和電氣部分,因此,它們比主機更容易出現(xiàn)故障,這就導致I/O操作中的

27、絕大多數(shù)錯誤都與設(shè)備有關(guān)。錯誤可分為如下兩類:(1) 暫時性錯誤。(2) 持久性錯誤。 第68頁/共131頁4. 4. 對獨立設(shè)備的分配與回收對獨立設(shè)備的分配與回收在系統(tǒng)中有兩類設(shè)備:獨占設(shè)備和共享設(shè)備。對于獨占設(shè)備,為了避免諸進程對獨占設(shè)備的爭奪,必須由系統(tǒng)來統(tǒng)一分配,不允許進程自行使用。每當進程需要使用某(獨占)設(shè)備時,必須先提出申請。OS接到對設(shè)備的請求后,先對進程所請求的獨占設(shè)備進行檢查,看該設(shè)備是否空閑。若空閑,才把該設(shè)備分配給請求進程。否則,進程將被阻塞,放入該設(shè)備的請求隊列中等待。等到其它進程釋放該設(shè)備時,再將隊列中的第一個進程喚醒,該進程得到設(shè)備后繼續(xù)運行。第69頁/共131頁

28、5. 5. 獨立于設(shè)備的邏輯數(shù)據(jù)塊獨立于設(shè)備的邏輯數(shù)據(jù)塊不同類型的設(shè)備,其數(shù)據(jù)交換單位是不同的,讀取和傳輸速率也各不相同,如字符型設(shè)備以單個字符(字)為單位,塊設(shè)備是以一個數(shù)據(jù)塊為單位。即使同一類型的設(shè)備,其數(shù)據(jù)交換單位的大小也是有差異的,如不同磁盤由于扇區(qū)大小的不同,可能造成數(shù)據(jù)塊大小的不一致。設(shè)備獨立性軟件應(yīng)能夠隱藏這些差異而被邏輯設(shè)備使用,并向高層軟件提供大小統(tǒng)一的邏輯數(shù)據(jù)塊。與設(shè)備無關(guān)軟件的功能如圖6-16所示。 第70頁/共131頁 圖6-16 與設(shè)備無關(guān)軟件的功能層次第71頁/共131頁設(shè)備分配設(shè)備分配系統(tǒng)為實現(xiàn)對獨占設(shè)備的分配,必須在系統(tǒng)中配置相應(yīng)的數(shù)據(jù)結(jié)構(gòu)。1. 1. 設(shè)備分配

29、中的數(shù)據(jù)結(jié)構(gòu)設(shè)備分配中的數(shù)據(jù)結(jié)構(gòu)在用于設(shè)備分配的數(shù)據(jù)結(jié)構(gòu)中,記錄了對設(shè)備或控制器進行控制所需的信息。在進行設(shè)備分配時需要如下的數(shù)據(jù)結(jié)構(gòu)。1) 設(shè)備控制表DCT系統(tǒng)為每一個設(shè)備都配置了一張設(shè)備控制表,用于記錄設(shè)備的情況,如圖6-17所示。第72頁/共131頁 圖6-17 設(shè)備控制表第73頁/共131頁2) 控制器控制表、通道控制表和系統(tǒng)設(shè)備表(1) 控制器控制表(COCT)。系統(tǒng)為每一個控制器都設(shè)置了用于記錄控制器情況的控制器控制表,如圖6-18(a)所示。(2) 通道控制表(CHCT)。每個通道都有一張通道控制表,如圖6-18(b)所示。(3) 系統(tǒng)設(shè)備表(SDT)。這是系統(tǒng)范圍的數(shù)據(jù)結(jié)構(gòu),記

30、錄了系統(tǒng)中全部設(shè)備的情況,每個設(shè)備占一個表目,其中包括有設(shè)備類型、設(shè)備標識符、設(shè)備控制表及設(shè)備驅(qū)動程序的入口等項,如圖6-18(c)所示。第74頁/共131頁 圖6-18 COCT、CHCT和SDT表第75頁/共131頁2. 2. 設(shè)備分配時應(yīng)考慮的因素設(shè)備分配時應(yīng)考慮的因素 系統(tǒng)在分配設(shè)備時,應(yīng)考慮如下幾個因素:1) 設(shè)備的固有屬性設(shè)備的固有屬性可分成三種,對它們應(yīng)采取不同的分配策略:(1) 獨占設(shè)備的分配策略。(2) 共享設(shè)備的分配策略。(3) 虛擬設(shè)備的分配策略,虛擬設(shè)備屬于可共享的設(shè)備,可以將它同時分配給多個進程使用。第76頁/共131頁2) 設(shè)備分配算法對設(shè)備分配的算法,通常只采用以

31、下兩種分配算法:(1) 先來先服務(wù)。(2) 優(yōu)先級高者優(yōu)先。第77頁/共131頁3) 設(shè)備分配中的安全性從進程運行的安全性上考慮,設(shè)備分配有以下兩種方式:(1) 安全分配方式。(2) 不安全分配方式。第78頁/共131頁3. 3. 獨占設(shè)備的分配程序獨占設(shè)備的分配程序 1) 基本的設(shè)備分配程序我們通過一個例子來介紹設(shè)備分配過程。當某進程提出I/O請求后,系統(tǒng)的設(shè)備分配程序可按下述步驟進行設(shè)備分配:(1) 分配設(shè)備。(2) 分配控制器。(3) 分配通道。 第79頁/共131頁2) 設(shè)備分配程序的改進在上面的例子中,進程是以物理設(shè)備名提出I/O請求的。如果所指定的設(shè)備已分配給其它進程,則分配失敗。

32、或者說上面的設(shè)備分配程序不具有與設(shè)備無關(guān)性。為獲得設(shè)備的獨立性,進程應(yīng)使用邏輯設(shè)備名請求I/O。 第80頁/共131頁邏輯設(shè)備名到物理設(shè)備名映射的實現(xiàn)邏輯設(shè)備名到物理設(shè)備名映射的實現(xiàn)1. 1. 邏輯設(shè)備表邏輯設(shè)備表LUT(Logical Unit Table)LUT(Logical Unit Table)在邏輯設(shè)備表的每個表目中包含了三項:邏輯設(shè)備名、物理設(shè)備名和設(shè)備驅(qū)動程序的入口地址,如圖6-19(a)所示。 第81頁/共131頁 圖6-19 邏輯設(shè)備表第82頁/共131頁2. 2. 邏輯設(shè)備表的設(shè)置問題邏輯設(shè)備表的設(shè)置問題在系統(tǒng)中可采取兩種方式設(shè)置邏輯設(shè)備表: 第一種方式,是在整個系統(tǒng)中只

33、設(shè)置一張LUT。第二種方式,是為每個用戶設(shè)置一張LUT。 第83頁/共131頁6.6 6.6 用戶層的用戶層的I/OI/O軟件軟件系統(tǒng)調(diào)用與庫函數(shù)系統(tǒng)調(diào)用與庫函數(shù) 1. 1. 系統(tǒng)調(diào)用系統(tǒng)調(diào)用一方面,為使諸進程能有條不紊地使用I/O設(shè)備,且能保護設(shè)備的安全性,不允許運行在用戶態(tài)的應(yīng)用進程去直接調(diào)用運行在核心態(tài)(系統(tǒng)態(tài))的OS過程。但另一方面,應(yīng)用進程在運行時,又必須取得OS所提供的服務(wù),否則,應(yīng)用程序幾乎無法運行。為了解決此矛盾,OS在用戶層中引入了一個中介過程系統(tǒng)調(diào)用,應(yīng)用程序可以通過它間接調(diào)用OS中的I/O過程,對I/O設(shè)備進行操作。第84頁/共131頁 圖6-20 系統(tǒng)調(diào)用的執(zhí)行過程第8

34、5頁/共131頁2. 2. 庫函數(shù)庫函數(shù)在C語言以及UNIX系統(tǒng)中,系統(tǒng)調(diào)用(如read)與各系統(tǒng)調(diào)用所使用的庫函數(shù)(如read)之間幾乎是一一對應(yīng)的。而微軟定義了一套過程,稱為Win32 API的應(yīng)用程序接口(Application Program Interface),程序員利用它們?nèi)〉肙S服務(wù),該接口與實際的系統(tǒng)調(diào)用并不一一對應(yīng)。用戶程序通過調(diào)用對應(yīng)的庫函數(shù)使用系統(tǒng)調(diào)用,這些庫函數(shù)與調(diào)用程序連接在一起,被嵌入在運行時裝入內(nèi)存的二進制程序中。第86頁/共131頁假脫機假脫機(Spooling)(Spooling)系統(tǒng)系統(tǒng)1. 1. 假脫機技術(shù)假脫機技術(shù) 在20世紀50年代,為了緩和CPU的

35、高速性與I/O設(shè)備低速性間的矛盾,而引入了脫機輸入、脫機輸出技術(shù)。該技術(shù)是利用專門的外圍控制機,先將低速I/O設(shè)備上的數(shù)據(jù)傳送到高速磁盤上,或者相反。這樣當處理機需要輸入數(shù)據(jù)時,便可以直接從磁盤中讀取數(shù)據(jù),極大地提高了輸入速度。反之,在處理機需要輸出數(shù)據(jù)時,也可以很快的速度把數(shù)據(jù)先輸出到磁盤上,處理機便可去做自己的事情。第87頁/共131頁2.2. SPOOLing SPOOLing的組成的組成如前所述,SPOOLing技術(shù)是對脫機輸入/輸出系統(tǒng)的模擬,相應(yīng)地,如圖6-21(a)所示,SPOOLing系統(tǒng)建立在通道技術(shù)和多道程序技術(shù)的基礎(chǔ)上,以高速隨機外存(通常為磁盤)為后援存儲器。SPOOL

36、ing的工作原理如圖6-21(b)所示。第88頁/共131頁 圖6-21 SPOOLing系統(tǒng)組成及工作原理第89頁/共131頁SPOOLing系統(tǒng)主要由以下四部分構(gòu)成:(1) 輸入井和輸出井。(2) 輸入緩沖區(qū)和輸出緩沖區(qū)。(3) 輸入進程和輸出進程。(4) 井管理程序。第90頁/共131頁3. 3. SPOOLingSPOOLing系統(tǒng)的特點系統(tǒng)的特點(1) 提高了I/O的速度。(2) 將獨占設(shè)備改造為共享設(shè)備。(3) 實現(xiàn)了虛擬設(shè)備功能。第91頁/共131頁4. 4. 假脫機打印機系統(tǒng)假脫機打印機系統(tǒng)打印機是經(jīng)常用到的輸出設(shè)備,屬于獨占設(shè)備。利用假脫機技術(shù)可將它改造為一臺可供多個用戶共享

37、的打印設(shè)備,從而提高設(shè)備的利用率,也方便了用戶。共享打印機技術(shù)已被廣泛地用于多用戶系統(tǒng)和局域網(wǎng)絡(luò)中。假脫機打印系統(tǒng)主要有以下三部分:(1) 磁盤緩沖區(qū)。(2) 打印緩沖區(qū)。(3) 假脫機管理進程和假脫機打印進程。第92頁/共131頁5. 5. 守護進程守護進程(daemon)(daemon)前面是利用假脫機系統(tǒng)來實現(xiàn)打印機共享的一種方案,人們對該方案進行了某些修改,如取消該方案中的假脫機管理進程,為打印機建立一個守護進程,由它執(zhí)行一部分原來由假脫機管理進程實現(xiàn)的功能,如為用戶在磁盤緩沖區(qū)中申請一個空閑盤塊,并將要打印的數(shù)據(jù)送入其中,將該盤塊的首址返回給請求進程。另一部分由請求進程自己完成,每個

38、要求打印的進程首先生成一份要求打印的文件,其中包含對打印的要求和指向裝有打印輸出數(shù)據(jù)盤塊的指針等信息,然后將用戶請求打印文件放入假脫機文件隊列(目錄)中。第93頁/共131頁6.7 6.7 緩緩沖沖區(qū)區(qū)管管理理在現(xiàn)代操作系統(tǒng)中,幾乎所有的I/O設(shè)備在與處理機交換數(shù)據(jù)時都用了緩沖區(qū)。緩沖區(qū)是一個存儲區(qū)域,它可以由專門的硬件寄存器組成,但由于硬件的成本較高,容量也較小,一般僅用在對速度要求非常高的場合,如存儲器管理中所用的聯(lián)想存儲器;設(shè)備控制器中用的數(shù)據(jù)緩沖區(qū)等。 第94頁/共131頁緩沖的引入緩沖的引入 引入緩沖區(qū)的原因有很多,可歸結(jié)為以下幾點:(1) 緩和CPU與I/O設(shè)備間速度不匹配的矛盾。

39、(2) 減少對CPU的中斷頻率,放寬對CPU中斷響應(yīng)時間的限制。(3) 解決數(shù)據(jù)粒度不匹配的問題。(4) 提高CPU和I/O設(shè)備之間的并行性。第95頁/共131頁 圖6-22 利用緩沖寄存器實現(xiàn)緩沖第96頁/共131頁單緩沖區(qū)和雙緩沖區(qū)單緩沖區(qū)和雙緩沖區(qū) 1. 1. 單緩沖區(qū)單緩沖區(qū)(Single Buffer)(Single Buffer)在單緩沖情況下,每當用戶進程發(fā)出一I/O請求時,操作系統(tǒng)便在主存中為之分配一緩沖區(qū),如圖6-23所示。 第97頁/共131頁 圖6-23 單緩沖工作示意圖第98頁/共131頁2. 2. 雙緩沖區(qū)雙緩沖區(qū)(Double Buffer)(Double Buff

40、er)由于緩沖區(qū)是共享資源,生產(chǎn)者與消費者在使用緩沖區(qū)時必須互斥。如果消費者尚未取走緩沖區(qū)中的數(shù)據(jù),即使生產(chǎn)者又生產(chǎn)出新的數(shù)據(jù),也無法將它送入緩沖區(qū),生產(chǎn)者等待。如果為生產(chǎn)者與消費者設(shè)置了兩個緩沖區(qū),便能解決這一問題。第99頁/共131頁 圖6-24 雙緩沖工作示意圖第100頁/共131頁如果在實現(xiàn)兩臺機器之間的通信時僅為它們配置了單緩沖,如圖6-25(a)所示,那么,它們之間在任一時刻都只能實現(xiàn)單方向的數(shù)據(jù)傳輸。例如,只允許把數(shù)據(jù)從A傳送到B,或者從B傳送到A,而絕不允許雙方同時向?qū)Ψ桨l(fā)送數(shù)據(jù)。為了實現(xiàn)雙向數(shù)據(jù)傳輸,必須在兩臺機器中都設(shè)置兩個緩沖區(qū),一個用作發(fā)送緩沖區(qū),另一個用作接收緩沖區(qū),

41、如圖6-25(b)所示。第101頁/共131頁 圖6-25 雙機通信時緩沖區(qū)的設(shè)置第102頁/共131頁環(huán)形緩沖區(qū)環(huán)形緩沖區(qū) 1. 1. 環(huán)形緩沖區(qū)的組成環(huán)形緩沖區(qū)的組成(1) 多個緩沖區(qū)。在環(huán)形緩沖中包括多個緩沖區(qū),其每個緩沖區(qū)的大小相同。作為輸入的多緩沖區(qū)可分為三種類型:用于裝輸入數(shù)據(jù)的空緩沖區(qū)R、已裝滿數(shù)據(jù)的緩沖區(qū)G以及計算進程正在使用的現(xiàn)行工作緩沖區(qū)C,如圖6-26所示。第103頁/共131頁 圖6-26 環(huán)形緩沖區(qū)第104頁/共131頁2. 2. 環(huán)形緩沖區(qū)的使用環(huán)形緩沖區(qū)的使用計算進程和輸入進程可利用下述兩個過程來使用形環(huán)緩沖區(qū)。(1) Getbuf過程。(2) Releasebu

42、f過程。第105頁/共131頁3. 3. 進程之間的同步問題進程之間的同步問題使用輸入循環(huán)緩沖,可使輸入進程和計算進程并行執(zhí)行。相應(yīng)地,指針Nexti和指針Nextg將不斷地沿著順時針方向移動,這樣就可能出現(xiàn)下述兩種情況:(1) Nexti指針追趕上Nextg指針。(2) Nextg指針追趕上Nexti指針。 第106頁/共131頁緩沖池緩沖池(Buffer Pool) (Buffer Pool) 1. 1. 緩沖池的組成緩沖池的組成緩沖池管理著多個緩沖區(qū),每個緩沖區(qū)由用于標識和管理的緩沖首部以及用于存放數(shù)據(jù)的緩沖體兩部分組成。緩沖首部一般包括緩沖區(qū)號、設(shè)備號、設(shè)備上的數(shù)據(jù)塊號、同步信號量以及

43、隊列鏈接指針等。為了管理上的方便,一般將緩沖池中具有相同類型的緩沖區(qū)鏈接成一個隊列,于是可形成以下三個隊列:(1) 空白緩沖隊列emq。(2) 輸入隊列inq。(3) 輸出隊列outq。 第107頁/共131頁2. 2. GetbufGetbuf過程和過程和PutbufPutbuf過程過程在數(shù)據(jù)結(jié)構(gòu)課程中,曾介紹過隊列和對隊列進行操作的兩個過程,第一個是 Addbuf(type,number)過程。該過程用于將由參數(shù)number所指示的緩沖區(qū)B掛在type隊列上。第二個是Takebuf(type)過程。它用于從type所指示的隊列的隊首摘下一個緩沖區(qū)。第108頁/共131頁3. 3. 緩沖區(qū)的

44、工作方式緩沖區(qū)的工作方式緩沖區(qū)可以工作在如下四種工作方式,如圖6-27所示。第109頁/共131頁 圖6-27 緩沖區(qū)的工作方式第110頁/共131頁6.8 6.8 磁盤存儲器的性能和調(diào)度磁盤存儲器的性能和調(diào)度磁盤性能簡述磁盤性能簡述磁盤設(shè)備是一種相當復雜的機電設(shè)備,在此僅對磁盤的某些性能,如數(shù)據(jù)的組織、磁盤的類型和訪問時間等方面做扼要的闡述。第111頁/共131頁1. 1. 數(shù)據(jù)的組織和格式數(shù)據(jù)的組織和格式磁盤設(shè)備可包括一個或多個物理盤片,每個磁盤片分一個或兩個存儲面(Surface)(見圖6-28(a),每個盤面上有若干個磁道(Track),磁道之間留有必要的間隙(Gap)。為使處理簡單起

45、見,在每條磁道上可存儲相同數(shù)目的二進制位。 第112頁/共131頁 圖6-28 磁盤的結(jié)構(gòu)和布局第113頁/共131頁 圖6-29 磁盤的格式化第114頁/共131頁2. 2. 磁盤的類型磁盤的類型對于磁盤,可以從不同的角度進行分類。最常見的有:將磁盤分成硬盤和軟盤、單片盤和多片盤、固定頭磁盤和活動頭(移動頭)磁盤等。下面僅對固定頭磁盤和移動頭磁盤做些介紹。(1) 固定頭磁盤。(2) 移動頭磁盤。 第115頁/共131頁3. 3. 磁盤訪問時間磁盤訪問時間磁盤設(shè)備在工作時以恒定速率旋轉(zhuǎn)。為了讀或?qū)懀蓬^必須能移動到所指定的磁道上,并等待所指定的扇區(qū)的開始位置旋轉(zhuǎn)到磁頭下,然后再開始讀或?qū)憯?shù)據(jù)。

46、 第116頁/共131頁早期的磁盤調(diào)度算法早期的磁盤調(diào)度算法 1. 1. 先來先服務(wù)先來先服務(wù)(FCFS)(FCFS)這是最簡單的磁盤調(diào)度算法。它根據(jù)進程請求訪問磁盤的先后次序進行調(diào)度。 第117頁/共131頁2. 2. 最短尋道時間優(yōu)先最短尋道時間優(yōu)先(SSTF)(SSTF)該算法選擇這樣的進程,其要求訪問的磁道與當前磁頭所在的磁道距離最近,以使每次的尋道時間最短,但這種算法不能保證平均尋道時間最短。 第118頁/共131頁 圖6-30 FCFS調(diào)度算法 第119頁/共131頁 圖6-31 SSTF調(diào)度算法 第120頁/共131頁基于掃描的磁盤調(diào)度算法基于掃描的磁盤調(diào)度算法 1. 1. 掃描掃描(SCAN)(SCAN)算法算法SSTF算法的實質(zhì)是基于優(yōu)先級的調(diào)度算法,因此就可能導致優(yōu)先級低的進程發(fā)生“饑餓”(Starvation)現(xiàn)象。因為只要不斷有新進程的請求到達,且其所要訪問的磁道與磁頭當前所在磁道的距離較近,這種新進程的I/O請求必然優(yōu)先滿足。在對SSTF算法略加修改后,則可防止低優(yōu)先級進程出現(xiàn)“饑餓”現(xiàn)象。第121頁/共

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論