|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.2 h# ~7 G g: g8 e- m; Z
" v/ u) N% s" M& u* W在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...+ A! P$ o$ h, @- y" o0 Z5 @
3 k5 a* E9 |; r5 b& n, n
有哪些 frequencies由 clockgen 提供?
4 o h; |' X5 T+ ~- o8 @; b- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
, O% Q. k* b" A1 V/ o6 Y- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)+ `: f. k9 f' Z r7 C
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步. s, U$ e. \7 H# Y2 Q9 z
# N/ ^, [+ R4 K! B; T! A補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.. \: H6 W2 V. {+ V& Z
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
7 i1 h! x+ l# U @# S8 |7 w4 h ]% q ^( K W& k1 V4 k }
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)4 e* ~1 Q7 o" T% v9 I, |9 E ]/ d
- PCI clock: 33.3MHz+ `/ Z' w- Y2 j* x! r# x! z
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
1 O# y: }4 `) j- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供, N2 X. k9 U3 C
- USB 1.1 clock: 12MHz( @+ o9 [8 F0 y; k, \3 @
更正: USB 的 clock 是 48MHz6 w8 ^& E, X f" u1 K: j0 u% o
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !& b F j8 K$ U$ x( m9 R5 j$ e9 ]) Q
$ h, C9 R* C6 _
- SIO clock...etc
; h2 ` {) E! j! }- \( K/ b7 h5 d& [# ~+ V$ n8 a* v
Clock Generator的架構' N. s R. w& Q# q' y1 [
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:# K* b% k8 m7 p$ ^! ?% Y& H
9 R6 S2 f9 b7 N: V3 b$ I
14.318MHz -> PLL -> F -> Div -> f2 ` \2 V0 e9 D2 p* Q: `2 A" ^
& B) C9 ]7 H0 ?' u2 PEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz" P7 @8 V! J4 M/ N2 t
! d# a- p; s @ i+ wClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen ! h9 }' c. t( L+ P' f) j. F
2 y1 v# {# _# h更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
5 E% l3 S, F( W: c V補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:: S- u' f5 S8 `8 ?: v! V+ r
1. 有 2 bytes(即所謂的M,N)來決定 VCO" H3 o [9 h- u
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
: q2 z; G: c/ R0 {& o. K3. VCO / div = frequency' i; U( ^3 [7 m6 {- [
3 s s: ~4 {0 _
How to access ClockGen/ e* _9 E7 D/ {
=>現今存取 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 - ?9 Q( I! I" W, U& O* a& t% q# d
4 N3 }9 j3 ~8 }1 l
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
4 [; i7 l' C5 O" u- pre-init( clear status or ...)( G# M3 ^4 V+ K% ^
- put slave address(要 access 的對象)
' B$ l) P" _! l1 j- decide Read or Write: a% i& J& h4 \" k1 m. Z# f2 Y( `
- put command(Protocol type, Ex. Block or Byte access)( |6 X3 j/ `$ S4 C
- put offset(要存取 自 clockgen中的哪一個 Byte開始...) [$ ]/ |3 I- ]
- put data if (Write device)
8 P/ I4 S# P9 w3 h- start transaction !!!
! ?. T9 L; b! c% C(... processing ...)
2 O" P8 X: h) M4 g+ ?+ w! z- get "Complete" status to check if transaction is done successfully
! C/ x& V1 `6 D# r8 F4 u(...wait for system reset...)
1 P+ L+ h0 { p, _3 ^2 B7 F# p* ^4 n% @7 ]9 o9 T
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
$ p) ^5 l2 M- e$ P6 d# v: z- Y( @ S7 z0 e' R
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.5 q4 s' _, M+ r$ w# K9 [* ?0 p/ l& E
" u, _' e# e) [4 ] J5 k% N
[2 Programming ways for clockgen]
' G7 Z! H( |0 A9 K; r) G=> 現今的 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時會用到
/ L! E% b' P* I0 p- l+ |- @1 N$ L% e8 t* u$ ^6 C( a
【Notes】
7 q$ F0 E" U2 N. P$ S0 n8 p5 w; a1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings5 D- r) o: a3 I, f8 q
' d W+ a8 e' S% V8 i更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper& k5 l0 U) I, k$ v3 }; f8 s
9 i4 m0 Y) K5 {) z, q; ?
7 j6 V0 K" V8 [3 H6 n. ^+ P2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成% B8 T' Z' q k; _+ H
. S- I) {3 {/ `! h# ~
給我正確的頻率,其餘免談 ...^_^... 5 z' u) d) @2 i/ A7 p: W/ m! ~
# K+ w R2 y+ f) q1 U! P
=====================================================================! _' l$ V/ @: h5 i* H: C
Q&A
V% Z4 T- I( W& M; G/ l=====================================================================
" r, A5 w+ D7 K3 X8 j# q% q>前輩我有幾個問題要發問!
* M7 @) j o' ^- g* Z* j2 e) {>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?# {# ] K( W5 M0 k* | m! Z
>$ `# p+ i; H6 v) A$ l7 V3 }
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?) u7 Q0 v6 V2 m8 a6 V
>
6 Y: ]. J- \) ^4 Y. ^* s>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
9 ~/ J E4 Y: r3 n>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
% w" O. ], V! _4 f1 K5 R3 S" u>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?7 ]3 j7 y7 w' y! B( S! [
, c. ?1 ~3 {: N% U[For #1]
- N- B* O. A& b: r; {6 \% V=> 我所謂的 "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 !. y* F( j6 _# m! c3 \- m2 r
+ p: H q# ~, L* l0 o" h
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies., d' x! a" @6 a
# v. o2 J" K: M$ _
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
: a- S/ p8 p: I# F) U0 v& O2 F7 Y" n/ F/ b4 N( f
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz7 _7 C1 ~! F9 m8 j
4 _% I o! S& [+ P5 {
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!+ R9 A# U7 U# H' c
8 E, y9 [* e# Z+ q3 H, s- u) oFor #2
, }. |0 N( G3 P2 E=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:2 c3 E& W% e( k2 l5 J
(...想像以前學的直流與交流的訊號...)4 }' ?" P; D2 E7 _* G; }- c" r; d M
2 U" y. p7 p! [$ j100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
. g" k( t* r: i7 g: I9 U: P$ O& @: b' i0 I7 \1 D- Z
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
^' v$ P1 M% G; ] q" c6 J
: @- Q8 J0 {+ J6 t+ U, {: FDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
8 j$ O" Y& ]+ h( [) k
, W$ ~# n" t" N6 GFor #3
) h" x2 |5 o7 g9 N$ N* M9 k=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了.... z8 _! U- E/ b7 ^+ k
# S6 K& l& X& S# l; x |2 h" Z
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
% l0 B& z, J/ S. `- N
4 Y4 I7 q. z$ n" k4 g[[EMI 測試的知識]]
8 u9 a4 X3 x H( i由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ! {9 e ]. J8 s0 R: e% R, s
4 N: W6 B5 ~0 y5 W4 }
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
; M; b8 b$ q6 L) l% n) [( u) x: _5 G2 I
; I( |2 i, n) h, O) n* I( d至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|