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

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

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

2 H2 @0 g. |, v2 p, u1 c8 U在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction.../ d: M8 c2 W. W, U0 b9 J
9 s9 Z/ e) t$ }2 J0 U
有哪些 frequencies由 clockgen 提供?
9 C3 |2 l" U6 |' G/ O7 g7 ?$ F+ v- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)4 j" d2 H: r0 Q( f0 m
- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)7 ^" d/ h+ d4 B) K
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
$ b9 o' V/ ~' o  g; n% e4 n% w
) E1 r8 j  Q1 i7 P7 w補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.$ S. f7 z. r) K# d% t6 i8 U
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz: d, ~4 a0 F; y5 J/ H% W5 X

% t, X3 t! \. m5 k" U& X8 z) [- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
/ e9 S) F% f0 d# q* R7 w- m- x- PCI clock: 33.3MHz6 E* z! x2 F" V$ Z3 k" @
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)# R: e; T( X8 H1 @
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供2 y# P; _8 Z7 f& r
- USB 1.1 clock: 12MHz0 C0 F" k" Z7 Q8 \
更正: USB 的 clock 是 48MHz  g' @% B: U2 w# |2 P& \
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !. ]1 v6 M0 z5 U3 d: O' i+ V

; m: j! L( S1 o+ X- SIO clock...etc
* t3 s! a. W1 s/ U( {; A
$ J- \+ t# A. s- ?Clock Generator的架構* y: _0 Z8 W- p0 H8 O; e8 `
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:5 k0 u0 ~. Y3 F' O/ W4 ]# _+ j) G
4 x( |! z( q7 N+ N" z/ A
14.318MHz -> PLL -> F -> Div -> f
4 I+ b1 r/ @& ?8 K# n
- R  [4 E' f6 uEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz3 R. d0 K: X+ o- f" C: T# o( P

3 ^2 z, M5 _9 u& f: v7 hClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !; C6 U3 N; D' @: K: X- q4 g4 X! _

( l) K" n7 O- j更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ' ^/ {0 _. \8 \% q* Z! }
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:0 u( M" Q( u/ U7 X, W
1. 有 2 bytes(即所謂的M,N)來決定 VCO4 U+ z" @0 }4 y# J+ C4 d5 A. P
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
9 e* q8 C5 L5 T% r- X1 V3. VCO / div = frequency- W0 a0 g5 S4 {7 P+ w2 T

8 B4 s* t3 {. o) dHow to access ClockGen
4 t& T, C: k. z5 t, C3 N=>現今存取 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
- C* ?1 ^3 R0 p0 D' ~
& {  n! u9 i) F) s3 c! W/ y不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:8 A0 z) s& G9 y" v2 A; c) ^9 S
- pre-init( clear status or ...)* @" v( M0 k' _; h9 a7 p( p' F
- put slave address(要 access 的對象)
/ Y) D( E6 e% d0 y% b- decide Read or Write
6 Q3 j* K1 e4 }- put command(Protocol type, Ex. Block or Byte access)
, u6 p6 ~/ U" ^' @/ H- put offset(要存取 自 clockgen中的哪一個 Byte開始...)$ ~- `; R6 X+ C$ Y9 b: C% |. q
- put data if (Write device)
+ H' d5 l; D/ \$ y: G" b8 o- start transaction !!!% x$ \4 J" ^: Y, E  ]
(... processing ...)
  f6 a5 }, e9 s+ u. ]- get "Complete" status to check if transaction is done successfully$ [1 \4 J( x' i! N8 ~9 z+ F. E
(...wait for system reset...) ) f5 p- I* \) E9 g: X, j

3 e* G5 L" @8 I; k+ @* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
! M6 H1 Q0 _. a. r
; G1 w! D+ x9 t, y1 r透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.2 ], i! r( z* `9 o6 w- ?

. n2 R& N0 P7 E: H" [[2 Programming ways for clockgen]& p3 h7 V. n; |7 t2 _
=> 現今的 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時會用到
4 |; l7 X( O  j. y: ^, F# I$ y9 Z( G$ a, Z& [
【Notes】5 m9 r9 h2 a9 }4 u6 U+ ]7 M
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
$ u% D- v% [0 ]- @0 I& c6 |
/ c5 D1 H8 T( a6 v更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper: n2 @$ N' U) V. N; Y

; a0 y% c. i* F$ E0 q0 P! y& l0 h7 h' ~
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成9 Q" l: M6 T* e+ D  t) O* m

/ d  s# |9 Y, k" m3 Z/ Q; u1 K給我正確的頻率,其餘免談 ...^_^... & T0 }% i: H" i! R% J( A% Y

0 ~7 N: k7 T: u=====================================================================
) J7 `$ Q- c) m% r# n5 MQ&A( }  j/ ]2 I' e" z. D% g
=====================================================================. i6 ?+ \! P! k0 b( p) ^
>前輩我有幾個問題要發問!
  S- s# c0 U' j4 y& |>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?8 F+ e, g9 T' X: E4 o( s) l
>& A8 `6 x7 H" X* q$ N3 M  Z  A% {
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?* H) P4 {. z1 L
>
- F  F4 v' `/ r: f: ^>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
& ~( W" A! Z  o  o5 C>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
% N$ H% \- w" j( j2 H  Q/ s% N>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?$ ^1 T1 i# [; d7 P6 a- F" }
/ t9 S" F: F  h
[For #1]
" {3 a0 g  C( b) ~, W=> 我所謂的 "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 !6 {" q; k* `7 ?& _
1 L5 A  f# A7 B! F2 G
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
! p/ q3 o8 Z$ U
4 K1 n, v1 r) o, }不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) ), K; L: Y) c1 z- |/ p

3 j) d( }* x9 nEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz" D4 g7 \$ ]" R; k
& M6 g( Z# }: ?& r$ R* F3 c
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!6 X. R% ^# {3 k  {/ f/ M

% k1 @6 U% y& M" H" Z) i7 O6 vFor #2
$ Q5 W4 ]' |6 G% V1 O" J=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:5 i* i( S, L9 r; g: p5 n6 q
(...想像以前學的直流與交流的訊號...)
# v' i6 o5 V, o& u8 _3 ^: l* w& m0 [/ K" b; C
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
0 i1 m9 D$ M$ v+ y2 C  V* Y, J* W! Q$ H: v* l, b* x  f+ L! H6 H
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
  |, a5 V5 I* Q6 Y
- A7 R) d+ R! |. G- MDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )8 b3 J3 Y" F: w2 ~
7 N( l% b) a$ T/ U
For #31 @5 v* g6 `' O, ^; y( ?6 C1 a; l
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...# \% g2 G# Y2 N8 ^; i) w9 \1 B' U
' q% |! j2 e% o
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )8 a( ], _! o) n$ f4 d/ g  @

- F/ S2 J, S8 p+ }! h[[EMI 測試的知識]]
3 v6 V. h0 M" t: a由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
7 X+ _3 T  H' \! H8 ~
8 ~6 j! I: Q' J4 i為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.6 R8 Z0 `7 i8 \7 p. ]! \
* k$ z/ G0 w, f  k7 P: z( P
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2024-5-16 10:33 , Processed in 0.054311 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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