+ -
当前位置:首页 → 问答吧 → 请你们帮忙看看我写的“切换到保护方式”的代码对吗(nasm)

请你们帮忙看看我写的“切换到保护方式”的代码对吗(nasm)

时间:2011-11-23

来源:互联网


在代码中把cr0的第0位设置为1后,跟着的指令不是跳转而是以下两条指令,执行完这两条指令后才跳转。请问这样写可以吗?屏幕会显示"OK"吗?
mov es:[0],'O'
mov es:[2],'K' ;进入保护方式且显示"ok"



以下是我写的“切换到保护方式”的代码,是用nasm写的
%include "c:\pm.inc"
org 0100H


mov ax,cs
mov ds,ax
movzx eax,ax
shl eax,4
mov ebx,eax
mov ecx,eax
add eax,gdt
add ebx,code_a
add ecx,code_b
mov [gdtr_ptr+2],eax
lgdt [gdtr_ptr]
mov [gdt+10],bx
shr ebx,16
mov [gdt+12],bl
mov [gdt+15],bh
mov [gdt+18],cx
shr ecx,16
mov [gdt+20],cl
mov [gdt+23],ch ;初始化gdtr和代码段a,代码段b描述符


cli ;屏蔽外中断


in al 92h
or al,00000010b
out 92h,al ;开a20地址线


mov dx,0b800h
mov es,dx
mov eax,cr0
or eax,01h
mov cr0,eax 
mov es:[0],'O'
mov es:[2],'K' ;进入保护方式且显示"ok"


jmp dword 08h:0;进入保护方式后跳转到代码段a


gdt
descriptor 0,0,0;空描述符
;代码a
descriptor 0,code_a_long - 1,4098h
;32位存在只执行代码段
;代码b
descriptor 0,code_b_long - 1,4098h
;32位存在只执行代码段
;显示缓冲区段
descriptor b8000h, 0400h,92h
;存在的可读写数据段
gdt_long equ $-gdt


gdtr_ptr
dw gdt_long - 1
dd 0


code_a
mov ax,18h
mov es,ax
mov es:[80],'a'
jmp short $
code_a_long equ $-code_a


code_b
mov ax,18h
mov es,ax
mov es:[162],'b'
jmp short $
code_b_long equ $-code_b

作者: dkikviegg   发布时间: 2011-11-23

占个沙发

作者: awperpvip   发布时间: 2011-11-23