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

[转载]我所知道的BIOS->[PowerOn Sequence & BIOS Entry] 3

[复制链接]
发表于 2010-7-1 12:01:25 | 显示全部楼层 |阅读模式
我所知道的BIOS->[PowerOn Sequence & BIOS Entry] 3 4 W  P) R! x" R, q; V: k9 }. W
在此將以DeskTop platform來說明(Notebook platform 的 power-on sequence 牽涉到 EC,可參考討論區中 "power on sequence" 文章);還有,所敘為rough flow,詳細的時序圖依據design會有些許不同.* ~& S8 A7 h! ?. D! h$ l  r6 ~2 ]- l! c
% c& q0 K% D, z' i; L
[Power-On sequence]
/ w6 b  u+ l+ h, V
3 V4 f% a' v+ K3 ~- AUX power ok
9 [; B0 }, O  p; i; ?4 U/ S& M- Main power ok
5 |. Q4 z, Y0 S8 w- PCI reset
, g& j2 r% r* A) n+ L! Q( @* Z- SB state-machine runs...
7 i& m, x0 e' ~+ D0 h; C- NB state-machine runs...6 g5 q3 ^/ F- b; _$ P% D
- CPU power-Good ok
2 g5 `$ }$ r: R0 D" J! P+ q6 Y( G" ]" S- CPU reset( K' {- N3 q. R  [4 \) m' x9 _
- 1st code-read by CPU ( <- BIOS entry point,即 CPU 會抓取 FFFFFFF0h 處的 BIOS code 來執行)
, l' _3 Y7 \! ~9 p/ u0 ~* }$ ]4 b$ @3 F! _
* 當然CPU一次抓取的BIOS data不僅僅是幾個Byte ! 而是一堆的data(Ex. 64 bytes);之後會從中 extract 出 FFFFFFF0h處的 data,然後來執行.
! x& H/ ?- }( a  p2 B2 N% g. i# ^
  |$ g+ }0 Q  w/ T& b5 k補充: 為什麼CPU 發的第一個位置不會只有FFFFFFF0h? 而是多抓很多個? 範例中為什麼是64 bytes? 3 L) F1 |+ H% j4 a% K) s
原因在於 cache的支援. cache不是細分為單一byte 的, 而是以block(many bytes)為單位. 這個block的大小的名詞就是 cache line size. 也就是要填入cache一次要寫入的bytes量. 例如 cache line size 為 16 bytes. 那麼一次就要讀16 bytes到cache去.6 M7 x9 T" g3 k8 M
CPU 一但發生cache miss(第一次開機一定是cache miss)的狀況時.就會通過host bus 對外取得資料. 這時就會產生burst read cycle來達成fill cache line的需求. 所以由CPU 的 cache line size的大小就可以知道CPU一次會抓多少的 bytes. P4以後CPU 的cache line size 為 64 bytes, 所以CPU 就會產生一個 burst length 為8 的 memory read cycle. 所以CPU 發出的位置就需往下減.然後在讀取的資料中可以包含到 FFFFFFF0h以後的資料. ! ^" j* G4 H# B0 a

. m' b1 l5 G2 W! v/ }+ Z8 P自此,CPU便循著 CPU->NB->SB->ROM 的 path,循序地至BIOS ROM中抓code,執行 fetch->decode->calculate->store...自此開始便是BIOS POST stage starts...
) ^9 v6 t. V0 t' b2 a) N. y& V- d( ]: N+ ?2 O% B

& @1 m! z/ C/ I[有可能遇到的問題是] debug code = "00" or "FF" (意即BIOS常用的 Port80 card所顯示出的 "code" ) !!! & n' _! |$ v- Z. Y2 \# B- P! h  |
  Q( @- ]+ _# n+ P
* 此時,強烈建議:請在BIOS entry point 處 丟Port 80(value可自行定義),因為,即使BIOS有跑到,但因為距離 1st 丟 Port80 的 code仍有一小段程式碼;若系統 hang在此其間,Port80仍是沒有 code,因此,在BIOS一開始進來便先 out Port80 將有助於判定: system hang before BIOS entry point or NOT !!! )0 V2 m4 y# b( x+ H; z

7 e5 `$ x8 h2 d* }! s; h% S# Assume system hang 'before' BIOS entry point, 可能的原因有:
) O: `6 j7 P4 q' ^- incorrect power sequence: 此 sequence 有 spec,規範訊號間的相對關係與 assert/deassert的時間,violate spec有可能導致 system hang;此時需要 H/W or board designer來量測, ~2 F7 T# v  T( S" ^
- incorrect power-on frequency:有發生過因為 Power-On CPU frequency錯誤而不開機者.請用 scope量測
6 f" U, R* I$ |5 U7 D3 l- incorrect chipset behavior: 意即上述的 power-on sequence中有關於 NB/SB的 state-machine部分,有可能這部分的行為不正常,因此需要 H/W designer來 clarify
6 W& b% I5 M( U3 ?- i9 k, {9 y& ?4 T/ r: X( `) A2 v
* 曾聽說,某家chipset需要BIOS image 中 include 幾個 bytes 來 config NB/SB的 registers;這些 settings也會影響 power-on時 chipset的 behavior;因此,這幾個 byte 若是錯的,也有可能 system hang
# Q- N) J. o4 J, T  s
2 Z5 G- h. q6 N9 X補充:很多chipset都(or 曾經)有這個功能, SiS, NV, VIA, Intel. 以前有個詞叫ROMSIP就是指這玩意兒... 即使在現今的intel platform也有預留這東東.
0 {5 n: g8 g5 _6 V5 O. n0 \+ l5 i% A% n" G* `. i$ a% k& ^
#Assume system hang 'after' BIOS entry point3 Q0 N9 V1 V! e. M0 z( z. V
=> 這就是BIOS engineer的時間了,就 debug吧...(儘管,有些 issue 是 board or H/W造成的...)
' a/ N. y. Y' m* j( W0 B- v8 q
' h3 ]' g/ Z6 {' [  \+ x* 此時的 debug方式,若有 輔助工具的(Ex. P debug card) 就用,沒有的就用Port80 card囉 !
0 D5 P0 ^( v3 H* r/ o$ W7 Y. a5 P+ P) n4 d$ V
[Summary]: 沒進入到 BIOS entry point前....不要找我....真的沒辦法 >_<0 ]$ v! C/ u6 f- e6 X
" i. g) J5 `. A. d) o
* 關於 BIOS entry point,請參考 討論區中 "追蹤BIOS code 的進入點" 文章 !!!
( a  k$ {. F3 a3 {; e8 y* n5 B+ _+ @4 @- m! z; ?5 \' V
[Power Button開始的動作]
* U6 C- @8 P. O8 ]: X9 S! m2 Q# ^' \+ w! W& U
一般Power Btn 都是EC 控制(或稱PCU),如果你說要知道Power Btn之後的動作就是問EC 工程師就對啦。
; Y$ O" B# [4 E我印象中好像是Power btn按下後-->EC 偵測到動作(應該是KBC 發Event給EC BIOS或是EC BIOS自己每隔一段時間去檢查有沒有Event..沒K過EC Spec,純猜測...)-->EC 檢查目前系統狀態(不同時間點按下Power Btn , EC可能會做一些動作,因此要判斷),檢查的時候主要會去檢查南橋ICH接到EC的訊號線,判斷Sx state-->如果是正常開機,則開始供電--->系統上電後,CPU會從起始位址開始讀取BIOS第一條指令(至於CPU何時收到重置訊號可能要看一下其他Spec...)。
* g9 s7 ~. W: H9 C" y, G2 ]% f$ }; s  D$ {# }' [9 b9 m; i/ C9 @
另外印象中EC BIOS有分成兩種形式,因為EC Controller可能裡面的記體器容量會不足,或是說節省成本故意做成那樣,所以 EC BIOS 會是包在SBIOS或是放在EC Controller裡面兩種格式。  {) a7 ]/ S6 X0 S* P" A' J" G8 B

5 B& l1 m: ^; k2 r) N4 ~" g如果真的要K流程,應該是去看EC Spec跟ICH Spec吧...
' R4 r! L/ z( A7 U6 B  A. Z' e& H9 N3 I! Y$ D. J9 e
當EC 收到power event (指power button的動作後...), 會根據目前系統的狀態來決定是否要開某些電源...For example, 當系統處於s3(suspend)的狀態時, 當user按下power button後, EC 會發一個訊號給南橋, 然後EC 會wait for SUSB and SUSC 的訊號assert. 然後開 main power的電(我指的是非suspend的power)...但是詳細的動作應該各家都不太一樣才對. 而且這些spec都是各公司的knowhow
发表于 2010-7-28 11:25:14 | 显示全部楼层
冒昧地问一下,楼主是原作者?
回复

使用道具 举报

发表于 2010-9-11 22:09:03 | 显示全部楼层
这个好像是从小华的部落格上转的。
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-17 14:06 , Processed in 0.075999 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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