找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 11275|回复: 1

[转载]我所知道的BIOS系統架構2

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)8 y4 N6 j: m& L0 K$ }

! P# b& x: a/ i4 [BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到), q$ {. |- X9 O. _
; T4 K* A4 b# z
- [CPU]5 _. H% J+ N/ m. u6 O: c) W
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
2 N3 p% `) ^9 O& X$ V8 w* K- }6 `5 l8 @4 ^4 ^
- [North bridge]9 [# J, |8 E# G& W/ z) g
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
/ ?7 e6 I0 C) J# l, |8 I1. Host interface: 即 與 CPU interface 的部分. 5 i8 f3 Y7 e4 n. Q$ F! m* [( G2 N
2. DRAM interface: 即與 DRAM interface的部分- |# }' x. l9 O  e0 o+ |( h. Q
3. Display interface: 即與 AGP/PCIe VGA interface的部分
2 H' G3 A  S8 J7 J. ~# M4. Link interface: 即與 South bridge(南橋) interface的部分" Z$ p" ^5 q  C7 F1 h6 B9 k
& u- B$ W8 ^% \0 u' Z* @
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
3 U" s7 V; A7 F0 L  B
3 X" D8 m) x. `( i' O8 D所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
+ y9 o& l) ^) m# Z, w% Y' b3 O
- u: r, i% R- h% X. ~* G-[South bridge]
+ D( q  B) P; M  y" }/ E=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
2 o( A# i7 P$ @6 L& v1. Link interface: 即呼應北橋的部分.) E/ W7 j% S, C2 `( [
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)
4 f; N$ Q& w8 w* j& U3. ACPI block: implement ACPI H/W part- [# C# m7 W6 A1 A( v' o
4. USB# G0 k8 n- H2 d5 i0 B4 }0 `
5. Audio! V/ ~% h# W, }$ e/ s
6. SATA(AHCI)
8 A+ Y: }7 i7 n3 ]  E$ \7. ...
% a) ^" v! n+ ^' }, ~3 b
- _! M, b* k" R4 s) W& T, \; F所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
' Q4 K, }6 M' L; P0 _
* i) R' f1 I* W3 d-[BIOS ROM]
( k$ A" }- C" o=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
# ^3 l0 G. g/ a: P  M
0 Y  d9 y7 z' i# F2 X6 r所以,總結來說: BIOS code被CPU fetch, 經過 decode後, 會轉發給NB.NB接到後也會自行decode 此 request;若是 與 DRAM有關的,則 forward to DRAM block;若與 display有關,則forward to display block;若是與 PCI有關的,則將之轉發給 SB(透過兩者中間的Link),請SB再找適合的人 Ex. USB, SATA, or 1394 controller ! ( 別忘了 PCI H/W是在SB裡...)9 ?- ~1 E) m( O4 d

8 F# T# I# j( ?6 x4 Z+ }3 Q以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.4 G* J9 }+ ~* ^6 ]1 k

% P/ R0 s& g2 v! WSummary:" o# G% Z. Z3 z) M
1. BIOS可以說是 chipset's driver !!!% _6 m: J  d. E: J9 F
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

Archiver|手机版|小黑屋|计匠网

GMT+8, 2024-11-15 21:02 , Processed in 0.031114 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表