|
|
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)4 Y. Q+ ~3 x4 Q ~. l* P$ r
* g! F* f! M) t& u- s4 V! u+ |/ PBIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
! I: R- h& R. C5 `
7 l" @ R' ^4 v( ]8 M7 M. K. G9 c- [CPU]
5 `: N+ U) ` V/ v$ [! e=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.1 J: J0 u6 p( A
6 I. Q, r" c* |- [North bridge]
4 Z1 w( o# D) C! C=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)# T6 j" _% t8 Q2 Z
1. Host interface: 即 與 CPU interface 的部分.
3 D7 E' t& @ P8 I5 `2. DRAM interface: 即與 DRAM interface的部分
8 r5 s9 T: g5 O \9 A' P8 t. K% J6 v3. Display interface: 即與 AGP/PCIe VGA interface的部分( @! M) J, {+ |% o# R
4. Link interface: 即與 South bridge(南橋) interface的部分
0 i5 v( ~, r) E& ~$ P2 F( m% r4 Q' K4 {! @
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
# l9 b: C5 S# g: `' y! Z$ p- ~3 k! x( }; E; v
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.: ?0 P4 w1 y, p- x' q% W
4 s* B- k# U* `: L-[South bridge]3 e# _, L! h4 v H% z- d, ?3 e. e
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
) d! Y( C) {% G1. Link interface: 即呼應北橋的部分.8 T" v! x1 E) L* n
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)! B3 v: Z1 W4 x; a! S
3. ACPI block: implement ACPI H/W part5 u7 g3 ~+ K8 h; i1 D3 i
4. USB' m7 u+ s( e7 f3 U% w
5. Audio3 B4 s; P; T) J; H- n; g8 v
6. SATA(AHCI)& J- `* s- i9 b, M3 s8 h. [
7. ...0 z; F; a9 n% {) h' @9 q* Q
, A, q' o: {. D' R8 D& c所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
( S9 q* O" @0 g2 j0 [8 B
2 p. @& k+ k3 E. M-[BIOS ROM]: P* y) D: i5 c" S
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
+ f* J8 t$ ?0 K+ I8 E9 G
9 D: r' h' [" f% D所以,總結來說: 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裡...)
+ I7 ?' J* x& m1 C* K$ F
) A( q. Y& w5 j0 i/ G& R+ ^9 u以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.4 @+ H1 Z2 X' M3 Z% A2 {
, b X5 k0 j0 S HSummary:' _# r( d4 Y, y- l# L/ r
1. BIOS可以說是 chipset's driver !!!
1 D( K' q" G4 H1 {3 D7 Q2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的 |
|