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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
$ X; m% V. T! T" f; B) S, ?+ y- L; \& v4 Z, ?
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)5 w% x' N$ L0 n9 n  B0 T2 y
) y$ h# P; O1 H( E8 ]
- [CPU]: @- T/ y% A7 M
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
6 L* y( u% X0 |! A
3 N( C5 y: I' [! Z0 I- [North bridge]
' ]; e; |2 s% n& X' y=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
9 c. e# ~1 [9 N1. Host interface: 即 與 CPU interface 的部分.
; L$ T3 f0 `! a7 Q' L! h% R7 g  U2. DRAM interface: 即與 DRAM interface的部分$ {: t1 w& B6 K& V4 {+ _9 C
3. Display interface: 即與 AGP/PCIe VGA interface的部分5 E7 d7 b. Y' a) M5 x
4. Link interface: 即與 South bridge(南橋) interface的部分
) b! D) r7 _; c
4 X& d1 N8 ?3 \; U9 |簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
" A% Y7 n: R0 ^' c! [% {4 G. x. q3 b' `. ?
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.+ @' V2 m* }4 J; J8 V/ W" _# {

4 i0 ~1 O' r- K( [/ R) S-[South bridge]: V6 P4 M/ Q5 n4 K, F
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:) ?+ L0 O/ e0 N6 I9 k3 M) G$ q$ s
1. Link interface: 即呼應北橋的部分.
& U$ L9 P; D+ ^+ z& u. v) D% L6 b5 v* B2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)
3 d$ u3 c) \) U2 O  h3. ACPI block: implement ACPI H/W part: h+ W) ]1 O/ V4 u
4. USB( s2 X: P3 R% ^3 P
5. Audio
( J- p. z7 x+ I6. SATA(AHCI)
7 I# d3 o1 g+ j, J; ?5 A9 g# [7. ...8 z& t$ s# U) c' y( S1 G

8 z' Q0 n% h- B: q所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等4 N/ G9 G4 k6 ^  p" H7 v* a* P
; D9 v7 C9 L4 m: Y1 q4 H
-[BIOS ROM]
/ \- L6 ]* S6 Q9 j# ?, X! d=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code7 k  ?: L- o. w4 c: l5 r# c: p

  x  W2 f- b$ Q' s: b+ g所以,總結來說: 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裡...)2 m0 g( q4 J" I5 k# E
  E% e2 F8 D$ [
以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
; j) C4 K/ M) m% V& O( a6 M- l" M4 S: U$ Z
Summary:
  m' E  N& U9 X! m1. BIOS可以說是 chipset's driver !!!0 s$ [1 @7 @+ u6 |8 g
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-1 00:19 , Processed in 0.212485 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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