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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步); G7 @$ c. M% o  W) k  ~
, C1 K) r* T7 T2 Z+ w
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)4 d! @/ X6 S  B9 O, }) t
+ F1 q$ C0 r" m3 H1 H0 j5 B
- [CPU]
3 ~  y2 ~# A, X# ]8 k=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
5 P' B0 w2 ~/ I7 |
. M1 v1 Y( K- n6 m  t0 T) O2 r- [North bridge], l5 W5 x8 Y; Z& |; ~" x
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view); i9 N' K9 {# B* T( ^
1. Host interface: 即 與 CPU interface 的部分.
# B; T# B, A( x9 D4 P) Y* S  [0 `2. DRAM interface: 即與 DRAM interface的部分
8 k* S/ r& }& U2 ^" P3. Display interface: 即與 AGP/PCIe VGA interface的部分) q3 P9 Z. d- R0 F+ d
4. Link interface: 即與 South bridge(南橋) interface的部分# u4 S. M  v' L& w' x1 C1 m8 L1 r

+ X9 C9 x6 [. {& S$ W/ n簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )9 m) Z! L% f1 k
6 f- q1 A5 }0 i" r/ v5 j1 G
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
# `4 O  C  j: K5 q4 A: D8 j7 I. d/ F
-[South bridge]
9 R( {2 f; Q* ?. [* ^=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:" E2 |+ x5 m& c, b
1. Link interface: 即呼應北橋的部分.1 U% w7 q& E- v
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part). D; H8 W2 ^7 H; p7 B
3. ACPI block: implement ACPI H/W part! V( n! F3 v9 b. A" c
4. USB* p1 w4 k2 x: T
5. Audio' h6 h$ ?( T+ f8 n
6. SATA(AHCI)( E8 j# k6 D' J% e0 U6 i7 O! [
7. ...
. n! H( u0 l+ Y" U$ q7 N# {! k
3 m* a" m) p- y, M  L+ Y* d所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等0 ~1 B% v4 y7 T( h- u1 I, C

7 J- q: H' ?' R3 B) i-[BIOS ROM]# s9 Q) k8 ]" s4 U
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
6 w& Z" G% t# E# z% i
4 S7 F6 o4 @" y, F0 f1 g所以,總結來說: 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裡...)( S, x. A7 ^) d6 T3 p

) d( x6 [7 O$ O, f0 ?# A以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
+ l# Z9 K% `* z
8 `3 Q* b6 R; `7 H6 r: cSummary:. U- l! Z) `8 O+ p8 Z% i7 b' K
1. BIOS可以說是 chipset's driver !!!- v0 S/ c/ N) X
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-21 07:59 , Processed in 0.062975 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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