`
yesjavame
  • 浏览: 679370 次
  • 性别: Icon_minigender_2
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

Windows的保护模式

阅读更多
Windows的保护模式
  
  孙喜明

一般来说,80x86(80386及其以后的各代CPU)可以在三种模式下运转:实模式,保护模式,V86模式。实模式就是古老的MS-DOS的运行环境。Win95只利用了两种模式:保护模式和V86模式。

为什么要进入保护模式

保护模式有许多优越性。其中最最直接的好处就是:你的程序可以利用更多的内存了!

不要以为这是什么大不了的问题,我相信每一个曾在MS-DOS下写程序的人都有一个苦恼:怎样在程序中开个足够大的数组?动不动就会堆栈溢出,许多事都不能做了。不要怨Turbo C、MS Fortran、Turbo Pascal,它们也是心有余而力不足。这些烦恼都源自“你的程序是运行在实模式下的”。运行在实模式下的16位程序最多只能存取1M的内存。你也许会问:我的机器上不是有64M内存吗?是啊,如果说你是在MS-DOS下运行程序(或者说CPU运转在实模式下),那你只利用了1M内存,其余的内存都“下岗”了,在这种情况下,你的386/486/586/PⅡ只相当于一个跑得快的8086。

但是保护模式给了我们一个惊喜。理论上,在保护模式下,CPU可以寻址4096M(即4GB)内存。这就是说,只需把你的程序编译成32位的可执行程序(当然得借助32位编译器),你就可以在程序中充分利用内存了,这样做的直接结果是:你可以不用再为堆栈溢出或开不出5000×5000的数组而吃不下饭了。

正是4GB内存存取的实现,使得操作系统有了更加智能化的物质基础,多任务的实现才可以提到日程上来考虑了。

再深入一些

从硬件结构上说,386由三个寄存器CR0、CR1、CR2控制着CPU的运转。比如说,CR0的第0位就是用来判断当前CPU是工作在保护模式还是实模式下。学过8088/8086汇编语言的人一定熟悉AX、BX、CX、DX、SI、DI、SP、BP这些16位的寄存器,在80386中,这些寄存器被扩展到了32位,即EAX、EBX、ECX、EDX、ESI、EDI、ESP、EBP,如果CPU是运转在实模式下,那你只能利用这些32位寄存器的前16位,而后面的16位就浪费了。

段的概念是我们理解保护模式的关键所在。在实模式下,段寄存器中存放着16位的段地址,这时,段地址是参与寻址的:把段地址左移4位,加上偏移地址,就是20位的物理地址了。在保护模式下,段寄存器中存放着16位的段选择器(Segment Selector),这个值是不直接参与寻址的,而只是一个指向段描述表(Segment Descriptor Table)的索引。段描述表(Segment Descriptor Table)中存放着段描述符(Segment Descriptor)。段描述符中有关于段的描述,比如:段在内存中的位置、段的大小、段的类型(是数据段还是代码段)等等。

当CPU运行在保护模式下时,内存中往往有至少三张段描述表:全局描述表(Global Descriptor Table,简称GDT)、局部描述表(Local Descriptor,简称LDT)、中断描述表(Interrupt Descriptor Table,简称IDT)。说到这里,我想提醒读者注意:记住GDT、LDT、IDT这三个词的含义,我们在后面会经常用到。

段描述表不可能超过64K(为什么?如果回答不上来,那就再看看前面的讲解),每个段描述符(也就是段描述表中的一项)都是8byte长,所以说,每个段描述表最多只能包含8192个段描述符。

在今后的“走进VxD世界”中,我们将对段描述表、段描述符以及分页机制作进一步的讲解。

分享到:
评论

相关推荐

    windows 保护模式编程

    《Windows 保护模式编程》是一本深入探讨操作系统核心机制,特别是Windows系统中保护模式运作原理的书籍。在保护模式下,计算机系统能够提供更高级别的内存管理和安全性,这对于理解和优化软件性能至关重要。以下是...

    x86汇编语言 从实模式到保护模式.zip

    保护模式的引入为现代操作系统提供了基础,例如Windows和Linux等都基于此模式。它允许操作系统实现多任务、内存管理和硬件抽象,提高了系统的稳定性和安全性。此外,通过分页机制,保护模式还可以实现虚拟内存,使得...

    windows操作系统保护模式教程

    在深入探讨“Windows操作系统保护模式教程”之前,我们先理解一下保护模式的概念。保护模式是现代计算机操作系统中的一种内存管理方式,它与实地址模式相比,提供了更高级别的硬件安全性和资源管理。在Windows操作...

    x86汇编语言-从实模式到保护模式 配套源码及资料

    《x86汇编语言-从实模式到保护模式》是一本深入探讨x86架构汇编语言的经典著作,涵盖了从计算机启动时的实模式到引入内存管理和硬件保护的保护模式的转换过程。这本书的配套源码和资料是学习过程中不可或缺的辅助...

    x86汇编语言-从实模式到保护模式源码及工具

    实模式是8086处理器的初始工作模式,而保护模式则是现代操作系统如Windows和Linux的基础。这本书通过源码和实验工具,为读者提供了亲自动手实践的机会,从而更好地掌握汇编语言和系统编程。 汇编语言是计算机科学的...

    x86汇编语言从实模式到保护模式(完整版)更新过

    x86汇编语言从实模式到保护模式,包括后三章,网上大部分缺少后三章。文件太大包内是网盘地址和提取码。之前的过期,已更新。 <br/>《x86汇编语言:从实模式到保护模式》采用开源的NASM汇编语言编译器和...

    80x86保护模式教程

    - **操作系统开发**:例如Linux、Windows等现代操作系统都是在80x86的保护模式下运行的,利用其特性实现进程管理、内存分配等。 - **驱动程序编程**:驱动程序通常需要在Ring 0运行,需要理解并使用保护模式下的...

    很详细的保护模式编程

    ### 保护模式编程详解 #### 一、保护模式编程概览 保护模式编程是深入理解计算机系统的关键之一,尤其对于那些希望深入了解计算机底层操作的人来说至关重要。保护模式是现代x86架构处理器的一种运行模式,相较于...

    intel80x86保护模式

    **Intel 80x86保护模式详解** Intel 80x86系列处理器的保护模式是一种高级的执行模式,它允许系统实现多任务、内存保护以及虚拟内存等功能,极大地提升了计算机系统的安全性与效率。这一模式是现代操作系统如...

    80x86保护模式系列教程

    80x86保护模式被广泛应用于各种操作系统,如Windows、Linux和FreeBSD等。理解并掌握保护模式对于操作系统开发、驱动编写以及系统调试等领域都至关重要。 本系列教程《80x86保护模式》将详细解析这些概念,并通过...

    80X86保护模式编程

    文件列表中的"80X86保护模式编程.chm"、"80386.chm"和"aogo论坛精华.chm"可能包含了更深入的讲解和技术细节,而"Seen Win32 ASM.chm"和"汇编语言的艺术.rar"可能提供了Windows平台下汇编语言编程的实践案例和技巧。...

    保护模式下的80386及其编程

    - 在保护模式下,系统调用通常通过软件中断实现,例如Linux的sysenter指令或Windows的int 2e。这些调用允许用户程序安全地请求操作系统服务。 9. **保护模式的扩展** - 80386的保护模式为后续的处理器如 Pentium...

    Windows Vista核心技术系 列之十四:深入理解Windows Vista IE保护模式

    **深入理解Windows Vista IE保护模式** Windows Vista中的Internet Explorer(IE)保护模式是一项重要的安全特性,旨在提升浏览器的安全性,防止恶意软件和病毒通过网页活动对用户系统造成损害。这一特性是Windows ...

    x86汇编语言 从实模式到保护模式配全套属书工具及源代码

    保护模式则是现代操作系统如Windows和Linux的基础,引入了内存分页和段机制,实现了多任务和内存保护。在这个模式下,处理器能够管理多个独立的地址空间,每个进程有自己的视图,防止了一个进程误操作其他进程的内存...

    兼容Windows10 IE11增强保护模式的BHO

    http://blog.csdn.net/magictong/article/details/21280243),本文主要讨论的问题是Windows10 x86 & x64(是的x64也包含了)下BHO与IE11(增强保护模式开启)兼容的问题。 其方法和思路跟Windows8下是类似的,但是...

    x86汇编语言 从实模式到保护模式(17章)

    x86汇编语言从实模式到保护模式,包括后三章,网上大部分缺少后三章 《x86汇编语言:从实模式到保护模式》采用开源的NASM汇编语言编译器和VirtualBox虚拟机软件,以个人计算机广泛采用的Intel处理器为基础,详细讲解...

Global site tag (gtag.js) - Google Analytics