CPIO parsing, kfs building, vfs tweaks
[akaros.git] / kern / src / Makefrag
1 # Makefile fragment for ROS kernel.
2 # This is NOT a complete makefile;
3 # you must run GNU make in the top-level directory
4 # where the GNUmakefile is located.
5 #
6
7 KERN_SRC_DIR = $(KERN_DIR)/src
8 OBJDIRS += $(KERN_SRC_DIR)
9 KERN_CPIO = initramfs.cpio
10
11 # entry.S must be first, so that it's the first code in the text segment!!!
12 #
13 # We also snatch the use of a couple handy source files
14 # from the lib directory, to avoid gratuitous code duplication.
15 KERN_SRCFILES := $(KERN_ARCH_SRCFILES) \
16                  $(KERN_SRC_DIR)/init.c \
17                  $(KERN_SRC_DIR)/monitor.c \
18                  $(KERN_SRC_DIR)/printf.c \
19                  $(KERN_SRC_DIR)/sched.c \
20                  $(KERN_SRC_DIR)/printfmt.c \
21                  $(KERN_SRC_DIR)/smp.c \
22                  $(KERN_SRC_DIR)/multiboot.c \
23                  $(KERN_SRC_DIR)/readline.c \
24                  $(KERN_SRC_DIR)/string.c \
25                  $(KERN_SRC_DIR)/atomic.c \
26                  $(KERN_SRC_DIR)/colored_caches.c \
27                  $(KERN_SRC_DIR)/page_alloc.c \
28                  $(KERN_SRC_DIR)/pmap.c \
29                  $(KERN_SRC_DIR)/env.c \
30                  $(KERN_SRC_DIR)/manager.c \
31                  $(KERN_SRC_DIR)/syscall.c \
32                  $(KERN_SRC_DIR)/timer.c \
33                  $(KERN_SRC_DIR)/kfs.c \
34                  $(KERN_SRC_DIR)/process.c \
35                  $(KERN_SRC_DIR)/kmalloc.c \
36                  $(KERN_SRC_DIR)/hashtable.c \
37                  $(KERN_SRC_DIR)/schedule.c \
38                  $(KERN_SRC_DIR)/mm.c \
39                  $(KERN_SRC_DIR)/resource.c \
40                  $(KERN_SRC_DIR)/slab.c \
41                  $(KERN_SRC_DIR)/elf.c \
42                  $(KERN_SRC_DIR)/frontend.c \
43                  $(KERN_SRC_DIR)/vfs.c \
44                  $(KERN_SRC_DIR)/testing.c
45
46 # Only build files if they exist.
47 KERN_SRCFILES := $(wildcard $(KERN_SRCFILES))
48
49 KERN_APPFILES := \
50
51
52 ifneq ($(findstring CONFIG_KFS,$(KERN_CFLAGS)),)
53 all: tests
54 $(OBJDIR)/$(KERN_DIR)/kernel: tests
55
56 KERN_APPFILES += \
57                  $(TESTS_DIR)/tlstest \
58                  $(TESTS_DIR)/fp_test \
59                  $(TESTS_DIR)/mproctests \
60                  $(TESTS_DIR)/hello \
61                  $(TESTS_DIR)/mhello \
62                  $(TESTS_DIR)/pthread_test \
63                  $(TESTS_DIR)/pthread_barrier_test \
64                  $(TESTS_DIR)/idle \
65                  $(TESTS_DIR)/tsc_spitter \
66                  $(TESTS_DIR)/msr_get_cores \
67                  $(TESTS_DIR)/msr_get_singlecore \
68                  $(TESTS_DIR)/msr_dumb_while \
69                  $(TESTS_DIR)/msr_nice_while \
70                  $(TESTS_DIR)/msr_single_while \
71                  $(TESTS_DIR)/msr_cycling_vcores
72 endif
73
74 KERN_LDFLAGS   := $(KERN_LDFLAGS) -L$(OBJDIR)/$(KERN_DIR) \
75                   -T $(KERN_ARCH_SRC_DIR)/kernel.ld
76
77 KERN_OBJFILES  := $(patsubst $(KERN_DIR)/%.c, \
78                              $(OBJDIR)/$(KERN_DIR)/%.o, \
79                              $(KERN_SRCFILES))
80 KERN_OBJFILES  := $(patsubst $(KERN_DIR)/%.S, \
81                              $(OBJDIR)/$(KERN_DIR)/%.o, \
82                              $(KERN_OBJFILES))
83
84 KERN_APPFILES  := $(patsubst %, $(OBJDIR)/%, $(KERN_APPFILES))
85
86 KERN_LDDEPENDS := $(KERN_OBJFILES) $(KERN_APPFILES) $(ARCH_DIR)/$(TARGET_ARCH)/kernel.ld \
87                   $(OBJDIR)/$(KERN_DIR)/libivykern.a $(OBJDIR)/$(KERN_DIR)/$(KERN_CPIO)
88
89 KERN_LDLIBS    := -livykern
90
91 KERN_GCC_LIB   ?= $(GCC_LIB)
92
93 KERN_INITRAMFS_FILES := $(shell mkdir -p $(INITRAMFS_PATHS); find $(INITRAMFS_PATHS))
94
95 $(OBJDIR)/$(KERN_DIR)/$(KERN_CPIO) initramfs: $(KERN_INITRAMFS_FILES)
96         @echo Building initramfs:
97         @if [ "$(INITRAMFS_BIN)" != "" ]; then \
98         sh $(INITRAMFS_BIN); \
99     fi
100         $(V)for i in $(INITRAMFS_PATHS); do cd $$i; \
101         echo Adding $$i to initramfs...; \
102         find -L . | cpio --quiet -oH newc > \
103              $(TOP_DIR)/$(OBJDIR)/$(KERN_DIR)/$(KERN_CPIO); \
104         cd $$OLDPWD; \
105     done;
106
107 $(OBJDIR)/$(KERN_DIR)/%.o: $(KERN_DIR)/%.c
108         @echo + cc [KERN] $<
109         @mkdir -p $(@D)
110         $(V)$(CC) $(KERN_CFLAGS) -c -o $@ $<
111
112 $(OBJDIR)/$(KERN_DIR)/%.o: $(KERN_DIR)/%.S
113         @echo + as [KERN] $<
114         @mkdir -p $(@D)
115         $(V)$(CC) $(KERN_CFLAGS) -D__ASSEMBLER__ -c -o $@ $<
116
117 UDEBUG := $(findstring -g,$(USER_CFLAGS))
118 $(OBJDIR)/$(KERN_DIR)/kernel: $(KERN_LDDEPENDS)
119         @echo + ld [KERN] $@
120         @if [ "$(UDEBUG)" != "-g" ] && [ "$(KERN_APPFILES)" != "" ]; then \
121                 $(STRIP) -s $(KERN_APPFILES) ; \
122         fi
123         $(V)$(LD) -o $@ $(KERN_LDFLAGS) $(KERN_OBJFILES) $(KERN_LDLIBS) \
124                         $(KERN_GCC_LIB) -b binary $(KERN_APPFILES) \
125                         $(OBJDIR)/$(KERN_DIR)/$(KERN_CPIO)
126         $(V)$(OBJDUMP) -S $@ > $@.asm
127         $(V)$(NM) -n $@ > $@.sym
128
129 all: $(OBJDIR)/$(KERN_DIR)/kernel
130