|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.; B' U6 o$ y! n# W. H1 {
+ k) s* p# A% x; V1 Q
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
) T a5 w; R" i" ~# ^, ^/ }, q: N" O
有哪些 frequencies由 clockgen 提供?
! B+ z+ x0 P ]$ h, Z- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)" r$ K2 s6 Y% z: _
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
8 H) r6 }3 \8 N; ?0 r更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.5 r# G8 F4 F$ Z
2 P7 H! z' X# R補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
+ O, R& ^$ q0 r; P/ PEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
5 V1 M' ^0 v8 z8 a0 s, Q, K+ Q! f7 _ R# |: ^( [
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
: }& o" V* \& K" y- PCI clock: 33.3MHz
# A* Z- s* A- y( P0 P- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
! t; n" h! c Q ]4 r- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
1 A# I* G$ H& _5 I- USB 1.1 clock: 12MHz6 B$ y" E" E: a# \8 ^
更正: USB 的 clock 是 48MHz* B/ G3 {, h; N5 H2 |# I) {8 L: X! M9 h
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies ! G6 z/ ]8 {+ j8 C6 Y2 E6 q
a. h: t. u. D: z- SIO clock...etc. Z- X' p- T5 L% `& A. v6 `
8 }* S: a! F6 z) dClock Generator的架構
' {6 D: R& n& Q=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:- ]9 H2 T, D+ r& m# I
% i8 `. M6 ]/ I, H4 @7 S- w14.318MHz -> PLL -> F -> Div -> f
6 y- _+ c) Z& j* j+ R; Q/ j5 P S% l0 X: g% [0 a
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
0 e0 Z' l9 h2 t9 B/ `$ J3 C; ~7 z; e
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
0 {& `; J6 M9 L' r5 b: ?# x9 ?% J/ E9 d% {* |2 f# V0 a" c
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) v: j6 b9 k6 t2 L! P- @ v
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:) J% B9 s% Y6 D- ]' H% z# u
1. 有 2 bytes(即所謂的M,N)來決定 VCO0 d8 q6 e# j9 [( a8 Q1 O
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
) H$ f5 J) T$ @6 ?3. VCO / div = frequency
! Q* |$ B" A8 P3 E6 T4 I8 |4 G+ f. f
- t4 I" p m* JHow to access ClockGen; d0 v1 _) K4 f. Z
=>現今存取 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
% ?& [; A f, v
& S, K. L1 f; @8 O$ Q! ~不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
1 A0 T \- j, }* c# ^+ A/ _5 `+ U- pre-init( clear status or ...)
, _: Q! `! m) j- put slave address(要 access 的對象)
T- b6 V7 S! `) {+ G- decide Read or Write
0 ?5 B1 R7 } k9 A+ A- put command(Protocol type, Ex. Block or Byte access)! P5 }+ k$ k# r6 E( ^8 g
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
7 f- ~! [1 Q/ H- put data if (Write device)
& {: z( ~* \$ g$ D- start transaction !!!% [: i) x z+ P1 N U1 B
(... processing ...). ^) N; Y4 E C" ]& d
- get "Complete" status to check if transaction is done successfully
- R* `# M! V. [8 n; {(...wait for system reset...)
" ~. [( s" ^ o' e
( h% y5 x* m6 }6 L' q$ I* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions./ o. ?( T! h/ \2 W7 ^& D. H" X/ L0 y
& p8 C' s8 |4 C7 ~2 I透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
3 o$ v: M- p) W, U- r/ z' h. R/ X+ \: F% S
[2 Programming ways for clockgen]
2 u0 l/ w) W4 s* c3 l) v=> 現今的 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時會用到0 I2 ?5 v& ^) ?% F$ J. @
7 h3 [/ X8 u6 G; r; l$ F
【Notes】. I! b3 a( ]0 I4 p/ g' q2 g7 ?
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings8 ^* {0 F, n5 S- `3 o9 O
' w0 W# x# j1 @, N* }# m5 U* I3 \8 K
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
7 v2 I" [5 X6 Q% U; y4 [* d% Y3 A$ g. F1 i
* H, B# w! j% X+ D' z; d. V2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成: r* {( W3 `" Y3 {) I
4 Z2 c. Q. `9 d2 s5 ]
給我正確的頻率,其餘免談 ...^_^... 0 N N+ Y. @& m0 d6 Y! j, c; M0 V
, ^4 V& Z6 p( I7 l- J( u0 _
=====================================================================
" {& C; L5 ~+ Y' b* z yQ&A& ^& O6 N8 k" t1 s
=====================================================================
+ ^3 B5 n3 P. h ~3 ^( B- k* f>前輩我有幾個問題要發問!
% @; @( N* N: |) Z4 ~9 L>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
1 w3 \4 h/ l( f3 c" z p5 G>1 g) P1 u+ J I, _! z, U) b
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?) @- ~8 t4 Q# I3 l$ G: u0 ]; m
>6 C+ l& ^3 _6 x. e
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以% u: H& [4 @* B4 ]3 B7 ?# T
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠+ q: m% h! ^! r+ s$ o. R
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
7 C# Y3 K3 z5 h
; Y. R d% }$ W) w; O[For #1] J5 U$ Q9 c. W- d9 `8 \
=> 我所謂的 "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 !
* z# `3 s" G* K4 J/ B" j+ m3 M e' |! g `: l+ w' f
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.. y8 n" X1 @- ]& n
4 r2 }& [* r3 f4 C# B/ V2 O不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
* |9 g6 f/ o0 q; s; f( @9 d) V" _7 n4 r" ?+ o* D$ Y, L* y$ a
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz! c% b W% }" s) K# }/ _4 f
! h3 }% J4 V6 Y, T- w還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
' a- R! q% H# T4 a4 G4 v
" m# E% T& }* Z/ h. kFor #2! b" | _% t6 {1 m) O/ I* l
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:$ Z: H+ L3 k* U9 `3 p
(...想像以前學的直流與交流的訊號...)# }1 k6 U' g/ D ]) u) F1 H6 ^+ `9 |
) S8 \, ~4 r( g% X; E' j x
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!: x3 ]+ V/ j4 w% z
9 Z# v. I: |4 u5 V+ t" }我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
2 g4 D* _3 \3 b, S$ Y- _" V9 u6 U! F+ s( m% }, [6 K! r2 C
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )) |- ^4 M( s4 p) ^& }
D7 d! x9 q7 s6 ~ x/ b" ^For #3
* h. Z" E$ s% N9 i( \=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
* [3 V' b! l0 Z& Z
- W, m e! D. f% i" e- }* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ ): y& J n3 C5 W* h$ e1 _
/ U& C2 \8 _" { }* C$ g
[[EMI 測試的知識]]
' N# g9 k- V1 I7 W3 f" C2 ?; `由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. # k% ~8 F) Z7 L: E! s
8 X( e2 E6 k; u r) `為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
0 A4 G+ h* h* V Q. D; n8 G* `# E2 N( }" D+ @
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|