toaruos/Makefile

121 lines
4.0 KiB
Makefile
Raw Normal View History

#CC = gcc
CC = clang
2011-02-21 12:11:30 +03:00
GCC = gcc
2011-02-09 23:32:49 +03:00
CFLAGS = -Wall -Wextra -pedantic -m32 -O0 -std=c99 -finline-functions -fno-stack-protector -nostdinc -ffreestanding -Wno-unused-function -Wno-unused-parameter
LD = ld -m elf_i386
YASM = yasm
2011-02-09 23:32:49 +03: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-10 00:33:03 +03:00
GENEXT = genext2fs
2011-02-19 07:22:25 +03:00
DD = dd conv=notrunc
2011-01-17 22:58:31 +03:00
2011-02-10 00:33:03 +03:00
.PHONY: all clean install run
2011-01-17 22:58:31 +03:00
2011-02-22 04:42:52 +03:00
all: toaruos-initrd toaruos-kernel bootdisk.img
2011-01-16 04:01:19 +03:00
2011-02-21 21:03:58 +03: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-16 04:01:19 +03:00
run: toaruos-kernel toaruos-initrd
${EMU} -kernel toaruos-kernel -initrd toaruos-initrd -serial stdio
2011-02-19 07:22:25 +03: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-22 04:44:09 +03:00
@${ECHO} "\033[34;1m -- Kernel is ready!\033[0m"
2011-01-16 04:01:19 +03:00
kernel/start.o: kernel/start.asm
2011-02-21 22:21:28 +03:00
@${ECHO} -n "\033[32m yasm $<\033[0m"
@${YASM} -f elf -o kernel/start.o kernel/start.asm
@${ECHO} "\r\033[32;1m yasm $<\033[0m"
2011-02-05 22:27:04 +03:00
2011-01-16 04:01:19 +03: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 22:58:31 +03:00
2011-02-19 07:22:25 +03: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-22 04:44:09 +03:00
@${ECHO} "\033[34;1m -- HDD image is ready!\033[0m"
### Ram Disk installers...
# Kernel
2011-02-21 22:29:09 +03:00
initrd/kernel: toaruos-kernel
@cp toaruos-kernel initrd/kernel
2011-02-19 07:22:25 +03:00
################
# Bootloader #
################
2011-02-21 22:29:09 +03:00
# Stage 1
2011-02-21 12:11:30 +03:00
bootloader/stage1/main.o: bootloader/stage1/main.c
@${ECHO} -n "\033[32m CC $<\033[0m"
@${GCC} ${CFLAGS} -c -o $@ $<
2011-02-21 12:11:30 +03:00
@${ECHO} "\r\033[32;1m CC $<\033[0m"
2011-02-19 07:22:25 +03:00
2011-02-21 12:11:30 +03:00
bootloader/stage1/start.o: bootloader/stage1/start.s
@${ECHO} -n "\033[32m yasm $<\033[0m"
2011-02-21 12:11:30 +03:00
@${YASM} -f elf32 -p gas -o $@ $<
@${ECHO} "\r\033[32;1m yasm $<\033[0m"
2011-02-21 12:11:30 +03: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-19 07:22:25 +03:00
2011-02-21 22:29:09 +03:00
# Stage 2
bootloader/stage2/main.o: bootloader/stage2/main.c
@${ECHO} -n "\033[32m CC $<\033[0m"
@${GCC} ${CFLAGS} -c -o $@ $<
2011-02-21 22:29:09 +03:00
@${ECHO} "\r\033[32;1m CC $<\033[0m"
bootloader/stage2/start.o: bootloader/stage2/start.s
2011-02-21 22:29:09 +03: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 22:29:09 +03: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 22:29:09 +03:00
@${ECHO} "\r\033[32;1m ld $<\033[0m"
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 22:29:09 +03:00
###############
# clean #
###############
2011-01-16 04:01:19 +03: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 12:11:30 +03:00
@-rm -f bootloader/stage1.bin
@-rm -f bootloader/stage1/*.o
2011-02-21 22:29:09 +03:00
@-rm -f bootloader/stage2.bin
@-rm -f bootloader/stage2/*.o
@-rm -f initrd/stage2
2011-02-21 22:29:09 +03:00
@-rm -f initrd/kernel
@-rm -f testdisk
@${ECHO} "\r\033[31;1m RM Finished cleaning.\033[0m\033[K"