|
|
我所知道的BIOS->[PowerOn Sequence & BIOS Entry] 3
3 F' ~8 E# Y z) q/ |在此將以DeskTop platform來說明(Notebook platform 的 power-on sequence 牽涉到 EC,可參考討論區中 "power on sequence" 文章);還有,所敘為rough flow,詳細的時序圖依據design會有些許不同.! l" B) {" d9 Y" |
6 c' v2 R x0 p ? g L[Power-On sequence]% l/ t0 H1 G' J6 c5 @9 ^, ~2 o
) A3 W, U3 R) l3 a- AUX power ok
8 L# @, T# Z, {9 g7 q. L1 A! f' B# B- Main power ok
9 y( o; w1 F" a- PCI reset
& |' U8 S) A% z- SB state-machine runs...
; B) ]* I0 d( X0 n- NB state-machine runs...# o* D# }) f2 H N$ z0 B
- CPU power-Good ok5 ?7 ]' z: L# }2 s
- CPU reset
, n& |! C2 L% j; i! T- P- 1st code-read by CPU ( <- BIOS entry point,即 CPU 會抓取 FFFFFFF0h 處的 BIOS code 來執行), o( M+ _9 [$ e3 z7 q; l
: v: P) ^! Z" c' ?, o+ y" l, C9 f
* 當然CPU一次抓取的BIOS data不僅僅是幾個Byte ! 而是一堆的data(Ex. 64 bytes);之後會從中 extract 出 FFFFFFF0h處的 data,然後來執行.
% E( p% u; q* d& k3 }. H. v$ e$ }2 h8 I3 i+ f4 z: z4 d$ {( ~
補充: 為什麼CPU 發的第一個位置不會只有FFFFFFF0h? 而是多抓很多個? 範例中為什麼是64 bytes? * t. X3 i% t% v& I2 Q, i6 W) o! E
原因在於 cache的支援. cache不是細分為單一byte 的, 而是以block(many bytes)為單位. 這個block的大小的名詞就是 cache line size. 也就是要填入cache一次要寫入的bytes量. 例如 cache line size 為 16 bytes. 那麼一次就要讀16 bytes到cache去.
* s, @! @$ Y8 k% G1 yCPU 一但發生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以後的資料. + r# z4 U+ G( V' o3 J0 p9 V/ }
/ v7 u, X) C$ B1 p; _- B3 p) o3 k自此,CPU便循著 CPU->NB->SB->ROM 的 path,循序地至BIOS ROM中抓code,執行 fetch->decode->calculate->store...自此開始便是BIOS POST stage starts...
/ o; I' ` ~/ K: p6 n" P5 D3 o8 e& \& {3 v& k8 e0 i3 h
& J6 c1 x) c' Q9 o( v
[有可能遇到的問題是] debug code = "00" or "FF" (意即BIOS常用的 Port80 card所顯示出的 "code" ) !!! 4 o- J( ]# m& h9 h+ \
% R! a2 \! k6 f* 此時,強烈建議:請在BIOS entry point 處 丟Port 80(value可自行定義),因為,即使BIOS有跑到,但因為距離 1st 丟 Port80 的 code仍有一小段程式碼;若系統 hang在此其間,Port80仍是沒有 code,因此,在BIOS一開始進來便先 out Port80 將有助於判定: system hang before BIOS entry point or NOT !!! )
% w. E: {& h: M- f6 B7 ?& G9 q+ u+ A# n& Q1 o) L, |) \& v
# Assume system hang 'before' BIOS entry point, 可能的原因有:
3 r B9 q! m' {. y5 K1 o. [! _. h/ U- incorrect power sequence: 此 sequence 有 spec,規範訊號間的相對關係與 assert/deassert的時間,violate spec有可能導致 system hang;此時需要 H/W or board designer來量測) E" C. m$ {' W( _% @6 T
- incorrect power-on frequency:有發生過因為 Power-On CPU frequency錯誤而不開機者.請用 scope量測
- m! F6 b2 |5 H, L- incorrect chipset behavior: 意即上述的 power-on sequence中有關於 NB/SB的 state-machine部分,有可能這部分的行為不正常,因此需要 H/W designer來 clarify8 D/ }" e& D3 G! j: U/ g
. v& `; z6 g8 M$ |7 t
* 曾聽說,某家chipset需要BIOS image 中 include 幾個 bytes 來 config NB/SB的 registers;這些 settings也會影響 power-on時 chipset的 behavior;因此,這幾個 byte 若是錯的,也有可能 system hang( N- e0 `+ R. O# ?9 j9 n, y
% O: A0 o% S8 n* v- a, z9 l
補充:很多chipset都(or 曾經)有這個功能, SiS, NV, VIA, Intel. 以前有個詞叫ROMSIP就是指這玩意兒... 即使在現今的intel platform也有預留這東東.
* |: h m$ J3 o9 q& V# L& r; c0 `. H5 X2 v4 F) y( o
#Assume system hang 'after' BIOS entry point
* S8 ^# s6 } I2 H0 F8 c+ E=> 這就是BIOS engineer的時間了,就 debug吧...(儘管,有些 issue 是 board or H/W造成的...)
/ j- C! B6 S7 w: { k& U. d0 }1 B6 W5 X; p( s$ l9 X6 w% ?
* 此時的 debug方式,若有 輔助工具的(Ex. P debug card) 就用,沒有的就用Port80 card囉 !
. ]" x! b8 H! C! F
# | B! e+ g! R( z3 B: P6 P% g[Summary]: 沒進入到 BIOS entry point前....不要找我....真的沒辦法 >_<# B1 F7 `3 t: [ P0 Q, l8 S
4 q: r% O% j, X, U, }
* 關於 BIOS entry point,請參考 討論區中 "追蹤BIOS code 的進入點" 文章 !!!* s$ ~6 _' Q7 z
% w8 X# @0 g9 m. b
[Power Button開始的動作]
9 ?2 p. O1 R6 M" h" q9 I# I' i6 D( C1 Y: J
一般Power Btn 都是EC 控制(或稱PCU),如果你說要知道Power Btn之後的動作就是問EC 工程師就對啦。
! B2 v; u! F3 g) I2 G, X1 x& m我印象中好像是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...)。8 n& m* I/ e l- S4 A8 X
: ?. s6 Q* x2 c! {# H) J
另外印象中EC BIOS有分成兩種形式,因為EC Controller可能裡面的記體器容量會不足,或是說節省成本故意做成那樣,所以 EC BIOS 會是包在SBIOS或是放在EC Controller裡面兩種格式。
2 x* u0 r$ r) D. | w8 u) f' q/ P A5 V1 j3 Q4 r0 H7 }$ b$ Y, n( H9 R
如果真的要K流程,應該是去看EC Spec跟ICH Spec吧...
: L! M6 y$ @6 n) {1 O
) x7 ^9 L; j- M0 r$ b當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 |
|