mirror of
https://github.com/postgres/postgres.git
synced 2025-11-04 20:11:56 +03:00
Add JIT deform_counter
generation_counter includes time spent on both JIT:ing expressions and tuple deforming which are configured independently via options jit_expressions and jit_tuple_deforming. As they are combined in the same counter it's not apparent what fraction of time the tuple deforming takes. This adds deform_counter dedicated to tuple deforming, which allows seeing more directly the influence jit_tuple_deforming is having on the query. The counter is exposed in EXPLAIN and pg_stat_statements bumpin pg_stat_statements to 1.11. Author: Dmitry Dolgov <9erthalion6@gmail.com> Reviewed-by: Pavel Stehule <pavel.stehule@gmail.com> Reviewed-by: Daniel Gustafsson <daniel@yesql.se> Discussion: https://postgr.es/m/20220612091253.eegstkufdsu4kfls@erthalion.local
This commit is contained in:
@@ -893,6 +893,7 @@ ExplainPrintJIT(ExplainState *es, int jit_flags, JitInstrumentation *ji)
|
||||
|
||||
/* calculate total time */
|
||||
INSTR_TIME_SET_ZERO(total_time);
|
||||
/* don't add deform_counter, it's included in generation_counter */
|
||||
INSTR_TIME_ADD(total_time, ji->generation_counter);
|
||||
INSTR_TIME_ADD(total_time, ji->inlining_counter);
|
||||
INSTR_TIME_ADD(total_time, ji->optimization_counter);
|
||||
@@ -920,8 +921,9 @@ ExplainPrintJIT(ExplainState *es, int jit_flags, JitInstrumentation *ji)
|
||||
{
|
||||
ExplainIndentText(es);
|
||||
appendStringInfo(es->str,
|
||||
"Timing: %s %.3f ms, %s %.3f ms, %s %.3f ms, %s %.3f ms, %s %.3f ms\n",
|
||||
"Timing: %s %.3f ms (%s %.3f ms), %s %.3f ms, %s %.3f ms, %s %.3f ms, %s %.3f ms\n",
|
||||
"Generation", 1000.0 * INSTR_TIME_GET_DOUBLE(ji->generation_counter),
|
||||
"Deform", 1000.0 * INSTR_TIME_GET_DOUBLE(ji->deform_counter),
|
||||
"Inlining", 1000.0 * INSTR_TIME_GET_DOUBLE(ji->inlining_counter),
|
||||
"Optimization", 1000.0 * INSTR_TIME_GET_DOUBLE(ji->optimization_counter),
|
||||
"Emission", 1000.0 * INSTR_TIME_GET_DOUBLE(ji->emission_counter),
|
||||
@@ -945,9 +947,15 @@ ExplainPrintJIT(ExplainState *es, int jit_flags, JitInstrumentation *ji)
|
||||
{
|
||||
ExplainOpenGroup("Timing", "Timing", true, es);
|
||||
|
||||
ExplainPropertyFloat("Generation", "ms",
|
||||
ExplainOpenGroup("Generation", "Generation", true, es);
|
||||
ExplainPropertyFloat("Deform", "ms",
|
||||
1000.0 * INSTR_TIME_GET_DOUBLE(ji->deform_counter),
|
||||
3, es);
|
||||
ExplainPropertyFloat("Total", "ms",
|
||||
1000.0 * INSTR_TIME_GET_DOUBLE(ji->generation_counter),
|
||||
3, es);
|
||||
ExplainCloseGroup("Generation", "Generation", true, es);
|
||||
|
||||
ExplainPropertyFloat("Inlining", "ms",
|
||||
1000.0 * INSTR_TIME_GET_DOUBLE(ji->inlining_counter),
|
||||
3, es);
|
||||
|
||||
@@ -185,6 +185,7 @@ InstrJitAgg(JitInstrumentation *dst, JitInstrumentation *add)
|
||||
{
|
||||
dst->created_functions += add->created_functions;
|
||||
INSTR_TIME_ADD(dst->generation_counter, add->generation_counter);
|
||||
INSTR_TIME_ADD(dst->deform_counter, add->deform_counter);
|
||||
INSTR_TIME_ADD(dst->inlining_counter, add->inlining_counter);
|
||||
INSTR_TIME_ADD(dst->optimization_counter, add->optimization_counter);
|
||||
INSTR_TIME_ADD(dst->emission_counter, add->emission_counter);
|
||||
|
||||
@@ -121,7 +121,9 @@ llvm_compile_expr(ExprState *state)
|
||||
LLVMValueRef v_aggnulls;
|
||||
|
||||
instr_time starttime;
|
||||
instr_time deform_starttime;
|
||||
instr_time endtime;
|
||||
instr_time deform_endtime;
|
||||
|
||||
llvm_enter_fatal_on_oom();
|
||||
|
||||
@@ -315,10 +317,14 @@ llvm_compile_expr(ExprState *state)
|
||||
*/
|
||||
if (tts_ops && desc && (context->base.flags & PGJIT_DEFORM))
|
||||
{
|
||||
INSTR_TIME_SET_CURRENT(deform_starttime);
|
||||
l_jit_deform =
|
||||
slot_compile_deform(context, desc,
|
||||
tts_ops,
|
||||
op->d.fetch.last_var);
|
||||
INSTR_TIME_SET_CURRENT(deform_endtime);
|
||||
INSTR_TIME_ACCUM_DIFF(context->base.instr.deform_counter,
|
||||
deform_endtime, deform_starttime);
|
||||
}
|
||||
|
||||
if (l_jit_deform)
|
||||
|
||||
Reference in New Issue
Block a user