Merge branch 'master' of github.com:Minep/lunaix-os
[lunaix-os.git] / lunaix-os / kernel.mk
index 81e8921201c9aae5770b2a7aab1f5644752c8587..189e97046385d7ffa581e5e52467bbf3cab2f3b3 100644 (file)
@@ -1,10 +1,11 @@
 include os.mkinc
 include toolchain.mkinc
 
+kexclusion = $(shell cat ksrc.excludes)
+
 define ksrc_dirs
        kernel
        hal
-       debug
        libs
        arch/$(ARCH)
 endef
@@ -12,6 +13,7 @@ endef
 define kinc_dirs
        includes
        includes/usr
+       arch/$(ARCH)/includes
 endef
 
 
@@ -19,26 +21,45 @@ 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))
 
 kinc_opts := $(addprefix -I,$(kinc_dirs))
 
+tmp_kbin  := $(BUILD_DIR)/tmpk.bin
+ksymtable := lunaix_ksyms.o
 
 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): $(ksrc_objs) $(kbin_dir)
+$(tmp_kbin): $(ksrc_objs)
        $(call status_,LD,$@)
-       @$(CC) -T link/linker.ld -o $(kbin) $(ksrc_objs) $(LDFLAGS)
+       @$(CC) -T link/linker.ld $(LDFLAGS) -o $@ $^
+
+$(ksymtable): $(tmp_kbin)
+       $(call status_,KSYM,$@)
+       @scripts/gen_ksymtable.sh DdRrTtAGg $< > .lunaix_ksymtable.S
+       @$(CC) $(CFLAGS) -c .lunaix_ksymtable.S -o $@
+
+.PHONY: __do_relink
+__do_relink: $(ksrc_objs) $(ksymtable)
+       $(call status_,LD,$(kbin))
+       @$(CC) -T link/linker.ld $(LDFLAGS) -o $(kbin) $^
+       @rm $(tmp_kbin)
 
-all: $(kbin)
+.PHONY: all
+all: __do_relink
 
 clean:
-       @rm -f $(ksrc_objs)
\ No newline at end of file
+       @rm -f $(ksrc_objs)
+       @rm -f $(ksrc_deps)
+       @rm -f .lunaix_ksymtable.S $(ksymtable)
\ No newline at end of file