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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
( h/ m0 f6 ^0 j) }* Z) A1 l* z( p8 B2 n4 ]
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...8 ]% i# W( D( A# N$ I$ v

& n8 r. G# `+ S  Y有哪些 frequencies由 clockgen 提供?
' P) W2 A8 V7 a% Q) i! M; r$ k- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)6 n& i) b' y; Q/ k  s! [8 }
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)5 |# a. H! o& |3 I
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
  F- I2 s; ^. |, |) k+ \8 m: |& d" [: I4 E: O  l# G1 N
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
! `0 m, ?) x" O$ B& HEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz1 g2 D6 D. \# O

. F; G  b: j. B  @- c5 a8 v2 B- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
2 l) L6 Z3 M) G% Y$ Y- PCI clock: 33.3MHz
( ^+ n! V- e4 Q' M" t- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
/ o, x' }3 S4 \+ i" u5 K" a- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供8 E9 _$ m0 w4 {8 @/ _+ |. ?  S
- USB 1.1 clock: 12MHz; R8 \% n, I+ l& f- ]/ G6 D, E
更正: USB 的 clock 是 48MHz  {3 a* q& s" J" J5 ?, x4 L
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !# }6 ^' P5 z. b! Z9 u6 x

7 o5 A( @; U: n+ I1 N, T- ?2 \- SIO clock...etc# `7 H8 i  `" Y6 z! w8 F
0 s$ U0 V1 J7 E( H' \1 n# R
Clock Generator的架構
$ D) V$ ]) p0 \4 C8 U( e=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
; P6 g9 U# L: h
" c* Y3 Q6 p3 p" G7 G8 n6 z14.318MHz -> PLL -> F -> Div -> f4 r( b4 B4 z; j; l# Y
) B/ G; {- d. ^3 _# O
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
! O7 C/ M& y$ p# O% {5 D4 K
2 m6 X2 D; T$ M7 K" gClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
3 }2 O& s9 [  O4 G1 C0 n1 H. K: q/ l' Q9 ]) z( V- u  Y; o
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
7 H! U6 E! V% W& e- E補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
5 M, j: L3 H4 m1 k7 ^1. 有 2 bytes(即所謂的M,N)來決定 VCO
! [% h) `& c: c; _4 q% n2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
" @, {$ E( \3 I, |3. VCO / div = frequency, `( p5 D0 X3 A' R. W6 p
& _$ a5 ~9 l7 g! v7 i2 I
How to access ClockGen+ o0 D* `& ]! S5 o5 N; Z
=>現今存取 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 b# S( a% v& \' I. O8 C" A' V
; h4 _. ~. q3 r( @4 w6 h4 h/ t
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:3 m" t& V( e3 T0 e% f' v; @9 \0 V
- pre-init( clear status or ...): l2 y& y6 L1 e/ Z- g! h
- put slave address(要 access 的對象) , g; M. d* r' y2 w4 U
- decide Read or Write
, m$ [/ M* l" Q- put command(Protocol type, Ex. Block or Byte access)  b3 i1 p- B; w
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)0 s# B  |9 u+ `+ |. P
- put data if (Write device)5 U/ ?: ~9 B- z: a, Z5 s4 z
- start transaction !!!
- G$ {. ?, P# d# ^9 Y9 z; l(... processing ...)
+ n) i1 Z& p2 `- get "Complete" status to check if transaction is done successfully8 R& I6 D% M% q. t" g
(...wait for system reset...) - O) S( I% a0 r! q

9 c3 `# U- U$ R1 W* ?# g* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.  h5 z5 Y/ J/ b
! `  Z2 g9 w4 x. ^
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.: O) ]" [1 q5 K9 J+ I
4 N% Y$ d/ Z, J$ T
[2 Programming ways for clockgen]6 J  A/ `) x0 Z" k
=> 現今的 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時會用到0 C1 `' n0 v  w. U9 P2 i* u8 J* G9 l

4 ?) z$ ~! h7 ~2 u& Z【Notes】
. _; T% P( i+ h: ^9 ^1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings: l' u+ x9 r! o& V( p# U
- _# U3 o7 d. A
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper1 V% m; T' F5 }1 T0 u! u/ y9 _

( D/ r/ b  i7 n% ], C
- \! q2 J: |, y% {" U2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成0 o5 Y) l! a9 i* W+ r0 v# L, N5 J$ n
& c- T0 }( F! I0 P3 s
給我正確的頻率,其餘免談 ...^_^... : B4 e9 [. E- }- K1 x. \

* T3 `( S* v  Y6 Q  U% H, b( \6 Q=====================================================================( Q" {) E5 H$ }: l! ?9 P) D& P
Q&A
- g1 j( l! c; h$ v1 M7 N=====================================================================
. R* S0 ?1 O" t9 x>前輩我有幾個問題要發問!) @8 x: h) P, @7 Q# w6 N) i
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?  x; G9 D7 p% A/ P5 J9 P3 I1 G+ |
>) g6 H" [/ z) F
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?$ K) C2 s, w/ y
>
. R# G8 U5 X9 x; Y>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
+ ]) I' s( v  b% Q3 D>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
/ K3 {1 l+ e5 ?0 ~( Q; B( J>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
) R( D+ n( R1 P  d- F
& R4 x. B) _1 `- T( W1 u3 C[For #1]7 B, l9 h: |! Q
=> 我所謂的 "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 !
4 E  ?- i7 k5 S3 _- s5 ^* E' _( D1 H4 k
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
* N2 z7 }3 s5 t2 a( V/ I. w, G0 D1 W1 G$ \5 @. t# K! `
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )- n/ h- b- n: o
% X# F2 D6 D' t/ d; a* [7 `
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz' ^  w: k0 u0 K9 U  O; x
  _8 |! A" t8 c  m
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!' i; a) g' G$ k+ u( k$ L
5 P$ x8 n+ _* ^: m( q8 U
For #2/ q0 d" {6 a1 k8 C  A9 n
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:2 f, D) R/ m7 J4 z7 x7 {$ l
(...想像以前學的直流與交流的訊號...)) r7 W' w) W) s0 H/ c5 Z  o& p  A

" H" l% Q! z0 Z7 K0 o9 m! E100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!5 R7 I9 \8 k* i5 |3 @. e* Q

  j% J+ G. l3 e3 Y' A5 w* X我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
2 i5 a- X/ L- I8 O2 w5 c
9 g6 p# l/ x- Z8 @  C% J; ZDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
7 f- A3 @# s- k/ m, }; O( z8 [2 \% J, U% B# _$ B1 X1 e$ [
For #3" d' S6 s( a5 l  [4 d
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
) i/ j! |* h& F5 }1 H
8 v/ G' R& P" y0 Z7 [1 i* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )# V3 t" Y. @. m' k; G0 u! {  D
5 H: ?$ r  }- a* U: ^
[[EMI 測試的知識]]! f: s' b- t7 A6 j% z( ]
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 1 d8 i9 f6 L+ t& M# r

' n7 `9 a9 {/ b8 g為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.8 t7 i& c! H0 E8 O
6 l4 d2 L" {' f% e8 ~/ V9 y
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2026-2-1 12:34 , Processed in 0.055162 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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