|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.' z6 J) x2 r! c5 J$ w
) a/ r* S4 G, `; L3 Y+ r
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...# ~ X x4 p8 ^1 @6 K
3 P( z- ]* i7 t3 f7 P
有哪些 frequencies由 clockgen 提供?. H) x6 _7 U& a7 p* r/ ^" r1 u% Z# e0 S
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
) p: O1 A$ J6 K% Q D& N2 |- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
0 x3 T2 C) [1 a' Q: t& q更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
. }6 L( r6 R8 u/ e$ p; k2 L ], g. C: u* `0 ?- p- N) {
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.7 h6 O% t$ \9 _/ ?' B2 D( {
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz( |% K" B& L5 q* M7 L9 s% ^1 X
$ S5 R, e3 h0 }& x1 t) t& y
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
" V, M# ?3 x8 R( l- PCI clock: 33.3MHz, r y; ~% G- u. `- Q
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...). e, M* f9 F) F" Y9 K* ~
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
8 [; G% o5 O k0 @1 s- USB 1.1 clock: 12MHz
. ^' {' E! l a* l$ p- ?9 h更正: USB 的 clock 是 48MHz9 U1 r2 U: b5 C1 E4 X# Z
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies ! c. @( c4 p1 ~
I# `5 U6 k9 T; f. H3 |
- SIO clock...etc% S3 d' u; c8 Z6 M( r: T: v
( B2 m3 C; w! X$ z8 a: v" Q9 TClock Generator的架構' s* S' H' R, S+ c
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:9 j3 c$ l1 L3 y
7 z& I) U" }4 w) U% U* k* P( V
14.318MHz -> PLL -> F -> Div -> f' L7 t5 N# K$ h0 \7 [
& [$ O" a; b0 ]! A
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz. g7 M1 U# y9 p- |
6 M) {8 K6 F) |( c
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
$ Y2 X: v T2 ~% Z* e. W/ L5 y
* ^8 Q4 _. G1 y- N9 I8 D+ N% V0 m& s更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
2 v, s+ n. J# B7 M u0 D* X補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
3 M1 b8 z6 u; n, l7 C: y# W1. 有 2 bytes(即所謂的M,N)來決定 VCO5 I8 b9 O. U8 g2 s/ d% R, l
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div/ e T0 Z9 n0 }/ X
3. VCO / div = frequency
; e* l- I3 U0 d4 v4 h8 A/ m& f# Z* @3 L# w, P% ]: n% t/ e; `
How to access ClockGen9 {$ r- a. R- i, F' f
=>現今存取 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
. w9 Z+ D4 m0 g# ~7 v; A F
" i# ~6 H( X. z" r$ l9 q1 V不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
% u: ^4 C' x) d9 U- pre-init( clear status or ...)) |! a/ A) t: D' n4 P& K
- put slave address(要 access 的對象) 9 Y7 `/ U. o- \/ ?* X Q# I
- decide Read or Write
' M. e/ Z! T+ q! n5 R. |8 r- put command(Protocol type, Ex. Block or Byte access)9 _1 E5 M; ]3 Q* |
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)+ D+ L9 {& E. S# U8 L6 N, h% `
- put data if (Write device)
/ `. g c' G/ U( H" R( H% k" B- start transaction !!!. A1 [2 w$ i9 P N# t# g
(... processing ...)3 q, H" z3 \ a) P1 [4 s, j9 x/ h1 j' M
- get "Complete" status to check if transaction is done successfully1 P1 p& j) D2 C/ _+ S
(...wait for system reset...)
" ^+ n) ]& I- {* r
3 u" f7 z$ C- G; P* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
; d* Q; ~0 O; J. K8 V/ E8 v3 g! ~4 g; f6 P1 e4 R+ Y$ y- h9 C' z1 M% q
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.# \) Q# Q" i' _3 f' Y
3 g) W9 D) a# i. b1 A1 E3 o
[2 Programming ways for clockgen]! n0 ]) R6 u6 o5 v( r
=> 現今的 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時會用到
8 U/ m2 L7 y6 j
+ s' H, r( R* l( j/ N8 o【Notes】
2 R- P" M5 j2 b, R1 z2 ~# I1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
: y$ L, p( `" v4 u$ K( z6 @7 Q3 d: ^& ~7 d4 o) d) L/ @
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
+ s. ~ N) P9 m/ @ V* n1 |+ s" P1 a7 s0 m) C
; f. {0 R8 B Q2 i( Y1 C' o
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
, ~6 e% ?# Y1 h, W1 D3 K3 {
# ?, ]9 q2 M0 h- J+ E9 t" ~+ B6 j# m給我正確的頻率,其餘免談 ...^_^...
3 m5 D: ]! E- L; S# k) i; J( O) z/ I% j% Z) h
=====================================================================; o T! q& Q3 t% B2 Z! @- n
Q&A
, [; |+ e: b5 {" [=====================================================================
8 H& P! D+ m1 x/ m Q>前輩我有幾個問題要發問!
+ u+ K t# _4 K$ b2 H8 i>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
% a, k5 X1 d- Y" z, `>' ?3 D; t5 Q) Q* v/ c8 m! w
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
+ e6 R8 F/ |8 n* i$ }>
3 ]8 {2 Z/ O+ ], r1 s& S. F>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
# h( [. K, @$ N% N* ^>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠/ @4 H8 I% v5 ~8 B9 Z$ W* l
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)? W' m0 O$ i2 }* q! s. s
+ u' b% y5 E/ T. }2 q6 U
[For #1]
, r3 h7 v! s% 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 !- c1 X) \2 {6 f" {( {) b$ U
- H, v3 ^, d6 M0 C, N2 P
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
* o, M o- V, K5 |) O
5 N/ C% c% J7 E# n* l8 H不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) ) t' [' ~& v% D3 Q
9 E2 P+ a, U* e9 }: N# o% B5 A
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz4 i8 h- b* Y( ^6 N+ Q; u
7 [) p- k s, J0 |
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
1 @/ [' j6 x* h2 t" p; N) P
, C- x" _! n! p2 TFor #27 G$ D0 k" d. F ]
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
5 Q9 h2 F& I8 ^* C8 ?(...想像以前學的直流與交流的訊號...)9 y9 _3 I! {0 j+ b; A) W
( E' E- w+ b+ r0 j2 ]8 [, l100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!% }2 J. D) \$ \; h/ M0 ?+ A) D
4 E& A$ T/ n* n8 v
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等, `3 t- J9 Y: J
$ ^6 r j! ^: y
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )% o1 F6 n: i! D8 B/ l { c
9 `) o' U* V8 j ]8 ~; T4 k$ @
For #3
6 P& x' b. {8 B2 K$ J8 v9 I=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
/ D e- J v9 d3 h8 d; n L& c2 o9 H+ q* M+ g
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
4 ?, Z) f* g8 C/ \1 k4 c- x( C: @0 T0 _1 q2 r) N
[[EMI 測試的知識]]- @' \$ Q" H* f
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
, ]' \, D2 ?7 R# Q# e; C8 l/ Q7 O7 v5 U( |
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.7 U4 V9 A5 B7 M5 j0 M e
8 Y9 {, d8 {3 G3 K$ M9 y8 ~6 d
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|