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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.( D- v/ l( q0 \8 l0 T+ T
) j. E) W! [0 A& k2 K7 H- V
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...0 P3 p* t; a8 b4 ^
( z$ `0 V; R  s4 N' ]7 h
有哪些 frequencies由 clockgen 提供?
* \' A4 ~+ N  Y, k/ U& W- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)- M4 I/ X/ n6 n
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)7 L1 g! A; r' o5 @
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.) b" w( q+ S: }/ Z7 A% [  X
: U0 U/ P( l# D* b2 E
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
# @+ s9 T* S5 n8 ZEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz! _. n$ K' V1 u7 V& v% _
$ O3 H) U0 n/ P: G, w  e
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
% X8 k- H* L# `0 R; m4 S- PCI clock: 33.3MHz, n7 W$ H/ [* I
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...), Q) U; u- K) O8 W, V, G- N0 w
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
% U, l# b, |% H: l9 L( }; w- USB 1.1 clock: 12MHz6 \! q! R- ~" B0 v
更正: USB 的 clock 是 48MHz
; `1 _. l0 j0 z7 O  r補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !8 l! V/ j! b, Z
  s/ k0 n& o5 {8 k* D
- SIO clock...etc
$ G. [  p: k2 @/ a7 _  S3 x- y5 }3 U
Clock Generator的架構4 b3 K8 k* i- h6 q1 J' C+ j- h9 J
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
/ i4 k6 H' p1 R) C; u5 k" R
3 ]+ P" ]3 m1 e1 B8 N0 Y14.318MHz -> PLL -> F -> Div -> f
7 h4 k7 v! q% v$ n, s" R' v
. c* l8 e6 B9 |* W" t6 Z: }/ eEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
- P' ~, |4 a- K
" V/ [6 W/ @! d7 p! x( Z8 T3 pClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !* ]- Y. f& C' j* x1 D2 S: ?

; w! Q: c  e# |# X+ l: }6 D" A更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
: Z6 P; |6 T4 G9 G6 ~補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:$ `$ \: ?2 Z9 ?; g# W
1. 有 2 bytes(即所謂的M,N)來決定 VCO6 m, J, f) {% E% d' j# T
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div: d0 Y# b2 y. D
3. VCO / div = frequency/ e! b. Q6 C3 r& B6 |
/ Z& S. ?- F! ?$ [
How to access ClockGen& R% w7 T" p  B5 u9 l- f# M
=>現今存取 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
' p( M$ w9 v0 p) l) L
# Y5 s' Q) ^$ a" b. ]; ^不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
! I" E4 F3 @, Z3 k* h' [) Z- pre-init( clear status or ...): y4 U) ?, q, R" N  k: E
- put slave address(要 access 的對象) ; |$ ]% U5 d" d% i1 ~/ L: U' d
- decide Read or Write- n- s; Y' q7 ^
- put command(Protocol type, Ex. Block or Byte access)1 ], Y# L1 S7 O: `
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)# F0 [8 o, W& A: p; l! m
- put data if (Write device)
, N& D! u/ q: Z' m9 `, B- start transaction !!!8 y7 w" b; E! E$ S9 O
(... processing ...)
# w# L; ?: Y7 m4 M  ?- get "Complete" status to check if transaction is done successfully8 b+ z& {  J& O, U. E
(...wait for system reset...) + C8 v- z" i- X7 U9 W2 H5 ?0 B
# E! m! P3 f* p
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.3 W# X9 g9 T; U6 r# r
+ \# Y. X6 E$ m  M1 l
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.. r+ x. P8 L+ G9 E% W/ |

6 z7 ]% Z+ {0 \! ?" k1 ?) V$ K[2 Programming ways for clockgen]
& ?. A1 S2 I; ~6 Y=> 現今的 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時會用到& }  g6 O; A: R5 A

! e- k7 T% J) i) f【Notes】
' G) x6 D( n4 z6 x# Y1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings' J9 @3 t' O& j' O4 f4 i

9 l$ D3 }. Y# M. b更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
. e9 |' j% q" a; z+ Y# \" t- {0 b. ^! |8 w+ ^. N, i# H

3 X. ?7 M8 @; p4 ?( O2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
2 [% M, C9 @- @) a8 y8 q
$ z6 w; f6 F. `3 @0 g給我正確的頻率,其餘免談 ...^_^...
. I5 C. b, F! ]& ^1 m5 A
) ]8 W/ p) k, W# r1 U- O  o=====================================================================5 {8 T6 w  \: H+ {. y; r& ]: T" u
Q&A
/ _" X- V3 v2 u2 n5 n% e) r+ Q=====================================================================
- {0 c2 V2 {# ^( _! W! t>前輩我有幾個問題要發問!1 L8 m* t4 g. Q& Y' A
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?: a$ |  ]4 o1 a8 ^$ j; S8 ]: C
>& R& n4 n  r, A  w2 J
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
1 O# z4 X: ?3 l" r0 B" ?+ z>9 ?4 N5 s% c2 w6 M9 _2 ?) B0 e1 P
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
/ Q7 q. S) Y2 J  I" K4 m+ S>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
. r$ L. W7 R. j# A>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?' G, p, ?# G- y4 {1 K

6 }/ }$ D! M( u( @& z9 V[For #1]
# t  \  d% ]8 _; t% ]3 I! x=> 我所謂的 "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 !8 h& q& T8 Q$ I) E* _. S1 o7 t

5 [% ?. r+ T- H) |7 H" u, |此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
; I; {) m) ~: P+ n# v4 ?! n7 Y7 i3 I! S( R- Z
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
0 f; L  p# f0 a8 ~1 @8 w
4 n9 d" W4 S' B, L! f' MEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
$ _! |* t, w! M
) c/ `6 B5 K. \) X7 A6 _( R/ W  M還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!7 }7 a7 A& a0 ]+ Y( _; q/ Z

! g. b- `- F7 H& v; w; n+ kFor #2
' Q5 e% t9 A" I6 o=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
. n; s! s& X8 C# w# n(...想像以前學的直流與交流的訊號...)
6 s9 k+ [1 ]2 r% D4 R4 y
2 f. A- ?5 Z! j0 K2 t; K100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
) f1 _7 A' M) j- G. l% M( }4 l- ~# D' e$ |7 h
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等' _! l- O' \: l  I+ o) \

- r* }. J6 d9 l. e8 G+ wDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )" h  j3 z- e# e$ h' U& K+ ^* S+ j5 m
5 g& N+ L7 @; d5 {
For #3
+ T* W) @5 N% V; F/ b* V=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...* V0 ?# @- v1 t/ M
/ d! i7 ^* Q2 k% f+ ?  R
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
5 \# c$ c1 \' ^8 u: E: x" M! [7 c
' `8 j) Y+ }4 }. }[[EMI 測試的知識]]) U( `3 Z" {7 |5 ^" k
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. + s9 U' {1 h! U% x+ B
9 y# y) u! q1 F, ?5 S% q3 `" F
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
. ~+ s6 i; ]% S2 S5 T! S' X( x1 ]6 E( H- J& ^* D  s
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2025-12-1 00:48 , Processed in 0.221023 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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