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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
5 ^  K: \& ~5 D) E4 u- m. R6 o! s" u/ r1 r. P' c! I- h3 P
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...1 _$ Z. |# Z' e0 R+ {8 c1 d

! ^- |3 k9 n! @8 t有哪些 frequencies由 clockgen 提供?. N- \: }$ c: `+ X: m
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)6 ~& O5 F1 e) q2 s* x* V
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)7 M; m) P! C6 P8 _* W" {5 k1 V
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.' p- Z* k+ d( E
2 w& \5 V9 ]" |' Y, s: _
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.9 w: r5 }1 ]& W$ {- p: z, N
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
% v& G6 }: d" q
% [7 u: F* `% W4 y- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
$ F; I9 }3 N0 f( o4 j- PCI clock: 33.3MHz
8 h, j- H1 @; X- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)5 `0 N+ E! f& S: T( ~0 K$ _
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供9 ~( r" t# P; l  t
- USB 1.1 clock: 12MHz
% U7 {. w) ^" \# P& n4 `更正: USB 的 clock 是 48MHz
6 j9 }0 m2 h0 n2 p' ~補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
8 P! f3 i9 v( E
, x$ l+ P# J! F- SIO clock...etc2 ?/ G  c# U5 i; V2 D1 D, I8 ^( `: I

$ P, b; S1 C' \% Y, ^5 qClock Generator的架構3 Q# k0 t: ~9 q" D+ J/ h
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
- a& X! y9 T3 Y0 D1 h- @+ r  @  P. {& z
14.318MHz -> PLL -> F -> Div -> f& g9 D# l& x: s( ]  g% I% S
" Y5 q+ E, h6 R  `: F* h
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
# w( q1 \# F8 e2 K7 i' l& G% x& l  k3 n
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !/ e( h) H& X; z6 _
/ v- c* G% M9 J7 Z
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ; \  e* j  w: i$ e
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:3 f5 b- l- o9 j
1. 有 2 bytes(即所謂的M,N)來決定 VCO9 F7 m9 t  q) M& ~
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
5 c, e* j0 [( n2 h& O# M3. VCO / div = frequency
+ K! u  P  K) R) m" C
  I% m- l9 [; s, e" u/ tHow to access ClockGen
+ Q# e; m9 Y& {$ x=>現今存取 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
7 W" z2 ^5 }. x. N0 ]! t( K
: q! H' s9 a; V' R( J9 o  J不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:+ N4 W  i' y$ m2 ~6 `2 Y6 _5 F2 N
- pre-init( clear status or ...)7 j/ Q& w4 a" i
- put slave address(要 access 的對象)
1 t$ G: \3 R7 B7 i1 R' B' c! |- decide Read or Write% j$ i5 L8 e; r5 h9 @
- put command(Protocol type, Ex. Block or Byte access): C; Q# c( f1 ?. Y2 P2 Q
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
  i; h* d& y& F* Q0 {7 W/ W- put data if (Write device): y% X$ Y. |5 e1 L
- start transaction !!!
0 {2 Q1 k9 j* v/ v(... processing ...)
. r5 {; w2 M1 [1 O- get "Complete" status to check if transaction is done successfully
- X# {8 G; J+ c/ p" ?. [9 B# x(...wait for system reset...)
+ x7 z1 L8 [. i& O8 ~$ J- y2 C' C8 i4 _8 V* S% ^: |" _8 U7 q
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
( O- P5 B! L, r2 v4 h
: _3 f! g1 N! {; ^% Q% [透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.; P  ]$ |  N1 k! [+ G0 y

6 l2 I0 V8 t. @$ A: ?[2 Programming ways for clockgen]$ ~0 ^$ w% s% ^; p; h' z- w7 L1 P
=> 現今的 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 L; A( z6 t* O. D' k5 a% G# u. M6 N1 R. |+ L# f4 L3 U: q6 `  M
【Notes】9 r# A, b7 K' m, W
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings. B# {5 U0 P1 J5 E

( l) h: E3 `  l; e8 M" N, A5 X% V更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
$ C! c# p* R* E; [* L1 D$ i5 Y  F! n' O+ Z! ]
2 C+ g- ?2 C# X) K
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
9 S9 q% ~/ n: x7 M6 f6 E- `- z; F7 [% i$ t. z# I5 l" V
給我正確的頻率,其餘免談 ...^_^...
& R' z: i, u- B& w5 @6 T2 X$ g
" Y5 O& v9 l- _9 q+ X=====================================================================
- \0 X9 Q/ e, [+ `7 [4 ~Q&A# B( m# ]9 t- e! D: ^* ?
=====================================================================
; f# C& |6 ?- R  `9 ]% {8 L8 P>前輩我有幾個問題要發問!
# {! M) H4 a. O, A1 w>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
3 G4 H3 T* }" j3 o3 M>/ ?% u) A3 a! m6 c' h
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?% K5 H, [7 m& E  U- B4 i9 F
>& K$ F, ^  b/ o- |* l# }+ ?
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
; }$ }6 P2 D" D) M+ c>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠/ Z" Q1 g7 |: D0 j2 x
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
+ J* W6 d( U; |0 g: ~5 u1 b' d' `
1 M, O2 i- c( v6 }* b[For #1]. F$ r3 [4 z# `
=> 我所謂的 "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 !
/ Q& d( a* V. W! [) T7 a; x, b3 d4 t% Q
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.- Q. ^6 K  ?0 u4 O  u$ S4 F' e
1 @. k) b' D& c0 K$ `
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )! r/ {6 I! {" N3 b/ r% O1 G8 n! a

" r- L8 x# O8 ^3 {( lEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
. ?6 p& i4 O( t, K+ }- _
& ~+ ~0 q& q, `4 z還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!# s7 f) v+ c3 F! ~
' t9 e2 F( n4 k% |9 ]+ ~
For #25 F& g' b4 N* w: t
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
4 f( |4 E; P4 c; U& H. L# s% }- t; q2 ~(...想像以前學的直流與交流的訊號...)
* m- ~, h& B; w' ]& n! Z
9 ]6 p+ ?9 u5 @/ L100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!( U" W7 f9 r4 s% [4 B& G
3 _; {$ j9 n. X% M/ S0 z
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等$ [6 X, w' V4 z: i0 H

- W, x+ j' ^( nDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
: U2 V( F/ C/ l& N/ z( {' _! `. c8 k( b0 S6 ]  Z
For #3
# j: _7 W+ {. `7 e% d6 u=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
3 H5 v+ ?3 }0 c" @/ S0 z( x7 r) Q
+ p' T+ ]! p. Y% k. B* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )) T2 X: `% @, I6 C6 X
( _  ?2 s1 \- p2 L8 [
[[EMI 測試的知識]]% Z( J7 D& |  F# |4 }
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
' E% c/ P% d1 O3 K9 Z! ]9 J3 s% u- t$ o. X0 m  ]; o( [
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
/ q. ^3 I" s) ~8 X4 Y
/ t2 ?1 ?! ^2 @! |' u. k' W- c至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2026-4-4 18:23 , Processed in 0.073640 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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