|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.+ N' y* X5 M" t, Z
! M# r3 v5 Z* S0 o: k; F9 h% Y: @
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...$ Z5 Q6 h0 C- [9 S; S: O. K2 p
; B, S* S2 a' P2 p有哪些 frequencies由 clockgen 提供?9 B- E# G1 L- Z R
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock), M0 G; c+ z; b9 m
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
$ Z' W1 u9 b* c3 \1 L+ V; V更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.- R# n- i3 y! {# s& h, K5 W- U3 F" o
6 ]$ L/ c2 t! V4 L# p S補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
( P' h% h) P6 C' ]3 K6 T( hEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz3 {; s _9 a3 A& w9 `' |1 n( e( j
5 h* w% K$ Q% J0 } V- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
a3 O% |, H- Q" m- PCI clock: 33.3MHz
, C7 I* p2 \; j5 ~- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)9 F/ ]& |9 Y9 N7 m6 Z
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供. `+ B4 p1 C7 H
- USB 1.1 clock: 12MHz- K( b0 C5 [! a1 I: W
更正: USB 的 clock 是 48MHz. |8 P7 C( I* [+ D+ y% T6 g) [
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !2 g1 h: h/ z" [
9 F; w4 U5 p; T' [9 I3 z- SIO clock...etc
( O! S9 H1 m5 X5 x0 V% y/ T: c/ \/ {, U1 B( O- ]! C5 V2 r
Clock Generator的架構( k( y z5 X" ^ a4 K! B; ^& q
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
0 |; a, n) S$ Z9 [7 W0 k) c2 w' M5 R
14.318MHz -> PLL -> F -> Div -> f. e4 c2 C* _9 H
- E5 o' U/ c$ Y3 w$ X. U8 J
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
$ j: R' l0 Z8 f6 {6 t8 \) t: j6 T: a! Z5 g6 W ^/ a
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !4 m4 _2 j& R0 {5 d
+ \9 @5 f) G5 `( e1 w; N+ x2 `更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
7 Y- t/ |* W" T% p- V: y" p ]4 y補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
3 k$ I8 {# W- ?9 r e1. 有 2 bytes(即所謂的M,N)來決定 VCO6 ]# ^8 o' {% U5 x1 w# C0 ]
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div% p. a4 `9 x8 w9 m4 e- g7 [5 Z, u
3. VCO / div = frequency
, I7 Z4 A" e# G* p0 s# i) M0 k8 |) O
How to access ClockGen
d' A' ]9 ~6 R, P=>現今存取 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 7 K; V: p4 f# H2 P7 Q
% [6 V" d1 {% J4 x, R Y
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:9 H5 ^) L: l; X; G8 \- S: p4 K
- pre-init( clear status or ...)
8 b' \( I) g- I J5 `8 z- put slave address(要 access 的對象) 6 u0 S, k U" T' o8 C2 s
- decide Read or Write) r: G# H( k* S) U
- put command(Protocol type, Ex. Block or Byte access)
: G& {. Y. Q% G% B- put offset(要存取 自 clockgen中的哪一個 Byte開始...)# R) F, o; R Z9 F
- put data if (Write device)
8 d' a' h- S1 M. p- start transaction !!!
! a# ` \0 t4 _; L* r+ w- f(... processing ...)
* F. ~: R7 B [/ o7 L; U8 a. a- get "Complete" status to check if transaction is done successfully+ i5 w2 k# K1 u/ |- c/ u' h) Z
(...wait for system reset...) 4 J& z f' f9 K( _" b( j6 J
' f* W, I! C% ]+ ]2 V
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.+ c9 h1 J) }* R$ C6 _, s
; G# \1 n& }, ]2 V1 J- k透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.# J/ ?! V- \/ ]1 l3 M1 K3 O+ R
1 ~) L B7 L* t) _( K I: a
[2 Programming ways for clockgen]
" [- f+ G7 T/ P* B5 i& N. x H/ u' O=> 現今的 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時會用到
. s" y" K- J$ x q R/ M' Z7 o' ~4 W3 F0 A) j7 @' S s
【Notes】0 C4 D# v: J/ j
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings p: d/ m4 z3 z5 v5 }
; m) ]/ B5 C* h" f2 I5 I9 l更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
0 q1 {9 i N4 Q/ }. O, E* ]( `5 n$ ?0 b' c" |
! d' m3 f( s$ D% K4 R1 ?9 k3 [2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
6 y" r1 Q, u4 m) J1 E# S+ B. [
6 Y7 T7 {! a& m1 D" O給我正確的頻率,其餘免談 ...^_^...
' c' s( E f. S2 \( B
1 I' X/ F6 F! b9 h* R& Z2 W=====================================================================9 m$ P. v4 B) N1 m# F9 r
Q&A
7 T. n$ P1 A2 j3 ^) h=====================================================================% b- F/ _+ `+ B2 t
>前輩我有幾個問題要發問!
1 d2 q' S2 X# n$ P/ L+ j>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
/ ?! G0 [/ M6 R ]>
" n6 }; I4 b9 i6 X! B. ?>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
$ U7 Z K1 R U7 l* U3 F2 j>
- ]* ]' A6 l1 c/ L) s>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
6 v1 k* U w, ~7 A; v7 y) v, h>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
: M2 B& `8 Y" }' n" R: J2 E>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
$ y( I8 p# v* `5 V" b3 [2 V" b6 j) O" K$ n' T
[For #1]) H Z/ P0 l' B R
=> 我所謂的 "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 !9 S9 t8 j7 u3 I. B/ m! k6 s
& X( D4 N6 a) d. Z8 Y此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
; z" n4 p) P& x0 w- ^% c5 f; v0 s, \& Y9 d0 u5 _1 I0 I
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
3 I( O% S' U' q- {2 a
. P9 n, @( T% o- e0 v8 Z, ZEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
$ l8 v5 _: Y- ^5 s4 c& V3 h2 O3 B; z3 x/ Q
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!/ g+ s' Y" r& y/ W( a+ y
6 e% `& x* Q+ o9 {9 _, n4 MFor #27 o! D- t, S* ?% _6 Q
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
9 j8 X* Z4 A7 G) V2 K5 c(...想像以前學的直流與交流的訊號...), N' H, b; d4 u* g7 d8 I
1 z/ f E& i8 f" k100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!0 T5 y7 M/ P2 W2 B- t- F# o
! r( g4 K' T: u
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
+ ]; S8 |) m7 V0 e8 t' y% m& z4 Q2 e+ k+ A/ X3 }! f: d& l
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )0 {' y( e) p% h- R/ ?
$ V" v* j/ H8 k5 G( |
For #3
! ^6 o3 P+ q2 M/ v=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...3 @3 L6 E c: E( e( y
( C8 R- s; b7 `& N- R! v0 ~# G
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )' Q5 t) r* r3 o. j1 s
; o( y, n3 B/ D8 P" q6 z[[EMI 測試的知識]]
6 X- A& Z. N B) b+ V由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. . l- ]- Z* h. E8 j
$ l6 I1 }& f) y& I5 h9 }: q
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.+ N* s6 g4 E B9 j" w
. K+ M' U+ f" I E( W" _至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|