jit: Don't inline functions that access thread-locals.
authorThomas Munro
Thu, 22 Jul 2021 02:11:17 +0000 (14:11 +1200)
committerThomas Munro
Thu, 22 Jul 2021 03:07:52 +0000 (15:07 +1200)
Code inlined by LLVM can crash or fail with "Relocation type not
implemented yet!" if it tries to access thread local variables.  Don't
inline such code.

Back-patch to 11, where LLVM arrived.  Bug #16696.

Author: Dmitry Marakasov 
Reviewed-by: Andres Freund
Discussion: https://postgr.es/m/16696-29d944a33801fbfe@postgresql.org

src/backend/jit/llvm/llvmjit_inline.cpp

index 2617a461caddf1304b17ea7b8a44ae6e85febb24..40b18d9a0eb32b3799284d937732e7ced1c3efa8 100644 (file)
@@ -608,6 +608,17 @@ function_inlinable(llvm::Function &F,
        if (rv->materialize())
            elog(FATAL, "failed to materialize metadata");
 
+       /*
+        * Don't inline functions that access thread local variables.  That
+        * doesn't work on current LLVM releases (but might in future).
+        */
+       if (rv->isThreadLocal())
+       {
+           ilog(DEBUG1, "cannot inline %s due to thread-local variable %s",
+                F.getName().data(), rv->getName().data());
+           return false;
+       }
+
        /*
         * Never want to inline externally visible vars, cheap enough to
         * reference.