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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.  @* Z+ ~6 ?/ `. W# x0 H
- r! B0 l  Z( A* ^3 N7 S" u
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...( d+ e* ]% j! D: n

, g+ {0 G" r& ^. x- `有哪些 frequencies由 clockgen 提供?
" l! p9 D" [; e7 S4 I- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
$ l- A4 _, h6 ^* K8 w8 m( U6 i- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)% B) f9 w+ |- Q. R  R; J4 B
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.3 J) |5 j0 ]( m# z. B
& ^' M5 F9 U! m6 h0 K# C, I$ k
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
" g7 o) a9 i! f  O, e. oEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
# K( b# H) G/ G4 y/ U0 g. M
/ I) G$ P) M0 P! I4 Q- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
9 Q- I2 ]" v$ s/ S9 y7 `- PCI clock: 33.3MHz
6 f5 p+ {7 k4 l9 V  D- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
+ b/ X) g# |# m8 Z- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供% A5 w# s* J1 o" g$ M* a& T4 r# s. q
- USB 1.1 clock: 12MHz) @. X6 N, r  S! k
更正: USB 的 clock 是 48MHz' I/ o+ c" `0 M: V9 K- y: V3 i. b8 r
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !1 E0 Z, p8 _+ [8 r

' i; ]3 X7 K8 T7 F; W: Z" G, ?- SIO clock...etc
- h/ f6 x. O8 n7 \+ A
: X& R5 l! G% `4 {) n# WClock Generator的架構. t, v' @  h3 s& t" W
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
0 m. B" T; t2 D
' a: ~6 F2 ~% t& _! P/ N14.318MHz -> PLL -> F -> Div -> f. q6 L4 U+ J( r) F# g* D% |. w- x

0 q5 ]* @0 L2 @( h0 z% fEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
/ a7 @& B4 c& n4 m5 \. z+ @( `7 k+ |; _& B2 M8 l. E
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
5 g- [5 c: W4 O5 Z5 t
: R/ N/ N: E9 U0 k3 Q/ N; ]' Q更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 2 c2 A  U- I, L
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:( M& b/ q& O, R8 S# G
1. 有 2 bytes(即所謂的M,N)來決定 VCO9 D5 c- _! |( ]: g) X4 k- A" s
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
2 E/ g" T! [0 u3. VCO / div = frequency
: ]/ E5 {. J% _8 o9 N4 N! R6 ]" }% m) u
How to access ClockGen
$ S8 P; c# Y- m# H" {: l& ]=>現今存取 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
! \' ~" G& ~$ H( G1 ]5 k* n1 z+ @) L4 C" X: q/ t% _% _8 k
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
7 d" r. L7 V6 n" S; U# [/ `- pre-init( clear status or ...)* d6 _1 `$ J, a2 f: B5 A- n
- put slave address(要 access 的對象) 4 V# J! R$ P" Q
- decide Read or Write2 V4 S7 c( _9 `& d
- put command(Protocol type, Ex. Block or Byte access)
2 @& Z4 A6 m# F, |! \6 `! u3 e- r- X- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
& k9 T* Z- S) C+ u- put data if (Write device)+ p2 {2 ~+ t- g8 V) m+ @: E; d
- start transaction !!!
4 x* G: J2 j/ P3 y5 ]% q. X(... processing ...)# I" J+ ]2 Y3 T; {
- get "Complete" status to check if transaction is done successfully: J6 b& g1 b  |+ A- f  R9 m/ L
(...wait for system reset...)
; D1 N) B% O' h& b
6 E! L( U& F" p3 u* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.$ f# J% a& E! e
  N, x# z5 c& }+ n# T% }/ a5 J
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.1 {7 f% S4 y3 K! X

" w1 G1 P1 }8 E  V[2 Programming ways for clockgen]
' K" O: e# A% o; L( l+ \" Y=> 現今的 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時會用到) d( f( [# M+ ]9 e

+ W+ C2 f& n8 [# V0 @7 C4 I4 x' b【Notes】
) ~9 J" G! C7 i3 H, L1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
+ v7 K* l2 g0 s7 ^* {. }0 K) U& l% _3 _
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
9 L& O+ P$ N; c, {- W5 M& s& |* v8 E' ]- z
) }$ Z2 S! R# j
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
1 d- R0 ?2 s; S) V1 t) p
& {8 V4 k2 Y( h- l8 I. I* w1 O給我正確的頻率,其餘免談 ...^_^... 4 K1 q  B# d0 s& A, U1 }
2 }+ B; ?3 J) L. S
=====================================================================
" O1 ~; ]4 ]0 B$ U- B' w- QQ&A$ m$ U! u) G, p# t2 m% ?! z
=====================================================================& u: ~& `3 R$ f( O$ i
>前輩我有幾個問題要發問!# `- J  L  |, t0 K
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
! L+ K# @' `- J. _1 Q/ v>( B- C3 h9 R  h
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
; H; y4 \3 ]( x4 c0 a2 o>
2 l6 T, L! Z9 H0 ]>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
- k  o2 D, |9 z* h- g( Q>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
& w0 }3 w: U# y+ b/ ~>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?
/ o+ V1 A8 j7 Z% Q! W4 p6 T7 N7 h9 s, J8 y
[For #1]0 J' H  E9 C9 x$ X( ]
=> 我所謂的 "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 q/ ^& J. R7 |3 f
# @  q: J5 c) e& s% f$ X此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.% O: h2 C( R2 n" [

3 p  V' B+ E) [, c. F0 j3 u不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )5 G% p  R+ e2 l9 k+ i; E

3 i+ ^4 f1 M/ |; ]( LEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz2 t5 X' z/ N6 X( u0 w2 @* ], z
5 ]& Q  L5 N) V! [6 M# u
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
7 V) P) G# P) |! H- a/ L' s& `# k2 f
For #2
+ K9 {7 Q( X* E* z8 a0 E) E, k=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
$ r/ S  c* ?% O8 L(...想像以前學的直流與交流的訊號...)" M8 q. `5 w3 }1 |( M

& n1 O( P+ B+ p. Q, \100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!% [5 r, @% q: Q, q& c- m; S# Y
* K9 v  X# @. w( B- a3 q
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
6 W, W1 L- F, g) r3 X/ P
- I; N0 o" @5 q0 SDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
6 M6 b: l. E/ S; n6 t( I, V( g5 f1 r+ d! h: t3 k( M
For #3
6 _; d/ f+ o) u2 U# D=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...4 ^% X. w2 f3 K, @# Q; a

/ F8 {6 x! c& }# o# a# T6 j2 G* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
+ D4 V, u$ S) O2 ~  L( }8 x) J# _5 P4 _4 y: q: O1 k! I2 o
[[EMI 測試的知識]]5 {! S! u7 q' J( q) W
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. / ~( b0 l7 m. J  L; }

% e0 \* e* p" F' e' P0 [為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.( @' d) G# v% }) ?; @: P

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

本版积分规则

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

GMT+8, 2026-3-5 14:20 , Processed in 2.560135 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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