|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
7 _( w6 F# q v' o9 L/ [4 M今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! * ]# ^& n$ e& X- F6 x
. `& m; T2 t9 y6 V! z
4 _( S$ [/ c7 U& \BIOS入门之一: 8086模式/ G' e" t/ ]2 g+ u* Y- ?
/ u$ A0 H$ o4 X/ Q4 }7 e+ D9 X
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
5 S) b6 ~0 `. V4 z
5 S( g. \& i; s- G9 n8 u1 \. J 先说一下目前的CPU的工作模式:
0 [3 V5 A D4 r; b# D b- `- f7 p 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
$ |/ b/ b, _$ F 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
% x' @% O9 T& c: R8 v/ Z. e( L( I 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
: [: X2 `; a _* Z4 ^/ ?* ]9 ] 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...8 c' W. L3 Q, X K
4. Long Mode : 64位 CPU的保护模式, 再再下一篇...) ^: f- c, c b: H
: Y' m) A; j( e h3 p) V 今天说说Real Mode 8086 寻址模式:' t' s2 f7 o/ T3 d$ J( q0 u; z3 \
- l: }* l5 a1 d' v3 S
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 6 w5 V" n" Q5 o1 F. [: O" s8 _# s
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,
2 p& Z- A7 U4 {# f 寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
3 a5 E- r4 ^7 Z7 Q
* E* w4 s. _! ? 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,
3 z2 S ]# B, ?7 c 试试在DOS下运行Debug:# i4 O; D; q5 i) u
-u F000:FFF0
* Q0 d! }$ Z# N0 _2 a! O$ b& TF000:FFF0 EA5BE000F0 JMP F000:E05B
J7 }. L0 ^; k5 Y& l, zF000:FFF5 3130 XOR [BX+SI],SI* {" {& E+ `; Q& E0 z5 `
F000:FFF7 2F DAS: y0 O6 Z7 Q3 v
F000:FFF8 3130 XOR [BX+SI],SI% e8 i$ k& M+ Q: D5 I
F000:FFFA 2F DAS# O9 s; H$ y" q
F000:FFFB 3037 XOR [BX],DH
7 p; c9 ]. {! w! n) EF000:FFFD 00FC ADD AH,BH
9 w; T- s# H5 f$ H! N1 o; c& eF000:FFFF 57 PUSH DI
- I. q0 Y$ R, [' D( U% q: o( \: @; Y7 Q1 |) o+ }
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.4 o( y$ Z& w+ P1 P7 F* e# i% s
- K" e. B8 m- t. L0 {试一下,
4 A" [/ A- S# y9 ]-G=F000:FFF06 W. ]: ]0 U" N- k
看看会什么样 , D6 L. f+ v! k. o7 Q; m ]+ j6 K7 f
3 y5 R- L6 G- w; i3 O( N
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
- k# Y2 n4 o% |( r
. p/ E7 I$ a& e 我们可以以多种方式来对8086寻址, 下面列出的是常的:: T) \& ]+ h; P ]/ o
! J" J& l: j1 R% q6 Q
MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存9 a; \2 m3 d- T H2 v
MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
# w( b: D: k- s7 Y: r2 L; L MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
# K' _7 R! W* Q: u* A9 I/ ~ ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
: q0 ?1 h! r$ T MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存6 S. N( }. I- d. R
% ^* f" r& _% x6 U% [; G) h8 s JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
' b0 J9 U4 s& A JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678
/ x6 l& R+ |4 g& ]1 C& E JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
0 N0 h/ k2 y& U2 a JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
( m' ?& m+ t; ~+ T: K$ ] JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]8 M. N% @2 Y& z/ Z9 y+ ]
& N$ B' ]& W9 K0 `2 K) U3 B9 F9 \
知道了什么寻址,我们来试试, 同样,运行Debug,
' a! Y. F: ]/ B% i=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.# o/ n' w0 S/ Q2 `2 F$ l
8 ?: `9 B5 C" l9 @# G# L' ^看看什么现象再说.
, H: P% F/ w+ H( J. c2 q: e
) p; A- _. Q$ o/ W% k 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了, % R( }4 z* k: [ Z$ I
经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
, J0 |6 n5 b( }/ Z% E# Q4 t B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF
. t f9 s6 m2 N `+ T 一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务
* ]& M, G+ e! E; v 2 l% }2 ~* E; ^% N& R! I5 ^
在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!
+ H( J- m8 a& T1 m5 b% a -D 0:4007 B5 X1 W/ h- H
0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
4 A6 o6 {2 l4 e9 G$ E) M4 b& U0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.' V7 a$ [, i1 q- u2 N; k
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
5 n4 f, w2 g, A7 {8 a- s" v0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...7 l1 D( X' r2 ]. x, v4 w# t
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...4 G$ f$ P3 E' m E% }4 s. D* ]
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
* U- j( N1 |, o8 n0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........% W6 Q) B2 p7 d4 u0 a
0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................
4 S( h0 l4 X8 g* z- j& z2 k5 k
- I$ D; b, l* m+ m1 I- }$ T# T7 D 第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
8 t. e) l1 E! U" G' ^2 z. Z/ r5 z; B3 k3 e .... |
|