|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了. # D8 A3 V5 G8 C4 [
今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创!
% \3 J- ~/ A# [( @: o' x7 g$ W/ S7 Y
' _1 h: v. u& ] M2 i1 E' b) v7 ~
BIOS入门之一: 8086模式) @7 p) z& U* L a. n
% p. g" N/ h6 k0 M+ z( F) S' ~2 z
我们目前几乎所有的计算机使用的都是 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 n. K- y4 }5 O5 z' T, b& f
; h" N1 [: u" F, N5 F! _ 先说一下目前的CPU的工作模式:
& F! W6 C; R; t o I q5 ~5 \ 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.! T' H8 P; N, U0 i* P* z* T) ~. z
2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....1 D$ p* S, j# Y0 V& |5 ]
3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....0 y; s4 u9 d/ z G. L( R
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...7 b) r5 @. i! z1 A$ W
4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
4 F+ F3 A9 ~, N& a7 i
2 N+ F* G0 J* e8 j 今天说说Real Mode 8086 寻址模式:
( H2 ?! U2 z2 L! y+ ]- D
4 u: u6 v ^! ?; h, b; @ 8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 9 F* ~- }, {! Q* ?
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址," {! G+ P$ ~, q* E& d! _4 R$ @
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
5 d' m, m: H8 f+ r y9 A" P( Z5 D 8 c! [/ X# p3 r) e
当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,9 p" |' t! u) x& y, P5 t+ x' w
试试在DOS下运行Debug:2 G' h& V$ I) s! i4 w; H1 L7 n' n
-u F000:FFF0
& K. H1 V1 X& Y$ `' H5 T1 kF000:FFF0 EA5BE000F0 JMP F000:E05B
5 C7 _4 R$ K: i3 sF000:FFF5 3130 XOR [BX+SI],SI8 \8 v& _+ l8 ], Y# q5 m3 i( k2 ~
F000:FFF7 2F DAS- ` O) J+ m7 f
F000:FFF8 3130 XOR [BX+SI],SI5 h+ X7 y. w. {# ^2 ~ F
F000:FFFA 2F DAS
+ C6 P \: n6 K. J6 E- {F000:FFFB 3037 XOR [BX],DH; Y' J' M; r& H1 n3 V- g
F000:FFFD 00FC ADD AH,BH
. e: S2 ?6 g# z; IF000:FFFF 57 PUSH DI
/ K! i# b' {6 F- t k8 c) G/ a0 ]; Q9 W k8 @
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
# s7 K" |: k7 Q" E4 u( P) R! O1 l: ~1 v5 y
试一下,, V5 P3 z; W- p! r1 S7 w! w
-G=F000:FFF0. a- t: x: A1 O$ a% R5 k0 m! R6 o# d
看看会什么样 & O' [7 x/ X: R Y
* |2 n0 @" o& j: ?- ~% G7 v以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..' R: S( i4 x% y3 J$ {
5 @- Y- d: K% P9 z+ S! f( \
我们可以以多种方式来对8086寻址, 下面列出的是常的:
. ~* I+ Y/ @" R: ]
& k& n% }' B9 n2 X7 v7 P$ S9 t MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
( a+ P4 |7 _' Q/ W# h MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存3 v' Q) O8 F3 v% s8 }
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
/ e p) S0 x$ g/ R0 r ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
/ j. X G# l+ J0 e2 @. {8 s MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存 c: E" E/ r* x( u) r
, }. m4 U8 M, t JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
# I2 @5 ]8 ^+ k9 z JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678
7 `1 r. m) s. z% B9 m JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
- h, C: X. f; S2 q$ C1 J' N JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变" O3 w! q- z4 k+ V& {
JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
9 d/ I: q7 B3 {: n* T
% R: j9 ?# f0 A8 d' k% f+ V0 | }/ y知道了什么寻址,我们来试试, 同样,运行Debug,
' m4 j4 h! Q) I=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.
& n6 S' I# p1 ?% S+ ?
- A- H( P0 E$ }0 w4 N; ~看看什么现象再说.
$ I, b( h0 o, y: y+ X1 W. j% } w. ~8 o [' q" {% U- ?
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了, " {4 Q6 V+ C8 z( z0 @
经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
* V' N% Q+ X: y9 c8 R t7 S B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF4 H$ T- A4 e d7 d0 o
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务0 i7 {( m- D- `( \% r6 v5 d
" p9 s; p) q& C3 Y 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!
- @3 \- Y- [+ B1 {6 `6 X E -D 0:400! i% K# }; E2 l; `
0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x.../ e- r8 E, e7 f0 _3 p& |- B% N
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.- U1 O ^, c# F! p8 V
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...% |+ N9 s" X7 [* B) f3 b' x
0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...9 h* A. S% P1 L- ?6 J# H) y3 k0 C
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
- _- M$ ^6 d% u [% h3 l; { r! X0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
; K% v2 b+ W P- K$ x5 G0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........: g3 f' s: W1 q1 q: x) f. u
0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................5 Z0 C2 W2 E5 R$ |1 l
! g5 |- K: J6 S4 W2 {, h9 v. t# A 第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..) P" L, { z0 A7 o+ Z
.... |
|