diff options
author | Andres Freund <andres@anarazel.de> | 2018-11-03 15:55:23 -0700 |
---|---|---|
committer | Andres Freund <andres@anarazel.de> | 2018-11-03 15:55:23 -0700 |
commit | 793beab37e8f7ec6a4ef39395c6c866d7e4c7af5 (patch) | |
tree | 229f8bcbf2f5745efb4321bcdb1266612c0078bb /src/backend/jit/llvm/llvmjit_expr.c | |
parent | 4c640f4f38d5d68cbe33ddfabbdc56eea8f1e173 (diff) | |
download | postgresql-793beab37e8f7ec6a4ef39395c6c866d7e4c7af5.tar.gz postgresql-793beab37e8f7ec6a4ef39395c6c866d7e4c7af5.zip |
Prevent generating EEOP_AGG_STRICT_INPUT_CHECK operations when nargs == 0.
This only became a problem with 4c640f4f38, which didn't synchronize
the value agg_strict_input_check.nargs is set to, with the guard
condition for emitting the operation.
Besides such instructions being unnecessary overhead, currently the
LLVM JIT provider doesn't support them. It seems more sensible to
avoid generating such instruction than supporting them. Add assertions
to make it easier to debug a potential further occurance.
Discussion: https://postgr.es/m/2a505161-2727-2473-7c46-591ed108ac52@email.cz
Backpatch: 11-, like 4c640f4f38.
Diffstat (limited to 'src/backend/jit/llvm/llvmjit_expr.c')
-rw-r--r-- | src/backend/jit/llvm/llvmjit_expr.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/src/backend/jit/llvm/llvmjit_expr.c b/src/backend/jit/llvm/llvmjit_expr.c index e5fe116acbc..42258774783 100644 --- a/src/backend/jit/llvm/llvmjit_expr.c +++ b/src/backend/jit/llvm/llvmjit_expr.c @@ -2124,6 +2124,8 @@ llvm_compile_expr(ExprState *state) LLVMValueRef v_nullp; LLVMBasicBlockRef *b_checknulls; + Assert(nargs > 0); + jumpnull = op->d.agg_strict_input_check.jumpnull; v_nullp = l_ptr_const(nulls, l_ptr(TypeStorageBool)); |