|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
3 y$ z9 Z( F! ~& W5 M9 N# W) Q今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! 2 M# O I& y: J) `0 {0 G
* l0 N# M& v: {) l5 r7 R9 d
, M% X4 o; T* ~6 _; c9 HBIOS入门之一: 8086模式
3 A/ ?8 ~& o$ d4 G; x( R \1 K3 }, c$ V7 C3 _/ j. M, I# W
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写. A N& D$ U I; U2 \6 ]7 j+ e/ }3 ~
1 a" Z. E# ^# c2 b
先说一下目前的CPU的工作模式:
1 h. h3 U1 ?. x7 @. o 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样." a5 F2 G! o3 g& S
2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
& F6 d: w- s8 z7 n6 k 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
% k) M! s) K% Y: p/ m& S# B 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇.... g' r2 A$ h3 \: c
4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
) D5 C; H0 o* X, q1 A * n3 g. x$ R: O, h! R" {
今天说说Real Mode 8086 寻址模式:& a9 x& f4 Y8 X1 d3 i
0 b, z- }/ M+ ` { _; l8 u
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移
+ i+ E4 ~9 y% l+ Y' X1 K 段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,
" R/ i' y$ M7 {+ z9 f 寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
$ n8 v J8 H$ u/ {& N3 K, ~- @" U0 e8 H
1 g% G" I! X: u2 u m4 f 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,9 G3 b3 r5 r2 W9 ~) Y" B
试试在DOS下运行Debug:
& {$ O: [& M5 M: }-u F000:FFF0
6 H/ H. k% C$ m& y# U1 XF000:FFF0 EA5BE000F0 JMP F000:E05B h% G0 I5 |0 v; k
F000:FFF5 3130 XOR [BX+SI],SI Y% J7 ]' P; \
F000:FFF7 2F DAS/ j5 C! w: e9 z/ K
F000:FFF8 3130 XOR [BX+SI],SI
5 M Z( l/ z4 {0 tF000:FFFA 2F DAS9 u) s9 D; ]# A# _% Y# P
F000:FFFB 3037 XOR [BX],DH
& n# q6 A$ |/ {0 m) X* m2 L+ KF000:FFFD 00FC ADD AH,BH
. m1 y \; ^) m; x( NF000:FFFF 57 PUSH DI
3 w# D, C3 r: a3 [7 I: r$ s* \/ [2 `: n
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.7 a/ J1 h- Z: q3 {$ m$ \% I
9 k- `& {$ `6 m; R* ^% N, Y
试一下,1 C. _- @) U/ n$ `
-G=F000:FFF0" T9 `# s* ~: s" B* T
看看会什么样 ' }: O7 f5 u. ^) ]5 s
# {" h6 x5 \9 s$ L
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
/ d: _1 l8 p/ B' t; h0 S1 m8 [ Z6 J0 f& H0 n! Z
我们可以以多种方式来对8086寻址, 下面列出的是常的:5 W# b) V& K$ n) o5 A* [# ?
* C: T/ W- m5 |0 y. W" K/ [. G1 b' e MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存* s( }8 E1 o C" \* ?
MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存* g, m% H& F- n. ~+ g9 a0 y/ H( o6 |
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存, 4 {3 v/ f- N- H$ L8 d! N2 h3 m
;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS2 |" | x1 I. d+ n8 ^
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存$ \3 W4 G/ V( |8 r
" |7 ?2 J0 E. y- V
JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变6 U) E, R& e! A, I1 v
JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678 A7 y0 h: Q. t. [. N" K" t4 [
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变- T( T7 w1 d$ o- E
JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
! U, [$ A$ y& P3 b b& c JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]4 j4 K& ? T. s8 w" q' C
: ^$ U! s& H6 m8 S1 n知道了什么寻址,我们来试试, 同样,运行Debug,
2 i+ D4 x( Q/ j8 c$ h=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.7 r/ H& X* k7 Z' c3 Q
4 @3 K% v, e7 n看看什么现象再说.6 i. V1 m# y& ~
% a4 h. @( e0 [+ ]
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
, H. I7 v9 D! D) b 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
% ?4 N [8 ?7 c+ @" @, n: m B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF! d' R5 Z r I6 z$ `8 E& t( R+ Q
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务2 h" g- U8 F3 y! A
/ l5 s7 b L0 d- [9 { 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!
% U" M! X1 e8 @3 T) ^2 R0 l, e9 w -D 0:400
4 D: N# y9 u1 j( h M# M/ g) l) M0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
: M3 g4 o4 I) b2 O0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.
: Z; \9 I. I g4 [( _0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...# z- }5 V6 ^3 u& q8 ~; Z
0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...
1 ]8 T1 D3 ]* a/ L0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
+ W8 }( p% O' y# \ @0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............- b4 b A5 g: }! @5 j% U) A" {. ?
0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
0 i M+ J9 f8 W! _2 o0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................# P3 f4 c7 U6 s( k3 O3 B Q7 |
$ \: |4 |& b3 v! ]* i5 x) j
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
# j7 ]5 e* t! i4 q/ u) X .... |
|