|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
" B8 t# a6 k2 ?7 e. J- F* r+ B' [9 @) A* v' }
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...+ ?7 a' f' t* ?# K1 N( J
5 j( Z& ?5 x s+ W, f1 @有哪些 frequencies由 clockgen 提供?
( { o* a: C/ d# q1 j' q- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)7 g1 }. v4 q: J9 p
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)( L0 T* J2 ^5 x; s6 w
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.. \$ Q g: o& p2 I5 t
. Z& t* T5 W# h% I1 t/ @+ R9 m
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
1 E4 g( T! Q# k, {) @4 g% ] NEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
+ `. b1 `7 E! N- h. @) x: A: t, v. |) v, y t. Q; ~+ q
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)& W6 c% S/ r" F3 r
- PCI clock: 33.3MHz
' E+ E( v& d7 J7 P! e- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
; D/ x( D P4 g( Q Y7 v P; ^- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供 G8 x+ i1 v. T4 T- o' P% B; E( Y
- USB 1.1 clock: 12MHz
3 [0 X: q. b/ t) x2 A* f更正: USB 的 clock 是 48MHz
. P J! d3 g1 X4 q; }補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
; t' w+ ]/ c4 S
/ M: N' f7 ]% E) L- SIO clock...etc
, c& j. E6 F9 w9 W) e: [. B2 b
' O6 T" { e5 ~1 W/ \" D2 WClock Generator的架構
( `$ V) v% @; S A: n& S, U=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:7 z% x+ Z' z+ W* F* l
; J9 h' c7 a0 g1 @+ ]# Y
14.318MHz -> PLL -> F -> Div -> f
! O V7 A8 @8 L
6 b9 |2 ]( u9 x: D4 d' U% W; tEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
! N0 o( [0 {, t- z) Q9 C8 C- r% ?. ^/ N3 G# o. J+ n# m
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !/ _5 V% _; {3 U0 S
9 A+ @! K2 ]+ z$ `" j7 e) C7 B
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) . }8 S2 V' ` ?
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:, I0 P, I2 t+ I: C8 A& j9 ^
1. 有 2 bytes(即所謂的M,N)來決定 VCO8 V! X& w- N$ u. ^5 ~
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
- ~# y* G+ h* b! C3. VCO / div = frequency/ e8 l2 y* j4 f1 H( [, ^4 J" F' M
5 y; e: K! \2 O3 _+ c( D0 S0 X4 B
How to access ClockGen+ C P- C p9 `. w+ H6 K3 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 8 ~/ {5 H# s6 N' l; _: ^) B' A
$ \! C- {, b2 E3 o
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:7 K; o7 u }( @' \/ p6 T" M/ Q! B4 U
- pre-init( clear status or ...)
. W. A" W% J7 w% k- put slave address(要 access 的對象)
7 v6 _! R' m* i7 p8 X- decide Read or Write
/ q' H( `, H9 A- b% k- put command(Protocol type, Ex. Block or Byte access)
3 ?2 t8 v8 Q, Z0 e- y( x2 R, v- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
" q/ y2 @9 u$ E' J5 J- put data if (Write device)& M$ e' H3 Y' b
- start transaction !!!2 x, T& ]) n% I
(... processing ...)
: v0 l$ \& Q+ ?3 f& [- get "Complete" status to check if transaction is done successfully7 t- Y3 f( \1 d$ T. l- |( u S
(...wait for system reset...)
) D4 b- H$ t/ D9 s; Q [% Y5 B* _' p
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
" z! N f0 ]- y7 U4 w7 i, X8 Y2 n7 f; e4 ?! v4 T
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.8 W: a5 R8 Q7 f
! b5 u7 p) k, D |. l' q[2 Programming ways for clockgen] g; z* U) J* C% k3 f& H& {% v
=> 現今的 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時會用到
$ M7 i! P8 E% y; m( j/ o8 r: ^( l. @8 C. W! X9 w4 k
【Notes】" M( M, L Y, R
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings! Q7 v" U, u) D; M5 C4 _
- a- d5 V* W$ y1 @
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
+ W/ Y) W; ~0 t; V6 i4 i" Q9 q: S" u6 x" ^1 m
- L! c! c, t2 C2 E( D2 H7 B2 N1 |2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成8 O7 [1 r! ~5 }- S
1 n7 e2 e* _" x6 w給我正確的頻率,其餘免談 ...^_^... j) x5 r- K6 V& A
3 Q7 a* N d0 @3 b
=====================================================================
3 X7 u( j" O; C2 i2 JQ&A
( X* @: T8 z2 V. u& `1 l=====================================================================6 K$ `% B0 ] R1 d5 n/ D4 X' C
>前輩我有幾個問題要發問!
" _) O& d6 A* O& ^& z$ {>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?6 ]" s. E7 O# E1 x$ z3 m) } C( r
>( a; E2 C/ D! _2 B) x
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
5 B- k0 w& ]. h7 Q, L5 P>
8 J* f5 I; ~- A6 l& b>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以7 e: ?' L/ B) V! N7 U
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠 A7 I2 h) T7 h
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
0 m" T# n; h( Y" O: I4 c+ s! k3 K% D, ]; [6 Y
[For #1]" J: O% L- h2 d
=> 我所謂的 "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 !4 q- `1 G' ?( k: Q' Y7 P( Z0 t
1 m$ A! `/ [3 B, X0 {' f此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies. {6 p( Z4 f2 ?+ y7 O" @- J% X
: |( h( O: P v& @9 C+ x2 O- U6 [不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
* P& c' Z: T& K" f4 O' D, H& a5 e: c" d& n- S& O- r" g3 Z! j% [% O+ F
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
/ q* a! h$ s& C: J' R: n
- v9 g) P; J H& D還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!. e! e( q, S _' h9 c! q. R0 y
! Y9 o; z0 f M; n
For #2
6 v" g$ L( h; a=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:& B% B/ G' e% e
(...想像以前學的直流與交流的訊號...)/ T7 {5 n6 W$ K+ X8 \
3 b. Q2 X- {) R/ y$ ]2 k( {% i100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!) E" Z/ M: Q2 V; B( @' ]
0 k; b* @# I. B我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等5 V# ]. h, O3 H# N& F" Q; y0 x
9 o, ~$ h) h) ^6 s/ Q" yDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )0 v: U+ g! {& g: R2 A
; N/ o, G O' `0 {( r' h9 ^+ R) sFor #3
7 G6 ~7 U( n9 ?: L0 r4 b=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
' T1 s8 Y2 o3 q! u; r
& \! k2 a$ {1 N* N7 g5 ]4 v* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )7 i3 u3 w$ p: y% D. o0 k; J5 e/ p# X
2 w, C8 L- n4 Z1 f9 |5 j
[[EMI 測試的知識]]& X D( G, `; K- J1 [- @5 }
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. u* ]; a+ c: X! `* j$ \
9 l8 |6 D/ z: T& }! P
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.- u3 \; ?# j( c4 ?
, [# `- R$ p, W* m5 K! H
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|