5 CLANG_SRCS= ${LLVM_SRCS}/tools/clang
7 CFLAGS+= -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
13 .if ${MK_CLANG_FULL} != "no"
14 CFLAGS+= -DCLANG_ENABLE_ARCMT \
15 -DCLANG_ENABLE_REWRITER \
16 -DCLANG_ENABLE_STATIC_ANALYZER
17 .endif # MK_CLANG_FULL
19 # LLVM is not strict aliasing safe as of 12/31/2011
20 CFLAGS+= -fno-strict-aliasing
22 TARGET_ARCH?= ${MACHINE_ARCH}
23 BUILD_ARCH?= ${MACHINE_ARCH}
25 .if (${TARGET_ARCH} == "arm" || ${TARGET_ARCH} == "armv6") && \
26 ${MK_ARM_EABI} != "no"
28 .elif ${TARGET_ARCH} == "armv6hf"
34 TARGET_TRIPLE?= ${TARGET_ARCH:C/amd64/x86_64/:C/armv6hf/armv6/}-${TARGET_ABI}-freebsd11.0
35 BUILD_TRIPLE?= ${BUILD_ARCH:C/amd64/x86_64/:C/armv6hf/armv6/}-unknown-freebsd11.0
36 CFLAGS+= -DLLVM_DEFAULT_TARGET_TRIPLE=\"${TARGET_TRIPLE}\" \
37 -DLLVM_HOST_TRIPLE=\"${BUILD_TRIPLE}\" \
38 -DDEFAULT_SYSROOT=\"${TOOLS_PREFIX}\"
39 CXXFLAGS+= -fno-exceptions -fno-rtti
41 .PATH: ${LLVM_SRCS}/${SRCDIR}
44 CLANG_TBLGEN?= clang-tblgen
46 Intrinsics.inc.h: ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td
47 ${TBLGEN} -gen-intrinsic \
48 -I ${LLVM_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
49 ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td
51 ARM/ARM Mips/Mips PowerPC/PPC Sparc/Sparc X86/X86
53 AsmMatcher/-gen-asm-matcher \
54 AsmWriter1/-gen-asm-writer,-asmwriternum=1 \
55 AsmWriter/-gen-asm-writer \
56 CallingConv/-gen-callingconv \
57 CodeEmitter/-gen-emitter \
58 DAGISel/-gen-dag-isel \
59 DisassemblerTables/-gen-disassembler \
60 FastISel/-gen-fast-isel \
61 InstrInfo/-gen-instr-info \
62 MCCodeEmitter/-gen-emitter,-mc-emitter \
63 MCPseudoLowering/-gen-pseudo-lowering \
64 RegisterInfo/-gen-register-info \
65 SubtargetInfo/-gen-subtarget
66 ${arch:T}Gen${hdr:H:C/$/.inc.h/}: ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td
67 ${TBLGEN} ${hdr:T:C/,/ /g} \
68 -I ${LLVM_SRCS}/include -I ${LLVM_SRCS}/lib/Target/${arch:H} \
69 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
70 ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td
74 Attrs.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
75 ${CLANG_TBLGEN} -gen-clang-attr-classes \
76 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
77 ${CLANG_SRCS}/include/clang/Basic/Attr.td
79 AttrDump.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
80 ${CLANG_TBLGEN} -gen-clang-attr-dump \
81 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
82 ${CLANG_SRCS}/include/clang/Basic/Attr.td
84 AttrIdentifierArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
85 ${CLANG_TBLGEN} -gen-clang-attr-identifier-arg-list \
86 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
87 ${CLANG_SRCS}/include/clang/Basic/Attr.td
89 AttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
90 ${CLANG_TBLGEN} -gen-clang-attr-impl \
91 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
92 ${CLANG_SRCS}/include/clang/Basic/Attr.td
94 AttrLateParsed.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
95 ${CLANG_TBLGEN} -gen-clang-attr-late-parsed-list \
96 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
97 ${CLANG_SRCS}/include/clang/Basic/Attr.td
99 AttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
100 ${CLANG_TBLGEN} -gen-clang-attr-list \
101 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
102 ${CLANG_SRCS}/include/clang/Basic/Attr.td
104 AttrParsedAttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
105 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-impl \
106 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
107 ${CLANG_SRCS}/include/clang/Basic/Attr.td
109 AttrParsedAttrKinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
110 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-kinds \
111 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
112 ${CLANG_SRCS}/include/clang/Basic/Attr.td
114 AttrParsedAttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
115 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-list \
116 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
117 ${CLANG_SRCS}/include/clang/Basic/Attr.td
119 AttrPCHRead.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
120 ${CLANG_TBLGEN} -gen-clang-attr-pch-read \
121 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
122 ${CLANG_SRCS}/include/clang/Basic/Attr.td
124 AttrPCHWrite.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
125 ${CLANG_TBLGEN} -gen-clang-attr-pch-write \
126 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
127 ${CLANG_SRCS}/include/clang/Basic/Attr.td
129 AttrSpellings.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
130 ${CLANG_TBLGEN} -gen-clang-attr-spelling-list \
131 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
132 ${CLANG_SRCS}/include/clang/Basic/Attr.td
134 AttrSpellingListIndex.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
135 ${CLANG_TBLGEN} -gen-clang-attr-spelling-index \
136 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
137 ${CLANG_SRCS}/include/clang/Basic/Attr.td
139 AttrTemplateInstantiate.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
140 ${CLANG_TBLGEN} -gen-clang-attr-template-instantiate \
141 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
142 ${CLANG_SRCS}/include/clang/Basic/Attr.td
144 AttrTypeArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
145 ${CLANG_TBLGEN} -gen-clang-attr-type-arg-list \
146 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
147 ${CLANG_SRCS}/include/clang/Basic/Attr.td
149 CommentCommandInfo.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
150 ${CLANG_TBLGEN} -gen-clang-comment-command-info \
151 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
152 ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
154 CommentCommandList.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
155 ${CLANG_TBLGEN} -gen-clang-comment-command-list \
156 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
157 ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
159 CommentHTMLNamedCharacterReferences.inc.h: \
160 ${CLANG_SRCS}/include/clang/AST/CommentHTMLNamedCharacterReferences.td
161 ${CLANG_TBLGEN} -gen-clang-comment-html-named-character-references \
162 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
163 ${CLANG_SRCS}/include/clang/AST/CommentHTMLNamedCharacterReferences.td
165 CommentHTMLTags.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
166 ${CLANG_TBLGEN} -gen-clang-comment-html-tags \
167 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
168 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
170 CommentHTMLTagsProperties.inc.h: \
171 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
172 ${CLANG_TBLGEN} -gen-clang-comment-html-tags-properties \
173 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
174 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
176 CommentNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/CommentNodes.td
177 ${CLANG_TBLGEN} -gen-clang-comment-nodes \
178 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
179 ${CLANG_SRCS}/include/clang/Basic/CommentNodes.td
181 DeclNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td
182 ${CLANG_TBLGEN} -gen-clang-decl-nodes \
183 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
184 ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td
186 StmtNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td
187 ${CLANG_TBLGEN} -gen-clang-stmt-nodes \
188 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
189 ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td
191 arm_neon.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
192 ${CLANG_TBLGEN} -gen-arm-neon \
193 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
194 ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
196 arm_neon.inc.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
197 ${CLANG_TBLGEN} -gen-arm-neon-sema \
198 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
199 ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
201 DiagnosticGroups.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
202 ${CLANG_TBLGEN} -gen-clang-diag-groups \
203 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \
204 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
206 DiagnosticIndexName.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
207 ${CLANG_TBLGEN} -gen-clang-diags-index-name \
208 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \
209 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
211 .for hdr in AST Analysis Comment Common Driver Frontend Lex Parse Sema Serialization
212 Diagnostic${hdr}Kinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
213 ${CLANG_TBLGEN} -gen-clang-diags-defs -clang-component=${hdr} \
214 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \
215 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
218 Options.inc.h: ${CLANG_SRCS}/include/clang/Driver/Options.td
219 ${TBLGEN} -gen-opt-parser-defs \
220 -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \
221 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
222 ${CLANG_SRCS}/include/clang/Driver/Options.td
224 CC1AsOptions.inc.h: ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td
225 ${TBLGEN} -gen-opt-parser-defs \
226 -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \
227 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
228 ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td
230 Checkers.inc.h: ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td
231 ${CLANG_TBLGEN} -gen-clang-sa-checkers \
232 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
233 ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td
235 .for dep in ${TGHDRS:C/$/.inc.d/}
239 SRCS+= ${TGHDRS:C/$/.inc.h/}
240 DPSRCS+= ${TGHDRS:C/$/.inc.h/}
241 CLEANFILES+= ${TGHDRS:C/$/.inc.h/} ${TGHDRS:C/$/.inc.d/}