|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
* _0 D9 n$ Q! U- B+ W: S: t7 o, Z! h& z% A' O" O: z
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...0 D& h) g( I; I! C# I, F. T: f+ c
1 ~/ f0 `9 A6 Q1 c, h' r有哪些 frequencies由 clockgen 提供?
3 r/ v9 b, V, Z5 i4 M- u. L- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)/ n& \1 M K; a' }8 q2 Z
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
! Z9 R) a$ Y) V更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
7 ^: h( z/ R* D- T4 f
! J4 e6 @8 r. ]0 c' A. F' A, f2 B補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
/ n) F, N, |+ i. a, Q4 w& IEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
+ a0 o2 \1 E9 x' d, F
8 T/ m* I: y9 W# g+ b8 d- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
3 ^& f3 o$ A4 E: j: f- PCI clock: 33.3MHz) c2 z. h9 ]/ W8 q# b" G
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
6 s* a, n6 Z( P, {- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
7 X' N. l, T3 H4 \! C% @- USB 1.1 clock: 12MHz- I1 ^# D% K M7 A( L+ _6 z
更正: USB 的 clock 是 48MHz
" Y2 s' s) @- {6 ?1 j補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !7 }4 R N" S- c i) h2 ~
* ?( q4 c& c2 F- SIO clock...etc
1 }6 }9 X, t( R5 ]
3 |& l! R! T9 [; ?$ S- f% S: lClock Generator的架構
7 V4 ^0 g. t" ], q=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:) `5 w$ N4 h& G9 v! d4 M
7 E* M; p0 Z, Q* p9 @+ O
14.318MHz -> PLL -> F -> Div -> f
& \. k- `/ m/ X. {% j2 I7 u s$ l7 W4 I, T2 E8 ~+ b
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz4 j6 y* s; |6 @3 g5 L
) e, |; d [6 E+ F4 ^ TClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
" z2 J# h* A. | ?$ r- u7 h! Q- W' i& G `& n. _$ |) M
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
+ q6 j Y/ P; S補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:8 f8 C6 ?2 r% s- J
1. 有 2 bytes(即所謂的M,N)來決定 VCO$ `% T6 d; s: y* o7 U- T. N* ~
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div) J" R- i1 U. b1 u+ e) d/ A8 L, B
3. VCO / div = frequency
8 d y- j. O$ H, J/ y y. ]3 z, }* C% L+ U
How to access ClockGen1 S3 e3 J% k w4 Z) u$ z1 ?
=>現今存取 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 ( {( A: }+ q! Q1 V. M6 u6 E
5 {8 x$ Z4 @2 M1 |4 e- c不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:9 I/ }( S+ O @: j
- pre-init( clear status or ...)( D" F! g% R) g, P7 [! g
- put slave address(要 access 的對象)
% G0 D. I/ P8 d3 b7 U2 e- decide Read or Write8 y3 o" l. n7 q. Y' T5 j: g
- put command(Protocol type, Ex. Block or Byte access)
4 Z2 E! ]! y( H- {" [* F1 W- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
\3 J2 ], e7 n% _2 j- put data if (Write device)6 z7 W z/ F( b. J% U& i
- start transaction !!!
/ u/ ]3 F5 L4 n M5 M5 c(... processing ...)2 M9 a0 u! j0 \$ O( Q- @
- get "Complete" status to check if transaction is done successfully9 x# |8 q0 r1 b) ]. R7 k& ~+ f
(...wait for system reset...) 6 e; `/ P+ m6 J; w
8 U$ v5 ^/ A5 g* ^
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.) g% K6 t% u2 Q
7 Q+ D3 n$ v) r" @3 U& W透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.( F8 b/ B4 Q* v. k# G
" b8 K+ r% l/ h: ~( l- W/ T6 C# k
[2 Programming ways for clockgen] y+ {- t e7 S! P
=> 現今的 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 R+ y1 I' n' b
* @/ m# z1 M8 t$ u; Q- r【Notes】5 m1 y0 H7 ], L
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings; E5 B# ^: k7 |7 O5 n) |8 o
/ Y! N0 @/ l- K" ]: I/ f, _
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
: r& o# j( J2 T
1 M* O. u; v c. D8 {
3 _0 b! j9 M& u C1 Y2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
2 l* X+ }+ e9 x w k6 t6 |! m# }, N1 C8 ?7 @2 L
給我正確的頻率,其餘免談 ...^_^... " t0 o& c: x: U: O. a0 y/ l
9 |9 F3 ]1 W1 ~1 u8 C1 T7 ~
=====================================================================7 d0 T; K+ \; g: u8 m
Q&A
3 {4 h) a) G8 D$ f/ M% V=====================================================================3 P" P3 \( K/ Y/ v
>前輩我有幾個問題要發問!6 X" |/ w6 F7 M7 c4 x, U1 P9 M; `0 ]
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
8 r4 X: w5 X0 q: t3 M/ Q>& M0 y# o+ e7 X$ V) V3 C
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?. J) X3 B$ D) M6 K- n: ]2 a
>
2 X/ R4 m/ o, g& Z" P2 g; ~>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以1 t5 D( _- H7 K, l8 F5 l( q
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠8 V1 X' Y9 \& |; ^: Q
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?7 ~. J# v, g! s+ N! n( f5 q
7 r! O0 ?2 v4 W' ^[For #1] x q1 Y- `+ S; ]
=> 我所謂的 "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 !" r( j; s$ q& h8 p9 r; n0 Y+ p) @
% s4 n u% o: I( }5 t5 T! j' ]
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
# I2 S6 B/ p6 e' T
3 H7 `/ f6 Q7 U4 j9 c4 U不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )6 Q! O& F( X& t. W1 ]. }- i1 ]
5 H% z5 a" s) K3 |4 QEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
. K9 C" ]% g0 J, W4 g( a, u4 N5 n1 l3 n3 H" k9 M
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!: e) {! J7 E. {& r4 s1 _
E" }; r& o4 @' F% s4 xFor #23 t2 C0 \) {! A
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
, a4 L0 D N7 D+ D& X0 k' j(...想像以前學的直流與交流的訊號...)
7 Q: {1 g# B- r. W2 s1 ^6 w" y) I) G; L
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!! `4 f' S, ~2 {3 a+ G
. h% O9 {; G) _# t' p2 y我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
& `6 z* x. ~) Y0 i( Z# k: K7 b0 f$ B4 `) M+ r- n
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )* P0 E8 T5 c* j! b g. P( Q+ C
. }+ A) K9 m p; O8 Y) W/ AFor #3* v3 K, \% t; ^2 Y+ J* Y
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...0 |8 m, p9 Y$ {* M
. a# Y" e0 A( F4 q
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
& L9 C S# h" ?* A3 Z- Q) ?, l& h$ w$ \8 |
[[EMI 測試的知識]]
* @ v# B& ~1 a由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ' }" C/ A7 A3 K- W) V& M
/ U5 n5 { f% }5 m8 `為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
2 |( j" i! C" _% z1 u- N: d0 y# u3 i9 T' `5 l: m% H
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|