|
|
要成为一个真正的BIOS工程师,最基本的必需熟悉整个80X86体系,PCI规范,ACPI规范,如果对PCIE,VESA,SATA,USB,ISA,PNP,AGP等均全面深入,那你应该是一个真正的高手了.
2 _4 `+ _7 d- G今天开始, 本人班门弄斧, 不定期写一些基本的计算机体系方面的知识, 希望对刚刚踏入BIOS这一领域的同行有所帮助! 以下所有文字除特殊说明外, 所有的均属本人原创!
4 y- a. s' P* ?" N, `
8 i! Z1 U0 w9 N! l) R, S( |& C6 L6 E4 W: c
BIOS入门之一: 8086模式 V `9 X t+ [& i
8 b& B, W, K. U! L1 Q' [/ ]
我们目前几乎所有的计算机使用的都是 Intel X86 兼容的CPU体系, 至少你眼前现用的电脑就是, (当然,也有其它的, 如Apple使用的是另外的架构 , Intel最成功的CPU是8086的推出, 拥有20条地址线, 最大寻址为1MB, 之后再推出的一系列 186/286/386/486...为了兼容已经成形的计算机革命, 均向下支持所有的8086程序和 OS, 当然真成功的是80386的推出, 提供32位4GB的空间寻址,基于段方式的保护模式管理和先进的虚拟页管理, 之后再推出的都是基于80386架构, 只是增加了新的一些多媒体指令, 如MMX, SSE等, 当然, 其中, 不得不提到AMD所做的贡献... 越说越远了, 回到主题上来, 先了解一下8086的东西, 80386以后的东西会在下一篇文章中写.( T N" G$ B9 L2 a1 A5 A( b* L/ m
/ u) i6 ~( R" y" }6 j 先说一下目前的CPU的工作模式:$ b% ?) r/ \1 I% V. |
1. Real Mode (实模式): DOS系统就是在这个模式下运行的,也就是8086兼容模式,所有的操作与8086 CPU完全一样.
* ]& u8 x1 k* c) |( x+ j" _. Q 2. Protect Mode (保护模式):Windows系统就是在这个模式下运行的.等下一篇....
% k8 n4 z, P9 p1 L3 I 3. VM86 Mode (虚拟86模式):RealMode和ProectMode不能同时运行的,因此,在Porect下,可以在这个模式下运行基于16位的8086程序, 下下一篇会讲到....8 @6 l3 t; a& \1 z
3. SMM Mode (系统管理模式): 提供给 BIOS 最底层的 CPU 的一个管理模式,再等下一篇...8 R1 S* e4 O+ X
4. Long Mode : 64位 CPU的保护模式, 再再下一篇...
- k% J, x a2 X' V1 `) z. U3 y : [) u! {/ F9 Q& J+ w
今天说说Real Mode 8086 寻址模式:; @+ Q/ Y$ D z' a
! h, Y# i) T8 j
8086全是16位工作模式,为了访问整个1M空间,使用了<段:偏移>的方式来实现,目标地址=(段<<4)+偏移 ' t; U7 r8 J9 B* b1 @
段寄存器: CS, DS, ES, SS, FS, GS 来定位以16Byte为单位的基地址,
+ v4 O* H7 k( ]6 o 寄存器: AX, BX, CX, DX, SI, DI, BP, SP 则作为偏移.
( E: u3 ]5 J0 Q1 I' A( P 8 Y; v6 I) {" j4 h. a
当CPU上电后,CS=0F000h, IP=0FFF0h, 指向 0FFFF0h 也就是1MB - 10h Byte的地方, 最多只有16字节的空间,放不了什么代码了,因此,这里一般放的是一条 JMP 指令,
0 A6 D1 p; U% Z$ g# s2 r4 n 试试在DOS下运行Debug:& e" _7 q1 o) E0 }$ e# Z+ i
-u F000:FFF0
& f! j! y" o0 j! _; m, M5 dF000:FFF0 EA5BE000F0 JMP F000:E05B, b8 p" V0 ?! a7 @
F000:FFF5 3130 XOR [BX+SI],SI
3 H" {9 ]3 P4 N0 M4 ^1 p& O3 mF000:FFF7 2F DAS
, [/ ], T4 G4 i; k9 qF000:FFF8 3130 XOR [BX+SI],SI, c7 i& y/ r) s: i. Q& N
F000:FFFA 2F DAS( J# {! ~1 V& I, |! l
F000:FFFB 3037 XOR [BX],DH. V# r7 J7 [1 O8 e; T
F000:FFFD 00FC ADD AH,BH
9 s2 h0 y z) h8 AF000:FFFF 57 PUSH DI
) m B0 i! E$ J* H" h' q+ _( \- p9 \# F% i( r+ R( w
对于Award BIOS来说, F000:FFF0的指令一定是 JMP F000:E05B ,其它的厂商BIOS可能不是E05B.2 V' |+ o% a& m$ j
D5 x/ Z/ S9 T0 Q试一下,3 N1 [3 o4 N5 Q. r+ h+ _8 k
-G=F000:FFF0' T6 L$ z x5 P% A9 P
看看会什么样 # K* T& D5 H! e1 C% w# Z
& l$ t& ?; j3 m+ f& }以上的操作在真正的的DOS下运行,不要在Windows下的 DOS Command 下!!!那个是VM86 Mode..
C! u% f- _/ `" B- v# X# G$ X$ k# Y8 a
我们可以以多种方式来对8086寻址, 下面列出的是常的:( X8 W9 k2 u$ l' E3 |
/ g' S5 q/ ?. t9 R/ L" F
MOV ES:[SI], AX ;把AX的内容复制到 (ES<<4)+SI 地址所指向的内存
0 O4 E( P& q7 c C& S MOV DS:[SI+1234], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存
+ V; T# ]: ?8 d& R0 b5 m7 B MOV [SI], AX ;把AX的内容复制到 (DS<<4)+SI+1234 地址所指向的内存, ( s ^3 u! [' O! {9 |
;通常,没有指定段,则 SI 使用 DS, DI 使用 ES, SP/BP使用SS, n( h1 ]5 C+ [6 w; [/ s5 v
MOV CS:[1234] ;把AX的内容复制到 (CS<<4)+1234 地址所指向的内存. w6 E. _6 v* |; K0 K1 }6 N: ?" Q/ c
. V. T B t; E5 H* i. t) n9 m
JMP 1234h ;跳转到 CS:1234的地方, 之后 IP = 1234h, CS不变& \, A7 a& j9 A# K
JMP 5678:1234 ;跳转到 5678:1234的地方, 之后 IP = 1234h, CS = 5678
% ?# B/ @9 v# x, e) v! B2 Z0 |% K JMP BX ;跳转到 BX 指向的地方, 之后 IP = BX, CS不变
y. ^& d) V5 j& ]' i1 q8 K$ M- W JMP word ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS不变
7 }6 J$ R0 @( y4 n! X6 \4 s JMP dword ptr [BX] ;跳转到 DS:[BX]的内容指向的地方, 之后 IP=DS:[BX], CS=DS:[BX+2]
* c) u8 X6 v6 N! e; X/ \# l/ D: ]8 z
* T$ N2 F% O7 V) U( a( u3 }; M知道了什么寻址,我们来试试, 同样,运行Debug,
$ p/ j1 R4 B- `- L=F B800:0 1000 55 17 ;填充 B800:0, 填1000h个字节, 使用55, 17, 你别告诉我debug使用不熟.& A1 X! Q# t9 J' h
" I9 s: u- y! e看看什么现象再说.+ J: U' d7 P0 G$ O) o: ^
; n4 r8 b: L# E! y! |0 ]0 x3 K 现在你应该知道了 DOS 1M 的空间, 实际上有些区域是已经固定给一些硬件使用的了,
" B7 x( {, S1 E! T; M1 p5 l 经常提到的640K基本内存, 就是00000-9FFFF, 这部分是可用内存, A0000-BFFFF 给VGA显存使用, 而你刚才填
$ @) d* D) q) K2 y4 i B8000则是文本缓冲区, 向该地址写任何东西, 均会立即反应在显示器上(记得是在文本模式下), C0000-CFFFF0 w, V" \. b$ I9 I0 a
一般是给VGA BIOS占用, D0000-DFFFF给一些其它ROM使用, E0000-FFFFF一般给BIOS占用, 提供BIOS相关的服务: p" \5 o$ L" R
4 D) t O$ F' w9 q$ q' Y* W 在基本内存中, 0-3FF共256*4, 存放INT0~FF的入口地址, 400-4FF存放BIOS的数据, 看一下吧!& U8 z: j$ `( }1 y
-D 0:400
5 }% U2 N g- e, A, \0 ~7 z0000:0400 F8 03 F8 02 E8 03 E8 02-BC 03 78 03 78 02 80 9F ..........x.x...
% c3 ^! l: B0 |* p7 C0000:0410 23 C8 00 80 02 00 00 00-00 00 24 00 24 00 30 0B #.........$.$.0.% t7 b, t. H% x8 q& X) d8 b
0000:0420 30 0B 0D 1C 20 39 30 0B-3A 27 34 05 30 0B 0D 1C 0... 90.:'4.0...
8 u) M8 @$ E) p q0000:0430 44 20 20 39 34 05 08 0E-30 0B 3A 27 34 05 00 00 D 94...0.:'4...
% x! l6 I+ P( w' T0 ~4 v1 g0000:0440 E0 00 C3 00 00 00 00 00-4D 03 50 00 40 1F 00 00 ........M.P.@...2 ?2 G, d) p6 ?& _; |
0000:0450 00 31 00 00 00 00 00 00-00 00 00 00 00 00 00 00 .1..............
+ g! A: [# ~+ }4 y* P. N. ~, L0000:0460 07 06 00 D4 03 29 30 F6-03 00 F0 FF D1 C4 0C 00 .....)0.........
* X5 k3 f- P9 x' Z8 Z( b3 C0000:0470 00 00 00 00 00 00 00 00-14 14 14 14 01 01 01 01 ................* F9 k X E5 x$ Z6 Z- z
5 g) u0 C3 r1 R$ F- _ 第1,2,3,4个字:03F8, 02F8, 03E8, 02E8, 原来是COM1/COM2/COM3/COM4的地址..
/ q: x8 L* W# A1 u; ]2 G$ G x2 t .... |
|