|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
t2 v4 \# i" U5 R6 w今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! 5 V* }# o+ ~* ^1 F" v! s. m
) g8 f# I) g8 [9 ?5 ]
; o' I" c' f) x2 r# jBIOS入门之一: 8086模式( g4 y$ { O+ ~- f/ S
4 y# O) x* u' R9 L/ y5 b7 ^$ k 我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
. ?8 F0 s+ d0 z9 W: P: e ( ^ `" M4 A' U/ i* z5 s) f. M3 e
先说一下目前的CPU的工作模式:
% y8 o, p+ S( d1 a 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
- e( A( W. W- e1 X/ E0 c U. ]2 s 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....7 j) l3 \4 T- A) g3 B
3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....0 X, X6 \& U+ Q
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
" ~8 s: K( R) F" h: j 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
" Q8 t" s" z6 d3 K) P& A
2 H9 T3 x9 V3 l( I5 F 今天说说Real Mode 8086 寻址模式:( g/ \9 K, @0 L
) n+ r1 a! H; H! u0 e* \ 8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移
+ _5 }, \ S4 m0 `" m0 x 段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,# |) R4 a8 ?- C7 P- E5 e8 \8 P
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
" g2 L+ E* K M7 f
/ D4 y- K8 D; i3 l3 S: b 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,+ c: Q" u/ d T; Y# B
试试在DOS下运行Debug:
1 x& s' { y. a-u F000:FFF0
% e( s% l# E7 f- U; R d0 cF000:FFF0 EA5BE000F0 JMP F000:E05B0 }' A, j7 H. x
F000:FFF5 3130 XOR [BX+SI],SI
- Y$ C$ N$ d' u# WF000:FFF7 2F DAS0 Z1 u# Y7 a) @% p- }7 s3 w
F000:FFF8 3130 XOR [BX+SI],SI9 p2 A6 f- G) e+ C* W6 ?- K
F000:FFFA 2F DAS9 B7 k5 k5 B* k
F000:FFFB 3037 XOR [BX],DH6 b4 W; l! x/ a2 F; G
F000:FFFD 00FC ADD AH,BH
( `9 o- J- x* }% B1 C) c9 lF000:FFFF 57 PUSH DI
4 c' Z$ Y% N& Y, ]: M* u& ?* z
, x, v3 R7 k, @' j* b' e对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.% b" F N& ?9 T8 s' s0 s3 t
5 E" E3 |$ m4 m: ^9 |" i
试一下,
+ J) q: H: _8 a- q) ]-G=F000:FFF0
0 I# R" m2 Q5 [' V5 Y1 L' h# @看看会什么样 ; j- a- n+ Z: p+ b5 D5 V- F
& n4 F$ }" _* }3 W& l
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
. }5 `, h6 S& j+ Z, G u; u% J; J* l
我们可以以多种方式来对8086寻址, 下面列出的是常的:
" q# y" V. D7 C, ?$ l
$ f, M( {0 ]$ N MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
# i4 t$ M' c b. J7 c* Y MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存: v0 ]2 |$ a( L3 p
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
$ i6 o6 i# z' ~& \/ i ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
& _& M7 ^$ ~, u MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存
U4 B, w( t4 o8 ?* g/ Y% `8 r2 s6 b! K9 {
JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变7 V. \" ]; w4 C" u
JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678& A) q' T2 l" q: c
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
; a2 e+ r( E9 z9 ?5 o JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
$ F, M% ]+ u! a' ] C- m8 I JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2] T/ u( ~0 j. C8 Z; L- j
2 _ X/ H0 H8 r2 ?5 F' `
知道了什么寻址,我们来试试, 同样,运行Debug, 0 U" L6 ^/ @7 D+ w* F6 B4 m
=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.+ y( j ~6 }2 C1 |
* \+ O3 o, i* x- e x9 D2 \& _4 I看看什么现象再说.
# x0 V% @2 ~3 N
2 y5 M1 H5 f# S# } 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
7 q* N+ t2 Q- w+ U( ?$ F 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填7 @# }4 q' D, Y
B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF
$ T z- H4 q( a 一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务 `0 G0 I8 H6 }
/ s! [8 N" ^& } 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!: T4 J7 [( \8 r" i% k- ^7 L( L
-D 0:400
3 J8 T; ^4 u; [0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...0 I9 T0 s0 N/ \1 q
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.1 K4 `8 z0 X# H. K, X8 N
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
5 z9 g' J% h) V9 H0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...2 W7 C, q0 l' ?2 p
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...6 ?, T, e* _2 x* v# g6 T P
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
0 H6 M* r+ Z9 u n: m0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........$ l1 \" b) o, ^4 U3 c
0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................4 B; R: ?6 S& Y+ @* r# u# x' U
z4 l `3 ], M: d% u1 a
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..7 ?; ^3 F$ Z7 D* c4 p6 L6 }
.... |
|