|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.% s% T3 ^9 m) y- ?! {
; I8 d( o# Q! T& i7 Y/ K& l' o" c, r1 Z
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
; T# E9 D3 v$ m/ Q" f
0 [4 {5 X7 W" A有哪些 frequencies由 clockgen 提供?
0 R# m. M, \) B9 d% l- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
, N* z& ]1 l0 j- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)8 F" t+ T0 d1 g
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
7 R# B) m" n. B5 }, r
: j, I8 L Q" \- v/ g& @( [補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
# I$ E# X0 W8 x' a! iEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
) R; q( ]! y% v0 [4 J' D' D8 S- |: C1 g8 u6 u/ _; Y( j
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock). z# d/ h+ u; N% _* ?. ^1 q$ N
- PCI clock: 33.3MHz
1 i: O: P( t+ }; _. t- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)* o5 k& @4 X1 v
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供+ J* @6 e& _- d7 O4 ~( @2 f& w1 @
- USB 1.1 clock: 12MHz
7 _7 J4 u/ t( H更正: USB 的 clock 是 48MHz
% J& n) r& K* ^2 g+ O% g補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
' e& k( l: y8 Q/ \$ e7 Q& R, Y O4 F& h' H6 f. I5 l! H
- SIO clock...etc
- O# Q0 `& \8 ^' t5 \/ G4 g4 j: N9 Q' x) e$ {; Z# U4 Y
Clock Generator的架構
1 F7 B, `! c! j3 X5 m9 f0 O" Q( [=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
1 ~! B3 K! `7 i1 v* E% i; v
" G/ j5 n+ o- f3 j" y14.318MHz -> PLL -> F -> Div -> f) D: f& N/ ~0 l9 t( ?0 i
# @8 H) q+ D# p- Q( t' |/ M
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz, J7 H1 L3 _' `, e4 {0 q9 m: M0 A9 p
& O& L8 y2 G E5 P( d. a4 ?! ]) z
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !0 Z0 s% X, l) R; j
* u( V- q t0 y8 G' R. X$ K$ ^
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) & ?7 R% |( q. u' m7 W% G' M$ p
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
* M1 D1 d6 W- j- w( z9 }1. 有 2 bytes(即所謂的M,N)來決定 VCO
) ~7 ` m; m7 Z7 l2 j6 `2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
: i5 Q. n- z; ~; Z, d3 s3. VCO / div = frequency
" m/ S! L; X9 C' l! W. b5 x8 R9 b( p5 m" N& G
How to access ClockGen
$ m( P4 G& z* ]) f; G=>現今存取 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
+ h3 D5 H) S1 ]0 F" Y
+ e& J, E$ _4 F! v% L不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:4 t8 b2 f. ^0 W/ i! V) A) U, L; e
- pre-init( clear status or ...)* V' G. N, J# u0 W, M% G
- put slave address(要 access 的對象) 7 l' Q6 l: k* g$ u' ^
- decide Read or Write2 V! X$ T3 A7 H; g: s1 m- o
- put command(Protocol type, Ex. Block or Byte access)
( d& t0 G" e7 I1 `. M, M" o- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
! K" b' q1 v0 U* O* ]8 I- put data if (Write device)
% y( N4 n Q+ u4 [! [- start transaction !!!
! b! m5 p) z. G& }2 P6 x0 n(... processing ...)! E8 u3 a! \* S f4 f5 D
- get "Complete" status to check if transaction is done successfully W( @/ i' U. r% s
(...wait for system reset...) # |+ g1 F& x1 s* I) V5 l
2 X3 N7 k! q8 S( f! w. }' p* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
6 Q& y: l9 R1 L5 d# `3 q9 E* e6 O
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.4 R o8 V+ F1 P
% x: s$ d- A- G! I0 H
[2 Programming ways for clockgen]
# N& N" f/ S0 J=> 現今的 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時會用到! Y% K2 t1 t) E9 {/ M- o5 u9 G
1 z' Q- a( ]. p0 U【Notes】0 _! y$ z4 a5 s: h
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings9 {- P' e. Z& _3 e+ E5 b: p, W
1 t; o3 w8 _! A: R# r% H5 d$ M更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
% R. t' c: W' `1 H2 O" v( I9 G3 C4 I$ f' h: ?, T0 Z
' C( b% K) O$ `- c8 e
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成0 N: @0 Y% J/ z
. b& j5 s' a" d4 @5 X+ i, _
給我正確的頻率,其餘免談 ...^_^... 6 M0 u; j: E) f. `3 z2 q
; k' p7 y F- Q @+ J+ L! e: ~
=====================================================================! j$ b5 E) ?% z0 ?5 l, x
Q&A
3 \6 i, a2 r) g. ^' b/ z2 T1 \=====================================================================
( P, H9 K. Q/ _0 {- d+ K! |+ q5 Q6 b% X4 e>前輩我有幾個問題要發問!9 E f$ r: k9 q" s( e9 C
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
1 z7 H; f6 B1 @4 {4 I- o4 m! l>
1 A8 z, \# H: B" [>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
/ X! ?$ H- e1 q& g, L& F- r>6 u" z5 |, H$ ^, S j! P9 X
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以 L) {$ }; p+ k' p$ F `+ V
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠8 J! _! U- S0 y) r. B [8 N. [1 ]
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
% Y# q1 M0 S' v+ J7 I }( C0 X! [( O2 F$ P J, B% l0 Q7 {
[For #1]. N* b% o- f" j
=> 我所謂的 "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 !$ J& a6 x* d+ B R
/ J9 J2 F6 Q( Z% z
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
. A8 n& x5 n+ F+ K+ L Q% O m! [+ `/ w# |0 N5 c! B5 a1 M
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
- j2 ]& ] }7 N% F: g ?
$ O7 H# ^1 S" g. h; l5 xEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
) M8 a) S3 O; a2 h# C- S5 `/ r' y( {% y6 K4 [. g Y9 R& m
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!7 S! n% r" n j$ i6 S
& x( t# r2 Y) |; ^* g
For #21 T7 ]9 f+ o. |/ U) z6 T1 `
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:! M; {! }/ g' w- L9 O7 M
(...想像以前學的直流與交流的訊號...)
* U" X2 h" j5 P' P* q3 `1 q" A2 ]) D$ U! W1 Y* U
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
! h# a+ m/ j9 y- N! Q" k {4 S: B" z( [/ t& z7 [) ]
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等5 Y' ?# _! J6 D/ Q3 F5 t7 f& G) ?
( a- x" B, A% L. x+ R6 q
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
8 z% l ^" I0 K! u4 B: w
- M- Q" A& X: uFor #3# v' n4 t# ], m
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...1 z8 F3 d: E0 ^7 Y4 Y8 O: ]" K
3 Q* \+ z" T# G* j
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )% L% u: S# Y5 d# k* { }" \2 e
2 f C( y4 R2 v( @- M[[EMI 測試的知識]] p- b p1 P) ]: X! M6 ~: G
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
) T2 G% ?2 U7 W! B$ ?- J* \- L7 B
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.' p1 [, A; j/ Q) \. T
) C, V0 ~# }, K9 C
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|