toaruos/Makefile

135 lines
4.3 KiB
Makefile
Raw Normal View History

#CC = gcc
CC = clang
2011-02-21 03:11:30 -06:00
GCC = gcc
CFLAGS = -Wall -Wextra -pedantic -m32 -O0 -std=c99 -finline-functions -fno-stack-protector -nostdinc -ffreestanding -Wno-unused-function -Wno-unused-parameter -g
LD = ld -m elf_i386
YASM = yasm
2011-02-09 14:32:49 -06:00
ECHO = `which echo` -e
MODULES = $(patsubst %.c,%.o,$(wildcard kernel/core/*.c))
FILESYSTEMS = $(patsubst %.c,%.o,$(wildcard kernel/core/fs/*.c))
EMU = qemu
2011-02-09 15:33:03 -06:00
GENEXT = genext2fs
2011-02-18 22:22:25 -06:00
DD = dd conv=notrunc
2011-01-17 13:58:31 -06:00
.PHONY: all system clean install run
2011-01-17 13:58:31 -06:00
all: system bootdisk.img docs
system: toaruos-initrd toaruos-kernel
2011-01-15 20:01:19 -05:00
2011-02-21 12:03:58 -06:00
install: toaruos-initrd toaruos-kernel
@${ECHO} -n "\033[34m -- Installing to /boot...\033[0m"
@cp toaruos-kernel /boot/toaruos-kernel
@cp toaruos-initrd /boot/toaruos-initrd
@${ECHO} "\r\033[34;1m -- Kernel and ramdisk installed.\033[0m"
2011-01-15 20:01:19 -05:00
run: toaruos-kernel toaruos-initrd
${EMU} -kernel toaruos-kernel -initrd toaruos-initrd -serial stdio
#################
# Documentation #
#################
docs: docs/loader.pdf
%.pdf: %.tex
@${ECHO} -n "\033[32m docs Generating documentation file $@"
@pdflatex -halt-on-error -output-directory docs/ $< > /dev/null
@${ECHO} "\r\033[32;1m docs Generated documentation file '$@'"
2011-02-18 22:22:25 -06:00
################
# Kernel #
################
toaruos-kernel: kernel/start.o kernel/link.ld kernel/main.o ${MODULES} ${FILESYSTEMS}
@${ECHO} -n "\033[32m LD $<\033[0m"
@${LD} -T kernel/link.ld -o toaruos-kernel kernel/*.o kernel/core/*.o kernel/core/fs/*.o
@${ECHO} "\r\033[32;1m LD $<\033[0m"
2011-02-21 19:44:09 -06:00
@${ECHO} "\033[34;1m -- Kernel is ready!\033[0m"
2011-01-15 20:01:19 -05:00
2011-02-27 21:08:55 -06:00
kernel/start.o: kernel/start.s
2011-02-21 13:21:28 -06:00
@${ECHO} -n "\033[32m yasm $<\033[0m"
2011-02-27 21:08:55 -06:00
@${YASM} -f elf -o kernel/start.o kernel/start.s
2011-02-21 13:21:28 -06:00
@${ECHO} "\r\033[32;1m yasm $<\033[0m"
2011-02-05 13:27:04 -06:00
2011-01-15 20:01:19 -05:00
%.o: %.c
@${ECHO} -n "\033[32m CC $<\033[0m"
@${CC} ${CFLAGS} -I./kernel/include -c -o $@ $<
@${ECHO} "\r\033[32;1m CC $<\033[0m"
2011-01-17 13:58:31 -06:00
2011-02-18 22:22:25 -06:00
################
# Ram disk #
################
toaruos-initrd: initrd/kernel
@${ECHO} -n "\033[32m initrd Generating initial RAM disk\033[0m"
@-rm -f toaruos-initrd
@${GENEXT} -d initrd -q -b 249 toaruos-initrd
@${ECHO} "\r\033[32;1m initrd Generated initial RAM disk image\033[0m"
2011-02-21 19:44:09 -06:00
@${ECHO} "\033[34;1m -- HDD image is ready!\033[0m"
### Ram Disk installers...
# Kernel
2011-02-21 13:29:09 -06:00
initrd/kernel: toaruos-kernel
@cp toaruos-kernel initrd/kernel
2011-02-18 22:22:25 -06:00
################
# Bootloader #
################
2011-02-21 13:29:09 -06:00
# Stage 1
2011-02-21 03:11:30 -06:00
bootloader/stage1/main.o: bootloader/stage1/main.c
@${ECHO} -n "\033[32m CC $<\033[0m"
@${GCC} ${CFLAGS} -c -o $@ $<
2011-02-21 03:11:30 -06:00
@${ECHO} "\r\033[32;1m CC $<\033[0m"
2011-02-18 22:22:25 -06:00
2011-02-21 03:11:30 -06:00
bootloader/stage1/start.o: bootloader/stage1/start.s
@${ECHO} -n "\033[32m yasm $<\033[0m"
2011-02-21 03:11:30 -06:00
@${YASM} -f elf32 -p gas -o $@ $<
@${ECHO} "\r\033[32;1m yasm $<\033[0m"
2011-02-21 03:11:30 -06:00
bootloader/stage1.bin: bootloader/stage1/main.o bootloader/stage1/start.o bootloader/stage1/link.ld
@${ECHO} -n "\033[32m ld $<\033[0m"
@${LD} -o bootloader/stage1.bin -T bootloader/stage1/link.ld bootloader/stage1/start.o bootloader/stage1/main.o
@${ECHO} "\r\033[32;1m ld $<\033[0m"
2011-02-18 22:22:25 -06:00
2011-02-21 13:29:09 -06:00
# Stage 2
bootloader/stage2/main.o: bootloader/stage2/main.c
@${ECHO} -n "\033[32m CC $<\033[0m"
@${GCC} ${CFLAGS} -I./kernel/include -c -o $@ $<
2011-02-21 13:29:09 -06:00
@${ECHO} "\r\033[32;1m CC $<\033[0m"
bootloader/stage2/start.o: bootloader/stage2/start.s
2011-02-21 13:29:09 -06:00
@${ECHO} -n "\033[32m yasm $<\033[0m"
@${YASM} -f elf32 -p gas -o $@ $<
@${ECHO} "\r\033[32;1m yasm $<\033[0m"
bootloader/stage2.bin: bootloader/stage2/main.o bootloader/stage2/start.o bootloader/stage2/link.ld
2011-02-21 13:29:09 -06:00
@${ECHO} -n "\033[32m ld $<\033[0m"
@${LD} -o bootloader/stage2.bin -T bootloader/stage2/link.ld bootloader/stage2/start.o bootloader/stage2/main.o
2011-02-21 13:29:09 -06:00
@${ECHO} "\r\033[32;1m ld $<\033[0m"
2011-02-21 20:35:37 -06:00
##############
# bootdisk #
##############
bootdisk.img: bootloader/stage1.bin bootloader/stage2.bin
@${ECHO} -n "\033[34m -- Building bootdisk.img...\033[0m"
@cat bootloader/stage1.bin bootloader/stage2.bin > bootdisk.img
@${ECHO} "\r\033[34;1m -- Bootdisk is ready! \033[0m"
2011-02-21 13:29:09 -06:00
###############
# clean #
###############
2011-01-15 20:01:19 -05:00
clean:
@${ECHO} -n "\033[31m RM Cleaning... \033[0m"
@-rm -f toaruos-kernel
@-rm -f toaruos-initrd
@-rm -f kernel/*.o
@-rm -f kernel/core/*.o
@-rm -f kernel/core/fs/*.o
2011-02-21 03:11:30 -06:00
@-rm -f bootloader/stage1.bin
@-rm -f bootloader/stage1/*.o
2011-02-21 13:29:09 -06:00
@-rm -f bootloader/stage2.bin
@-rm -f bootloader/stage2/*.o
@-rm -f initrd/kernel
@-rm -f bootdisk.img
@-rm -f docs/*.pdf docs/*.aux docs/*.log
@${ECHO} "\r\033[31;1m RM Finished cleaning.\033[0m\033[K"