X-Git-Url: http://git.dujemihanovic.xyz/posts?a=blobdiff_plain;f=Makefile;h=5d9822946a116ea2bce52b0cef027cdbf59832d9;hb=3568adbeba1623a28e80fa3680a2286fd48b0ed3;hp=c895701d2b911f6517b90be5d4b4fd8cbea6cfcb;hpb=3d58037b465f917b19b0f786c334ed70e1065857;p=nameless-os.git diff --git a/Makefile b/Makefile index c895701..5d98229 100644 --- a/Makefile +++ b/Makefile @@ -4,28 +4,31 @@ CC = i686-elf-gcc KERNEL_OBJ = kernel/entry.o kernel/arch/x86/tty/tty.o kernel/kernel.o -all: boot.img +all: boot.img kernel/kernel.elf -boot.img: boot kernel/kernel.bin - cat boot kernel/kernel.bin > $@ +boot.img: boot/x86/boot kernel/kernel.bin + cat boot/x86/boot kernel/kernel.bin > $@ truncate -s1440K $@ -boot: boot.s - $(AS) -f bin boot.s -o $@ +boot/x86/boot: boot/x86/boot.s boot/x86/a20.s boot/x86/protected.s boot/x86/print.s + $(AS) -f bin boot/x86/boot.s -o $@ kernel/kernel.bin: ${KERNEL_OBJ} - $(LD) -o $@ -T kernel/linker.ld ${KERNEL_OBJ} --oformat=binary + $(LD) -o $@ -T kernel/linker.ld ${KERNEL_OBJ} kernel/entry.o: kernel/entry.s $(AS) -f elf kernel/entry.s -o $@ kernel/arch/x86/tty/tty.o: kernel/arch/x86/tty/tty.c - $(CC) -o $@ -ffreestanding -c kernel/arch/x86/tty/tty.c + $(CC) -g -o $@ -Iinclude/arch/x86 -ffreestanding -c kernel/arch/x86/tty/tty.c kernel/kernel.o: kernel/kernel.c - $(CC) -o $@ -Iinclude/arch/x86 -ffreestanding -c kernel/kernel.c + $(CC) -g -o $@ -Iinclude/arch/x86 -ffreestanding -c kernel/kernel.c + +kernel/kernel.elf: kernel/kernel.bin + $(LD) -o $@ -T kernel/linker.ld ${KERNEL_OBJ} --oformat=elf32-i386 clean: - rm boot kernel/kernel.bin ${KERNEL_OBJ} boot.img + rm boot/x86/boot kernel/kernel.bin kernel/kernel.elf ${KERNEL_OBJ} boot.img .PHONY: all clean