|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了. 8 h& E4 K4 V* X: A
今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! ; s+ S* Q8 b% \1 B/ e& t* S7 J1 `' K
5 Z7 D4 `. N& P C( I" R# }3 r# ?# B2 w- m7 H- q# h$ O
BIOS入门之一: 8086模式+ I8 T& O2 ~* W: J+ c! s9 g$ ^
0 o, y4 V6 x _- H
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
" Y% m0 G+ J l9 ?3 D8 C- K' v
7 S2 }+ R8 u2 n- M$ Z5 t; X$ A 先说一下目前的CPU的工作模式:) W; K5 [9 U$ r% K" \
1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
! [2 W5 l8 n9 r) C 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....) X7 O. K: K( d; o V# n/ j1 Y/ g
3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....* ^) o S- t. N
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
7 w, q" G. N9 Z; h+ x: D 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
+ ?. n' t+ y, b- r: Q$ D, E$ h
( B7 v# n0 Q- D1 U& V' A+ a) S 今天说说Real Mode 8086 寻址模式:; {* o. z" p' _
$ k0 X4 T! C% m" u @
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移
8 Q8 t6 x- z- y6 c6 L 段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,
6 x% C6 v5 e1 r/ l- c# c 寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.7 H; D0 u1 N+ c y
. k0 W2 E- z* L( z2 S# p! S, |' e
当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,( C' D7 N& i* c1 W' R
试试在DOS下运行Debug:
+ v/ |; U3 I I8 _9 N; n-u F000:FFF0; {0 H! k% \0 Q8 h( V
F000:FFF0 EA5BE000F0 JMP F000:E05B
( s0 O& U9 Z) @; {1 qF000:FFF5 3130 XOR [BX+SI],SI
1 v7 `5 T7 { y8 S" ]/ M* `, }F000:FFF7 2F DAS
9 \! j, Q5 q. F: {9 J0 YF000:FFF8 3130 XOR [BX+SI],SI
# ?, p& j# R# u/ g, }* ?* VF000:FFFA 2F DAS8 o6 f" ?: |/ z; L6 `& [+ o
F000:FFFB 3037 XOR [BX],DH6 J3 Y9 t( q& j/ E
F000:FFFD 00FC ADD AH,BH
v+ `2 v. @8 x4 n2 F7 a* kF000:FFFF 57 PUSH DI
8 N5 X3 z# U# g: u. x: ? V, @' Y1 M
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.% X& h9 I7 a3 H' v8 U
8 l6 M) Z0 R. _8 T1 U
试一下,% M" P/ }, R" D- B
-G=F000:FFF0% N5 a: A& {- V' T
看看会什么样 5 B6 A3 i1 _1 j# e9 S+ Y3 C H. v
- @5 _% Q+ I6 A1 r# X& a以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
' O0 v6 F( l: v$ l$ y$ K6 m" V+ m
* O* w1 f* T; N 我们可以以多种方式来对8086寻址, 下面列出的是常的:
`) `' h5 v4 o) g5 v
7 K9 D& X4 Q/ W4 o( x. Y- h MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
- Q* t1 |- J7 i) q MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
$ B) q' k; h5 n. R X1 v MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
6 @7 l8 b1 |" b: F# m ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
0 ?4 T" m; J6 N$ J6 k MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存2 ]. Z A6 |! Q, |8 Z* U2 D' b3 d
" U; T! X* L* Q2 `- x; u" L JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
5 z& t5 w8 L4 I) T5 N+ o JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678
5 d" o% p- X* T" M5 S JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变" ~/ C2 i4 _7 N5 q* ~2 {: b
JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变- M9 F" ?* M4 u: a. d
JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2], K1 @5 p7 a5 v) q1 R
. _; w! f, P) h' @; m- }6 O知道了什么寻址,我们来试试, 同样,运行Debug, ' E' X1 d7 P' a, X# z
=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.4 F, ~, r& w+ {* t4 J; P- I
$ ^1 f3 A8 z1 s/ U看看什么现象再说.8 S& ]+ M2 T3 i- t' z' Q
2 l% S2 N4 F: B/ |& N+ F, e
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
. t7 }6 g* h( Z6 z& p 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
& y1 Y8 s# T/ ] B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF/ ?6 [1 A7 h: e4 Y; t% i. L
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务, I H6 N) Q2 b4 ?. H. a
; `' E+ ~/ P q$ E* e# u 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!, s6 N* d9 E4 Q! v& c8 _7 [
-D 0:400) T+ W& x, [, f( q
0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...3 N) l# q0 ]: `, p3 Y1 q
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0./ C% I6 B4 t! T% }# x% G1 G" e9 [* i* b
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
, r4 {. y- u+ J" Z6 ]) J0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...- {+ }1 R3 d7 F, U" I! R0 J7 v
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...% t7 c$ g' P# {
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............& J" n2 l) Q. Q3 ~
0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........; s( f- V5 D" d- H2 T8 k
0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................
! V& f" t) T( O8 A8 o# @6 f, q& [/ V/ F8 l
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
+ Y: W5 [+ i, o5 O .... |
|