# $NetBSD: Makefile,v 1.40 2017/01/11 12:02:28 joerg Exp $ .include .PATH: ${CLANG_SRCDIR}/lib/Headers .if ${MACHINE_ARCH} == "i386" || ${MACHINE_ARCH} == "x86_64" INCS= __wmmintrin_aes.h \ __wmmintrin_pclmul.h \ adxintrin.h \ ammintrin.h \ avx2intrin.h \ avx512bwintrin.h \ avx512cdintrin.h \ avx512dqintrin.h \ avx512fintrin.h \ avx512erintrin.h \ avx512ifmaintrin.h \ avx512ifmavlintrin.h \ avx512pfintrin.h \ avx512vbmiintrin.h \ avx512vbmivlintrin.h \ avx512vlbwintrin.h \ avx512vlcdintrin.h \ avx512vldqintrin.h \ avx512vlintrin.h \ avxintrin.h \ bmi2intrin.h \ bmiintrin.h \ clflushoptintrin.h \ cpuid.h \ emmintrin.h \ f16cintrin.h \ fmaintrin.h \ fma4intrin.h \ fxsrintrin.h \ ia32intrin.h \ immintrin.h \ lzcntintrin.h \ mm3dnow.h \ mmintrin.h \ mm_malloc.h \ mwaitxintrin.h \ nmmintrin.h \ pkuintrin.h \ pmmintrin.h \ popcntintrin.h \ prfchwintrin.h \ rdseedintrin.h \ rtmintrin.h \ shaintrin.h \ smmintrin.h \ tbmintrin.h \ tmmintrin.h \ wmmintrin.h \ x86intrin.h \ xmmintrin.h \ xopintrin.h \ xsavesintrin.h \ xsaveintrin.h \ xsaveoptintrin.h \ xsavecintrin.h \ xtestintrin.h .elif ${MACHINE_ARCH} == "powerpc" || ${MACHINE_ARCH} == "powerpc64" INCS= altivec.h \ htmintrin.h \ htmxlintrin.h .elif ${MACHINE_CPU} == "arm" INCS= arm_acle.h \ arm_neon.h .elif ${MACHINE_CPU} == "mips" || ${MACHINE_CPU} == "mips64" INCS= msa.h .endif INCS+= stdalign.h stdatomic.h stdnoreturn.h INCSDIR= /usr/include/clang-${CLANG_VERSION:R} .PATH: ${LLVM_SRCDIR}/include/llvm/IR \ ${CLANG_SRCDIR}/include/clang/AST \ ${CLANG_SRCDIR}/include/clang/Basic \ ${CLANG_SRCDIR}/include/clang/Driver \ ${CLANG_SRCDIR}/include/clang/StaticAnalyzer/Checkers TABLEGEN_SRC= Attributes.td Intrinsics.td Options.td TABLEGEN_OUTPUT.Attributes.td= \ llvm/IR/Attributes.gen|-gen-attrs TABLEGEN_OUTPUT.Intrinsics.td= \ llvm/IR/Intrinsics.gen|-gen-intrinsic CLANG_TABLEGEN_SRC= Attr.td CommentCommands.td CommentHTMLTags.td \ CommentNodes.td CommentHTMLNamedCharacterReferences.td DeclNodes.td \ StmtNodes.td Diagnostic.td arm_neon.td Checkers.td CLANG_TABLEGEN_INCLUDES.Attr.td= -I${CLANG_SRCDIR}/include CLANG_TABLEGEN_OUTPUT.Attr.td= \ clang/AST/Attrs.inc|-gen-clang-attr-classes \ clang/AST/AttrDump.inc|-gen-clang-attr-dump \ clang/AST/AttrImpl.inc|-gen-clang-attr-impl \ clang/AST/AttrVisitor.inc|-gen-clang-attr-ast-visitor \ clang/Basic/AttrList.inc|-gen-clang-attr-list \ clang/Basic/AttrHasAttributeImpl.inc|-gen-clang-attr-has-attribute-impl \ clang/Parse/AttrParserStringSwitches.inc|-gen-clang-attr-parser-string-switches \ clang/Sema/AttrParsedAttrImpl.inc|-gen-clang-attr-parsed-attr-impl \ clang/Sema/AttrParsedAttrKinds.inc|-gen-clang-attr-parsed-attr-kinds \ clang/Sema/AttrParsedAttrList.inc|-gen-clang-attr-parsed-attr-list \ clang/Sema/AttrSpellingListIndex.inc|-gen-clang-attr-spelling-index \ clang/Sema/AttrTemplateInstantiate.inc|-gen-clang-attr-template-instantiate \ clang/Serialization/AttrPCHRead.inc|-gen-clang-attr-pch-read \ clang/Serialization/AttrPCHWrite.inc|-gen-clang-attr-pch-write CLANG_TABLEGEN_OUTPUT.StmtNodes.td= \ clang/AST/StmtNodes.inc|-gen-clang-stmt-nodes CLANG_TABLEGEN_OUTPUT.DeclNodes.td= \ clang/AST/DeclNodes.inc|-gen-clang-decl-nodes CLANG_TABLEGEN_OUTPUT.CommentNodes.td= \ clang/AST/CommentNodes.inc|-gen-clang-comment-nodes CLANG_TABLEGEN_OUTPUT.CommentCommands.td= \ clang/AST/CommentCommandInfo.inc|-gen-clang-comment-command-info \ clang/AST/CommentCommandList.inc|-gen-clang-comment-command-list CLANG_TABLEGEN_OUTPUT.CommentHTMLTags.td= \ clang/AST/CommentHTMLTags.inc|-gen-clang-comment-html-tags \ clang/AST/CommentHTMLTagsProperties.inc|-gen-clang-comment-html-tags-properties CLANG_TABLEGEN_OUTPUT.CommentHTMLNamedCharacterReferences.td= \ clang/AST/CommentHTMLNamedCharacterReferences.inc|-gen-clang-comment-html-named-character-references CLANG_TABLEGEN_INCLUDES.Diagnostic.td= -I${CLANG_SRCDIR}/include/clang/Basic CLANG_TABLEGEN_OUTPUT.Diagnostic.td= \ clang/Basic/DiagnosticAnalysisKinds.inc|-gen-clang-diags-defs^-clang-component=Analysis \ clang/Basic/DiagnosticASTKinds.inc|-gen-clang-diags-defs^-clang-component=AST \ clang/Basic/DiagnosticCommentKinds.inc|-gen-clang-diags-defs^-clang-component=Comment \ clang/Basic/DiagnosticCommonKinds.inc|-gen-clang-diags-defs^-clang-component=Common \ clang/Basic/DiagnosticDriverKinds.inc|-gen-clang-diags-defs^-clang-component=Driver \ clang/Basic/DiagnosticFrontendKinds.inc|-gen-clang-diags-defs^-clang-component=Frontend \ clang/Basic/DiagnosticLexKinds.inc|-gen-clang-diags-defs^-clang-component=Lex \ clang/Basic/DiagnosticParseKinds.inc|-gen-clang-diags-defs^-clang-component=Parse \ clang/Basic/DiagnosticSemaKinds.inc|-gen-clang-diags-defs^-clang-component=Sema \ clang/Basic/DiagnosticSerializationKinds.inc|-gen-clang-diags-defs^-clang-component=Serialization \ clang/Basic/DiagnosticGroups.inc|-gen-clang-diag-groups \ clang/Basic/DiagnosticIndexName.inc|-gen-clang-diags-index-name CLANG_TABLEGEN_OUTPUT.arm_neon.td= \ clang/Basic/arm_neon.inc|-gen-arm-neon-sema \ arm_neon.h|-gen-arm-neon CLANG_TABLEGEN_INCLUDES.Checkers.td= -I${CLANG_SRCDIR}/include CLANG_TABLEGEN_OUTPUT.Checkers.td= \ clang/StaticAnalyzer/Checkers/Checkers.inc|-gen-clang-sa-checkers TABLEGEN_INCLUDES.Options.td= -I${CLANG_SRCDIR}/include/clang/Driver TABLEGEN_OUTPUT.Options.td= \ clang/Driver/Options.inc|-gen-opt-parser-defs .include "${.PARSEDIR}/../tablegen.mk" DPSRCS+= clang/Basic/Version.inc CLEANFILES+= clang/Basic/Version.inc clang/Basic/Version.inc: ${LLVM_TOPLEVEL}/Makefile.inc mkdir -p ${.TARGET:H} printf '#define CLANG_VERSION ${CLANG_VERSION}\n' > ${.TARGET}.tmp printf '#define CLANG_VERSION_STRING "${CLANG_VERSION}"\n' >> ${.TARGET}.tmp printf '#define CLANG_VERSION_MAJOR ${CLANG_VERSION:R:R}\n' >> ${.TARGET}.tmp printf '#define CLANG_VERSION_MINOR ${CLANG_VERSION:R:E}\n' >> ${.TARGET}.tmp printf '#define CLANG_VERSION_PATCHLEVEL ${CLANG_VERSION:R:R}\n' >> ${.TARGET}.tmp mv ${.TARGET}.tmp ${.TARGET} lld/Config/Version.inc: ${LLVM_TOPLEVEL}/Makefile.inc .if ${MKLLD} != "no" DPSRCS+= lld/Config/Version.inc CLEANFILES+= lld/Config/Version.inc lld/Config/Version.inc: ${LLVM_TOPLEVEL}/Makefile.inc mkdir -p ${.TARGET:H} printf '#define LLD_VERSION ${LLD_VERSION}\n' > ${.TARGET}.tmp printf '#define LLD_VERSION_MAJOR ${LLD_VERSION:R:R}\n' >> ${.TARGET}.tmp printf '#define LLD_VERSION_MINOR ${LLD_VERSION:R:E}\n' >> ${.TARGET}.tmp printf '#define LLD_REVISION_STRING "r${LLD_REVISION}"\n' >> ${.TARGET}.tmp printf '#define LLD_REPOSITORY_STRING "${SVN_ROOT}/lld/${SVN_BRANCH}"\n' >> ${.TARGET}.tmp mv ${.TARGET}.tmp ${.TARGET} .endif .ifndef HOST_BUILD DPSRCS+= llvm/Config/config.h llvm/Config/llvm-config.h CLEANFILES+= llvm/Config/config.h llvm/Config/llvm-config.h NATIVE_LIBS= -lm -lexecinfo llvm/Config/config.h: ${LLVM_TOPLEVEL}/Makefile.inc ${LLVM_TOPLEVEL}/config/llvm/Config/config.h.in mkdir -p ${.TARGET:H} ${TOOL_SED} -e /LLVM_DEFAULT_TARGET_TRIPLE/d -e /LLVM_NATIVE_/d \ -e /LLVM_VERSION_/d -e /PACKAGE_VERSION/d -e 'x' \ < ${LLVM_TOPLEVEL}/config/llvm/Config/config.h.in \ > ${.TARGET}.tmp printf '#define LLVM_DEFAULT_TARGET_TRIPLE "${MACHINE_GNU_PLATFORM}"\n' >> ${.TARGET}.tmp printf '#define PACKAGE_VERSION "${LLVM_VERSION} (trunk ${LLVM_REVISION})"\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_MAJOR ${LLVM_VERSION:R:R}\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_MINOR ${LLVM_VERSION:R:E}\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_PATCH ${LLVM_VERSION:E}\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_STRING "${LLVM_VERSION}"\n' >> ${.TARGET}.tmp printf '#endif\n' >> ${.TARGET}.tmp mv ${.TARGET}.tmp ${.TARGET} llvm/Config/llvm-config.h: ${LLVM_TOPLEVEL}/Makefile.inc ${LLVM_TOPLEVEL}/config/llvm/Config/llvm-config.h.in mkdir -p ${.TARGET:H} ${TOOL_SED} -e /LLVM_DEFAULT_TARGET_TRIPLE/d -e /LLVM_NATIVE_/d \ -e /LLVM_VERSION_/d -e /PACKAGE_VERSION/d -e 'x' \ < ${LLVM_TOPLEVEL}/config/llvm/Config/llvm-config.h.in \ > ${.TARGET}.tmp printf '#define LLVM_DEFAULT_TARGET_TRIPLE "${MACHINE_GNU_PLATFORM}"\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_MAJOR ${LLVM_VERSION:R:R}\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_MINOR ${LLVM_VERSION:R:E}\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_PATCH ${LLVM_VERSION:E}\n' >> ${.TARGET}.tmp printf '#define LLVM_VERSION_STRING "${LLVM_VERSION}"\n' >> ${.TARGET}.tmp printf '#endif\n' >> ${.TARGET}.tmp mv ${.TARGET}.tmp ${.TARGET} run-configure: [ ! -d tmp ] || rm -r tmp mkdir -p tmp cd tmp && CONFIG_SITE= ${CONFIG_DIR}/configure ${LLVM_CONFIGURE_ARGS} \ CC=${CC:Q} CFLAGS=${CFLAGS:N-Werror:Q} CXX=${CXX:Q} CXXFLAGS=${CXXFLAGS:N-Werror:Q} \ CPPFLAGS=${CPPFLAGS:N-std=c++11:Q} LDFLAGS=${LDFLAGS:Q} LD=${LD:Q} LIBS=${NATIVE_LIBS:Q} \ BUILD_CC=${CC:Q} BUILD_CXX=${CXX:Q} cp -r tmp/include/llvm/* ${LLVM_INCLUDE_CONFIG}/llvm/ mv ${LLVM_INCLUDE_CONFIG}/llvm/Config/llvm-config.h \ ${LLVM_INCLUDE_CONFIG}/llvm/Config/llvm-config.h.in cp -r tmp/include/clang/* ${CLANG_INCLUDE_CONFIG}/clang/ rm -r tmp mv ${LLVM_INCLUDE_CONFIG}/llvm/Config/config.h \ ${LLVM_INCLUDE_CONFIG}/llvm/Config/config.h.in .endif depend dependall all: ${DPSRCS} .include