溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何搭建X86匯編調試環(huán)境

發(fā)布時間:2022-03-04 11:52:19 來源:億速云 閱讀:157 作者:小新 欄目:開發(fā)技術

這篇文章將為大家詳細講解有關如何搭建X86匯編調試環(huán)境,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

匯編環(huán)境搭建

本次使用vscode搭建的,需要的插件有X86 and X86_64 Assembly(也可以使用masm插件),還有一個hexdump for VSCode。
安裝NASM,并添加到環(huán)境變量
安裝QEMU,并將其添加到環(huán)境變量下

編寫代碼:(代碼來自30天自制操作系統(tǒng))

; hello-os
; TAB=4

; 標準FAT12格式軟盤專用的代碼 Stand FAT12 format floppy code

        DB      0xeb, 0x4e, 0x90
        DB      "HELLOIPL"      ; 啟動扇區(qū)名稱(8字節(jié))
        DW      512             ; 每個扇區(qū)(sector)大?。ū仨?12字節(jié))
        DB      1               ; 簇(cluster)大?。ū仨殲?個扇區(qū))
        DW      1               ; FAT起始位置(一般為第一個扇區(qū))
        DB      2               ; FAT個數(必須為2)
        DW      224             ; 根目錄大?。ㄒ话銥?24項)
        DW      2880            ; 該磁盤大小(必須為2880扇區(qū)1440*1024/512)
        DB      0xf0            ; 磁盤類型(必須為0xf0)
        DW      9               ; FAT的長度(必須是9扇區(qū))
        DW      18              ; 一個磁道(track)有幾個扇區(qū)(必須為18)
        DW      2               ; 磁頭數(必須是2)
        DD      0               ; 不使用分區(qū),必須是0
        DD      2880            ; 重寫一次磁盤大小

        ; 書中作者說原因不明的兩行代碼我查到了,see https://www.ntfs.com/fat-partition-sector.htm
        DB      0               ; BPB_Physical_Disk_Number    DB   (This is related to the BIOS physical disk number. Floppy drives are numbered starting with 0x00 for the A disk. Physical hard disks are numbered starting with 0x80. The value is typically 0x80 for hard disks, regardless of how many physical disk drives exist, because the value is only relevant if the device is the startup disk.)
        DB      0               ; BPB_Current_Head            DB   (Not used by FAT file system)
        DB      0x29            ; BPB_Signature               DB   (Must be either 0x28 or 0x29 in order to be recognized by Windows NT.)
        DD      0xffffffff      ; BPB_Volume_Serial_Number    DD



        DB      "HELLO-OS   "   ; 磁盤的名稱(必須為11字節(jié),不足填空格)
        DB      "FAT12   "      ; 磁盤格式名稱(必須是8字節(jié),不足填空格)
        TIMES   18  DB 0        ; 先空出18字節(jié)

; 程序主體

        DB      0xb8, 0x00, 0x00, 0x8e, 0xd0, 0xbc, 0x00, 0x7c
        DB      0x8e, 0xd8, 0x8e, 0xc0, 0xbe, 0x74, 0x7c, 0x8a
        DB      0x04, 0x83, 0xc6, 0x01, 0x3c, 0x00, 0x74, 0x09
        DB      0xb4, 0x0e, 0xbb, 0x0f, 0x00, 0xcd, 0x10, 0xeb
        DB      0xee, 0xf4, 0xeb, 0xfd

; 信息顯示部分

        DB      0x0a, 0x0a      ; 換行兩次
        DB      "hello, world"
        DB      0x0a         ; 換行
        DB      0

        TIMES   0x1fe-($-$$) DB 0x00         ; 填寫0x00直到0x001fe

        DB      0x55, 0xaa

; 啟動扇區(qū)以外部分輸出

        DB      0xf0, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00
        TIMES   4600    DB 0
        DB      0xf0, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00
        TIMES   1469432 DB 0
; 只是把 RESB 20 改成了 TIMES 20 DB 0

編譯命令
vscode寫好后直接終端運行

nasm -f bin day1.asm -o day1.img

-f指定輸出格式為bin,本次生成的是img文件,因為后續(xù)調試要用,當然也可以生成其他類型文件

運行命令

qemu-system-i386 day1.img

運行結果:

如何搭建X86匯編調試環(huán)境

調試環(huán)境搭建

調試匯編我們一般用bochs軟件調試
下載鏈接

進入安裝目錄找到一個叫bochsdbg。exe的程序,我們調試主要用到這個程序
打開即可看到如下界面

如何搭建X86匯編調試環(huán)境

在白色menu框中點擊Disk & Boot選項,選擇ATA channel 0下的First HD/CD on channel

如何搭建X86匯編調試環(huán)境

修改如下參數

如何搭建X86匯編調試環(huán)境

第一個指定為磁盤
第二個指定img文件路徑
Heads:磁頭數
Sectors per track :每磁道有幾個扇區(qū)
這些參數其實是由上文的程序指定的程序指定的

DW      18              ; 一個磁道(track)有幾個扇區(qū)(必須為18)
DW      2               ; 磁頭數(必須是2)

之后點擊Boot Options中的boot drive設置為disk即可

如何搭建X86匯編調試環(huán)境

點擊ok后會退到Bochs start menu菜單, 點擊start即可啟動調試
這里展示了一下

如何搭建X86匯編調試環(huán)境

注意最下面的s 其實就是單步調試的意思,還有注意的是展示的一行匯編代碼實際是未運行的,是下次運行的,比如這里的

jmpf 0xf000:e05b

實際未運行,需要輸入s才能運行這一步

如果想要跳轉個某個地址呢 比如0x7c00,該怎么辦呢?
輸入 b 0x7c00 b就是打斷點 運行一下
再輸入c就是continue繼續(xù)的意思即可跳轉到這
想要退出的話需要輸入2次q即可
后續(xù)有什么命令在繼續(xù)補充吧

需要注意的是匯編代碼必須加前面那個fat代碼,不然bochs無法調試,還有另一種方法是用FixVhdw。

關于“如何搭建X86匯編調試環(huán)境”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

x86
AI