|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
5 ?- c9 E- g J9 [. k4 o5 @9 j6 }* P今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! 6 Q7 B( R4 J9 @
$ j, S0 p8 v( J/ z# Z
8 u% B9 W) D. l* U% x) vBIOS入门之一: 8086模式
2 L% b, U# s# J' y" z1 A
+ J# V* |8 k/ f8 u2 m 我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
4 k+ F0 x. k+ z& K5 W - ?, p' `) K( |# r9 |0 Z( w4 E
先说一下目前的CPU的工作模式:
1 K; O. E6 `- B% [+ h: \% R) T1 \" x. y 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
7 ]6 o9 y, O; ~" U" Z) p" S 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
3 G1 t; }3 }1 h* o$ u# ~$ q 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....; q/ N$ A$ E( x" _
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
: b0 w: P! o- H8 g, u 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
7 ?2 G3 ~+ [6 ~
. N, h, Q! Z$ `5 s 今天说说Real Mode 8086 寻址模式:
3 D0 e- S2 ]' H% ^8 X- `
3 r0 [% p$ E3 ^: Z 8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 7 v; D1 K9 x8 y8 J
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,3 q- Q" U! z- M3 _
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.( m6 e3 U9 ~- ~4 S' i
, |" \3 @% Z, }( l ~
当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,; }$ f+ T( ] _! f' A; U' K
试试在DOS下运行Debug:
" J# L( [, Q1 p6 ~1 C: z1 [-u F000:FFF0( k$ \+ H. g! P
F000:FFF0 EA5BE000F0 JMP F000:E05B
7 Q7 K- ~; O. }1 t0 Y# Q. W/ g1 vF000:FFF5 3130 XOR [BX+SI],SI+ g, w- z# p1 }# ~; |
F000:FFF7 2F DAS
0 Y3 @: P. `7 V$ p. K @$ Z' }F000:FFF8 3130 XOR [BX+SI],SI- X, ]' E# T8 W$ |& ?
F000:FFFA 2F DAS
$ J; z4 f$ N8 `& s' MF000:FFFB 3037 XOR [BX],DH
; L2 r6 }; @1 |$ z2 zF000:FFFD 00FC ADD AH,BH1 u, _% s# D8 [3 U( C8 p% B
F000:FFFF 57 PUSH DI, D3 p: N; A) E
) t( @$ k" b* T' f/ V0 u对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
+ o# O7 G" x! b8 e$ L- r2 W+ ]% R
试一下,( H; s: P! D! U
-G=F000:FFF0( A8 E1 c/ f. r( f
看看会什么样 3 w' m9 l) M" {2 |' T1 T
, I/ e c# L8 I
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
" D) W, I! l" [7 A7 I" a$ P! C. w+ v/ r( V. k
我们可以以多种方式来对8086寻址, 下面列出的是常的:0 ]) B( D0 }* \! F/ A; S( _
2 C& [3 d) t4 g' r) |* { MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存1 W! w% Y" c* x/ p& h, a
MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
2 ~6 f- D5 l+ j- a9 d MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
$ F6 ^6 h9 {2 }, `3 `- S3 m' J ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS ?. H# O6 K( ]' Q4 h2 b( i% {' a* F
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存 a" T) }4 b3 B
1 e# ]$ t3 _- N8 x2 [( U JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
# N) ?& E5 @# }3 \: D JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678/ K2 ^# u" Q5 U9 t
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
/ C4 n" _) ?. Z$ u JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
9 R+ M* x( X% i9 T2 D* I+ y7 D JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]/ J3 x: n- {! t
: G; j) `/ z! P- ^
知道了什么寻址,我们来试试, 同样,运行Debug, $ } h1 C) i7 R1 N
=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.
4 s# r, n/ e$ A* |$ e& P, T% i$ _5 }: Y" j; V; U' A4 c7 D, Y
看看什么现象再说.: |% b1 Q% d# B$ K: l, P
2 N0 e! O' d2 o0 T4 l- O 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
; N9 t" s$ G* D: H* | 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
/ G4 b" _5 q7 N, B% f% I B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF
# Z- G0 x& a3 g 一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务
" z: A& i# J8 N0 M8 Y+ E ) N$ z% w4 b) @2 x) Q( \8 o
在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!3 c r" Q: l. |: g
-D 0:400
1 A% P. E7 X5 e6 U- |% S# n6 [3 c0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...3 Z; b, q# N; w2 g
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.
; X8 h. ^6 n, x/ `, S, l; o/ s9 s0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
' e0 T% _* R+ q5 c: p0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...- t# @+ x2 a! D3 Q; I# k9 v
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...8 R3 x( l' q/ ^
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............& R5 h% C/ U& L; b
0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
5 E' @. r0 G) m: O$ ~# _, f0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................
: u1 N# Z" ~- V: [7 f. X; p' t) k) y3 F# {' P
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
2 f/ ^' [. ^1 O/ Q8 {7 Q% t .... |
|