本文乃fireaxe原创,使用GPL发布,可以自由拷贝,转载。但转载请保持文档的完整性,并注明原作者及原链接,严禁用于任何商业用途。
作者:fireaxe_hq@hotmail.com
博客:fireaxe.blog.chinaunix.net
今天终于实现了由汇编进入c程序,由于C程序都是在32位模式下操作的,所以需要由汇编中进入保护模式,然后才能进入C程序。保护模式下与实模式有一点不同,要注意个段的属性。
实模式下段地址设置:
mov ax, cs
mov ds, ax
mov ss, ax
mov es, ax
mov sp, 01000h
保护模式下段地址设置:
mov eax, SelectorStack
mov ds, eax
mov ss, eax
mov es, eax
mov sp, 01000h
实模式中可以用代码段寄存器cs来设置堆栈、数据等段寄存器;保护模式中断寄存器是设置了代码段属性的(DA_C + DA_32),所以只能用用于代码段,堆栈、数据段等需要进行数据操作的段,必须设置其他GDT段(属性为DA_DRW)。
阅读(3664) | 评论(0) | 转发(1) |