| 1 | # | 
|---|
| 2 | # Copyright (c) 2005 Martin Decky | 
|---|
| 3 | # Copyright (c) 2007 Jakub Jermar | 
|---|
| 4 | # All rights reserved. | 
|---|
| 5 | # | 
|---|
| 6 | # Redistribution and use in source and binary forms, with or without | 
|---|
| 7 | # modification, are permitted provided that the following conditions | 
|---|
| 8 | # are met: | 
|---|
| 9 | # | 
|---|
| 10 | # - Redistributions of source code must retain the above copyright | 
|---|
| 11 | #   notice, this list of conditions and the following disclaimer. | 
|---|
| 12 | # - Redistributions in binary form must reproduce the above copyright | 
|---|
| 13 | #   notice, this list of conditions and the following disclaimer in the | 
|---|
| 14 | #   documentation and/or other materials provided with the distribution. | 
|---|
| 15 | # - The name of the author may not be used to endorse or promote products | 
|---|
| 16 | #   derived from this software without specific prior written permission. | 
|---|
| 17 | # | 
|---|
| 18 | # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | 
|---|
| 19 | # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | 
|---|
| 20 | # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | 
|---|
| 21 | # IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | 
|---|
| 22 | # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | 
|---|
| 23 | # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
|---|
| 24 | # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
|---|
| 25 | # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
|---|
| 26 | # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | 
|---|
| 27 | # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
|---|
| 28 | # | 
|---|
| 29 |  | 
|---|
| 30 | # Individual makefiles set: | 
|---|
| 31 | # | 
|---|
| 32 | #   USPACE_PREFIX  (*) relative path to uspace/ directory | 
|---|
| 33 | #   SOURCES        (*) list of source files | 
|---|
| 34 | #   LIBS               libraries to link with | 
|---|
| 35 | #   DEFS               compiler defines | 
|---|
| 36 | #   EXTRA_CFLAGS       additional flags to pass to C compiler | 
|---|
| 37 | #   LINKER_SCRIPT      linker script | 
|---|
| 38 | #   PRE_DEPEND         targets required for dependency check | 
|---|
| 39 | # | 
|---|
| 40 | #   BINARY         (/) binary output name (like appname) | 
|---|
| 41 | #   LIBRARY        (/) library output name (like libname) | 
|---|
| 42 | #   EXTRA_OUTPUT       additional output targets | 
|---|
| 43 | #   EXTRA_CLEAN        additional cleanup targets | 
|---|
| 44 | # | 
|---|
| 45 | # (x) required variables | 
|---|
| 46 | # (/) exactly one of the variables must be defined | 
|---|
| 47 | # | 
|---|
| 48 |  | 
|---|
| 49 | ROOT_PATH = $(USPACE_PREFIX)/.. | 
|---|
| 50 |  | 
|---|
| 51 | VERSION_DEF = $(ROOT_PATH)/version | 
|---|
| 52 |  | 
|---|
| 53 | COMMON_MAKEFILE = $(ROOT_PATH)/Makefile.common | 
|---|
| 54 | COMMON_HEADER = $(ROOT_PATH)/common.h | 
|---|
| 55 |  | 
|---|
| 56 | CONFIG_MAKEFILE = $(ROOT_PATH)/Makefile.config | 
|---|
| 57 | CONFIG_HEADER = $(ROOT_PATH)/config.h | 
|---|
| 58 |  | 
|---|
| 59 | -include $(VERSION_DEF) | 
|---|
| 60 | -include $(COMMON_MAKEFILE) | 
|---|
| 61 | -include $(CONFIG_MAKEFILE) | 
|---|
| 62 |  | 
|---|
| 63 | ifneq ($(BINARY),) | 
|---|
| 64 | JOB = $(BINARY).job | 
|---|
| 65 | OUTPUT = $(BINARY) | 
|---|
| 66 | EXTRA_OUTPUT += $(BINARY).disasm | 
|---|
| 67 | EXTRA_CLEAN += $(BINARY).map | 
|---|
| 68 | endif | 
|---|
| 69 |  | 
|---|
| 70 | ifneq ($(LIBRARY),) | 
|---|
| 71 | JOB = $(LIBRARY).job | 
|---|
| 72 | OUTPUT = $(LIBRARY).a | 
|---|
| 73 | endif | 
|---|
| 74 |  | 
|---|
| 75 | DEPEND = Makefile.depend | 
|---|
| 76 | DEPEND_PREV = $(DEPEND).prev | 
|---|
| 77 |  | 
|---|
| 78 | LIB_PREFIX = $(USPACE_PREFIX)/lib | 
|---|
| 79 |  | 
|---|
| 80 | LIBC_PREFIX = $(LIB_PREFIX)/c | 
|---|
| 81 | LIBSOFTFLOAT_PREFIX = $(LIB_PREFIX)/softfloat | 
|---|
| 82 | LIBSOFTINT_PREFIX = $(LIB_PREFIX)/softint | 
|---|
| 83 |  | 
|---|
| 84 | LIBBLOCK_PREFIX = $(LIB_PREFIX)/block | 
|---|
| 85 | LIBFS_PREFIX = $(LIB_PREFIX)/fs | 
|---|
| 86 | LIBCLUI_PREFIX = $(LIB_PREFIX)/clui | 
|---|
| 87 |  | 
|---|
| 88 |  | 
|---|
| 89 | LIBUSB_PREFIX = $(LIB_PREFIX)/usb | 
|---|
| 90 | LIBUSBVIRT_PREFIX = $(LIB_PREFIX)/usbvirt | 
|---|
| 91 | LIBDRV_PREFIX = $(LIB_PREFIX)/drv | 
|---|
| 92 | LIBPACKET_PREFIX = $(LIB_PREFIX)/packet | 
|---|
| 93 | LIBNET_PREFIX = $(LIB_PREFIX)/net | 
|---|
| 94 |  | 
|---|
| 95 | BASE_LIBS = $(LIBC_PREFIX)/libc.a $(LIBSOFTINT_PREFIX)/libsoftint.a | 
|---|
| 96 |  | 
|---|
| 97 | LINKER_SCRIPT ?= $(LIBC_PREFIX)/arch/$(UARCH)/_link.ld | 
|---|
| 98 |  | 
|---|
| 99 | ifeq ($(CONFIG_OPTIMIZE_FOR_SIZE),y) | 
|---|
| 100 | OPTIMIZATION = s | 
|---|
| 101 | else | 
|---|
| 102 | OPTIMIZATION = 3 | 
|---|
| 103 | endif | 
|---|
| 104 |  | 
|---|
| 105 | .PHONY: all clean | 
|---|
| 106 |  | 
|---|
| 107 | all: $(VERSION_DEF) $(COMMON_MAKEFILE) $(CONFIG_MAKEFILE) $(CONFIG_HEADER) $(LIBS) $(OUTPUT) $(EXTRA_OUTPUT) | 
|---|
| 108 | -[ -f $(DEPEND) ] && cp -a $(DEPEND) $(DEPEND_PREV) | 
|---|
| 109 |  | 
|---|
| 110 | clean: | 
|---|
| 111 | rm -f $(DEPEND) $(DEPEND_PREV) $(JOB) $(OUTPUT) $(EXTRA_OUTPUT) $(EXTRA_CLEAN) | 
|---|
| 112 | find . -name '*.o' -follow -exec rm \{\} \; | 
|---|
| 113 |  | 
|---|
| 114 | GCC_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \ | 
|---|
| 115 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \ | 
|---|
| 116 | -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \ | 
|---|
| 117 | -Wall -Wextra -Wno-clobbered -Wno-unused-parameter -Wmissing-prototypes \ | 
|---|
| 118 | -Werror-implicit-function-declaration -Wwrite-strings \ | 
|---|
| 119 | -pipe -g -D__$(ENDIANESS)__ | 
|---|
| 120 |  | 
|---|
| 121 | ICC_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \ | 
|---|
| 122 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \ | 
|---|
| 123 | -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \ | 
|---|
| 124 | -Wall -Wextra -Wno-clobbered -Wno-unused-parameter -Wmissing-prototypes \ | 
|---|
| 125 | -Werror-implicit-function-declaration -Wwrite-strings \ | 
|---|
| 126 | -pipe -g -D__$(ENDIANESS)__ | 
|---|
| 127 |  | 
|---|
| 128 | CLANG_CFLAGS = -I$(LIBC_PREFIX)/include -O$(OPTIMIZATION) -imacros $(CONFIG_HEADER) \ | 
|---|
| 129 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \ | 
|---|
| 130 | -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \ | 
|---|
| 131 | -Wall -Wextra -Wno-unused-parameter -Wmissing-prototypes \ | 
|---|
| 132 | -Werror-implicit-function-declaration -Wwrite-strings \ | 
|---|
| 133 | -pipe -g -arch $(CLANG_ARCH) -D__$(ENDIANESS)__ | 
|---|
| 134 |  | 
|---|
| 135 | ifeq ($(CONFIG_DEBUG),y) | 
|---|
| 136 | GCC_CFLAGS += -Werror | 
|---|
| 137 | ICC_CFLAGS += -Werror | 
|---|
| 138 | endif | 
|---|
| 139 |  | 
|---|
| 140 | ## Setup platform configuration | 
|---|
| 141 | # | 
|---|
| 142 |  | 
|---|
| 143 | -include $(LIBC_PREFIX)/arch/$(UARCH)/Makefile.common | 
|---|
| 144 |  | 
|---|
| 145 | ## Compilation options | 
|---|
| 146 | # | 
|---|
| 147 |  | 
|---|
| 148 | JOBFILE = $(LIBC_PREFIX)/../../../tools/jobfile.py | 
|---|
| 149 |  | 
|---|
| 150 | ifeq ($(COMPILER),gcc_cross) | 
|---|
| 151 | CFLAGS = $(GCC_CFLAGS) $(EXTRA_CFLAGS) | 
|---|
| 152 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) | 
|---|
| 153 | endif | 
|---|
| 154 |  | 
|---|
| 155 | ifeq ($(COMPILER),gcc_native) | 
|---|
| 156 | CFLAGS = $(GCC_CFLAGS) $(EXTRA_CFLAGS) | 
|---|
| 157 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) | 
|---|
| 158 | endif | 
|---|
| 159 |  | 
|---|
| 160 | ifeq ($(COMPILER),icc) | 
|---|
| 161 | CFLAGS = $(ICC_CFLAGS) $(EXTRA_CFLAGS) | 
|---|
| 162 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) | 
|---|
| 163 | endif | 
|---|
| 164 |  | 
|---|
| 165 | ifeq ($(COMPILER),clang) | 
|---|
| 166 | CFLAGS = $(CLANG_CFLAGS) $(EXTRA_CFLAGS) | 
|---|
| 167 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS) | 
|---|
| 168 | endif | 
|---|
| 169 |  | 
|---|
| 170 | -include $(DEPEND) | 
|---|
| 171 |  | 
|---|
| 172 | OBJECTS := $(addsuffix .o,$(basename $(SOURCES))) | 
|---|
| 173 |  | 
|---|
| 174 | ifneq ($(BINARY),) | 
|---|
| 175 | %.disasm: $(BINARY) | 
|---|
| 176 | ifeq ($(CONFIG_LINE_DEBUG),y) | 
|---|
| 177 | $(OBJDUMP) -d -S $< > $@ | 
|---|
| 178 | else | 
|---|
| 179 | $(OBJDUMP) -d $< > $@ | 
|---|
| 180 | endif | 
|---|
| 181 |  | 
|---|
| 182 | $(BINARY): $(LINKER_SCRIPT) $(OBJECTS) $(LIBS) $(BASE_LIBS) | 
|---|
| 183 | $(LD) -N $(LFLAGS) -T $(LINKER_SCRIPT) -M -Map $(BINARY).map -o $(BINARY) $(OBJECTS) $(LIBS) $(BASE_LIBS) | 
|---|
| 184 | ifeq ($(CONFIG_STRIP_BINARIES),y) | 
|---|
| 185 | $(STRIP) $(BINARY) | 
|---|
| 186 | endif | 
|---|
| 187 | endif | 
|---|
| 188 |  | 
|---|
| 189 | ifneq ($(LIBRARY),) | 
|---|
| 190 | %.a: $(OBJECTS) | 
|---|
| 191 | $(AR) rc $@ $(OBJECTS) | 
|---|
| 192 | endif | 
|---|
| 193 |  | 
|---|
| 194 | %.o: %.S $(DEPEND) | 
|---|
| 195 | $(CC) $(DEFS) $(CFLAGS) -D__ASM__ -c $< -o $@ | 
|---|
| 196 | ifeq ($(PRECHECK),y) | 
|---|
| 197 | $(JOBFILE) $(JOB) $< $@ as asm/preproc $(DEFS) $(CFLAGS) -D__ASM__ | 
|---|
| 198 | endif | 
|---|
| 199 |  | 
|---|
| 200 | %.o: %.s $(DEPEND) | 
|---|
| 201 | $(AS) $(AFLAGS) -o $@ $< | 
|---|
| 202 | ifeq ($(PRECHECK),y) | 
|---|
| 203 | $(JOBFILE) $(JOB) $< $@ as asm | 
|---|
| 204 | endif | 
|---|
| 205 |  | 
|---|
| 206 | %.o: %.c $(DEPEND) | 
|---|
| 207 | $(CC) $(DEFS) $(CFLAGS) -c $< -o $@ | 
|---|
| 208 | ifeq ($(PRECHECK),y) | 
|---|
| 209 | $(JOBFILE) $(JOB) $< $@ cc core $(DEFS) $(CFLAGS) | 
|---|
| 210 | endif | 
|---|
| 211 |  | 
|---|
| 212 | $(DEPEND): $(PRE_DEPEND) | 
|---|
| 213 | makedepend -f - -- $(DEPEND_DEFS) $(CFLAGS) -- $(SOURCES) > $@ 2> /dev/null | 
|---|
| 214 | -[ -f $(DEPEND_PREV) ] && diff -q $(DEPEND_PREV) $@ && mv -f $(DEPEND_PREV) $@ | 
|---|