[我所知道的BIOS]->[系統架構] 2
2016-11-02 19:56
453 查看
出自: http://biosengineer.blogspot.com/2007/09/bios_26.html
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
- [CPU]
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
- [North bridge]
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
1. Host interface: 即 與 CPU interface 的部分.
2. DRAM interface: 即與 DRAM interface的部分
3. Display interface: 即與 AGP/PCIe VGA interface的部分
4. Link interface: 即與 South bridge(南橋) interface的部分
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
-[South bridge]
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
1. Link interface: 即呼應北橋的部分.
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)
3. ACPI block: implement ACPI H/W part
4. USB
5. Audio
6. SATA(AHCI)
7. ...
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
-[BIOS ROM]
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
所以,總結來說: 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裡...)
以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
Summary:
1. BIOS可以說是 chipset's driver !!!
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的 (北桥的是dram和display)
張貼者: Harrison Hsieh
![](http://img1.blogblog.com/img/icon18_email.gif)
標籤: BIOS相關
![](http://img1.blogblog.com/img/blank.gif)
shit man 提到...
dear master:
some SB signal connected to CPU directly,does it has need to decode by NB then forward to SB?
thanks.
七月 31, 2008 2:27 上午
![](http://img2.blogblog.com/img/b16-rounded.gif)
Harrison Hsieh 提到...
硬體線路直接拉到CPU的那種就不需要,例如INIT#
會轉送是因為Intel 架構問題,他們EDS內就開宗明義的說了,晶片內是一個邏輯的PCI Bus 0 , 北橋跟南僑間有個DMI通道
然後相關的說明就在EDS內提到了...
八月 02, 2008 8:39 下午
![](http://img1.blogblog.com/img/blank.gif)
匿名 提到...
How do I get the EDS?
十一月 17, 2008 7:39 下午
![](http://img2.blogblog.com/img/b16-rounded.gif)
Tokico 提到...
EDS 是 機密文件
除非你在業界工作
否則是不能取得的
還有一些像 BIOS Writing Guide 也是
十月 08, 2010 9:49 上午
任何 firmware 都有相對應的硬體;也唯有深入瞭解硬體,才能寫出好的 firmware ! (當然,對 programming language 很熟,有技巧的的人可以寫出好的 firmware,但是,另一個層面是:對硬體很瞭解,所以所寫的firmware 與 H/W 搭配良好,這也是另一種值得追求的地步)
BIOS 就是 "主機板的 F/W". 所以,它的對象就是主機板上的所有 devices. (為了後續的解說,我只列出一些,其他的坊間書上都可找到)
- [CPU]
=> central process unit. 依架構不同有分 Intel or AMD cpu. 其工作之一是: fetch code->decode it->fetch operands->calculate->store result.
- [North bridge]
=> 即俗稱的北橋. 常見的 Intel 945/P/G,965 等是其北橋晶片代號. 它可以約略區分成四個 blocks(H/W view)
1. Host interface: 即 與 CPU interface 的部分.
2. DRAM interface: 即與 DRAM interface的部分
3. Display interface: 即與 AGP/PCIe VGA interface的部分
4. Link interface: 即與 South bridge(南橋) interface的部分
簡單說,North bridge的功能是: Host block 承接 CPU 所 issue 的 cycle, 辨認(identify),並且將之 forward至 "正確的接收者" ( Ex. DRAM block, display block, or Link block )
所以,它像交通警察一樣,接收中央的命令,將來自四面八方的車流引導至正確的地方,讓整個城市的各部分各角落可以相互交流無虞.
-[South bridge]
=> 及俗稱的南橋. 常見的 Intel ICH7/8為其南橋晶片代號. 它"可能"包含以下的 blocks:
1. Link interface: 即呼應北橋的部分.
2. PCI block: 處理 PCI request部分(即 implement PCI spec H/W part)
3. ACPI block: implement ACPI H/W part
4. USB
5. Audio
6. SATA(AHCI)
7. ...
所以, 南橋裡面包含許多我們常見的名詞, USB/1394/SATA/HDA/TPM/PCIE...等
-[BIOS ROM]
=> 儲存 BIOS image的device. 常見的有 ISA ROM/LPC ROM/SPI ROM. 編譯出來的 BIOS binary file透過燒錄器或是 flash tool 燒錄到此 ROM中. 內容是0101...的 binary code
所以,總結來說: 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裡...)
以上依序所講到的 CPU->NB->SB->ROM,將在後面的敘述中用來說明一些觀念及flow.
Summary:
1. BIOS可以說是 chipset's driver !!!
2. CPU所 issue 的 cycle會先抵達NB,由NB判定是給誰的;若不是 for DRAM or display,則會再轉發給SB,由它判定是要給誰的 (北桥的是dram和display)
張貼者: Harrison Hsieh
![](http://img1.blogblog.com/img/icon18_email.gif)
標籤: BIOS相關
4 意見:
![](http://img1.blogblog.com/img/blank.gif)
shit man 提到...
dear master:
some SB signal connected to CPU directly,does it has need to decode by NB then forward to SB?
thanks.
七月 31, 2008 2:27 上午
![](http://img2.blogblog.com/img/b16-rounded.gif)
Harrison Hsieh 提到...
硬體線路直接拉到CPU的那種就不需要,例如INIT#
會轉送是因為Intel 架構問題,他們EDS內就開宗明義的說了,晶片內是一個邏輯的PCI Bus 0 , 北橋跟南僑間有個DMI通道
然後相關的說明就在EDS內提到了...
八月 02, 2008 8:39 下午
![](http://img1.blogblog.com/img/blank.gif)
匿名 提到...
How do I get the EDS?
十一月 17, 2008 7:39 下午
![](http://img2.blogblog.com/img/b16-rounded.gif)
Tokico 提到...
EDS 是 機密文件
除非你在業界工作
否則是不能取得的
還有一些像 BIOS Writing Guide 也是
十月 08, 2010 9:49 上午
相关文章推荐
- [我所知道的BIOS]->[系統架構] 2
- [我知道的BIOS]->[系統資源] 6
- [我知道的BIOS]->[系統資源] 6
- [我所知道的BIOS]->[Shadowing] 8
- [我所知道的BIOS]->[PCI SCAN] 9
- [我所知道的BIOS]->[PCI SCAN]
- 【我所認知的BIOS】—>计算机中断系統(2)
- [我所知道的BIOS]->[VGA init] 10
- [我所知道的BIOS]->[PowerOn Sequence & BIOS Entry] 3
- [我所知道的BIOS]->[PowerOn Sequence & BIOS Entry] 3
- [我所知道的BIOS]->[Jumpless] 4
- [我所知道的BIOS]->[Remaining POST Tasks] 11
- [我所知道的BIOS]->[Jumpless] 4
- [我所知道的BIOS]->[Chipset Config] 5
- [我所知道的BIOS]->[Chipset Config] 5
- [我所知道的BIOS]->[DRAM Sizing] (1) 7
- [我所知道的BIOS]->[DRAM Sizing] (1) 7
- [我所知道的BIOS]->[Shadowing] 8
- [我所知道的BIOS]->[PCI SCAN] 9
- [我所知道的BIOS]->[VGA init] 10