|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
9 N) L! j2 T# b/ d1 r6 [" l0 ^: w今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创!
# w/ k9 N7 R* y& R2 i. W; P. y" n4 M7 a9 s" n* f3 W+ E# P' V
" Z7 W! D& e# b r- l! G; v
BIOS入门之一: 8086模式* A ?, ]4 F* c
$ w5 x2 o8 }* x* q9 H, N# ^
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
; S+ Z8 m6 Y7 j9 K
- v, J# g% G [3 z* A b, A# } 先说一下目前的CPU的工作模式:( B4 N( }5 C' k
1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
! z$ ?5 h7 M7 e* m- R1 q9 |3 S4 O 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
8 D- L$ \! R7 R 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....% O- `" b; K: g/ |( L
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...! d7 }: Z2 G w
4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
8 }% j$ s3 u' e: A$ d $ S4 K7 Q9 ]& G$ {' r0 b8 `
今天说说Real Mode 8086 寻址模式:
7 T) y+ d' {6 L* @7 y) C3 e5 h, ~7 s- \
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 / [5 q% x/ U" L% ~0 \
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,% j$ C6 N& N- R9 b- V$ g
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.' e, s. y6 D* V! t% E3 X0 D: Y3 H
5 j) j& l3 N4 x! B 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,
; _! X7 Y2 I5 w* a3 p$ i# G4 v 试试在DOS下运行Debug:
% }* C& H& ?* O6 `-u F000:FFF0
' k) L) L2 X& T6 w) pF000:FFF0 EA5BE000F0 JMP F000:E05B
6 U# T* `1 N! { V% O5 ZF000:FFF5 3130 XOR [BX+SI],SI
5 s+ V8 N4 v" G' n) e4 j, RF000:FFF7 2F DAS& \$ {; ~( d6 v* w
F000:FFF8 3130 XOR [BX+SI],SI
+ d1 w1 e* b3 k% L VF000:FFFA 2F DAS; D$ [6 K/ d3 D8 B3 N+ L
F000:FFFB 3037 XOR [BX],DH j4 r8 |; w) B, g- m
F000:FFFD 00FC ADD AH,BH7 y* O, J$ z6 @& h" j
F000:FFFF 57 PUSH DI
; P" ?/ @$ Q, s( e/ y
; K! n7 ~( d( i8 f* c对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
; P& b& g$ n; K8 b" u; h. y& W8 @& w E
试一下,& Y, ?- L1 m, k G. {
-G=F000:FFF0
: d" D+ M' y) {! v. C' \ V看看会什么样
2 X1 X) u' [/ D7 p6 }/ j
! a% o! R& y5 U ]以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..% }2 [! ]1 b( d
7 n+ p1 N( ]! W 我们可以以多种方式来对8086寻址, 下面列出的是常的:
, `5 S3 q6 o; w* K8 K' Q8 N/ M7 ]/ f
9 C0 w" g7 o! u0 @7 P$ L MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
+ _- v# F+ z& q8 Y MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存* d0 ]; S1 G! S5 _
MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
! ]. ^( h1 `& M! ?3 s ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
9 v9 p% f$ x0 W; Y MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存) J A; G7 }# O5 k' @: a
" O) v7 G0 R( I( F# @( \: l) L7 k JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
; V" U- P5 G! G5 y JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678
8 f% Z$ v6 }. |$ d/ D# @ JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
0 B# s" ~/ Q/ r% c0 p( b% i! g JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变) \" l2 @' W( v% F% L
JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
% X5 _9 \ T6 e. L 9 Z$ W) Y% q# e6 f7 P5 k; v! L4 m
知道了什么寻址,我们来试试, 同样,运行Debug, ' Y3 U& Q- q$ o0 W9 w
=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.
* j6 l+ ]2 d, G f
% u4 U+ [$ m/ q3 J看看什么现象再说.
& F* r; x6 V/ x) T9 D3 a9 Q/ m2 f2 |3 M! K: L! I* Z" [$ a' T3 p
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
6 L6 C' O: q( A+ t) G( V5 X 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填6 X* K9 o: ~# j; @( D' J0 y, H
B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF9 W& T5 }' m8 p x' q
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务
9 _: r, v2 k9 ?: M: I9 m 4 F. s; h# g9 [3 X6 H/ w. i- n
在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!
0 I3 A% d4 l! x# z- X7 P+ _5 G -D 0:4001 g1 Z$ f B) `0 M+ O: Z9 p$ O
0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
1 f2 l6 g8 ?4 s8 b- r( G3 {/ H g0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.& c1 c) j7 g* Z/ F) B9 [6 ]
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
4 o1 E8 P. d, e0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...
' }/ y; p3 ~- ^0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...6 M! d8 g! T6 p$ g( v) b l
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
6 i6 k K* l2 M0 X, Y3 O: |4 V* O$ T0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
5 M f1 V; f' b* e0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................9 c; j' b/ ^4 H7 ~- v' k
7 r7 ?% \0 ^3 Y* S$ Q; a5 Y 第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
- a0 X: ?3 O( p5 W/ B& t$ ] P .... |
|