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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.1 H$ L# X  K4 F( n- X' Q9 K

7 n! M. O; p" l在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
5 S" b) M; C) Z5 t6 Q+ r
2 I0 E- X+ Y* k! P% C, r1 G7 i有哪些 frequencies由 clockgen 提供?- M5 ?' E: C0 A
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)0 a* I5 `, b' _6 d: c8 m
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)* ^! M1 C' F# _5 S
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.0 Q" a  t% W" m% b
2 w: q0 J# ^4 v9 O" `1 z
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.+ n: U- ]/ K" @( I1 g* q: P5 F
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz6 i* r" n6 A6 P4 _( M1 R" w

0 g% }/ f& J! c  Z- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)8 A9 L! i" i  Q* ]$ a7 X
- PCI clock: 33.3MHz
! @8 ?. @+ C- _- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
2 v) o. s! A9 n* s- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供6 Q- o5 i! o  e
- USB 1.1 clock: 12MHz
# d9 r; ]& k. H! Z更正: USB 的 clock 是 48MHz% w! a) h- c7 d) I  _9 W
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
! y# d: o- h" D9 h7 p; x; }2 G  p( m
- SIO clock...etc3 z- ?2 g9 Z$ c  E/ v2 g! X9 ^# L
$ G: j5 Y: s( [# L
Clock Generator的架構8 A, P: i; S! v, l7 P
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:3 b; ~! C& Y/ Y* t- H; {) b& F9 R
$ q' {& h/ Y/ j  N4 I
14.318MHz -> PLL -> F -> Div -> f
4 J9 M1 a+ n) O8 \0 X
3 w% [! f! _: ]7 B) G' W/ Y$ BEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
1 M2 ~, y0 ]1 ?, K9 a* |; |2 L. q8 K* n+ U: W+ c5 Q1 j  A
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !* ?; J, Z( _) }4 e5 [
* z2 @5 X9 ?, \: p1 R' V
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ( q* B* B/ Z0 A/ b  `, g9 l  ]
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
) Q6 ~& R/ f/ m# v1. 有 2 bytes(即所謂的M,N)來決定 VCO! E6 t% ?. P7 t6 q# Q
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div( C. b5 L5 x1 h; ^+ {6 X
3. VCO / div = frequency1 `  E. A5 [$ d' n
" M) V9 z/ E5 l' J6 \$ q/ e
How to access ClockGen. b& X& l) w2 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
5 V7 A' O/ s: g% i  K# U- W* c' `, X
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:9 k& {6 r# e# m% [
- pre-init( clear status or ...)
8 B" o6 e' k$ `  t6 i' K1 B- put slave address(要 access 的對象) 6 @: j  A6 D3 O2 s
- decide Read or Write6 o3 {$ J- ?' j* R
- put command(Protocol type, Ex. Block or Byte access)) S+ T0 H2 y+ U5 y
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)$ b( M% }/ H2 f8 Z/ @) Y
- put data if (Write device)
/ U& I) h- F  W6 G- start transaction !!!' V1 ]9 ^$ o+ @% i9 [* \/ s
(... processing ...)" y/ Z/ W* a; }
- get "Complete" status to check if transaction is done successfully
0 Q' N9 d2 _/ S2 J  m(...wait for system reset...) 6 ]" m) B+ u7 y  n9 x

& s8 }& p4 H# F) Q+ }* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.- L' ~& O$ x6 ^

: R$ F2 A& }3 j3 }: T7 X. p# q透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies./ E2 ~4 i) R' |6 n# P6 O: ~! M
  I/ _  e7 h* n
[2 Programming ways for clockgen]0 K6 c" p8 [4 e, Z* P" C0 W* q
=> 現今的 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時會用到  O9 X, v% C! W% x

# d  q: f. H5 {* s5 ?; y- }0 \3 y1 \【Notes】
9 }4 I  s  j8 G8 e1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
1 V8 ?0 z9 Q: U% q: z4 F5 j) k6 p7 @$ g8 u! p
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
3 a0 P% z# G# t
  U; G  ^3 @! D5 C& }( Q: Q6 y0 n3 z5 `5 X5 ]9 N5 s
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成# h: w, I4 e4 X6 F& x

5 `+ H% h/ j0 p# o4 y5 y4 b. X給我正確的頻率,其餘免談 ...^_^...
* c! U6 l1 J+ i2 R7 h% h7 N0 f! R- _
=====================================================================; G4 Z4 A1 L" }/ X- Q4 ?
Q&A4 ~" I( ~# q# X3 z" W
=====================================================================. B1 ^* q; h$ ^8 D& U, a. X
>前輩我有幾個問題要發問!
* {( b) i& O- o6 [* t>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?' q5 L: y7 C! k8 l& B
>
0 z# g. i# z  j( s5 B+ c>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
8 |8 ?/ @- L2 q+ `# X>! |7 k- r0 ^' ]- Q: F
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
5 b( I! A! n+ I>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠& I& ~$ N  k6 W6 W* f6 Z
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?; U# I1 M3 ~3 [  n' S9 v
, d6 ~* R" O( V+ c
[For #1]
  K& }" r: D3 [: i2 Z0 O=> 我所謂的 "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 !
/ U  ^' q9 ?: n. ^5 F  L+ n5 ^4 O5 l/ U3 Z2 L* c$ f& G7 W+ Q: x
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.% E) `- E, X3 A2 w! R
& M9 O5 P) D) u9 S- D8 H& e0 o
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
8 B# X/ d: t, o  d% O- a$ T% L* Y. I
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
3 E  ^; R! S: _( F, n' Q# P; t$ i5 S) l+ V3 ~7 f! Z
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
  c: r- ~/ x( @) c; ~3 z
( r! _8 B7 ?: {% MFor #2
' L$ f" L$ [% K; Q5 J- l. _$ R/ U=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:% q/ D: q! {2 |5 K) }
(...想像以前學的直流與交流的訊號...)5 M. [! D6 s: z, s8 O7 W8 c5 m' I

/ I: r/ F1 c# ], H5 u" L. t100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
* v4 o; T  W; U" R$ j+ q4 m) W# Y7 l, B) e) \9 M
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等& E4 H" @. t8 W9 g1 G% Z, t% u% c) ^
/ h) M& ?( N0 Q) L
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )% a6 A1 ~/ h( B/ K: w  r- Q

# Z' I( M0 m, ], _For #3
' k- D0 G9 k$ ^0 u* B3 ?=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
0 J+ w3 B8 u: Z& U* n  c" `2 e% a! Y7 j5 x7 t' \
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
0 ~5 S) `$ x* A7 G, y5 s0 e1 d% I7 K% s# `, L
[[EMI 測試的知識]]9 F& m2 U: `8 d" j/ W# r6 N
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
) m4 _8 b* R! C' E( A, f
# ?/ V6 f6 d6 I' I0 X( q為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
* K" ?& _4 j0 Q: o$ e+ E$ Y- B/ L+ f- {4 q  ]- G# d
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2026-6-13 20:46 , Processed in 0.344981 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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