X-Git-Url: https://scm.lunaixsky.com/lunaix-os.git/blobdiff_plain/1025235c72c31f7fa7b648c0e32ddcaa68a8f66a..9d4cc53314b8e2a236401733ac6c7093c97d4351:/lunaix-os/kernel.mk diff --git a/lunaix-os/kernel.mk b/lunaix-os/kernel.mk index 9399e71..a0a2404 100644 --- a/lunaix-os/kernel.mk +++ b/lunaix-os/kernel.mk @@ -1,53 +1,69 @@ -include os.mkinc -include toolchain.mkinc - -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 +include kbuild_deps.mkinc kbin_dir := $(BUILD_DIR) kbin := $(BUILD_NAME) -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 +klinking := link/lunaix.ld -CFLAGS += $(khdr_opts) +CFLAGS += $(kcflags) -MMD -MP --include $(ksrc_deps) +all_linkable = $(filter-out $(klinking),$(1)) %.S.o: %.S $(khdr_files) kernel.mk - $(call status_,AS,$<) - @$(CC) $(CFLAGS) $(kinc_opts) -MMD -MP -c $< -o $@ + $(call status,AS,$<) + @$(CC) $(CFLAGS) -c $< -o $@ + +%.c.o: %.c kernel.mk + $(call status,CC,$<) + @$(CC) $(CFLAGS) -c $< -o $@ + -%.c.o: %.c $(khdr_files) kernel.mk - $(call status_,CC,$<) - @$(CC) $(CFLAGS) $(kinc_opts) -MMD -MP -c $< -o $@ +$(klinking): link/lunaix.ldx + $(call status,PP,$<) + @$(CC) $(CFLAGS) -x c -E -P $< -o $@ -$(tmp_kbin): $(ksrc_objs) - $(call status_,LD,$@) - @$(CC) -T link/linker.ld $(LDFLAGS) -o $@ $^ + +$(tmp_kbin): $(klinking) $(ksrc_objs) + $(call status,LD,$@) + + @$(CC) -T $(klinking) $(config_h) $(LDFLAGS) -o $@ \ + $(call all_linkable,$^) + +ksymtable := lunaix_ksyms.o +ksecsmap := lunaix_ksecsmap.o + +kautogen := $(ksecsmap) $(ksymtable) $(ksymtable): $(tmp_kbin) - $(call status_,KSYM,$@) - @scripts/gen_ksymtable.sh DdRrTtAGg $< > .lunaix_ksymtable.S - @$(CC) $(CFLAGS) -c .lunaix_ksymtable.S -o $@ + $(call status,KSYM,$@) + @ARCH=$(ARCH) scripts/gen-ksymtable DdRrTtAGg $< > lunaix_ksymtable.S + + @$(CC) $(CFLAGS) -c lunaix_ksymtable.S -o $@ + +$(ksecsmap): $(tmp_kbin) + $(call status,KGEN,$@) + @scripts/elftool.tool -p -i $< > lunaix_ksecsmap.S + + @$(CC) $(CFLAGS) -c lunaix_ksecsmap.S -o $@ .PHONY: __do_relink -__do_relink: $(ksrc_objs) $(ksymtable) - $(call status_,LD,$(kbin)) - @$(CC) -T link/linker.ld $(LDFLAGS) -o $(kbin) $^ + +__do_relink: $(klinking) $(ksrc_objs) $(kautogen) + $(call status,LD,$(kbin)) + + @$(CC) -T $(klinking) $(config_h) $(LDFLAGS) -o $(kbin) \ + $(call all_linkable,$^) + @rm $(tmp_kbin) + .PHONY: all all: __do_relink + clean: @rm -f $(ksrc_objs) @rm -f $(ksrc_deps) - @rm -f .lunaix_ksymtable.S $(ksymtable) \ No newline at end of file + @rm -f $(klinking) + @rm -f lunaix_ksymtable.S $(ksymtable) \ No newline at end of file