|
|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.2 l8 i& V: k$ z5 z
: R1 X+ |0 U5 L; j. d& H% I2 ~
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...' O2 s: n/ C C3 r7 }
8 I. f0 P; N! e有哪些 frequencies由 clockgen 提供?% {! e I+ |) c& V) f" z6 Y
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
& U& Y- Q( c; |, G9 ~9 x- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)6 U" w9 _* |/ Y% u1 [, w
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
' i4 `$ e, F# P) q+ B7 ^ b
+ G% l/ G0 c3 L3 O補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
& j& W; v; V2 }- ~+ r- TEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
8 i9 b" p5 G5 g
6 ]( s7 L" N) X6 J2 J9 ~- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)- r2 z. l6 H* {7 m& S% `
- PCI clock: 33.3MHz
1 O. Y2 U1 ~/ M& S: B* F" V! y- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)7 u; j7 L# s! ]# `
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供0 n; b# @0 Q* w$ A8 d: ^
- USB 1.1 clock: 12MHz$ ~7 q5 M2 l6 y3 s- y5 B: [3 b/ ~
更正: USB 的 clock 是 48MHz+ G( U- @9 C4 [7 k6 u/ L! Z
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !# X* C) T7 o4 }8 h, a: W! T) {
p0 a4 c* N" S& p. E) g! f- SIO clock...etc
% W2 A d6 X* Z" { V4 j0 @* a s# S' E4 [5 G$ D
Clock Generator的架構
" m/ K/ U, W; o8 c9 _=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
# A- q. f' ^! o3 y% F/ [
2 l/ q/ n/ G% w14.318MHz -> PLL -> F -> Div -> f
* s8 p# \, P( G& x$ H4 m& ]5 ~# Q- }4 k J8 g" a5 v
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz% Q6 e5 L8 q0 V+ e" a% v: L
% L: ~2 y5 K5 a# R( M2 ~ z
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
4 y5 c! u5 A% v( g0 |& b3 L
: G, g4 z# a# `6 J, y0 O更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 3 T/ X; I+ J+ `( G
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:1 L# \6 `3 d$ f
1. 有 2 bytes(即所謂的M,N)來決定 VCO5 q T/ }; U& z" p4 r
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
0 E% U, L% q- n+ ]3. VCO / div = frequency+ [) M, R; x3 Q
( m2 L0 |4 F- W+ C5 qHow to access ClockGen
: ?3 j# V8 u! q2 h& d=>現今存取 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 $ F. ^. o H! |9 a$ ~% g1 A) k- E
% y- j" s& n t& o不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:) G8 ^+ D" l" y9 y3 G. G& d3 P: Q, R V* h
- pre-init( clear status or ...)
5 y1 @' O6 D; x4 n! T4 c- put slave address(要 access 的對象) & K" {' `# E% U5 D2 V- O
- decide Read or Write9 D" A5 x/ L6 r* e1 w3 v
- put command(Protocol type, Ex. Block or Byte access)
" O; x3 p1 ^7 _. b) ~- put offset(要存取 自 clockgen中的哪一個 Byte開始...)+ K9 s ]* P7 Z5 [) l- }5 Z. H# F
- put data if (Write device)
% L/ a) F- g, _% ]- start transaction !!!
' g. A: o* E; T7 {" K- i) o(... processing ...)
3 `8 D3 D Q, g$ {2 \' D7 {- get "Complete" status to check if transaction is done successfully
6 X/ _/ u8 c" t(...wait for system reset...)
# w2 l9 l0 E( \8 j8 N+ F" p" E% g$ l4 M2 Z% }0 B- z. `9 M ]# g
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.0 D0 o9 z5 T1 o8 R
# v9 n" U/ v" O. g! T透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies. H3 }+ d" i" J' q0 }: m: \& h
" @8 |* _! F# {$ T; b* ~" u$ u[2 Programming ways for clockgen], A/ T- _+ ?5 ?" j; x
=> 現今的 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時會用到3 x2 \9 i( a: U; {" g6 }. ?6 c
: o7 \: A; y7 _# Y【Notes】
3 R; [2 ~0 W9 V8 F( h/ `, t+ l1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
0 x3 x1 }; A1 h8 Y% d" G, S. v7 O) B2 s6 A# I3 p7 y3 J
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper3 U& x0 G2 z* G( f) }
4 o3 U! G7 ^, K5 I
$ x* o6 n5 M) f) d$ Q: `. V
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
0 |' @% A! z: K# W
; W* Q& O; Q+ k9 S3 S1 [" d給我正確的頻率,其餘免談 ...^_^... 5 l. I$ A6 k& u) `5 ?- |% C# q, {, ~
# \% F, p' |8 W: e# ~. V" r
=====================================================================9 }9 ?* `/ m, a! k; {# U7 s, n1 c
Q&A
! r' r& Y1 |% U$ H=====================================================================* J+ |3 T9 J6 W1 A* ^4 @
>前輩我有幾個問題要發問!
/ b; `0 C: G A' v% \% D5 Q>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?$ O& ?9 g3 `% O) R, X- c) Y
>
/ z- Z7 J" E: v5 J% T>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
5 u; e1 ] I2 @: C k1 c> b0 s7 u# d9 L* F( V- l/ h& b- J9 k
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
) e* F x6 f$ o: V% D/ U# C6 i8 X>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠5 u, }6 g8 R9 C, y- q+ E
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
6 X# [$ @9 G2 U) v# r; {. [4 \
- C2 J8 G+ u/ K[For #1]
' d4 ~% Y( J+ S=> 我所謂的 "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$ R& @2 E4 A( _
7 s) r5 |) G0 K4 }+ h此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
# i% l7 ]5 F+ v( b) ^5 g7 r+ a1 l3 p* p; j" D
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )/ _$ n/ s8 [4 p; N3 T. h. B& \
7 J, h# |* |/ C8 q: q9 f
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz, h- m) K- W8 |: b" }9 P# X
3 j; \' i$ s A( W+ s
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!( [5 K) o7 G, N7 ^2 ^( R
2 d) C1 V* ] p h. ]; tFor #2& R, c. q0 o/ }) t
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:' a5 p7 N2 p1 j. y
(...想像以前學的直流與交流的訊號...)8 A$ Z& X2 o7 u7 E* F% q9 S8 O( l
, l0 A0 p) B2 z( ~! G v
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
$ y8 c5 _! |2 W3 x# o/ a' v0 T( ]3 {
- S" m9 b3 J% N3 F" f9 l( d我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等1 v- F( s- y! t1 T7 g6 w" b
( i% u0 H2 p' Q$ Z- J: l2 x' BDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
0 N( |3 ]. g9 O2 E0 H# e* d0 p9 r
" g# n% q, t/ P! \9 `2 Z; HFor #3
* q5 s8 [# N7 H2 |! p/ P, K# q=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...) b# T7 r: Q, W& W/ \, K
( h1 x# m( B" g* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ ); g- G+ x4 O: B3 O( B @& A
2 l2 j, z0 V, d$ G# k$ N" w9 M* m
[[EMI 測試的知識]]3 F: C' L6 z) }/ j! ]( X6 [
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. ; f! q& t9 ^0 N0 Q
. v! ~; T& x; |) z: Z) @+ d1 ^" B
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.) \8 e9 i- l' K7 M
& w7 I; w/ ]& R
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|