|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
, J" L" F' k1 i2 L( @2 z7 S
( D6 c1 H: P+ U1 e在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
' }! u T9 j4 W, Q
) V b9 _8 c1 Z ~4 }有哪些 frequencies由 clockgen 提供?1 h; a/ {4 A( s; U; c4 S
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
( T% c) K0 q; F* ^$ V Q$ s( I- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
! X9 ]3 V+ `' Q1 j: e更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.2 ]6 R5 P6 R8 q
! A& W' m7 X+ D( S g% N
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
1 E( ?. {) N" l" {4 |- jEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
9 s- @1 t1 s8 {
5 _, F3 t ~1 j1 I) v, d- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)1 h ]1 a/ d+ [! ~" f' D
- PCI clock: 33.3MHz
) J1 ~( E7 Z1 P/ B8 I- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
2 a3 e4 \; h& T) P# S9 H' X- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
9 l0 c( `$ v8 F( C; z# O- USB 1.1 clock: 12MHz
3 f* U- `! F0 ?. X5 q更正: USB 的 clock 是 48MHz% h6 H! w7 q8 r( a- H: g8 z
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !& R: X4 B4 _( p, U/ F( t
. c. r: ~, d" A# `( ~( u; ]2 m: {* G3 {; l- SIO clock...etc- w) F9 q! _4 }! H5 `
5 l1 n$ z- M6 R% N0 ^Clock Generator的架構
0 w# D* k2 e# \=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
' h6 c% t1 f- ?3 j& w# w
6 {/ q: P! o" l& R7 j& P14.318MHz -> PLL -> F -> Div -> f0 }) F- @6 v* I, p/ m, W
$ O3 d5 |- h; W2 ~! i8 i
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
9 D" d3 b) U' [: ~- @" N( ]: F. Y( E$ }5 f _. Q, S
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !- H( U# q; o: x" C' L
% y& h$ U3 d% o" b' l) B0 h更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 7 B% g! n8 ]) @3 J, `, `
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
/ F& y! |* {+ E& D% [+ G1. 有 2 bytes(即所謂的M,N)來決定 VCO2 Q! [, f+ S3 C+ N5 g2 D
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div) H5 Q. d1 H+ c! Q7 X. y$ u! }
3. VCO / div = frequency
5 u$ a! g. v$ {9 j, @! M% z. J- A* ~2 K0 G
How to access ClockGen
+ a, `2 T; |; E; F- j; {=>現今存取 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 ( R' u9 s; g' w6 D$ M# e
R% g9 s& U0 j2 P7 t/ C
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:. s" g# I" o& k! |( Q: h: ]
- pre-init( clear status or ...)
# V4 } O) V9 P: ~. r, |- put slave address(要 access 的對象) $ }: j- s$ [2 L
- decide Read or Write4 d% H) A. h v* N8 o. [4 j
- put command(Protocol type, Ex. Block or Byte access)& o/ J8 M7 p0 R7 n
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)" q- m1 V# F5 g
- put data if (Write device)
( M& t+ S3 A/ X8 V b) {- start transaction !!!
! v6 y4 u& Z( ]5 J# n# V; h(... processing ...)0 S& ]& k; M5 P- O8 \
- get "Complete" status to check if transaction is done successfully9 J" ]* p; o5 x" V
(...wait for system reset...) , p7 ?( y; A& c9 x; Z v
# O: _2 w* n" w4 W( b* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
$ U. X4 Z5 ^4 y
: H; C$ z$ o" [- n/ F0 c透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.7 S) r. j+ q3 ]2 w
& n3 J4 k ]% ^1 I5 H3 o$ `6 W2 t
[2 Programming ways for clockgen]
+ B, d' |% |# j& ~9 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時會用到
, q, Y2 D. _5 H; \ M/ x( b9 l8 @& u' h) @: D
【Notes】, S/ \( {7 E) o7 `: J4 @
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings: z; q, W8 }" a
5 O% P" @* g0 i3 F) P) h
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
, T+ q) h# p! V" l- @7 f0 x6 Z1 b) n, `3 s8 C
, ?2 Z5 v u% \/ ~3 z' q
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成2 u3 u. Y9 `" T" ~. t9 @+ C
1 W8 Y2 a7 T3 \& l
給我正確的頻率,其餘免談 ...^_^... 8 X6 E" v. z8 H+ x
$ a* r' G3 `$ _
=====================================================================
1 W8 e, v# t! j5 O9 Q& @( M6 _Q&A
# ^9 }6 n% V p3 ~: x5 i# g B=====================================================================
# P; X$ m3 U& G* v3 I>前輩我有幾個問題要發問!
6 Y# t& F6 J+ d. S* |+ c0 j>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
" M4 o3 H. h8 D B>5 k/ u# l& b1 @- o% c) q2 z5 Q' U
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
8 ^) L5 I; s4 g0 N. I/ P>! w I% j6 A r9 }+ {! T7 p
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以% U5 a4 _1 W6 u* e0 U
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠 ^ G3 \0 M- W( y; ~
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?" l+ u9 v8 H) i. a0 k9 C+ L
U. n. e& V- B# D" O
[For #1]& ], |1 k' N+ C/ V7 D+ W$ A
=> 我所謂的 "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 !7 }2 z, _% [' h0 u5 w4 r" j, N
$ D9 d" I$ u# d2 _/ ?- s此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
. \. A3 `5 m' N" T; {3 ? [+ r2 Z7 y3 N& F
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
! j" h6 G! ?5 a; z) w! ^5 `8 Q
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
9 ~+ c3 R5 l9 y- y8 o# Z" r5 s5 _1 w' m
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!* M; Y, ~; Y- @2 V
6 s, | M& X4 X% c G
For #2' Y3 O# {5 \( |1 B s9 S7 A' a
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
! }$ p# h9 b. j7 A/ d6 N( }(...想像以前學的直流與交流的訊號...)
: o; l" B& X# q7 T) |" J
$ E$ l: E) G, M+ ?% V$ P100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!# H2 d4 G1 ]/ J
2 y7 `# y' h6 A) N# ^. J- x我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等8 B1 O4 t- _" p+ t& j
8 u @% [6 W3 U2 q* m
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
+ [# C4 Q6 @* J3 Y) u* c$ I+ i8 b% w3 I$ O5 j* h$ H
For #3% _ T( I8 w0 n( P8 f8 `
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...) \: ~3 J9 M. W5 e/ S" N3 }8 [7 ?3 |# c
% }: @* K/ Y: ^2 l" P* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
V. Y( M, T1 {4 q: i
7 E$ k* P. R+ M; }" Q j; I; y[[EMI 測試的知識]] k" ~& Z# h. }1 u5 [
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 5 E5 M: Z: A* o5 M% X" `3 k( x% F% X7 o) m `
/ n+ i& e' Q% B
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.3 ]5 r2 U7 a& c3 E9 ~& @) x
" F) j# V1 P. n至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|