1

オペレーティング システムの動作を理解するために、プロテクト モードなどをテストするための小さなテスト アプリケーションをロードする simpel ブートローダーを作成しました。しかし、保護モードに入ろうとすると、システムが再起動します。誰でもこの問題を解決できますか?

これはセクション0x2000の私のコードです

    BITS 16

; Entering_ProtectedMode:   

    cli                                             
    mov ax, 2000h
    mov ss, ax                                      
    mov sp, 0FFFFh
    sti                                             
    cld                                             

    mov ax, 2000h                                   
    mov ds, ax                                      
    mov es, ax                                      
    mov fs, ax                                      
    mov gs, ax

    ;xor ax, ax
    ;mov ds, ax              ; update data segment

    cli                     ; clear interrupts

    lgdt [gdtr]             ; load GDT from GDTR (see gdt_32.inc)

    call OpenA20Gate        ; open the A20 gate 
    call EnablePMode        ; jumps to ProtectedMode

OpenA20Gate:
    in al, 0x93         ; switch A20 gate via fast A20 port 92
    or al, 2            ; set A20 Gate bit 1
    and al, ~1          ; clear INIT_NOW bit
    out 0x92, al
    ret

EnablePMode:
    mov eax, cr0
    or eax, 1
    mov cr0, eax
    jmp CODE_SEG : ProtectedMode

;*********************************
;* Global Descriptor Table (GDT) *
;*********************************
NULL_DESC:
    dd 0            ; null descriptor
    dd 0

CODE_DESC:
    dw 0xFFFF       ; limit low
    dw 0            ; base low
    db 0            ; base middle
    db 10011010b    ; access
    db 11001111b    ; granularity
    db 0            ; base high

DATA_DESC:
    dw 0xFFFF       ; limit low
    dw 0            ; base low
    db 0            ; base middle
    db 10010010b    ; access
    db 11001111b    ; granularity
    db 0            ; base high

gdtr:
    dw gdtr - NULL_DESC - 1 ; length of GDT
    dd NULL_DESC   ; base of GDT

CODE_SEG equ CODE_DESC - NULL_DESC
DATA_SEG equ DATA_DESC - NULL_DESC  

;******************
;* Protected Mode *
;******************
    BITS 32

ProtectedMode:

    .halt:
        jmp .halt

    ;mov     ax, 10h
    ;mov     ds, ax ; update data segment
4

1 に答える 1

1

これを試してください:

OpenA20Gate:
in al, 0x92; instead of 0x93; switch A20 gate via fast A20 port 92
or al, 2            ; set A20 Gate bit 1
and al, ~1          ; clear INIT_NOW bit
out 0x92, al
ret

EnablePMode:
mov eax, cr0
or eax, 1
mov cr0, eax

……

;CODE_SEG は、"8:ProtectedMode" のように 8 に等しくなければなりません。GDT の最初の記述子で 8 ポイント。16 ビット: 15-3 - GDT のインデックス (ゼロ記述子の場合は 0、最初の記述子の場合は 1 - コード、2 番目の記述子の場合は 2 - データ)、2 - テーブル インジケータ (GDT の場合は 0、LDT の場合は 1) )、1-0 - RPL (リクエスト特権レベル)。

jmp CODE_SEG:ProtectedMode
于 2015-05-11T05:16:19.263 に答える