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

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

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

* g& w" x9 y& @+ |有哪些 frequencies由 clockgen 提供?
0 s. d% M( n& r5 ~2 P( c- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
& g8 G8 J* m  F9 K- c- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)1 Z7 V) @$ e9 U: `8 ?) Y- G( r
更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.0 }: r8 `- L* M( p1 |) F

. j3 q. P) y8 N, n) s/ ^5 H1 C' K補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.0 T; d. I& ]0 p+ d/ n: o
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz! Z5 x* W4 L2 p8 r  P
9 f5 R6 r/ F5 K/ f
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)4 M* x) T2 Y: ^9 o
- PCI clock: 33.3MHz
+ i* l( k0 D: r1 y! _  v$ ~- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)- h; _9 [! n+ [) S& C. W
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供& p0 [- B5 [" B/ d$ ]
- USB 1.1 clock: 12MHz# B0 p" c* n* }6 j) c
更正: USB 的 clock 是 48MHz
/ `$ p4 A+ [7 b  E補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !) e# E$ [4 ]7 l* m* [) E9 ]7 M9 C

6 V+ Q2 g6 B& H9 U$ P$ ?1 |# F- SIO clock...etc
/ K; |5 ]1 y! v& Q3 w" ^' x" E% c
. q  k$ O: g. u5 }. ^Clock Generator的架構
; H1 P/ m+ E8 t* H& j* x=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:  ~" Z9 n* s" Z* _  n2 y, A

4 p. D, w8 d* Q# c8 J) T7 K14.318MHz -> PLL -> F -> Div -> f  L( g9 P& v) r  a

& W8 G) e) N6 y  k( zEx. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz- G; U/ B7 s' x6 n3 @: [: Z
1 Z! t. ?! b  @) h
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
2 b5 X+ c3 s! M) k( s" G1 m7 J8 @" @
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider)
# e4 t/ [  L% K% |5 a補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
9 X* h+ \) ^4 F$ L- C1. 有 2 bytes(即所謂的M,N)來決定 VCO% E9 g& ^( A; d6 g
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div, u* u5 ?' q" l8 Y& j9 x0 e1 K
3. VCO / div = frequency
6 J# [6 {- ?' p. Q; ?9 Y% X& R3 j" W! S* r
How to access ClockGen" D. I. s. k. u
=>現今存取 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( y: ^$ \8 v! B+ I/ B& e  p! m/ w* s6 G
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:. U! Y1 [6 ?/ _
- pre-init( clear status or ...)6 O% \# f. x* o7 ^
- put slave address(要 access 的對象) ( n! ]9 e, w3 Z6 z  X
- decide Read or Write4 R; z1 F' c3 U% O
- put command(Protocol type, Ex. Block or Byte access)1 @  `) @- z2 @
- put offset(要存取 自 clockgen中的哪一個 Byte開始...); p5 q! E3 C. E9 J0 s6 [4 V2 z1 |% H
- put data if (Write device)
: k8 z0 m3 s1 q3 f, s- start transaction !!!# H& `- r% Y& b: k: U5 V* `
(... processing ...)3 A+ M" h$ p) r8 r9 u6 D5 Z
- get "Complete" status to check if transaction is done successfully
% C3 s8 n# u$ `$ ]# d4 ?8 i(...wait for system reset...) ; d! d; n6 {0 y' ]8 Q  B2 ~
; e5 [, k5 i# `2 j6 C: c9 a
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.1 F+ {( y/ x* S# \/ f
5 N# i2 F* r# X- g2 d7 S& q, Y3 d
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.
- J/ H1 j' J( r, u* P: _" W- [1 }2 x( A. ?) v* W( w7 E
[2 Programming ways for clockgen]
5 D4 \5 U6 X) w" ^6 g=> 現今的 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時會用到
& B- `1 i  a3 U7 Y  L( ?4 U
. s5 ]+ t" X, h4 a# n8 J$ F【Notes】
' v/ @7 N0 M) {1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
0 K6 c9 {$ t% G" b) A6 f8 @! H$ b6 }
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper
8 |, H# M7 P: y" ^/ O/ ?+ K* ~
4 Z8 e& L) f2 j3 \) N8 b: k) W+ ]; b0 a5 F1 v/ l( b
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
) @6 y( T0 G2 ~- h9 S' U0 L4 V5 ^: R* w
給我正確的頻率,其餘免談 ...^_^...
+ F3 s3 e5 P7 a' }. R* J
# W. J. j+ |$ {, k- l=====================================================================8 M* M, x: x, K6 Z' j
Q&A7 Q& T, n: a4 `* W& X" P% ^
=====================================================================  O% e- G8 u5 N6 ^
>前輩我有幾個問題要發問!: I2 ]; ^& z& h# J% d8 b7 z* c
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
! N: u4 y) i) L3 P3 s% m/ B>; _8 u! p7 m9 j# P0 X" u3 i+ f
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
% ?$ w7 w! ?- r>' Z" c+ @( Z; D1 G" `
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
+ i2 C, u3 B/ Q! [0 _>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠2 G' \4 E6 n* X$ G# |
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?- U! w# L+ a9 Y- k# C2 m' V

, c! q6 y; q* c[For #1]* ]' k7 |2 f+ v( r2 [! Y% L5 b
=> 我所謂的 "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 !5 t- _' E  ?" ~: n4 @5 M% ?& ^1 n
, l- b+ W4 s6 `$ ~( w1 C4 _
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
7 p" @3 {5 l9 X' K2 X( S) L* B8 |. [6 D* ~. O. W- X
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )) a$ ]  u, Z) E
, {! p6 R9 ?8 E3 W/ N" }
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz/ u$ r! @5 d2 }! Q# m2 @! Y
: y% ]9 m. r" H4 ]4 T
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!& u- P) ^4 ^& x( R2 T; I" X
" N: @& F" d( l7 u3 |- S
For #2
* d7 u* T+ F  r& E9 k7 ^=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:
6 H  k; b0 h" \# U7 A5 \5 p: d7 j(...想像以前學的直流與交流的訊號...)
; s# p; m7 C( G. B0 m) g  d1 b" g/ M+ x4 \
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!+ o5 k5 y$ Q3 n$ [
3 e0 u0 h0 c' c& n1 O: q
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
4 p  C. _( Y& M( L- B% d- ^- Z0 W/ T0 y
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? ): Y& w6 @6 U, x( s

9 q6 {6 }9 P7 J3 |' ]For #3
2 b! v3 o* |& ^: h: D# G=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
# D2 v; N- G& M
# p  e. z% j! f9 m; _* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )2 t' X' I, g5 ?" a$ O
9 i- a9 H+ u/ R
[[EMI 測試的知識]], m, ^% o0 ?5 ^8 s3 A
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. " R$ z) `. o2 u0 ?% i
6 q9 t; P0 A3 I4 M3 `7 x- |
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.5 o( {, R* J( A+ \, j& j
8 T3 |4 k; I& U( z/ ^
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2024-5-9 16:44 , Processed in 0.064550 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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