|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
7 _! ` \' G+ e, [( {今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创!
: p3 s9 W9 g5 G; H0 e
/ \* @# P* c E x8 _7 c+ z; F
2 | ]9 b) w. o; l, ~$ NBIOS入门之一: 8086模式' [5 u' {4 Y8 H. d1 a$ }$ G( l
& [- N; f- J1 x; w- g
我们目前几乎所有的计算机使用的都是 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 P+ i$ L+ H1 O
5 m3 ^6 i/ U5 ^5 J% s5 j 先说一下目前的CPU的工作模式:
. P5 {! P8 y" w. } 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.' T6 r9 k4 T' y z1 l
2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....+ F6 ?5 y, b$ v* l. S
3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
1 O4 _# O* Y( ^ 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...: K! O6 F& _: F, q- u8 w/ I
4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
5 X" r3 F8 B1 y+ N% F2 q' Y , Q+ g% @: R p
今天说说Real Mode 8086 寻址模式:
8 w# w- H6 s* t- U1 Z8 }( B4 o7 Y
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移
$ E. ~" J+ A# s6 A: j% ] 段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,
7 ?' J6 B/ U" ~% a, N5 `" Q# L1 { 寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
) R s+ ^* k; R. W
, e9 ]: [, n8 z. q 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,
+ Y) {* p' q2 t C 试试在DOS下运行Debug:4 w$ m9 I" \1 k9 v
-u F000:FFF0
- B" t' @ r5 w l4 z& fF000:FFF0 EA5BE000F0 JMP F000:E05B
+ A: A; [9 c1 M( RF000:FFF5 3130 XOR [BX+SI],SI
- Z! ]1 S* K' }- k7 e) aF000:FFF7 2F DAS
/ u$ S3 t+ e j+ Z$ @% qF000:FFF8 3130 XOR [BX+SI],SI! y4 x* E& k. Y9 l" r6 P* y9 ~
F000:FFFA 2F DAS
4 A: Y& N/ v3 D" @' NF000:FFFB 3037 XOR [BX],DH2 q9 O9 j' @. r0 V; b9 {
F000:FFFD 00FC ADD AH,BH9 N% g4 W' O& X
F000:FFFF 57 PUSH DI
* @* s% i7 n f4 A. z, B9 \
- R) W: I, t2 \) _3 Y! x8 B5 q对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.2 a3 P. f# b6 L
$ K0 n$ K. a% I y& k
试一下,
. }4 I$ ?1 e/ c, F! }- t+ z-G=F000:FFF0' d' L- I% `9 T' a& Z, q& F5 i
看看会什么样
5 |! k+ |3 h/ J, ?% }/ X# Z
) V" q) |1 k4 l- X$ c% w8 W7 K以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..9 p3 S( }# [- E* u I% ^
1 X/ s2 Z) i4 i" ~5 S1 A2 S9 f 我们可以以多种方式来对8086寻址, 下面列出的是常的:. v( I9 K G& p/ K" a: J" r
3 U! Z& }) ?1 \' e# _ MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存$ V9 e3 j# W1 o2 d! ^ N# F
MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
/ x8 |5 z% Q7 t, q2 w1 Y+ A( L8 C MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
: z9 c0 r% P& X$ b# S3 z+ z ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
5 f& O d# H: O5 Q2 z' f' Q: J MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存
+ J1 q; C1 c2 n v& S8 X/ s5 H- T: P/ A% p& t4 E3 J# j
JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变) O, g/ f9 ~& f& P
JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678* o3 l9 J1 J3 c
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
5 C; C! V+ ^# `4 H4 m% @ JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变3 u- H b" i* o: [# j
JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
1 \9 E+ F/ X2 z) \5 h 7 ^, ?7 v, @& m9 [
知道了什么寻址,我们来试试, 同样,运行Debug, ( @3 S- z \: p6 h7 Q" C- ?
=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.
- `+ `0 m, @) a) d0 o4 @) X: d7 S( r
看看什么现象再说.
0 L$ R1 E% B1 w" s$ [4 f9 N0 f, D$ ]2 n
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了, + O+ O, I) @4 X6 W2 Q
经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
* Y$ n+ i( d/ a* p' b R' [ B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF
6 ?1 B" e( v2 j0 _9 u 一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务 l8 L E1 Q1 `- o2 q5 u" Z, B/ t
, v2 `# F* L& }0 |/ w
在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!1 N0 r0 ~# [$ y# M5 d8 j9 T
-D 0:400' B1 L% b0 V: M( ~6 N- Y `! c, \9 _
0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
4 I0 m1 z; w4 }/ w) d, m0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.( j. a$ c. o2 K2 d
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
' _5 K! _% g6 `/ C. l" c6 N1 @0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...
, L. r R, v9 I# M4 d( V0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
; ~; ?- \! {* \) R. r0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............8 N: Z ], A) [. w) N* \- H- h
0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........$ U' I. C# k. D
0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................1 C5 Q8 G$ _4 \3 ^6 t. E1 X
+ l( S& X8 v' J9 d% K- i
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
, ^. N- p7 x( C5 C/ P .... |
|