jit: Changes for LLVM 17.
authorThomas Munro <tmunro@postgresql.org>
Wed, 18 Oct 2023 09:15:54 +0000 (22:15 +1300)
committerThomas Munro <tmunro@postgresql.org>
Wed, 18 Oct 2023 16:17:27 +0000 (05:17 +1300)
Changes required by https://llvm.org/docs/NewPassManager.html.

Back-patch to 12, leaving the final release of 11 unchanged, consistent
with earlier decision not to back-patch LLVM 16 support either.

Author: Dmitry Dolgov <9erthalion6@gmail.com>
Reviewed-by: Andres Freund <andres@anarazel.de>
Reviewed-by: Thomas Munro <thomas.munro@gmail.com>
Discussion: https://postgr.es/m/CA%2BhUKG%2BWXznXCyTgCADd%3DHWkP9Qksa6chd7L%3DGCnZo-MBgg9Lg%40mail.gmail.com

src/backend/jit/llvm/llvmjit.c
src/backend/jit/llvm/llvmjit_wrap.cpp

index 3867ec589d26f920050f08a5c852f72bb75f15de..a87cd3d054bc1d8655bfbcefbf89cac699dab732 100644 (file)
@@ -29,6 +29,9 @@
 #include <llvm-c/BitWriter.h>
 #include <llvm-c/Core.h>
 #include <llvm-c/ExecutionEngine.h>
+#if LLVM_VERSION_MAJOR > 16
+#include <llvm-c/Transforms/PassBuilder.h>
+#endif
 #if LLVM_VERSION_MAJOR > 11
 #include <llvm-c/Orc.h>
 #include <llvm-c/OrcEE.h>
 #endif
 #include <llvm-c/Support.h>
 #include <llvm-c/Target.h>
+#if LLVM_VERSION_MAJOR < 17
 #include <llvm-c/Transforms/IPO.h>
 #include <llvm-c/Transforms/PassManagerBuilder.h>
 #include <llvm-c/Transforms/Scalar.h>
 #if LLVM_VERSION_MAJOR > 6
 #include <llvm-c/Transforms/Utils.h>
 #endif
+#endif
 
 
 /* Handle of a module emitted via ORC JIT */
@@ -564,6 +569,7 @@ llvm_function_reference(LLVMJitContext *context,
 static void
 llvm_optimize_module(LLVMJitContext *context, LLVMModuleRef module)
 {
+#if LLVM_VERSION_MAJOR < 17
    LLVMPassManagerBuilderRef llvm_pmb;
    LLVMPassManagerRef llvm_mpm;
    LLVMPassManagerRef llvm_fpm;
@@ -627,6 +633,31 @@ llvm_optimize_module(LLVMJitContext *context, LLVMModuleRef module)
    LLVMDisposePassManager(llvm_mpm);
 
    LLVMPassManagerBuilderDispose(llvm_pmb);
+#else
+   LLVMPassBuilderOptionsRef options;
+   LLVMErrorRef err;
+   const char *passes;
+
+   if (context->base.flags & PGJIT_OPT3)
+       passes = "default<O3>";
+   else
+       passes = "default<O0>,mem2reg";
+
+   options = LLVMCreatePassBuilderOptions();
+
+#ifdef LLVM_PASS_DEBUG
+   LLVMPassBuilderOptionsSetDebugLogging(options, 1);
+#endif
+
+   LLVMPassBuilderOptionsSetInlinerThreshold(options, 512);
+
+   err = LLVMRunPasses(module, passes, NULL, options);
+
+   if (err)
+       elog(ERROR, "failed to JIT module: %s", llvm_error_message(err));
+
+   LLVMDisposePassBuilderOptions(options);
+#endif
 }
 
 /*
index 89b276e692c45343c4be682b162ebed9ae24ba74..1c374d937a42a3afda93cb5c01de089c38730e10 100644 (file)
@@ -23,8 +23,14 @@ extern "C"
 
 #include <llvm/IR/Attributes.h>
 #include <llvm/IR/Function.h>
+#if LLVM_VERSION_MAJOR < 17
 #include <llvm/MC/SubtargetFeature.h>
+#endif
+#if LLVM_VERSION_MAJOR > 16
+#include <llvm/TargetParser/Host.h>
+#else
 #include <llvm/Support/Host.h>
+#endif
 
 #include "jit/llvmjit.h"