6 .error Please define LLVM_BASE before including this file
10 .error Please define LLVM_SRCS before including this file
14 .error Please define SRCDIR before including this file
17 .PATH: ${LLVM_BASE}/${SRCDIR}
19 CFLAGS+= -I${SRCTOP}/lib/clang/include
20 CFLAGS+= -I${LLVM_SRCS}/include
21 CFLAGS+= -D__STDC_CONSTANT_MACROS
22 CFLAGS+= -D__STDC_FORMAT_MACROS
23 CFLAGS+= -D__STDC_LIMIT_MACROS
24 CFLAGS+= -DHAVE_VCS_VERSION_INC
25 .if ${MK_LLVM_ASSERTIONS} == "no"
29 TARGET_ARCH?= ${MACHINE_ARCH}
30 BUILD_ARCH?= ${MACHINE_ARCH}
32 # Armv6 and armv7 uses hard float abi, unless the CPUTYPE has soft in it.
33 # arm (for armv4 and armv5 CPUs) always uses the soft float ABI.
34 # For all other targets, we stick with 'unknown'.
35 .if ${TARGET_ARCH:Marmv[67]*} && (!defined(CPUTYPE) || ${CPUTYPE:M*soft*} == "")
36 TARGET_ABI= -gnueabihf
37 .elif ${TARGET_ARCH:Marm*}
43 OS_VERSION= freebsd13.0
45 LLVM_TARGET_TRIPLE?= ${TARGET_ARCH:C/amd64/x86_64/:C/[hs]f$//:S/mipsn32/mips64/}-${VENDOR}-${OS_VERSION}${TARGET_ABI}
46 LLVM_BUILD_TRIPLE?= ${BUILD_ARCH:C/amd64/x86_64/:C/[hs]f$//:S/mipsn32/mips64/}-${VENDOR}-${OS_VERSION}
48 CFLAGS+= -DLLVM_DEFAULT_TARGET_TRIPLE=\"${LLVM_TARGET_TRIPLE}\"
49 CFLAGS+= -DLLVM_HOST_TRIPLE=\"${LLVM_BUILD_TRIPLE}\"
50 CFLAGS+= -DDEFAULT_SYSROOT=\"${TOOLS_PREFIX}\"
52 .if ${MK_LLVM_TARGET_AARCH64} != "no"
53 CFLAGS+= -DLLVM_TARGET_ENABLE_AARCH64
54 . if ${MACHINE_CPUARCH} == "aarch64"
55 LLVM_NATIVE_ARCH= AArch64
58 .if ${MK_LLVM_TARGET_ARM} != "no"
59 CFLAGS+= -DLLVM_TARGET_ENABLE_ARM
60 . if ${MACHINE_CPUARCH} == "arm"
64 .if ${MK_LLVM_TARGET_BPF} != "no"
65 CFLAGS+= -DLLVM_TARGET_ENABLE_BPF
67 .if ${MK_LLVM_TARGET_MIPS} != "no"
68 CFLAGS+= -DLLVM_TARGET_ENABLE_MIPS
69 . if ${MACHINE_CPUARCH} == "mips"
70 LLVM_NATIVE_ARCH= Mips
73 .if ${MK_LLVM_TARGET_POWERPC} != "no"
74 CFLAGS+= -DLLVM_TARGET_ENABLE_POWERPC
75 . if ${MACHINE_CPUARCH} == "powerpc"
76 LLVM_NATIVE_ARCH= PowerPC
79 .if ${MK_LLVM_TARGET_RISCV} != "no"
80 CFLAGS+= -DLLVM_TARGET_ENABLE_RISCV
81 . if ${MACHINE_CPUARCH} == "riscv"
82 LLVM_NATIVE_ARCH= RISCV
85 .if ${MK_LLVM_TARGET_X86} != "no"
86 CFLAGS+= -DLLVM_TARGET_ENABLE_X86
87 . if ${MACHINE_CPUARCH} == "i386" || ${MACHINE_CPUARCH} == "amd64"
92 .ifdef LLVM_NATIVE_ARCH
93 CFLAGS+= -DLLVM_NATIVE_ASMPARSER=LLVMInitialize${LLVM_NATIVE_ARCH}AsmParser
94 CFLAGS+= -DLLVM_NATIVE_ASMPRINTER=LLVMInitialize${LLVM_NATIVE_ARCH}AsmPrinter
95 CFLAGS+= -DLLVM_NATIVE_DISASSEMBLER=LLVMInitialize${LLVM_NATIVE_ARCH}Disassembler
96 CFLAGS+= -DLLVM_NATIVE_TARGET=LLVMInitialize${LLVM_NATIVE_ARCH}Target
97 CFLAGS+= -DLLVM_NATIVE_TARGETINFO=LLVMInitialize${LLVM_NATIVE_ARCH}TargetInfo
98 CFLAGS+= -DLLVM_NATIVE_TARGETMC=LLVMInitialize${LLVM_NATIVE_ARCH}TargetMC
101 CFLAGS+= -ffunction-sections
102 CFLAGS+= -fdata-sections
103 LDFLAGS+= -Wl,--gc-sections
106 CXXFLAGS+= -fno-exceptions
108 CXXFLAGS.clang+= -stdlib=libc++
110 .if ${MACHINE_ARCH:Mmips64}
111 STATIC_CFLAGS+= -mxgot
112 STATIC_CXXFLAGS+= -mxgot