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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
9 g. [* C1 W& q, T) Z' t
4 R2 L( Z' L+ @: \* h6 k4 d' A. N: [, HBIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到): j$ l1 n" d6 i  k7 H
( N( m6 z; g) P8 u5 V0 K6 }7 Y6 D
- [CPU]
" n! L, o- R5 \: j7 S=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
6 i0 o% M8 ]( B5 V/ _. c" r- Y- w4 a& v$ H1 W
- [North bridge]. ?  B! T5 E& A
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)9 \/ C5 k4 [3 g" Q! H' E9 c
1. Host interface: 即 與 CPU interface 的部分. # I' g6 u* k. g8 n" A% [  {8 n
2. DRAM interface: 即與 DRAM interface的部分
; ]: {9 B. |( n' D( w6 {2 n, p3. Display interface: 即與 AGP/PCIe VGA interface的部分+ ?0 c/ n4 `2 T, L# `
4. Link interface: 即與 South bridge(南橋) interface的部分
2 h. N# J% d; u+ H
# n' v# c/ r# P簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
7 E2 O) K( |# d7 R
2 }. m  B. m7 Y' @3 z所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
2 P2 K# h+ {) s7 N
5 B$ ?" W, U6 E, o6 e-[South bridge]8 _6 n0 u. w$ N6 t" i, |
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
& R9 v6 k  `  }1 X/ Y5 Y3 f6 X1. Link interface: 即呼應北橋的部分.
3 l9 k; Y/ A5 l, Q3 h/ X) I9 \  |2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)
* q9 D) ?" h9 F3 S& b$ f% q# w  f8 Q3. ACPI block: implement ACPI H/W part
* n0 k9 S4 t2 G7 ?* S* M$ X! S4. USB9 s. H, [; B  U* `
5. Audio9 Y9 R) L& O! `3 D* L- P
6. SATA(AHCI)
8 R0 t7 ]  Y  r) ?! Z7. ...
: z5 z1 e# T& Z9 Y, ], [. w9 v# n2 Q
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等0 ~. E% K7 t2 v% L$ H& r

" u# U3 Z" ]$ g6 ^8 |2 I-[BIOS ROM]7 B0 V7 p. I5 z* O
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
( F- u; p9 u& t' F2 O* ^$ q. Z7 i! I4 S$ H0 R
所以,總結來說: 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裡...)
$ R# j) W6 e* m6 e3 \; F7 T) b1 O
0 E4 V; I2 Y, }* w- I" L以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.+ N- @! I+ k" |9 ~# a
$ |" e+ b! ^) C+ l4 d: D# d
Summary:
6 U1 o) L5 x! R6 f' ]& I6 U1. BIOS可以說是 chipset's driver !!!9 n7 y3 A; W" l% P2 L( b
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-6-8 08:09 , Processed in 0.299963 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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