|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.+ Y+ L: z1 R- ]( y% J
# I( O( G* ^% k在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...9 ?; H0 y3 B; X) M6 M$ v7 Q0 i
5 [1 ]" O; I. v# v' z+ U& m. d. F+ _
有哪些 frequencies由 clockgen 提供?: r* x" S2 I, O" k2 @3 S% R: o- F
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)1 v4 }" l3 [/ g! M4 H
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock). a+ P X9 ?9 a( Z! m/ j
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.. K0 T. Y& }8 }, G: D$ ]: a# }
; @/ Y b' G& j( n+ Q7 `
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
6 R- S& I- r) OEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz' y7 Y( O: M+ H! z6 \# L
% \ V) X5 a6 P1 w7 V* ]
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
% U! Z( s2 H: y+ w- PCI clock: 33.3MHz5 e3 _# p( l' Y( u) [% d
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)- V0 z7 C; B1 a
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供 m& C/ |% X5 s' R- S
- USB 1.1 clock: 12MHz! i9 d3 f5 J, B' @
更正: USB 的 clock 是 48MHz* e N# l# A$ L+ J5 R0 b8 t9 o
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !2 J, U7 G4 S+ e9 k7 O- d
- C7 G; ^% r4 N4 b- a! i+ H
- SIO clock...etc
$ p3 m4 w$ D& x
# O7 o! M8 m. @4 n0 C$ HClock Generator的架構
4 T o# L$ j( x0 T6 w5 G=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:) C( b8 j& F! y% k) |0 s6 Q7 Q0 v
, j! }3 ]3 F8 V+ ^' H7 w7 I14.318MHz -> PLL -> F -> Div -> f
' `0 U; C, k* ]( ^" Z$ | i6 C4 T3 Y3 P0 G
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz/ W3 y: C8 H# L% Q7 P
; M5 u, ?7 p: [! ~8 UClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !+ }, Q5 L6 I. j6 ] R, e! r: h) e: I
1 J: Q( I! s( n6 z+ X更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ' c1 r( h) P' c& C
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
8 R( L5 o: C- b& c* t1. 有 2 bytes(即所謂的M,N)來決定 VCO+ D$ [, C; n$ y
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
2 z) D- g' u# }+ z3. VCO / div = frequency
5 i6 Q; O# m9 m. i6 k2 _& f; B; v5 x
( ~/ h( e2 W$ G; s( \How to access ClockGen
" b% |9 Q: N) {=>現今存取 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 s/ j6 o. J! I. M$ L- q l2 f% ^& h* W
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
3 R" V) Z) }1 u2 t7 C3 q- pre-init( clear status or ...)
9 t9 U" R1 e1 B& R) z$ d- put slave address(要 access 的對象) & C8 V6 ~' \ P7 L; r: H! S3 N
- decide Read or Write& e1 R4 Y( F/ N* y+ w9 p" h
- put command(Protocol type, Ex. Block or Byte access)) O5 d+ j/ U* P0 W
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)) y/ N, B2 i9 k( D1 |3 ~: `
- put data if (Write device)2 @2 v( D9 m7 Z ]
- start transaction !!!
9 L2 [' p- l) T0 f, h(... processing ...)
; V9 L; A1 o& ~9 S( Z0 @- get "Complete" status to check if transaction is done successfully
! V, y" _8 s: ~, ^6 c. _$ N(...wait for system reset...) 5 a' U7 o7 u; H
/ l9 T8 a% h/ p9 f) Z, d9 l4 V/ b* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
; a1 v' b5 D Z+ \3 Z% ^. A: Y9 h, N5 `
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
1 D$ g2 h c ~. t# n6 a3 t) P9 k8 L) T$ k0 I
[2 Programming ways for clockgen]% m2 K+ m8 [! I
=> 現今的 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時會用到
1 {9 x/ D) F6 q; v* W/ I; g- ~ C% d0 H( @$ X* h, Q
【Notes】
w" i2 M5 a% b6 x6 G1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
# ^. m) w/ R: e8 p8 l
( Y1 |9 K8 ]' Q5 Y8 j+ l更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper/ ~8 y- C, p( N W) Y
* z$ A/ y$ T! k7 ]9 q1 C
- T" q5 W- G( n. E+ X4 T7 t2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成( l9 h. R5 @! _: [/ E
6 |, O4 u. n9 s給我正確的頻率,其餘免談 ...^_^... 8 |8 ~9 R2 Z* u" l! k
' D+ |# v6 J& q L=====================================================================
, |- d+ Z, V( |2 m" h4 L& z7 S HQ&A
) l: X, J' @. h4 K0 p: S=====================================================================
! A$ ^: ^: }7 X; h>前輩我有幾個問題要發問!" o0 h4 z1 w$ V! {! l9 X `
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
9 e C* Z9 z0 a9 ]8 c" o0 p>
. {; ]& A" T; J3 E/ B r>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
( |2 H+ F" W1 w0 s& B: S>) _- P5 h5 d/ H% h8 O
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以1 z$ n9 @, L" K
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
9 f8 T: x" [; K2 c$ n; _7 {>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?7 q- L5 N' O7 o& V% V9 y
1 z: o7 e$ ]4 O P; ~. B: K" i' {
[For #1]
6 h& T8 q- W+ P=> 我所謂的 "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 !$ S: ]2 [' W$ O9 H# v8 \
' t6 g3 I$ E7 `此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.; T% T5 S6 d- o
: {& c. \/ p- {4 o: a4 _不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
: ~/ Q4 }# v, w0 z/ C3 X3 m- e) Y3 f0 X
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz% D. z% J6 L& f% G7 n1 p
# O- E- W+ N" A; Q+ \- p, ?
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!2 A+ {' K3 ^1 `2 l z& w
; A( [8 r6 V4 C/ f6 R+ q; P
For #2 j3 ]# Z4 r$ G% [+ A9 u# A6 Y, u/ V
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:9 I" V8 w/ w5 I) g
(...想像以前學的直流與交流的訊號...)
$ K+ L* b3 `0 D' j! n: D
! j- v+ t' J- I% ~5 t3 r* i- _100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!0 N( {2 B; O! P( f& n3 [8 F# x
. f! l w! K! m! P. b: T我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
0 Y' b# m J9 Y, D; {. Q9 i2 ~. j2 w) q! K: x2 a" r6 P8 ~
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
3 B9 i- F$ [# s4 s7 \0 W+ R, z& `) p) f$ F0 C
For #3
5 N2 U' T* |9 R- T: S7 i% G7 o- U=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
4 O! h2 j& k$ w$ K! b" I. k+ k$ o- j: J. f1 T( O
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )9 }; x' N, n: w& v2 \+ k) |2 w2 m
# q! y; _6 e: G. b
[[EMI 測試的知識]]* y: G/ {- P% g! ?* ?) o
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
: j4 }3 U& E* F p# Z/ G# P9 V; F4 ^
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.* x" E: u; |# s! ?/ e
! C, N& T" F% D7 x5 G9 Y
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|