|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
: E. t* R7 ?+ Q$ M; P9 }! W7 F% _ o9 m% A% R
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...6 I7 S6 c3 K; z( a
: S/ h- f! F3 S9 |3 {2 W有哪些 frequencies由 clockgen 提供?( t8 K) g5 V0 l" L* ^8 h
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
: f! ~' {4 Q' n- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)2 z4 \, }3 f# s$ \: D |1 X5 \' i
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
2 c6 _1 H7 z- x% Q5 n5 j5 t( \
$ ]$ f: W- A/ A- k3 L補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
3 S ]6 r8 k9 g+ nEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz: d( M8 s; i# A) s; Y4 @
5 d1 j" H$ X7 P r- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
8 p& X7 {6 g% T8 T+ A- PCI clock: 33.3MHz
7 P6 }2 h% R- k) ]# s0 M" b1 c- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)8 m# t7 M2 ~3 L: I# }
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
& ]) x1 B# C' b1 x' H; H6 n- USB 1.1 clock: 12MHz* f" u1 s8 \. e# d3 h) A
更正: USB 的 clock 是 48MHz
5 q* G" a' U1 u3 \; L: \' i( @: x補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !; _$ n4 L0 g. |0 l B3 M
: Y# F. o2 g% U- SIO clock...etc: S: O: D) j! y9 H4 \( }
( D1 L8 _5 _3 l% q" \, p
Clock Generator的架構
0 _# K" H/ r8 {=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:' t+ N: D% w' t1 q
p' S7 O: P; g) g7 g7 C; T3 D& x
14.318MHz -> PLL -> F -> Div -> f/ V; [+ w# W5 E
$ f9 }1 ^# \: }6 G
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz- [! j& f+ B/ v N0 ~) u) e3 D
8 y: h, Y4 X' y) U% _% J/ t
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !5 ]2 x9 u% E V$ k
8 c1 C O3 f. ~' x- S
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 5 s* L+ b7 o: ^% m- A# x8 n& r
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中: R5 {; r& ? ?( U
1. 有 2 bytes(即所謂的M,N)來決定 VCO) D6 A8 }" F3 S$ J, w9 b5 l& P
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div$ K' x4 r- P' I
3. VCO / div = frequency
& ]! q4 E& G3 F/ X$ t
. K; I1 ]. G6 w" c- f7 H1 a1 [' T7 ]( LHow to access ClockGen
/ M [$ u" H$ k0 B=>現今存取 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
q& e9 U- u" E3 p6 F: r. c0 k6 `. W" G: y- {
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:' R& V/ o; x) @* e: W- j
- pre-init( clear status or ...)$ q# a! H0 p- O6 E/ F! j6 R
- put slave address(要 access 的對象) / |! H1 j( }6 Z" Q# a/ ?; P
- decide Read or Write
( [ B R' ?: j( {3 Y- put command(Protocol type, Ex. Block or Byte access)
G/ _: }5 n! y: t- put offset(要存取 自 clockgen中的哪一個 Byte開始...); J) J: f5 O4 ~7 a& U, h2 F3 J1 z! h9 a: D
- put data if (Write device)
0 b6 B$ Z3 P# j1 o% o& H. w1 Y- start transaction !!!( [& v5 d, T; U5 h, o9 }" m4 e
(... processing ...)$ j$ b0 s' f$ x% r8 c1 U
- get "Complete" status to check if transaction is done successfully# L4 k3 |( L; `6 _' C& }
(...wait for system reset...) # Q, j: B$ h8 v! h s
/ ^6 H4 z, G; m1 @7 t' w* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.8 W l& W5 ^# p1 Y0 i( Y$ v
G0 A4 M3 B4 A9 G$ `
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.4 f# q% J: d6 ?& h( E& B8 C
, P8 r# g! c2 e# }8 P7 i' f7 c( K[2 Programming ways for clockgen]0 [; Z/ w7 X4 q6 N" K6 N
=> 現今的 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時會用到% H% A( B4 B+ R2 C% b9 \; O' P
# ~: j1 k2 E* G: j4 R【Notes】% y9 \0 A5 g, M5 l8 }
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
! ? f; q5 m7 Y. m% n; i7 e. r4 l0 e2 s3 I: V5 p) ]
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
9 e0 F! j! u J8 Z% A" }
) i; ?" s3 \+ ]+ q2 c; s% o1 n+ u( H- S& k7 N
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成5 y- ?) w! k9 L5 f! r
) m3 L( H) D; V給我正確的頻率,其餘免談 ...^_^... + _ d& g9 d/ ?
, s9 K$ S4 N4 j% J. {7 R=====================================================================7 J! R! q4 o3 a8 N
Q&A+ q |# V5 O9 p/ u: Q
=====================================================================
Q& V$ W8 L9 n: H. Y>前輩我有幾個問題要發問!$ B% G! j D1 i3 V
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?4 v7 l+ ]: Z( A3 M! b6 B" \. b
>9 ~5 k( Y; ~% Q0 R
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
& _9 n" S' S, R& ] ?>( c* [- v% m) n' x
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
% p' F; ] h( d# X5 z# {2 Z; @>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
7 ^. x! d2 Z# Q9 U8 `; n>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
$ j- Z% {8 f* ?. |4 ~. F0 y8 A" U' P/ V/ n
[For #1]
7 p0 I1 f7 Q, n2 J8 q- O$ j=> 我所謂的 "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 !* f5 ^ E7 o, Q% p5 p% R' q3 K
0 U( c4 z3 W( h' j z0 P- x( \6 D此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
' T( ^/ ?. n/ w z6 U1 W
! @; `& l* R, ~% D7 |. Q3 I' y+ p- x7 U不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
' c! F8 h h+ j- w
' R( o% w5 F4 Z, i" kEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz& [: H- G/ d5 T# ]* W+ ?5 D. Z& X# ^) Y
; B) \4 B6 \4 x- H) g/ V% d* {5 c還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!9 \$ D, F2 ?1 z, O
0 r: Q9 k( E+ C& l# V1 YFor #2
& L- h3 t$ ]9 A: a7 X4 a=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:) ?% v0 T3 ?" x/ u' g4 S' L
(...想像以前學的直流與交流的訊號...)" H! @! e, X- N" O+ S* g3 ]
, U q- x7 [5 l$ |100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
& I% h& I0 [8 x3 I
/ K% \- T) l `5 I) z$ g; X- L我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
9 x1 ]6 V7 Y. q* [' m4 e9 l0 m! \8 m2 d" y! p
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
+ x: J# `4 A# ~
: r- z. c% E" \" j7 H$ X# VFor #3
L( X5 v8 q% l- Y# b$ D4 a5 Z=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
* H8 ]/ P4 Z. `1 D) e' t( V8 i( F
7 q& e; K" Q0 D' T* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )- R" `7 ~- h+ o/ i. O. H8 y/ g- X9 n
$ U! \' H; ]6 S. @' s' K# g
[[EMI 測試的知識]]
V! \$ A) \: X ^由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ( {* j8 r8 @: K* C$ E
) _5 X1 {: ]. w
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
, B- i6 X/ `. }" L
. _5 K0 C5 \; M& z至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|