[25b0e6a] | 1 | #
|
---|
| 2 | # Copyright (C) 2005 Martin Decky
|
---|
| 3 | # All rights reserved.
|
---|
| 4 | #
|
---|
| 5 | # Redistribution and use in source and binary forms, with or without
|
---|
| 6 | # modification, are permitted provided that the following conditions
|
---|
| 7 | # are met:
|
---|
| 8 | #
|
---|
| 9 | # - Redistributions of source code must retain the above copyright
|
---|
| 10 | # notice, this list of conditions and the following disclaimer.
|
---|
| 11 | # - Redistributions in binary form must reproduce the above copyright
|
---|
| 12 | # notice, this list of conditions and the following disclaimer in the
|
---|
| 13 | # documentation and/or other materials provided with the distribution.
|
---|
| 14 | # - The name of the author may not be used to endorse or promote products
|
---|
| 15 | # derived from this software without specific prior written permission.
|
---|
| 16 | #
|
---|
| 17 | # THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
---|
| 18 | # IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
---|
| 19 | # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
---|
| 20 | # IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
---|
| 21 | # INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
---|
| 22 | # NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
---|
| 23 | # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
---|
| 24 | # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
---|
| 25 | # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
---|
| 26 | # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
---|
| 27 | #
|
---|
| 28 |
|
---|
[6ab8697] | 29 | GCC_CFLAGS = -I$(LIBC_PREFIX)/include -O3 -imacros $(LIBC_PREFIX)/../../../config.h \
|
---|
[ac47b7c2] | 30 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
|
---|
[6ab8697] | 31 | -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
|
---|
| 32 | -Wall -Wextra -Wno-unused-parameter -Wmissing-prototypes \
|
---|
| 33 | -Werror-implicit-function-declaration -pipe -g -D__$(ENDIANESS)__
|
---|
| 34 |
|
---|
| 35 | ICC_CFLAGS = -I$(LIBC_PREFIX)/include -O3 -imacros $(LIBC_PREFIX)/../../../config.h \
|
---|
| 36 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
|
---|
| 37 | -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
|
---|
| 38 | -Wall -Wextra -Wno-unused-parameter -Wmissing-prototypes \
|
---|
| 39 | -Werror-implicit-function-declaration -pipe -g -D__$(ENDIANESS)__
|
---|
| 40 |
|
---|
| 41 | CLANG_CFLAGS = -I$(LIBC_PREFIX)/include -O3 -imacros $(LIBC_PREFIX)/../../../config.h \
|
---|
| 42 | -fexec-charset=UTF-8 -fwide-exec-charset=UTF-32$(ENDIANESS) \
|
---|
| 43 | -finput-charset=UTF-8 -ffreestanding -fno-builtin -nostdlib -nostdinc \
|
---|
| 44 | -Wall -Wextra -Wno-unused-parameter -Wmissing-prototypes \
|
---|
| 45 | -Werror-implicit-function-declaration -pipe -g -arch $(CLANG_ARCH) \
|
---|
| 46 | -D__$(ENDIANESS)__
|
---|
| 47 |
|
---|
[8bd0316] | 48 | LFLAGS = -M -N $(SOFTINT_PREFIX)/libsoftint.a
|
---|
[25b0e6a] | 49 | AFLAGS =
|
---|
[11a4fbf] | 50 |
|
---|
[54b2e74] | 51 | ## Cross-toolchain prefix
|
---|
| 52 | #
|
---|
| 53 |
|
---|
| 54 | ifndef CROSS_PREFIX
|
---|
| 55 | CROSS_PREFIX = /usr/local
|
---|
| 56 | endif
|
---|
| 57 |
|
---|
[25b0e6a] | 58 | ## Setup platform configuration
|
---|
| 59 | #
|
---|
| 60 |
|
---|
[94790d01] | 61 | -include $(LIBC_PREFIX)/../../../Makefile.config
|
---|
| 62 | -include $(LIBC_PREFIX)/../../../config.defs
|
---|
| 63 | -include $(LIBC_PREFIX)/arch/$(UARCH)/Makefile.inc
|
---|
[25b0e6a] | 64 |
|
---|
[f5b4fb9] | 65 | ## Simple detection of the host system
|
---|
| 66 | #
|
---|
| 67 | HOST = $(shell uname)
|
---|
| 68 |
|
---|
| 69 | ## On Solaris, some utilities have different names
|
---|
| 70 | #
|
---|
| 71 | ifeq ($(HOST),SunOS)
|
---|
| 72 | BINUTILS_PREFIX = "g"
|
---|
| 73 | else
|
---|
| 74 | BINUTILS_PREFIX = ""
|
---|
| 75 | endif
|
---|
| 76 |
|
---|
[25b0e6a] | 77 | ## Toolchain configuration
|
---|
| 78 | #
|
---|
| 79 |
|
---|
[8786aa5] | 80 | JOBFILE = $(LIBC_PREFIX)/../../../tools/jobfile.py
|
---|
| 81 |
|
---|
[69dc065] | 82 | ifeq ($(COMPILER),gcc_cross)
|
---|
| 83 | CC = $(TOOLCHAIN_DIR)/$(TARGET)-gcc
|
---|
[f563126] | 84 | GCC = $(CC)
|
---|
[69dc065] | 85 | AS = $(TOOLCHAIN_DIR)/$(TARGET)-as
|
---|
| 86 | LD = $(TOOLCHAIN_DIR)/$(TARGET)-ld
|
---|
| 87 | AR = $(TOOLCHAIN_DIR)/$(TARGET)-ar
|
---|
| 88 | OBJCOPY = $(TOOLCHAIN_DIR)/$(TARGET)-objcopy
|
---|
| 89 | OBJDUMP = $(TOOLCHAIN_DIR)/$(TARGET)-objdump
|
---|
[6ab8697] | 90 | CFLAGS = $(GCC_CFLAGS)
|
---|
[69dc065] | 91 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
|
---|
| 92 | endif
|
---|
| 93 |
|
---|
[67f5fbd9] | 94 | ifeq ($(COMPILER),gcc_native)
|
---|
[25b0e6a] | 95 | CC = gcc
|
---|
[f563126] | 96 | GCC = $(CC)
|
---|
[f5b4fb9] | 97 | AS = $(BINUTILS_PREFIX)as
|
---|
| 98 | LD = $(BINUTILS_PREFIX)ld
|
---|
| 99 | AR = $(BINUTILS_PREFIX)ar
|
---|
| 100 | OBJCOPY = $(BINUTILS_PREFIX)objcopy
|
---|
| 101 | OBJDUMP = $(BINUTILS_PREFIX)objdump
|
---|
[6ab8697] | 102 | CFLAGS = $(GCC_CFLAGS)
|
---|
[fcd7053] | 103 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
|
---|
[67f5fbd9] | 104 | endif
|
---|
| 105 |
|
---|
[69dc065] | 106 | ifeq ($(COMPILER),icc)
|
---|
[67f5fbd9] | 107 | CC = icc
|
---|
[f563126] | 108 | GCC = gcc
|
---|
[67f5fbd9] | 109 | AS = as
|
---|
| 110 | LD = ld
|
---|
| 111 | AR = ar
|
---|
| 112 | OBJCOPY = objcopy
|
---|
| 113 | OBJDUMP = objdump
|
---|
[6ab8697] | 114 | CFLAGS = $(ICC_CFLAGS)
|
---|
[fcd7053] | 115 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
|
---|
[67f5fbd9] | 116 | endif
|
---|
| 117 |
|
---|
[69dc065] | 118 | ifeq ($(COMPILER),clang)
|
---|
| 119 | CC = clang
|
---|
[f563126] | 120 | GCC = gcc
|
---|
[69dc065] | 121 | AS = $(BINUTILS_PREFIX)as
|
---|
| 122 | LD = $(BINUTILS_PREFIX)ld
|
---|
| 123 | AR = $(BINUTILS_PREFIX)ar
|
---|
| 124 | OBJCOPY = $(BINUTILS_PREFIX)objcopy
|
---|
| 125 | OBJDUMP = $(BINUTILS_PREFIX)objdump
|
---|
[6ab8697] | 126 | CFLAGS = $(CLANG_CFLAGS)
|
---|
[fcd7053] | 127 | DEPEND_DEFS = $(DEFS) $(CONFIG_DEFS)
|
---|
[25b0e6a] | 128 | endif
|
---|