Проблемы с простой загрузкой/ядром C

Недавно я заинтересовался написанием своей собственной действительно очень простой ОС. Я написал (точнее, скопировал) некоторый базовый ассемблер, который создает стек и делает некоторые базовые вещи, и это, казалось, работало нормально, однако попытка ввести C в смесь все испортила.

У меня есть два основных файла проекта: loader.s, представляющий собой некий NASM, создающий стек и вызывающий мою функцию C, и kernel.c, содержащий базовую функцию C.

Моя проблема на данный момент заключается в том, что QEMU зависает, когда я запускаю файл kernel.bin. Я предполагаю, что с моим кодом что-то не так - возможно, этот вопрос не совсем подходит для формата StackOverflow из-за его крайней специфичности. Файлы проекта у меня такие:

loader.s:

BITS 16                         ; 16 Bits

extern kmain                    ; Our 'proper' kernel function in C

loader:
    mov ax, 07C0h           ; Move the starting address [7C00h] into 'ax'
    add ax, 32              ; Leave 32 16 byte blocks [200h] for the 512 code segment
    mov ss, ax              ; Set 'stack segment' to the start of our stack
    mov sp, 4096            ; Set the stack pointer to the end of our stack [4096 bytes in size]

    mov ax, 07C0h           ; Use 'ax' to set 'ds'
    mov ds, ax              ; Set data segment to where we're loaded
    mov es, ax              ; Set our extra segment

    call kmain              ; Call the kernel proper

    cli                     ; Clear ints

    jmp $                   ; Hang


; Since putting these in and booting the image without '-kernel' can't find
; a bootable device, we'll comment these out for now and run the ROM with
; the '-kernel' flag in QEMU
        ;times 510-($-$$) db 0          ; Pad remained of our boot sector with 0s
        ;dw 0xAA55                      ; The standard 'magic word' boot sig

kernel.c:

#include <stdint.h>

void kmain(void)
{
        unsigned char *vidmem = (char*)0xB8000; //Video memory address
        vidmem[0] = 65; //The character 'A'
        vidmem[1] = 0x07; //Light grey (7) on black (0)
}

компилирую все так:

nasm -f elf -o loader.o loader.s

i386- elf-gcc -I/usr/include -o kernel.o -c kernel.c -Wall -nostdlib -fno-builtin -nostartfiles -nodefaultlibs

i386-elf-ld -T linker.ld -o загрузчик kernel.bin .o kernel.o

А затем протестируйте так:

qemu-system-x86_64 -kernel kernel.bin

Надеюсь, кто-нибудь сможет просмотреть это для меня — фрагменты кода не очень длинные .

Спасибо.

5
задан 3 October 2013 в 20:00
поделиться