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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)3 K: A# y: C$ d  e. t

+ W. Z* I+ t9 X' ^" |3 w6 G2 [BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)- w8 F+ c5 c7 H( S; C! i
& ~$ `# A+ u0 T* L1 W
- [CPU]! u0 v; g- L( O5 l$ H1 }+ p2 h7 }) T
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
8 `4 ~+ q) ^; g) u
5 f1 C9 z: H) d5 |: f: q- [North bridge]7 e- S$ `! [5 K+ Z7 `6 j
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
( U6 y! k3 e2 v1. Host interface: 即 與 CPU interface 的部分. - X, z6 G! t- D9 g
2. DRAM interface: 即與 DRAM interface的部分
# |4 [: s& R0 I4 k- i4 A5 h3. Display interface: 即與 AGP/PCIe VGA interface的部分
0 j1 Q, ]8 p1 q7 ~$ @4. Link interface: 即與 South bridge(南橋) interface的部分! S$ h0 {; m/ c* u7 A6 D

( a5 }. L+ L  ?: Z8 t  L9 r& G簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )+ j2 i0 q9 j% I* J* p- |6 K: D
' w% ^, g- N: G2 |
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.( ?& _/ I9 F$ x8 n. @* F
' ?3 D9 c- s  \- P- y; G; b
-[South bridge]
$ V: Y4 N, @) I; g=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
2 Y# G& `+ H" l' h5 C* d  c* I1. Link interface: 即呼應北橋的部分.; w) ^+ x* G  }0 c1 U
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)' q" p1 ]$ l; I( C7 X: U/ s3 F
3. ACPI block: implement ACPI H/W part
- e/ H( t  m, p2 N! e4. USB
- B  [, a7 @  F/ g$ z5. Audio+ u% K6 J4 R  z, i2 w1 Q
6. SATA(AHCI)9 n' K: f" k7 a4 ]. r" R
7. ..., `1 x( J( T' ~! K) R1 W
6 d8 c# C, S; M$ z
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
) q, ~& [* A" v- Z3 w4 B  E8 U0 Y9 p7 f
-[BIOS ROM]# I7 R! k/ d9 U; Z6 Z! W
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code/ D! O' [' \2 [* T

( o1 V" u7 A( k  |2 V所以,總結來說: 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裡...)
+ o0 k/ l; b- k7 S+ x! \3 d/ m0 {9 u4 J: v
以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
+ D$ C! ^9 U' e3 Z0 j6 ]% T( F$ Q8 H8 J
Summary:
4 U. k7 p2 ^( r: H& N: D1. BIOS可以說是 chipset's driver !!!, i) J/ h9 D* _: j- P
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-12 00:50 , Processed in 0.303000 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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