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

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

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

" \( E2 Z9 J) g! b/ x: jBIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
  W( A& h* a8 t  V9 _& n2 `
# O% f- p0 m! m' x# l- [CPU]
! A' D. W6 O. c% D. _" N=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.# b& y) x8 ^. ~6 G. {

; q4 b9 u# N+ S. a9 |1 g+ B" @2 ?, ~: d- [North bridge]4 b$ s1 F4 g' ~0 }& W
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)) m5 L$ L+ b1 H7 J
1. Host interface: 即 與 CPU interface 的部分. % Y2 h7 T* z3 k8 m( m; t8 h
2. DRAM interface: 即與 DRAM interface的部分
5 N3 D7 ~: X+ F- d1 U& q! I6 G3. Display interface: 即與 AGP/PCIe VGA interface的部分
- \8 c: R( {4 O2 ?4. Link interface: 即與 South bridge(南橋) interface的部分
  T6 y7 c1 v1 m; D
/ `) V  u3 {: i$ v2 W# z5 T簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )7 ]9 @+ V  t8 r7 K) [. i" ~$ i+ x, A

+ h4 ?) @4 r! P; o) ]所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
8 D- `& O; E+ n, ^6 U, Z' m# a3 _2 b9 _9 I  r1 o1 D
-[South bridge]- V; S8 G2 a* u9 v8 P
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:5 ^; E- H/ H$ A$ C" p; P
1. Link interface: 即呼應北橋的部分.& a* G+ I1 [$ B& M& ]
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)  @9 w0 P) @2 O( J9 b: a
3. ACPI block: implement ACPI H/W part9 Y) _7 O! \* e! S% \( Y
4. USB
/ K$ d8 C$ p  K. m( x1 M5 B5. Audio
! U' I9 ^: m, m) b+ {6. SATA(AHCI)& K" Y9 Y4 e4 Q) Q: v' b
7. ...
2 x; E: H4 X9 T$ x! R
( S1 m& i& p  I+ ?; k* S) m" U% X4 c所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等1 ?8 T: T, j/ O4 b. `2 |2 L! s

4 b' C4 U" c- A: Y1 f2 R6 B-[BIOS ROM]
& k  O/ _* {" d# ^4 U=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code! g% k/ C* ^( B: |* l1 ]

" u8 V1 {5 y" a" `0 T  I2 D+ M所以,總結來說: 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裡...)( H& ?7 R5 }/ g) I. h4 E2 o

$ L' I2 J7 h! k  t  x3 f. H# e% U以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
5 C% T- [* B3 ^& i8 f( z+ G- i* J3 r! T( M
Summary:5 r% X, H* n! R8 v9 w6 q  F5 g" Z
1. BIOS可以說是 chipset's driver !!!3 U% ~( H( s& B! O4 I7 Q! \: ?+ L
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-5 00:30 , Processed in 0.024399 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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