|
|
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
# T- K0 J* L% f. e' L2 H$ j* S# {7 G" A: I7 N3 o/ _
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
( h. P$ y5 d! ^* G. a
& [( t7 s1 Z, c- [CPU]
9 e! k5 e) a+ J=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
0 z# g& [: j6 c' P' d
5 U2 S' k7 H4 g# N0 v$ r' Q- [North bridge]
8 C0 |* L9 m) L/ h' O' z=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view). j- n) T7 C$ S5 f
1. Host interface: 即 與 CPU interface 的部分. $ _" O! C2 F8 u% I3 ]0 p7 n
2. DRAM interface: 即與 DRAM interface的部分" o0 b' N( S! N
3. Display interface: 即與 AGP/PCIe VGA interface的部分
4 t* b" O. ~2 [, M4. Link interface: 即與 South bridge(南橋) interface的部分6 z9 ]4 X, R i0 e, D' J
; ]2 A1 q. G3 m) [; Q, u5 ?: r, r簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
0 n' p; k q+ u& c% O- D
9 _1 Z% K5 w3 T3 S所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
! E) o+ e- R) O0 |5 I: [' m$ z6 k# r+ L4 l A1 ]$ K* U' m2 p3 d: Y
-[South bridge]4 d% G7 Q7 B- ?$ Q3 R% \5 V
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:* l, _% y, r. ^8 a. ~3 k: z
1. Link interface: 即呼應北橋的部分.4 f1 k2 Z! a4 f; ^1 Z5 W
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)3 t2 g3 O" z0 h
3. ACPI block: implement ACPI H/W part7 M: u2 H: C( h% g8 q" I0 N
4. USB, _: n4 Y: \5 M9 u% I$ o3 W, y
5. Audio
. f* ?4 a/ A* I+ x6 M0 i; N$ G6. SATA(AHCI)* n! n$ Q- q2 [6 L
7. ...: o3 Q" _( P" [! E
5 x8 q: @) \4 Q8 F5 ^所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
' C/ }" K8 e& k1 i; D* G
! m/ C) Z0 O' _9 R6 w-[BIOS ROM]& X! u' L$ e0 f3 F
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code8 D' a# a6 U* W% H
2 [/ x8 z# z( I; W所以,總結來說: 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裡...)
2 C4 U( v# z) k! Q
4 K5 Q- l6 H6 }" g+ K0 s以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.; Y+ [; c1 Q+ D! {* q
2 m% }, A+ I8 C" l' W! b2 P5 C" Q
Summary:
. x2 P! G! j. r" ?/ d1. BIOS可以說是 chipset's driver !!!8 T+ x5 A; W: m. _, M( x
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的 |
|