mirror of
https://git.postgresql.org/git/postgresql.git
synced 2025-01-12 18:34:36 +08:00
Prevent generating EEOP_AGG_STRICT_INPUT_CHECK operations when nargs == 0.
This only became a problem with4c640f4f38
, 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-, like4c640f4f38
.
This commit is contained in:
parent
4c640f4f38
commit
793beab37e
@ -3023,7 +3023,7 @@ ExecBuildAggTrans(AggState *aggstate, AggStatePerPhase phase,
|
||||
* just keep the prior transValue. This is true for both plain and
|
||||
* sorted/distinct aggregates.
|
||||
*/
|
||||
if (trans_fcinfo->flinfo->fn_strict && numInputs > 0)
|
||||
if (trans_fcinfo->flinfo->fn_strict && pertrans->numTransInputs > 0)
|
||||
{
|
||||
scratch.opcode = EEOP_AGG_STRICT_INPUT_CHECK;
|
||||
scratch.d.agg_strict_input_check.nulls = strictnulls;
|
||||
|
@ -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));
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user