|
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)0 c0 \; n; E0 U
( n3 P' O/ P! Y2 M- H
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)6 Z* t4 ^& B9 M9 `/ V2 @
' O( e3 u" X) \- d( V8 H. D& r- [CPU], N9 M2 ~+ h* G
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.6 j& B; |; y; }' `9 z9 d
, B( g( d) z+ @# ~* m! c
- [North bridge]% z# A, ]1 r9 ] ]+ C" ?+ j
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)* ^1 T( R, s: W1 T! p6 S# R
1. Host interface: 即 與 CPU interface 的部分.
F* k* _6 |6 @3 ~* Y; ~0 c2. DRAM interface: 即與 DRAM interface的部分
3 Q+ P8 p7 ^: B5 i3. Display interface: 即與 AGP/PCIe VGA interface的部分
" a$ b1 v( h; s) I4. Link interface: 即與 South bridge(南橋) interface的部分
4 T- F& Q! ?3 L; u* Q6 I9 }- Q0 E9 Z/ Z5 f* y
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )9 `% p: |6 I; S& a9 V6 o O. t
3 B- A& w! ]9 N5 x5 r所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
' e5 u) W4 s+ l$ W: }' k5 }( ?0 Z5 c! a* ` a
-[South bridge]' W. n( T0 x' d# L f
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
3 P0 k( o3 \# w1. Link interface: 即呼應北橋的部分.
/ a- ^" n1 a' W! a+ R, N5 D6 Z2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)* E2 n3 d0 {6 o. K" F4 W" W
3. ACPI block: implement ACPI H/W part8 P1 e9 |2 A/ d# \& o
4. USB
( X. ~. u) T: |% ^; S$ o0 [; Z5. Audio
2 c6 S: ]) _6 ` t3 d3 \% S7 i6. SATA(AHCI)+ o! e4 E. Y H* g% u/ y8 H
7. ...
" ^: ?! j( ^) T& p$ v
* l* U8 ^) {, Q5 p& _3 b9 w所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
4 Z1 m! x, Z0 e% R9 K3 [2 E8 L0 r/ g3 z6 @
-[BIOS ROM]
) N5 l. \& B/ I; h=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code* s# f! N5 [- b' n& y
) |, F* _- B5 y/ ^
所以,總結來說: 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裡...)
" W X' Z' i4 r3 Z4 T1 f) T
) z' k2 _0 p2 D! l以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.) B" `/ f8 l3 t: j. W/ s
% t9 B& r5 [' E e2 A( Z
Summary:2 ~4 }# X0 J$ l5 x( S7 g1 `
1. BIOS可以說是 chipset's driver !!!0 R' D+ c) y& q f4 @' }2 u6 ~
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的 |
|