]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - lib/clang/llvm.build.mk
MFV r336851:
[FreeBSD/FreeBSD.git] / lib / clang / llvm.build.mk
1 # $FreeBSD$
2
3 .include <src.opts.mk>
4
5 .ifndef LLVM_SRCS
6 .error Please define LLVM_SRCS before including this file
7 .endif
8
9 .ifndef SRCDIR
10 .error Please define SRCDIR before including this file
11 .endif
12
13 .PATH:          ${LLVM_SRCS}/${SRCDIR}
14
15 CFLAGS+=        -I${SRCTOP}/lib/clang/include
16 CFLAGS+=        -I${LLVM_SRCS}/include
17 CFLAGS+=        -DLLVM_BUILD_GLOBAL_ISEL
18 CFLAGS+=        -D__STDC_LIMIT_MACROS
19 CFLAGS+=        -D__STDC_CONSTANT_MACROS
20 #CFLAGS+=       -DNDEBUG
21
22 TARGET_ARCH?=   ${MACHINE_ARCH}
23 BUILD_ARCH?=    ${MACHINE_ARCH}
24
25 # Armv6 and armv7 uses hard float abi, unless the CPUTYPE has soft in it.
26 # arm (for armv4 and armv5 CPUs) always uses the soft float ABI.
27 # For all other targets, we stick with 'unknown'.
28 .if ${TARGET_ARCH:Marmv[67]*} && (!defined(CPUTYPE) || ${CPUTYPE:M*soft*} == "")
29 TARGET_ABI=     -gnueabihf
30 .elif ${TARGET_ARCH:Marm*}
31 TARGET_ABI=     -gnueabi
32 .else
33 TARGET_ABI=
34 .endif
35 VENDOR=         unknown
36 OS_VERSION=     freebsd12.0
37
38 LLVM_TARGET_TRIPLE?=    ${TARGET_ARCH:C/amd64/x86_64/:C/arm64/aarch64/}-${VENDOR}-${OS_VERSION}${TARGET_ABI}
39 LLVM_BUILD_TRIPLE?=     ${BUILD_ARCH:C/amd64/x86_64/:C/arm64/aarch64/}-${VENDOR}-${OS_VERSION}
40
41 CFLAGS+=        -DLLVM_DEFAULT_TARGET_TRIPLE=\"${LLVM_TARGET_TRIPLE}\"
42 CFLAGS+=        -DLLVM_HOST_TRIPLE=\"${LLVM_BUILD_TRIPLE}\"
43 CFLAGS+=        -DDEFAULT_SYSROOT=\"${TOOLS_PREFIX}\"
44
45 .if ${MK_LLVM_TARGET_AARCH64} != "no"
46 CFLAGS+=        -DLLVM_TARGET_ENABLE_AARCH64
47 . if ${MACHINE_CPUARCH} == "aarch64"
48 LLVM_NATIVE_ARCH=       AArch64
49 . endif
50 .endif
51 .if ${MK_LLVM_TARGET_ARM} != "no"
52 CFLAGS+=        -DLLVM_TARGET_ENABLE_ARM
53 . if ${MACHINE_CPUARCH} == "arm"
54 LLVM_NATIVE_ARCH=       ARM
55 . endif
56 .endif
57 .if ${MK_LLVM_TARGET_MIPS} != "no"
58 CFLAGS+=        -DLLVM_TARGET_ENABLE_MIPS
59 . if ${MACHINE_CPUARCH} == "mips"
60 LLVM_NATIVE_ARCH=       Mips
61 . endif
62 .endif
63 .if ${MK_LLVM_TARGET_POWERPC} != "no"
64 CFLAGS+=        -DLLVM_TARGET_ENABLE_POWERPC
65 . if ${MACHINE_CPUARCH} == "powerpc"
66 LLVM_NATIVE_ARCH=       PowerPC
67 . endif
68 .endif
69 .if ${MK_LLVM_TARGET_SPARC} != "no"
70 CFLAGS+=        -DLLVM_TARGET_ENABLE_SPARC
71 . if ${MACHINE_CPUARCH} == "sparc64"
72 LLVM_NATIVE_ARCH=       Sparc
73 . endif
74 .endif
75 .if ${MK_LLVM_TARGET_X86} != "no"
76 CFLAGS+=        -DLLVM_TARGET_ENABLE_X86
77 . if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
78 LLVM_NATIVE_ARCH=       X86
79 . endif
80 .endif
81
82 .ifdef LLVM_NATIVE_ARCH
83 CFLAGS+=        -DLLVM_NATIVE_ASMPARSER=LLVMInitialize${LLVM_NATIVE_ARCH}AsmParser
84 CFLAGS+=        -DLLVM_NATIVE_ASMPRINTER=LLVMInitialize${LLVM_NATIVE_ARCH}AsmPrinter
85 CFLAGS+=        -DLLVM_NATIVE_DISASSEMBLER=LLVMInitialize${LLVM_NATIVE_ARCH}Disassembler
86 CFLAGS+=        -DLLVM_NATIVE_TARGET=LLVMInitialize${LLVM_NATIVE_ARCH}Target
87 CFLAGS+=        -DLLVM_NATIVE_TARGETINFO=LLVMInitialize${LLVM_NATIVE_ARCH}TargetInfo
88 CFLAGS+=        -DLLVM_NATIVE_TARGETMC=LLVMInitialize${LLVM_NATIVE_ARCH}TargetMC
89 .endif
90
91 CFLAGS+=        -ffunction-sections
92 CFLAGS+=        -fdata-sections
93 LDFLAGS+=       -Wl,--gc-sections
94
95 CXXFLAGS+=      -std=c++11
96 CXXFLAGS+=      -fno-exceptions
97 CXXFLAGS+=      -fno-rtti
98 CXXFLAGS.clang+= -stdlib=libc++
99
100 .if ${MACHINE_CPUARCH} == "arm"
101 STATIC_CFLAGS+= -mlong-calls
102 STATIC_CXXFLAGS+= -mlong-calls
103 .endif