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

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

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

3 Y- [% N$ @6 Q) M, uBIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
; {% B$ z2 e# E, a% R; \" k) h4 t4 j$ A. A1 H
- [CPU]" y2 C2 c) _5 O/ @$ W
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result., p8 S! ~- b  B& u! f3 @- W' w  d

  V$ I# v5 a2 ^' w9 w- [North bridge]4 o: F1 F+ b5 j
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)  [* w2 P  u) T9 H- J, |
1. Host interface: 即 與 CPU interface 的部分. 8 u' W* q: L  T. K, G' Y' Y0 Z
2. DRAM interface: 即與 DRAM interface的部分
1 R3 q) y( q/ o) v0 S$ ^- V  U3. Display interface: 即與 AGP/PCIe VGA interface的部分3 r% t+ \& x" H
4. Link interface: 即與 South bridge(南橋) interface的部分
& \. ~  o8 D1 @$ B- [5 X8 M+ P& s5 ]2 M* D& W. m4 X
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
5 Y( ?- v# q8 C  D/ R1 ?$ z
0 y% ~. v5 q) i- n; `所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞./ T  e. n1 H3 x7 [" \" f  r

0 V1 K1 ^: E; U$ m-[South bridge]
) p# K. o0 q+ J# B=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:" d8 k% p- i) x2 g
1. Link interface: 即呼應北橋的部分.# M/ d0 n0 y5 ~% ^! I1 ~! z, e
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)8 Y$ S4 }' {7 q4 @1 _& L
3. ACPI block: implement ACPI H/W part1 O# I( j2 E1 b* d+ E
4. USB
' Q4 C, x( ^) }& E' k5. Audio
7 [& g$ a' F+ ^9 G. `( t1 s2 K6. SATA(AHCI)
3 ]/ |' k; E' c7. ...( O9 I2 s- o* Z4 H" a' j0 i4 Y
- T$ @8 d+ P$ o* m) F$ U! J5 W( }
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
, M1 t/ S6 l0 f  V# n
; ^+ T2 w3 {0 a9 ^) n, ?) S-[BIOS ROM]
+ T0 N, R; [* G=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
+ k6 j( ~( N( k, j
) R3 c! z% P$ _, A* 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裡...)
/ O, B; I' K) o2 ~$ ~
7 R. _& ]4 R$ a2 W# c7 z* K$ c以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
1 j  g4 ?- E* ]0 i* ]- d8 @% G. Q5 c5 ]1 R& ]0 B
Summary:
3 {& ~5 k- S4 r1. BIOS可以說是 chipset's driver !!!3 D9 W- @/ d; b8 b* J5 \
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-4 14:42 , Processed in 0.090666 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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