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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
' w& Y8 Y, S1 F2 h0 w- T' O1 Q; z+ h) f0 A8 H
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)0 k; v2 K) r: U7 P- k

* p0 w0 o, l- s/ f# a- [CPU]
) F, J- \# I( g; y* y% j) ]- @=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
( [! j0 a! r8 ^3 x
3 k4 ?) t  s- R5 B2 _! r. |/ t6 D- [North bridge], f, [3 X4 e5 |* v
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)$ X  D0 D6 T* a! \" H9 ]' o: O/ s
1. Host interface: 即 與 CPU interface 的部分.
3 p- T8 ?8 I% |4 e0 E2. DRAM interface: 即與 DRAM interface的部分
5 P1 \* E2 f2 N2 X) D3. Display interface: 即與 AGP/PCIe VGA interface的部分' _6 g% A5 v) x
4. Link interface: 即與 South bridge(南橋) interface的部分1 e* s. {6 C3 i5 v% T( `) J5 w
$ E# Q/ }, m; f# N/ O) \
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )" ~$ |# d* e7 I: R+ W8 B0 y
" G3 J! Z, f* L
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.1 m" t* n% c8 d- F
: X- W  C: K* q
-[South bridge]3 Z6 G5 v! }6 s; r7 m: J/ y6 X
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
  G+ `# u0 X' i8 R( \1. Link interface: 即呼應北橋的部分.5 i( d0 K# S- K5 G" O' c
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)6 ]( j! [3 G/ y$ ?
3. ACPI block: implement ACPI H/W part$ j1 V: j; ]" A- O, V) m4 O
4. USB6 H5 n- J0 P9 X- `( k" o( \8 W
5. Audio6 [3 P+ R7 J, \- o
6. SATA(AHCI)
. L2 G+ l+ Y6 h1 t6 h. p% J7. ...
/ s* S% `; M* r
( |/ H5 P8 M/ r6 m3 W所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
+ J* U, B7 f. B
  c: C( z- d, g( f7 n: L) L-[BIOS ROM]& Q8 G0 g( D0 i9 h* @
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code3 P( r9 w. t8 T

0 A2 m* A# _* \0 L" }) F所以,總結來說: 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裡...)
. b4 n3 S  T$ _* q3 X# i+ s" h" s# s; n0 ~4 C! [) `0 ^
以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
! S2 z/ A) h  A  ^$ W& q3 e+ N6 p7 t9 @9 D$ x  E
Summary:% A$ N* e7 [" `1 x7 o  J
1. BIOS可以說是 chipset's driver !!!
& q. i) j' L% k. v# k2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-19 21:53 , Processed in 0.074018 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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