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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.% @8 N3 q2 j( T. Q7 x9 s
7 H5 s& j" i+ w* i0 `) ~
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...6 I+ j8 v1 k: Q! J- i" M8 ^6 L

+ n1 p; x0 _! M0 u* H有哪些 frequencies由 clockgen 提供?7 r8 R( ]4 r5 b4 G# ?" ^
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)# P3 q2 Q* U5 Y- I4 I& Q
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)& s1 j* K! F# _
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.# A3 }8 s9 x6 C$ i
5 Y: b8 p9 X% X; K& |
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
7 S% ]: I! `6 z# L+ y* \  rEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz( `* V2 n8 F4 h8 I

% b) h7 j6 W3 [+ u8 m+ k9 \5 q- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)7 `( \" X% V3 u! N3 S
- PCI clock: 33.3MHz4 P9 I1 }, M, I) h
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)$ h$ @. X  s4 B
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供/ F7 G# r2 q6 s7 _" b$ c  \
- USB 1.1 clock: 12MHz
. [! b8 Q" z+ E更正: USB 的 clock 是 48MHz  L, f; _4 ^5 h. Q; ~" H3 n
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
8 J* w& }7 V% X9 ~, P
6 b" F( y7 ~: m& {( n- SIO clock...etc5 `2 [8 g9 l, A. G" F! h2 X( u
4 `2 r  e% v$ q- v$ I. l" t/ H7 z
Clock Generator的架構
1 \. ~+ ]! o' {=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
9 u, j* N' F6 h, f
$ n6 t  k3 ~( e/ U5 p8 \14.318MHz -> PLL -> F -> Div -> f/ }8 z. q. I0 i( {: d9 i

" o! Q2 |' E3 M/ d; h: F4 pEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz1 T& Z- v3 ]6 i3 U  Q% j

% V; O- Z) J' n+ O6 W2 I+ AClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
" I, n- z( I$ K0 `7 d: [6 V8 b3 e
( V. G! R/ I! m; o$ r$ ~, m! G( n更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
1 j6 N9 U1 ?! R' L) U$ M$ L補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:1 m, A8 D3 K! Y! e" {# b
1. 有 2 bytes(即所謂的M,N)來決定 VCO7 s* b1 K: W0 t3 ^2 b
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div2 d/ c0 [  S6 g0 }" p9 i5 W
3. VCO / div = frequency7 L) o: Z5 s$ O* F0 C% u4 m

) C  k* a: |1 rHow to access ClockGen3 y3 \: `% ~, G6 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
4 E" V6 A5 H8 q0 b; i- `" A1 w" p* r% q
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:: ^8 i6 p- \  k. ~  \: U, k
- pre-init( clear status or ...)9 r0 V, x8 r' s. A- r6 e
- put slave address(要 access 的對象)
& h5 @% Y$ k  i. t! `- decide Read or Write! q& e  N( i' X  |) G2 b! L) I# N
- put command(Protocol type, Ex. Block or Byte access)8 M: L% K; G; z0 [
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
6 r# o2 q7 G$ k- put data if (Write device)
& V6 k) S; S) x  a5 d5 ]- start transaction !!!
  b9 p$ c6 ?/ d$ K(... processing ...), T# q( C) J( w. Y& y8 Z* D3 H3 S
- get "Complete" status to check if transaction is done successfully/ o( T# g# W" ^/ B
(...wait for system reset...)
& N& f: H# h! y% n7 }: T& d; t2 l2 ~3 z3 g
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
0 ~! q& S$ a# ^2 t8 @# k/ R1 o0 V0 \0 L0 s( Y+ i, Y$ ]) s
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
. K8 O) Y( }; j% w1 t+ ]. C# L% G) p& z* m8 r8 h1 J
[2 Programming ways for clockgen]
8 M) e, x$ x7 T6 X=> 現今的 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時會用到
8 F& M; X4 _0 Q! c% ?0 o% P+ d7 G6 I5 b* h: `' m- {, N
【Notes】
9 M! U# ]$ ^  F, x# [/ b/ w1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
( g  t; j9 y6 r! f- ^6 `, d# e1 g" w2 C2 Q: ^. F
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
& R# O* _! p2 S. I7 R. y. i3 N; C. j, K9 n6 L! c$ D
' C) E# _: i. R5 G: ]; [
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成/ X* {1 }2 q# A' c3 Z

$ k: j! j# K9 J# P給我正確的頻率,其餘免談 ...^_^... " s( Q) @, ?4 M) K7 F' i" T
9 ?% A! M" Y, r. v9 f( p
=====================================================================; Y4 A( J* X! ^9 d
Q&A/ C6 S8 g: Q" f" K6 D+ T, ]
=====================================================================
3 `3 [4 y4 @4 ?5 E7 t>前輩我有幾個問題要發問!
6 B, C4 ~0 m+ l% y; c>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
" z# `$ M5 z) J>. ^$ P. J9 c: o5 Z: Q1 B! X
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?: A6 l" _: u( z" P: K+ p$ u& t
>
2 T" C' o' ^4 t; E8 _, }>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以- m# [) i9 o4 h; e2 H- C
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠) {" q* S; k8 h
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?$ c5 @' H4 `1 x# B! z
* O( l  N0 N6 f% q) S
[For #1]4 ]3 h6 H7 H8 c+ `! I
=> 我所謂的 "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 C5 ]8 ]' e4 u% V4 I$ v7 r% }' _
# P' p6 I+ ]6 c# o) @" j此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.9 f, C" ~7 }+ r9 }( b$ P8 [9 g

7 E" L9 o0 }4 k6 b不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )5 X' {( n( K$ R. n: {

7 z7 K' Y( q: \7 _# A: v" qEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz+ e5 q$ _& c* m& K! z; n: n

, @2 j- ^& o3 L; {還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
3 Z: ?( i5 S# j8 P* R( S* c" ]4 V" Y* I0 P% {
For #2- K6 U8 m% x% O- K! m
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:+ i; f, {% ?7 b+ d3 n  H5 j
(...想像以前學的直流與交流的訊號...)8 }" Z. t" f( K+ w7 w- C, Z: x- @
# S6 r6 I; J  b% _9 c2 R
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!# P( B! f2 \' k; A% l

, j7 b' E) W7 H0 J2 o0 g3 h我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等" |1 ^+ z: b+ a+ N  E

" Z1 M' m1 `4 @; bDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )/ a% O4 o3 l2 m' ]2 B+ ?. U. W# T
$ `. V  \6 [) Y7 i* n
For #3
5 V0 O, O8 L4 {$ e1 S7 W2 m1 {: ?=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...3 }" a3 _" q- {0 _5 ~" C7 [

) R& t0 D* q9 L1 O! C# K* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )8 r$ O  C7 X; t- s5 W& |% p9 f7 i
& u1 i# }: {2 I$ w
[[EMI 測試的知識]]! S, A9 [8 t/ y# d
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 3 ~0 F) D# Z7 Y" u0 G; l
" B1 @$ `, G. P
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
0 _+ c, ?+ @* ~- R9 v8 ?( V1 U+ W
" p& k6 Q3 E( k/ o至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2024-5-16 06:30 , Processed in 0.029566 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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