|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.4 @1 C* c D8 P3 O. n% r- o
; p1 ]* f( b2 B# ~在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction... O7 R1 c4 K" K/ {0 o) ]' T
0 z3 }; `) M* Y+ K+ d1 \有哪些 frequencies由 clockgen 提供?
c J O( v# T" o7 e& [- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
+ I' V* i4 A% T0 `- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)* w: ^/ v: g# b
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.9 G/ r0 \' x6 z" d
* \' x- q9 X% f' W! o% O4 S b7 t補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.: \ k: `. N9 X* Q! |
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz, w! b, D1 B6 A, ?& R* X
. k0 r8 Z* o% _( G$ n5 |
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)' |/ n. @3 N0 \( @
- PCI clock: 33.3MHz' S) `8 A5 }: Q6 U! L. F& H
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)% j* G, G7 v/ o H0 b H
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供7 `% z: P: m+ G% p/ t
- USB 1.1 clock: 12MHz' x8 W4 R2 o8 |. f d
更正: USB 的 clock 是 48MHz" e% F1 I1 v2 c6 k
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
8 K. I+ p1 U3 M# A) ?" D& ~4 ?/ m) A3 n" \6 F' u
- SIO clock...etc4 W7 N/ d* M" K( U% S o; P
0 A( |0 @. k5 Y6 t- V! L
Clock Generator的架構/ f. h% c* G# U- s( ^8 P* g
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:! k% Q5 T: r D# G) [( q) v! C
; h% V& Y' S$ O' v14.318MHz -> PLL -> F -> Div -> f4 y4 v2 ^: D- [1 @
' r, y& X4 f. ~
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
0 I; _- |" Q/ T$ P& r( \$ g2 {
" V' T! ~ R+ c& G, BClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
. b) P; B* Q* s$ u6 G
' x' ^, B* k0 B6 _* e更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
' E9 e* x) E9 Q& {! m* U補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:2 o3 B# V: H% @; r; h0 ?0 F4 i
1. 有 2 bytes(即所謂的M,N)來決定 VCO' T4 r v e" _8 T# u5 [/ V0 z1 I, e
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div6 y5 g' G" {1 M v. q0 b
3. VCO / div = frequency
7 N) l; ~9 n& G% T) m
5 m4 ?4 h. {+ d9 u0 }How to access ClockGen
W# j4 G. [6 A4 x1 g2 [=>現今存取 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
4 H( X4 X3 F9 A$ T! O+ v, [5 i' a& J P
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:$ D) g- [+ k) }0 Q% F7 m1 b
- pre-init( clear status or ...)1 i9 [2 S5 I$ y: | [
- put slave address(要 access 的對象) ; q, x6 }7 a& U Z4 o
- decide Read or Write
7 S! I1 K$ E/ F: e) l: ^) @- put command(Protocol type, Ex. Block or Byte access)6 I; A3 x, u: h. Q) i% Y7 j
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
7 k. F. N( w/ d7 F- put data if (Write device)" X/ {9 z4 b; Q2 @& A( z0 N
- start transaction !!!" I) V: R w" E, H& |# N
(... processing ...)
4 x! l2 D% @6 V, F- get "Complete" status to check if transaction is done successfully' Q3 B+ ^9 Q6 Q7 J8 H+ t
(...wait for system reset...)
: `( ]# Q4 U2 s/ }
6 d0 m& P4 z7 e6 P; }; J7 Z% y* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
2 l$ a1 x2 k F4 R
/ D: W8 |2 E4 ]' h: ?透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.2 Y* O! }3 `6 s1 e; ^
7 B6 {3 ^( W# |! a
[2 Programming ways for clockgen]5 u; R& [* z+ _! }# E
=> 現今的 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 V$ |, h- P4 `- }5 y
+ e5 E% N8 l0 L$ v! W9 E
【Notes】1 Z1 r6 S: E3 y* T: P, L$ B8 @
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
1 m: ^, |8 k9 y* q/ J) A9 X4 ~% b/ j e6 V% I# W: B
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
" I' u0 M! S9 x, ~$ f* t& }: J2 I) [- j
9 Y* t2 D7 N) f z
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
4 b E: w8 M6 W3 m! v: B0 H9 I; X0 @8 f9 i1 }6 o' L) a
給我正確的頻率,其餘免談 ...^_^...
7 p' g- N4 k# S" {$ G5 e! S) ? n
=====================================================================6 |* ]1 }* \* C
Q&A
7 W5 p/ ~ K- t=====================================================================" P8 U6 U/ C6 }3 A. \8 s# V4 h/ ?
>前輩我有幾個問題要發問!
8 ?" |! b. n" j4 z) i( N>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
5 }, F* t; Z \) D4 s( D& {>
* J# g+ m9 {" |4 _# B>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?5 j. R" G1 H5 C) C5 B+ ~0 z7 M
>
9 O2 M* g) i7 S) i" |3 Q) ~# M6 T2 f>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
% O( _* `% ~+ Q, a7 x, t. c [1 C>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
+ Q1 t5 H7 g; o* E2 Y# o, q>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
* H/ @. \; h" R# `$ e. b( r) ]6 t. a1 i' [, _2 K
[For #1]
: c6 Y& A: n$ \=> 我所謂的 "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 !
b, `$ f1 ^, M7 \; \) I
' v7 X4 V) K/ H3 O: ^' j" b此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
9 h) p3 o. Y3 n* I
. z. b& S2 m5 Z: y: `不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
4 X8 F# x+ ]: c9 t! b/ T* y2 A# t! F9 V3 C
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz: o+ W6 b/ n6 r% w( ?
/ x5 D p% j' }' ?# R, ~
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!7 J; J. r! Q! n5 `3 R
% O; t: T% W9 u: k
For #25 {' h2 n+ v; z' A: C
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
0 B. r% A3 k9 Q$ }; \(...想像以前學的直流與交流的訊號...)8 M; Q9 l% r6 Y2 ?- j8 G
( J8 O7 w" j4 r8 o0 U. }, L" P
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
8 \% r, B) N3 w
/ W* V$ l, i$ C" A, w7 H1 w我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
& A" k' ~4 N# m8 F6 W+ D+ |, K
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
+ Q& V+ V* `- E9 ~1 X8 w7 p5 b3 F4 a
For #3
# F4 [5 q8 t: C=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...8 v2 i4 A9 @5 a# r3 ?* ^8 F1 M
. m9 B! x/ U( C. c" ]* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ ); k* S1 X7 M/ z) H/ g+ R9 x# u2 C
1 m, ]! d @% ^1 B$ H[[EMI 測試的知識]]
( g) G4 D8 L0 M: s) J0 q由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ( |3 K. I. U+ }) K; q
8 l& D) r* H7 i1 a. l% {: \1 x為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理." b& ~' p: l6 z- k% s
" H K- a2 Z& T至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|