[llvm] f897266 - [examples] Skip building the Bye pass plugin on windows
Martin Storsjö via llvm-commits
llvm-commits at lists.llvm.org
Wed May 13 03:41:07 PDT 2020
Author: Martin Storsjö
Date: 2020-05-13T13:40:56+03:00
New Revision: f8972662bc3b39377374a5e7d8abe7b4a74ac573
URL: https://github.com/llvm/llvm-project/commit/f8972662bc3b39377374a5e7d8abe7b4a74ac573
DIFF: https://github.com/llvm/llvm-project/commit/f8972662bc3b39377374a5e7d8abe7b4a74ac573.diff
LOG: [examples] Skip building the Bye pass plugin on windows
Windows doesn't properly support pass plugins (as a shared library
can't have undefined references, which pass plugins assume, being
loaded into a host process that contains provides them), thus
disable building it and the corresponding test.
This matches what was done for the passes unit test in
bc8e44218810c0db6328b9809c959ceb7d43e3f5.
Differential Revision: https://reviews.llvm.org/D79771
Added:
Modified:
llvm/examples/Bye/CMakeLists.txt
llvm/test/CMakeLists.txt
llvm/test/Feature/load_extension.ll
Removed:
################################################################################
diff --git a/llvm/examples/Bye/CMakeLists.txt b/llvm/examples/Bye/CMakeLists.txt
index 3206f90d0916..bb96edb4b4bf 100644
--- a/llvm/examples/Bye/CMakeLists.txt
+++ b/llvm/examples/Bye/CMakeLists.txt
@@ -2,12 +2,18 @@ if(LLVM_BYE_LINK_INTO_TOOLS)
message(WARNING "Setting LLVM_BYE_LINK_INTO_TOOLS=ON only makes sense for testing purpose")
endif()
-add_llvm_pass_plugin(Bye
- Bye.cpp
- DEPENDS
- intrinsics_gen
- BUILDTREE_ONLY
- )
+# The plugin expects to not link against the Support and Core libraries,
+# but expects them to exist in the process loading the plugin. This doesn't
+# work with DLLs on Windows (where a shared library can't have undefined
+# references), so just skip this example on Windows.
+if (NOT WIN32)
+ add_llvm_pass_plugin(Bye
+ Bye.cpp
+ DEPENDS
+ intrinsics_gen
+ BUILDTREE_ONLY
+ )
-install(TARGETS ${name} RUNTIME DESTINATION examples)
-set_target_properties(${name} PROPERTIES FOLDER "Examples")
+ install(TARGETS ${name} RUNTIME DESTINATION examples)
+ set_target_properties(${name} PROPERTIES FOLDER "Examples")
+endif()
diff --git a/llvm/test/CMakeLists.txt b/llvm/test/CMakeLists.txt
index 330a35212883..c765943a9b36 100644
--- a/llvm/test/CMakeLists.txt
+++ b/llvm/test/CMakeLists.txt
@@ -144,13 +144,17 @@ endif()
if(LLVM_BUILD_EXAMPLES)
list(APPEND LLVM_TEST_DEPENDS
- Bye
Kaleidoscope-Ch3
Kaleidoscope-Ch4
Kaleidoscope-Ch5
Kaleidoscope-Ch6
Kaleidoscope-Ch7
)
+ if (NOT WIN32)
+ list(APPEND LLVM_TEST_DEPENDS
+ Bye
+ )
+ endif()
endif()
if(TARGET ocaml_llvm)
diff --git a/llvm/test/Feature/load_extension.ll b/llvm/test/Feature/load_extension.ll
index a9367e4071d6..9792bf97a80a 100644
--- a/llvm/test/Feature/load_extension.ll
+++ b/llvm/test/Feature/load_extension.ll
@@ -6,6 +6,7 @@
; RUN: llvm-lto2 run %t.o %loadbye %loadnewpmbye -wave-goodbye -use-new-pm -o %t -r %t.o,somefunk,plx -r %t.o,junk,plx 2>&1 | FileCheck %s
; RUN: llvm-lto2 run %t.o %loadbye %loadnewpmbye -opt-pipeline="goodbye" -wave-goodbye -use-new-pm -o %t -r %t.o,somefunk,plx -r %t.o,junk,plx 2>&1 | FileCheck %s
; REQUIRES: plugins, examples
+; UNSUPPORTED: windows
; CHECK: Bye
target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
More information about the llvm-commits
mailing list