clang.build.mk revision 226475
1# $FreeBSD: head/lib/clang/clang.build.mk 226475 2011-10-17 18:30:18Z dim $
2
3CLANG_SRCS=${LLVM_SRCS}/tools/clang
4
5CFLAGS+=-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
10
11# Correct for gcc miscompilation when compiling on PPC with -O2
12.if ${MACHINE_ARCH} == "powerpc"
13CFLAGS+= -O1
14.endif
15
16TARGET_ARCH?=	${MACHINE_ARCH}
17CFLAGS+=-DLLVM_HOSTTRIPLE=\"${TARGET_ARCH:C/amd64/x86_64/}-unknown-freebsd10.0\"
18
19.ifndef LLVM_REQUIRES_EH
20CXXFLAGS+=-fno-exceptions
21.else
22# If the library or program requires EH, it also requires RTTI.
23LLVM_REQUIRES_RTTI=
24.endif
25
26.ifndef LLVM_REQUIRES_RTTI
27CXXFLAGS+=-fno-rtti
28.endif
29
30.ifdef TOOLS_PREFIX
31CFLAGS+=-DCLANG_PREFIX=\"${TOOLS_PREFIX}\"
32.endif
33
34.PATH:	${LLVM_SRCS}/${SRCDIR}
35
36TBLGEN?=tblgen
37TBLINC+=-I ${LLVM_SRCS}/include -I ${LLVM_SRCS}/lib/Target
38
39Intrinsics.inc.h: ${LLVM_SRCS}/include/llvm/Intrinsics.td
40	${TBLGEN} -I ${LLVM_SRCS}/lib/VMCore ${TBLINC} -gen-intrinsic \
41	    -o ${.TARGET} ${LLVM_SRCS}/include/llvm/Intrinsics.td
42.for arch in \
43	ARM/ARM Mips/Mips PowerPC/PPC X86/X86
44. for hdr in \
45	AsmMatcher/-gen-asm-matcher \
46	AsmWriter1/-gen-asm-writer,-asmwriternum=1 \
47	AsmWriter/-gen-asm-writer \
48	CallingConv/-gen-callingconv \
49	CodeEmitter/-gen-emitter \
50	DAGISel/-gen-dag-isel \
51	DisassemblerTables/-gen-disassembler \
52	EDInfo/-gen-enhanced-disassembly-info \
53	FastISel/-gen-fast-isel \
54	InstrInfo/-gen-instr-info \
55	MCCodeEmitter/-gen-emitter,-mc-emitter \
56	MCPseudoLowering/-gen-pseudo-lowering \
57	RegisterInfo/-gen-register-info \
58	SubtargetInfo/-gen-subtarget
59${arch:T}Gen${hdr:H:C/$/.inc.h/}: ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td
60	${TBLGEN} -I ${LLVM_SRCS}/lib/Target/${arch:H} ${TBLINC} \
61	    ${hdr:T:C/,/ /g} -o ${.TARGET} \
62	    ${LLVM_SRCS}/lib/Target/${arch:H}/${arch:T}.td
63. endfor
64.endfor
65
66ARMGenDecoderTables.inc.h: ${LLVM_SRCS}/lib/Target/ARM/ARM.td
67	${TBLGEN} -I ${LLVM_SRCS}/lib/Target/ARM ${TBLINC} \
68	    -gen-arm-decoder -o ${.TARGET} ${.ALLSRC}
69
70Attrs.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
71	${TBLGEN} -I ${CLANG_SRCS}/include/clang/AST ${TBLINC} \
72	    -gen-clang-attr-classes -o ${.TARGET} \
73	    -I ${CLANG_SRCS}/include ${.ALLSRC}
74
75AttrImpl.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
76	${TBLGEN} -I ${CLANG_SRCS}/include/clang/AST ${TBLINC} \
77	    -gen-clang-attr-impl -o ${.TARGET} \
78	    -I ${CLANG_SRCS}/include ${.ALLSRC}
79
80AttrList.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
81	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic ${TBLINC} \
82	    -gen-clang-attr-list -o ${.TARGET} \
83	    -I ${CLANG_SRCS}/include ${.ALLSRC}
84
85AttrPCHRead.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
86	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Serialization \
87	    ${TBLINC} -gen-clang-attr-pch-read -o ${.TARGET} \
88	    -I ${CLANG_SRCS}/include ${.ALLSRC}
89
90AttrPCHWrite.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
91	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Serialization \
92	    ${TBLINC} -gen-clang-attr-pch-write -o ${.TARGET} \
93	    -I ${CLANG_SRCS}/include ${.ALLSRC}
94
95AttrSpellings.inc.h: ${CLANG_SRCS}/include/clang/Basic/Attr.td
96	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Lex ${TBLINC} \
97	    -gen-clang-attr-spelling-list -o ${.TARGET} \
98	    -I ${CLANG_SRCS}/include ${.ALLSRC}
99
100DeclNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/DeclNodes.td
101	${TBLGEN} -I ${CLANG_SRCS}/include/clang/AST ${TBLINC} \
102	    -gen-clang-decl-nodes -o ${.TARGET} ${.ALLSRC}
103
104StmtNodes.inc.h: ${CLANG_SRCS}/include/clang/Basic/StmtNodes.td
105	${TBLGEN} -I ${CLANG_SRCS}/include/clang/AST ${TBLINC} \
106	    -gen-clang-stmt-nodes -o ${.TARGET} ${.ALLSRC}
107
108arm_neon.inc.h: ${CLANG_SRCS}/include/clang/Basic/arm_neon.td
109	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic ${TBLINC} \
110	    -gen-arm-neon-sema -o ${.TARGET} ${.ALLSRC}
111
112DiagnosticGroups.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
113	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic ${TBLINC} \
114	    -gen-clang-diag-groups -o ${.TARGET} ${.ALLSRC}
115
116DiagnosticIndexName.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
117	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic ${TBLINC} \
118	    -gen-clang-diags-index-name -o ${.TARGET} ${.ALLSRC}
119
120.for hdr in AST Analysis Common Driver Frontend Lex Parse Sema
121Diagnostic${hdr}Kinds.inc.h: ${CLANG_SRCS}/include/clang/Basic/Diagnostic.td
122	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Basic ${TBLINC} \
123	    -gen-clang-diags-defs -clang-component=${hdr} \
124	    -o ${.TARGET} ${.ALLSRC}
125.endfor
126
127Options.inc.h: ${CLANG_SRCS}/include/clang/Driver/Options.td
128	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Driver ${TBLINC} \
129	    -gen-opt-parser-defs -o ${.TARGET} ${.ALLSRC}
130
131CC1Options.inc.h: ${CLANG_SRCS}/include/clang/Driver/CC1Options.td
132	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Driver ${TBLINC} \
133	    -gen-opt-parser-defs -o ${.TARGET} ${.ALLSRC}
134
135CC1AsOptions.inc.h: ${CLANG_SRCS}/include/clang/Driver/CC1AsOptions.td
136	${TBLGEN} -I ${CLANG_SRCS}/include/clang/Driver ${TBLINC} \
137	    -gen-opt-parser-defs -o ${.TARGET} ${.ALLSRC}
138
139Checkers.inc.h: ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td \
140	    ${CLANG_SRCS}/include/clang/StaticAnalyzer/Checkers/CheckerBase.td
141	${TBLGEN} -I ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers \
142	    ${TBLINC} -gen-clang-sa-checkers -o ${.TARGET} \
143	    -I ${CLANG_SRCS}/include \
144	    ${CLANG_SRCS}/lib/StaticAnalyzer/Checkers/Checkers.td
145
146SRCS+=		${TGHDRS:C/$/.inc.h/}
147DPADD+=		${TGHDRS:C/$/.inc.h/}
148CLEANFILES+=	${TGHDRS:C/$/.inc.h/}
149