12.5. SBus

2018-02-24 15:50 更新

12.5.?SBus

當(dāng)大部分計(jì)算機(jī)配備有 PCI 或 ISA 接口總線, 大部分老式的基于 SPARC 的工作站使用 SBus 來連接它們的外設(shè).

SBus 使一個非常先進(jìn)的設(shè)計(jì), 盡管它已出現(xiàn)很長時間. 它意圖是處理器獨(dú)立的(盡管只有 SPARC 計(jì)算機(jī)使用它)并且為 I/O 外設(shè)板做了優(yōu)化. 換句話說, 你不能插入額外的 RAM 到 SBus 槽位( RAM 擴(kuò)展板即便在 ISA 世界也已被忘記很長時間了, 并且 PCI 不再支持它們). 這個優(yōu)化打算來簡化硬件設(shè)備和系統(tǒng)軟件的設(shè)計(jì), 代價是主板的一些增加的復(fù)雜性.

這個總線的 I/O 偏好導(dǎo)致了使用虛擬地址來傳送數(shù)據(jù)的外設(shè), 因此不必分配一個連續(xù)的 DMA 緩沖. 主板負(fù)責(zé)解碼虛擬地址并映射它們到物理地址. 這要求連接一個 MMU(內(nèi)存管理單元)到總線; 負(fù)責(zé)這個任務(wù)的芯片組稱為 IOMMU. 盡管比在接口總線上使用物理地址更復(fù)雜, 這個設(shè)計(jì)被很大地簡化, 由于 SPARC 處理器一直設(shè)計(jì)為保持 MMU 內(nèi)核和 CPU 內(nèi)核獨(dú)立(要么是物理上地, 要么至少在概念上). 實(shí)際上, 這個設(shè)計(jì)選擇被其他的智能處理器設(shè)計(jì)所共享并且全面受益. 這個總線的另一個特性是設(shè)備板采用大塊地理式尋址, 因此沒有必要實(shí)現(xiàn)一個地址解碼器在每個外設(shè)或者處理地址沖突.

SBus 外設(shè)使用 Forth 語言在它們的 PROM 中來初始化它們自己. 選擇 Forth 是因?yàn)榻忉屍魇禽p量級的, 并且因此, 可輕易在任何一個計(jì)算機(jī)系統(tǒng)固件中實(shí)現(xiàn). 另外, SBus 規(guī)范規(guī)定了驅(qū)動處理, 使兼容的 I/O 設(shè)備輕易適用到系統(tǒng)中并且在系統(tǒng)啟動時被識別. 這是一個大的步驟來支持多平臺設(shè)備; 相比我們熟悉的以 PC 為中心的 ISA 之類它是一個完全不同的世界. 但是, 它不能成功, 因?yàn)樵S多商業(yè)的原因.

盡管當(dāng)前的內(nèi)核版本提供了對 SBus 設(shè)備的很多全特性的支持, 這個總線現(xiàn)在用的很少, 以至于在這里它不值得詳細(xì)描述. 感興趣的讀者可查看源代碼 arch/sparc/kernel 和arch/sparc/mm

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號