[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v9 12/13] tb-stats: adding TBStatistics info into perf dump
From: |
Richard Henderson |
Subject: |
Re: [PATCH v9 12/13] tb-stats: adding TBStatistics info into perf dump |
Date: |
Tue, 8 Oct 2019 15:46:50 -0400 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 |
On 10/7/19 11:28 AM, Alex Bennée wrote:
> diff --git a/accel/tcg/perf/jitdump.c b/accel/tcg/perf/jitdump.c
> index e1d6f2214e..e7b86173e0 100644
> --- a/accel/tcg/perf/jitdump.c
> +++ b/accel/tcg/perf/jitdump.c
> @@ -146,7 +146,20 @@ void start_jitdump_file(void)
>
> void append_load_in_jitdump_file(TranslationBlock *tb)
> {
> - gchar *func_name = g_strdup_printf("TB virt:0x"TARGET_FMT_lx, tb->pc);
> + g_autoptr(GString) func_name = g_string_new("TB virt:");
> +
> + g_string_append_printf(func_name, "0x"TARGET_FMT_lx, tb->pc);
I think it was clearer as a single printf. Use g_string_printf().
But now I see where the missing GString went -- bad patch splitting. ;-)
> + if (tb->tb_stats) {
> + TBStatistics *tbs = tb->tb_stats;
> + unsigned g = stat_per_translation(tbs, code.num_guest_inst);
> + unsigned ops = stat_per_translation(tbs, code.num_tcg_ops);
> + unsigned ops_opt = stat_per_translation(tbs, code.num_tcg_ops_opt);
> + unsigned spills = stat_per_translation(tbs, code.spills);
> +
> + g_string_append_printf(func_name, " (g:%u op:%u opt:%u spills:%d)",
> + g, ops, ops_opt, spills);
> + }
Oh, hum. Does it really make sense to have accumulated averages here? Why
does it not make more sense to have the statistics about this particular TB?
After all, different TB -- even for the same guest code -- will appear at
different places within the code_gen_buffer, and so have different entries in
this log.
r~
- [PATCH v9 04/13] accel: replacing part of CONFIG_PROFILER with TBStats, (continued)
- [PATCH v9 04/13] accel: replacing part of CONFIG_PROFILER with TBStats, Alex Bennée, 2019/10/07
- [PATCH v9 08/13] tb-stats: reset the tracked TBs on a tb_flush, Alex Bennée, 2019/10/07
- [PATCH v9 10/13] tb-stats: dump hot TBs at the end of the execution, Alex Bennée, 2019/10/07
- [PATCH v9 05/13] accel: adding TB_JIT_TIME and full replacing CONFIG_PROFILER, Alex Bennée, 2019/10/07
- [PATCH v9 12/13] tb-stats: adding TBStatistics info into perf dump, Alex Bennée, 2019/10/07
- Re: [PATCH v9 12/13] tb-stats: adding TBStatistics info into perf dump,
Richard Henderson <=
- [PATCH v9 13/13] configure: remove the final bits of --profiler support, Alex Bennée, 2019/10/07
- [PATCH v9 09/13] Adding info [tb-list|tb] commands to HMP (WIP), Alex Bennée, 2019/10/07
- [PATCH v9 11/13] accel/tcg: adding integration with linux perf, Alex Bennée, 2019/10/07
- Re: [PATCH v9 00/13] TCG code quality tracking and perf integration, no-reply, 2019/10/07
- Re: [PATCH v9 00/13] TCG code quality tracking and perf integration, no-reply, 2019/10/07