找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 10434|回复: 0

[转载]我所知道的BIOS -Jumpless 4

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
8 A. q3 }1 k- Y5 P# |
: V1 E9 U$ ?: M% S4 Q7 G在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
1 n  H! G  p: z! E8 K
( B) B4 q" u: {* u/ T! N有哪些 frequencies由 clockgen 提供?, }7 j3 Q* a" _, u
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)  g$ O8 e7 b0 I4 Z( U' i  K; f4 G
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)( [9 e/ A) L4 L$ ]) O  m5 L6 M
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
- Z, R6 k5 B, E! ?9 W2 ]1 V7 f) l$ M+ @9 T5 o0 J
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.: _4 i0 U  ]. Q) O3 e& M7 j! Y
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz$ a* |/ ~: P: E+ U2 l- d; I, K
  b2 G1 l  B5 J5 Z& ?4 }
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
/ g  q2 ^# f' }- PCI clock: 33.3MHz& b) m( r" a3 Y2 x! s1 }  @
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
4 K4 w( A) f; l: B! I  P4 q- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
& S9 m( V& Y+ l  |- USB 1.1 clock: 12MHz' F- g* H4 ]8 y) \* \) ]" m
更正: USB 的 clock 是 48MHz
# \/ M( J6 y9 ~1 ?3 m. ~補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !: \3 Y/ [/ h& `  K6 \# m
) Q+ @' |+ R2 h6 u/ e. I9 w
- SIO clock...etc
% b& f+ S# Q9 P4 G' u. m! G8 z$ N* X6 l, J
Clock Generator的架構
, x4 x: X# `& x3 B1 J# g=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:0 m% M) J$ C8 N! o2 \+ Q% M2 X

; K. V* j1 u  L: c+ @: z* t14.318MHz -> PLL -> F -> Div -> f5 v' C3 l) m3 h# d

/ @2 n, |8 K+ r( F( C' n% x4 `4 DEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
+ ~8 M) A" B8 N
: h, g0 g2 M# l' pClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !: S3 N6 p( b7 _. @: Z
# G% n/ }0 [" \! K6 W9 m6 ?* _- E
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
' V4 E: N5 T: K6 w補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
1 H! N) C, v3 D) _( Z1. 有 2 bytes(即所謂的M,N)來決定 VCO" [3 N% {; r3 ?0 H6 `
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
+ }0 R* B8 |2 n. s, e2 |3. VCO / div = frequency2 Y, c+ m7 ^# t7 h3 a
$ `$ ?# W# y. A+ L: t$ J7 W; m/ r+ f
How to access ClockGen
' g! @8 q3 U" J3 V$ d. C/ s; j=>現今存取 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 % D( _; ]) d4 F2 Z

9 |! @4 D: j; r4 ~不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
% r* P7 z( J" o7 M, E- pre-init( clear status or ...)
/ V0 b% X: |* S- put slave address(要 access 的對象)
8 z$ z1 |* k2 q0 D& I) S- decide Read or Write& p7 A% b. M, ]  r- v! m# O
- put command(Protocol type, Ex. Block or Byte access)
& [! O0 s% |# D6 X, v- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
! d/ P- Q! m' s1 {$ h* t9 i- put data if (Write device)
. T8 e( d7 h- o" U8 c/ _- start transaction !!!
* y: o$ I( ~; D& t0 p: a' E(... processing ...)) O3 u, x  L8 c0 P  k
- get "Complete" status to check if transaction is done successfully
1 ~( e3 O1 ^: O( \9 w: d(...wait for system reset...) 9 `- h6 ^& z5 j9 p

; u" A) y" o7 p* i; C% _. r* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.- U" S' q  y/ f

5 I3 U3 b9 R7 I' h透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
( V$ d8 x$ q, d8 u# Y3 u/ ]3 n( S. q' `  u
[2 Programming ways for clockgen]% h* n' _# p: x- e8 _
=> 現今的 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 P( ?9 y. v3 p7 N7 r4 c
3 K! e; V7 u5 K: c【Notes】
: B2 `* R) ]  y7 l9 ?8 ^* ]  y1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings1 b, R  }% y; K6 n

& k) p" Q! ^- T5 T" ]3 ^7 j更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
% ~1 |+ O4 L/ }) q/ m2 t% n0 ~2 [' Z$ r( \1 w4 ]7 q$ Z
" H& }) K1 V+ L6 X2 s( }& y
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
; \, ~/ r" M. }# i5 {  [4 E
2 f' {! d. g  b5 v2 B$ n# B給我正確的頻率,其餘免談 ...^_^...
5 V' X5 W, R" Y1 M
: h6 M& j, n) t# ~0 ~5 |=====================================================================+ u! H. h! G1 m6 P0 @
Q&A
: k$ z0 c# X9 H( U=====================================================================
$ M. l. H& z+ z# E>前輩我有幾個問題要發問!
: f0 e3 m' O$ k! y4 v; ?- O0 l& x>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
; B' N( b. r+ u. t" j7 o>! ~1 c( R: ]# u) A- t9 V
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
! |0 m/ L2 W& A2 z$ w" @9 h>% n8 P6 G1 j/ E* c9 S
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以# k( F2 V! K5 \2 v: A. f; F
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
/ ?9 h5 w4 F4 ^; t8 P$ x& \>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
0 _! j' z( I! S" T
5 e- o, ]$ Q9 d+ L% \[For #1]
! y# v- b+ Z" C) Z: x=> 我所謂的 "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 !7 a3 Y# I4 j* A0 Z; Y* B7 D, i- V6 q
* Y/ w) k: a: f2 A
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies." C6 @' C3 A6 r: [# Y4 Z
  m, X0 n; E1 v6 D' J$ L
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )  }8 Q4 Y7 h" O! h+ h+ t$ o' Q
' O5 A! `) t% y, p, C" g% V
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
; m6 ?2 L/ A; U* {3 w
/ H7 B6 u! b, U- r# @2 _還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!" ]; Y! b% n) W' |$ ~, l- R

! \, e9 F. R6 X+ A" d. I: R5 EFor #2
+ f* G  J7 a% B6 I/ k2 V=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
" I3 e2 Q# F0 {# G5 [" A" v(...想像以前學的直流與交流的訊號...)+ d  }2 E: P6 `1 ]

5 W3 O4 E5 p( _* B0 ]8 w+ d100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!2 }. G2 x& e, N) G9 K

. l' _5 q. o( J2 p% _' F+ i我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等3 O1 N* J# S+ u" g* U
3 q3 r9 c2 g4 i9 g
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )' t# Y3 J2 f/ a) G
9 H. y8 g" v" V
For #3# y1 [. ~3 m3 _2 r3 m9 B& ?
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
2 J. A) O% n* x; r; R) v% M; F2 ^. l+ E3 s! G8 {! W
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )  _; k* y) v1 @. @4 i6 H! T7 T. f/ V
+ O4 P! m: }1 e" V: l
[[EMI 測試的知識]]
( B6 ?3 ?0 W8 h  a* L由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
- |" ~8 w7 \$ `9 M. u9 g; i! _& E1 t( V' a, L
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
# S: C$ \4 b' D. O' X9 p2 m# _
0 c% P. G3 X5 P: I% i* \/ q至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

Archiver|手机版|小黑屋|计匠网

GMT+8, 2026-4-19 23:49 , Processed in 0.090792 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表