|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
5 v9 {- G) I7 K- t今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! . w! p ?) r6 b( x, K
$ z& e% m1 g1 e, r2 {2 U
, a; g* X* M0 L. {' W5 l# Q4 {/ n; o# p# W
BIOS入门之一: 8086模式 T" E+ G- G; u0 L6 k
( i+ U9 {0 \9 A" ^9 b8 z1 w
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.9 \/ p. g8 f; i7 D& P. D& U
' C( j. u1 M6 q$ g0 G3 v 先说一下目前的CPU的工作模式:
0 a$ L: H1 G2 L. ? 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
: B' N$ _7 B5 ?% ]- u, y 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....$ Q. J& V5 j0 l/ k3 H4 q, v9 J
3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
( i) q- a2 R. ~ 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
' \9 {$ Y6 s m6 q: c 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
& h3 {$ F; t. i! ~- F( m! S
2 [% A% O+ w% K8 z 今天说说Real Mode 8086 寻址模式:
/ i' B" m* L) @6 f8 f
3 M4 L t9 B1 [2 q0 j/ M9 Z6 T 8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 5 c7 c; K) Y: n- ^
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,4 a" N+ _4 d, _+ j$ z
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.# n$ N! F! E6 d. r+ C7 e! T$ q9 p; n
0 {' I6 f- O6 ?0 ]' Z
当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,: F8 n1 V, h7 `3 j4 w
试试在DOS下运行Debug:8 r* R1 y- n2 q5 j, c# B
-u F000:FFF05 N" C ~5 _2 h5 \; V0 g
F000:FFF0 EA5BE000F0 JMP F000:E05B
* h( o- A. Z) d3 d7 `! F: v2 O) OF000:FFF5 3130 XOR [BX+SI],SI
8 Q! z; `/ Q+ G CF000:FFF7 2F DAS4 m8 O1 N$ c5 G1 u0 q6 \) Y
F000:FFF8 3130 XOR [BX+SI],SI9 c. P Y# W! I# t( v
F000:FFFA 2F DAS+ M# h) s F9 w6 T$ c
F000:FFFB 3037 XOR [BX],DH
# a( j9 {9 Q- DF000:FFFD 00FC ADD AH,BH, R2 T/ X1 I( a* x9 W/ ` e
F000:FFFF 57 PUSH DI! g$ n' S6 m. w. t
* \* @! I- S4 _1 R+ U
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
2 J- s1 H0 t$ B3 Z/ ?
# P+ o+ e6 d; ~- t试一下,
8 T& m3 G' k: n! @3 o: m* G-G=F000:FFF0
" F. C E# Q7 c$ W$ ~1 c看看会什么样
' j5 r+ F2 ?/ W3 h( @1 o2 D: ]( F* ^
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
: r4 d- p, O6 N
- `1 ?; V7 e6 M$ { 我们可以以多种方式来对8086寻址, 下面列出的是常的:) n3 f. o5 r! q0 Z2 M$ t
5 ^5 Q6 C; m# A6 ]' I3 P MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存. E6 Q) d$ S9 u' a* V' n
MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存$ V3 _ O, ~- N) c/ n: e: \( i
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存, 1 u% S, Q4 v; Q7 Z" b
;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS6 [. _9 u) I1 h" F4 [; ]
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存
/ {5 m( i: Z9 h) C5 _6 R4 K2 q( o# w4 g6 w0 H
JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变. N3 u% A. Z6 V% f/ W9 J1 u3 D
JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678
* {9 A# {3 d+ x( M JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
/ K8 |9 Z3 X5 v) ?! m6 m3 S$ h+ A1 @0 Q JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
6 o: D) s0 u) C: G5 y JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
/ j9 k2 B8 ~" H # k2 f j/ G E! {6 Q; P4 @& M
知道了什么寻址,我们来试试, 同样,运行Debug, + a) F7 X9 W, \- Y- W' I% Y
=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟." L8 s' F/ ]; b- l0 h$ u) z4 x+ j
/ U$ f7 _$ H6 S) f. e) j! X. Z1 o
看看什么现象再说.
. Q/ r1 m4 H* p3 m' I
: H' H# v0 r( r; H x: g 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了, ) s! V8 l `! M& t, v
经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填) Z5 {8 G C5 {. z
B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF
* L: \- `3 f9 k5 U9 V0 i 一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务' ^3 V! V' w7 a) K- Q" a. ]
$ B$ @+ {' E# M" l, u1 h 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!
& R) {* |3 w9 j -D 0:400
Q+ G' ?# C- \/ b2 d2 s' Q. V6 g: z0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...6 r7 g: P* n9 d
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.5 z6 h8 m- j( f( o& s
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...( z( }1 ]/ V! T( h+ T9 w
0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...
4 Y0 R1 u) @$ h Q( |( L0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
7 D' G4 H, C5 D b6 N5 ~+ |0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1............... `. U3 Y/ Q% J4 G ` ~
0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........0 }1 v9 ~* x1 t. C
0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................1 N% S5 w8 P5 ^" F/ l
& L9 e( F; q* N0 `0 C& L 第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..! `4 Q* G9 m) j: H$ Q/ _, w' L
.... |
|