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

[转载]我所知道的BIOS -Jumpless 4

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
# D5 T8 n& s2 @
. M  D6 M" `# c6 H# j在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
7 M' w3 y4 e( o1 @3 c$ W5 [, t9 j# @' k4 E3 o$ K  Q9 j4 d' V
有哪些 frequencies由 clockgen 提供?
0 X- _0 D' A: N* n0 {- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)9 m& c0 h6 t4 A; [, L+ k7 O
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
( C+ `6 X: P  X6 o1 L更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.$ ]% r5 ]# K4 d+ W8 ~0 R

# M! r; V; \+ G  ]補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
# A% K$ E; k, `3 q: c$ ^Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz8 r: R; A. h% e8 l5 T/ v+ U+ J7 a

. ?2 t7 n- `( q  ]* ?- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
6 O: H0 `, A5 {# n' e- PCI clock: 33.3MHz5 d# e1 b, T+ _) Z
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)* }( H6 D9 h0 z3 z
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供) y0 Y6 m: W6 A1 ?+ u
- USB 1.1 clock: 12MHz/ z3 y4 s3 q7 M
更正: USB 的 clock 是 48MHz! M& G- M$ u. n6 s, ~' R
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
2 K( w% ?- G! l6 z) u- H( T. ^) i5 y! n
6 A" V; ?- r$ ^* g/ Y( n) x- SIO clock...etc% x7 [9 K& P5 i, F

