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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.5 F1 V. d5 q9 S* s

1 G' r8 _) N2 a% ?* Q; h在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...& o' G" C) e/ }4 H
4 x0 F3 [/ Y' B3 Y0 P
有哪些 frequencies由 clockgen 提供?5 d7 g# p% [2 L" ^! J4 w1 F, H+ g
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)7 Q4 Q) q3 K- X+ r) m1 B5 |
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
8 y* \" P- x( U4 j' ]' {$ V更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.7 J( [2 c# M. p2 q

- y1 k% ^- d: p1 y補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.: k: F2 x4 J  G- ?' b
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
  o& P" j3 m) i" _. q+ n
8 ?7 B  j; \2 B; k) B$ U- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
" G- I9 i/ e$ T" @8 z) _1 D- PCI clock: 33.3MHz
1 B/ _3 y0 j8 U" Z& _- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
/ {# o6 A4 z& P' _/ t( I- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
3 \1 d* x) `1 o# e5 c0 [- USB 1.1 clock: 12MHz
# u9 J$ l! V3 f' C) v$ P更正: USB 的 clock 是 48MHz
. A4 h0 ]% @! }0 D& v補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !" f; J+ B* C2 e0 g! |' e
. E9 J* m. U0 a) B8 s! j: {
- SIO clock...etc
: c0 n" t8 v( D. e
7 V  s* [) a0 `' Z& q+ P& U3 x' mClock Generator的架構
$ l5 R+ P/ h, G' P8 [4 \4 f=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:+ j: X$ ?# N. o+ W6 j

2 P* r. u& o2 k6 `2 S0 J# D* v8 H$ g14.318MHz -> PLL -> F -> Div -> f
6 a# b3 y; n, G" O, {+ l
6 d% I) j2 D' G6 m- j; N* ]Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz. U6 Q( A9 v( a/ H$ h: f

  u1 T% K5 q  v+ g/ G2 Q5 j' `' DClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !" |0 n' ]( [% T( R) s4 ~' ]

5 o. h0 `  i& M. v2 g更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 5 c+ r) U- l. w' f
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
+ Y/ `/ }( y8 X/ Q" m8 i; B0 \1. 有 2 bytes(即所謂的M,N)來決定 VCO# t3 W# p, A  s0 p$ p0 _
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div2 R9 n, E, L8 ?' w+ a" f# @5 b
3. VCO / div = frequency
. @- S' Q5 T4 A' E6 `. e. M/ N5 c4 C
How to access ClockGen9 ]; T# G( D+ f+ S7 O
=>現今存取 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/ f' S, l! W

# E0 c; a  r* @9 U- q& ~不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
& [! G, ?4 n# z- pre-init( clear status or ...)5 ]) ~9 w8 b( a: }' E2 N1 c
- put slave address(要 access 的對象) 0 d$ e1 N! ]$ G& ^! g  c' }
- decide Read or Write
, c8 V2 y% a! W3 {+ N7 H- put command(Protocol type, Ex. Block or Byte access): u5 I* m+ \* I" C* s* Q, S4 H
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)# J. {$ Q/ t- x6 Y
- put data if (Write device)
0 K3 @2 M/ Z* s" u5 w- start transaction !!!, d1 U7 a+ K# `5 D1 F8 u& n% X
(... processing ...)
- O* ?- U( A0 f: c- get "Complete" status to check if transaction is done successfully- N9 Z/ Q) U6 ?3 @; v  _$ l6 w) _
(...wait for system reset...) . }& p& ^( U# M2 |1 {
7 T* W* ?! |' j, U  d
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
2 p9 y) H" p- p; d" ^
9 M  j: P$ o9 S8 E6 g透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
- F; _$ a8 Z9 m9 G6 ?, h: H' }" X/ l# O, W
[2 Programming ways for clockgen]
/ ~' R0 N3 x2 H2 j+ W! 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時會用到
% b  y; d( T4 ~: v3 }$ M1 i- ^0 I
- ]+ ?6 @4 k& }' ~【Notes】& P8 W% J& ]; Z0 Q
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
+ X, r8 N, i# `* D: K
" c( ~$ d; q9 U8 p8 v7 r9 c更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper) c( |# _2 k6 @1 s+ `6 b
8 q8 S3 D! H4 V7 j! `, h

. _6 q9 [6 k. e& |- \* U" I' y2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成$ e/ x# n* f- V# }
# _$ k- c. _2 j. [# D
給我正確的頻率,其餘免談 ...^_^...
1 p) T0 g" \. l6 _$ K9 I8 M" @/ g, a1 x$ T2 Y
=====================================================================# ~7 u! M: t5 ~) V/ _; X2 d! u
Q&A1 q$ Z5 }$ V8 ?6 O9 ^& o6 E
=====================================================================( n0 x8 V  d" \: `5 o
>前輩我有幾個問題要發問!; G: E( _) e' B
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?' k9 W$ l" o) D
>7 S! D0 o2 {5 U. i
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
/ D% \$ h6 g7 v0 W, h3 f0 r; u# G. L>
% d  H9 N. W6 z>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以4 d  I  _+ z/ a- |
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠: F" R4 S4 J$ I) q2 q7 o. y) {
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?( h! {2 A0 T& F7 g+ \; i# A0 v/ c
0 Y: C; _( U2 H4 T" P5 ^( t
[For #1]
3 k. s/ j2 s; q: a( _' X0 l=> 我所謂的 "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 o+ H" K% f7 {, y( l
( k; A9 \1 W$ M& T' j  N
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
, M- `# x4 e! G9 ]) b9 `7 N; {$ e0 d1 `/ C
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )- ^4 O! J0 G* z1 l7 I0 F7 O5 X

: [1 m5 V- j, {Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
! S! i5 W1 H' U* T0 D, z
: N: A& q0 N2 H% E% z; [- B還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
& l$ m: o, V9 R+ F+ S. I9 a5 }6 k. x: z9 c
For #2# q* a( u- \4 @2 C
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:, q0 s; a8 [9 _3 w$ W5 I# D
(...想像以前學的直流與交流的訊號...)
! C7 I' Y# l& M# x1 l7 o
5 x: O; \9 k8 {9 n$ n% D/ y100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!2 R) m' E" [% R5 Z- V
( E9 h3 X0 w6 H( g- p
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
8 I6 a) ^9 X9 x$ |1 L' W
' m8 @& a+ u2 N; ~( e; vDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
1 K+ V. q6 t6 \3 W6 _2 g
/ R* D( d# o( K, f+ @6 tFor #31 c# i0 `3 L$ P( i; b
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...$ }6 N3 p. i, a* f  O
4 R) H7 Z  R- k% p
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ ), Q& o' W9 Y0 G0 B! I+ ~. s- o

  \, m8 ~0 h& _: ^, B+ t  j[[EMI 測試的知識]]4 Z% S8 y" X; Z9 L( t& x  K
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
8 G$ ^) U. l1 R8 G& r4 @- W8 M6 k9 [# I$ B7 w4 r1 ~
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
1 G8 i& `& f: I% @3 I: j0 w9 U
$ R+ {% y* D8 |6 S, i) \- ~至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2026-1-12 00:47 , Processed in 0.086374 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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