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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
8 V, e- S; E' F% }/ `4 c: ?. @& }- w! H' D
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
& w- i, T$ }1 C2 \# A
3 c  m- K8 `" ^- [CPU]" ?4 q% }' n7 b* P$ G& }
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.1 ~3 r2 `3 a0 Q# l1 w! v* j/ \
# W6 D9 W. I- Q* J- M
- [North bridge]" G$ ~4 |0 ^# z' H
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)8 ?: S( Q& I( s6 D$ J. v/ \5 u3 w
1. Host interface: 即 與 CPU interface 的部分. . Q: c2 u% O  b/ ~8 D
2. DRAM interface: 即與 DRAM interface的部分
. O  W) B  V+ M3. Display interface: 即與 AGP/PCIe VGA interface的部分
9 [, c! U; W! t8 d3 m6 ]3 ]# y4. Link interface: 即與 South bridge(南橋) interface的部分
+ Y9 ^3 v" d4 u; ~
* t1 y% z1 G" ]( C簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block ). z4 u' J% c& E+ f9 E$ y- H) S* A% A
6 X, I) T9 i. J/ c1 H
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
8 \0 @# K, t# R  |- A* I* K  N& Y) {" }0 t8 f& f4 K! x+ [  f% g
-[South bridge]; J  f3 l  b9 ]" f: k; j' m4 ?- D
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:2 Z2 N/ @8 @+ L8 T$ D& T
1. Link interface: 即呼應北橋的部分.& W3 h2 W. S- I4 h; f  i
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)
6 M2 U9 V, l0 v2 i3 O( y2 {( a3. ACPI block: implement ACPI H/W part4 P1 ?5 t  X' ]3 E7 x. f# N
4. USB0 C% C& J" |& ~) F- n3 c; T
5. Audio
  f4 R  T' h' T( }; b- I6. SATA(AHCI)
# }) A( j$ [8 h! K& f- x6 d7. ...
* W0 K3 ?2 E7 V- t* h( {
/ D( Q# `( u6 }' w; r" d所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
1 x& z6 o2 W% b1 X5 y& g# k% C# z- J4 a
-[BIOS ROM]5 U; _) b' N$ ]. ]4 {! D( F9 c
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code9 J# d0 F+ w9 y4 ^  ^2 Y, `9 k% D
( N8 j8 u- X9 {- v( ^( t, o' x' 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裡...)
5 I. J4 o" s! z, C* _9 `3 E5 N0 G. P7 H9 u( F- Y
以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
# ~2 z" h. l* G% s7 L# W2 `# P# ~8 a
. }% h2 v9 \% RSummary:2 r2 v  P$ c* W+ Z9 t$ E( I* t( p
1. BIOS可以說是 chipset's driver !!!
( |- T6 m% o4 D2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-4 08:55 , Processed in 0.041766 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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