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

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

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

1 {& e3 C3 o) T. f& W  CBIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
# t  z4 H. O3 D% f+ G- L1 m% T: f5 G7 Z/ Z% J* k% W  K
- [CPU]! \; B8 L1 @+ T7 g
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.0 ?: O0 p0 C. R* b' f1 T2 Z) Q4 ]
! |7 u0 k9 _5 S2 g) B
- [North bridge]. U$ F5 |; u' t( g7 p
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
  B( ~  Z" O( y) d8 E# G1. Host interface: 即 與 CPU interface 的部分.
( U7 I0 J! v' k7 w; ^6 w) _2 X$ l7 {2. DRAM interface: 即與 DRAM interface的部分% F" D5 z% @$ `' P+ o3 V1 y
3. Display interface: 即與 AGP/PCIe VGA interface的部分
# E# d( U8 G, J/ n4. Link interface: 即與 South bridge(南橋) interface的部分
1 `6 @/ O' L% t6 D6 Z+ d$ F! B/ O- E. o; n4 M& E% A; I& R
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
1 v- p% n" L, U1 _3 W& o
4 K3 @$ A7 I' X3 N  n所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
0 y1 I* f$ j1 D+ p* j* k* r6 U! \2 Z( ~6 n7 c# |5 ^7 H) F8 m" t' D
-[South bridge]
( c- `$ v  r" t; w7 v=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
/ m; i) e- o- r6 w) E1. Link interface: 即呼應北橋的部分.
- R( R7 J/ j3 ]5 J) A2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)' g# k3 [5 f9 w
3. ACPI block: implement ACPI H/W part$ q- y3 D+ P& ~* S" F4 ^( H
4. USB4 R6 S9 B" ~0 U! |7 R/ a( r: Q
5. Audio' l) g# t+ N+ X! j" C# G
6. SATA(AHCI)5 }* o$ ~8 H% u$ o0 T! S! s! e
7. ...
1 {+ P. ^) @5 I* n* [3 g( }0 N) K9 [, P& C, ]$ a
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等+ L. _6 ]6 w2 W+ C5 S1 p. D, ]

0 B8 @) D: h, H& b# e-[BIOS ROM]
. y# l/ x5 x  X, b6 D3 b4 ^5 @=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code0 `  e! g3 a5 Z5 i% M4 m

  S# D  A6 _2 _0 \5 W7 E所以,總結來說: 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裡...)
) y7 C  O6 U; n8 h) j
: B' F) z5 h  r3 T& o以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
! m! G# t: n, e- ^. v. v4 L
' W! t$ v) w; A( m+ WSummary:1 `" r( ]* G& ^( a8 x# p) ~5 a7 c3 o
1. BIOS可以說是 chipset's driver !!!: ^# O9 M  J9 s, D" g( W2 u# n) V9 p: {1 [
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-2-1 04:22 , Processed in 0.164019 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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