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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
; \) M" Y. d9 L$ ~( E3 x$ i$ w4 [$ {3 z+ Y8 x
在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...# y7 H$ k8 J% S

( g  n2 U  e* e; G" B. b3 \有哪些 frequencies由 clockgen 提供?
' N- r: E- T; T# b- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
+ Q+ b  K1 j9 E) X, H/ K8 b" h8 I( |- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
$ y/ M% r2 S1 C- P: E) @2 i; b更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.9 R. L5 n' P/ N4 W* P

( L1 {7 j3 n3 M5 D2 `0 m/ j補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.$ u- o( f1 y9 g$ o& I1 C, X" d% `: \
Ex. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz; e- {$ a4 p% U; B

. B+ S! h* r8 v2 K% Q, G; ~- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)+ Q: R0 x8 f, _) P8 k! ~
- PCI clock: 33.3MHz% t! d; Y: U* X! A8 c4 |
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...), b  |5 X* s+ |
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
$ J7 P0 F2 z6 P# v9 J' L- w- USB 1.1 clock: 12MHz) C8 a( z$ g( y; N7 A
更正: USB 的 clock 是 48MHz
) M( s' u3 }& D1 m) m+ S- x; R補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
% ?, {4 n5 }- R4 v- D) Y% U8 x9 j2 q3 M1 y6 x( a8 N
- SIO clock...etc4 i; `. s/ M) p

$ H( q8 z" j/ i& cClock Generator的架構- y6 b- y7 A. m
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
  {/ I7 N: D3 W& B/ c) ^* `, H* m( H- N4 K1 t( x. ^$ m% L! x
14.318MHz -> PLL -> F -> Div -> f
+ Y4 W8 k+ X! D* K( l6 ?; `1 g' ], ]; U9 ?
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz6 E9 N/ N9 X/ b- O% f' R) k7 r- r* W
4 s% ?" M: A0 e2 t* {( f5 Y
ClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !
' U% a4 v0 C' l# {8 r# [- I+ B( X' O, s6 f! ]$ ?) @1 Y
更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) ( g! {2 t0 g4 Z9 x9 b
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:, u$ O2 l  {; G% @
1. 有 2 bytes(即所謂的M,N)來決定 VCO* g0 ]+ G4 G1 r, m* J
2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
1 y' G5 y, u% s+ m. O2 G/ V3. VCO / div = frequency. n: c& F* e, k- K- U) X
& Y' n' s+ n$ J) ?/ L/ G
How to access ClockGen
2 d( R6 [) L! U/ G# y=>現今存取 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 3 Q. s" i: p' P& |* r$ r

6 ^4 x! S8 c5 H% ~7 w- F; w不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:6 O" M5 v' l6 z. d
- pre-init( clear status or ...)
/ f, E$ F* u6 g5 F2 _: Z( p- put slave address(要 access 的對象)
$ M: e! A) h- P" l1 i" F  I+ p- decide Read or Write7 {4 \1 t6 d6 Y4 D2 f
- put command(Protocol type, Ex. Block or Byte access)
- q8 z( E7 \" f9 ^% m8 z- put offset(要存取 自 clockgen中的哪一個 Byte開始...)- k0 e4 g& S# c3 T! P0 [+ {
- put data if (Write device)
/ _0 Z8 p- T7 B- start transaction !!!8 t, \2 Z. a0 M% K! k  u; {$ }
(... processing ...)2 w, d) q: p# d) z8 X
- get "Complete" status to check if transaction is done successfully
, H1 J% e0 P$ A% P7 R(...wait for system reset...) ! \( R' x' O; B& E: ?
1 M  B0 y" A7 q3 d+ s) s+ C
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
1 X2 _9 W2 t3 P3 ~' r, w) P/ c1 m% \1 }) N/ \" C7 U3 l5 ^  t
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies." k0 V% p6 C7 ]5 b8 x4 p

- Z# Q* z5 P, ^0 J; t2 R[2 Programming ways for clockgen]2 f8 P1 h* D9 K2 @' [: E9 w9 e! z
=> 現今的 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時會用到
) I$ l& A8 P# l+ p) V7 Q1 b) f0 m9 R) t( r& c
【Notes】( D6 E- {( n7 w4 b- o
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
0 [* H; W* G! S8 Q% n" n! C* b: f* c  X
更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper& y+ ~8 V0 v, j# F6 _1 m

8 s( E& ?' O& V$ |- P% Q  |( R
2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
7 N& {& V* a. D
3 j( L$ P; ?, J) L+ F; W給我正確的頻率,其餘免談 ...^_^...
5 t5 |8 Y9 W9 H% [5 q; a" X3 k  C
=====================================================================
1 I2 E! d& V% VQ&A
0 ]6 I+ u8 y) C0 w=====================================================================
. v8 e- |4 |5 a" s& j>前輩我有幾個問題要發問!
% f7 k5 N! B, |8 M/ N) _3 m. p>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
8 @+ o2 L  o- i  D6 `>
7 f3 Z: k5 T7 W/ b" N. |& e; h>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?" I5 V2 H: A2 W2 X5 k; D0 m
>  [! X5 D  P- V! [! u0 A- M
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
; o! @8 u. A$ z, R4 R8 {>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
& W& L8 _% U, ~" s>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?2 }" O3 D6 o3 e9 Q. Y. K
- y7 p/ l; u! H0 p2 ?
[For #1]/ C6 o: l- W) x6 w' Y5 z. g
=> 我所謂的 "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 !* j% c9 }% ]- p& k+ R% p: J
; U) N5 T1 Q& v% A
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.
( j% p. R  u8 ^
1 p6 Z  W2 E2 o8 p不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
. O# J7 a& l: V, H: h# q2 B# U0 Z" p! S" t9 t6 z6 }2 D
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
/ E0 m6 N( C5 u: v' w1 c7 ~: u1 e/ X8 h
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!7 x% W+ N* \5 y1 W) c( f

  V& w* T' @# XFor #2
6 n, D; S& R% J5 g( G3 m2 [=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:$ [2 |! ~4 F6 V( z+ i
(...想像以前學的直流與交流的訊號...)* U" p8 s* D- y! `1 `% q5 t$ O+ v
+ v9 B* g9 v) z
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!" ?+ B8 C, b% I% M! \) r3 g' q6 Z

1 d1 o: n  G) S9 [) H我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等. S) i( I7 `6 h( ?- z

" |3 u6 H) p. N! J' r9 E- Z- r3 TDown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
# G$ V+ F  h4 G" t6 E; ~! n- X/ T/ Z6 g$ o' r% O# J
For #3
) c; M: P& Y3 Z: O* I$ i=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
& ?7 \9 [7 k/ n5 M% e* C' |7 h6 _7 S0 j, f
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
7 x, D8 x/ M: ?" K9 R+ H( i: ?5 @  S7 v9 d5 t5 p. D6 Y9 r$ K$ `: ]. @$ L% B
[[EMI 測試的知識]]
  s0 b7 i, L" L$ l6 x由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. " Y6 L- A2 R& h* p1 N

; N8 b5 Z) E! _' L2 o為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
* e1 B2 o9 K8 [" `# M, _/ B  q* r' ~0 i* R4 \. A+ I3 n
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2025-5-2 06:06 , Processed in 0.032224 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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