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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.
+ O$ r1 ~3 A3 b! s9 U
: e; r/ u3 m5 _0 c+ K在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...0 w# k; p- W0 H& T7 N4 K
& ]0 m% l+ M  j8 ?5 L$ E
有哪些 frequencies由 clockgen 提供?
1 o8 f9 ?, @; V% C$ I1 {- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
/ _4 W6 ]7 V( k6 e" k$ k- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
8 z" j2 U0 a4 z$ J更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.* M: x# @4 _% p) [9 r0 B& u+ O  S9 {
3 O; }1 F: O! y" M  T! c# {2 \. c
補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
! E7 c, G  M2 u; vEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz
# y6 X& T% S) R1 H9 ~( b+ ^. b/ Z9 D/ f6 V+ j" N' {
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)2 Y- w+ N; @0 o# U2 h
- PCI clock: 33.3MHz
7 t' a, l& w, Y! g8 o8 @( _  C- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)
9 J3 I) @/ r! D/ X4 l& _- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供
' c/ Z% L2 w+ y$ @5 \7 W- USB 1.1 clock: 12MHz
2 p7 Q4 S6 _3 S* \" P* X更正: USB 的 clock 是 48MHz
/ M$ j* h$ V* |* b/ n' W$ i1 x% V補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !
9 R6 \, r% z) D6 B4 i. z* b# k6 J& L  W
- SIO clock...etc( B7 ]: ]  g1 \( C) L1 F
. E5 b% F! Z/ G7 U. [" P( t5 V( P
Clock Generator的架構
2 I# o* P5 a3 i1 K8 ]- d9 j=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:5 {$ M: W6 L' f$ n& D- b1 ~
9 S, ~$ }# d' q# f8 ]
14.318MHz -> PLL -> F -> Div -> f
, }- q( K" [' v6 W2 t: u6 d. ^$ G; `( C8 b' Z5 E/ J9 L0 S
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz
6 I' Y( P1 ]! d, g7 L' b
( A5 F) |/ v% Y5 wClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !3 h7 b( c$ n, N, m0 ^% c2 R

. A. q- k# {( e' U. g更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) , m5 e3 [, @2 P  r  d% i; F9 u2 S2 l
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
$ \5 y6 z: y; l6 t* ]1. 有 2 bytes(即所謂的M,N)來決定 VCO
7 z  Y, e  A# c7 _2 j4 K9 |2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div+ n$ q3 z# O6 e8 n  G! Q% K
3. VCO / div = frequency
( Q+ [8 z+ M9 S6 j, B' G# L1 x, V. D2 e/ _9 n& m
How to access ClockGen! ^6 l; y( J' R1 x
=>現今存取 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
% L% Z5 U- S$ ?9 |7 A' Q4 U* L! E: v# P- B: P! @
不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:
7 M8 B  j9 q8 i# ?5 w5 `' ~- pre-init( clear status or ...)/ M: A( ^# X1 H! ^
- put slave address(要 access 的對象) ! ^! ]' f: s! m' ?! H
- decide Read or Write) \& i3 ?7 j) }9 a, h' V  _5 |  f
- put command(Protocol type, Ex. Block or Byte access)
( a5 r( p# h2 _: j% i4 p1 O: w0 N- put offset(要存取 自 clockgen中的哪一個 Byte開始...)9 n' ~  W7 b5 @- M( f
- put data if (Write device)
  h1 Q7 B2 [$ M8 M- start transaction !!!
+ T7 O" _% C5 A(... processing ...)
, x. ~; Y& N; ]& c9 r9 X# U/ S5 S; ~- get "Complete" status to check if transaction is done successfully
. `" e" r6 T/ `; f; H(...wait for system reset...)
1 E* g0 M& J: E8 m# Z
4 |4 t2 W* T" H* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
6 O9 X0 N6 T7 j- D8 ~) h9 a& ?1 U5 p: ^" w' }& X. u+ Z$ m0 o. i
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies.4 E2 Q' Y1 _5 i" R1 \$ i

  b) q1 ^5 V2 s; l/ @" Y[2 Programming ways for clockgen]: K3 U! R9 P1 X/ {) P
=> 現今的 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時會用到* ?7 c8 ^2 ?: D) x2 t
( f; W3 e" J* o; U
【Notes】
1 F1 E; g$ x5 b4 n2 |# D1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
2 N2 [9 U+ ^; ?8 o, b* ^
3 V5 f; l: C4 [. w$ V  e更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper; M7 ?& L( X, a
. h6 ~$ n0 i2 |) }/ E( u" ?. g( i

- P4 O- A# P6 i) c% e2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
8 l2 e, j/ T5 s1 [* Z& [5 `( B' M; X" h# f3 p- l
給我正確的頻率,其餘免談 ...^_^... * R) M" Q: f4 s# n  U
7 ]1 X7 p  i8 o5 E- v6 U1 w
=====================================================================- b9 _9 [' U) X
Q&A9 X. {8 r; Y) S; s  X: {8 ~' F2 W
=====================================================================
+ E+ j" c3 v/ A# k) `" y$ b>前輩我有幾個問題要發問!* X# h& u# S/ C+ Y( H
>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?
: l% ]9 D# S. L. J; h>
2 o1 B% r- Q% P0 ]$ ?2 Q) v>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?
/ k2 a) _5 J+ Y  K5 x- Z$ c>' _* u+ i& j/ V4 G9 N$ f
>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以
- d! ?6 m  E7 f5 X7 J>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠
% N" T1 E+ Z5 R+ h8 d5 @+ F% h>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?+ H; S3 x9 P) s% q  x4 K  `" Q

! ]3 O% N( l0 v/ E- f7 M[For #1]
) B6 Q9 `8 I9 W: n0 O=> 我所謂的 "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 !, V$ \, S. k) v: V& w* Q
5 |) W9 Q, n$ m
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.4 M! y# c4 t5 g4 u* t! H/ S

$ M* r8 p  N0 N! O8 Z' p, O不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )
0 u. W% R  {6 S# O! ~/ R
* U" v3 q+ t, S$ M, l5 _' vEx. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz
2 h" D& t, j  g  Q+ O
  Y8 o) W  ~! V0 A4 E3 k" Q還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!% S& B( S# S8 o4 @; c

" ]: j: Q( \4 ?# j4 [7 BFor #2+ J9 W( d5 \% r# I5 r
=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:2 m( c0 }8 M# j8 e9 @
(...想像以前學的直流與交流的訊號...)
9 @$ y. R  l2 [; Y4 n& B' z
% B/ B; m4 ^: @100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!
2 c+ X( n2 u; t2 c* E
# e' T& d) D% j7 T# O$ t0 v# X我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等
# I$ L/ g9 ]# P+ a% @( t4 x* S' A
# e* ^9 Z. z4 W! y1 Y0 ODown spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
. F; G9 M. T( X( t: V
$ o8 `' I" R3 l' Z5 xFor #33 @! Y0 @5 K3 F6 \( l! i2 c
=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...
8 ]3 e' a& v$ K. ^! @8 ~" H- G- L1 [0 o: T" e
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )0 u+ P( D0 ~$ Z# C$ }" W

) T- `0 s$ Q2 W9 B6 v+ Y" c[[EMI 測試的知識]]# f6 G& B( e2 A, r; X" B! v
由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 6 Q& F+ Y; }6 y9 }# F# t: k1 a- v+ e
( |" @* r  s4 M( \
為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
, d1 o/ j7 Y  \5 \4 r) h+ `6 \; X' _
% F( K  o  l/ l9 W* w至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2025-5-22 03:39 , Processed in 0.040482 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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