我刚刚根据这个 youtube教程创建了一个在屏幕上打印文本的基本操作系统。本教程中使用的方法相当复杂(我假设),因为它使用 C++ 而不是 C。在 Grub 菜单中选择操作系统后,菜单关闭但屏幕保持紫色。没有文本打印到屏幕上。我已经仔细检查了我的代码是否与教程相匹配,但它仍然不能像在他的机器上那样工作。
相关硬件:
CPU: Ryzen 5 2600
MOBO: Asrock B450-M HDV
这些文件相当小,包括在下面。
内核.cpp:
void printf(char* str) {
unsigned short* VideoMemory = (unsigned short*)0xb8000;
for(int i = 0; str[i] != '\0'; ++i) {
VideoMemory[i] = (VideoMemory[i] & 0xFF00) | str[i];
}
}
extern "C" void kernelMain(void* multiboot_structure, unsigned int magicnumber) {
printf("Hello World!");
while(1);
}
loader.s:(因为 C++ 期望在运行之前设置堆栈指针)
.set MAGIC, 0x1badb002
.set FLAGS, (1<<0 | 1<<1)
.set CHECKSUM, -(MAGIC + FLAGS)
.section .multiboot
.long MAGIC
.long FLAGS
.long CHECKSUM
.section .text
.extern kernelMain
.global loader
loader:
mov $kernel_stack, %esp
push %eax
push %ebx
call kernelMain
_stop:
cli
hlt
jmp _stop
.section .bss
.space 2*1024*1024; # 2 MB
kernel_stack:
链接器.ld:
ENTRY(loader)
OUTPUT_FORMAT(elf32-i386)
OUTPUT_ARCH(i386:i386)
SECTIONS {
. = 0x0100000;
.text : {
*(.multiboot)
*(.text*)
*(.rodata)
}
.data : {
start_ctors = .;
KEEP(*(.init_array));
KEEP(*(SORT_BY_INIT_PRIORITY( .init_array.* )))
end_ctors = .;
*(.data)
}
.bss : {
*(.bss)
}
/DISCARD/ : {
*(.fini_array*)
*(.comment)
}
}
生成文件:
GPPPARAMS = -m32 -fno-use-cxa-atexit -nostdlib -fno-builtin -fno-rtti -fno-exceptions -fno-leading-underscore
ASPARAMS = --32
LDPARAMS = -melf_i386
objects = loader.o kernel.o
%.o: %.cpp
g++ $(GPPPARAMS) -o $@ -c $<
%.o: %.s
as $(ASPARAMS) -o $@ $<
mykernel.bin: linker.ld $(objects)
ld $(LDPARAMS) -T $< -o $@ $(objects)
install: mykernel.bin
sudo cp $< /boot/mykernel.bin