[PATCH] D79771: [examples] Skip building the Bye pass plugin on windows
Martin Storsjö via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue May 12 02:07:05 PDT 2020
mstorsjo created this revision.
mstorsjo added reviewers: rnk, thakis.
Herald added a subscriber: mgorny.
Herald added a project: LLVM.
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 <https://reviews.llvm.org/rGbc8e44218810c0db6328b9809c959ceb7d43e3f5>.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D79771
Files:
llvm/examples/Bye/CMakeLists.txt
llvm/test/CMakeLists.txt
llvm/test/Feature/load_extension.ll
Index: llvm/test/Feature/load_extension.ll
===================================================================
--- llvm/test/Feature/load_extension.ll
+++ 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"
Index: llvm/test/CMakeLists.txt
===================================================================
--- llvm/test/CMakeLists.txt
+++ llvm/test/CMakeLists.txt
@@ -144,13 +144,17 @@
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)
Index: llvm/examples/Bye/CMakeLists.txt
===================================================================
--- llvm/examples/Bye/CMakeLists.txt
+++ llvm/examples/Bye/CMakeLists.txt
@@ -2,12 +2,18 @@
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()
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D79771.263378.patch
Type: text/x-patch
Size: 2163 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200512/0642b027/attachment.bin>
More information about the llvm-commits
mailing list