1# $FreeBSD$ 2 3.include <src.opts.mk> 4 5CLANG_SRCS= ${LLVM_SRCS}/tools/clang 6 7CFLAGS+= -I${LLVM_SRCS}/include -I${CLANG_SRCS}/include \ 8 -I${LLVM_SRCS}/${SRCDIR} ${INCDIR:C/^/-I${LLVM_SRCS}\//} -I. \ 9 -I${LLVM_SRCS}/../../lib/clang/include \ 10 -DLLVM_ON_UNIX -DLLVM_ON_FREEBSD \ 11 -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS #-DNDEBUG 12 13.if !defined(EARLY_BUILD) && defined(MK_CLANG_FULL) && ${MK_CLANG_FULL} != "no" 14CFLAGS+= -DCLANG_ENABLE_ARCMT \ 15 -DCLANG_ENABLE_REWRITER \ 16 -DCLANG_ENABLE_STATIC_ANALYZER 17.endif # !EARLY_BUILD && MK_CLANG_FULL 18 19# LLVM is not strict aliasing safe as of 12/31/2011 20CFLAGS+= -fno-strict-aliasing 21 22TARGET_ARCH?= ${MACHINE_ARCH} 23BUILD_ARCH?= ${MACHINE_ARCH} 24 25.if (${TARGET_ARCH} == "arm" || ${TARGET_ARCH} == "armv6") && \ 26 ${MK_ARM_EABI} != "no" 27TARGET_ABI= gnueabi 28.elif ${TARGET_ARCH} == "armv6hf" 29TARGET_ABI= gnueabihf 30.else 31TARGET_ABI= unknown 32.endif 33 34TARGET_TRIPLE?= ${TARGET_ARCH:C/amd64/x86_64/:C/armv6hf/armv6/}-${TARGET_ABI}-freebsd11.0 35BUILD_TRIPLE?= ${BUILD_ARCH:C/amd64/x86_64/:C/armv6hf/armv6/}-unknown-freebsd11.0 36CFLAGS+= -DLLVM_DEFAULT_TARGET_TRIPLE=\"${TARGET_TRIPLE}\" \ 37 -DLLVM_HOST_TRIPLE=\"${BUILD_TRIPLE}\" \ 38 -DDEFAULT_SYSROOT=\"${TOOLS_PREFIX}\" 39CXXFLAGS+= -fno-exceptions -fno-rtti 40 41.PATH: ${LLVM_SRCS}/${SRCDIR} 42 43.if ${MK_STAGING} == "yes" 44TBLGEN= ${STAGE_HOST_OBJTOP}/usr/bin/tblgen 45CLANG_TBLGEN= ${STAGE_HOST_OBJTOP}/usr/bin/clang-tblgen 46.endif 47TBLGEN?= tblgen 48CLANG_TBLGEN?= clang-tblgen 49 50Intrinsics.inc.h: ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td \ 51 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsARM.td \ 52 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsHexagon.td \ 53 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsMips.td \ 54 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsNVVM.td \ 55 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsPowerPC.td \ 56 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsR600.td \ 57 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsX86.td \ 58 ${LLVM_SRCS}/include/llvm/IR/IntrinsicsXCore.td 59 ${TBLGEN} -I ${LLVM_SRCS}/include \ 60 -gen-intrinsic -o ${.TARGET} \ 61 ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td 62.for arch in \ 63 ARM/ARM Mips/Mips PowerPC/PPC Sparc/Sparc X86/X86 64. for hdr in \ 65 AsmMatcher/-gen-asm-matcher \ 66 AsmWriter1/-gen-asm-writer,-asmwriternum=1 \ 67 AsmWriter/-gen-asm-writer \ 68 CallingConv/-gen-callingconv \ 69 CodeEmitter/-gen-emitter \ 70 DAGISel/-gen-dag-isel \ 71 DisassemblerTables/-gen-disassembler \ 72 FastISel/-gen-fast-isel \ 73 InstrInfo/-gen-instr-info \ 74 MCCodeEmitter/-gen-emitter,-mc-emitter \ 75 MCPseudoLowering/-gen-pseudo-lowering \ 76 RegisterInfo/-gen-register-info \ 77 SubtargetInfo/-gen-subtarget 78${arch:T}Gen${hdr:H:C/$/.inc.h/}: ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td 79 ${TBLGEN} -I ${LLVM_SRCS}/include -I ${LLVM_SRCS}/lib/Target/${arch:H} \ 80 ${hdr:T:C/,/ /g} -o ${.TARGET} \ 81 ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td 82. endfor 83.endfor 84 85Attrs.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 86 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 87 -gen-clang-attr-classes -o ${.TARGET} ${.ALLSRC} 88 89AttrDump.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 90 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 91 -gen-clang-attr-dump -o ${.TARGET} ${.ALLSRC} 92 93AttrIdentifierArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 94 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 95 -gen-clang-attr-identifier-arg-list -o ${.TARGET} ${.ALLSRC} 96 97AttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 98 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 99 -gen-clang-attr-impl -o ${.TARGET} ${.ALLSRC} 100 101AttrLateParsed.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 102 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 103 -gen-clang-attr-late-parsed-list -o ${.TARGET} ${.ALLSRC} 104 105AttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 106 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 107 -gen-clang-attr-list -o ${.TARGET} ${.ALLSRC} 108 109AttrParsedAttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 110 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 111 -gen-clang-attr-parsed-attr-impl -o ${.TARGET} ${.ALLSRC} 112 113AttrParsedAttrKinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 114 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 115 -gen-clang-attr-parsed-attr-kinds -o ${.TARGET} ${.ALLSRC} 116 117AttrParsedAttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 118 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 119 -gen-clang-attr-parsed-attr-list -o ${.TARGET} ${.ALLSRC} 120 121AttrPCHRead.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 122 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 123 -gen-clang-attr-pch-read -o ${.TARGET} ${.ALLSRC} 124 125AttrPCHWrite.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 126 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 127 -gen-clang-attr-pch-write -o ${.TARGET} ${.ALLSRC} 128 129AttrSpellings.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 130 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 131 -gen-clang-attr-spelling-list -o ${.TARGET} ${.ALLSRC} 132 133AttrSpellingListIndex.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 134 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 135 -gen-clang-attr-spelling-index -o ${.TARGET} ${.ALLSRC} 136 137AttrTemplateInstantiate.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 138 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 139 -gen-clang-attr-template-instantiate -o ${.TARGET} ${.ALLSRC} 140 141AttrTypeArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 142 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 143 -gen-clang-attr-type-arg-list -o ${.TARGET} ${.ALLSRC} 144 145CommentCommandInfo.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td 146 ${CLANG_TBLGEN} \ 147 -gen-clang-comment-command-info -o ${.TARGET} ${.ALLSRC} 148 149CommentCommandList.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td 150 ${CLANG_TBLGEN} \ 151 -gen-clang-comment-command-list -o ${.TARGET} ${.ALLSRC} 152 153CommentHTMLNamedCharacterReferences.inc.h: \ 154 ${CLANG_SRCS}/include/clang/AST/CommentHTMLNamedCharacterReferences.td 155 ${CLANG_TBLGEN} \ 156 -gen-clang-comment-html-named-character-references -o ${.TARGET} \ 157 ${.ALLSRC} 158 159CommentHTMLTags.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td 160 ${CLANG_TBLGEN} \ 161 -gen-clang-comment-html-tags -o ${.TARGET} ${.ALLSRC} 162 163CommentHTMLTagsProperties.inc.h: \ 164 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td 165 ${CLANG_TBLGEN} \ 166 -gen-clang-comment-html-tags-properties -o ${.TARGET} ${.ALLSRC} 167 168CommentNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/CommentNodes.td 169 ${CLANG_TBLGEN} \ 170 -gen-clang-comment-nodes -o ${.TARGET} ${.ALLSRC} 171 172DeclNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td 173 ${CLANG_TBLGEN} \ 174 -gen-clang-decl-nodes -o ${.TARGET} ${.ALLSRC} 175 176StmtNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td 177 ${CLANG_TBLGEN} \ 178 -gen-clang-stmt-nodes -o ${.TARGET} ${.ALLSRC} 179 180arm_neon.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td 181 ${CLANG_TBLGEN} \ 182 -gen-arm-neon -o ${.TARGET} ${.ALLSRC} 183 184arm_neon.inc.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td 185 ${CLANG_TBLGEN} \ 186 -gen-arm-neon-sema -o ${.TARGET} ${.ALLSRC} 187 188DiagnosticGroups.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 189 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic \ 190 -gen-clang-diag-groups -o ${.TARGET} ${.ALLSRC} 191 192DiagnosticIndexName.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 193 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic \ 194 -gen-clang-diags-index-name -o ${.TARGET} ${.ALLSRC} 195 196.for hdr in AST Analysis Comment Common Driver Frontend Lex Parse Sema Serialization 197Diagnostic${hdr}Kinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 198 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic \ 199 -gen-clang-diags-defs -clang-component=${hdr} -o ${.TARGET} \ 200 ${.ALLSRC} 201.endfor 202 203Options.inc.h: ${CLANG_SRCS}/include/clang/Driver/Options.td 204 ${TBLGEN} -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \ 205 -gen-opt-parser-defs -o ${.TARGET} ${.ALLSRC} 206 207CC1AsOptions.inc.h: ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td 208 ${TBLGEN} -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \ 209 -gen-opt-parser-defs -o ${.TARGET} ${.ALLSRC} 210 211Checkers.inc.h: ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td \ 212 ${CLANG_SRCS}/include/clang/StaticAnalyzer/Checkers/CheckerBase.td 213 ${CLANG_TBLGEN} -I ${CLANG_SRCS}/include \ 214 -gen-clang-sa-checkers -o ${.TARGET} \ 215 ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td 216 217SRCS+= ${TGHDRS:C/$/.inc.h/} 218DPADD+= ${TGHDRS:C/$/.inc.h/} 219CLEANFILES+= ${TGHDRS:C/$/.inc.h/} 220 221# if we are not doing explicit 'make depend', there is 222# nothing to cause these to be generated. 223beforebuild: ${SRCS:M*.inc.h} 224