十、实模式和保护模式简介
2013-10-22 14:45
288 查看
1. 纯DOS的实模式:
a. 背景是DOS特别简单,没有能力对硬件系统进行全面、严格地管理,因此对用户的一些非法操作将不会检查到,从而这些非法操作可能会导致系统崩溃;
b. 因此在DOS系统中用户可以毫无顾虑地对硬件进行操作,而不受到操作系统的限制;
c. 这就是实模式;
d. 如果在实模式下用户非法修改了DOS系统在内存中的空间可能会直接导致系统崩溃;
2. CPU保护模式:
a. 在8086CPU之后基本上都提供了CPU的保护模式,即可以限制用户的一些操作,而保证操作系统的安全;
b. 对于现代操作系统比如Unix、Windows系列等都利用了CPU的保护模式,对硬件系统进行严格地管理,使得硬件系统对用户来说是屏蔽的,用户只能看到操作系统,但是不能接触到硬件系统,硬件系统(即所有的硬件资源)都被操作系统管理着;
c. 因此在保护模式下非法访问操作系统或者其它应用程序或者是硬件在内存中的空间将会被视为非法,而被强制踢出或者终止你的行为;
d. 因此在保护模式中想要用汇编语言去真实地操作硬件系统是完全不可能的;
3. DOS中的安全空间:一般在DOS中0:200~0:2FF中的256个字节是空白的,可以用在Debug中用D命令查看(值都是0),因此可以放心地使用;
4. 程序示例:将FFFF:0~FFFF:B中的数据复制到0:200~0:20B中:
可以逐个字节复制:
注:使用两个段寄存器,并且运用段前缀访问内存的方式,可以使程序得到大大的简化,而不必使用一个段寄存器做两次中转来表示两个需要进行数据交换的段基地址了;
5. 程序示例:将0:200~0:23F中的字节单元依次赋值为0~3F:
使用栈的做法:
a. 背景是DOS特别简单,没有能力对硬件系统进行全面、严格地管理,因此对用户的一些非法操作将不会检查到,从而这些非法操作可能会导致系统崩溃;
b. 因此在DOS系统中用户可以毫无顾虑地对硬件进行操作,而不受到操作系统的限制;
c. 这就是实模式;
d. 如果在实模式下用户非法修改了DOS系统在内存中的空间可能会直接导致系统崩溃;
2. CPU保护模式:
a. 在8086CPU之后基本上都提供了CPU的保护模式,即可以限制用户的一些操作,而保证操作系统的安全;
b. 对于现代操作系统比如Unix、Windows系列等都利用了CPU的保护模式,对硬件系统进行严格地管理,使得硬件系统对用户来说是屏蔽的,用户只能看到操作系统,但是不能接触到硬件系统,硬件系统(即所有的硬件资源)都被操作系统管理着;
c. 因此在保护模式下非法访问操作系统或者其它应用程序或者是硬件在内存中的空间将会被视为非法,而被强制踢出或者终止你的行为;
d. 因此在保护模式中想要用汇编语言去真实地操作硬件系统是完全不可能的;
3. DOS中的安全空间:一般在DOS中0:200~0:2FF中的256个字节是空白的,可以用在Debug中用D命令查看(值都是0),因此可以放心地使用;
4. 程序示例:将FFFF:0~FFFF:B中的数据复制到0:200~0:20B中:
可以逐个字节复制:
assume cs:codesg codesg segment mov ax, 0ffffh mov ds, ax mov ax, 20h mov es, ax mov bx, 0 mov cx, 0ch s: mov al, [bx] mov es:[bx], al inc bx loop s mov ax, 4c00h int 21h codesg ends end
注:使用两个段寄存器,并且运用段前缀访问内存的方式,可以使程序得到大大的简化,而不必使用一个段寄存器做两次中转来表示两个需要进行数据交换的段基地址了;
5. 程序示例:将0:200~0:23F中的字节单元依次赋值为0~3F:
assume cs:codesg codesg segment mov ax, 20h mov ds, ax mov bx, 0 ;地址必须是16位的,因此无法使用bl等与8位数据适配,而只能用16位寄存器 mov cx, 40h s: mov [bx], bl ;此句很巧妙,由于64个数据没有超过8位,因此bx的第8位的数据仍然正确 inc bx loop s mov ax, 4c00h int 21h codesg ends end
使用栈的做法:
assume cs:codesg codesg segment mov ax, 20h mov ss, ax mov sp, 40h mov ax, 3f3eh mov cx, 32 s: push ax sub ax, 202h loop s mov ax, 4c00h int 21h codesg ends end
相关文章推荐
- x86实模式到保护模式及Linux启动协议的演变
- 什么是实模式,平面模式,保护模式(指操作系统)
- 段寄存器在实模式下和保护模式下的作用有什么不同
- Linux-0.11 实模式到保护模式
- 保护模式和实模式
- 什么是实模式、保护模式和虚拟8086方式
- 保护模式和实模式对比
- 保护模式简介
- 保护模式和实模式
- 自己动手写操作系统 实模式到保护模式 GDT表
- [系列]OS学习-自己写操作系统(3)- 实模式到保护模式的跳转
- 保护模式下,读写大地址内存 & 从32位保护模式跳回16位实模式
- 实模式切换到保护模式,为什么要开启A20地址线(系统升级产生的兼容性问题)
- 386实模式转保护模式那点事(1)
- CPU 实模式 保护模式
- 驱动程序9--实模式,保护模式,虚拟8086模式
- 寻访x86处理器“实模式”和“保护模式”的前世今生
- CPU 实模式 保护模式 和虚拟8086模式
- 寻访x86处理器“实模式”和“保护模式”的前世今生
- 实模式、保护模式的区别 实模式保护模式切换方法