|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記." Q% y3 Y0 g: Q
$ ^: }0 {* D; {5 M" v! G) R: Y) b5 [在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
/ C: j+ x% p- x8 f
& i: z+ A/ V. }. }, D3 |/ m) h有哪些 frequencies由 clockgen 提供?
* A' d4 K% R5 S* F; V7 ?* F: G- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)* b) C& {# Q! \1 n
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
% D/ n, V! H2 m! c; v$ j更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
4 i. }& _; Q0 Z J+ f# ~7 B0 e0 l; Z+ L6 K. e" q* V
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.! H/ N0 ^# g) h z
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz( A3 ^( z* Q/ o6 i- j3 q G! _
9 \& ]/ ] h: G' C* w3 J- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)- Y! r( \. w. p
- PCI clock: 33.3MHz
6 `/ X( d$ y- V/ K/ k2 v- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)9 ~( `6 Y7 E% K2 V
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供5 m& I2 G C7 z' E' w z
- USB 1.1 clock: 12MHz! d. A7 H Y5 Y$ G6 `4 G7 _
更正: USB 的 clock 是 48MHz
- g8 \- a A' K: A5 ~' \2 \# _# a補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
2 W$ s. ^. b+ x) J5 A
v5 F+ I% u* V- SIO clock...etc% }$ H( N; e& D7 w, J3 v5 H- X
. N- j+ a2 i* \: } i5 L
Clock Generator的架構
! i) e# E. W8 ~ I=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
8 m0 R- {3 F0 U* A- t
0 ~. h& V: w! Q5 O. ]! Z14.318MHz -> PLL -> F -> Div -> f! ^4 ~' [0 v! y* Y$ f
2 {) [: ]! E6 ~Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
/ L# V/ p' ?5 y# X" I% p5 H G9 w4 D% D1 x; j& c
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !3 @- r _' R; a0 R* m0 T4 n9 C3 P
4 u: K" ?8 I: F5 C% D; y! j( x4 u更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 7 b1 n' D3 w d
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:0 z9 H3 D4 M- P! u! q: Y
1. 有 2 bytes(即所謂的M,N)來決定 VCO
" } F$ ~) e* {" S2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div6 C+ [2 h- g/ D4 E X Y6 |
3. VCO / div = frequency
. R6 f2 v" P; y: w* K' G! ]
+ h) } [: A, g1 Z( HHow to access ClockGen j+ R, p3 U+ V, h$ i
=>現今存取 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
5 h1 ]2 z( }3 i7 k' Q
" J3 [, j& Z2 i; w4 e不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:6 W: w+ u; u% k( P; S
- pre-init( clear status or ...)
! c$ k' O* y+ n2 }! I! P( y- put slave address(要 access 的對象)
, _% a/ }$ s5 z! q- decide Read or Write$ g1 ~8 q( o1 y, D
- put command(Protocol type, Ex. Block or Byte access)9 H: Q9 k4 X' {* _5 P) X, S5 `
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
# r6 c r" W# Y9 I5 j3 l% M4 U! J, E, L; |- put data if (Write device)
5 y) c0 I: b$ Y; y6 N8 i/ v- start transaction !!!' Q/ j8 p, ^9 l$ A/ t, v
(... processing ...)) K/ N; L4 Q( e( O
- get "Complete" status to check if transaction is done successfully; M5 y, D$ k. c
(...wait for system reset...)
6 C' {" y: q" i! E1 x8 n' q
, j4 |. Z- j$ o, V* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.) I* o/ s( c Z' B) U. D
/ l7 B& Q7 E7 k8 f5 l4 `
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies." ^2 ?" n3 H9 N. L# l$ T- }
* _5 ]! C& \* `( i
[2 Programming ways for clockgen]
. U7 f i8 c2 ]/ ?9 @$ v7 A=> 現今的 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時會用到1 R' N; n T5 ?
4 K, F: A p; S, D( g【Notes】
! ~) y( s% u* D: u F( d1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings+ M5 s7 W0 @/ ?( D
- p( c* C1 z/ G9 ^3 T
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper7 c$ y9 G% X; q) |
9 X; t. c" P- b8 q! G9 {* E, ?6 G% E# } Y9 A3 B
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成% Y0 ]& g' ?3 e: h) P+ N+ F; S
5 E# S4 X$ B7 Q6 R6 o' x# [% s給我正確的頻率,其餘免談 ...^_^... 3 O( o3 Q" ~9 y5 J/ R
3 p1 r0 n# q9 V& c! D/ b$ Y=====================================================================
: Y% }/ a) p* `& gQ&A3 s0 w$ J4 T/ x7 i4 \6 o, q+ w
=====================================================================2 f1 a. \5 S$ ], D( |. P
>前輩我有幾個問題要發問!; I6 k, f! t' j; ^
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?- ?/ J) Z l& G
>
* P. f+ W. ]4 H. V6 [. c2 c" ~>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?0 i) S7 {' [! ?8 X7 I% |, b
>
& Y6 w& \2 _ L. \2 k>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以) d c* l: n% n' R
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
+ u! o. M& n4 X>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
9 l: _9 H* E& U1 {7 l4 _: g
' v& t( E8 P2 I4 a9 B4 H[For #1]# T5 b* h# s' y; D, a
=> 我所謂的 "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 !
/ x. F6 w" K# r& o1 Y! y9 n {; O! o6 S8 `
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.9 J! ], }* @/ h8 Z, Q
, X& b1 I! I+ V& h) c
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
* @' Y+ B) q5 R. _0 ~
. f; }! K6 L% PEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
/ r6 k( `- d1 ^2 {& m4 Q' W- L0 N6 X: P. k W
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
7 L+ ?- N: z; [/ H r1 }: t2 i K" ?" D, Y) a' l( h, W4 G! X/ ]* q/ D
For #2; H) t5 }; e0 E
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:. x Z& ?) z, \1 k, }1 H
(...想像以前學的直流與交流的訊號...)# e* U. x9 M: |
9 N0 @+ G. K0 L- G7 y& E100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!5 Z: Y9 K% d* J) x8 J
( L7 K/ l4 T& [9 y我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等 {# \' Q* q, D+ T: C* I1 C/ r9 P/ M7 V
5 c* L9 {, N$ x1 i# c
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
; g, m8 |& q* j6 d/ @! v( |$ A. {
For #32 \1 Q; Y% o4 w5 [
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...6 {. k6 c- f/ u1 W E
2 m8 y, G: ]% M" J/ G
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )/ _( T) M$ ^0 I1 {3 g3 E5 y/ @5 \
0 O7 @1 ]/ h5 e* x/ X9 N- Q( Y[[EMI 測試的知識]]1 u* [2 x( O6 h$ M0 U
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
) t% m% H* y: g) p- R9 U6 C9 R5 G5 l& r' J
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.3 D, m" y l; u1 @ b0 u3 i
" ~$ D$ o: z. P* ^1 k: a' a
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|