|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
! F `# e& H4 T) {, @# L6 l# X
" n- ?1 U1 e, b( y6 t在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
; Y' G( Z9 ?- K" f# X+ a0 T' Z7 k4 y6 J3 W$ B
有哪些 frequencies由 clockgen 提供?
# o. C2 L! u" @- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
5 q6 {4 X+ z) u: D- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock), _* t" T% i2 G$ H
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.8 k! R4 g: i/ k2 |1 l7 C/ Q
( t) X. Y! f7 n# p補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.6 X3 l- E; w8 L1 T4 e# g. c% t' y
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz7 _( e0 {8 [. p1 Q( X
* J$ g$ P. \) H5 Y$ X- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
( q) {2 ?) R4 K5 y, ?7 V" |7 w [- PCI clock: 33.3MHz
5 ^& M7 J5 L# G. t }4 B0 F- SATA clock: 100MHz(see SATA spec,似乎還要更精確...): I" N1 ]. Y% X2 \. }: f, f
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
% Z! ^& V1 k9 g7 H$ s: N7 J* x8 @- USB 1.1 clock: 12MHz
# W7 O' r2 J9 D& \9 z. i4 Z更正: USB 的 clock 是 48MHz8 ~3 A; C/ U2 {0 o! }7 W! y
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
r/ B u" d _4 d+ [4 Z
! _2 {2 K, w/ L2 k% t9 h! T& b- SIO clock...etc4 A. g N) q+ u) f
& o$ _4 G7 g2 K
Clock Generator的架構0 J4 R; r, V/ r5 s+ C
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:6 S) b$ K$ D- f, O( q' c6 _
/ F) d4 z" y! j1 {1 [% G14.318MHz -> PLL -> F -> Div -> f2 S( N4 J- O2 v. `5 A
1 x5 F$ m6 q- w7 K3 a, i# P
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
3 \5 K9 c7 N. W5 W8 Z E
$ R- ~2 N1 n. E1 b% Z+ ~! v" E4 PClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !4 ^- X5 p" l: ?& m: P# ?1 v8 v& ]
9 [, D' Y0 x# v: H; E$ g
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
1 f8 }$ W+ y* x補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:- Q* o0 p( w! O5 x
1. 有 2 bytes(即所謂的M,N)來決定 VCO
) J) L4 C) d8 }) K+ n2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div* g! ?3 P0 p/ I5 W% Q- F$ I/ j
3. VCO / div = frequency
3 w# W# p9 P$ p8 l& O
3 Y) m0 X' d* T( }. d+ T5 QHow to access ClockGen
$ ?) O; ?4 `$ t0 J$ O5 V=>現今存取 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 % x9 T7 Q: h$ ~7 D
7 G5 R% P9 S$ h/ r- L) T# ~0 f
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
) J! }& X1 V% @' z1 |7 ]- pre-init( clear status or ...)/ P3 M7 F4 u0 [0 ]' h2 `- n
- put slave address(要 access 的對象)
Z0 g: a3 h0 S- decide Read or Write
4 E' |7 \1 l- Z" ~- put command(Protocol type, Ex. Block or Byte access): k, q N: F8 {$ ~
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)' f% v+ M' Y6 _+ u* M) }; e
- put data if (Write device)" b1 h( r8 ^9 `
- start transaction !!!
2 B/ w' M7 H4 c9 D5 n _(... processing ...)
5 c8 y6 Q' L) G- get "Complete" status to check if transaction is done successfully* P% J& G( C3 B7 a8 ~2 r
(...wait for system reset...)
J4 O+ ]" @+ N1 y. z$ h4 O, I1 c! M0 s- o
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
! L, \5 w6 ?; b+ \& H# x* v0 f* N. m6 c2 v- V. ^& H7 L
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
$ T7 E5 V& p" N7 T N; }+ e$ j8 Z' V4 z y0 Q, P( f+ T" ]- [
[2 Programming ways for clockgen]
" Y6 f* W0 ?# 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時會用到* q3 X. d' h$ W- B; s8 c5 e2 {
( u) k3 w5 k5 m) Z0 t. x
【Notes】6 t1 u. n" T8 T* N
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
2 g ?& I6 S4 f6 s" W6 [
. h4 F. ]* Z4 ~) W" y更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
7 r+ d$ H$ ~2 R* J
2 m, `# x' t3 D* d) y! Y9 @
4 a T I/ c l2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
i0 v2 |5 X8 o" z
) ?& u8 J$ J5 V6 i3 d- R! T給我正確的頻率,其餘免談 ...^_^...
) t0 U( V4 ^3 T# W E q# a" |* t! G# I, _0 t+ A
=====================================================================
, s( [( A b) L3 bQ&A
" D$ ?, t4 P9 q6 k4 Z& g7 y=====================================================================
) [& o x$ |: x* H7 b! U>前輩我有幾個問題要發問!# Y7 o2 X9 ]( ` x6 K, U/ n& p8 L
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
8 y0 X& k2 p! K; K( q7 D0 b>
4 R" G$ f0 Q: x6 M* g. s>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?8 J2 Z8 n' S7 U9 T# h
>9 E0 h0 C. D7 k* K7 W, N
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以; Z$ j7 q' C3 v9 b! M9 D' d
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠9 {+ E( b( g$ u2 W# w2 c7 J
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?% k. a( U2 |1 k R* s7 L: d
. N% j" k0 E: d) Z( R( E[For #1]
2 i$ X8 D$ _' S+ s# |$ M+ s=> 我所謂的 "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 !
5 n3 {1 d, w4 r! ^7 J2 z `+ ^0 m: D) I$ @. h: n. ^# h
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
0 v+ d0 B/ q- D9 g% m
& r0 ^4 N3 E7 \& k6 V不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
6 d5 E+ e" X. w/ i, X! |! d5 R) U) _3 m( F( { {
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
0 X6 x+ ^( S* x3 }1 ^: Q8 C, c( A
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!1 R0 @- ~# I8 f; d1 D% i
5 k( f# E- M' t% ~# q9 HFor #2( U, `! ~/ i+ k, G
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:1 S: Q' K9 e: O7 x, H% K, W
(...想像以前學的直流與交流的訊號...)4 M+ f! ?3 r. x- _9 P
: e# _' s$ p9 O" |1 |100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!8 P# V& v7 M; s: j: A
0 l6 ]5 a/ T5 c! o/ \! @我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等- t2 {( v) `9 d b1 C
2 K1 V3 P: \% S5 {
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )2 s+ S" {$ e: D% z; S j
6 K+ }3 r0 r5 E& m0 w0 v2 ]
For #3/ J& s& ?0 R9 ~+ N0 l2 W
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...: k+ o; u. P7 @1 K
3 A7 U$ E, j, `5 ^6 Q8 F( O9 z& W, }
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )) g: u6 H0 H% H$ S8 H
* m/ a+ d" o' [* p7 }9 U+ U9 y[[EMI 測試的知識]]) l' }0 e8 L6 a+ c7 S' i
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. & K# L1 c+ r5 d+ Z
) ]5 k+ P: d* A" Q! ~) P D% h, O
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
5 t Z3 x) \) T, \* ?( F
) \8 }6 u& _ t至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|