Subversion Repositories HelenOS

Rev

Rev 350 | Rev 377 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 jermar 1
include Makefile.config
376 jermar 2
include arch/$(ARCH)/Makefile.inc
1 jermar 3
 
376 jermar 4
sources=src/cpu/cpu.c \
5
	src/main/main.c \
6
	src/main/kinit.c \
7
	src/main/uinit.c \
8
	src/proc/scheduler.c \
9
	src/proc/thread.c \
10
	src/proc/task.c \
11
	src/proc/the.c \
12
	src/mm/heap.c \
13
	src/mm/frame.c \
14
	src/mm/page.c \
15
	src/mm/tlb.c \
16
	src/mm/vm.c \
17
	src/lib/func.c \
18
	src/lib/list.c \
19
	src/lib/memstr.c \
20
	src/lib/sort.c \
21
	src/debug/print.c \
22
	src/debug/symtab.c \
23
	src/time/clock.c \
24
	src/time/timeout.c \
25
	src/time/delay.c \
26
	src/preempt/preemption.c \
27
	src/synch/spinlock.c \
28
	src/synch/condvar.c \
29
	src/synch/rwlock.c \
30
	src/synch/mutex.c \
31
	src/synch/semaphore.c \
32
	src/synch/waitq.c \
33
	src/smp/ipi.c \
34
	src/fb/font-8x16.c
1 jermar 35
 
326 palkovsky 36
# CFLAGS options same for all targets
376 jermar 37
CFLAGS+=-nostdinc -Iinclude/ -Werror-implicit-function-declaration -Wmissing-prototypes -Werror
326 palkovsky 38
 
1 jermar 39
ifdef DEBUG_SPINLOCK
40
CFLAGS+=-D$(DEBUG_SPINLOCK)
41
endif
42
 
34 jermar 43
ifdef USERSPACE
44
CFLAGS+=-D$(USERSPACE)
45
endif
46
 
1 jermar 47
ifdef TEST
376 jermar 48
test_objects:=$(addsuffix .o,$(basename test/$(TEST_DIR)/$(TEST_FILE)))
1 jermar 49
CFLAGS+=-D$(TEST)
50
endif
51
arch_objects:=$(addsuffix .o,$(basename $(arch_sources)))
52
objects:=$(addsuffix .o,$(basename $(sources)))
53
 
54
.PHONY : all config depend build clean dist-clean boot
55
 
56
all: dist-clean config depend build
57
 
58
-include Makefile.depend
59
 
60
config:
376 jermar 61
	find src/ include/ -name arch -type l -exec rm \{\} \;
62
	ln -s ../arch/$(ARCH)/src/ src/arch
63
	ln -s ../arch/$(ARCH)/include/ include/arch
1 jermar 64
 
65
depend:
326 palkovsky 66
	$(CC) $(CFLAGS) -M $(arch_sources) $(sources) >Makefile.depend
1 jermar 67
 
68
build: kernel.bin boot
69
 
70
clean:
376 jermar 71
	find src/ arch/$(ARCH)/src/ test/ -name '*.o' -exec rm \{\} \;
72
	-rm *.bin kernel.map kernel.map.pre kernel.objdump src/debug/real_map.bin
73
	$(MAKE) -C arch/$(ARCH)/boot/ clean
1 jermar 74
 
75
dist-clean:
376 jermar 76
	find src/ include/ -name arch -type l -exec rm \{\} \;
1 jermar 77
	-rm Makefile.depend
78
	-$(MAKE) clean
79
 
376 jermar 80
src/debug/real_map.bin: $(arch_objects) $(objects) $(test_objects) arch/$(ARCH)/_link.ld 
81
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab Makefile src/debug/empty_map.o
82
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(arch_objects) $(objects) $(test_objects) src/debug/empty_map.o -o $@ -Map kernel.map.pre
293 palkovsky 83
	$(OBJDUMP) -t $(arch_objects) $(objects) $(test_objects) > kernel.objdump
376 jermar 84
	tools/genmap.py kernel.map.pre kernel.objdump src/debug/real_map.bin 
293 palkovsky 85
 
376 jermar 86
src/debug/real_map.o: src/debug/real_map.bin
293 palkovsky 87
	$(OBJCOPY) -I binary -O $(BFD_NAME) -B $(BFD_ARCH) --prefix-sections=symtab $< $@
88
 
89
 
376 jermar 90
kernel.bin: $(arch_objects) $(objects) $(test_objects) arch/$(ARCH)/_link.ld src/debug/real_map.o
91
	$(LD) -T arch/$(ARCH)/_link.ld $(LFLAGS) $(arch_objects) $(objects) $(test_objects) src/debug/real_map.o -o $@ -Map kernel.map
1 jermar 92
 
314 palkovsky 93
%.o: %.S
94
	$(CC) $(ASFLAGS) $(CFLAGS) -c $< -o $@
1 jermar 95
 
96
%.o: %.s
76 jermar 97
	$(AS) $(ASFLAGS) $< -o $@
1 jermar 98
 
99
%.o: %.c
100
	$(CC) $(CFLAGS) -c $< -o $@
101
 
102
KS=`cat kernel.bin | wc -c`
103
 
104
boot:
376 jermar 105
	$(MAKE) -C arch/$(ARCH)/boot build KERNEL_SIZE=$(KS)