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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
5 N* F8 t! H0 r: M1 h3 `
" {- F! G+ D: E" {1 O6 @BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)4 Y$ ~; q' P6 t: U$ I

1 r4 e2 F( q* j" J6 d/ V, u- L/ z- [CPU]
: i3 I7 R& q$ e+ R- k5 l=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.% }$ u1 K! Z! a9 }  O
* {! j1 ^' {; f9 v8 p1 v" c' x. o2 T
- [North bridge]
# l* Y/ C' ~  X* z+ p=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
3 V. z9 L* o5 I  [5 H6 G1. Host interface: 即 與 CPU interface 的部分. 2 `  t$ U2 j) h7 W# x6 |
2. DRAM interface: 即與 DRAM interface的部分3 ^5 }8 h* Y9 j9 t" f9 C5 g
3. Display interface: 即與 AGP/PCIe VGA interface的部分3 I% x; n; n' M
4. Link interface: 即與 South bridge(南橋) interface的部分9 \* M& J/ ?5 W0 z6 I& J, x

6 A# E6 U/ B' j6 h) `# D簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
# i6 u, O, Y+ h1 p9 q3 N8 d  }
- q1 D* u6 {# X# q所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
# W& H' d7 S' B- G$ _' H4 X! M$ ~: A4 U
-[South bridge]
  u3 G% ~' X8 G% i8 G=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
& `% A( Z# s* L/ c1. Link interface: 即呼應北橋的部分.
) ?# M3 u/ o  W; E# ^6 L7 C9 j2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)
: }* Q$ _6 {. M( }0 K9 p. X3. ACPI block: implement ACPI H/W part
! b% P5 K+ F& K3 U2 I* c4. USB5 v' N& K% Y9 L
5. Audio. n6 }! k# s: m6 {8 @5 j& A7 Q* d
6. SATA(AHCI)2 X' `  m8 g' }# c. l! P) S
7. ...$ |, r6 k( m( a5 u; c9 ]
& Y! t+ z" J7 Q1 ?: r' W6 s
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
5 H! G" f! ~- }: h( e) X7 N; U6 `, X* Y) b9 u# N8 u
-[BIOS ROM]1 U) |7 b2 p4 t* q7 N' S1 t; V
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code1 B0 j0 |' B( I" w. S. y& J

5 F& i1 [8 L% \所以,總結來說: 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裡...)! u6 Y" n: ~7 l

! ^0 N# H! h4 F- x以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.0 [( `, X" |8 {/ S3 W

0 t, |) T+ j, A$ K& iSummary:
% n" _7 ^( ~! \( U0 Y' b1. BIOS可以說是 chipset's driver !!!
$ [# {' [: I" e9 b0 t7 z' Q2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 07:13 , Processed in 0.073057 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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