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

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

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

2 W/ Y- @4 B' u( l- o+ L1 f. F7 nBIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)  N/ h. T5 k9 |0 a

0 g  O8 \+ ~3 b( {& V- [CPU]: d' J8 u& |- @  L" M& o  s3 L4 Q8 g
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.3 y  U, v. X! ?( p8 a

" S5 h$ e# T/ R3 `9 ]' C- [North bridge]3 z7 f4 j* f2 z
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)8 k/ M! z: M4 J1 P- M# b' l
1. Host interface: 即 與 CPU interface 的部分.
2 J% u+ b) p) B" x2. DRAM interface: 即與 DRAM interface的部分
  Q$ j) v, F" Y& `; I( \3. Display interface: 即與 AGP/PCIe VGA interface的部分
" z8 p4 ?) j# Z3 Y1 B8 |; I$ `- ^4. Link interface: 即與 South bridge(南橋) interface的部分( R0 A4 K0 ~* o9 T. o, ^0 z. R
$ z; V* M- Q( D7 W( J  ]
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )! {& }+ B/ Q, v3 `7 P6 P" ]5 z

2 G( A2 T" h* H4 p所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.& x2 d4 T4 s. R* h
4 S* a. R" k/ S  ?
-[South bridge]3 z/ y+ a" f/ P# _$ k
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:$ H; D; m$ V" E+ C: {4 |
1. Link interface: 即呼應北橋的部分.
5 _! `1 G% K; ~4 X2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)  W6 a8 m  N+ u; Y
3. ACPI block: implement ACPI H/W part
8 P0 o5 j2 a5 G" e8 x1 L4. USB
# k+ A# @; k5 m3 K5. Audio9 D. z) u) I1 ]: }. X5 Y; r5 r9 n' z
6. SATA(AHCI), p" S9 z, X: M& g- f8 J2 ?
7. ...5 d" K9 P' j. W7 j- [# O

; X3 P- F$ y' E9 }; ^$ u) {所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等0 l5 S' `9 K+ g) a# a! U

7 V9 k" i) z* b5 k! T( k: o-[BIOS ROM]
7 N' x0 i' }+ }=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
/ I: H- P; E% j% L9 H. D$ e# @5 }  U
所以,總結來說: 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裡...)' o+ t4 ?/ Y8 m. ~. w

4 r5 g& H7 Y* `以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
7 f; B$ N) h4 b2 V! L4 ~: J' H+ a8 \4 y; k
Summary:
- [" S6 k6 `" Q* a0 \8 l, g8 \8 X) i1. BIOS可以說是 chipset's driver !!!
+ G# L( |0 O1 l* p9 y1 ~2 ~2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 18:16 , Processed in 0.075681 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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