|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了. # e' p/ S ?( ?+ d+ p: C/ {
今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创!
' \5 `) y8 e; o; t& E7 { T
. }+ ~2 u' H- a. d+ y2 H# C
9 a$ V! o4 s5 r- k, e1 j+ eBIOS入门之一: 8086模式
* g4 a6 Z" ]6 ~ {- C0 e% l
- t$ ]5 G$ r0 I, S. O 我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.* i( Q N; B. i) Q2 U" g
- \2 c) H1 l" @/ w6 U6 U0 H- x
先说一下目前的CPU的工作模式:) L6 z, i2 k# i" E1 r- O H
1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.1 h% E0 U7 i$ R1 ?7 s
2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....0 c1 u( Z% z |; K( v0 @% |
3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
4 |% J% X3 c+ J; E5 I( f* b 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
3 `7 m3 W0 Q2 ^- h. n* p7 v 4. Long Mode : 64位 CPU的保护模式, 再再下一篇.../ o1 p7 W. |' M5 z1 M9 h
) H2 B! G! C% }5 A$ e 今天说说Real Mode 8086 寻址模式:
" w9 K# p' r0 s1 k% R! q. I# B9 ~8 K1 y/ j J
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移
5 C- [1 R4 V. P) c: @' q: ~+ X( b5 ~ 段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,5 L* D2 G% [* T0 B3 \. \4 T
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
7 V9 f1 c( Q; A/ W & d: O4 A( z4 F; y/ v
当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,, c' x' m! j# y" D9 y
试试在DOS下运行Debug:7 {4 [$ l0 A# z7 f8 c
-u F000:FFF0
9 s$ {" p7 X& l3 k6 U6 s. {F000:FFF0 EA5BE000F0 JMP F000:E05B
( S% _. l/ o% p5 ^( D/ o8 rF000:FFF5 3130 XOR [BX+SI],SI
1 h3 a8 I x9 C+ L" R. W4 ^" j$ wF000:FFF7 2F DAS/ p8 ~8 a$ w L3 E8 _
F000:FFF8 3130 XOR [BX+SI],SI3 ~# r; A/ o! }
F000:FFFA 2F DAS
, i* g8 q; L8 c8 N9 k9 X' [F000:FFFB 3037 XOR [BX],DH
& m2 r; N) z Q; s* PF000:FFFD 00FC ADD AH,BH! g+ t+ ~5 W |4 R6 s
F000:FFFF 57 PUSH DI
2 t: y& }8 u3 k, j- |
; o4 I2 ]7 ?' K5 J对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
5 G; U- {* r8 b3 \: b) T
, Q e, Z+ h" W. Y4 r' q8 F试一下,
/ N( A* f, G+ Z4 p; e: K* K( ]/ l-G=F000:FFF01 n' I+ A) S7 _, R7 o
看看会什么样
/ f9 w9 ] V4 I5 i V+ H+ ]6 b* Q4 {7 b& u* f$ y; Y
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..0 o f r+ C! z7 r$ V" m
3 |* N3 n/ ^' p3 G
我们可以以多种方式来对8086寻址, 下面列出的是常的:
; X' [& T- V% W - R4 K& o# F$ v+ i, G7 B8 n- k
MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
1 Z( [' H( u" [, v' R MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
% k7 B2 ]# b2 Z4 ? MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
! X" O3 x, l# z ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS. m8 @$ K* V& x& o4 d" }
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存+ r$ z' W& s+ ^4 w! I: }. i( @3 x
$ n/ m6 g9 `, x8 J) X* r, a5 h
JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变; l% I a- P& ]6 s7 s; z
JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 56783 U8 r' X% P/ x" O8 ^+ o
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
/ I/ D. a) ^7 i0 x5 j. n5 p/ f JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
4 m7 c+ B7 S% a JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
& b' t( p. Q* U" x ! {6 p' a. d% J. }# @5 ?& P
知道了什么寻址,我们来试试, 同样,运行Debug, ; R- V" h% w/ A" ^. s1 T- ]+ e1 s. b
=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.0 V' X4 \9 G7 q; ^
' D' r F2 u6 a4 Y4 ^# I8 o
看看什么现象再说.
9 q8 n g% Y( p; O# Y, i
3 c, F; A7 A( Y( N" w 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
2 Q* t2 a- T" c( \/ s9 w 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
9 C5 v8 x' |' X: M B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF A Q0 K. L7 w1 H8 ~
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务
3 \+ K$ j+ c' {6 [$ B ) |# P* @7 v y' O. G
在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!5 Z# ?2 X6 e) j X$ N9 ?
-D 0:4004 i8 s* o% j7 q1 b9 a% v9 [
0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
3 N t3 g' D( o0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.
$ q' m5 t/ d- p; i8 K |' y- B5 P0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
d4 z# o& ]2 B* v/ o: a. Y) }0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...
+ r; m! v4 z9 c7 c1 V% y. p$ O1 \0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
4 r( F' |, B9 k3 ?0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
) f0 _ V: F9 }% ?8 u/ N0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........; v' X+ |, z5 j. Q4 i& ~
0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................2 u U3 _7 [! ]1 J8 ?6 g
7 Z8 h! o( Q$ F
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
! p- `( S- j( ] .... |
|