Merge remote branch 'origin/sparc-dev'
[akaros.git] / GNUmakefile
1 #
2 # This makefile system follows the structuring conventions
3 # recommended by Peter Miller in his excellent paper:
4 #
5 #       Recursive Make Considered Harmful
6 #       http://aegis.sourceforge.net/auug97.pdf
7 #
8
9 OBJDIR := obj
10
11 # Make sure that 'all' is the first target
12 all: symlinks
13
14 # User defined constants passed on the command line 
15 TARGET_ARCH := i386
16 COMPILER := IVY
17
18 -include Makelocal
19
20 TOP_DIR := .
21 ARCH_DIR := $(TOP_DIR)/kern/arch
22 INCLUDE_DIR := $(TOP_DIR)/kern/include
23
24 UNAME=$(shell uname -m)
25 V = @
26
27 # Cross-compiler ros toolchain
28 #
29 # This Makefile will automatically use the cross-compiler toolchain
30 # installed as 'i386-ros-*', if one exists.  If the host tools ('gcc',
31 # 'objdump', and so forth) compile for a 32-bit x86 ELF target, that will
32 # be detected as well.  If you have the right compiler toolchain installed
33 # using a different name, set GCCPREFIX explicitly in your Makelocal file
34
35 # try to infer the correct GCCPREFIX
36 ifndef GCCPREFIX
37 GCCPREFIX := $(shell if i386-ros-objdump -i 2>&1 | grep '^elf32-i386$$' >/dev/null 2>&1; \
38         then echo 'i386-ros-'; \
39         elif objdump -i 2>&1 | grep 'elf32-i386' >/dev/null 2>&1; \
40         then echo ''; \
41         else echo "***" 1>&2; \
42         echo "*** Error: Couldn't find an i386-*-elf version of GCC/binutils." 1>&2; \
43         echo "*** Is the directory with i386-ros-gcc in your PATH?" 1>&2; \
44         echo "*** If your i386-*-elf toolchain is installed with a command" 1>&2; \
45         echo "*** prefix other than 'i386-ros-', set your GCCPREFIX" 1>&2; \
46         echo "*** environment variable to that prefix and run 'make' again." 1>&2; \
47         echo "*** To turn off this error, run 'gmake GCCPREFIX= ...'." 1>&2; \
48         echo "***" 1>&2; exit 1; fi)
49 endif
50
51 # Default programs for compilation
52 ifeq ($(COMPILER),IVY)
53 KERN_CFLAGS := --deputy\
54                   --no-rc-sharc\
55                   --sc-dynamic-is-error\
56                   --sc-ops=$(INCLUDE_DIR)/ivy/sharc.h\
57                   --sc-all-in-thread\
58                   --enable-precompile\
59 #                  --enable-error-db\
60
61 USER_CFLAGS := --deputy --enable-error-db
62 CC          := ivycc --gcc=$(GCCPREFIX)gcc
63 else
64 CC          := $(GCCPREFIX)gcc 
65 endif
66
67 AS          := $(GCCPREFIX)as
68 AR          := $(GCCPREFIX)ar
69 LD          := $(GCCPREFIX)ld
70 OBJCOPY := $(GCCPREFIX)objcopy
71 OBJDUMP := $(GCCPREFIX)objdump
72 NM          := $(GCCPREFIX)nm
73 PERL    := perl
74
75 EXTRAARGS ?= -std=gnu99 -Wno-attributes -fno-stack-protector -fgnu89-inline
76
77 # Universal compiler flags
78 # -fno-builtin is required to avoid refs to undefined functions in the kernel.
79 # Only optimize to -O1 to discourage inlining, which complicates backtraces.
80 CFLAGS := $(CFLAGS) -D$(TARGET_ARCH) $(EXTRAARGS)
81 CFLAGS += -O2 -pipe -MD -fno-builtin -gstabs
82 CFLAGS += -Wall -Wno-format -Wno-unused -fno-strict-aliasing
83 #CFLAGS += -nostdinc -Igccinclude/$(TARGET_ARCH)
84
85 # Universal loader flags
86 LDFLAGS := -nostdlib
87
88 # GCC Library path 
89 GCC_LIB := $(shell $(CC) -print-libgcc-file-name)
90
91 # List of directories that the */Makefrag makefile fragments will add to
92 OBJDIRS :=
93
94 symlinks:
95         @rm -f kern/include/arch
96         @ln -s ../arch/$(TARGET_ARCH)/ kern/include/arch
97         @rm -f kern/boot
98         @ln -s arch/$(TARGET_ARCH)/boot/ kern/boot
99
100 # Include Makefrags for subdirectories
101 include user/Makefrag
102 include kern/Makefrag
103
104 # Eliminate default suffix rules
105 .SUFFIXES:
106
107 # Delete target files if there is an error (or make is interrupted)
108 .DELETE_ON_ERROR:
109
110 # This magic automatically generates makefile dependencies
111 # for header files included from C source files we compile,
112 # and keeps those dependencies up-to-date every time we recompile.
113 # See 'mergedep.pl' for more information.
114 $(OBJDIR)/.deps: $(foreach dir, $(OBJDIRS), $(wildcard $(OBJDIR)/$(dir)/*.d))
115         @mkdir -p $(@D)
116         @$(PERL) scripts/mergedep.pl $@ $^
117
118 # By including this file we automatically force the target that generates it 
119 # to be rerun
120 -include $(OBJDIR)/.deps
121
122 # Use doxygen to make documentation for ROS
123 docs: 
124         @doxygen doc/rosdoc.cfg
125         @if [ ! -d doc/rosdoc/html/img ];          \
126          then                                      \
127                 ln -s ../../img doc/rosdoc/html;       \
128          fi
129
130 doxyclean:
131         rm -rf doc/rosdoc
132
133 augment-gcc: symlinks
134         scripts/augment-gcc $(dir $(shell which $(CC))).. $(TARGET_ARCH)
135
136 # For deleting the build
137 clean:
138         @rm -rf $(OBJDIR)
139         @rm -f kern/boot
140         @rm -f kern/include/arch
141         @echo All clean and pretty!
142
143 always:
144         @:
145
146 .PHONY: all always docs clean
147