|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
& L ~' z& R N. y* l8 }& F( O, H# ?' M3 t7 D2 k" l' d n2 j
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
7 t- Y* n" c4 H3 C. K
0 R( Z: K, m+ c( u* _有哪些 frequencies由 clockgen 提供?, B: e9 L# z# w( c+ U( G
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
5 |9 I4 C" }' G+ k: x. q3 E% ?' ^- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)( G$ P! o# Q# V# j
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.# a% \3 @% X' \& S: A
" z0 j b. F0 @/ K9 I2 C
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
; ]( r: F; G; h+ {! KEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
7 k/ D5 K* @, c- |( n% p' n5 G0 N4 ~: |+ E. T
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock). k& l# F) U+ d0 P% } X5 [% A: k9 E
- PCI clock: 33.3MHz
! d/ E' X5 o ]; m. Z9 M- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)4 r8 M) D& Q& D$ s9 m: f4 Q
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供! w+ v$ _6 {/ B ~
- USB 1.1 clock: 12MHz
" P U j7 r! t4 D# O( O! L& }& _6 a更正: USB 的 clock 是 48MHz; `3 ]7 J# F$ j7 I' h
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !5 c; a$ s% j3 x5 H: h, h- M
- l: a* A) h# S2 I8 k7 ~' g- SIO clock...etc
2 x+ K8 g0 Z; z& C& @. V+ ]2 |, \- f5 T% C; L( h
Clock Generator的架構 {5 }$ p0 O! Q
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
2 j; I2 g7 n" C/ S% {: [. R" _$ l# y
14.318MHz -> PLL -> F -> Div -> f' a t; h- o3 h6 I( b$ \+ b
7 p2 `7 r- G7 o: S
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
9 a$ A& \, w( C+ i+ i4 h. T
Z5 T" M2 o2 o) \ oClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
1 o" c% t. I4 ~. y
( g* {) g/ F4 H: j% i7 S+ `! F更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
# `0 u$ N3 [: j$ n補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:5 ^; f; d6 N6 g. s, E! v( q$ Q) c
1. 有 2 bytes(即所謂的M,N)來決定 VCO
% n# v9 _8 h% w5 {; F2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div6 w1 X' F( ?# D' n+ H
3. VCO / div = frequency2 g! P3 Y' ]/ c8 @: B/ Z0 n; @
- f5 \* W! S7 z* F/ ?
How to access ClockGen! T% u' @# }8 D0 T* t1 [: 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 6 r6 S1 \$ s4 H; X2 o- z4 J
8 v! n; b. F& h不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:, c I. f$ o, P1 O: G
- pre-init( clear status or ...)8 G% `) S! ?$ k0 K
- put slave address(要 access 的對象)
3 [ L2 \" o( w# t' P) P5 g- decide Read or Write
6 L5 F1 E2 h7 Q8 n9 X, G- put command(Protocol type, Ex. Block or Byte access)( r) f- C! a( m1 O2 G
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
8 y4 J0 a0 S. w3 v6 [- put data if (Write device)
& T9 o* o2 S2 A, c- start transaction !!!$ [$ I2 ]3 M7 M) K
(... processing ...)
* U7 F# G0 k" s' r& P0 f- get "Complete" status to check if transaction is done successfully
8 p8 S0 m0 I4 {+ Q% j2 C(...wait for system reset...) : J2 @, H( G# i3 p- M* _# v5 m8 A
) t3 K/ c% e8 e! O4 j) J+ v7 M
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.* k" i- V$ J% h, Y$ W+ E8 w6 Y9 v: u, [
" d$ t9 h9 ~( _4 ]% A' |6 ?
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
5 c2 v; j8 K) h" W& V" f1 r0 {5 n1 k4 G1 N$ D
[2 Programming ways for clockgen]
) ~) t5 q. l! {) L: c" P$ Z7 `& `=> 現今的 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時會用到
" `" ]* F3 l5 Q" a! X9 Q) E6 L
^ r: t$ |( a e q+ s9 b【Notes】, A1 f+ K- Y- P; f) H0 t
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
G9 z. i) B1 H1 Z* _' o) b( I' g' y& r+ T
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper, V, f& L2 s& B! m
* c; I! l6 ]" s! z& i6 J& P+ u) u0 ]% S" G! }: T. d& l- P! Q
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成" j! q0 P/ l5 {" N3 A, b
" ?& m/ _6 S- j# v5 h) x2 a給我正確的頻率,其餘免談 ...^_^... & z/ ?0 p6 G5 q" y
! _6 S/ P) }. ^3 w7 T6 o ?=====================================================================% h1 W+ f7 G/ e* s* d, [
Q&A, G( d% Z3 i% K, s
=====================================================================8 {7 N' e0 F+ ?& \3 x! \! |
>前輩我有幾個問題要發問!
( C0 O' V s( h$ L1 j>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?# G) u! x& }. k5 e. r
>8 Y# m' L; c L& l
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?# Q/ F1 U k% q% A
>
+ X e% q1 A5 `+ m% Q7 }>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以# K$ {3 H; Z$ S
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
/ Z/ l H7 g3 o" a. k>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
0 _5 t; W# W h4 y& h) u4 m+ s( c/ X! e" F& Y& p+ R% r
[For #1]$ N8 s" `; g, v) o
=> 我所謂的 "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 !
3 ]4 K S9 q1 v ~9 ^$ n6 M' c0 p% g. @. |
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.0 @$ W( l, V( y# x8 b
* t1 w$ }7 r* e" ~' ?' s8 d
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
/ j! T1 a& s. U
# v: K0 ^2 m5 \& x2 Q' T2 @Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz1 \( k/ g" C2 H: [; A7 k6 r
) {6 Y x. j' @0 ^還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
* A# _. p& G+ `) @9 G2 @
3 I. D9 I: h& yFor #2& K i O X" R% P
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
N% A/ e0 K, R& j; p(...想像以前學的直流與交流的訊號...)
2 A2 t; j. u* F1 [
9 e" G; r* p5 M. ^; _100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
( Y" N# b" S8 r
) l' j. h* t! a! s/ B我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等6 ^) ?% [8 ]. L S0 [, A
* K9 {; r: c5 ]' _% l1 D* h& k
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )! @ _ Q3 m1 V, a# ^! E6 Q
7 h& A; ~) z. i, v
For #3
( D" }4 U3 }8 M# u& j# f( y7 q+ P=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...3 G5 R! v; p7 G* ?: F
) _0 P' r5 E: \2 R6 G6 w) {4 m, t
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
/ c, U% \5 n; R( \5 b q: e' l- I3 I9 z ^% a
[[EMI 測試的知識]]8 U8 Y! u' ^' G8 C" h
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. + n% t6 P% s" _! T
8 H5 D1 V3 M( I" s9 L$ \為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
7 }. B# R- |# N# Y |
, b+ q$ Q- z: _/ L( R至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|