Makefile cleanup

This commit is contained in:
K. Lange 2018-04-24 19:39:47 +09:00 committed by Kevin Lange
parent 5dd763780a
commit c8ae1a5fb3

View File

@ -17,14 +17,12 @@ endif
# Disable built-in rules # Disable built-in rules
.SUFFIXES: .SUFFIXES:
KERNEL_TARGET=i686-pc-toaru TARGET_TRIPLET=i686-pc-toaru
KCC = $(KERNEL_TARGET)-gcc
KAS = $(KERNEL_TARGET)-as
KLD = $(KERNEL_TARGET)-ld
KNM = $(KERNEL_TARGET)-nm
CC=i686-pc-toaru-gcc # Userspace flags
AR=i686-pc-toaru-ar
CC=$(TARGET_TRIPLET)-gcc
AR=$(TARGET_TRIPLET)-ar
CFLAGS= -O3 -m32 -Wa,--32 -g -std=c99 -I. -Iapps -pipe -mfpmath=sse -mmmx -msse -msse2 -fplan9-extensions CFLAGS= -O3 -m32 -Wa,--32 -g -std=c99 -I. -Iapps -pipe -mfpmath=sse -mmmx -msse -msse2 -fplan9-extensions
LIBC_OBJS=$(patsubst %.c,%.o,$(wildcard libc/*.c)) LIBC_OBJS=$(patsubst %.c,%.o,$(wildcard libc/*.c))
@ -40,7 +38,12 @@ LIBS_Y=$(foreach lib,$(LIBS),.make/$(lib).lmak)
all: image.iso all: image.iso
# Kernel # Kernel / module flags
KCC = $(TARGET_TRIPLET)-gcc
KAS = $(TARGET_TRIPLET)-as
KLD = $(TARGET_TRIPLET)-ld
KNM = $(TARGET_TRIPLET)-nm
KCFLAGS = -O2 -std=c99 KCFLAGS = -O2 -std=c99
KCFLAGS += -finline-functions -ffreestanding KCFLAGS += -finline-functions -ffreestanding
@ -56,6 +59,8 @@ KERNEL_OBJS += $(patsubst %.c,%.o,$(wildcard kernel/*/*/*.c))
KERNEL_ASMOBJS = $(filter-out kernel/symbols.o,$(patsubst %.S,%.o,$(wildcard kernel/*.S))) KERNEL_ASMOBJS = $(filter-out kernel/symbols.o,$(patsubst %.S,%.o,$(wildcard kernel/*.S)))
# Kernel
cdrom/kernel: ${KERNEL_ASMOBJS} ${KERNEL_OBJS} kernel/symbols.o cdrom/kernel: ${KERNEL_ASMOBJS} ${KERNEL_OBJS} kernel/symbols.o
${KCC} -T kernel/link.ld ${KCFLAGS} -nostdlib -o $@ ${KERNEL_ASMOBJS} ${KERNEL_OBJS} kernel/symbols.o -lgcc ${KCC} -T kernel/link.ld ${KCFLAGS} -nostdlib -o $@ ${KERNEL_ASMOBJS} ${KERNEL_OBJS} kernel/symbols.o -lgcc
@ -68,6 +73,14 @@ kernel/symbols.o: ${KERNEL_ASMOBJS} ${KERNEL_OBJS} util/generate_symbols.py
kernel/sys/version.o: kernel/*/*.c kernel/*.c kernel/sys/version.o: kernel/*/*.c kernel/*.c
kernel/%.o: kernel/%.S
${KAS} ${ASFLAGS} $< -o $@
kernel/%.o: kernel/%.c ${HEADERS}
${KCC} ${KCFLAGS} -nostdlib -g -c -o $@ $<
# Modules
cdrom/mod: cdrom/mod:
@mkdir -p $@ @mkdir -p $@
@ -80,12 +93,6 @@ cdrom/mod/%.ko: modules/%.c ${HEADERS} | cdrom/mod
modules: ${MODULES} modules: ${MODULES}
kernel/%.o: kernel/%.S
${KAS} ${ASFLAGS} $< -o $@
kernel/%.o: kernel/%.c ${HEADERS}
${KCC} ${KCFLAGS} -nostdlib -g -c -o $@ $<
# Root Filesystem # Root Filesystem
base/dev: base/dev:
@ -133,12 +140,12 @@ ifeq (,$(findstring clean,$(MAKECMDGOALS)))
-include ${LIBS_Y} -include ${LIBS_Y}
endif endif
# Init # Init (static)
base/bin/init: apps/init.c base/lib/libc.a | dirs base/bin/init: apps/init.c base/lib/libc.a | dirs
$(CC) -static -Wl,-static $(CFLAGS) -o $@ $< $(CC) -static -Wl,-static $(CFLAGS) -o $@ $<
# Userspace # Userspace applications
.make/%.mak: apps/%.c util/auto-dep.py | dirs .make/%.mak: apps/%.c util/auto-dep.py | dirs
util/auto-dep.py --make $< > $@ util/auto-dep.py --make $< > $@
@ -152,7 +159,6 @@ endif
cdrom/ramdisk.img: ${APPS_X} ${LIBS_X} base/lib/ld.so Makefile | dirs cdrom/ramdisk.img: ${APPS_X} ${LIBS_X} base/lib/ld.so Makefile | dirs
genext2fs -B 4096 -d base -U -b 4096 -N 2048 cdrom/ramdisk.img genext2fs -B 4096 -d base -U -b 4096 -N 2048 cdrom/ramdisk.img
# CD image # CD image
image.iso: cdrom/ramdisk.img cdrom/boot/boot.sys cdrom/kernel ${MODULES} image.iso: cdrom/ramdisk.img cdrom/boot/boot.sys cdrom/kernel ${MODULES}