diff options
author | Benji Dial <benji6283@gmail.com> | 2020-09-06 15:47:06 -0400 |
---|---|---|
committer | Benji Dial <benji6283@gmail.com> | 2020-09-06 15:47:06 -0400 |
commit | b8284137d4e0eec11c78bc14047243fce6a51373 (patch) | |
tree | 5969602dc3d090b536edccbf34d33d46a300c192 /makefile | |
parent | 73bb0e48640b842824a0b45fe4854df8ff7faf7b (diff) | |
download | portland-os-b8284137d4e0eec11c78bc14047243fce6a51373.tar.gz |
minor changes, redoing makefile, meminfo program
Diffstat (limited to 'makefile')
-rw-r--r-- | makefile | 117 |
1 files changed, 53 insertions, 64 deletions
@@ -1,5 +1,13 @@ -disk: kernel boot skel init hello - mkdir -p obj out +kgccargs = -Wall -Wsuggest-attribute=pure -Wsuggest-attribute=const -Wsuggest-attribute=malloc -m32 -Og -ffreestanding -fno-asynchronous-unwind-tables +ugccargs = ${kgccargs} -Isrc/user/include +nasmargs = -f elf32 +partlink = -r -m elf_i386 + +out/disk.vdi: out/disk.img + VBoxManage convertfromraw out/disk.img out/disk.vdi --uuid a61929ed-3bf2-45ff-b98a-44f87c616dba + +out/disk.img: out/kernel.bin out/boot.bin out/fs + mkdir -p obj /sbin/mkfs.fat -C -f 1 -F 16 -n "PORTLAND OS" -R 65 -s 1 -S 512 obj/shadow.img 8192 echo -n -e '\xeb\x3c' > obj/jmp.bin dd if=obj/jmp.bin of=obj/shadow.img obs=2 conv=notrunc @@ -8,78 +16,59 @@ disk: kernel boot skel init hello mv obj/shadow.img out/disk.img mcopy -i out/disk.img -s out/fs/* ::/ -vdi-file: disk - VBoxManage convertfromraw out/disk.img out/disk.vdi --uuid a61929ed-3bf2-45ff-b98a-44f87c616dba - -debug: disk +debug: out/disk.img gdb -x qemu-debug.gdb clean: rm -r obj out || true -skel: - mkdir -p out/fs +out/fs: obj/hello.elf obj/init.elf obj/meminfo.elf + mkdir -p out/fs/bin cp -r fs-skel/* out/fs/ + objcopy -S obj/hello.elf out/fs/bin/hello.elf + objcopy -S obj/init.elf out/fs/bin/init.elf + objcopy -S obj/meminfo.elf out/fs/bin/meminfo.elf + +obj/kernel/%.ko: src/kernel/%.c + mkdir -p $(shell dirname $@) + gcc ${kgccargs} -c $< -o $@ + +obj/kernel/%.kao: src/kernel/%.asm + mkdir -p $(shell dirname $@) + nasm ${nasmargs} $< -o $@ + +out/kernel.bin: obj/kernel/drive.ko obj/kernel/fat.ko obj/kernel/ide.ko \ + obj/kernel/idt.ko obj/kernel/log.ko obj/kernel/main.ko \ + obj/kernel/main2.ko obj/kernel/pmap.ko obj/kernel/paging.ko \ + obj/kernel/panic.ko obj/kernel/pci.ko obj/kernel/elf.ko \ + obj/kernel/serial.ko obj/kernel/task.ko obj/kernel/util.ko \ + obj/kernel/vga.ko obj/kernel/isrs.kao + mkdir -p out + ld -T src/kernel/elf-link.ld obj/kernel/* -o obj/kernel.elf + objcopy -O binary obj/kernel.elf out/kernel.bin -kgccargs = -Wall -Wsuggest-attribute=pure -Wsuggest-attribute=const -Wsuggest-attribute=malloc -m32 -Og -ffreestanding -fno-asynchronous-unwind-tables -ugccargs = ${kgccargs} -Isrc/user/include -nasmargs = -f elf32 -partlink = -r -m elf_i386 - -init: knob - mkdir -p obj/init out/fs/bin - - gcc ${ugccargs} -c src/user/init/main.c -o obj/init/main.o - - ld -T src/user/elf.ld obj/init/main.o obj/knob.o -o obj/init.elf - objcopy -S obj/init.elf out/fs/bin/init.elf - -hello: knob - mkdir -p obj/hello out/fs/bin - - gcc ${ugccargs} -c src/user/hello/hello.c -o obj/hello/hello.o - - ld -T src/user/elf.ld obj/hello/hello.o obj/knob.o -o obj/hello.elf - objcopy -S obj/hello.elf out/fs/bin/hello.elf - -knob: - mkdir -p obj/knob +out/boot.bin: src/boot.asm + mkdir -p out + nasm src/boot.asm -o out/boot.bin - gcc ${ugccargs} -c src/user/knob/env.c -o obj/knob/env.o - gcc ${ugccargs} -c src/user/knob/file.c -o obj/knob/file.o - gcc ${ugccargs} -c src/user/knob/format.c -o obj/knob/format.o - gcc ${ugccargs} -c src/user/knob/heap.c -o obj/knob/heap.o - gcc ${ugccargs} -c src/user/knob/quit.c -o obj/knob/quit.o - gcc ${ugccargs} -c src/user/knob/user.c -o obj/knob/user.o - gcc ${ugccargs} -c src/user/knob/task.c -o obj/knob/task.o - nasm ${nasmargs} src/user/knob/entry.asm -o obj/knob/entry.o +obj/%.o: src/user/%.c + mkdir -p $(shell dirname $@) + gcc ${ugccargs} -c $< -o $@ - ld ${partlink} obj/knob/*.o -o obj/knob.o +obj/%.ao: src/user/%.asm + mkdir -p $(shell dirname $@) + nasm ${nasmargs} $< -o $@ -kernel: - mkdir -p obj/kernel out +obj/knob.so: obj/knob/env.o obj/knob/file.o obj/knob/format.o \ + obj/knob/heap.o obj/knob/quit.o obj/knob/user.o \ + obj/knob/task.o obj/knob/entry.ao + ld ${partlink} obj/knob/* -o obj/knob.so - gcc ${kgccargs} -c src/kernel/drive.c -o obj/kernel/drive.o - gcc ${kgccargs} -c src/kernel/fat.c -o obj/kernel/fat.o - gcc ${kgccargs} -c src/kernel/ide.c -o obj/kernel/ide.o - gcc ${kgccargs} -c src/kernel/idt.c -o obj/kernel/idt.o - gcc ${kgccargs} -c src/kernel/log.c -o obj/kernel/log.o - gcc ${kgccargs} -c src/kernel/main.c -o obj/kernel/main.o - gcc ${kgccargs} -c src/kernel/main2.c -o obj/kernel/main2.o - gcc ${kgccargs} -c src/kernel/pmap.c -o obj/kernel/pmap.o - gcc ${kgccargs} -c src/kernel/paging.c -o obj/kernel/paging.o - gcc ${kgccargs} -c src/kernel/panic.c -o obj/kernel/panic.o - gcc ${kgccargs} -c src/kernel/pci.c -o obj/kernel/pci.o - gcc ${kgccargs} -c src/kernel/elf.c -o obj/kernel/elf.o - gcc ${kgccargs} -c src/kernel/serial.c -o obj/kernel/serial.o - gcc ${kgccargs} -c src/kernel/task.c -o obj/kernel/task.o - gcc ${kgccargs} -c src/kernel/util.c -o obj/kernel/util.o - gcc ${kgccargs} -c src/kernel/vga.c -o obj/kernel/vga.o - nasm ${nasmargs} src/kernel/isrs.asm -o obj/kernel/isrs.o +obj/hello.elf: obj/hello/hello.o obj/knob.so + ld -T src/user/elf.ld obj/hello/* obj/knob.so -o obj/hello.elf - ld -T src/kernel/elf-link.ld obj/kernel/*.o -o obj/kernel.elf - objcopy -O binary obj/kernel.elf out/kernel.bin +obj/init.elf: obj/init/init.o obj/knob.so + ld -T src/user/elf.ld obj/init/* obj/knob.so -o obj/init.elf -boot: - mkdir -p out - nasm src/boot.asm -o out/boot.bin +obj/meminfo.elf: obj/meminfo/meminfo.o obj/knob.so + ld -T src/user/elf.ld obj/meminfo/* obj/knob.so -o obj/meminfo.elf
\ No newline at end of file |