|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
5 f3 L: P' o8 P1 F+ W+ l4 C j# o1 S+ e: \
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction..., R5 e# r# F0 D! J
! s9 D8 V# O% i' y1 E% \( T& }有哪些 frequencies由 clockgen 提供?! s- O$ i. f% S3 B% e
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
( D% ~5 }/ i3 m: F4 d" [2 F6 r- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
7 C, L* V3 w3 h! D' a5 U更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.) P, t" q% L5 \# y' ^9 G! N
f5 j% |# W2 U* x補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.' k8 w7 m, P! M1 y
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
: d" t% E Z# Y( X
6 J o9 z( A: \) F4 v- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)# U* K4 z& r. u
- PCI clock: 33.3MHz, l3 n- G( j& g$ _
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
6 e4 i1 c9 d. _! W! m- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供' B( A% o2 r% f$ ~$ x5 ?
- USB 1.1 clock: 12MHz
6 X$ ^- h4 U# w更正: USB 的 clock 是 48MHz" P v/ R' F7 U8 p- Q
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !1 s! @" ~& d& r, l/ a1 O
4 C6 L/ K& S# z n \, f2 K) k
- SIO clock...etc
c# H; Z! L l/ v% F
. U. _9 C0 d7 `Clock Generator的架構, g, u3 ]( z5 F/ s" _3 Z, L
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示: P3 L) J: K; G3 [ j& Y
' W4 U( G. a5 i
14.318MHz -> PLL -> F -> Div -> f9 `1 _6 g" R& Z) i$ F; L+ U9 M
! I& `% E m4 H V( N
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz# ]5 B* Z4 m/ u8 I/ H/ p
. C- k- A- B! m8 Z2 ?) OClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !) O& a+ d/ J- r v6 V2 M
, Q6 C E0 X# u! z- F# h. x9 g
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 9 z% |5 O, V- p. l5 L( H
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
+ x2 W2 | E _8 Q( _' D1. 有 2 bytes(即所謂的M,N)來決定 VCO
0 J; b7 Y6 \3 {2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
0 ~( ~! r3 r) X# |$ d# M: P3. VCO / div = frequency! N' h/ S3 l& J1 q
- }2 b; B2 b& L: k" q2 r" r2 j
How to access ClockGen9 a! y4 ^2 {1 e( d: m- _ 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 - E5 ^9 w/ M" S% A
+ s" p6 @0 n; J* }! L' M不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
8 e4 S0 e1 a6 T# |, M- pre-init( clear status or ...)
9 F, e! L7 I; b" B- put slave address(要 access 的對象)
3 E/ H# d5 P+ v/ B# Z- decide Read or Write
, p' D# D: ~" x- put command(Protocol type, Ex. Block or Byte access)
' Q6 a* Y5 z' G- n* t- put offset(要存取 自 clockgen中的哪一個 Byte開始...)9 ~$ o( d9 o4 y3 i: f i7 E
- put data if (Write device): }+ |" y _) ~! |) h
- start transaction !!!
! j# R ~) [3 `: h(... processing ...): A0 A1 t8 ?! J' y6 y
- get "Complete" status to check if transaction is done successfully
! c( j% ]1 F" ]2 X* l7 x* [(...wait for system reset...) 7 I4 A8 {5 K' M6 j1 n4 M/ r
/ n ~0 e4 h' D* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
* _6 p& G a/ t7 C, S3 o- {9 g$ z. t7 \# }% f( Q( _3 G; s) s
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies./ Y( }9 m6 Y8 j8 `, D, D# s
) R2 l4 z7 \' n. E, S+ Z1 N3 Q[2 Programming ways for clockgen]4 F( u& o! m( P3 R" K6 Z: T @; x
=> 現今的 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時會用到
5 m2 ~5 L4 a9 O f0 i( v+ K) ~; C8 t2 \7 {) f. e" p: q4 A
【Notes】 a5 i. A* r2 {. C( Y& U
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings% ?8 _: ~* T( }& L' [, g
5 O. c9 M& X1 O# _7 f7 x
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
1 R( q; z+ t8 ?3 x0 @; o! W. H9 V& f) R3 W$ z) v8 A- E t
}8 _0 F I+ F+ p/ S+ f2 Y$ j2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成# T5 K4 F2 N' A0 X" W1 _1 l
1 F3 O2 X( V. R/ x8 i0 r給我正確的頻率,其餘免談 ...^_^...
3 D- ]) o% k' W3 u
5 s9 J2 m' s( Y: Z$ V- ~0 S' F% M=====================================================================
8 |3 U, S( ~$ J$ p3 d0 K% \% |Q&A* p1 f- O8 }5 L
=====================================================================( z+ }- h+ n' \& k) K
>前輩我有幾個問題要發問!# u6 H" H4 u% ?* \# @
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?* k# W* X' }, j4 @3 V
>
: N5 e' P4 s- {- N+ [>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?1 R( r& u+ d- L7 m# ^
>( B6 L: L q0 I- H2 r$ u: B
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以) o! K- S( j* _) G" D; F4 J; I
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
$ ]; q) ?% k9 n6 k" n, H>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)? S% r$ \9 Z3 Q
3 Y+ z2 K; Q7 w& @& a4 b6 w1 E[For #1]/ ` a# R9 L" D$ s; E
=> 我所謂的 "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 !' }2 C) f/ {/ U0 h4 }
7 f; P/ g1 S1 X4 g0 \6 F$ F7 q此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
* M9 k( r% A' [6 }# [: n s* ]! m7 n, ^; r
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
1 y* ^( |6 E* ?% E; S* V" p) v) q+ _7 R% M
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
. j$ }' X- c1 n2 h( V# j3 ^, _' _+ I% K
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
8 A; q- V. H! s# K4 Z
& s _! w6 s) s0 D$ E' EFor #2
# r2 s( m# ^7 O" M% U=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
, A- P; \% `" C" z(...想像以前學的直流與交流的訊號...)9 V) i* r9 \$ @( O9 I
! R8 D7 I6 v* m7 d* Q100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!8 Z; z/ n7 Q" ^
& b; o9 h# X5 ~* k0 H7 {
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
; d& C9 ~1 `9 |$ m9 a" `& \! q/ R7 v5 z8 R
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
: h9 C4 S3 m _( I. H; |; ]2 K) D' j) ~; Y- K B% H, c3 E. K: X* n. R
For #3
! o6 t/ c- K7 R% m; E=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
9 e' D9 U# _3 @8 [" v9 l8 z/ n. S9 l* H; C# D
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
$ o4 v: m" j2 r. W6 c" p4 b4 B: c* L' h1 \/ l# a' P
[[EMI 測試的知識]]
$ O/ b2 L0 \- f1 R# E3 `; o& e由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ; L! g B& a0 l1 V6 M
* L4 Z2 E8 \7 x8 Q9 j, f- D
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.4 @$ q5 \0 I1 Y! [" l& K
- n( R$ U- S8 q
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|