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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
* q* S' X! A5 S, s  u+ B: y9 Z3 s5 G$ @* q  J9 B: J' ]
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
, g$ a1 y/ r# x* U5 I; P5 s
( ?4 J' |/ F. X% k: t& n3 ~. A# U- h有哪些 frequencies由 clockgen 提供?8 x, A' j7 R0 o& Y
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)5 l, ~5 W4 |6 o5 E1 I$ _! A9 J
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)/ V" p0 @: F% f' I/ G7 j% L
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步., ~0 V6 l  M$ L9 ?2 C8 l- h
2 h# i$ Q+ V  i/ u
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio., y9 k* O7 L- t; ?' R1 ^' u
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
6 m  Y3 j% O+ z1 Y  X) U2 i2 Y  e$ k4 A
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
2 G* r+ V2 M; F; Q7 q# c- o' c- PCI clock: 33.3MHz5 `7 W4 M+ y- E, P9 T) T, F
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)) Q3 S& n/ n+ D5 B. r
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
( L+ [) p- d, w0 `5 i' u8 b# N- USB 1.1 clock: 12MHz
& y: z' m7 A0 m( ]1 v+ j5 W3 m更正: USB 的 clock 是 48MHz
+ l) \) e) a" k1 N補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !7 Y, g+ o# _2 _: p
/ i3 z$ q5 b: K" v9 D1 `
- SIO clock...etc
% z" n% t3 O) U% a/ E' i* D6 V/ D; k  ]) F) c. B  h, q
Clock Generator的架構
) T% e% x. ^1 P% p=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:+ k$ U+ x3 l$ ^  p2 `' P' C

( T7 r$ n( L; Q9 W6 u) d14.318MHz -> PLL -> F -> Div -> f
, C5 U' c" x; L: e6 e  P( Z3 }
$ I+ @: G' |  P# K, pEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
3 |+ S7 D; X$ B' ^( k
+ Y, u6 Q& ^/ IClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !  e+ Z/ ?: K8 u. R+ I2 s
$ S7 `4 Q% E8 P, P& p/ D/ |
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ! N0 K( r) U* l7 U+ H. E
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
, s/ n5 v: q0 g0 j1. 有 2 bytes(即所謂的M,N)來決定 VCO' w0 p$ h2 h& s8 B
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div) K; |7 z, o" ~- v; G2 F( E$ h
3. VCO / div = frequency
' @8 S$ b3 u) M5 ~" w
" z: d0 {* y7 [How to access ClockGen
) f3 t0 ?2 r* O4 C5 B=>現今存取 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 - \# U+ k7 q& V7 `8 s
( [: m  }8 R  g+ Y% S5 R8 {
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:" b2 ?% j$ w1 N& c0 Y* O  m; }3 ]8 w
- pre-init( clear status or ...)6 v* i/ w, o# f& B& u' i+ n
- put slave address(要 access 的對象) 3 }5 z9 q$ E2 j  D
- decide Read or Write
9 k0 Y! D- w( ?- put command(Protocol type, Ex. Block or Byte access)
+ B. T( ?' _1 W7 V% {2 L- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
. _/ I# K2 ^% q& _$ y4 P- put data if (Write device)
* c* U- p! @. Y) }0 u) U- start transaction !!!  }+ y( a- o% P3 _0 k' ^. x
(... processing ...)
/ L$ J( Q6 T3 J5 \! }- get "Complete" status to check if transaction is done successfully4 d8 j! Q3 F$ W
(...wait for system reset...)
6 D" z  S4 U" v! J$ ^
% @$ T* D: r# i1 Y* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
/ _' a) W% |9 e5 d* r- D) }/ s, l" F" H8 ?4 o2 z( ?, u  ?
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.5 b# \8 a- c- j
8 q7 C% [2 Z5 ~
[2 Programming ways for clockgen]
( ^: L  f0 B/ K; e- \  o7 I=> 現今的 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時會用到6 P; f4 @! }7 E, S- h+ E: b4 [

( t, q! [. U. a& J  t4 W  H5 d【Notes】
5 @2 [1 t9 \" s4 D$ X4 ~' v/ i  f1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings* @0 M0 t( Q) c; ?8 Q2 U
6 T5 f9 s$ n/ c9 Q, o1 l- q! N8 O6 w
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
/ S% s; H: |) ^2 I' i" @1 \$ x0 k

1 [) Q: f1 f# D0 X# u. m2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
: I5 U4 X0 c0 z1 o) m! m
+ k9 Y* e$ ?9 s- T6 f( z7 X給我正確的頻率,其餘免談 ...^_^... ; @) C; a8 [; {- C, T. @

+ X/ o, w* u, ^: p' l: Y7 d=====================================================================; B) Z$ L( H6 y- f# `7 s' t
Q&A
  f! U4 E: [9 W1 {: W9 }: |8 _=====================================================================  i7 e# K4 F; J0 Z
>前輩我有幾個問題要發問!
/ U: ~: J6 r9 H$ m>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?+ U' _! D" w( ^( `; U$ j# ?) c
>; a8 T0 |! i5 H; K
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?' ?6 w! z; V4 M5 {# b
>0 |1 }5 _# h* t9 b6 d
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以2 ~; Q3 I. w. Q/ Y  w2 D
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
9 A$ ~3 i! _6 I& z. d) d>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
. x2 A  i9 X! s
; j0 O/ r0 T0 ~[For #1]0 W0 ^: `1 O7 J" b8 I  D& |4 A
=> 我所謂的 "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 n+ B' H2 d& m+ j9 W# ^
2 m' y1 }* ?+ D
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
1 W' ^7 Y2 O4 P! U+ k6 Q, I* z$ ~7 N. H$ x$ d4 ]' k
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
. i$ K' `. K( c% d' N7 R9 T! k$ x( E( _4 E! d2 t! H
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz9 F/ ?- W5 m6 i9 _1 g& j+ w
$ J; `3 E/ J7 X9 p9 ^: F* S. Y
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
( F/ D2 S& I$ V' h- k4 h
0 a3 S8 [: q7 i) V; B) nFor #26 _# e& \9 J; j
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
2 A' h& G3 X; R" j( N(...想像以前學的直流與交流的訊號...)2 E# z( J& z+ k: c

0 ~; I) z; o4 k100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
0 d$ j3 ?3 P1 w# `2 `
% Z. M6 v+ P$ i8 }+ h我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等! {& \( J! p: \4 [; \4 P* ?
2 f6 [! y. ]" i' R
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
" P. \. Y4 O/ {! O
: p! F2 T! f$ v1 s% I$ YFor #3
  x( r# O1 c( P=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...' k5 b! C0 ]) w; W) S
, v8 W; w; V. u; K
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )# f' {% ^, {4 k+ e( C6 p- ~
/ U. K- I) a9 c" q# b. l6 w
[[EMI 測試的知識]]
5 V# t! b; W3 R由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 5 ^, p6 P5 U$ p% j- Q  r

0 T, r( [- u( K, `- A  K為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
/ J% I( g, |- B0 l0 W2 P9 ]
( ^5 c5 ?. f) M" o8 D# C' ^8 n+ h至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2026-4-19 22:01 , Processed in 0.070756 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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