我已经制作了基本的os,它还没有真正做任何事情,但我想在qemu上测试它。但是,我必须为ld链接器的输出文件做些什么才能使其与qemu(iso或其他什么?)一起工作。
这是我的链接器脚本:
OUTPUT_FORMAT("binary")
ENTRY(start)
SECTIONS
{
.text 0x00100000:
{
code = .; _code = .; __code = .;
*(.text)
. = ALIGN(4096);
}
textEnd = .;
.data :
{
data = .; _data = .; __data = .;
*(.data)
. = ALIGN(4096);
}
dataEnd = .;
.bss :
{
bss = .; _bss = .; __bss = .;
*(.bss)
. = ALIGN(4096);
}
bssEnd = .;
end = .; _end = .; __end = .;
}
boot.s:(ASM)
[BITS 32]
MBOOT_PAGE_ALIGN equ 1 << 0
MBOOT_MEM_INFO equ 1 << 1
MBOOT_AOUT_KLUDGE equ 1 << 16
MBOOT_MAGIC equ 0x1BADB002
MBOOT_FLAGS equ MBOOT_PAGE_ALIGN | MBOOT_MEM_INFO | MBOOT_AOUT_KLUDGE
CHECKSUM equ -(MBOOT_MAGIC + MBOOT_FLAGS)
STACK_SIZE equ 0x1000
[global start]
[extern main]
[extern textEnd]
[extern dataEnd]
[extern bssEnd]
entry:
jmp start
align 4, db 0
mBootHeader:
dd MBOOT_MAGIC
dd MBOOT_FLAGS
dd CHECKSUM
dd mBootHeader
dd entry
dd dataEnd
dd bssEnd
dd entry
start:
call main
cli
hlt
我把整个事情整理如下:
$ nasm -f aout boot.s -o boot.o
$ gcc -c kernel.cpp -ffreestanding -nostdlib -fno-builtin -fno-rtti -fno-exceptions -m32
$ ld -T link.ld -o kernel.bin boot.o kernel.o -melf_i386
这一切都没有错误,唯一的问题是我如何在qemu中启动它?输出文件是可执行的,但我当然不能在linux上运行它,因为它是一个操作系统。
如果你有qemu,你可以使用:启动它
qemu-system-i386 -kernel kernel.bin