|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了. , K/ }. D" \( {1 s N
今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! p2 ]7 E3 \: e: c7 v
# B. N$ n! G% o5 K9 O9 f |! r
9 v$ h( K; y7 l: H! m! g7 ZBIOS入门之一: 8086模式
# B4 [2 _! D% O( `
1 y: o3 p' r, ] 我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构, Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
! w9 L# \, j6 |, b4 e+ m , t( V+ W# \" d; P+ h* z
先说一下目前的CPU的工作模式:. v7 A% g3 s9 `7 z
1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.& [ m* e4 ]" m2 Z# X( c ]
2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
" z' ]' W' T% o4 `5 M9 ~4 ~% ` 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
! G8 r8 V7 U# j# F 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...% a2 K; s$ s) @1 t4 Q: l
4. Long Mode : 64位 CPU的保护模式, 再再下一篇...2 C4 d: }$ u. a2 J; ~0 z
1 { [; D" h6 `- R3 |
今天说说Real Mode 8086 寻址模式:
; D- [0 Y# `) F( ?. J% E5 H3 V" [7 p
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 / q( w% @* s& P6 Y6 }$ J2 |
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址," ^. Q/ _7 u, p6 C/ ?( D
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
0 p {9 t9 Q; W6 C5 V, m; \
. T" r9 V" q- c" a$ G( }" i; M 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,
0 ]$ S1 N0 E! l2 L7 L3 |" X 试试在DOS下运行Debug:( ?3 U6 X8 V$ Y+ U5 T6 S
-u F000:FFF0) ]" w u. P H2 A; K
F000:FFF0 EA5BE000F0 JMP F000:E05B/ S, y D H, F7 f1 ^$ S, H
F000:FFF5 3130 XOR [BX+SI],SI
& e: g4 ]' s/ w5 |7 RF000:FFF7 2F DAS. ?* g" q$ W2 N/ R
F000:FFF8 3130 XOR [BX+SI],SI. N! w1 i6 E Z- f# x1 Y$ k& c
F000:FFFA 2F DAS, j6 Y# y! e% g! v# l: Z8 C
F000:FFFB 3037 XOR [BX],DH. [" L7 }6 R1 f: K0 m. K) F- f7 u# h8 H
F000:FFFD 00FC ADD AH,BH
8 H: i# s, Q; q5 Y( z* vF000:FFFF 57 PUSH DI$ H* ~1 {% t/ w. m$ B
# {1 I7 `" ~- A( M7 C
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
0 }$ ?3 T3 P5 s
6 o0 |- q9 a V& r) o6 h试一下,
T8 _( |% y/ u0 v" Z! ?" Y-G=F000:FFF0
: _* {$ P2 O. v/ d1 ^/ e3 @看看会什么样 7 W* Z8 }* W7 `9 k; d! B! p( N
! E/ j; n( x" t' }1 _0 v以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..: ^8 c7 d: v2 \$ C9 Y
. u- t' D4 l/ @9 X
我们可以以多种方式来对8086寻址, 下面列出的是常的:# o4 p* O. P3 [( I( j& }
! h7 D9 {5 Z; T" y MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存' K3 a8 j4 Q! l9 Z% Q, L( s( c
MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存" _9 H9 L$ a: Q: d
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
' ~$ Y* e3 C( G) I6 C5 M ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
. i4 y' @% E7 b0 v# N& G MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存
0 _. I3 V% [# S
D! `( W) g$ z JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
- a$ R* g$ X! c/ j JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678
" a& _; U2 t' z8 s4 k JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变6 U, C" k5 l% d* |6 B8 N% d! j2 K
JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
5 z- m1 [" w6 z, n0 C JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]+ f# d: S1 F, P; f6 D t
! k% X( B7 @( m0 p知道了什么寻址,我们来试试, 同样,运行Debug,
- H& g9 X/ b# ]4 g1 q=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.5 i8 ]) n% @: N' [4 l/ j: `) j
% n+ T0 ?# z, C看看什么现象再说.
! T9 S8 x. n: Q% m U8 a8 N
7 |0 h' d) R) t7 h! ` 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
+ W( ]( Q; w/ f& i) p7 O( k 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填4 A- [* G- q- @( N% c. i0 G
B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF
3 i4 q, J$ a( V7 v& K 一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务
! {, l; a6 o/ \" } $ A) G$ C: E+ R
在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!
4 P- q. |- j2 l9 U+ x -D 0:400
! w' g: F8 g( l2 J0 c0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
* X6 r/ b& b' a5 B! M% t0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.) B' W3 m% E+ i0 V6 k$ S
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0... b' N% V5 j* E
0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4..." p A" @% ?: O0 k
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...) L/ o, z# r7 G- v4 R: j9 d
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
0 ~" ?% p. b6 Q% U8 P% r, k0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
/ }/ h8 p8 a: M8 S3 |6 A* B0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................! w) `4 O* I/ I- b1 D) K
" D% k9 Q1 {: {9 Q$ Q$ Z
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
" j+ L- @* O2 P3 @ .... |
|