|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
9 h/ `- r9 \$ K3 r& H" Z' ]7 l7 M) B+ T5 N; g% L) ]" N* z% O# u
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
$ k6 O' I: C0 }7 f! M1 F
! A' ?1 c* }. F# z7 }. ~! P有哪些 frequencies由 clockgen 提供?
" M$ S' g: w0 b5 V( Y4 a; ]6 ?% c- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock) d. m3 A( \# g3 u) h- c! m
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)9 U+ `4 J i, ~0 G& L& R6 {
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.! _4 P; R2 n% }9 W; E" k, o
6 r( K; S. |4 m+ v; ?補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
: Z I$ i$ J& Y% w: I5 s9 h, tEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz% }& ], D( X# }; @7 Z! g# h6 G6 X8 o
: h3 P6 q; L: y: F! S" w0 s- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)0 z- z. w( k5 [" p6 N9 B" }4 g
- PCI clock: 33.3MHz
7 m8 p: D% q8 j/ @0 m0 L; A- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
1 u c! X' S+ N5 G* m- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供( f$ n8 K' I9 h3 c6 f" R
- USB 1.1 clock: 12MHz
+ {0 B# H4 S4 x$ u6 _" i更正: USB 的 clock 是 48MHz3 q0 V5 C: J' o. \" l% M+ d
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !' B7 i" V f. [7 z4 G
; w. ]' b+ C$ R. s
- SIO clock...etc& v1 ?. _ X) [, x; R
0 M; D# M. M) l9 x6 }( T& ?- K, n
Clock Generator的架構
5 c5 o/ Y5 F3 u& w: X# f1 U=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
% ?7 k6 v" V8 a7 i
) U0 z" n+ N9 b1 z7 @14.318MHz -> PLL -> F -> Div -> f
3 B: Y$ K. V: C1 | c! U" l# D. E% ]. p
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz+ M9 U, A* i$ x! e) l9 E4 W6 E
- r6 z* F9 r. v4 X8 J1 Y) L
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
1 Y/ d1 W, W: a1 D1 l. W0 x
; Z b2 B+ p6 g: n8 A0 v. Q更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) , m2 l! A2 M N6 `0 Q7 C" G
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:/ p( ]9 t/ I F# D, j- b
1. 有 2 bytes(即所謂的M,N)來決定 VCO7 }0 R+ U, b7 R# r
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div$ S' |/ h9 L$ T- B
3. VCO / div = frequency
" \+ @! z; K' z9 x% h4 \7 Y( _
: u+ h" _$ F2 D3 A3 qHow to access ClockGen
' C3 O, i- x8 g6 X=>現今存取 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
( X& e& |5 N$ P' s+ d0 P' q
6 a, W4 z/ E5 {, k3 ~不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
4 O7 s1 D: R6 t+ e6 l9 @2 X- pre-init( clear status or ...)
4 ~+ _# G% |% T! s- put slave address(要 access 的對象) & ^) T( [" R) |9 N1 [
- decide Read or Write$ ~' A5 U$ d* @5 V: p9 B
- put command(Protocol type, Ex. Block or Byte access)
5 y! S% G3 I6 H" ^7 |! |: d- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
0 |& \* S7 I4 u2 G9 R5 a- put data if (Write device)
/ [; y( h- ?+ R1 y- start transaction !!!, z" C4 A' b- A O
(... processing ...)
. D) s4 W+ n$ E- get "Complete" status to check if transaction is done successfully- F+ Y7 A. f: ~& T' J3 N
(...wait for system reset...)
2 J1 F( c! `# h8 r$ k5 q
" A% M7 p2 V2 h9 n* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
7 T+ w& x9 o& b" b( F! @% R5 @0 ] W: m0 v
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
2 k+ s& \& v* y
& e( X; j7 h2 I3 X# [: i[2 Programming ways for clockgen]$ y. C+ k7 j7 @# Z4 M. o+ y
=> 現今的 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時會用到
* b# @% U. |& X2 a7 Q+ J. h% u+ T$ v9 O6 L- h$ |' ^
【Notes】
8 X- u- n# k9 `$ o( G1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
. l& j5 t9 L& T. L5 F: `) J) Q$ I4 k( u/ t* v
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
5 ^2 S$ `% N2 d. G' l( P$ `% w! x* F' p q. ^" r
+ q7 O9 V: R! m' Z; N& k2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
' ^ n+ k9 l/ ?
3 v( x2 D4 P5 D% ~# ^( D給我正確的頻率,其餘免談 ...^_^... , @ X M/ }) b$ `" _0 K
* H: r! d+ q0 Z0 v1 x* A
=====================================================================
3 e" m- Y# o; u" ?* |, ZQ&A9 O' ^7 w/ d) i. b/ O" r9 k
=====================================================================1 b2 f& `8 `4 m% G4 S; O. k
>前輩我有幾個問題要發問!
( H& ]/ J! y u8 ]9 `3 {0 u" m>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?) R) q2 C6 R# k& r0 v5 A) u8 U
>: v2 N/ Y l: Y2 c8 ~7 V& K
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?4 d5 `/ Y- t4 y% e" R
>
0 ]& F$ w; Y$ i9 G>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以+ X/ y6 C W R, ~
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
8 T# k' H" G: U% w5 ^/ u8 G>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
5 L% s) s) y- O3 Y! H0 v1 G/ q0 C3 i; F
[For #1]. j- A: B9 X4 ?$ k% F0 R1 Y
=> 我所謂的 "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 !
: O v- ]( E0 Z6 Y' b$ M! L0 C' w* S' W* Q/ ]: U. V
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.( a$ p7 G) {, L2 e" y! i7 _
0 `; L" |! x$ O, T2 }不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )7 }; ^2 k3 f! K
3 ~+ v1 ^6 E# Z+ g8 P" r, |Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
2 {3 N) B9 _5 K1 l% s. R1 y2 O u/ c8 {/ ]8 \" C
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
& A% f, p! l5 m
( `, P: ~1 V, U9 i* ^% \& jFor #2
& k0 K( `7 F7 u$ S=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:( T$ M8 h x4 U+ ^# P4 n7 Y
(...想像以前學的直流與交流的訊號...)& ]" F# N* O8 r# ~, \8 `# |
: v+ j! c' Q1 U% i& ^+ }100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
7 y8 ?" a* ?0 y' k$ p" p, u' r9 p4 L" \# [- D( {3 l8 b
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等' R& t o8 \6 v5 k J5 M: X
" _6 |, G1 V6 ~5 ~, Q8 N
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
' C( h) X2 c- A5 {- P5 s# a5 o3 `! D" f8 T
For #3
! z, j5 D2 A8 w4 N, @1 A# j=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...7 R: u- @0 r, \, u s& C0 p. c
% l2 L& o* @7 t, x* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
3 p2 N! |' b9 U; {, y1 @. F+ E3 ~1 K
[[EMI 測試的知識]]
, ` }$ V( e8 S由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
7 M( f6 y5 X* C" L9 ]) t
0 f7 i2 v8 H$ U5 r# x: b為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
; ^" Y* R, a+ f: s& d, L
! u- T5 D; @; @4 o* G# j3 ]8 Q至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|