|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
% H5 w5 i/ b0 ~' h2 y今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创!
! y$ E. A' v6 Z/ B n" d3 s
0 S) a% r/ z6 ?* a
. ^/ V1 n0 `0 O* U+ K2 gBIOS入门之一: 8086模式* b9 Q5 Z- f+ h/ k
1 d4 V5 G6 S) F6 k6 D 我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
' b, u2 L6 R. j- m" V' v 2 s7 O: h S5 C0 t: ~
先说一下目前的CPU的工作模式:
/ y4 v8 `# K$ e2 ?! S7 j7 M 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
: j7 ]# ?: W0 w# R F! ?7 \ 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
; C! I V- w+ d6 c" e 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....
% ~3 Z0 A4 _: h2 k1 R 3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
& V& e. D0 J4 n5 [ 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...& S( {5 T3 W1 U1 E3 O, \* \9 v( Q* y
( b. k. F* V6 S% C6 q6 D 今天说说Real Mode 8086 寻址模式:5 f, t# U7 I9 L2 @3 O; B6 t
& l6 b9 [/ f1 U v
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 " L# [# j/ l/ X( O1 U
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址," q- I4 r5 j g' D5 n, v& O7 {3 c
寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
" o# J" r7 m! C6 d/ `, J, \
J$ b( p* ]7 z8 ~! \4 G 当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,
0 c& t9 A( Y0 y& a% Q 试试在DOS下运行Debug:
$ U2 L0 M# A. c# [: R( I1 r. L-u F000:FFF09 x; j, ~$ s1 G! z( C* k+ `0 l
F000:FFF0 EA5BE000F0 JMP F000:E05B
# _7 t; v1 X# R/ xF000:FFF5 3130 XOR [BX+SI],SI0 O! s, H- T7 v1 X+ y$ t; ?4 s
F000:FFF7 2F DAS3 {3 _9 ^+ Z5 ]' I0 d- p
F000:FFF8 3130 XOR [BX+SI],SI
/ u" X/ e' L5 n( n2 k6 yF000:FFFA 2F DAS9 V) y, C5 L: M8 R! k
F000:FFFB 3037 XOR [BX],DH
* [8 Q) s+ c1 b: |6 e& JF000:FFFD 00FC ADD AH,BH
. ]- y O' J/ h: ~1 \. E1 FF000:FFFF 57 PUSH DI
: F# V& g! K. e) R
7 m3 i0 {3 J; R+ \6 N+ \' e" D$ V对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.2 ^' h/ |% D# `" L( n- i' e0 s3 g
+ c9 g2 Z! r! ^: {0 |0 X
试一下,0 Y: o( ]5 |0 V4 l& ~
-G=F000:FFF0
3 A8 ]( O4 P7 T9 e& O% G看看会什么样
2 R9 R+ V0 \. f7 C i" [1 ^7 A4 {* B6 O0 {. u3 I
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..; L- g y, X+ q$ r0 P1 w. K. a3 Q g
- d# j" [. P; n' Q/ y( U* @
我们可以以多种方式来对8086寻址, 下面列出的是常的:
* H3 G I# G! C/ k& a+ r* H2 p
" w0 T4 P/ l2 s. @4 Q9 p8 x MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
9 _9 ^ w$ b: e2 M3 Q- m: ` MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
+ Q6 b1 t" E/ N6 B5 } MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存,
0 V2 U3 I( u- N2 y! y ;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS4 O, H1 l; G) ^
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存$ W4 |5 U3 Q M& H
+ [8 Q" R& C5 ]2 |$ B# r5 O6 S JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
m# C* P" A1 f JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678* Z# |* V$ L8 [
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
5 j6 v4 Z/ o! H( t0 F8 u. x JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
" e6 X2 q# _& ~" |/ Q& q6 | JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
+ ?8 U3 w' W' W: f! n- M; s2 ^5 y. B
4 L6 o0 k3 F2 x* H( `知道了什么寻址,我们来试试, 同样,运行Debug,
. R Q, d# L% a9 O; o=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟. C+ V) v' X9 j6 @
0 T P6 q. w+ U/ m- Z看看什么现象再说.2 X: A+ ]* |: }- Q- R
! u( M0 O3 U+ h' E0 F8 g 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了, ! N! M/ g# L: ]; h' C) \1 L9 g
经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
, p1 t$ ~0 d! c6 D1 l4 Z B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF2 V) [' c" N) Y% I
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务+ x! K$ O8 b. ~5 n5 c
: D$ e. ?7 u1 ]" F- \2 ? 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!: s+ I$ |( A; R" \( I3 C4 y) z Y1 A& c
-D 0:400+ C4 e+ t: E# x& `
0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...2 h, R/ O' |- y& E) \
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.6 F5 J. z; l! V6 R
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
) G0 x$ t9 T) X5 y+ v' ]$ r4 Y% u0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...
$ \- K" h& M' l; k8 j0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...
( l5 c6 @9 l# z0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
! @& D9 \$ B H3 |+ o. L0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
S0 s3 P. `2 B- [1 k9 u0 E0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................# x5 j) T" e3 ]; Y
! g# L5 n4 d1 z. I7 f0 b1 b
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..& M, v* E% r9 }+ A& ?
.... |
|