0176-打印错误提示信息

环境

  • Time 2022-11-12
  • WSL-Ubuntu 22.04
  • QEMU 6.2.0
  • NASM 2.15.05

前言

说明

参考:https://os.phil-opp.com/entering-longmode//

目标

为了方便在出错的时候,看到错误代码,新增一个打印错误代码的函数。

汇编代码

section .multiboot_header
header_start:
    dd 0x1BADB002  ; 魔法数字,固定值
    dd 0
    dd -0x1BADB002 ; 定义的这三个数字相加需要等于0
header_end:

global start
section .text
bits 32

start:
mov al,44
call error

; 打印 `ERR: ` 和一个错误代码并停住。
; 错误代码在 al 寄存器中
error:
    mov dword [0xb8000], 0x4f524f45
    mov dword [0xb8004], 0x4f3a4f52
    mov dword [0xb8008], 0x4f204f20
    mov byte  [0xb800a], al
    hlt

其中的 call 指令在之前已经学过了,同时 0xb8000 在之前实模式时也学过了。

自动启动 QEMU 脚本

#! /usr/bin/bash

nasm -f elf32 -g boot.asm
ld -T linker.ld -m elf_i386 boot.o -o kernel.elf
qemu-system-x86_64 -kernel kernel.elf -display curses -s -S

自动 GDB 连接脚本

#! /usr/bin/bash

gdb kernel.elf -ex "set architecture i386:x86-64" \
    -ex "target remote localhost:1234" \
    -ex "break start" -ex "continue"

总结

通过启动 QEMU 和 GDB,单步调试后,屏幕上打印出了红色的 ERR 字样。

附录

posted @   jiangbo4444  阅读(11)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2020-07-14 【JavaScript】函数返回值
点击右上角即可分享
微信分享提示