|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
6 c" a8 |. l8 f% x7 Q9 f( @- O8 @! `3 @# |
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...6 [0 N8 _3 S+ T, `& d$ @0 z+ |
8 t* _$ f# t- s3 f+ }有哪些 frequencies由 clockgen 提供?! r9 ~+ x+ N" _6 [- d/ p
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)7 F1 m2 V) [; K3 g
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
% a8 M5 e/ I5 H1 Y* ^, Y更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
# j. F: `. t# w+ e; _5 t# P% p
/ c& J2 u7 @$ R9 P% h7 J4 a補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
9 ?" N& w( M8 O) ZEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
8 `& B8 q' [9 I+ |3 g( K; h$ E5 C$ n& T ^9 y: O
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
9 ^) E) `( a. f& G- PCI clock: 33.3MHz
* O+ f+ `* i* c* f5 u6 {" ^3 \$ {- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)) @( v' w, p7 c' t+ |
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供0 \5 m4 S+ a7 M
- USB 1.1 clock: 12MHz
9 T; A/ F% D$ N! D" M6 K3 o更正: USB 的 clock 是 48MHz( }" f6 Q; z, b0 e# J) I
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !' s6 d2 R& s/ c8 t; \( Z X) o
9 R' @- \3 h+ P& M+ f# o
- SIO clock...etc5 w& U S B x& x$ q
* {9 m1 G0 ?6 [2 C
Clock Generator的架構$ t, v( k C6 v7 [! f U/ j
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:- a1 b" S, s# r, o" F# W' }! x
/ Z* o; c6 J" _( m/ I14.318MHz -> PLL -> F -> Div -> f
. S; Y9 b" @ s1 [8 m$ P) N# }' t2 k0 [
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
$ d& X) Z7 @$ w% v# y6 N$ i- M
3 B8 W R( e3 W5 e: @5 Y3 E6 p9 f9 PClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
9 m n0 l* F0 P) s/ W( x8 i0 y9 m5 H1 G7 j! O
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) + G" o7 n1 t1 g$ a& |9 n! q
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:% `) \, B& i3 j
1. 有 2 bytes(即所謂的M,N)來決定 VCO% ~3 I* u. k, j$ H9 M, ^
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
3 S6 f/ O2 p8 z3 ?( n3. VCO / div = frequency% u' b. F% o2 [1 `3 _
7 {9 I( L9 O* pHow to access ClockGen# K1 w. @* N! p H% t9 O0 ^
=>現今存取 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
1 u& \1 x! |8 G+ P$ Y3 x7 I! p
1 }- \: r+ |+ h5 p" f3 ^" ?不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:, X' u3 G7 o' L' Q4 l& O
- pre-init( clear status or ...)
, u. R" N9 K$ g3 ^/ q6 g" e- put slave address(要 access 的對象)
7 E& {# O8 |! J, M) b6 K- decide Read or Write0 k) Z4 `. j/ b) H. D4 L
- put command(Protocol type, Ex. Block or Byte access)# e1 y. d2 g) f
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
9 E- @8 E6 a9 ]0 u9 l- put data if (Write device)
, \9 Z) s* R0 l. Y1 H$ M- start transaction !!!$ C8 S; S x. g2 t8 @: n( [: n7 e
(... processing ...)/ r5 Y- @3 d# o& F( a+ ~! x
- get "Complete" status to check if transaction is done successfully
% j ~4 ?& x6 A0 n( p/ _5 G) e0 ^(...wait for system reset...)
g2 P' S% L8 Z7 l1 W% x( \8 ?8 V1 V4 V( @, q
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
% N* e7 q4 Y! G+ Q% D; r7 c
/ j7 G8 K( I6 _! m9 [) s/ I透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.' ?8 c& Y1 `. t5 ^
' ^2 L5 {$ l; g3 Y$ ]/ D/ X
[2 Programming ways for clockgen]
- d9 D$ e* x$ A. _2 i u=> 現今的 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時會用到
# T" [$ ]' O( {# ~5 Y) Y1 U- o; C% r! j- N3 i) R
【Notes】: A* n( h% U8 a3 c* ~7 h! T
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings, D' `1 D/ ~# {0 k
2 t8 K r6 A. s" [2 N更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper. t1 h* | b& F% o5 b; u, W
0 V1 ^- Y1 \5 t0 ~3 X3 z S+ M$ C. j4 F
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
# b. h0 D9 M* S2 x# ]
* t: I8 k" I" g+ x; @- N1 V- X給我正確的頻率,其餘免談 ...^_^...
" F, V# {' I$ S
4 s- _4 x1 P$ l& s9 [=====================================================================# f4 J! f( }, ]6 B
Q&A) S# r5 F' p: b% _+ M8 a
=====================================================================
7 `+ J# R, m. v; Q8 E. [4 G>前輩我有幾個問題要發問!
5 M0 S+ _( R4 u4 Z" b; d2 a>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
+ p E2 N# `7 Z1 ?" k. f>+ N" @9 z- c3 X
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
7 D2 t4 R+ e& c2 d, ^9 L>
3 e& s: m: ~3 T>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以# c$ A" W O2 z- Z# J8 ?# o* h
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠3 j( Y' U2 |! n1 P; J% u
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
3 _3 J6 H6 W# o( P; F0 Q. c
. G! [) {( X( c9 {: M7 |5 `" m5 x[For #1]
' v& w3 E* ]2 U1 K* n) I=> 我所謂的 "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 !! R4 \+ E% O9 C
, F: N4 f% A z& n4 |
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
+ x0 e2 ~0 B& O# e' u3 S5 D/ |' ^; ?, ]# L* E& g
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )% t; l# G, U8 K' W% h; g
7 m5 u: k& N/ J" B5 ^
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
% S1 E e- }3 g( H, `! {1 v. ?6 A. o
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!& h6 V5 a9 V1 v2 R5 f" i3 x6 J! \
* S% z7 V9 \4 E4 K6 F
For #2/ y3 p8 h: w6 C0 ~1 X8 J5 o
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
, z. ?% v7 K* ]5 x3 h- p(...想像以前學的直流與交流的訊號...). A. H/ ^. T/ m
5 X1 L9 d* v. `* F
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!3 T9 H5 c6 A; [# J7 d) Y; P
- J7 a' W/ v; z2 r1 d8 ]& d K2 G' v我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
& x/ `3 W, z( u# }0 [( {
- [! v; @, q2 s8 \# {Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
' F' z* F* \8 l) v8 s, r& f8 `9 q8 \; l2 B5 L$ G4 v u# O$ K
For #3$ s- @$ ?4 p" K9 w' G6 Z1 H
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...3 M/ \, l/ X& u' m
1 G2 v2 D7 z& S; T( P* K0 w6 Y* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )% h' r8 U8 }& k: b# c1 d; ~
1 t, A, L( L) M; p- e[[EMI 測試的知識]]
1 o+ \: h* w. C- H5 b' M( z由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
( c+ V% ^ [% X" p8 l9 m9 y/ h1 e9 t. \6 d( x5 @
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
' D) K0 D7 p- |0 t: m, p2 O: }- s: a5 X+ A0 }0 s7 a, L& E
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|