|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記., x; z ]. }! Y
1 v! r+ z) X. K* ]) l- n1 k, g+ s在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
: x1 y8 H* P( `( p! s- U" m2 \6 D, e S- |. G& r/ E
有哪些 frequencies由 clockgen 提供?
3 ~6 _/ o, `) E, ^) }- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)" R1 |/ e$ T, D1 q
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)4 R! T6 q9 |3 g0 ^) z
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.' v; i5 R' s8 R& ~- ?$ h7 T* M# N
. D+ h0 s7 h0 z* @, f& w. A* i
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
0 L i* l- N! q( S2 Q0 Q' JEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
5 Y) [0 `6 @; f3 v6 Y" W" X
! u/ ?8 B, T- r. b0 h( |- _- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)3 q9 P2 x+ `: w' P$ m9 R! a3 @
- PCI clock: 33.3MHz
. {, y2 P2 u# ^- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
8 ]+ _& Q; V" `7 e ~+ Q) ?- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
$ a7 e N" X. e- USB 1.1 clock: 12MHz
' g# G' b6 B- ?/ L/ I更正: USB 的 clock 是 48MHz" v( p. B3 C# Z+ D9 A
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !4 W7 D* ^6 L" F
$ z' c( F& b1 b/ D
- SIO clock...etc: B( c7 j9 s9 y+ j) U3 f
, }2 s. I" W+ AClock Generator的架構! U) q7 N7 B8 I3 X" k5 x
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:) K; L0 i) S" B0 U# Q
7 [/ p' q- w5 T1 m1 X
14.318MHz -> PLL -> F -> Div -> f+ J2 v A: h) y! S0 _& a4 g
/ B/ J0 s/ M6 o" o% z5 G+ iEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz% H# X/ o4 c2 ?! r( Z1 ?
' a9 N' U5 q3 X" m1 s. C( Q6 CClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
) J* `9 a6 ^& e+ a0 j& k& A( v9 v }
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
" D5 R3 w7 P+ Z+ k i6 O/ X, J補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
9 U# s' j. W7 W* J S8 ?1. 有 2 bytes(即所謂的M,N)來決定 VCO
% `' v6 S9 b* Z: y1 ?2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div: b, {9 j7 E" n: ?0 E2 G
3. VCO / div = frequency
8 D+ }" J1 {( E9 b1 n/ U) h7 n' `9 ?
How to access ClockGen
; N( Y. z: ^, M1 P& d- y6 y=>現今存取 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
. Z5 e9 |* a) x1 c, S
7 n" D: w6 l5 U9 n不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
3 v4 W& t+ ], }% s0 H- pre-init( clear status or ...)# L0 g+ I7 G( d! o3 X
- put slave address(要 access 的對象)
. X, A* j% t* E, F4 Z8 U; o. X5 q- decide Read or Write
$ ^6 Z( Q! L( i4 N- put command(Protocol type, Ex. Block or Byte access)
( d3 n* C2 Y+ Q1 O3 C0 j- put offset(要存取 自 clockgen中的哪一個 Byte開始...), q) ~9 V) C2 E4 ^1 k
- put data if (Write device)7 S( J# h* q# l+ J; ]9 J8 F( S; {
- start transaction !!!. q) J5 q/ b( W/ {, F2 a7 z
(... processing ...)" c# P" _4 B5 m+ H# ]5 ~
- get "Complete" status to check if transaction is done successfully
# b; G8 t& p. m; _4 ?; d" U" g(...wait for system reset...)
, d7 Q& d8 m" i! H8 M* `
- t$ s/ ?9 L' s* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
% |: Y4 O, g% O" D9 M! S4 ]! W9 W
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
# ~' G) d9 T; T0 J6 [
+ b( y/ v8 F& ]/ b[2 Programming ways for clockgen]8 C9 E4 m# G6 _$ y9 K0 o9 _
=> 現今的 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時會用到
9 t1 f2 U2 r, Y! d; T& x ~ R! S9 P, Q1 N8 P* W& e1 A
【Notes】/ e; N, j. Q2 g2 F" w0 |: v
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
* z: _% B$ \; d% c/ M0 c3 u2 `( c6 D: x+ f9 L' w3 e8 q% C- C
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper" u' u5 E0 ]# H2 J9 K% B; S4 u
v3 n6 I w+ p$ S5 C4 V& j
& o7 k: c S5 ]: e4 f3 v
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
2 J7 C" k5 R6 C3 \. \* p" l
+ k; ~, l0 ]; M0 Y1 @3 F/ X* ~給我正確的頻率,其餘免談 ...^_^... % Z- Y! M; q$ ]. Z ]
4 U2 ?) `: Y8 x( y8 N5 z7 c2 r=====================================================================. ]; F% }4 h! B) U4 t! r4 j; o
Q&A0 X: g, J7 ] {* G% q
=====================================================================5 ~' T9 q' k1 y2 a# C" G' G
>前輩我有幾個問題要發問!
; J, a* G( z1 I>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?$ f G3 w4 g+ ~6 J$ W
>
, A" u& v3 l/ @( S0 C>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
! v5 l3 H- L8 P7 P>
4 |% R% _4 J- q>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
) }, y% h& e5 P7 ~4 V* a8 C) y>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠+ v |+ l7 r6 A
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?2 D7 Y: t m1 [: M h& z' u
0 F- R8 ^0 c- l* E Y+ F6 Z2 t
[For #1]
% i9 \/ _5 S7 `: P& a# U=> 我所謂的 "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 !# W3 N1 X( ?/ B; j8 L& n& C+ }
( c8 ]1 `" i. U$ D& \* z2 h" C
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.7 s- @3 q: z8 }2 T! s0 P! v6 o
. B) u5 G! `# ]& J) P6 L* S不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )/ [( t |, G+ z9 i
8 S o$ e+ {. mEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz4 c3 y% j. o- _: p/ c$ F/ X4 v I
- [9 I+ w8 K2 ]: ]& ~. u) s3 m還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
0 u/ h2 Y& B/ ^* C" N2 ~
$ {% J. _. I3 z7 ?+ z& f- qFor #2$ U: v' B+ M- I
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:$ w% O! J6 B& b1 `9 g" S' T, m
(...想像以前學的直流與交流的訊號...)2 @% }- F1 X0 q& _9 G) r
* J( D/ c1 P' ]% o* e
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!6 J2 [* @9 n3 E! }& \
( g& F Q( W% k0 L% }我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
6 O2 X$ r! F; }7 S1 v4 t# v1 l: L; ]; g5 D3 N5 z
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? ): I e4 Q) T4 ]7 E; g5 b5 _
3 ]5 Y4 \$ ~7 f
For #32 H2 x2 \; r" ^0 z, _
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...$ t9 a/ @5 y& U8 o
6 [1 s0 `2 S) @" N* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
$ U$ ^& M% q2 ] d4 h7 ~/ c6 |
- O- d, M4 \/ z' y[[EMI 測試的知識]]
0 @% {3 `8 Y% B. d) { g7 e3 v由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
' ~! D( t/ l ]' V R
: r x! {, w/ l" I為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
# ]; V0 L( e: `$ k/ l
3 v! R; A3 _' t! B. n. H! d至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|