第12章 存储器的保护
生活随笔
收集整理的這篇文章主要介紹了
第12章 存储器的保护
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
學習32位保護模式明顯感覺比16位實模式復雜一些,其實兩者之間所做的事情是一樣的,無非是對內存的各種操作,對棧的各種操作,但是手段不一樣,實模式是野蠻的,可以在任意地方讀寫(比如代碼區),保護模式比實模式要文明的多,增加了許多的保護手段和一些資源使用限制,就如同一個文明國家的規章制度一樣,初次讀起來費解難懂,因為這夾雜著歷史的演進。但是關鍵的地方就那幾點,明白了這幾點32位保護模式基本上就很輕松了。
1,全局描述符數據結構,段選擇子的數據結構,里面每個字段表示的含義(這個不用記憶,可以回頭再查);
2,GDT的加載過程;
3,32位尋址過程;
4,數據段,代碼段,棧段各自的保護措施;
書中的代碼不難,粘在下面:
;代碼清單12-1;文件名:c12_mbr.asm;文件說明:硬盤主引導扇區代碼 ;創建日期:2011-10-27 22:52;設置堆棧段和棧指針 mov eax,cs mov ss,eaxmov sp,0x7c00;計算GDT所在的邏輯段地址mov eax,[cs:pgdt+0x7c00+0x02] ;GDT的32位線性基地址 xor edx,edxmov ebx,16div ebx ;分解成16位邏輯地址 mov ds,eax ;令DS指向該段以進行操作mov ebx,edx ;段內起始偏移地址 ;創建0#描述符,它是空描述符,這是處理器的要求mov dword [ebx+0x00],0x00000000mov dword [ebx+0x04],0x00000000 ;創建1#描述符,這是一個數據段,對應0~4GB的線性地址空間mov dword [ebx+0x08],0x0000ffff ;基地址為0,段界限為0xfffffmov dword [ebx+0x0c],0x00cf9200 ;粒度為4KB,存儲器段描述符 ;創建保護模式下初始代碼段描述符mov dword [ebx+0x10],0x7c0001ff ;基地址為0x00007c00,512字節 mov dword [ebx+0x14],0x00409800 ;粒度為1個字節,代碼段描述符 ;創建以上代碼段的別名描述符mov dword [ebx+0x18],0x7c0001ff ;基地址為0x00007c00,512字節mov dword [ebx+0x1c],0x00409200 ;粒度為1個字節,數據段描述符mov dword [ebx+0x20],0x7c00fffemov dword [ebx+0x24],0x00cf9600;初始化描述符表寄存器GDTRmov word [cs: pgdt+0x7c00],39 ;描述符表的界限 lgdt [cs: pgdt+0x7c00]in al,0x92 ;南橋芯片內的端口 or al,0000_0010Bout 0x92,al ;打開A20cli ;中斷機制尚未工作mov eax,cr0or eax,1mov cr0,eax ;設置PE位;以下進入保護模式... ...jmp dword 0x0010:flush ;16位的描述符選擇子:32位偏移[bits 32] flush: mov eax,0x0018 mov ds,eaxmov eax,0x0008 ;加載數據段(0..4GB)選擇子mov es,eaxmov fs,eaxmov gs,eaxmov eax,0x0020 ;0000 0000 0010 0000mov ss,eaxxor esp,esp ;ESP <- 0mov dword [es:0x0b8000],0x072e0750 ;字符'P'、'.'及其顯示屬性mov dword [es:0x0b8004],0x072e074d ;字符'M'、'.'及其顯示屬性mov dword [es:0x0b8008],0x07200720 ;兩個空白字符及其顯示屬性mov dword [es:0x0b800c],0x076b076f ;字符'o'、'k'及其顯示屬性;開始冒泡排序 mov ecx,pgdt-string-1 ;遍歷次數=串長度-1 @@1:push ecx ;32位模式下的loop使用ecx xor bx,bx ;32位模式下,偏移量可以是16位,也可以 @@2: ;是后面的32位 mov ax,[string+bx] cmp ah,al ;ah中存放的是源字的高字節 jge @@3 xchg al,ah mov [string+bx],ax @@3:inc bx loop @@2 pop ecx loop @@1mov ecx,pgdt-stringxor ebx,ebx ;偏移地址是32位的情況 @@4: ;32位的偏移具有更大的靈活性mov ah,0x07mov al,[string+ebx]mov [es:0xb80a0+ebx*2],ax ;演示0~4GB尋址。inc ebxloop @@4hlt ;-------------------------------------------------------------------------------string db 's0ke4or92xap3fv8giuzjcy5l1m7hd6bnqtw.' ;-------------------------------------------------------------------------------pgdt dw 0dd 0x00007e00 ;GDT的物理地址 ;------------------------------------------------------------------------------- times 510-($-$$) db 0db 0x55,0xaa實驗現象:
總結
以上是生活随笔為你收集整理的第12章 存储器的保护的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: oracle18c卸载方法,在debia
- 下一篇: websphere jndi oracl