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

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

[复制链接]
发表于 2010-7-1 12:02:25 | 显示全部楼层 |阅读模式
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
/ V4 X7 x, g2 s
3 d8 ]2 m; R8 g) d+ A# j: YBIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
0 l* w0 k- G; \- m9 M0 {0 I, F& B
. i, o+ y1 H+ F0 F- [CPU]
& L4 `' F9 N# f=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.. O# L& ?# _+ t6 \3 ]

* o) }7 h! K( W5 d- [North bridge]  q3 y9 j' W3 f' g" [# h
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
9 |- W9 n: i3 Z; }! ~1. Host interface: 即 與 CPU interface 的部分. : G9 i! L- v4 C
2. DRAM interface: 即與 DRAM interface的部分
0 f3 f8 O: ^9 y$ t3. Display interface: 即與 AGP/PCIe VGA interface的部分/ j+ W& y5 E1 u* f9 ]4 a
4. Link interface: 即與 South bridge(南橋) interface的部分, N- T; M) i) T" Z8 H( \
* x0 {1 o" G; _& E6 W7 K
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )5 C  p! F) t; A, _
4 f- m% H1 w% ]# {2 L
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
$ W9 R2 ^2 |2 X) M& x' C2 U$ C2 g' G& c* y
-[South bridge]
5 M7 `- H- M3 q8 Z=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
$ w1 y$ ~% w" N# ~& m1. Link interface: 即呼應北橋的部分.) `! h: E2 I0 s: P8 W
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part): }8 c! l! w( R! b4 x- m& M
3. ACPI block: implement ACPI H/W part
- v3 g2 y& v( N. J/ @4. USB/ J: F6 M3 C8 }' v4 F3 s( ~5 c
5. Audio: \1 q2 A' f, B; N8 ~# t8 J
6. SATA(AHCI)
0 O9 `5 A* j' B7. ...
2 X  l! [: Y2 ^5 @, j, ?* b
. w- f6 f5 A' X所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
" k, B7 w% t2 G" M
4 {: Y+ ?2 w* m- i) ~/ `. v6 n-[BIOS ROM]* k1 z. y$ {1 t# `2 V' C. w! `
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
8 z4 b1 m' e: ]- V/ Z
* l* y  Z9 Z! }. H7 {7 k6 f所以,總結來說: 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裡...): [: s7 n# @, y

0 `: x  X3 r3 U以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.' }5 ^  p6 I/ _6 p/ D, L
, h; H4 `$ f: }/ s; S
Summary:4 a' u" u6 Z4 F6 v6 x+ L9 k( P4 c
1. BIOS可以說是 chipset's driver !!!
0 Y" l9 M4 k( l& H) h. B  d; D2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的
发表于 2011-10-14 07:42:23 | 显示全部楼层
感谢楼主分享!
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-16 09:10 , Processed in 0.023270 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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