3 CLANG_SRCS= ${LLVM_SRCS}/tools/clang
5 CFLAGS+= -I${LLVM_SRCS}/include -I${CLANG_SRCS}/include \
6 -I${LLVM_SRCS}/${SRCDIR} ${INCDIR:C/^/-I${LLVM_SRCS}\//} -I. \
7 -I${LLVM_SRCS}/../../lib/clang/include \
8 -DLLVM_ON_UNIX -DLLVM_ON_FREEBSD \
9 -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS -DNDEBUG
11 .if !defined(EARLY_BUILD) && defined(MK_CLANG_FULL) && ${MK_CLANG_FULL} != "no"
12 CFLAGS+= -DCLANG_ENABLE_ARCMT \
13 -DCLANG_ENABLE_REWRITER \
14 -DCLANG_ENABLE_STATIC_ANALYZER
15 .endif # !EARLY_BUILD && MK_CLANG_FULL
17 # LLVM is not strict aliasing safe as of 12/31/2011
18 CFLAGS+= -fno-strict-aliasing
20 TARGET_ARCH?= ${MACHINE_ARCH}
21 BUILD_ARCH?= ${MACHINE_ARCH}
23 .if (${TARGET_ARCH} == "arm" || ${TARGET_ARCH} == "armv6") && \
24 ${MK_ARM_EABI} != "no"
30 TARGET_TRIPLE?= ${TARGET_ARCH:C/amd64/x86_64/}-${TARGET_ABI}-freebsd10.4
31 BUILD_TRIPLE?= ${BUILD_ARCH:C/amd64/x86_64/}-unknown-freebsd10.4
32 CFLAGS+= -DLLVM_DEFAULT_TARGET_TRIPLE=\"${TARGET_TRIPLE}\" \
33 -DLLVM_HOST_TRIPLE=\"${BUILD_TRIPLE}\" \
34 -DDEFAULT_SYSROOT=\"${TOOLS_PREFIX}\"
35 # Work around gcc 4.2 "section type conflict" bug with -fdata-sections on
36 # powerpc: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=33168
37 .if !(${MACHINE_CPUARCH} == "powerpc" && ${COMPILER_TYPE} == "gcc" && \
38 ${COMPILER_VERSION} < 40300)
39 CFLAGS+= -ffunction-sections -fdata-sections
40 LDFLAGS+= -Wl,--gc-sections
42 CXXFLAGS+= -fno-exceptions -fno-rtti
44 .PATH: ${LLVM_SRCS}/${SRCDIR}
47 CLANG_TBLGEN?= clang-tblgen
49 Intrinsics.inc.h: ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td
50 ${TBLGEN} -gen-intrinsic \
51 -I ${LLVM_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
52 ${LLVM_SRCS}/include/llvm/IR/Intrinsics.td
54 ARM/ARM Mips/Mips PowerPC/PPC Sparc/Sparc X86/X86
56 AsmMatcher/-gen-asm-matcher \
57 AsmWriter1/-gen-asm-writer,-asmwriternum=1 \
58 AsmWriter/-gen-asm-writer \
59 CallingConv/-gen-callingconv \
60 CodeEmitter/-gen-emitter \
61 DAGISel/-gen-dag-isel \
62 DisassemblerTables/-gen-disassembler \
63 FastISel/-gen-fast-isel \
64 InstrInfo/-gen-instr-info \
65 MCCodeEmitter/-gen-emitter,-mc-emitter \
66 MCPseudoLowering/-gen-pseudo-lowering \
67 RegisterInfo/-gen-register-info \
68 SubtargetInfo/-gen-subtarget
69 ${arch:T}Gen${hdr:H:C/$/.inc.h/}: ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td
70 ${TBLGEN} ${hdr:T:C/,/ /g} \
71 -I ${LLVM_SRCS}/include -I ${LLVM_SRCS}/lib/Target/${arch:H} \
72 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
73 ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td
77 Attrs.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
78 ${CLANG_TBLGEN} -gen-clang-attr-classes \
79 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
80 ${CLANG_SRCS}/include/clang/Basic/Attr.td
82 AttrDump.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
83 ${CLANG_TBLGEN} -gen-clang-attr-dump \
84 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
85 ${CLANG_SRCS}/include/clang/Basic/Attr.td
87 AttrIdentifierArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
88 ${CLANG_TBLGEN} -gen-clang-attr-identifier-arg-list \
89 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
90 ${CLANG_SRCS}/include/clang/Basic/Attr.td
92 AttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
93 ${CLANG_TBLGEN} -gen-clang-attr-impl \
94 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
95 ${CLANG_SRCS}/include/clang/Basic/Attr.td
97 AttrLateParsed.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
98 ${CLANG_TBLGEN} -gen-clang-attr-late-parsed-list \
99 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
100 ${CLANG_SRCS}/include/clang/Basic/Attr.td
102 AttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
103 ${CLANG_TBLGEN} -gen-clang-attr-list \
104 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
105 ${CLANG_SRCS}/include/clang/Basic/Attr.td
107 AttrParsedAttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
108 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-impl \
109 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
110 ${CLANG_SRCS}/include/clang/Basic/Attr.td
112 AttrParsedAttrKinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
113 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-kinds \
114 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
115 ${CLANG_SRCS}/include/clang/Basic/Attr.td
117 AttrParsedAttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
118 ${CLANG_TBLGEN} -gen-clang-attr-parsed-attr-list \
119 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
120 ${CLANG_SRCS}/include/clang/Basic/Attr.td
122 AttrPCHRead.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
123 ${CLANG_TBLGEN} -gen-clang-attr-pch-read \
124 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
125 ${CLANG_SRCS}/include/clang/Basic/Attr.td
127 AttrPCHWrite.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
128 ${CLANG_TBLGEN} -gen-clang-attr-pch-write \
129 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
130 ${CLANG_SRCS}/include/clang/Basic/Attr.td
132 AttrSpellings.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
133 ${CLANG_TBLGEN} -gen-clang-attr-spelling-list \
134 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
135 ${CLANG_SRCS}/include/clang/Basic/Attr.td
137 AttrSpellingListIndex.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
138 ${CLANG_TBLGEN} -gen-clang-attr-spelling-index \
139 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
140 ${CLANG_SRCS}/include/clang/Basic/Attr.td
142 AttrTemplateInstantiate.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
143 ${CLANG_TBLGEN} -gen-clang-attr-template-instantiate \
144 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
145 ${CLANG_SRCS}/include/clang/Basic/Attr.td
147 AttrTypeArg.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
148 ${CLANG_TBLGEN} -gen-clang-attr-type-arg-list \
149 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
150 ${CLANG_SRCS}/include/clang/Basic/Attr.td
152 CommentCommandInfo.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
153 ${CLANG_TBLGEN} -gen-clang-comment-command-info \
154 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
155 ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
157 CommentCommandList.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
158 ${CLANG_TBLGEN} -gen-clang-comment-command-list \
159 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
160 ${CLANG_SRCS}/include/clang/AST/CommentCommands.td
162 CommentHTMLNamedCharacterReferences.inc.h: \
163 ${CLANG_SRCS}/include/clang/AST/CommentHTMLNamedCharacterReferences.td
164 ${CLANG_TBLGEN} -gen-clang-comment-html-named-character-references \
165 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
166 ${CLANG_SRCS}/include/clang/AST/CommentHTMLNamedCharacterReferences.td
168 CommentHTMLTags.inc.h: ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
169 ${CLANG_TBLGEN} -gen-clang-comment-html-tags \
170 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
171 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
173 CommentHTMLTagsProperties.inc.h: \
174 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
175 ${CLANG_TBLGEN} -gen-clang-comment-html-tags-properties \
176 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
177 ${CLANG_SRCS}/include/clang/AST/CommentHTMLTags.td
179 CommentNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/CommentNodes.td
180 ${CLANG_TBLGEN} -gen-clang-comment-nodes \
181 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
182 ${CLANG_SRCS}/include/clang/Basic/CommentNodes.td
184 DeclNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td
185 ${CLANG_TBLGEN} -gen-clang-decl-nodes \
186 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
187 ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td
189 StmtNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td
190 ${CLANG_TBLGEN} -gen-clang-stmt-nodes \
191 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
192 ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td
194 arm_neon.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
195 ${CLANG_TBLGEN} -gen-arm-neon \
196 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
197 ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
199 arm_neon.inc.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
200 ${CLANG_TBLGEN} -gen-arm-neon-sema \
201 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
202 ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
204 DiagnosticGroups.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
205 ${CLANG_TBLGEN} -gen-clang-diag-groups \
206 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \
207 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
209 DiagnosticIndexName.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
210 ${CLANG_TBLGEN} -gen-clang-diags-index-name \
211 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \
212 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
214 .for hdr in AST Analysis Comment Common Driver Frontend Lex Parse Sema Serialization
215 Diagnostic${hdr}Kinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
216 ${CLANG_TBLGEN} -gen-clang-diags-defs -clang-component=${hdr} \
217 -I ${CLANG_SRCS}/include/clang/Basic -d ${.TARGET:C/\.h$/.d/} \
218 -o ${.TARGET} ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
221 Options.inc.h: ${CLANG_SRCS}/include/clang/Driver/Options.td
222 ${TBLGEN} -gen-opt-parser-defs \
223 -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \
224 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
225 ${CLANG_SRCS}/include/clang/Driver/Options.td
227 CC1AsOptions.inc.h: ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td
228 ${TBLGEN} -gen-opt-parser-defs \
229 -I ${LLVM_SRCS}/include -I ${CLANG_SRCS}/include/clang/Driver \
230 -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
231 ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td
233 Checkers.inc.h: ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td
234 ${CLANG_TBLGEN} -gen-clang-sa-checkers \
235 -I ${CLANG_SRCS}/include -d ${.TARGET:C/\.h$/.d/} -o ${.TARGET} \
236 ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td
238 .for dep in ${TGHDRS:C/$/.inc.d/}
242 SRCS+= ${TGHDRS:C/$/.inc.h/}
243 CLEANFILES+= ${TGHDRS:C/$/.inc.h/} ${TGHDRS:C/$/.inc.d/}