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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
. x  D7 O! h$ c* V1 ^  n8 U
1 u% {+ R2 R3 q2 ]在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
/ U+ w3 X$ E& y
) O7 j/ N# G7 i! |' l# U8 r有哪些 frequencies由 clockgen 提供?, |# ?8 F, O/ G# u7 E: Z" ]
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
5 g$ U" C  w9 F4 s  L5 r- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
9 \6 u$ K4 T$ ^$ c7 K$ A更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.9 R2 _1 y# j$ A5 e7 j1 {) w
+ Y$ p5 X1 Z' e! r
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.9 ]3 G6 g1 x# F, [. [- ~0 w
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
8 I" R1 ]" u& \2 p8 ]1 m9 j5 P' C5 J* x/ P0 }/ b
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
* l% v' b# q( n3 c8 l$ y7 H- PCI clock: 33.3MHz
" m* u7 r$ u3 O& K5 S+ \- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
) q9 _' z/ O: ?0 X# O0 ?  z9 ]! t- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
( U& z$ J9 @1 Z/ Y- USB 1.1 clock: 12MHz
, ~) ^# X4 v9 N* ~& `7 |更正: USB 的 clock 是 48MHz
1 f& X! ]' ^0 @8 a補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !5 f* M! j" e* p2 r! _
2 [( g$ h0 q: m6 A4 X! ~
- SIO clock...etc
6 b/ t' `. H* k4 h8 T# I
. m3 m/ g6 c6 G, J" XClock Generator的架構
  A, P& ^" T. @2 y=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
3 m* ~8 g7 y0 U& f* ]! ?- P
: ]1 [3 Z  V+ O# A14.318MHz -> PLL -> F -> Div -> f
7 D1 P. D1 U8 g: C- h' {0 t7 C6 ~9 d5 @2 h: n7 `
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz- J9 D7 d+ Y; v  R+ Z) b
0 G# ?5 C8 o5 a. D0 I
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !( p' x' X2 }+ f+ K: ^  q! b  v
3 [. x0 o" k, h2 V) q- d
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) / ?! n! S5 k, G% O: E- G0 X
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
6 N0 h. c1 K4 s2 x1. 有 2 bytes(即所謂的M,N)來決定 VCO6 ?8 }/ y0 y6 K7 ^  D
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div' v& N6 Z( c3 `( |( @- m  V
3. VCO / div = frequency* M' s  ~. T1 ^6 f& n2 g3 W7 j
: @5 C+ J7 O# b
How to access ClockGen
0 k0 \7 D" w- F, y/ `8 c) L* s=>現今存取 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
" [- e3 K* K/ L: N. o- @8 }0 K8 M/ Y& p5 ~7 M9 \; _! e
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
5 R7 p% F9 j0 i- pre-init( clear status or ...)
5 Z& ?# Z2 _% V# N/ a# y% g" R- put slave address(要 access 的對象)
5 _3 k) m. X5 o+ p5 X! U; N* r- decide Read or Write
9 Z* M' f( K5 e! c$ H- put command(Protocol type, Ex. Block or Byte access)2 A' R) [4 N/ n8 n
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)2 L- V+ M0 e7 a7 G& s) I
- put data if (Write device)0 j; V7 `3 t6 X& Z3 D% B
- start transaction !!!
! d+ s0 c2 Q2 f  Y7 ~(... processing ...)
' G2 k& j! r% I5 ^- get "Complete" status to check if transaction is done successfully
0 v1 z8 s, b+ ~" F( o, ^0 F(...wait for system reset...) 2 M2 r' }- a0 X. x1 X

0 s+ l* F# N2 ?  P& t* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
; p+ [3 G* }; @3 x9 Q0 A  ?8 r( `; I6 ~7 }0 r5 ~% T, X- _
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.# M. o1 C) ~# v2 A
& y. P2 `* |+ o8 @- V3 G! ^
[2 Programming ways for clockgen]
) \$ c- n: T3 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時會用到
  H3 }' [5 h) l, h, ]- ~; z2 B
* P5 H. ^+ j- S# `# b7 b5 U【Notes】
7 _5 _4 x+ B# w7 ?1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
  n8 K% f- ?  k+ E( t$ v
4 e# R( Q0 L0 s( G% ~更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
2 m6 c$ Q: O/ G# C) y8 K8 }& r( s  U7 |
! d% C, G1 t$ q0 j/ ~: t
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成5 `5 h; L6 ]5 ?. q

) P: _6 v( J; z0 k1 o1 x給我正確的頻率,其餘免談 ...^_^... : f# r% a7 B, q6 w. J4 Q; s& a6 n% P* Z
5 S$ @, {" A" P% F6 X
=====================================================================/ B, a# W- o4 O' x- k- ?' H
Q&A- K1 M2 ]9 v. \( j8 ?8 J( F) W+ a
=====================================================================
1 [, h! H- ]8 g. c>前輩我有幾個問題要發問!
! F3 [7 M+ h% E! o>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?& Z+ ]$ G# ]: V1 M8 s) E
>
# R5 g5 P9 c1 \8 ?% `+ X>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
5 H+ f" S: |. ^>: S% k0 `7 n1 k8 }- P
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
2 ^" j" d2 {' h* E+ M>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
/ i5 n( f3 L: `. _>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?. H- k$ ~* J# b9 y# C, N
) J3 ^# I" L) Y* b  v$ M2 z
[For #1]
' K' q7 ]8 k5 g6 s=> 我所謂的 "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 G& N. V- F# I1 A( a

% ^! v3 I+ P. H7 ^# g9 f& Q; E此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.4 l/ z% y0 x6 d. P6 ^/ V
' U+ z! A4 `9 |$ B5 \; R
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) ); h  e( W2 I  x- Z$ q. Q
4 K, i' N# h, {$ @, O: l; M* S: T
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
" h8 q8 A* w7 ?2 I5 {+ r0 L4 z* n$ r! t, o$ b* D7 X
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!1 t% s2 Z; Q8 x0 x1 q- L

" d( l' T' v9 J& a0 S& p$ WFor #2
  y9 T( H* u! T% {=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:9 r* E* }- h, Q& }
(...想像以前學的直流與交流的訊號...)
4 b: e' S6 Y. l. ?- Q: U9 y; P* [4 \* y* B8 f2 _
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!; i+ i. l- Q7 o9 _, E' I- \  E; C

& r3 L4 `' m1 |" Q6 N我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
  }" ~/ x3 A8 s: E/ o% {& Z' ^0 C" o( b: K6 K
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
, S- X6 g3 C" F, v# a; n2 v
0 n( V4 ?7 \) N" m% |' {+ g, t2 _9 |6 o' kFor #3" n4 u4 H, K1 A7 ]- d* [: x
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...- R6 L& h3 N6 |# ?0 m; h
0 A0 q7 E9 T- u( U1 B7 ]+ V5 u
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
! i' a! Y/ F/ C# d3 {0 d4 D$ N
9 [7 i  ?$ [' Y& L4 S7 F$ J[[EMI 測試的知識]]
& b; E* m) o7 s4 e* ?由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
. Z! p. B# S5 w( z/ H5 E" [: a/ S& h8 ~% B% A8 ~( P
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.' V5 h' C" a( e
  H9 h$ l7 v) _/ A" _
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2025-12-1 07:13 , Processed in 0.111945 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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