|
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
7 _, @. c4 T8 x9 |
, w: S/ C4 k& } z8 M" I5 K* U1 X在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
$ t! [! q, G# K& \2 G$ k9 m" l3 W/ a V- [! }* |" {
有哪些 frequencies由 clockgen 提供?# T5 V1 V) q% X
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)1 T$ g: C; k" \
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)2 C: A/ i1 H# R
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
4 A' n5 y- Y, s) i# d7 S( s$ P4 ]- u1 T+ ?0 z# O, P
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
9 ]5 x' y9 L) {, m- \) D1 u7 j+ pEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz' n' }5 G( w, @
+ K/ u& o9 u% K
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
0 S: W9 Z( t* n- |+ L9 B! w) y- PCI clock: 33.3MHz
% G2 w/ A! d) J9 S7 |8 h" b9 z- SATA clock: 100MHz(see SATA spec,似乎還要更精確...), k$ [7 z0 o9 y+ f
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
' A- Y8 s1 E$ O- T5 ^# ]- USB 1.1 clock: 12MHz2 ~& }7 A8 y" Z$ \
更正: USB 的 clock 是 48MHz, b H ~8 u6 ^, C
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
! a) {. j; n# t$ t, m$ m. S6 ]+ Q P5 G8 ^3 Q
- SIO clock...etc
( @" ?: n- s, v* u1 t! b) A' p; T2 `! l$ z
Clock Generator的架構
K" e, b6 E6 A% ~; {=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:* b6 d' S, Y, U* A: n! q& }2 t0 J
* A# r- }# z. Q7 ~% U- L3 P( d14.318MHz -> PLL -> F -> Div -> f
8 K x1 n" w/ E# X
. j' B* A9 D# `5 z3 nEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
& c, `4 K. ^) d2 J0 @4 U' F" L/ O; W/ P9 z
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !, m: n# ~; `) n8 w$ N& k
$ ^) L: V8 ~9 }/ H: W3 n: T/ d
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
F0 z, D8 T. U" c: i. ]+ Q補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
0 W- k. y/ j0 [4 B1. 有 2 bytes(即所謂的M,N)來決定 VCO
+ S$ X, Y) q; J1 b5 P* u2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div A/ D: f" U% |$ }
3. VCO / div = frequency
3 U5 ^' e/ i/ n; `# H0 v3 E+ a) E) A4 U# Q) R6 `
How to access ClockGen
- W# T9 F$ E7 }( e9 g=>現今存取 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
, H2 l7 {) }6 P/ Z9 h) s
9 y7 w9 ~3 t& y3 ]0 o2 O) D不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:: P/ E: C' z) B2 E/ J3 ~7 O' @
- pre-init( clear status or ...)
$ O. r$ b6 ~4 B3 M/ t4 N- put slave address(要 access 的對象)
9 w- f0 |7 r( ^- decide Read or Write: O! O1 v- \; P8 E
- put command(Protocol type, Ex. Block or Byte access). ?2 q( t- ]6 K- e
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
" b: U0 Y/ L0 C, |: R" Y$ w- put data if (Write device)* {" i; W4 g* s, U R( O
- start transaction !!!3 x" ?: V- \0 C
(... processing ...)
3 z( ]2 {$ _; x! h: O- get "Complete" status to check if transaction is done successfully
+ y% r' ~% x9 X" {. Q9 R* h' ?; x0 }(...wait for system reset...) 4 H% o' f2 M; B) j, Q# v/ g0 J
. \* j. ~1 |, }) |: W
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
( A. A) j8 C/ T; H( _3 ^9 p8 w* V6 T7 R; `% {- [7 }7 Y
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.9 S& g3 D3 i" j- [3 o& P: v% _, L
! X" y: [! R% k! z$ q1 n" K z! ~
[2 Programming ways for clockgen]5 P0 o+ A5 U' d8 m$ ~* u3 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時會用到6 [% A* x$ C( r! Q
( z4 j1 K/ x9 Y! p5 j9 i
【Notes】2 [* T' V* i& x; c' `
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
/ ^/ |5 g# _2 f& U5 J* i' P+ d/ c2 D8 d, e' D9 d
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
6 n! f0 U4 c b a
; `" [5 E8 {2 ~3 f" ^
" X. E3 o6 H" C( F7 X, U2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
8 @( ~8 ?4 u! e
" l0 M: O4 V2 X! X" y7 b4 v% s給我正確的頻率,其餘免談 ...^_^...
8 ~* G/ N( \1 w: R6 E F/ g3 t3 w3 B2 p* G; X: y2 t0 j
=====================================================================4 Q k! i! e: m( ?8 q3 J( c
Q&A# f a N+ I) ?0 N M9 o
=====================================================================) Y' Q0 ?/ Z* j* C
>前輩我有幾個問題要發問!
( `0 |( \" w7 A>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
+ B, q; n2 c( {$ [ W% E1 e9 v>! v, W! ?5 Z, t- a% m1 K/ C
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?: a% o9 x' l4 Y& o/ b5 n
>8 e+ m' C. f4 @- S/ \
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
0 j6 @! _5 M) H- d' a; J9 t6 d>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠. R7 l" W3 j0 b1 N* K" R; q
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
# F; i1 h/ J. g2 {" X+ C# t
* p: a$ l* W/ `3 c- a* [[For #1]6 F- e i% D2 x: M6 v& }/ L* 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 !* \1 w9 k2 ]/ l- q2 P5 ^7 g/ s
' ^% t0 M+ p+ i5 m& [9 N此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.0 u% b6 X' h$ {, i( O( i! }
5 u% u/ H# l/ I a+ o- M3 B( I
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )' K0 D+ H% A/ T/ _! W5 t* [
/ T( A$ n, |( C* V1 L) PEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz' W0 n# s. m P0 s
S/ v' l4 V" k7 [' K! K; K0 L4 o5 p
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!% H/ q8 p& O) _/ H
# ^# Y2 X5 e0 y+ t* t
For #2
1 a7 h! c; w X6 L! A4 O$ S=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
9 m2 K y2 L( q' j" m' q(...想像以前學的直流與交流的訊號...)+ {6 M+ X/ m) u" E' o9 ~& L# |
4 a# n9 H; x. a. n100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
; Z3 U- E9 `) P+ i u d9 }7 D" \0 ]; H5 B% T
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
( y9 u! P, g7 o; y+ @' o/ E U# X
, M/ l' \" V: u" X- c- ZDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
6 }& K& e# W! n
$ Z+ N5 K3 H5 B) q$ }For #3
6 P8 u& h& K) }& p6 y& H& L=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...3 D9 n% p4 z# j4 L
! H7 ^; L& T/ M) ~& w$ l7 C s* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
7 y; z7 |5 V0 y0 b* f! g, j* ~+ s: e
[[EMI 測試的知識]]
8 B# L. x C" W+ K由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.
" |1 g9 i: |( a
. @0 \! q6 E: M& G* Z為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.4 s+ \% e4 w: }4 N4 ^
& M4 i. F, `: ?1 ?3 u8 u: b
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改. |
|