|
|
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
& F9 Q0 g' \! F/ \+ w/ T( |& x e1 T- s5 m) B# u4 W3 t
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
! g5 F/ Y/ C* q# p& \' T4 m1 c" e6 _' ^
- [CPU]5 z! e( C/ r/ T; l
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.+ c6 v* Z( }& e# X( ?( j9 c
8 y2 n1 v$ S9 E5 H' h
- [North bridge]
7 ?9 [( Z* j& |1 b; D) P- b: y- C1 R=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
6 F4 J/ b; O9 l1. Host interface: 即 與 CPU interface 的部分. # `3 V+ N$ j. C( n w5 @
2. DRAM interface: 即與 DRAM interface的部分6 T& s" C8 h+ o* N+ ^5 n5 k
3. Display interface: 即與 AGP/PCIe VGA interface的部分
& ~' j: \9 W7 k( G4. Link interface: 即與 South bridge(南橋) interface的部分- L. s! E7 @& n2 T( F; U
; E% f5 C. S, K簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
- W7 J' n; Z9 ?$ x3 [: c5 M
! m. j4 u( N: m. X; y2 C1 C! e所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
' A8 N8 g* X4 I0 d' R
: H! S3 U, N. t% [: C1 Q7 ]6 T-[South bridge]
; f& Q$ S* a% W2 ]7 N+ O=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:& e/ c: x0 v9 F3 t; G5 n
1. Link interface: 即呼應北橋的部分., R5 ]: h* e: }
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)) r9 l4 F A+ P
3. ACPI block: implement ACPI H/W part) s d* u1 Z% t: P
4. USB
& o4 a% l! u5 T: F5. Audio+ d; j$ D K5 M, b5 b# x1 M
6. SATA(AHCI)
; P* S: K1 |2 `$ N; I. q' m& @7. ...# r/ j6 T. l* P1 k
$ J! x. R( X7 L, `$ J t
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
- g3 t) v" ~" p. t$ `# ~
, t4 n/ j. e: b. @, t! B! l-[BIOS ROM]
* F6 o9 B, b9 T8 O6 G2 m" @=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code, i2 S M; `2 a( t
6 A( b1 T1 m# w, q
所以,總結來說: 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裡...)5 h+ J" L1 i* {: v. ]) s
3 z2 I( i7 w# L2 P以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow." B J: ? L% }2 d; P
+ y% z9 d1 y4 m" L, N5 e3 ASummary:
1 U& R/ V% _3 u$ h0 ^6 g1. BIOS可以說是 chipset's driver !!!2 F1 ^! ` f! |; ^7 P' n
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的 |
|