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