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 ${MK_CLANG_FULL} != "no" 14CFLAGS+= -DCLANG_ENABLE_ARCMT \ 15 -DCLANG_ENABLE_REWRITER \ 16 -DCLANG_ENABLE_STATIC_ANALYZER 17.endif # 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 ${MACHINE} == "host" && defined(EARLY_BUILD) 44.if !empty(LEGACY_TOOLS) && exists(${LEGACY_TOOLS}/usr/bin/tblgen) 45TOOLSDIR= ${LEGACY_TOOLS} 46.endif 47.endif 48.if ${MK_STAGING} == "yes" 49TOOLSDIR?= ${STAGE_HOST_OBJTOP} 50.endif 51TOOLSDIR?= 52.if !empty(TOOLSDIR) && exists(${TOOLSDIR}/usr/bin/clang-tblgen) 53TBLGEN= ${TOOLSDIR}/usr/bin/tblgen 54CLANG_TBLGEN= ${TOOLSDIR}/usr/bin/clang-tblgen 55.endif 56TBLGEN?= tblgen 57CLANG_TBLGEN?= clang-tblgen 58 59Intrinsics.inc.h: ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td 60 ${TBLGEN} -gen-intrinsic \ 61 -I ${LLVM_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 62 ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td 63.for arch in \ 64 ARM/ARM Mips/Mips PowerPC/PPC Sparc/Sparc X86/X86 65. for hdr in \ 66 AsmMatcher/-gen-asm-matcher \ 67 AsmWriter1/-gen-asm-writer,-asmwriternum=1 \ 68 AsmWriter/-gen-asm-writer \ 69 CallingConv/-gen-callingconv \ 70 CodeEmitter/-gen-emitter \ 71 DAGISel/-gen-dag-isel \ 72 DisassemblerTables/-gen-disassembler \ 73 FastISel/-gen-fast-isel \ 74 InstrInfo/-gen-instr-info \ 75 MCCodeEmitter/-gen-emitter,-mc-emitter \ 76 MCPseudoLowering/-gen-pseudo-lowering \ 77 RegisterInfo/-gen-register-info \ 78 SubtargetInfo/-gen-subtarget 79${arch:T}Gen${hdr:H:C/$/.inc.h/}: ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td 80 ${TBLGEN} ${hdr:T:C/,/ /g} \ 81 -I ${LLVM_SRCS}/include -I ${LLVM_SRCS}/lib/Target/${arch:H} \ 82 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 83 ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td 84. endfor 85.endfor 86 87Attrs.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 88 ${CLANG_TBLGEN} -gen-clang-attr-classes \ 89 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 90 ${CLANG_SRCS}/include/clang/Basic/Attr.td 91 92AttrDump.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 93 ${CLANG_TBLGEN} -gen-clang-attr-dump \ 94 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 95 ${CLANG_SRCS}/include/clang/Basic/Attr.td 96 97AttrIdentifierArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 98 ${CLANG_TBLGEN} -gen-clang-attr-identifier-arg-list \ 99 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 100 ${CLANG_SRCS}/include/clang/Basic/Attr.td 101 102AttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 103 ${CLANG_TBLGEN} -gen-clang-attr-impl \ 104 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 105 ${CLANG_SRCS}/include/clang/Basic/Attr.td 106 107AttrLateParsed.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 108 ${CLANG_TBLGEN} -gen-clang-attr-late-parsed-list \ 109 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 110 ${CLANG_SRCS}/include/clang/Basic/Attr.td 111 112AttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 113 ${CLANG_TBLGEN} -gen-clang-attr-list \ 114 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 115 ${CLANG_SRCS}/include/clang/Basic/Attr.td 116 117AttrParsedAttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 118 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-impl \ 119 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 120 ${CLANG_SRCS}/include/clang/Basic/Attr.td 121 122AttrParsedAttrKinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 123 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-kinds \ 124 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 125 ${CLANG_SRCS}/include/clang/Basic/Attr.td 126 127AttrParsedAttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 128 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-list \ 129 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 130 ${CLANG_SRCS}/include/clang/Basic/Attr.td 131 132AttrPCHRead.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 133 ${CLANG_TBLGEN} -gen-clang-attr-pch-read \ 134 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 135 ${CLANG_SRCS}/include/clang/Basic/Attr.td 136 137AttrPCHWrite.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 138 ${CLANG_TBLGEN} -gen-clang-attr-pch-write \ 139 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 140 ${CLANG_SRCS}/include/clang/Basic/Attr.td 141 142AttrSpellings.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 143 ${CLANG_TBLGEN} -gen-clang-attr-spelling-list \ 144 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 145 ${CLANG_SRCS}/include/clang/Basic/Attr.td 146 147AttrSpellingListIndex.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 148 ${CLANG_TBLGEN} -gen-clang-attr-spelling-index \ 149 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 150 ${CLANG_SRCS}/include/clang/Basic/Attr.td 151 152AttrTemplateInstantiate.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 153 ${CLANG_TBLGEN} -gen-clang-attr-template-instantiate \ 154 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 155 ${CLANG_SRCS}/include/clang/Basic/Attr.td 156 157AttrTypeArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td 158 ${CLANG_TBLGEN} -gen-clang-attr-type-arg-list \ 159 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 160 ${CLANG_SRCS}/include/clang/Basic/Attr.td 161 162CommentCommandInfo.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td 163 ${CLANG_TBLGEN} -gen-clang-comment-command-info \ 164 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 165 ${CLANG_SRCS}/include/clang/AST/CommentCommands.td 166 167CommentCommandList.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td 168 ${CLANG_TBLGEN} -gen-clang-comment-command-list \ 169 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 170 ${CLANG_SRCS}/include/clang/AST/CommentCommands.td 171 172CommentHTMLNamedCharacterReferences.inc.h: \ 173 ${CLANG_SRCS}/include/clang/AST/CommentHTMLNamedCharacterReferences.td 174 ${CLANG_TBLGEN} -gen-clang-comment-html-named-character-references \ 175 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 176 ${CLANG_SRCS}/include/clang/AST/CommentHTMLNamedCharacterReferences.td 177 178CommentHTMLTags.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td 179 ${CLANG_TBLGEN} -gen-clang-comment-html-tags \ 180 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 181 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td 182 183CommentHTMLTagsProperties.inc.h: \ 184 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td 185 ${CLANG_TBLGEN} -gen-clang-comment-html-tags-properties \ 186 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 187 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td 188 189CommentNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/CommentNodes.td 190 ${CLANG_TBLGEN} -gen-clang-comment-nodes \ 191 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 192 ${CLANG_SRCS}/include/clang/Basic/CommentNodes.td 193 194DeclNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td 195 ${CLANG_TBLGEN} -gen-clang-decl-nodes \ 196 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 197 ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td 198 199StmtNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td 200 ${CLANG_TBLGEN} -gen-clang-stmt-nodes \ 201 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 202 ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td 203 204arm_neon.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td 205 ${CLANG_TBLGEN} -gen-arm-neon \ 206 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 207 ${CLANG_SRCS}/include/clang/Basic/arm_neon.td 208 209arm_neon.inc.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td 210 ${CLANG_TBLGEN} -gen-arm-neon-sema \ 211 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 212 ${CLANG_SRCS}/include/clang/Basic/arm_neon.td 213 214DiagnosticGroups.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 215 ${CLANG_TBLGEN} -gen-clang-diag-groups \ 216 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \ 217 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 218 219DiagnosticIndexName.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 220 ${CLANG_TBLGEN} -gen-clang-diags-index-name \ 221 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \ 222 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 223 224.for hdr in AST Analysis Comment Common Driver Frontend Lex Parse Sema Serialization 225Diagnostic${hdr}Kinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 226 ${CLANG_TBLGEN} -gen-clang-diags-defs -clang-component=${hdr} \ 227 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \ 228 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td 229.endfor 230 231Options.inc.h: ${CLANG_SRCS}/include/clang/Driver/Options.td 232 ${TBLGEN} -gen-opt-parser-defs \ 233 -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \ 234 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 235 ${CLANG_SRCS}/include/clang/Driver/Options.td 236 237CC1AsOptions.inc.h: ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td 238 ${TBLGEN} -gen-opt-parser-defs \ 239 -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \ 240 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 241 ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td 242 243Checkers.inc.h: ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td 244 ${CLANG_TBLGEN} -gen-clang-sa-checkers \ 245 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \ 246 ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td 247 248.for dep in ${TGHDRS:C/$/.inc.d/} 249. sinclude "${dep}" 250.endfor 251 252SRCS+= ${TGHDRS:C/$/.inc.h/} 253DPADD+= ${TGHDRS:C/$/.inc.h/} 254CLEANFILES+= ${TGHDRS:C/$/.inc.h/} ${TGHDRS:C/$/.inc.d/} 255 256# if we are not doing explicit 'make depend', there is 257# nothing to cause these to be generated. 258beforebuild: ${SRCS:M*.inc.h} 259