|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
9 f: d2 L/ `4 ?5 x9 z! ?- ~今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创! 9 {% V" W& E' e4 B& ?
: n$ r( {% t9 s3 P) G. l, w, O4 s3 v
BIOS入门之一: 8086模式% q0 c9 f- D/ ?: G% _
6 `8 Y! U; ` D& Y 我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.
' w# y$ k, p% w; q
6 `3 E- u8 K; d) a' T 先说一下目前的CPU的工作模式:
3 y# y( \8 }, @; l 1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
" |9 U2 D/ o2 A2 l& c. W. d 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
2 {: C/ V! L6 R2 R) I 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到..... s/ P6 X) X% `( k8 u
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...
0 P' r5 C, s- C; @1 x) F, g- e 4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
, Z. a) J. p0 A" z! T , \9 @0 ]% `7 X$ Q% j( ]0 @1 _2 O
今天说说Real Mode 8086 寻址模式:5 N) u- z7 S2 ?
( O! e9 m( h" F. A V 8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 3 m# n0 |$ [7 R( P+ P5 B
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,
: s) S. i7 e- T( M4 | 寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.4 h, L8 ?7 ~' H1 j
" X9 D9 n& i4 G6 H9 C
当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,4 o5 L1 e, ^. V- m6 s1 ]+ r
试试在DOS下运行Debug:
* k7 Y! A% j: p. p3 T-u F000:FFF07 l% O# e q0 a" m- Y/ z
F000:FFF0 EA5BE000F0 JMP F000:E05B/ |5 Q8 d8 C7 n* m' k
F000:FFF5 3130 XOR [BX+SI],SI2 q/ O5 C( i$ a
F000:FFF7 2F DAS
8 ~8 B& G% t7 g/ n% b: }# }F000:FFF8 3130 XOR [BX+SI],SI1 E. E$ c5 G- u: e* Q* u3 r& V6 m
F000:FFFA 2F DAS) C0 z$ g' k2 q/ ^ M* z
F000:FFFB 3037 XOR [BX],DH5 ]# |' e9 F; q6 \8 }2 Q; S
F000:FFFD 00FC ADD AH,BH
1 l+ ^8 n, H5 i; e! r' l+ ?F000:FFFF 57 PUSH DI
$ K$ ?0 M( T) z ?* m! \- K5 K6 m7 D' s3 h, L, V
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.
7 N/ k8 }7 }7 ?% t& z2 [% e' O6 q( ^! D7 U0 T. r
试一下,: s4 ~$ P2 D( k% i
-G=F000:FFF0
/ Z, }, q: `; T) A& G看看会什么样 6 O3 c! o2 g& I4 A
# u( }, G6 b( C$ r$ H
以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
+ h3 @) F7 |. u- e6 c! u! n+ e
, Q% b7 r- r2 M# Q: S$ l; f1 |9 h2 G 我们可以以多种方式来对8086寻址, 下面列出的是常的:: j1 M7 O8 ]( i$ g' Y# Z& E5 [# l
6 K( H5 J! c1 E' @$ @0 X MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
( B E5 C" J& ^( V$ H3 h6 L7 d6 [ MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
- Y6 q7 X' {; ]! R: B( `# M MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存, $ b! h. y% |) ?: ]2 o' l* Y
;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS
4 J# F" r3 w2 [* s U9 t MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存9 M6 U7 o1 A0 }! o1 z2 o7 N
0 v# a2 @$ E# n' Y JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变
- C& F+ O9 B) Q8 p JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678. n1 V$ u8 y5 [4 w" K" T) b
JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
% ?2 X# z4 P& _/ ~$ d1 X R0 d# B JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
0 p+ I H J4 j! v. \& z JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
/ q0 o* B' }& _+ q! @' E; G
* H" s0 g" l) t y. r! |8 O知道了什么寻址,我们来试试, 同样,运行Debug,
7 w8 D, w9 i6 S" X2 v) g6 |* Z! h=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.
' x: f P2 C( x: I2 t4 B" w0 r& O5 F# j; F' x/ c7 l+ A. g
看看什么现象再说.
: o7 `" I$ Q. u. K R( o+ D' D3 R6 j5 l/ Z2 D
现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
; z% v' b3 S& ^2 B: D 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填% P. @( U$ \6 V0 M* l3 ^
B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF W! q; w3 @( _' d, ^8 ]
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务 v4 ~- a S8 ?8 A
+ l5 m5 \2 y! ^. T! W 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!, n4 P2 V6 d0 c& j
-D 0:400
+ ? A! Z1 w. F0 c$ s2 P, }0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...7 T0 {7 f0 D2 N- d( i4 P6 ~
0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.! ~+ i% s2 U8 y. u" c _, O
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...* p. [8 Q$ A: k
0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...0 |" d% h* F) s& q
0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...5 e* n' r3 {$ u) p! G, M; i5 @! x6 H
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
S: G+ g; s% Y( u C. N5 R0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
9 V. y, R& W m7 _8 P ]! z0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................5 h3 \; P) X- ^% Z+ f! G0 a, A* k& M6 X
; i8 B; r0 T7 u" y% v5 W( t
第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址.., V- e8 _5 i% u! E+ e+ C: W+ w+ m
.... |
|