|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.3 s* D! Q5 X4 H' p. w
" U+ Y* z$ C, ?在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
: e$ g) S9 R3 F9 t9 j& \* s! Z: ]. A: p5 l J1 Q: s( \! A* s
有哪些 frequencies由 clockgen 提供?4 y) D. s8 T6 q- k4 N2 W) F
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
. I, H6 q# r1 U- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
$ T4 g' s6 W, z" w' S7 E& a8 D* q/ d更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.9 A- P/ @) c% V j
0 U; L( Y/ ]( l" P1 Y
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.& U2 x N2 s! j; g
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
6 T) W( c. o5 b @2 E0 E0 g- H( q& z7 G4 E; }% x. A8 t
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
+ q m! A; k! P1 o$ B+ a8 f1 p- PCI clock: 33.3MHz% A: P5 A {& y: u* s4 I& o
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)4 A' E6 O [# N- Q
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供( g, r7 g( l' O* T, b9 s7 D' G1 _' }
- USB 1.1 clock: 12MHz+ T7 h y2 y1 u7 H1 @4 W
更正: USB 的 clock 是 48MHz
- Z! x, }& H% k1 q+ J. y1 V+ g4 f補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !0 {: S; l7 z: O0 ^9 W8 _; Z+ `0 M6 D
) C+ o9 S. V5 {; c+ Y; o/ z- SIO clock...etc; ^' E/ C" o% J- s4 o" ]$ G9 H
& Y& V; W; Q! EClock Generator的架構4 C" P% b: {. r5 j. V$ R6 F- s
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
% U* f0 j+ d# h$ t
+ i& g: \, u+ w$ j" d0 b+ ^2 t14.318MHz -> PLL -> F -> Div -> f
# V) b! [# G5 s q v- L0 q9 j! G9 z# G2 ~2 [
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz1 s% F/ M4 i. \1 V, [% \" L4 O6 m
+ |+ {' S9 V( P' o- G4 x
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !' t& P. p. ~% L& o% ^: [, `
: o+ j/ M+ G, Y1 `更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) + F) P% I/ f, I8 v
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:! F* v# v3 ^ Q6 I' _
1. 有 2 bytes(即所謂的M,N)來決定 VCO. b) e' _4 I" A0 c) x- o
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
4 P9 h$ g* I( {9 m8 E3. VCO / div = frequency' P3 P! { q c+ C0 G. y
3 i8 j# `1 O% U) l! g" UHow to access ClockGen
# q7 }% Y0 p$ e* G- z0 X2 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
( d t8 y1 y9 |6 J( I: a! b( p1 G: Z% w* M; p
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:3 n( c$ p4 A( z; J' w
- pre-init( clear status or ...)" w1 q( V# I1 n. o# f
- put slave address(要 access 的對象) 1 x! X1 p% U6 ]2 o1 f' B
- decide Read or Write8 ~; z$ x4 h& @
- put command(Protocol type, Ex. Block or Byte access) s, @. A% ]2 O4 z+ B
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
1 U6 @$ I6 ?, Z) i6 v, k- put data if (Write device)
8 g4 Q2 w' i( M7 b% _ U& N% O- start transaction !!!2 q$ j5 s% I. Y& ~/ g4 d5 y: B
(... processing ...)
$ C, k. j4 S x/ ` j/ T- get "Complete" status to check if transaction is done successfully1 T2 o/ w$ v5 b& R! d- @# ]
(...wait for system reset...)
* `& I+ }* h1 U: [
# Y- q) h* G3 ]( D( j7 s+ O- {" z' e% l* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
8 S! i1 h; z6 D
- V9 l a3 s: g& F1 [' s" T透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
6 F1 n3 l- ?! E+ e K; i( @4 V- J, _, W
[2 Programming ways for clockgen]/ g2 o; C/ p6 k( q1 z/ ?6 r4 U& s2 [
=> 現今的 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時會用到$ B7 I9 ? Q# v
{, ?& h3 b) @1 d3 D% N【Notes】
, }: I- p' d% |" ?1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
" [ N @( @1 X& `+ V! _% u# k
! A; u" P$ C0 {4 r更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper* n' Q1 L( n8 E# R
6 s( W! F+ B& k9 N) P
" @) }2 W7 _7 f* R- U* c& U
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
9 o: {- w+ a2 b1 J/ k0 ~
& ]0 u; b1 ?# d; b2 ?5 Z給我正確的頻率,其餘免談 ...^_^...
( F4 J7 H; V P
1 n0 {2 @- ?( P$ R2 n! H=====================================================================
7 E X4 y8 o7 c4 ?- p. T! U$ D: a3 bQ&A0 B4 m& U f7 E" }; x. C
=====================================================================
' ^6 t, c, Q) ^1 t/ @4 d% X% R>前輩我有幾個問題要發問!& J. J. @: A1 U& |
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
. |) w! d; P. r) V' I>; I4 M4 S0 t# h" x$ r
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
1 H8 {( M, u! C% f6 w; }>
0 G) o) E/ y. `, Q$ T7 V, {9 I>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
% C# @) P$ y3 ?0 l2 k1 x>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠! I9 ?7 |6 R, k8 `2 k6 e) w; u
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
2 Q) `; i' a( ]8 N) k; @: ?
* A( _/ m7 k) y! G) e- {7 X[For #1]
" ^, P0 U2 j/ u, E4 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 ! C3 {5 t& M. j* _- {3 d, L( n y
# C+ W$ H( P- v! ]5 J# K# B
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.4 e0 b* D: V4 i5 ~
/ z9 i( Y) `3 n- C+ t
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )2 E& G8 e9 B% q1 }8 {
/ W- O; j& ]1 i, b* z) ]- S: ?
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
: N2 V! f- M( ]+ n
5 h% P/ J* ?3 ~* h% N4 N* C還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!' l/ P3 X, b9 c( [) @ ~1 h
% B0 @0 o" Y) ^4 y. l$ w: k3 KFor #2
( O5 f- U( A' y7 \# K=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:) D9 i8 l# f% R2 G! ?
(...想像以前學的直流與交流的訊號...)
' e% z. |9 k+ \, @ ]0 w! K% S/ K7 D: J# V) E3 q% K
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!% H5 Y I& ?; W
- k; e2 E0 S5 j) d- w
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等0 N$ L E( L- I$ q& H: V6 V
: t Q H$ K* ?# S+ ]' _- r S
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )" B; r1 K% q2 A: s/ P- g4 k
2 U" |8 U. f7 UFor #3
# \1 u$ B* `5 [2 X/ E/ Y/ V& q=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...5 |0 v3 Y/ h# y0 i. o6 S( D
% p( k; p8 r8 S* s! l# g( l* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
3 j, o ?! N. x2 t1 `" f0 y& f& F: ?' Q2 M8 w2 Y% E& e4 J4 ?9 k
[[EMI 測試的知識]]
* c+ p8 ?0 _& f' O由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ( \) F6 L- W2 n9 P' c% D# x
) y }; X/ e4 B
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理. t" {! {* U6 c4 R, J
" e8 @# @3 I' g5 [( M至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|