diff --git a/llvm/test/tools/llvm-libtool-darwin/Inputs/arm64-asm.ll b/llvm/test/tools/llvm-libtool-darwin/Inputs/arm64-asm.ll new file mode 100644 --- /dev/null +++ b/llvm/test/tools/llvm-libtool-darwin/Inputs/arm64-asm.ll @@ -0,0 +1,7 @@ +target triple = "arm64-apple-macosx11.0.0" + +module asm ".desc ___crashreporter_info__, 0x10" + +define void @somesymbol() { + ret void +} diff --git a/llvm/test/tools/llvm-libtool-darwin/Inputs/x86_64-asm.ll b/llvm/test/tools/llvm-libtool-darwin/Inputs/x86_64-asm.ll new file mode 100644 --- /dev/null +++ b/llvm/test/tools/llvm-libtool-darwin/Inputs/x86_64-asm.ll @@ -0,0 +1,7 @@ +target triple = "x86_64-apple-macosx11.0.0" + +module asm ".desc ___crashreporter_info__, 0x10" + +define void @somesymbol() { + ret void +} diff --git a/llvm/test/tools/llvm-libtool-darwin/arm64-asm.test b/llvm/test/tools/llvm-libtool-darwin/arm64-asm.test new file mode 100644 --- /dev/null +++ b/llvm/test/tools/llvm-libtool-darwin/arm64-asm.test @@ -0,0 +1,9 @@ +# REQUIRES: aarch64-registered-target +## This tests that archives are correctly created when the llvm +## has native assembly info + +# RUN: llvm-as %p/Inputs/arm64-asm.ll -o %t-arm64-asm.bc +# RUN: llvm-libtool-darwin -static -o %t-arm64.lib %t-arm64-asm.bc +# RUN: llvm-nm %t-arm64.lib | FileCheck %s + +# CHECK: T somesymbol diff --git a/llvm/test/tools/llvm-libtool-darwin/x86_64-asm.test b/llvm/test/tools/llvm-libtool-darwin/x86_64-asm.test new file mode 100644 --- /dev/null +++ b/llvm/test/tools/llvm-libtool-darwin/x86_64-asm.test @@ -0,0 +1,9 @@ +# REQUIRES: x86-registered-target +## This tests that archives are correctly created when the llvm +## has native assembly info + +# RUN: llvm-as %p/Inputs/x86_64-asm.ll -o %t-x86_64-asm.bc +# RUN: llvm-libtool-darwin -static -o %t-x86_64.lib %t-x86_64-asm.bc +# RUN: llvm-nm %t-x86_64.lib | FileCheck %s + +# CHECK: T somesymbol diff --git a/llvm/tools/llvm-libtool-darwin/CMakeLists.txt b/llvm/tools/llvm-libtool-darwin/CMakeLists.txt --- a/llvm/tools/llvm-libtool-darwin/CMakeLists.txt +++ b/llvm/tools/llvm-libtool-darwin/CMakeLists.txt @@ -4,6 +4,7 @@ Object Support TextAPI + ${LLVM_TARGETS_TO_BUILD} ) add_llvm_tool(llvm-libtool-darwin diff --git a/llvm/tools/llvm-libtool-darwin/llvm-libtool-darwin.cpp b/llvm/tools/llvm-libtool-darwin/llvm-libtool-darwin.cpp --- a/llvm/tools/llvm-libtool-darwin/llvm-libtool-darwin.cpp +++ b/llvm/tools/llvm-libtool-darwin/llvm-libtool-darwin.cpp @@ -21,6 +21,7 @@ #include "llvm/Support/CommandLine.h" #include "llvm/Support/InitLLVM.h" #include "llvm/Support/LineIterator.h" +#include "llvm/Support/TargetSelect.h" #include "llvm/Support/VirtualFileSystem.h" #include "llvm/Support/WithColor.h" #include "llvm/Support/raw_ostream.h" @@ -682,6 +683,10 @@ if (VersionOption) cl::PrintVersionMessage(); + llvm::InitializeAllTargetInfos(); + llvm::InitializeAllTargetMCs(); + llvm::InitializeAllAsmParsers(); + Config C = *ConfigOrErr; switch (LibraryOperation) { case Operation::None: