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

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

[复制链接]
发表于 2010-7-1 11:35:07 | 显示全部楼层 |阅读模式
上一篇所提到的是:BIOS entry point. 它是第一個被 CPU 所抓取並執行指令之處.每家BIOS都有其相應的 file,要牢記.: A- M5 B' ]9 {& H' K$ ^& y

- B; ?/ M6 |5 j/ r$ f在本文中,要提及: Jumpless ! 在此要先說明Jumpless的意義.它代表:"用 s/w方式來 config clockgen generator,使之產生正確的 頻率s 來供應系統運作". 重要性在於:假如某個 frequency錯了,則將導致 system abnormal or malfunction...
' u% _  Y/ Q# Q; i' Y( c6 [" u6 M. `, P2 `
有哪些 frequencies由 clockgen 提供?' Y, o. b6 q6 A' K( y' B
- CPU clock (在此指的是 : host clock, Ex. FSB800 CPU 需被 supply 200MHz clock)
8 T" o- l4 p, j8 T, \* D- DRAM clock( depends on chipset design; Ex. DDR 533要被 supply 266MHz clock)
0 y; Y3 {: B% [- l6 c) x$ }5 r4 d更正 : DRAM clock現在都是由NB產生 . 外部的最多是 buffer而已. 並非 clock generator. 原因是為了保持較良好的 host clock & DRAM clock的同步.7 Z+ }. I7 K: `/ [" t$ V4 S* F

! H+ \' E; v4 ~2 ?- L補充:我舉的例子是以前的chipset design. 現在我做過的 chipset 其 DRAM clock的確由北橋來推. 北橋中有一會 register定義: CPU-DRAM ratio.
: t6 ]5 b+ q, c8 A# k3 \) F& XEx. CPU clock = 100MHz. Ratio = 3:5,則可得 DRAM clock = 166MHz! z& q- v8 j# a. u, |
% v1 X8 F1 s" W5 w' ~
- AGP clock: 標準 is 66.6MHz (= 1/2 PCI clock)
- p4 p- q/ v* d- P: f' R- PCI clock: 33.3MHz  i! m4 T$ K' {9 ~( y
- SATA clock: 100MHz(see SATA spec,似乎還要更精確...)5 d0 q& d5 P9 d( H
- Link clock: 即假如NB/SB中間有 link,亦由clockgen提供9 `& m! z. b2 S
- USB 1.1 clock: 12MHz
. ~) J2 K" z. z9 T6 q更正: USB 的 clock 是 48MHz6 o, U$ X" m2 z/ Y
補充:我們 chipset的 design是: 由 clockgen提供 12MHz clock(或由 external crystal提供),被 PLL吃進去後,會產生 48MHz給 USB 1.1(你說的應該是這部分). 至於 USB 2.0,則是 supplied other freuencies !- M; `) [1 ?& s8 s
  k8 o) `" X5 @# u( y7 b
- SIO clock...etc
$ M0 |6 V( c' t' Y* A1 M4 [; Z. g# C5 o! q/ c) i+ [1 \1 S8 a* w
Clock Generator的架構# M- ^9 N" O1 Y! b+ {; M
=> ClockGen基本組成為 PLL(Phase Looked Loop) + Div. PLL 的輸入為 14.318MHz, 利用 迴授方式產生出 frequency F;之後 經過 Div 除頻,便得到 desired frequency,見下列圖示:
4 A! H9 q% p9 C
/ q3 W& c, o; v. U. b14.318MHz -> PLL -> F -> Div -> f
. V( ^0 Z4 j% I/ i6 P6 W% h7 D. t9 E; v* t- a
Ex. F = 400MHz, 為 PLL振出來的;若 Div = 4,則 f = 100MHz7 e  _. k. \3 s4 w

6 @; {1 E! H) K) i8 tClockGen的 spec中,會列出許多 registers,好比是 Function 的 "contact window",透過這些 registers可以設定此clockgen !$ B2 h: Y1 B) S3 h6 j% H$ r+ Z

) e% O- V2 j9 I/ s* Q3 \更正:其實PLL 不是單純一個的 div. 鎖相迴路的參數是兩的divider 組成 M(VCO divider)/N(REF divider) 4 l1 e# k! Y3 H- q- h3 \+ u
補充:觀念上來說是 PLL所振出的頻率經 div後可得到 desired frequency. 但在 clockgen中:
9 I$ t# M  U) b8 `2 c$ Q1. 有 2 bytes(即所謂的M,N)來決定 VCO
! s9 W7 E6 E4 h$ ]' _2. 有幾個 bits來決定 div;一些主要的 frequency都有相對應的div
' R1 I7 x' l9 n" Z3. VCO / div = frequency
' n0 K. J9 l" b! {+ @. N
+ P8 V4 j, {& e' g2 [How to access ClockGen
1 q/ I5 q/ q/ c! S% D=>現今存取 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
' F% K' v' o2 t
$ ?/ k( p0 x5 S: I5 [9 R% U不同家 chipset 的 SMBUS controller implement方式不同,自然下command的方式亦不同;主要的步驟是:: q. W8 ^. ?( ^0 n; c" |! T$ O1 e' P
- pre-init( clear status or ...)
) x, P" J9 {% n9 J- put slave address(要 access 的對象)
: F+ ^  A; V+ ]+ E- decide Read or Write/ b- n& Q4 g; L7 z) s. T2 h
- put command(Protocol type, Ex. Block or Byte access)
3 e; N! Y7 h7 f) D- put offset(要存取 自 clockgen中的哪一個 Byte開始...)7 V5 M+ ~' ~( i1 A" G
- put data if (Write device)
6 v. L. D6 G+ s: {8 `- start transaction !!!
" |" B9 c8 t+ `8 ~. ^! H(... processing ...)+ l, Z1 t; P" N
- get "Complete" status to check if transaction is done successfully% Q; J2 z1 g4 f1 ]( h5 O  U* b& o
(...wait for system reset...)
5 z3 w) v' v$ D4 l  R$ x4 d0 N( @8 l4 Y. r$ b1 ^
* 當 start transaction後, SMBUS controller便會將 programmer所 prepare的資訊將之轉成 SMBUS command打給 device;完成後應該在 controller端有 status register可以檢查,看看是否 transaction ok or failed,或是有其他 error conditions.
' V# ?) x8 O9 F: q# a& _: }) J) d7 A, D2 J8 R" |' m2 n
透過這樣的方法,programmer便可以 config clockgen使之產生正確的 frequencies., g/ i9 k* T. i4 W" U  U

