|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.; w- z1 T- g& @; M% |
6 @' D8 |, A/ L+ _在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...% R* f5 w0 S' p2 K6 F+ Y7 g' X1 @0 V' w
( _+ ?& z( K2 O Z有哪些 frequencies由 clockgen 提供?" w9 u, |- j- l+ j4 p& k3 j
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)3 X$ z, W. t- R& T' H7 F8 f, \
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)$ e6 n( T4 ?- t" ]
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
% G3 y3 U% p' s& C* @/ J7 L! Q* w0 S& H8 K5 Z) U) Z6 M6 i" T
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
" b! U$ G& e; u4 X& vEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz1 z% \, q* v( N5 f5 C, }, i
5 ^( D% H: C" z/ N9 Y4 L
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock); {% W4 D' r1 X) c4 N9 G. |. J1 j
- PCI clock: 33.3MHz
! q; |7 X, Q4 d/ u& `- X3 B6 K- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
; S5 | g% @% [) h- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供8 x; y0 p6 o+ N$ ^; V7 o w
- USB 1.1 clock: 12MHz$ ?' j' T* E3 R B
更正: USB 的 clock 是 48MHz, K! r# M5 e: a) X- ?" @
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !4 _ j7 f i$ j8 I, {8 n
( l' o. D" }( E9 X3 ^- SIO clock...etc% j1 |1 ?7 m6 ~- c4 U; r! ]
! n! o8 R! Y6 a7 V4 K8 T; g
Clock Generator的架構
4 c( n3 a: [" i=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:7 ~* c8 Z# f; {3 R* F9 C
. Z) v- s5 G! Q5 j* S3 U
14.318MHz -> PLL -> F -> Div -> f
+ [, L3 p( L# X3 o4 R' W6 g. j( I% X0 l: o6 R. U! V) j2 K
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz: H% `, ?% c1 \- |8 k3 @# L* Y6 c
8 F- @' C# f% m% o! Z" d1 U0 M
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !/ J# B# Q& f# R) X7 I, [+ q' E9 l4 u* f
% J7 z4 ?* T9 f更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ) H' D. n) ]2 Z; n
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:- Q5 ]3 {" k s1 X& N0 @5 Z) v
1. 有 2 bytes(即所謂的M,N)來決定 VCO5 p9 n3 X: h8 o; Q
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
! s% k# H7 I5 c- o* i3. VCO / div = frequency, _) ~$ o% w3 B! h
$ }- h9 A4 I! F1 t
How to access ClockGen
" X( j- P; u* C2 p9 j=>現今存取 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
K' e d& r6 d% b( `7 I2 L3 o) K4 Z% H
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
2 q& c/ u+ @. a- pre-init( clear status or ...)
5 p% @- u, n, T$ m/ E# _! K0 Q- put slave address(要 access 的對象)
# H" o& ?( L) W3 A- F- decide Read or Write
3 _) E6 F6 R1 G& J1 @6 d- put command(Protocol type, Ex. Block or Byte access)
* ]3 n! `' T; v: w- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
: t- M9 }; J. h) A/ X+ _3 q- put data if (Write device)* |+ z$ f0 J) Z* S0 G& O. x
- start transaction !!!/ V( u+ L" A+ b% V) Y; U) O/ v0 u$ W
(... processing ...)
! {* y6 ]% {8 E. ]) U- get "Complete" status to check if transaction is done successfully
! A& D% j: M+ C(...wait for system reset...) ) D# `+ {+ l( D7 U* N( c
' y4 J" ]7 U/ D p; A2 H. ~! R
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
. g1 ]# q' T+ @# r- y# M' I, V& A' v7 u: I7 ?" m4 u
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.+ X5 d( ^/ o9 b$ I
/ t" \' i7 n/ H% ^; G0 B* t[2 Programming ways for clockgen]
7 k& x; t) Q, A7 m d4 j# u1 d=> 現今的 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時會用到
+ g5 x3 q- L" M, ~0 y9 D7 b' x3 ~8 h
【Notes】( w1 x( y, N7 P# \$ Z( C& q
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings: U; ?5 c% P6 T& f3 ]9 k* ]& c5 A
' W$ T& d9 e$ t% g更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
) Y( O8 t& j* b
- v: Z7 q$ g4 Z. r& b9 X w6 q7 x9 w2 d' e. m
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成; y$ D1 d& v. ^ D7 Y7 d
% @0 o" o$ G/ s6 a5 b' q) A6 [給我正確的頻率,其餘免談 ...^_^...
" q' ?+ D* D# C4 {* [4 q9 l+ t2 ?. h& h/ i: y
=====================================================================& k0 X7 E) G. o% v
Q&A/ E8 H! B+ C2 u( ~3 X% P7 ~
=====================================================================2 n0 C, y- s" k$ f! b
>前輩我有幾個問題要發問!
. w' y+ b- q& w>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
# e8 v% }9 P1 k9 B) D2 b>0 P* \ p( w: w( f5 a
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
& }1 S: z: |/ m1 @1 S>% F5 H+ X/ K' B( O% Z. {5 [, U; V
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以4 B* @* P+ I( s: x
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
# `; X* x; P* E* T$ G0 W>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?+ V6 u$ H3 }/ h4 \# I$ ^; c: V
, S5 E. ?9 }2 c" f: D
[For #1]+ y) Y1 t* F5 X u7 C2 r
=> 我所謂的 "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 !
( q2 T9 x S5 b9 Y& U
% Q5 E: M' F: _1 t1 k4 P2 u此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
) Y/ L! [4 H3 a5 q, V
; _8 a" l; u% Z) k3 n9 i S5 h不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )/ r; o F4 `$ w( i+ R7 p8 _
4 v, s$ k! o/ H3 g2 o8 S. q
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz4 I, }1 _& i4 H, _9 G t, c5 u8 ]& `) M
@! k- s6 y7 D8 T" d, r
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
0 f) H7 b8 S D9 `# V. B
: |: S8 X d5 t( d# Z4 ]For #2( {" o" D+ P* k% e V
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:, h# X* s/ o8 Q% h9 q. K
(...想像以前學的直流與交流的訊號...)6 _" P% o: j" J+ j) P4 K+ ?& C! Q
# I% d% ]' A8 i# j100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!4 c' o4 z7 X+ Z6 Z R. b
# U7 l4 S8 y& Y' ~! z
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等3 f5 A: R9 Q7 r R" p# {
6 e% S7 S- |- Q& c" X1 A, X6 ADown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )0 U, G- d- |1 \
. G' M! ?; }8 `+ q6 \For #3( _9 |7 D1 f, ]
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...; x- V# Q4 E7 j
' Y& j" A$ Q5 h$ F( _
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )/ d1 y& P6 b8 J0 V- C6 ~
1 ?$ i2 A. g: k, L4 X% q% r; Z[[EMI 測試的知識]]
0 g* e7 Z6 Q2 c& l* [5 g' G; N6 }由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
9 o% H; u8 J& b0 p+ \) s) `5 l6 C; g' j1 k! J% L
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.* P0 h6 j1 N, Y4 U1 e
- W1 M ~& n7 f; P至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|