+ }; u9 g1 y9 f# c0 R2 n1 I/ F- ^- Y) C6 @Clock Generator的架構8 U" ]! s9 h0 w& m/ `/ ^
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:% E. V; `0 }  o' G2 L, N: i" @* D# }) W
! f4 L& m9 _; t* o0 o7 q7 X
14.318MHz -> PLL -> F -> Div -> f
3 }/ |4 B. m' ?- D
' F% @7 J' v! w7 X2 z4 e6 ]: x/ ?; ^- GEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
0 }* h  u5 v2 P. Y6 Y. X- Z( f1 O- Z* W1 {- K
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
& c2 D  p3 \7 A; ]  p: I. W  S! |& J% l9 l4 p  _
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) * A* m' B3 O% {8 |- q$ u: B& u+ E
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:( r) D. [! |, r; B- j3 B
1. 有 2 bytes(即所謂的M,N)來決定 VCO* E: b, k5 p! X; v, C$ a
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
# J0 ?# c$ y+ x+ M2 X) ^" O3. VCO / div = frequency3 Z" E# h4 R8 q$ ~
& ]- t% R5 e6 S9 F- |
How to access ClockGen
+ ]9 P) D" c9 w; m7 Q, b. a=>現今存取 clockgen的方式,都是透過 SMBUS來達成. SMBUS 有分 1.1 and 2.0,不過大同小異. SMBUS是 2-wire protocol;由 SMBUS master(即內建在南橋內部的 SMBUS controller )來下 command 給 SMBUS device(Ex. Clockgen);Command中常用的有 Block Read/Write & Byte Read/Write
( g3 b; A  z; R) q. F- Z" Q8 h7 m; s# \3 Z! A( }- J
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
  O1 M0 M# e1 ~- pre-init( clear status or ...)
4 I. c  z  J* x1 y- put slave address(要 access 的對象) : n: ?+ u: r  Y' O5 j# Z
- decide Read or Write
. V% S, O# W: @* Y- put command(Protocol type, Ex. Block or Byte access)
' I; d# @3 u$ b  l/ |$ U- put offset(要存取 自 clockgen中的哪一個 Byte開始...)7 j1 p; V3 U3 \/ g* u  T) k
- put data if (Write device)0 C8 @( }; ~* S- t! A: Z
- start transaction !!!
$ R2 t, B7 [! B2 _0 S4 C9 ~(... processing ...), F8 b& z0 v# X- `  z0 W
- get "Complete" status to check if transaction is done successfully
) s1 g0 A9 I5 p1 Y: K6 n# i(...wait for system reset...) 3 V9 n; p, O, t/ n
* b$ H1 M2 Q4 x" V
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
! g% o( ^2 z" I1 \8 e" I$ n* ^5 z; z
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.- Z3 x! Z4 w" p" P6 I- N4 g  @, _' y
6 B+ s. I0 a' o' }/ ?8 Z+ o. x
[2 Programming ways for clockgen]2 M, i9 s, {- b7 [# Z' v% b; C
=> 現今的 ClockGen有提供兩種方式 for S/W config. 一為 table mode,一為linear mode. Table mode指的是: ClockGen spec 中會有一個 table,裡面說明: 要產生 ? frequency 要填 ? 值.因此,這種方式只需program 1 byte to Clockgen就行了. 若是 linear mode,則是坊間所說的無段變頻,即可以微調frequency. Ex. table mode只提供 100/133/166/200MHz,但 linear mode則可以提供類似 102.6/136.3/168.7..等的頻率. 此時,要program的 byte數就很多了.....除此之外, linear mode也可以config 所謂的 spread spectrum(%),板廠測EMI時會用到, A1 D( n* i6 l. O% e; R7 ?- d

1 i/ F9 F, X5 }" e" Z【Notes】
# U/ @1 _$ a% Q) d9 {" q1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings& V+ x! ]) W! Z
% D% r" }( d5 z: B5 t
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper2 Y5 w3 b0 {+ p: g( x$ i" E! }* n

0 @7 n5 N+ Y: [3 x7 v% r5 O- o2 _$ Z2 F" n: R
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
. {8 u1 T3 R! ^0 g2 X! q6 _
# s" C5 x( Y* v3 Q給我正確的頻率,其餘免談 ...^_^...
+ n6 d. {$ N: `- J% ]: q5 Q) {% K* S/ o- y4 A6 e
=====================================================================9 n. y% R& L* C' _
Q&A
* }/ T) l! ?- I# U- _. q- u+ J* \=====================================================================" `2 r$ Y, z+ o( u( L  E
>前輩我有幾個問題要發問!
; x- x( ]8 K. ~>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
- J$ ?. a, |0 n+ \>* r/ h7 p- X! B* [/ Z2 }/ \' r
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?; }! W% B! V6 k, X
>9 b! G; k. {8 ?% f
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
" Y# u# Z* n$ Y# H5 k>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
6 y0 R; m$ R0 m! X1 O) v>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
; l! V0 U& e3 Z6 g, d% l0 h! P4 n3 p, F! |
[For #1]6 I- P5 C& z5 X8 y4 H9 n
=> 我所謂的 "Table"方式指的是: 為了方便設定,clockgen designer會專門提供一個byte register(8-bit);此 byte的某些 bit fields(Ex. bit[4:0])可以讓programmer填一組值,例如 01001b. 此值 write 至 clockgen成功後, CPU/DRAM/AGP/PCI/...etc 都會是固定的頻率. Ex. 100/133/66/33/...etc. 所以才說只填 1 byte only !
; s* I; v( g- K- Y* c
  x6 H- T( [3 M1 ?此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
5 k) b: k9 S& ?6 {* ?, Y) ~5 F; B9 S- p# C
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
; f3 T6 V$ D8 d8 Z7 |: U3 I0 B
, M) Q! H5 b5 P0 u* EEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
* ]% S3 D+ J1 C5 @8 \3 B9 z- y
4 d" j$ @$ Q1 Y) ~4 y還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
6 X% G7 F- l6 v! A: C* q8 P$ ?2 I$ E! ^
For #2
6 P( Y, e$ z- c=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:1 t  R- `$ \8 e$ z
(...想像以前學的直流與交流的訊號...)
7 @7 U' ]: C* W, T$ f! K" p$ X: E" M/ V2 a+ D
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!/ R% P! o# @/ m# ?5 S, l" |
0 B0 j( {6 i, I7 L8 W; [
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
& k5 C6 ]& {' |' K8 I; @5 e
; i7 [: M9 L5 ~% L) qDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )* h% T8 f) x% \& R% U

3 A" P1 l5 W/ Q9 B5 x  P; Z, K  r3 w. XFor #3, ?! a- I2 |- T2 X1 P7 u0 \
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...$ T) Z0 X, A& B5 q

9 N, _' g* b8 g8 L5 `" h* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
5 e( J1 Q: v% D2 K: Z( j* Q& G" C! ?: s. y
[[EMI 測試的知識]]- n3 K) m) r, v. s8 F( o
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 2 D% M( ?5 I& D- Y

+ t& t  l) P% x* i% q; \為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
; B: A! G$ b1 ~8 J' {: x4 _
: p! d/ B5 e6 S7 {至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2024-5-20 12:58 , Processed in 0.025686 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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