|
|
发表于 2009-6-17 21:28:27
|
显示全部楼层
你所指的BIOS应该是SYS BIOS吗.
2 f" \8 I" x! j4 v分为两种情况' v2 k# o6 i' n9 b/ I
(1):而且EC和SYS合用一个SPI ROM.8 {8 j" s, a7 k s- k3 Z
在flash sys bios时EC什么也不用做,虽然EC和SYS共用一个SPI ROM.* O0 T0 G2 N: {
在BIOS是有定义要flash的SPI ROM的位置,事先BIOS已经知道那几个Block是6 l8 [6 c$ V3 j9 r; {
留给EC ROM使用,所以不会去flash.0 [3 P/ |9 Q! V3 c. f2 Q& K
反之,如果是flash EC ROM.: g0 P! V" p" Z& G
EC的flash tool也知道自已应该把Code写到那个block的SPI ROM中。
$ }8 n9 \: `8 O# S可以用intel的fpt.exe来实现这种思想。
, ~$ ^/ q9 b1 C# L( D: Ifpt -f file.rom -a 0x80000; i+ i; j: H$ L/ }: v
就是跑过前面的512K来刷file.rom到SPI ROM中。9 p6 V# I9 \6 L" R; z, l& \
fpt -f ec.rom -a 0x0 -l 0x80000
5 E2 t0 D& Z" }! J) s4 `6 } ?, n就是将EC.rom写入SPI开始的地方,长度是512K/ l, O7 h! w7 s+ a. E3 H _
我看到的SYSBIOS是在开始的地方,地址0x0留64KB的空间给EC
5 T8 f) t# Z( N- `; Q它自已还是会影射到0xFFFFFFF0地方开始执行。7 u8 |+ G2 \' ~% ^" F% Z6 G& B
EC ROM可以当然SYS BIOS中的一个PCI设备的ROM来看待(当然不会被enum)
3 O5 b6 h8 W N. O. I+ ]" F1 f {如果EC的位置不会在第一位,ITE的也不知道自已要跑到什么地方去读7 L: ]( ?" Z$ h7 E& q$ T( _0 q
SYS是从BIOS最后的地方开始执行,EC是从最头开始执行,各取所需。; M9 U, i1 e8 p7 d. Y' g+ e0 |
1 ^% J0 x; U, N8 D第二种情况:( x' p6 W8 y, C, f9 j
EC和SYS是分开的。; ` k- Y- @8 }3 @9 s
那就是各玩各的,你想怎么刷就怎么刷,两者是独立的。
5 H+ k) r9 {. N/ |; X" v9 pcalpella平台就是这样子的(一定要这样子)7 f8 a0 \* R+ x& w
SYSBIOS要留出512K的ME和descriptor空间,没有多少空间给EC用了。
) n5 S }2 L n: R( S% \' u
& P+ {& J" x- d/ BSYS怎么知道要从SPI来读SYSBIOS rom,是由PCH的硬联线决定的。 |
|