X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/d1b1c8d9119229dbeed06cd252917e54a1cb77f6..1025235c72c31f7fa7b648c0e32ddcaa68a8f66a:/lunaix-os/kernel.mk?ds=sidebyside diff --git a/lunaix-os/kernel.mk b/lunaix-os/kernel.mk index 189e970..9399e71 100644 --- a/lunaix-os/kernel.mk +++ b/lunaix-os/kernel.mk @@ -1,45 +1,33 @@ include os.mkinc include toolchain.mkinc -kexclusion = $(shell cat ksrc.excludes) - -define ksrc_dirs - kernel - hal - libs - arch/$(ARCH) -endef - -define kinc_dirs - includes - includes/usr - arch/$(ARCH)/includes -endef - +ksrc_files = $(shell cat .builder/sources.list) +kinc_dirs = $(shell cat .builder/includes.list) +khdr_files = $(shell cat .builder/headers.list) +khdr_files += .builder/configs.h kbin_dir := $(BUILD_DIR) kbin := $(BUILD_NAME) -ksrc_files := $(foreach f, $(ksrc_dirs), $(shell find $(f) -name "*.[cS]")) -ksrc_files := $(filter-out $(kexclusion),$(ksrc_files)) ksrc_objs := $(addsuffix .o,$(ksrc_files)) ksrc_deps := $(addsuffix .d,$(ksrc_files)) - +khdr_opts := $(addprefix -include ,$(khdr_files)) kinc_opts := $(addprefix -I,$(kinc_dirs)) tmp_kbin := $(BUILD_DIR)/tmpk.bin ksymtable := lunaix_ksyms.o -CFLAGS += -include flags.h -CFLAGS += -include config.h +CFLAGS += $(khdr_opts) + +-include $(ksrc_deps) -%.S.o: %.S +%.S.o: %.S $(khdr_files) kernel.mk $(call status_,AS,$<) - @$(CC) $(CFLAGS) $(kinc_opts) -c $< -o $@ + @$(CC) $(CFLAGS) $(kinc_opts) -MMD -MP -c $< -o $@ -%.c.o: %.c +%.c.o: %.c $(khdr_files) kernel.mk $(call status_,CC,$<) - @$(CC) $(CFLAGS) $(kinc_opts) -c $< -o $@ + @$(CC) $(CFLAGS) $(kinc_opts) -MMD -MP -c $< -o $@ $(tmp_kbin): $(ksrc_objs) $(call status_,LD,$@)