. W9 Y' m4 S7 i: e1 `) L[2 Programming ways for clockgen]
+ ~( _9 {) a& a3 y, q=> 現今的 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時會用到; O! [8 ~+ j) |& @- v2 t1 \2 V
, y' w% ~2 W$ f' d( F
【Notes】$ ~# f4 N  f' B( s0 V; b& E% R
1. For NB platform power-on CPU frequency 由 2 pins來決定;DT platform會由 Jumper決定.不管如何,之後做Jumpless都可以 override掉原 clock settings
9 M, t7 E6 U' A& s* z4 L5 n7 {
- K; _* ~- H, |. z# R7 N更正: 不是只有NB如此.不管DT 或server. CPU FSB 也是 pin(由於FSB頻率比NB多.所以是 3 pins )來決定的.不是jumper. 即使要做超頻設計會對這三pin做手腳, 也不會使用jumper% `6 z# Z! U8 g
3 ]! A  M/ `2 D

& Z& R: Z9 b& O" s2. 有些 clockgen所提供的 SS 都是 center spread. 若需要 Down spread則可以由 center spread搭配 改變後的 frequency(類似直流準位)來達成
; W& n/ P" H+ ~2 R1 a6 k( c$ _& @2 N& a
給我正確的頻率,其餘免談 ...^_^... % `; q8 z$ W6 _& x$ E) S
7 R* i& g& M( J( F, j  z
=====================================================================) w( ]8 }7 k# v$ W' f  C
Q&A/ L" q8 B5 }+ h) p  s, R" f, Z
=====================================================================- X  ]# R! k5 B# }: V, F4 W9 q
>前輩我有幾個問題要發問!
0 h5 P; E! [* E+ _- F>1. 你這邊說的Table方式頻率是指供應給CPU頻率嗎? Intel網站的CPU說明,他說是固定的不可調的? 所以這不是HW固定住(Latch)設定值了嗎?. E" J0 R7 d1 @: b1 G: \
>! ]* n4 M& I3 e" z' \3 S
>2. 可以解釋一下Down Spread/Center Spread /...所代表的意思嗎? 還有用途?" g. G/ q7 }$ P/ ]2 Q
>
8 |" u9 C6 P& h3 K>3. 我目前也在嘗試Program ClcokGen(新手上路),很多專有名詞還沒搞懂,另外目前ClockGen不是可以0 z8 b3 {. y, f6 G- P% E  t9 z
>輸出不同頻率嗎? 為什麼Table方式只需要Program 1 byte就好 ???還是說各家廠商設定方式不同,有些廠8 A6 ^- s- T( x" m- X% A5 s
>商只要利用1 Byte 就已經選擇好所有的頻率了(33MHZ/48MHz/DOT96MHZ/LCD27MHZ...)?5 u! D) L( N9 y% ]  N0 T

4 h+ m1 k5 b/ _3 t[For #1]  B2 i$ V1 s4 t! h
=> 我所謂的 "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 !
; o$ x8 z. N2 m0 b9 y" V, _( R" Y' `  H
此值一旦填至 clockgen, clockgen便依據該 byte(可參考 spec前幾頁,會有一張表說明: bit[4:0] <-> frequency combinations)來產生出 frequencies.$ s9 o; r( ]$ P; c
9 ?6 W. A; L( a. P6 {
不管用哪一種方式(table or linear mode),都會 supply CPU frequency !!!不過,此時的 CPU frequency is CPU的外頻 ( CPU 總頻率(core) = (外頻)*(倍頻 <-multiplier) )+ h' [$ p" ~0 y
# j6 s8 O5 c/ Z' n. s- j1 f
Ex. 外頻 200MHz(Merom CPU, FSB 800),倍頻 = 12 -> core freq = 2.4GHz/ X/ T6 Y/ j1 }" d: i5 Z0 P+ n
4 {/ Q6 m6 _# F0 x
還有,BIOS可以調整 外頻 & 倍頻 ! 沒問題 ! 不過,若遇到鎖頻的CPU(Ex. 量產版的CPU),倍頻可能無法調整.但外頻還是可以靠 config clockgen來達到 !!!
. F: S3 V# v2 x. F
5 S* K% x" J4 N6 H4 @& lFor #2
5 G- ]1 v- }# H; `7 [% U# f0 w=> 假設要達到 100MHz 且 SS = 0.5% center spread.則:3 `& p9 f" {* r& T; K$ F
(...想像以前學的直流與交流的訊號...)
; k; f* o/ K2 v8 k7 S% Q$ b# o" ]7 r5 U9 g' v/ H. ~
100MHz 相當於 直流的部分,其值不隨時間而變; 0.5% center spread好比弦波訊號(振幅是 100M * 0.005 * (1/2);所以,兩者的合成便是: 以 100MHz為中心,其值隨時間而變,振幅 is 100M * 0.005 * (1/2) 的訊號 !!!0 \2 s- V% J3 s8 H- G0 M8 A7 b
9 s  s7 t2 X6 m; ?5 ]# n) ^7 d
我 '猜' 要這樣測試的原因是:所產生的 clock一定不會是 perfect的 100MHz,有可能因為元件或是外部干擾而被 "改變".為了模擬這樣的情況,我們會將 clock的 spread spectrum enable,產生 "隨時間而改變"的頻率,來測試系統的穩定度...等4 Y. L0 X! M' }1 ?' C
% A6 O7 k/ m& ?  e
Down spread 0.5% 指的是:距離 水平 100MHz, 最低的值是 100M-100M*0.005,最高值則是 100M本身( 等同於: 水平值 99.5 + center spread 0.5%, right ? )
2 r& `/ J# z& x: ^' w" w8 i
# T& t  l2 b, ZFor #3
/ Z8 @2 [2 S3 I- P=> 前面提過,只設 1 byte 就可以產生所有頻率是因為: clockgen公司已經把設定各頻率的功能"濃縮"在一個 byte裡面 ; programmer只要 config this byte 就可以了...( F) H* R4 U0 O
# B* j8 N, P2 `( g7 T' X3 Q5 W6 h
* 關於 EMI 測試部分,有錯請指正. ( ...我有用到 "猜" 字眼...^_^ )
. E0 p1 @2 T5 ~( s' a2 a6 v
- {" L9 e: C/ n2 g! R3 E5 r[[EMI 測試的知識]]
, Y5 P4 k* l8 j  w2 K* T: l0 i4 [由於 對clock信號來說. 鋒(peak)值是能量最強的地方. 所以peak的能量就會不斷累積, 發射出來. 因此在頻譜上就會出現能量很強的頻率. EMI 工程師的工作就是要想辦法屏閉這些電磁波的干擾. 
6 [- ~1 Y# T& V3 u% U9 Y
9 c! @/ ~) A$ Q4 o: h為什麼需要 spread spectrum? 由於PLL 十分精準. 也就是說 100MHz的clock, 其 peak & peak之間的距離一致(波長固定). 所以能量十分驚人. 使用展頻可以使 peak 的距離改變(由於頻率不斷的在一個範圍內改變, 這個可以用示波器累積clock信號來看) 所以累積的能量會比較低. 這樣EMI 可以比較好處理.
/ F5 _( Q7 U3 ]$ p" F6 O9 i4 {2 O* J8 c! R$ v3 C/ u, n% q
至於為什麼會有要求BIOS一開始就把展頻開著, 以確保板子的穩定? 很簡單.不開展頻clock很穩定.自然比較不會有問題. 展頻一開. 由於頻率是浮動的. 很多設計欠佳的板子就會不穩定. 及早發現才能及早修改.
您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

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

GMT+8, 2026-3-15 05:41 , Processed in 0.573388 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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