More verbose multicore debugging
[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
10 # entry.S must be first, so that it's the first code in the text segment!!!
11 #
12 # We also snatch the use of a couple handy source files
13 # from the lib directory, to avoid gratuitous code duplication.
14 KERN_SRCFILES := $(KERN_ARCH_SRCFILES) \
15                  $(KERN_SRC_DIR)/init.c \
16                  $(KERN_SRC_DIR)/monitor.c \
17                  $(KERN_SRC_DIR)/printf.c \
18                  $(KERN_SRC_DIR)/trap.c \
19                  $(KERN_SRC_DIR)/trapentry.S \
20                  $(KERN_SRC_DIR)/sched.c \
21                  $(KERN_SRC_DIR)/kdebug.c \
22                  $(KERN_SRC_DIR)/apic.c \
23                  $(KERN_SRC_DIR)/printfmt.c \
24                  $(KERN_SRC_DIR)/smp.c \
25                  $(KERN_SRC_DIR)/multiboot.c \
26                  $(KERN_SRC_DIR)/readline.c \
27                  $(KERN_SRC_DIR)/string.c \
28                  $(KERN_SRC_DIR)/atomic.c \
29                  $(KERN_SRC_DIR)/workqueue.c \
30                  $(KERN_SRC_DIR)/colored_caches.c \
31                  $(KERN_SRC_DIR)/page_alloc.c \
32                  $(KERN_SRC_DIR)/pmap.c \
33                  $(KERN_SRC_DIR)/env.c \
34                  $(KERN_SRC_DIR)/manager.c \
35                  $(KERN_SRC_DIR)/syscall.c \
36                  $(KERN_SRC_DIR)/timer.c \
37                  $(KERN_SRC_DIR)/kfs.c \
38                  $(KERN_SRC_DIR)/process.c \
39                  $(KERN_SRC_DIR)/kmalloc.c \
40                  $(KERN_SRC_DIR)/hashtable.c \
41                  $(KERN_SRC_DIR)/hashtable_itr.c \
42                  $(KERN_SRC_DIR)/schedule.c \
43                  $(KERN_SRC_DIR)/mm.c \
44                  $(KERN_SRC_DIR)/resource.c \
45                  $(KERN_SRC_DIR)/slab.c \
46                  $(KERN_SRC_DIR)/testing.c
47
48 # Only build files if they exist.
49 KERN_SRCFILES := $(wildcard $(KERN_SRCFILES))
50
51 KERN_APPFILES := \
52                  $(USER_APPS_ROSLIB_DIR)/proctests \
53                  $(USER_APPS_ROSLIB_DIR)/fptest \
54                  $(USER_APPS_ROSLIB_DIR)/null \
55                  $(USER_APPS_ROSLIB_DIR)/spawn \
56                  $(USER_APPS_ROSLIB_DIR)/hello \
57                  $(USER_APPS_ROSLIB_DIR)/mhello \
58                  $(USER_APPS_ROSLIB_DIR)/measurements \
59                  $(USER_APPS_PARLIB_PTHREAD_DIR)/pthread_test \
60                  $(USER_APPS_PARLIB_PTHREAD_DIR)/blackscholes \
61                  $(USER_APPS_PARLIB_DIR)/draw_nanwan_standalone \
62                  $(USER_APPS_PARLIB_DIR)/channel_test_client \
63                  $(USER_APPS_PARLIB_DIR)/channel_test_server \
64                  $(USER_APPS_PARLIB_DIR)/hello \
65                  $(USER_APPS_PARLIB_DIR)/manycore_test \
66                  $(USER_APPS_PARLIB_DIR)/matrix  \
67                  $(USER_APPS_PARLIB_DIR)/fptest
68 #                 $(USER_APPS_PARLIB_DIR)/open_read
69
70 KERN_LDFLAGS   := $(KERN_LDFLAGS) -L$(OBJDIR)/$(KERN_DIR) \
71                   -T $(KERN_ARCH_SRC_DIR)/kernel.ld
72
73 KERN_OBJFILES  := $(patsubst $(KERN_DIR)/%.c, \
74                              $(OBJDIR)/$(KERN_DIR)/%.o, \
75                              $(KERN_SRCFILES))
76 KERN_OBJFILES  := $(patsubst $(KERN_DIR)/%.S, \
77                              $(OBJDIR)/$(KERN_DIR)/%.o, \
78                              $(KERN_OBJFILES))
79
80 KERN_APPFILES  := $(patsubst %, $(OBJDIR)/%, $(KERN_APPFILES))
81
82 KERN_LDDEPENDS := $(KERN_OBJFILES) $(KERN_APPFILES) $(ARCH_DIR)/$(TARGET_ARCH)/kernel.ld \
83                   $(OBJDIR)/$(KERN_DIR)/libivykern.a
84
85 KERN_LDLIBS    := -livykern
86
87 KERN_GCC_LIB   ?= $(GCC_LIB)
88
89 $(OBJDIR)/$(KERN_DIR)/%.o: $(KERN_DIR)/%.c
90         @echo + cc [KERN] $<
91         @mkdir -p $(@D)
92         $(V)$(CC) $(KERN_CFLAGS) -c -o $@ $<
93
94 $(OBJDIR)/$(KERN_DIR)/%.o: $(KERN_DIR)/%.S
95         @echo + as [KERN] $<
96         @mkdir -p $(@D)
97         $(V)$(CC) $(KERN_CFLAGS) -D__ASSEMBLER__ -c -o $@ $<
98
99 $(OBJDIR)/$(KERN_DIR)/kernel: $(KERN_LDDEPENDS)
100         @echo + ld [KERN] $@
101         $(V)$(LD) -o $@ $(KERN_LDFLAGS) $(KERN_OBJFILES) $(KERN_LDLIBS) \
102                         $(KERN_GCC_LIB) -b binary $(KERN_APPFILES)
103         $(V)$(OBJDUMP) -S $@ > $@.asm
104         $(V)$(NM) -n $@ > $@.sym
105
106 #$(OBJDIR)/$(KERN_DIR)/bochs.img: $(OBJDIR)/$(KERN_DIR)/kernel $(OBJDIR)/$(KERN_DIR)/boot
107 #       @echo + mk [KERN] $@
108 #       $(V)dd if=/dev/zero of=$(OBJDIR)/$(KERN_DIR)/bochs.img~ count=10080 2>/dev/null
109 #       $(V)dd if=$(OBJDIR)/$(KERN_DIR)/boot of=$(OBJDIR)/$(KERN_DIR)/bochs.img~ conv=notrunc 2>/dev/null
110 #       $(V)dd if=$(OBJDIR)/$(KERN_DIR)/kernel of=$(OBJDIR)/$(KERN_DIR)/bochs.img~ seek=1 conv=notrunc 2>/dev/null
111 #       $(V)mv $(OBJDIR)/kern/bochs.img~ $(OBJDIR)/kern/bochs.img
112
113 all: $(OBJDIR)/$(KERN_DIR)/kernel
114