|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
0 v- b B. m: k
: c0 ~* T4 @, h$ D( o; D在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...3 ~ m1 B0 _- K4 s
$ I. w1 f I9 r6 q A2 S+ H% m6 n有哪些 frequencies由 clockgen 提供?* C* c3 p/ I. G) ?+ i
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock). p9 q! a6 [. h& K2 z9 _5 @; c
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)0 W- ~% \2 k! F$ o) o5 N
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.6 v/ Z4 N% I# Z/ G i
8 Q+ j+ S: j; q- y
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.5 C* k( x4 _' Y1 ]6 S; u8 I2 ^+ P" f
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
+ V$ @. E8 `. j: ^, g {& u2 p. @4 X* Q( v
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
2 u7 A. K8 T: O) x& _2 O- PCI clock: 33.3MHz. q% C6 e4 t* ]3 J# g# O
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
- N7 |# Q! n2 N N3 } ]- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
0 ]; z- l0 y" G" _4 r1 x: ?9 P- USB 1.1 clock: 12MHz2 F$ N5 i$ C8 t8 h0 ?
更正: USB 的 clock 是 48MHz
" @$ d/ Y' v7 ^, h. p$ X補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !# D# b0 t- }6 o
: R" S3 J5 P# c- SIO clock...etc
' O8 R( d0 P' z) `# ^& f; G; L0 g: w. Z) @, z, q# |9 \
Clock Generator的架構1 l; ~3 J( K( Z ]0 V2 ]& q
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:: W! |- S5 |6 {$ z
- ^' F. a. z2 h; e$ W" b+ ]4 f14.318MHz -> PLL -> F -> Div -> f* z, R. W% w% C1 I; Q
' G5 n* ^9 E. z2 @- T) ^5 W
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
2 W4 Y+ R$ f3 r9 C
, X# R1 h* K$ V s0 g) F/ BClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
1 q$ c. X8 {+ b6 G1 _
' i7 x! Q! X) F1 U* C更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
* u% R0 s4 v- k% X! }$ p補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
! H% G6 ^7 A g# U+ \! B1. 有 2 bytes(即所謂的M,N)來決定 VCO
" v, S8 z+ i/ E! K! e; ^( R2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div. b4 A: K" n/ Y9 s
3. VCO / div = frequency, i3 p# B1 H0 `; z3 F6 z L7 ~# F( ?
4 x* _; |3 b a7 s) v' S0 ?7 `) GHow to access ClockGen- Y8 G* `+ g X: p
=>現今存取 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
+ v* r0 G* h) c0 p* [9 i
) b; f6 \3 [) O/ t9 Z0 E不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
' t9 h+ l/ T; X0 h- pre-init( clear status or ...)
' m8 j- r, @1 T% f( j' U- put slave address(要 access 的對象)
+ {. o0 }- Q, c. Q- decide Read or Write
! H) X0 f1 k. Y) U8 P8 U6 H) `9 N# s" g- put command(Protocol type, Ex. Block or Byte access), K4 f' T' ^) S% c
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
6 V; t4 h X; b3 ^, G" H- put data if (Write device)& b% @8 z) T% ~- F" g
- start transaction !!!
( a# V! W1 G9 W+ |% x4 E2 O(... processing ...)
' n' I& k4 ?# w2 g, f- get "Complete" status to check if transaction is done successfully, }- h, a' o$ {. C) o. {- S3 y
(...wait for system reset...) ' j( b: Z" T; p2 Z0 \) y' @
- h9 l$ ~9 f4 F3 |6 l* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
; }* `- y H: y; W; W1 [4 k# i
5 n7 f9 Y2 I. @- Q& t$ o' K; E4 j透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
: F% | c2 n& ^; ^2 _* [/ d9 Z" `! @- s5 z$ d2 C! f
[2 Programming ways for clockgen]" t5 d% D4 c6 o2 V$ U# `" Z0 A
=> 現今的 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時會用到
$ ?0 A3 T) G* j+ u* P0 e# p; s4 m: d5 c1 A+ {
【Notes】
! |* a. }+ Q5 |- E5 l1 t1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
: v" Q: Y/ J+ ^ w2 }+ l( x3 I* a* R7 t
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper/ k& }5 M' I9 |
' P; { W& v& Q1 s% f2 P0 i4 n* u! Q" j: I" F! t' N4 ~" \' P0 H
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成8 Q0 U! `2 F7 @! `$ R
+ ?) Z6 c* [+ \5 n6 B給我正確的頻率,其餘免談 ...^_^...
, L6 ^- `5 D0 \, `
+ Q# @9 E9 j/ C! b9 `=====================================================================
( q# x! r: z( D FQ&A
! z) M e0 p8 n1 Q1 t- u=====================================================================
4 I8 v0 h3 A) N$ h; D" Z$ j>前輩我有幾個問題要發問!
G8 i. W8 ~2 {" L) t/ p/ _+ g>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?+ q7 I- B% [3 ?4 D1 ~) k8 f+ Y6 V
>
, r# d* _+ L0 J% V+ P>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
$ q# j8 N3 U0 F+ P>! ]6 L8 M. z, J) h8 t& j7 A5 s
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以5 a2 p. e* t5 ]% x$ y9 U
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
* ^! |' }- b* E# f I/ P>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?, l' ~8 E& O3 x) H* X7 r
; ]! P5 N' ?5 L9 L4 {, G
[For #1]) V4 f; o* X& a6 `- q
=> 我所謂的 "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 !4 L0 s3 t- _& x! D0 k1 R
7 [' w8 Q/ ?1 E" \- T0 E, j
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
% i& `" P2 w: {% b1 D; A# S
8 q. s7 p1 |+ J4 o不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
3 E! x) y# j, \! \
$ w8 c& a1 A+ D/ o+ w! LEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz% n; O7 I* c" v" T4 y
: ?5 o; {! ^# |* g還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
3 D, [& Y5 ^$ r" f7 ~& Z: w$ X: R2 k- p/ `, s& s' ?5 ~2 S; M( s! q
For #2( V# Z7 M; U6 a( Z! d
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
: F" d; J( ~, v+ k(...想像以前學的直流與交流的訊號...) V* @" C9 ~2 _( D5 r6 s8 `3 z8 q- ]
# P4 R5 B$ E, H
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!6 |8 \" o5 z P/ I) h% m! ]5 i; `
/ p) C* a; p- J
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
- Q! F4 S% s4 j. t0 r' f
' M. y* ]5 z YDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )5 W2 ]/ X# O9 ?2 z3 m$ U
* I- _2 @$ X& n. u4 d. f; ~For #37 e" k( D# ? G3 e
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
; l3 i* l3 o' S' a6 r3 ~$ _2 \* }* f+ c' Q: e; p
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
( o5 U' t* n7 K4 E8 c7 ]
9 t' `7 g7 K, _' A0 L[[EMI 測試的知識]]
6 k+ t0 I: u8 h- _+ V由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 5 I0 d" G. Z. s
' A# Q' n( n7 C! d$ Y3 n為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.4 x' o+ _# g+ p
, H: T: a* _7 M至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|