|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
4 m6 S- b( p* G" w今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创!
) S# d( n* }, G+ ?
9 I: S! @1 B8 p: q w" ~: X( |
, l: d+ `# {( S+ f' IBIOS入门之一: 8086模式
/ o! S9 c$ \/ D/ {1 ]/ c h: n( `4 k0 S2 ~0 I3 b6 y, l
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
7 w' r, h. c! Z+ A: A6 W
) p3 t3 b x& e. `5 I 先说一下目前的CPU的工作模式:# |$ h2 r0 [ l' c' V8 Z
1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.6 Z! u. {4 \& f1 `: ?
2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
8 S3 d+ e& g- v 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....0 _ @; U) P$ M& e! ^% X7 w' k
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
5 m$ x7 k, o& n+ E k 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...0 S7 {0 j+ Q6 \/ X# I$ b: k
" S2 T, n8 k# ^+ }: X- L! o) U9 D
今天说说Real Mode 8086 寻址模式:1 E: ~9 l7 U3 u6 d/ ?' g3 d: R! }
5 E# W- s; y) E7 A( {* @% d
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移
; p- {, M7 P- @ M0 K 段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,
6 W- ?& Z( n G# I 寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
D# h) X" I* T0 Z: c5 A3 g
7 q& W. M9 @1 W' i7 G& V 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,
* a' e @" a, h1 |7 W% v- ^ 试试在DOS下运行Debug:4 H# ]4 V Y6 M. {; }
-u F000:FFF04 h* Q w& r4 c% n, g* o
F000:FFF0 EA5BE000F0 JMP F000:E05B
9 Q# L P; i8 F9 XF000:FFF5 3130 XOR [BX+SI],SI3 ~9 d& y- W4 v! Z$ h2 t
F000:FFF7 2F DAS K1 l' F; d& k
F000:FFF8 3130 XOR [BX+SI],SI
" K- X) P2 U I5 U. o3 @9 z! mF000:FFFA 2F DAS
( c) u' L7 `$ ?5 T2 A- EF000:FFFB 3037 XOR [BX],DH. M, f- T9 o C+ n$ A
F000:FFFD 00FC ADD AH,BH* R. s4 |+ U- q& r
F000:FFFF 57 PUSH DI% Z! S; m; c& N5 h
" u* @( X ~' }, r! d W7 W; P, o5 j
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.! w5 c" c- O! m- L$ e k* b( B* U
3 r# `3 Z' v& S. t. m
试一下,8 P6 |4 q( Q( {0 p
-G=F000:FFF03 k8 f; n% S7 N" Z* h( D, }# [2 g
看看会什么样 ( b' A2 i' A" J, y- D0 S1 `! r
# D3 D$ Q- S* K& j以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..' I1 V! s- S) [6 d& A" J7 x
7 `+ z$ \- q1 |8 k 我们可以以多种方式来对8086寻址, 下面列出的是常的:: n% h2 _ ?8 a e5 I1 A* p
& s5 n* Q) Z( a! h: t
MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存9 P4 m" C: }* w
MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存( g a! [% ]1 M/ { `" _ J
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
" ?5 V* S! P& e ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS! X1 y) A7 h* F& @% o' b
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存
' B1 {# K* \9 V) ^. l- D
I! }4 A. d' W% Z1 M% ]4 B8 S4 [ JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变8 _8 y l! p& I5 ~5 S
JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678' x* V) Y% t8 X2 W8 `+ C
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变/ J/ n. t& _9 y' Y* \/ c$ ~
JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
# E7 O v0 P6 T4 r JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
9 ^1 H5 K9 B [) c 6 j8 s$ q" S' i
知道了什么寻址,我们来试试, 同样,运行Debug,
6 p# x6 S5 u+ M5 n' j4 p=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.
+ j. @$ V& h4 a8 a+ m3 a, p% S ?8 k) b1 ]9 M! b; \4 O$ p s7 T% D2 U
看看什么现象再说., r) I$ Q7 n: Q! D/ b) A, ~) p
{! j) X" \* I+ G" D$ l) G
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
7 i6 j \: x5 M6 g 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
# F; ]2 n" d1 j" e B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF/ n! V0 k9 M7 ^6 j* u+ a
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务8 m8 w2 }, k! i
& F! { j! j8 I8 Z2 X1 \3 m 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧! J% M# O; L0 ` z5 B' N- z
-D 0:400
/ x o6 J/ R3 D; R0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
: {. x. G6 I+ G( C! d2 Z0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.: {, C- e2 Y; _: V: Y. P6 k
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
G2 N; s; h" G# c9 P3 a) X0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...+ u N: Y( D1 q1 [1 N
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
. i! k9 ?9 z* c2 B0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
, L1 T7 G3 E" f X; G+ W' N0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
' ^/ O2 L( u) K0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................$ C, O+ O/ D0 Y
8 E6 R% }0 \& T V6 [2 F7 U! j
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..4 b4 f( b! I% k; F6 g
.... |
|