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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.0 }7 L& T$ C4 V' ]1 J

$ z0 w* |$ k$ C在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
" Z$ m0 w( A0 t, b
7 a6 |( q# y6 T  r4 h3 r& a# ^有哪些 frequencies由 clockgen 提供?
# F6 I% o" P$ R9 j6 }- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
. i( M3 L( Q: }# v. e, P* o$ g- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)- h) D- V1 Q: r: h
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.3 Z. i/ q! i9 b& s2 v' G
5 F5 O  g4 v  t( o' r
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
* W& y1 ]6 f2 b6 C  @9 H& kEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
. L( X' O& }! l$ O1 G* x
* D1 j1 C" r! }9 V- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
( U; q2 b9 o5 k9 _# C) ^' @& m- PCI clock: 33.3MHz" h6 O0 f* b" Y( e; J: j/ h
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
) P8 K3 c! ~) z; y% a- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
5 }8 M3 k& ^) w% M7 H9 H- USB 1.1 clock: 12MHz' o+ u. v6 ]6 n& p( A: Q
更正: USB 的 clock 是 48MHz
5 S; _/ d+ {2 z, w* W; R5 M  a補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !  u  I' R* d! Z# w( a( r3 U" ~
- i3 z2 t' e: O/ ^7 r
- SIO clock...etc' F- B; V& F. s" b- \3 Y& z  k
' z% c& M  v9 V8 f! M8 d
Clock Generator的架構
6 r0 X7 W; l1 Z4 z. R=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
' R! h; R4 j! \% c6 |, _0 P" J. B, R5 w! v% z
14.318MHz -> PLL -> F -> Div -> f
3 |0 i$ Q3 K" S9 s( ]: \' c" U, q5 e; G
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz* G9 }& j" k) b3 G% q5 }! X
% d) [3 D6 o: p4 u; V
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
4 S$ C: X7 V, l/ C0 U: M( r) n
/ }* [2 m" }8 e0 _更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) # K8 b. U! x3 l3 P+ ~/ i& j
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:3 V5 A( n  n; z9 G5 Y. }' Y* Q3 D
1. 有 2 bytes(即所謂的M,N)來決定 VCO
: v9 d- Q- W: k2 g2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div: @/ S: U9 ], ], y" T  j& p+ I
3. VCO / div = frequency* ~* {+ y: d( {! u) }; m6 w" \
" l/ \: O! r  a! E
How to access ClockGen
/ E% y8 F- z# [+ m$ h% v1 p=>現今存取 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
! G7 u; d. u( p, R6 P; h1 z/ V+ O- }; j- {3 j
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:6 o. b" z& u  N" R" D, y1 Y
- pre-init( clear status or ...); r( W  |" K  h7 o! b. Y
- put slave address(要 access 的對象) $ e3 W2 x0 z9 D6 ]
- decide Read or Write& a7 S0 }) i$ c/ \0 x) t8 T& X
- put command(Protocol type, Ex. Block or Byte access): H9 G8 |+ N! V/ H4 W
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
, e- E0 L& \3 w- put data if (Write device)" S1 z2 p- h8 h( R
- start transaction !!!
6 Q7 y3 B+ D7 n7 Y& j8 A(... processing ...); _* |- y# ]( k; R$ O$ n
- get "Complete" status to check if transaction is done successfully9 H( ~( v8 `: f5 {8 k
(...wait for system reset...)
9 H' Q4 V" B1 \* O, _* J- O& S- a/ K& _# o! h" I0 R
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.5 _+ r- G3 \2 \$ C/ ?" h; _

, s' \4 O) t7 D: w2 t透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.( B; R6 I- U/ e+ w, I) s

; }' [# }  t9 c[2 Programming ways for clockgen]
6 r3 H' D4 G! s6 t=> 現今的 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時會用到
1 r* p6 J. G3 q) e3 `( t+ _0 I% T
& p% H' ]% U8 {% Z! [7 G【Notes】
' _! d" `* L6 C! t1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
2 I2 b  Z6 @7 s1 V8 g& M7 f
. @0 x: ]. h! N3 ?更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper( p5 i+ k3 d4 j% _6 X

- `3 f' u8 X! V1 W% t5 I' H+ G- d; L  {, h' v
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成- U; [5 G: H! \# S4 ~, |
) H- E4 h! V3 G8 V( o
給我正確的頻率,其餘免談 ...^_^...
8 M  Z* d0 ^8 Y% m4 @' n( O. C5 x; u' J: ]' X" O, @
=====================================================================. |& [- |, Q1 e) q0 T+ B
Q&A" j) k( Q4 F. m0 ^
=====================================================================7 n: j5 T' \" E9 C2 Y
>前輩我有幾個問題要發問!" p5 s7 O( n$ @3 S: l. E& V
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
# d8 w- K, G& i& B9 r>
$ ]* k" f$ w( F  V: o  l>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
* A+ d! e: |4 N7 E  |0 V>  Z( |1 p! s, p
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以/ c$ d+ d) B) S9 k$ ?
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠, ]9 ~# N! |) O) ^* E$ {9 C
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
, [" N# g) j2 i) h4 P. b6 j! y. Q2 o2 o
[For #1]+ T" m* T& j: O: c, l
=> 我所謂的 "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 !" G. \* b3 K, T& g0 t
% D6 Z9 ?' J. H8 f5 ^( C& k
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.+ u; C/ v' o' W) V/ J
+ m" Y, G* P9 S7 I7 a1 `& B$ `2 O2 ^
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )+ c, k# o* P1 y9 ]* r! D/ e
/ o. v1 z  k" H' m. P2 z* F! t
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
' P& j3 H0 p# D* ?7 Y' \9 J8 {6 K  W# x3 V
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
( K& t0 A# v2 ]+ J; b, k
1 X4 e1 U- S( o- |0 p( \For #2
% z: V7 c, j8 s2 H- K=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:  j9 q% Z. p( c
(...想像以前學的直流與交流的訊號...)
4 s2 r* B' d2 n: v: E
) W. w' ~- r/ H' V100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!5 ^: ]0 E( b" O& q9 V

, q% k% ]7 m8 @8 w9 F4 W3 O我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
# k7 o! `. l. o$ {- _
7 n% h/ y! R1 V" X) \. d  ~; _4 E& RDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )! i) c4 r! x: i' ~# m
; f0 q' \' u8 k/ w  N
For #3
& O0 j- Q+ l" b0 M5 r=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
& N2 I. `4 w) E* N, u( r* X5 d& ~! C  O5 x! O: o% ~
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
) U% E9 w8 P+ h
# ?. N# B7 w5 I& B[[EMI 測試的知識]]
1 ~2 N7 }; s  i$ X8 R由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. * P  J* L/ S, C8 c# c% K

6 n5 N  p% K- }3 c" Z* L+ E為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
) I% ^  `" \, v" f6 ~5 @
9 e3 f3 r' U3 d. l5 t" Z7 N$ {至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2024-5-20 07:08 , Processed in 0.024444 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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