|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記./ S# x1 t$ s6 b% ?- {- V5 Q
9 Q" `+ J+ |: W% B/ r在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...! w+ ^" g7 X$ [% C! b u# o
# N. W2 a, u/ T. V# S) e/ v: |有哪些 frequencies由 clockgen 提供?
5 i( }8 [6 C. v1 n- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)* L8 i) G2 w0 U# c s0 W2 s' \6 X
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)9 Z. k9 d9 ?, \ d$ n" Y$ @
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.1 Y1 E$ E' B$ L! V, J3 b+ w
{" E6 E+ x" B0 ?% K+ }補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.: J; H! u3 h6 [; E2 ^
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz! x- E3 M) O% y$ S
7 [6 [: n0 f* s' t
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
) ^; W, r* ^$ K; g/ s- PCI clock: 33.3MHz$ U) G9 |* z: s$ V F
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)$ d6 q n7 Q8 W7 X2 |
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
' E- h# e, j {. g9 S. C- USB 1.1 clock: 12MHz: {: h3 w# W- v) N0 m
更正: USB 的 clock 是 48MHz
4 C: d+ U( ]5 Q; s& j$ Y補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !2 s5 l5 ~5 |* m. g" |
2 {; N* c4 W$ x3 O
- SIO clock...etc* S# t5 z" ]0 p& z$ r; z
: a7 h8 e5 j* g0 O7 |) u
Clock Generator的架構& I4 N" d$ b9 R ^% X" X5 d
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
8 u$ C/ O* I* {) l
. l" \1 c+ u- e4 c* ]14.318MHz -> PLL -> F -> Div -> f
4 u2 Z& |+ P: i; K; n. V! K1 S( k# O( t) z; w1 I) k
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
5 A. q. E Q- m" i h/ F7 v }4 ^1 \6 M# U" r
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
) J& I9 A) Z2 N& T1 O: j
2 Y5 g8 P# v0 r4 Z更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ' Q" r$ G! \6 L4 V- f
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:( R) ` X* }$ ]& M( p _' O7 J
1. 有 2 bytes(即所謂的M,N)來決定 VCO, n* G2 n) E7 i
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div6 d$ G7 _5 Z# |% B" |+ t% A0 t
3. VCO / div = frequency1 N0 z# q1 ^3 n6 @ R: j3 r
* N8 c- l" H, F# r, v6 v! ]How to access ClockGen3 F3 i5 X4 }; ]2 i5 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 : ^% m" z6 E7 y# i& {- D8 j
0 G$ O9 O1 H2 Y' `9 X |: d+ \/ k1 t不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:- p- f+ J& J; D: |9 q( U, ?
- pre-init( clear status or ...)# U- |+ `8 S3 Q' G' r% c3 }
- put slave address(要 access 的對象)
# Z8 c' C. I q' Q- decide Read or Write
) Z% ?5 W; T- q( p- put command(Protocol type, Ex. Block or Byte access)- ]1 h3 f9 C2 o2 g, H) F. C$ y3 |
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
! J3 Q4 F, ], h; G6 B+ }% C% `+ ^) o D- put data if (Write device)8 x( R& m7 d# n) N$ W$ O
- start transaction !!!
8 I/ e, ?' @! a# M; Y9 ?5 b(... processing ...)
% `' t# n' ^$ o3 d+ j; v! ]- get "Complete" status to check if transaction is done successfully, f+ z, t8 ~+ T4 x1 g( g, ~# Z, L
(...wait for system reset...)
Z( t0 m/ @# \1 J
3 A" D! y0 J1 _* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
$ N: b6 B* [& L
: V3 |0 E: e* o" I$ L透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
5 S# I9 `5 u# ?, x/ a0 r& A& ~ U+ h( k/ z3 s
[2 Programming ways for clockgen]
* i" R. V6 ~, U7 u$ V$ j4 c=> 現今的 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時會用到 H# X9 I' K& [1 r: U4 Y3 i3 z3 F9 `
% e6 l' D; o2 M8 [3 T, E【Notes】0 ^/ _& L9 y! ~7 `
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings, v! ^8 T5 m/ r) g( |4 X
a/ x- D3 m% B# `# G3 W' u更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
4 |" W8 t) E8 L9 r7 y8 h6 M) y# a% T H
' B! v4 f3 N0 a$ p$ A( n
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成$ g! G% |% |. w) J# P* Z
" X' w0 W/ E2 y5 }1 k6 u R
給我正確的頻率,其餘免談 ...^_^...
* e7 k2 f( x/ F. a8 x7 V6 ^ o% O# J
=====================================================================0 `- ^7 q4 r; P8 p* H
Q&A* @: d$ e3 d; a2 k# N* ?
=====================================================================# e/ S# s( G6 J4 t
>前輩我有幾個問題要發問!8 }0 {' m, h2 ?+ _
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?. a) m4 S" ~2 t# [2 y. h5 h
>
* [) ^* z# ?$ j4 ]1 @# o8 T>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
9 h# o) J0 X+ z1 G9 w6 C>: I9 N5 A$ _1 }: }& q! M! Z
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
: s8 p: T& a x* F9 s" |7 ~! U>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
/ Y% A, x9 z5 W- w>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?' l5 H' p* G- `+ v, V: g3 l$ m
8 U* Y1 P6 I; [2 Z8 c# j2 {* g. P[For #1]' U& P l- F3 i
=> 我所謂的 "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 !
+ p- q2 i: `& R) x4 b5 q! \
# [& w% U, T$ g7 @2 V% {/ t此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies." J) m9 a! g6 F M
. C% \# O" |6 E' ~不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )4 B( h4 b( Z) c5 H, }' F
! a, A- m* u2 t7 J0 X7 h" I
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz/ C& Z w" Y7 B. N* R# j( Y: g+ Y
) F- d2 l' v! D, K. y. K3 G: @, m還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
/ Z; A" u. n% l1 f2 k8 a9 H" L2 r9 V- J3 n9 ?5 O w9 |
For #2/ ?0 K( o; J! p9 A0 I* p
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:, y! S7 {' @0 N" t" }
(...想像以前學的直流與交流的訊號...)4 n/ ?, e D% t! ~
+ i8 r; Q4 L% |4 Y! r/ B# z
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
U0 ~/ |2 K( G( n @% F6 b
: A h4 n- T- k& c0 }0 }我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等" Y. Y5 u [" B' o4 P4 w+ D
' r5 O7 J* C, ?3 P! @$ cDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )6 q1 U7 Y8 H- J* m
' r. E M0 ~0 b
For #3
9 y2 C4 p0 g; N+ J# x- l7 ]=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
# j2 Q: Q- a0 A- S& R; c
3 E3 Q9 o2 B( p- r* C2 j* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )# L$ U' W) p8 m- A4 m
+ E5 ^9 {6 [7 z3 j6 i/ ~
[[EMI 測試的知識]]
6 J* O* {) q, `- s2 X6 n# l+ h- N由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ) o( N* |/ N7 K, d- D' q, k
9 G% S* b5 t: i% a! k) T4 z, R1 T/ a為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
3 i3 @6 v# S0 o9 y7 c! P: [: J( W* J% I2 I& G4 D
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|