|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了. 5 Q5 g8 r; D" M6 f# S
今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! 3 J, T. c" d4 U
: {. _/ k! K) N" C0 D
4 ?& v2 u, |6 Z- eBIOS入门之一: 8086模式5 U4 k4 v8 H1 {% z7 E8 s! |) d5 L
) L* Q) e. U8 V3 O, v2 g3 `
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
' i4 x# f5 H2 w! Q6 T; d- q, A! o + h W8 `# ?1 Z# ] f7 G0 c8 J
先说一下目前的CPU的工作模式:
- V: O6 \5 q$ S, i* w/ E4 ]& o. c" G 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.% Y6 }' G: l ?. _9 j& t( n
2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....5 ]6 a. D0 K& a4 v; k9 b7 p6 w
3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
+ ]8 I: ?# T4 l2 N 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
) S, J5 f/ p. |5 N4 u% [" }: M8 U 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
: L* @2 v$ _/ v: n* u w' U+ n " C3 @- n+ i3 U
今天说说Real Mode 8086 寻址模式:
$ C4 m. {2 B* I Y' h2 }6 q' R
3 B+ s8 F2 Z$ h4 K3 Z" [, \. R 8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移
7 v/ r6 j; F- |& M, b4 e: ^ 段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,. V7 C7 ?" K/ u f
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
2 r9 S1 k) M6 j3 n! w8 B
" Q6 B4 v0 Z l6 \ _% R5 H 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,! t( t' m6 E# R$ ?6 X( y9 d) D O* w' ]
试试在DOS下运行Debug:
" l" W0 a2 F) t8 f& o-u F000:FFF0
& t" o7 T( O* o# J Q& p# t* ]F000:FFF0 EA5BE000F0 JMP F000:E05B( t3 \7 n+ h# J5 y3 q8 t& L7 E
F000:FFF5 3130 XOR [BX+SI],SI
1 b' E+ s4 A. E5 q3 @% |F000:FFF7 2F DAS
4 l* k( X' u, ]F000:FFF8 3130 XOR [BX+SI],SI3 y, R5 ]' X# W; J1 [1 T$ d* l( Z
F000:FFFA 2F DAS
' C# l n* V. D1 V( l D$ kF000:FFFB 3037 XOR [BX],DH0 t5 I, z* u- ~ m8 s% v
F000:FFFD 00FC ADD AH,BH1 f8 ?; j4 o- a- c4 \- k
F000:FFFF 57 PUSH DI
: }( |( I$ V( n0 z3 z) i, P
+ D1 k( R x1 k* g1 ^ [2 D对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
+ u7 H: \6 Z! c" v: D$ y% r4 s/ ]
: \8 e2 }0 H) P& d% A: j, I试一下,
: p: W- k- C9 S-G=F000:FFF0" a, q C4 \# `: I
看看会什么样
4 y! R/ r& k: V$ V) f0 u
d4 \/ a! o1 i' x# e" i以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
4 i0 ], y3 `( f }5 x. s4 G0 Y8 s, ~9 i: i" c% h4 R- ]
我们可以以多种方式来对8086寻址, 下面列出的是常的:
, w+ m2 v; q' c+ T. d' X 1 R# e* {* ^2 x3 t: q5 g4 O
MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
3 Z4 w; v6 A* _2 {- t Y+ ?8 I MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存# u+ `' {! v+ G2 n8 O) r
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存, , A2 l4 B0 D' E5 a% n" e T
;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS! R) U. t; y( S5 \, l1 Z% S
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存) r6 d# S. ^- t/ S
Y( \( T; F4 T1 I" b4 q
JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
! ?5 T2 m. l& `8 u3 P4 W JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 56787 F8 n$ o; Y: x8 U' j
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变7 o1 v# K2 y. ]% ?
JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变" B) N' K7 S% \
JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
# {" j! ?. C, ]
; ^: m% Z6 {$ O) T2 O知道了什么寻址,我们来试试, 同样,运行Debug,
! C; Y9 p& ]% w5 @ g7 Y=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.5 U2 A8 S& T7 U3 ^9 k5 H
- J* W( ]9 }) f ]- J/ b看看什么现象再说.# S" S7 ? Q8 A
' R3 h, r% s2 a6 `1 R: f
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了, + q1 L& Q9 x( }" e
经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
& f2 |+ M$ ]/ B. R B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF* {% c' X( v" q# T
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务
$ e" n: j1 o+ k* ~. O
) u9 I% m) w! Y$ o) q* t' J 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!
6 w6 I* ~4 d+ n1 q0 U -D 0:400
6 M$ K% D$ E- n) r* f+ t0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...3 w1 [# K: h+ j' c/ R
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.
, _! X; Z1 A% |7 B7 ?$ U) B/ `0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...3 x1 s4 b, y4 t1 k2 V+ {$ d% r1 b
0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...* O- X+ K6 _7 P* k, e- J
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
' m0 L3 b8 H/ k0 r( Z" S0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............0 {: ~: z0 i. S* P
0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
7 n. S$ K2 |5 ^; A" m0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................ I! k( u- a4 m9 e* n$ q; A
( I6 I d! [! I* u
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
, |9 q% h3 J3 J$ B3 h$ z! N .... |
|