X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/b632f535c4a6882bdca0317fb88cbe6e165f24eb..c166bd62fbb907f95f79f621e2a2fb4fdde08e01:/lunaix-os/kernel.mk diff --git a/lunaix-os/kernel.mk b/lunaix-os/kernel.mk index 5d64514..9d6ca02 100644 --- a/lunaix-os/kernel.mk +++ b/lunaix-os/kernel.mk @@ -1,6 +1,8 @@ include os.mkinc include toolchain.mkinc +kexclusion = $(shell cat ksrc.excludes) + define ksrc_dirs kernel hal @@ -19,6 +21,7 @@ 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)) @@ -26,22 +29,23 @@ kinc_opts := $(addprefix -I,$(kinc_dirs)) CFLAGS += -include flags.h +CFLAGS += -include config.h %.S.o: %.S $(call status_,AS,$<) - @$(CC) $(kinc_opts) -c $< -o $@ + @$(CC) $(CFLAGS) $(kinc_opts) -c $< -o $@ %.c.o: %.c $(call status_,CC,$<) @$(CC) $(CFLAGS) $(kinc_opts) -c $< -o $@ $(kbin_dir)/modksyms: $(kbin) - $(call status_,GEN,$@) + $(call status_,MOD,$@) @$(PY) scripts/syms_export.py --bits=32 --order=little -o "$@" "$<" .PHONY: __do_relink __do_relink: $(ksrc_objs) - $(call status_,LD,$@) + $(call status_,LD,$(kbin)) @$(CC) -T link/linker.ld -o $(kbin) $(ksrc_objs) $(LDFLAGS) .PHONY: all