xref: /freebsd/lib/clang/clang.build.mk (revision 76b28ad6ab6dc8d4a62cb7de7f143595be535813)
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