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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
& A/ o% V8 e, K  Y0 l
" p7 [5 U; _/ i/ Y在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
8 j% q! P$ h7 J' G3 H& N& `  t3 y) t0 C4 j
有哪些 frequencies由 clockgen 提供?% s5 C3 r+ p  G3 B' `- U& v
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)6 t1 e4 r' i6 a& B( \$ g- x
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)/ I8 L' D8 F0 d3 U% {3 u+ {" H
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
! ?) @7 R; q% D9 W9 a, u, n. y9 h) Z1 i& }$ y
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
1 z+ [, |  e( x: Q! x$ KEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
# `  r2 f+ ]7 q0 I
1 l: j( I& I2 l1 }0 h' q1 h5 Y/ y: x- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)$ z. e' w0 N4 I- M& u" f
- PCI clock: 33.3MHz  f' e1 u; a7 M
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)5 Y7 L! d" C7 m5 R
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
( q4 B0 B! }* Z* X" i, r8 {# _5 r- USB 1.1 clock: 12MHz
' _( `6 h5 C8 _  J( p2 H2 F( T: [4 N更正: USB 的 clock 是 48MHz
. Y+ {  }; o' ]% x補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !0 g' x# v" U, q! _
8 A6 {" a- ~  _0 n1 P2 @# ?
- SIO clock...etc$ [% K$ _) v0 O5 h$ U* J/ w9 ?
- D9 q) Q- Y! \4 ?  v' [; ~
Clock Generator的架構
! w9 Y+ L' K0 D: z1 \+ D; b7 D=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
" B& S0 r/ _# K5 A6 W+ ?# R+ t3 y7 p& I. _
14.318MHz -> PLL -> F -> Div -> f$ I5 _" G8 T  m5 V8 f& Y
  g2 ~) S0 {/ n5 n8 L
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz9 R3 e2 V# r6 k! o

" v0 n1 e# N: K$ y3 p0 s+ IClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
) N/ s/ c& Z& E) \* J6 t6 C2 E; F0 t' `: v, W6 n* s: [
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
4 `& f: E+ `( O6 S- z' y# e補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:) r1 i- n2 @3 j3 k, z
1. 有 2 bytes(即所謂的M,N)來決定 VCO5 D# l4 B) K: L3 }: w3 X
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
$ \& Q5 O5 F" G; S- V3 z3. VCO / div = frequency
3 s- i; B4 N# c4 ?7 L; W. T; s1 ?
& @6 n4 t$ _( C, U6 ^5 S; UHow to access ClockGen" m  f6 y& v9 }& o) g" d' w1 v
=>現今存取 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
6 d" f- {9 l5 P% ~4 ~+ b" a/ z" A3 t7 ?* F5 o9 J1 Z  P3 I4 Y3 M' R
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:, T* M. u+ p% V- }! _& H9 x/ Y
- pre-init( clear status or ...)9 {; ?# p) H% V  L
- put slave address(要 access 的對象)
) F. e7 ~" O3 E7 o- decide Read or Write
. d6 G# K7 t; u% x8 `" V- put command(Protocol type, Ex. Block or Byte access)" N! a0 D2 p5 `, j2 {8 ?
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
  B" n/ \+ y- z7 m4 r; K3 T6 k& p! I- put data if (Write device)
9 m2 S  h4 |+ d8 h. j7 b3 n- start transaction !!!
* M6 ?9 y/ Z0 Y5 K4 B4 y$ ?; ?) o(... processing ...)6 q; }+ J5 r2 o) Q
- get "Complete" status to check if transaction is done successfully; m! Y1 R3 @# g/ c6 |6 `
(...wait for system reset...) 8 m' Q4 _( F# w! \  Z
9 O: k+ `6 g0 w3 B$ s
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.7 y8 g# k' D+ N1 A

. b( _8 }6 s  C! P$ L透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
) V2 G8 W3 e5 f& D2 `) }. M* |: l1 w. _  f$ I
[2 Programming ways for clockgen]
' ]) _4 @8 w1 @=> 現今的 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時會用到
! W/ \5 ^$ p( T) ^7 {$ X  t3 {- P- Q* B; P6 C. V
【Notes】3 d% V1 _* m8 L7 H; @; T
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
0 B; |# ?2 k4 X  ]" m# Y9 l4 z6 x. }1 G$ r' }" H; p
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper, y- m3 K) f' O6 n6 _% c. L
1 j4 C6 g( I9 R- ?, E, V

* x3 E. d/ ]# |9 E, X3 i: q2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
3 {7 _5 _; `& W! B" ]0 f9 G
- m+ A/ r. j: ?  U% w( g7 Y給我正確的頻率,其餘免談 ...^_^...
- {6 T7 {& Z9 x4 |1 T( k- D* o2 u! N7 X2 [! T7 X- l. L
=====================================================================# H: D& Y* A6 |7 m6 D
Q&A2 F5 A8 r1 I0 b9 C6 Z, Y( |
=====================================================================
: d9 h, ]+ W) J+ Q# \) s>前輩我有幾個問題要發問!
  ~" J2 q; t/ W( G8 H1 O>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
+ O1 x. x' ~8 ?1 l>
- M2 j0 R4 a% u0 N+ j" {>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
& y, q3 ?( d/ l- T1 q( T  e>
! T3 h$ e0 ?0 Y8 s- Q/ o>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
  O( J; I4 S2 d3 H>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠8 N4 ]: {* b2 U# f' o: |+ l
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?* R" N- i& [" V0 K. L

; A' h2 l- K* o) L# x[For #1]; g1 ?7 |& j$ ^. Y3 m; A, ~: p# ?3 _
=> 我所謂的 "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 !# z/ r# @6 Y4 O0 m

3 S4 T. Z4 b# d2 \! [. g5 f此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
% H' T6 s, Y- s" T3 w7 l3 X# p! s  c9 z5 @; A" D; ~
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
$ A# A  m, w; A
% U* S: V6 F& i6 MEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
7 a  P) y# f$ |9 j! I
, F: B5 a" k$ y. w" D還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
7 M- U: h7 D9 |3 u1 I* t: t4 m% P  |) h+ e; I
For #2
  s5 L* x# @: _6 h=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:; y# L; Y& k8 N) z( d" k) P
(...想像以前學的直流與交流的訊號...)2 W* H2 i8 B3 F

% g- }0 F( D' f) c% Q$ l" ^100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
2 h6 U, b& U; ~0 b+ j: X% o- c/ w
3 {# I$ I- k* B" m& x8 ^我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
& u) {" r) q5 K4 L0 M) H' L6 H5 A
/ l" U- k4 P9 j+ e- \" d3 |- vDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
4 m, H7 C/ J( R; D; R$ ^& R8 ~4 T' Y& R' Q
For #3
4 F1 u8 E' T. h# j=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
. N0 X3 ^* B. m/ T3 K$ t1 P# }2 _
4 R) F* n* M- p) W- w" ~' O* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )6 i) ?) p$ @% @/ E8 N

4 W3 g( F- L7 H1 c[[EMI 測試的知識]]  I* L% q% G& u  `) h+ L- x, k
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
, N6 Z: A1 ]( v* \9 m/ a( ?
; O6 W% b0 k4 y+ m" Z為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.2 y0 f, ?7 c& o. l

9 y2 j, A0 C1 e9 c至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2026-6-4 08:57 , Processed in 0.059589 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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