xref: /minix/external/bsd/llvm/include/Makefile (revision 0a6a1f1d)
1#	$NetBSD: Makefile,v 1.37 2015/05/29 17:40:41 joerg Exp $
2
3.include <bsd.init.mk>
4
5.PATH:	${CLANG_SRCDIR}/lib/Headers
6
7.if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "x86_64"
8INCS=	__wmmintrin_aes.h \
9	__wmmintrin_pclmul.h \
10	adxintrin.h \
11	ammintrin.h \
12	avx2intrin.h \
13	avx512bwintrin.h \
14	avx512fintrin.h \
15	avx512erintrin.h \
16	avx512vlbwintrin.h \
17	avx512vlintrin.h \
18	avxintrin.h \
19	bmi2intrin.h \
20	bmiintrin.h \
21	cpuid.h \
22	emmintrin.h \
23	f16cintrin.h \
24	fmaintrin.h \
25	fma4intrin.h \
26	ia32intrin.h \
27	immintrin.h \
28	lzcntintrin.h \
29	mm3dnow.h \
30	mmintrin.h \
31	mm_malloc.h \
32	nmmintrin.h \
33	pmmintrin.h \
34	popcntintrin.h \
35	prfchwintrin.h \
36	rdseedintrin.h \
37	rtmintrin.h \
38	shaintrin.h \
39	smmintrin.h \
40	tbmintrin.h \
41	tmmintrin.h \
42	wmmintrin.h \
43	x86intrin.h \
44	xmmintrin.h \
45	xopintrin.h
46.elif ${MACHINE_ARCH} == "powerpc" || ${MACHINE_ARCH} == "powerpc64"
47INCS=	altivec.h
48.elif ${MACHINE_CPU} == "arm"
49INCS=	arm_acle.h \
50	arm_neon.h
51.endif
52INCS+=	stdatomic.h
53INCSDIR=	/usr/include/clang-${CLANG_VERSION:R}
54
55.PATH:	${LLVM_SRCDIR}/include/llvm/IR \
56	${CLANG_SRCDIR}/include/clang/AST \
57	${CLANG_SRCDIR}/include/clang/Basic \
58	${CLANG_SRCDIR}/include/clang/Driver
59
60TABLEGEN_SRC=	Intrinsics.td Options.td
61
62TABLEGEN_OUTPUT.Intrinsics.td= \
63	llvm/IR/Intrinsics.gen|-gen-intrinsic
64
65CLANG_TABLEGEN_SRC=	Attr.td CommentCommands.td CommentHTMLTags.td \
66	CommentNodes.td CommentHTMLNamedCharacterReferences.td DeclNodes.td \
67	StmtNodes.td Diagnostic.td arm_neon.td
68
69CLANG_TABLEGEN_INCLUDES.Attr.td=	-I${CLANG_SRCDIR}/include
70CLANG_TABLEGEN_OUTPUT.Attr.td= \
71	clang/AST/Attrs.inc|-gen-clang-attr-classes \
72	clang/AST/AttrDump.inc|-gen-clang-attr-dump \
73	clang/AST/AttrImpl.inc|-gen-clang-attr-impl \
74	clang/AST/AttrVisitor.inc|-gen-clang-attr-ast-visitor \
75	clang/Basic/AttrList.inc|-gen-clang-attr-list \
76	clang/Basic/AttrHasAttributeImpl.inc|-gen-clang-attr-has-attribute-impl \
77	clang/Parse/AttrParserStringSwitches.inc|-gen-clang-attr-parser-string-switches \
78	clang/Sema/AttrParsedAttrImpl.inc|-gen-clang-attr-parsed-attr-impl \
79	clang/Sema/AttrParsedAttrKinds.inc|-gen-clang-attr-parsed-attr-kinds \
80	clang/Sema/AttrParsedAttrList.inc|-gen-clang-attr-parsed-attr-list \
81	clang/Sema/AttrSpellingListIndex.inc|-gen-clang-attr-spelling-index \
82	clang/Sema/AttrTemplateInstantiate.inc|-gen-clang-attr-template-instantiate \
83	clang/Serialization/AttrPCHRead.inc|-gen-clang-attr-pch-read \
84	clang/Serialization/AttrPCHWrite.inc|-gen-clang-attr-pch-write
85
86CLANG_TABLEGEN_OUTPUT.StmtNodes.td= \
87	clang/AST/StmtNodes.inc|-gen-clang-stmt-nodes
88
89CLANG_TABLEGEN_OUTPUT.DeclNodes.td= \
90	clang/AST/DeclNodes.inc|-gen-clang-decl-nodes
91
92CLANG_TABLEGEN_OUTPUT.CommentNodes.td= \
93	clang/AST/CommentNodes.inc|-gen-clang-comment-nodes
94
95CLANG_TABLEGEN_OUTPUT.CommentCommands.td= \
96	clang/AST/CommentCommandInfo.inc|-gen-clang-comment-command-info \
97	clang/AST/CommentCommandList.inc|-gen-clang-comment-command-list
98
99CLANG_TABLEGEN_OUTPUT.CommentHTMLTags.td= \
100	clang/AST/CommentHTMLTags.inc|-gen-clang-comment-html-tags \
101	clang/AST/CommentHTMLTagsProperties.inc|-gen-clang-comment-html-tags-properties
102
103CLANG_TABLEGEN_OUTPUT.CommentHTMLNamedCharacterReferences.td= \
104	clang/AST/CommentHTMLNamedCharacterReferences.inc|-gen-clang-comment-html-named-character-references
105
106CLANG_TABLEGEN_INCLUDES.Diagnostic.td=	-I${CLANG_SRCDIR}/include/clang/Basic
107CLANG_TABLEGEN_OUTPUT.Diagnostic.td= \
108	clang/Basic/DiagnosticAnalysisKinds.inc|-gen-clang-diags-defs^-clang-component=Analysis \
109	clang/Basic/DiagnosticASTKinds.inc|-gen-clang-diags-defs^-clang-component=AST \
110	clang/Basic/DiagnosticCommentKinds.inc|-gen-clang-diags-defs^-clang-component=Comment \
111	clang/Basic/DiagnosticCommonKinds.inc|-gen-clang-diags-defs^-clang-component=Common \
112	clang/Basic/DiagnosticDriverKinds.inc|-gen-clang-diags-defs^-clang-component=Driver \
113	clang/Basic/DiagnosticFrontendKinds.inc|-gen-clang-diags-defs^-clang-component=Frontend \
114	clang/Basic/DiagnosticLexKinds.inc|-gen-clang-diags-defs^-clang-component=Lex \
115	clang/Basic/DiagnosticParseKinds.inc|-gen-clang-diags-defs^-clang-component=Parse \
116	clang/Basic/DiagnosticSemaKinds.inc|-gen-clang-diags-defs^-clang-component=Sema \
117	clang/Basic/DiagnosticSerializationKinds.inc|-gen-clang-diags-defs^-clang-component=Serialization \
118	clang/Basic/DiagnosticGroups.inc|-gen-clang-diag-groups \
119	clang/Basic/DiagnosticIndexName.inc|-gen-clang-diags-index-name
120
121CLANG_TABLEGEN_OUTPUT.arm_neon.td= \
122	clang/Basic/arm_neon.inc|-gen-arm-neon-sema \
123	arm_neon.h|-gen-arm-neon
124
125TABLEGEN_INCLUDES.Options.td=	-I${CLANG_SRCDIR}/include/clang/Driver
126TABLEGEN_OUTPUT.Options.td= \
127	clang/Driver/Options.inc|-gen-opt-parser-defs
128
129.include "${.PARSEDIR}/../tablegen.mk"
130
131DPSRCS+=	clang/Basic/Version.inc
132CLEANFILES+=	clang/Basic/Version.inc
133
134clang/Basic/Version.inc: ${LLVM_TOPLEVEL}/Makefile.inc
135	mkdir -p ${.TARGET:H}
136	printf '#define CLANG_VERSION ${CLANG_VERSION}\n' > ${.TARGET}.tmp
137	printf '#define CLANG_VERSION_MAJOR ${CLANG_VERSION:R:R}\n' >> ${.TARGET}.tmp
138	printf '#define CLANG_VERSION_MINOR ${CLANG_VERSION:R:E}\n' >> ${.TARGET}.tmp
139	mv ${.TARGET}.tmp ${.TARGET}
140
141lld/Config/Version.inc: ${LLVM_TOPLEVEL}/Makefile.inc
142
143.if ${MKLLD} != "no"
144DPSRCS+=	lld/Config/Version.inc
145CLEANFILES+=	lld/Config/Version.inc
146
147lld/Config/Version.inc: ${LLVM_TOPLEVEL}/Makefile.inc
148	mkdir -p ${.TARGET:H}
149	printf '#define LLD_VERSION ${LLD_VERSION}\n' > ${.TARGET}.tmp
150	printf '#define LLD_VERSION_MAJOR ${LLD_VERSION:R:R}\n' >> ${.TARGET}.tmp
151	printf '#define LLD_VERSION_MINOR ${LLD_VERSION:R:E}\n' >> ${.TARGET}.tmp
152	printf '#define LLD_REVISION_STRING "r${LLD_REVISION}"\n' >> ${.TARGET}.tmp
153	printf '#define LLD_REPOSITORY_STRING "${SVN_ROOT}/lld/${SVN_BRANCH}"\n' >> ${.TARGET}.tmp
154	mv ${.TARGET}.tmp ${.TARGET}
155.endif
156
157.ifndef HOST_BUILD
158
159DPSRCS+=	llvm/Config/config.h llvm/Config/llvm-config.h
160CLEANFILES+=	llvm/Config/config.h llvm/Config/llvm-config.h
161
162llvm/Config/config.h: ${LLVM_TOPLEVEL}/Makefile.inc ${LLVM_TOPLEVEL}/config/llvm/Config/config.h.in
163	mkdir -p ${.TARGET:H}
164	${TOOL_SED} -e /LLVM_DEFAULT_TARGET_TRIPLE/d -e /LLVM_NATIVE_/d \
165	    -e /LLVM_VERSION_/d -e /PACKAGE_VERSION/d -e 'x' \
166	    < ${LLVM_TOPLEVEL}/config/llvm/Config/config.h.in \
167	    > ${.TARGET}.tmp
168	printf '#define LLVM_DEFAULT_TARGET_TRIPLE "${MACHINE_GNU_PLATFORM}"\n' >> ${.TARGET}.tmp
169	printf '#define PACKAGE_VERSION "${LLVM_VERSION} (trunk ${LLVM_REVISION})"\n' >> ${.TARGET}.tmp
170	printf '#define LLVM_VERSION_MAJOR ${LLVM_VERSION:R:R}\n' >> ${.TARGET}.tmp
171	printf '#define LLVM_VERSION_MINOR ${LLVM_VERSION:R:E}\n' >> ${.TARGET}.tmp
172	printf '#endif\n' >> ${.TARGET}.tmp
173	mv ${.TARGET}.tmp ${.TARGET}
174
175llvm/Config/llvm-config.h: ${LLVM_TOPLEVEL}/Makefile.inc ${LLVM_TOPLEVEL}/config/llvm/Config/llvm-config.h.in
176	mkdir -p ${.TARGET:H}
177	${TOOL_SED} -e /LLVM_DEFAULT_TARGET_TRIPLE/d -e /LLVM_NATIVE_/d \
178	    -e /LLVM_VERSION_/d -e /PACKAGE_VERSION/d -e 'x' \
179	    < ${LLVM_TOPLEVEL}/config/llvm/Config/llvm-config.h.in \
180	    > ${.TARGET}.tmp
181	printf '#define LLVM_DEFAULT_TARGET_TRIPLE "${MACHINE_GNU_PLATFORM}"\n' >> ${.TARGET}.tmp
182	printf '#define LLVM_VERSION_MAJOR ${LLVM_VERSION:R:R}\n' >> ${.TARGET}.tmp
183	printf '#define LLVM_VERSION_MINOR ${LLVM_VERSION:R:E}\n' >> ${.TARGET}.tmp
184	printf '#endif\n' >> ${.TARGET}.tmp
185	mv ${.TARGET}.tmp ${.TARGET}
186
187run-configure:
188	[ ! -d tmp ] || rm -r tmp
189	mkdir -p tmp
190	cd tmp && ${LLVM_SRCDIR}/configure ${LLVM_CONFIGURE_ARGS} \
191	    CC=${CC:Q} CFLAGS=${CFLAGS:N-Werror:Q} CXX=${CXX:Q} CXXFLAGS=${CXXFLAGS:N-Werror:Q} \
192	    CPPFLAGS=${CPPFLAGS:N-std=c++11:Q} LDFLAGS=${LDFLAGS:Q} LD=${LD:Q} LIBS=-lm \
193	    ac_cv_func_mmap_fixed_mapped=yes ac_cv_func_mmap_file=yes llvm_cv_c_printf_a=yes
194	cp -r tmp/include/llvm/* ${LLVM_INCLUDE_CONFIG}/llvm/
195	mv ${LLVM_INCLUDE_CONFIG}/llvm/Config/config.h \
196	   ${LLVM_INCLUDE_CONFIG}/llvm/Config/config.h.in
197	mv ${LLVM_INCLUDE_CONFIG}/llvm/Config/llvm-config.h \
198	   ${LLVM_INCLUDE_CONFIG}/llvm/Config/llvm-config.h.in
199	cp -r tmp/tools/clang/include/clang/* ${CLANG_INCLUDE_CONFIG}/clang/
200	rm -r tmp
201.endif
202
203depend dependall all: ${DPSRCS}
204
205.include <bsd.prog.mk>
206