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

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

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

8 s4 ?, K7 S9 g1 F在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...! K% Y$ u; K' _8 _
8 r4 x* M  E  l9 i! v
有哪些 frequencies由 clockgen 提供?
/ B; f* g7 }6 R  F. M- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
0 t7 j& Y/ l- q6 B5 P$ y- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)7 M' \' F4 f% Q( U. Q8 {
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.
2 v7 w: N2 ]1 r( K' {( c( s' G. A7 g1 Y2 P/ U3 [( [# Y
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
# \- a: I* H! \Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz# x: x% R( h5 p3 }1 V0 |6 q. _! P
  {" f- }. O, ^1 V
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)9 e" n5 `1 }. O1 w4 ^/ z$ u
- PCI clock: 33.3MHz
' B7 r/ T  s3 J1 E- W* z- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)+ F7 \* X' l9 V; z, ~
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
8 w7 m4 ?' f) {. R2 O) l( {6 ?- USB 1.1 clock: 12MHz
! m$ J7 t2 I# [& I: b0 O0 s8 E8 m+ ]更正: USB 的 clock 是 48MHz. q0 f, @2 m5 O; k" s: G7 T
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
: z" h$ R- z+ u5 g" N/ `  m
. H7 I  ^  p" w* c- h, i( @- SIO clock...etc9 A" i5 f0 F+ Z# n' W
5 x6 q+ m) j5 ^* {* C- x* j. P) D) [
Clock Generator的架構
8 p  Q; m( `( u2 c. X* y) z=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
, R2 Y/ `! T6 r$ y( z: V5 f( L' z
' I. x' g3 n8 V- x2 F- u& o+ ?14.318MHz -> PLL -> F -> Div -> f$ H- [" z# Q6 A- p' d, c

* b5 l% H( y9 A6 J5 ^5 F0 e! pEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz! T. |( o* j7 q

: @2 p) q2 P  B6 E0 Q. l$ r3 x1 RClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !" E2 A) U. N0 W" g
6 d+ O0 J8 J+ K. O
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ( t' f) b: u8 A( r6 B8 U: \# G  K1 I
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:5 L7 e- t; \1 I
1. 有 2 bytes(即所謂的M,N)來決定 VCO/ x' N" u4 J0 r) }% ^$ j
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div' u9 b3 K& I+ \3 o( U5 P8 _
3. VCO / div = frequency
' v% `& ^# R- T7 t& U. l+ v; j8 P% t, Q& b
How to access ClockGen
! `' J7 J% W/ E# x+ E( M' Z& R=>現今存取 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 d9 n% R7 t, w; W  T6 p$ M( C% n

! |) e( f4 Z, c; E! z不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
0 m) u+ _9 }! ~2 C" L& l- pre-init( clear status or ...)2 {6 e* B" R) L- N! I
- put slave address(要 access 的對象)
* B$ ?0 k# h$ ]; I1 W* N" t- decide Read or Write" ~) x8 f' U& [$ K( w+ n0 h5 G
- put command(Protocol type, Ex. Block or Byte access); [) @( b! O4 Z! w
- put offset(要存取 自 clockgen中的哪一個 Byte開始...)
8 k) p3 f, y8 _# B$ g- put data if (Write device)
1 h/ q" X. E7 O  z3 t- start transaction !!!& k, M3 g9 H8 I
(... processing ...)( ]" v' i. |+ I; e
- get "Complete" status to check if transaction is done successfully
) _/ Y; F: s  o(...wait for system reset...) 1 B6 t, ^1 }4 _& \. d
  j$ A" p! h6 x' p  i3 |
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
( O: K1 B8 `+ J. G" }( H
; M9 Z1 x# j9 k5 u: T透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.: Z8 g* J! w: a
% i4 \: @, S2 i% b- N' X! l
[2 Programming ways for clockgen]6 p4 G; w, z# C) g: x. n3 q$ n- ?
=> 現今的 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時會用到8 k2 I" q$ ]2 E- [1 N% |( v9 y! L
) q  D8 _2 U. E1 }
【Notes】. U) {$ w  g9 f7 k
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings! x( \8 X8 O: w  U) s+ l; q8 G

6 X7 d9 k5 n4 E# v更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper( D4 r5 O' w6 M" Z; P/ x

8 N8 b6 S6 o7 y6 l3 f$ W; C. O( L* t1 r/ W0 z
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
  B( g6 |% d1 o0 Y. k# z1 q# S6 S7 R2 f8 l* P
給我正確的頻率,其餘免談 ...^_^... 0 F4 |2 {) e+ d
; H5 C( B4 A! E/ A
=====================================================================
' ~  c3 P1 X5 v7 a0 ?Q&A
) I8 W- J; s% ~# W  y1 p- u" W0 @=====================================================================. N0 T: I2 r! a; _
>前輩我有幾個問題要發問!. Q( L1 ~4 L! }- |1 f: P' H  i2 V
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?: v8 P5 g: x2 O) T& E( v! \
>
, x- H8 o0 g) W" T5 R' h; b>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?& ~7 D) }/ t) |2 c
>) V) u+ J! Q5 }. \
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
3 S1 Z/ P, y. C4 K1 h, k! ], n& f>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠$ a1 m+ s  t" i' }% n: Q
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?; X5 Y; t' S6 y# O

$ h. R0 d. Q7 P) P3 G' S7 ]+ b[For #1]
* w! n' w. P, X; b4 f=> 我所謂的 "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 !
' w+ _% K' x2 W2 D0 d
! h0 ]% A# v. d此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
  u; o/ U( e7 _; k
" v2 S) }2 {3 z" M: @: }不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )8 w9 J" z" s) L
' N. z3 v. g" T$ w8 t. b% E
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz9 o9 k) `/ t! Y6 `
( C9 V7 O$ K+ Q; i
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
' V! L$ Y. @) ?' _! H$ Q3 B. q! s! N, f  L6 E
For #2
5 `$ j; R. d( _+ C; |4 Z9 u; w=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
7 p/ z% u: A9 d6 {3 `2 s9 q(...想像以前學的直流與交流的訊號...)" c9 X4 U! w; |  o
6 F" n3 X' v; R8 [  J9 q: [1 w
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
. K: k+ o* z  p- H7 E
; V  a  E% v. m" O" k2 E' Z3 L我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等. m1 |% H1 i& f# ~- O6 U
/ [& C3 [+ w$ x# W  S: A
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )6 T* N2 B; A" O8 e

7 w/ Y/ s. H& |; t0 ?1 w0 L/ GFor #36 e) b4 F2 k9 P' P
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...! v* I6 Q" w9 i

* o* V$ v) q6 P$ B, g5 U% d9 T* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )% U7 A7 W, w# m5 b) n% o2 i

: ~/ x* D4 x' ?" }$ d/ h[[EMI 測試的知識]]
& G/ ~$ g; O# g" Q2 `) Y由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 8 [6 Z  a# V  S7 e

2 J9 I2 d. n% ?% A1 k為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.7 S* l: F3 _- o+ J% B( x* [

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

本版积分规则

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

GMT+8, 2026-4-25 00:04 , Processed in 0.533903 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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