- 论坛徽章:
- 0
|
开启了,问题依旧。新的代码如下:
如果PAGE_DIR_ADDR=0x0,则运行正常;如果改为0x00100000,则在JMP $时,重启
;存储段描述符类型值说明
;----------------------------------------------------------------------------
ATDR equ 90h ;存在的只读数据段类型值
ATDW equ 92h ;存在的可读写数据段属性值
ATDWA equ 93h ;存在的已访问可读写数据段类型值
ATCE equ 98h ;存在的只执行代码段属性值
ATCER equ 9ah ;存在的可执行可读代码段属性值
ATCCO equ 9ch ;存在的只执行一致代码段属性值
ATCCOR equ 9eh ;存在的可执行可读一致代码段属性值
;----------------------------------------------------------------------------
;其它常量值说明
;----------------------------------------------------------------------------
GL equ 80h ;段界限以4K为单位标志
;----------------------------------------------------------------------------
;分页机制使用的常量说明
;----------------------------------------------------------------------------
PL equ 1 ;页存在属性位
RWR equ 0 ;R/W属性位值,读/执行
RWW equ 2 ;R/W属性位值,读/写/执行
USS equ 0 ;U/S属性位值,系统级
USU equ 4 ;U/S属性位值,用户级
PAGE_DIR_ADDR equ 0x00100000 ;U/S属性位值,用户级
segment a
desc_null:
dw 0;Segment Limite
dw 0;Segment Base(15...0)
db 0;Segment Base(23...16)
db 0;Attributes(m+5)[P DPL DT1 TYPE]
db 0;Attributes(m+6)[G D 0 AVL Limit(19...16)]
db 0;Base(31...24)
desc_code:
dw a_end;Segment Limite
dw 0;Segment Base(15...0)
db 0;Segment Base(23...16)
db ATCER;Attributes(m+5)[P DPL DT1 TYPE]
db 0;Attributes(m+6)[G D 0 AVL Limit(19...16)]
db 0;Base(31...24)
desc_data:
dw a_end;Segment Limite
dw 0;Segment Base(15...0)
db 0;Segment Base(23...16)
db ATDWA;Attributes(m+5)[P DPL DT1 TYPE]
db 0;Attributes(m+6)[G D 0 AVL Limit(19...16)]
db 0;Base(31...24)
desc_line:
dw 0xffff;Segment Limite
dw 0;Segment Base(15...0)
db 0;Segment Base(23...16)
db ATDWA;Attributes(m+5)[P DPL DT1 TYPE]
db 0xf + GL;Attributes(m+6)[G D 0 AVL Limit(19...16)]
db 0;Base(31...24)
sel_code equ desc_code - desc_null
sel_data equ desc_data - desc_null
sel_line equ desc_line - desc_null
vgdt:
dw 0xffff
dd 0
..start:
mov ax,a
mov ds,ax
mov bx,16
mul bx
mov [desc_code + 2],ax
mov [desc_data + 2],ax
mov [desc_code + 4],dl
mov [desc_data + 4],dl
mov [desc_code + 7],dh
mov [desc_data + 7],dh
mov [vgdt + 2],ax
mov [vgdt + 4],dx
;打开A20地址线
push ax
in al,92h
or al,00000010b
out 92h,al
pop ax
cli
lgdt [vgdt]
mov eax,cr0
or eax,1
mov cr0,eax
jmp sel_code:do
real:
mov ax,4c00h
int 21h
do:
;初始化页目录表
mov ax,sel_line
mov es,ax
;初始化两个页目录表
mov dword[es:dword PAGE_DIR_ADDR],PAGE_DIR_ADDR + 0x00001000 +USU+RWW+PL
;初始化第一个页目录表项的页表项
mov ax,sel_line
mov es,ax
mov edi,0x00101000
mov cx,1024
xor eax,eax
or eax,USU+RWW+PL
loop1: stosd
add eax,0x1000
loop loop1
;切换
mov eax,PAGE_DIR_ADDR
mov cr3,eax
mov eax,cr0
or eax,80000000h
mov cr0,eax
jmp $
a_end: |
|