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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.  M/ z5 p6 i# M0 P; {. f2 e. z
1 B* R' v! I8 k4 @9 l6 O4 X  e
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
( c& P0 j5 N7 L3 W" M9 `4 s! y4 z4 i+ Q3 c
有哪些 frequencies由 clockgen 提供?
3 w9 f+ {( v( F5 ^0 Y- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)/ c. M1 J( Y2 ^/ A/ V% e
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)3 v& I% U& `: |) m! ^; Y
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.9 ]& @  B( [; b

/ e* W  z2 I+ a% v/ B補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.& i, Y8 q. J( b* y$ S
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz. w& l/ E. g' k. U# W! [: ]
8 u3 @/ I) k8 }0 n
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)2 S$ U; J" q1 ?5 i  W& Y
- PCI clock: 33.3MHz+ S8 y1 X9 h) q1 _
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)! f) ?( ]# f# N" }6 s. x
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供( k* @7 C$ U- X. \+ N4 K
- USB 1.1 clock: 12MHz
# }9 C9 z& F' X) e9 P/ x更正: USB 的 clock 是 48MHz' C# g9 R9 O( g7 g& V# w
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
7 k( m6 |" t/ s( a- U! I; p3 U/ }8 p& |& J  |: q  G1 F4 L/ d
- SIO clock...etc
0 S5 F" a7 D# x0 U0 f& h6 N: b
( T$ m" ~) r" b+ G6 [) dClock Generator的架構
- b9 ?8 t% |- P2 q=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
+ N. G, K, d1 `6 l. b2 L7 o1 I; h! l  i, z
14.318MHz -> PLL -> F -> Div -> f
( h* Q, W$ ?6 A0 ^. X: U9 M0 g+ R- G' @, r* @7 B
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz( Z4 X2 L; U) u- t

  _$ ^9 v; L: w# u9 K3 ~3 w( hClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
1 W' t& S- w! f2 w, V- p, v; D( B& y
. M0 n$ ^- D; U3 _0 b/ K更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
2 ?6 G* k8 q, h9 T. D; ~, r# x1 S補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:9 W6 S/ X8 Y* x
1. 有 2 bytes(即所謂的M,N)來決定 VCO) t; j  v6 _/ M
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
. j* }0 K  h; q3 U( m3. VCO / div = frequency
& \' a6 M8 `2 o5 u$ t# ~9 @& w1 r. w( J
How to access ClockGen
% |7 t; I" ?% w+ F) x2 ~7 ]' e=>現今存取 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
2 k0 g- a1 S  ?& x' K2 w& `0 i- `' [) v4 F1 K4 A& n9 v* i! Q/ P
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:$ o+ \" `% H- M( Z% s- L$ }
- pre-init( clear status or ...)
+ Q) {7 f3 v* W7 g- h1 B# |- put slave address(要 access 的對象) 4 X# ?& I0 g  v6 h* x$ G
- decide Read or Write
4 z; d7 C6 d) P/ j; p- put command(Protocol type, Ex. Block or Byte access)
% a1 \# `9 _3 V4 }- put offset(要存取 自 clockgen中的哪一個 Byte開始...)1 T" @3 [$ S* \4 H, Y
- put data if (Write device)) A6 P( w6 ~/ q1 B" d/ x
- start transaction !!!
& r7 i  J, B( s(... processing ...)
! h0 D% L+ s) b  ?. q$ e! A8 e. [2 F- get "Complete" status to check if transaction is done successfully
# v" k; q( y: G. z/ Q/ J6 _/ a# n* \(...wait for system reset...)   W, A1 J5 i) s0 b7 s

, d) U% n2 [, G8 X/ y* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.6 t( N( Z' h  y$ d. B/ S# v

3 v6 g) c- z, Z% |# `透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies./ S; c1 y4 f' b3 J0 A2 r! B1 Z2 `
1 ?  j' L6 I. l
[2 Programming ways for clockgen]
. C" r8 L) w8 W) c" F# o=> 現今的 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 a/ _* c6 s5 a4 H$ c( r) m( `+ ?9 E* p4 M
【Notes】3 z2 k' z$ N1 Q* T, F
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings. G# M$ O0 ]* R7 F1 C  m8 s

+ u; A+ D& K- f1 h更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper  x" u$ W5 l  \( W
6 w- C/ ?. S( q( R( h

" K$ [$ \7 H( Y0 H2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成' f& r1 E! w( }8 U, P

. p! Y! l- W7 z! o% U- S% X# V$ D* v給我正確的頻率,其餘免談 ...^_^... 4 u# X: H3 I+ |( W+ V  d' m  c

: x' z+ ?9 ?$ z3 X+ z3 V=====================================================================6 T) q( Q" S: ?* z7 J
Q&A$ g1 w# J4 w+ S  B" B8 X
=====================================================================3 t/ x/ a0 O( \2 D8 E
>前輩我有幾個問題要發問!
% A* L1 B6 l3 d( [>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
2 _0 X6 N% b6 ^$ f>7 a6 t% X, |' i9 c# @, L
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
0 k1 p9 ~9 `& p& }: v>
9 w+ ^3 z2 _- ]9 y>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以6 Q5 K/ P4 C4 n" `" \! u
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠1 ~) H$ ~2 {" @1 K1 v* j
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?2 s1 A3 `! \9 G; {# r+ S/ N& W0 f+ s
" C$ J$ p' [0 w
[For #1]4 I& n1 T. e5 e  G  \8 M
=> 我所謂的 "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 !  _9 R$ m6 q& o9 i3 s: G

" D, ]6 _, n+ D5 M# b2 @4 a2 I此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies." \' P# n! s1 `. v- {* q8 d& G
8 M2 D$ a3 x6 P, W) y# n7 R
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )( M" ]6 m0 O3 h, H$ {

" e% `7 k" b% i4 uEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz. \9 Z+ C9 r7 o: I! e

9 H9 N/ T/ b; D' H2 }3 i還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!  q; _5 K5 N3 @7 c% D4 @

; g4 b$ M% C, E7 p7 }0 D+ r) k3 \% J# sFor #2) d# Q8 |" h2 j
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
  G7 Q) s+ U/ S1 I% N(...想像以前學的直流與交流的訊號...). |7 o. i6 n5 S' C7 _

3 r' U" t4 c$ {; s. M100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
) Z* |$ a. Q+ n/ Z& ~9 z# x9 |+ N& G; f3 w
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
" r1 }" P: q; m; T; M6 @
# G2 ?7 T9 `* I  }6 i6 sDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? ); o) \+ z& B# p1 x# A
# R  e, i7 v3 Q) H
For #3. ]! t) |0 ?. ~* [# P9 I8 E4 @
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...) S  f8 w8 y" o
5 Y% o6 y( r7 y* G! T
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )8 h# R3 k4 K! e4 E. S: \9 z" @

0 h& d+ I7 A4 z+ s7 \[[EMI 測試的知識]]
+ R2 R2 t% j) p8 _8 m7 C由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾.   _1 {: ~. C# V8 v. M) q

0 S+ H/ A- h0 V為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
7 }3 @+ p7 j4 y3 \. ~, @5 \
& ]  @7 S- V% W  j& M至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2025-12-1 01:27 , Processed in 6.446956 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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