qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
To: Markus Armbruster <armbru@redhat.com>
Cc: qemu-devel@nongnu.org
Subject: Re: [Qemu-devel] [PATCH 04/17] tcg: Simplify how dump_exec_info() prints
Date: Fri, 12 Apr 2019 18:09:40 +0100	[thread overview]
Message-ID: <20190412170939.GJ2906@work-vm> (raw)
In-Reply-To: <20190411152520.10061-5-armbru@redhat.com>

* Markus Armbruster (armbru@redhat.com) wrote:
> dump_exec_info() takes an fprintf()-like callback and a FILE * to pass
> to it.
> 
> Its only caller hmp_info_jit() passes monitor_fprintf() and the
> current monitor cast to FILE *.  monitor_fprintf() casts it right
> back, and is otherwise identical to monitor_printf().  The
> type-punning is ugly.
> 
> Drop the callback, and call qemu_printf() instead.
> 
> Signed-off-by: Markus Armbruster <armbru@redhat.com>

Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com>

> ---
>  accel/tcg/translate-all.c | 45 ++++++++++++++++++++-------------------
>  include/exec/cpu-all.h    |  2 +-
>  monitor.c                 |  2 +-
>  tcg/tcg.c                 | 41 ++++++++++++++++++-----------------
>  tcg/tcg.h                 |  2 +-
>  5 files changed, 47 insertions(+), 45 deletions(-)
> 
> diff --git a/accel/tcg/translate-all.c b/accel/tcg/translate-all.c
> index 85e80a1fad..75a6cf49f1 100644
> --- a/accel/tcg/translate-all.c
> +++ b/accel/tcg/translate-all.c
> @@ -50,6 +50,7 @@
>  #include "translate-all.h"
>  #include "qemu/bitmap.h"
>  #include "qemu/error-report.h"
> +#include "qemu/qemu-print.h"
>  #include "qemu/timer.h"
>  #include "qemu/main-loop.h"
>  #include "exec/log.h"
> @@ -2214,8 +2215,7 @@ void tb_flush_jmp_cache(CPUState *cpu, target_ulong addr)
>      tb_jmp_cache_clear_page(cpu, addr);
>  }
>  
> -static void print_qht_statistics(FILE *f, fprintf_function cpu_fprintf,
> -                                 struct qht_stats hst)
> +static void print_qht_statistics(struct qht_stats hst)
>  {
>      uint32_t hgram_opts;
>      size_t hgram_bins;
> @@ -2224,7 +2224,7 @@ static void print_qht_statistics(FILE *f, fprintf_function cpu_fprintf,
>      if (!hst.head_buckets) {
>          return;
>      }
> -    cpu_fprintf(f, "TB hash buckets     %zu/%zu (%0.2f%% head buckets used)\n",
> +    qemu_printf("TB hash buckets     %zu/%zu (%0.2f%% head buckets used)\n",
>                  hst.used_head_buckets, hst.head_buckets,
>                  (double)hst.used_head_buckets / hst.head_buckets * 100);
>  
> @@ -2234,7 +2234,7 @@ static void print_qht_statistics(FILE *f, fprintf_function cpu_fprintf,
>          hgram_opts |= QDIST_PR_NODECIMAL;
>      }
>      hgram = qdist_pr(&hst.occupancy, 10, hgram_opts);
> -    cpu_fprintf(f, "TB hash occupancy   %0.2f%% avg chain occ. Histogram: %s\n",
> +    qemu_printf("TB hash occupancy   %0.2f%% avg chain occ. Histogram: %s\n",
>                  qdist_avg(&hst.occupancy) * 100, hgram);
>      g_free(hgram);
>  
> @@ -2247,7 +2247,7 @@ static void print_qht_statistics(FILE *f, fprintf_function cpu_fprintf,
>          hgram_opts |= QDIST_PR_NODECIMAL | QDIST_PR_NOBINRANGE;
>      }
>      hgram = qdist_pr(&hst.chain, hgram_bins, hgram_opts);
> -    cpu_fprintf(f, "TB hash avg chain   %0.3f buckets. Histogram: %s\n",
> +    qemu_printf("TB hash avg chain   %0.3f buckets. Histogram: %s\n",
>                  qdist_avg(&hst.chain), hgram);
>      g_free(hgram);
>  }
> @@ -2285,7 +2285,7 @@ static gboolean tb_tree_stats_iter(gpointer key, gpointer value, gpointer data)
>      return false;
>  }
>  
> -void dump_exec_info(FILE *f, fprintf_function cpu_fprintf)
> +void dump_exec_info(void)
>  {
>      struct tb_tree_stats tst = {};
>      struct qht_stats hst;
> @@ -2294,43 +2294,44 @@ void dump_exec_info(FILE *f, fprintf_function cpu_fprintf)
>      tcg_tb_foreach(tb_tree_stats_iter, &tst);
>      nb_tbs = tst.nb_tbs;
>      /* XXX: avoid using doubles ? */
> -    cpu_fprintf(f, "Translation buffer state:\n");
> +    qemu_printf("Translation buffer state:\n");
>      /*
>       * Report total code size including the padding and TB structs;
>       * otherwise users might think "-tb-size" is not honoured.
>       * For avg host size we use the precise numbers from tb_tree_stats though.
>       */
> -    cpu_fprintf(f, "gen code size       %zu/%zu\n",
> +    qemu_printf("gen code size       %zu/%zu\n",
>                  tcg_code_size(), tcg_code_capacity());
> -    cpu_fprintf(f, "TB count            %zu\n", nb_tbs);
> -    cpu_fprintf(f, "TB avg target size  %zu max=%zu bytes\n",
> +    qemu_printf("TB count            %zu\n", nb_tbs);
> +    qemu_printf("TB avg target size  %zu max=%zu bytes\n",
>                  nb_tbs ? tst.target_size / nb_tbs : 0,
>                  tst.max_target_size);
> -    cpu_fprintf(f, "TB avg host size    %zu bytes (expansion ratio: %0.1f)\n",
> +    qemu_printf("TB avg host size    %zu bytes (expansion ratio: %0.1f)\n",
>                  nb_tbs ? tst.host_size / nb_tbs : 0,
>                  tst.target_size ? (double)tst.host_size / tst.target_size : 0);
> -    cpu_fprintf(f, "cross page TB count %zu (%zu%%)\n", tst.cross_page,
> -            nb_tbs ? (tst.cross_page * 100) / nb_tbs : 0);
> -    cpu_fprintf(f, "direct jump count   %zu (%zu%%) (2 jumps=%zu %zu%%)\n",
> +    qemu_printf("cross page TB count %zu (%zu%%)\n", tst.cross_page,
> +                nb_tbs ? (tst.cross_page * 100) / nb_tbs : 0);
> +    qemu_printf("direct jump count   %zu (%zu%%) (2 jumps=%zu %zu%%)\n",
>                  tst.direct_jmp_count,
>                  nb_tbs ? (tst.direct_jmp_count * 100) / nb_tbs : 0,
>                  tst.direct_jmp2_count,
>                  nb_tbs ? (tst.direct_jmp2_count * 100) / nb_tbs : 0);
>  
>      qht_statistics_init(&tb_ctx.htable, &hst);
> -    print_qht_statistics(f, cpu_fprintf, hst);
> +    print_qht_statistics(hst);
>      qht_statistics_destroy(&hst);
>  
> -    cpu_fprintf(f, "\nStatistics:\n");
> -    cpu_fprintf(f, "TB flush count      %u\n",
> +    qemu_printf("\nStatistics:\n");
> +    qemu_printf("TB flush count      %u\n",
>                  atomic_read(&tb_ctx.tb_flush_count));
> -    cpu_fprintf(f, "TB invalidate count %zu\n", tcg_tb_phys_invalidate_count());
> +    qemu_printf("TB invalidate count %zu\n",
> +                tcg_tb_phys_invalidate_count());
>  
>      tlb_flush_counts(&flush_full, &flush_part, &flush_elide);
> -    cpu_fprintf(f, "TLB full flushes    %zu\n", flush_full);
> -    cpu_fprintf(f, "TLB partial flushes %zu\n", flush_part);
> -    cpu_fprintf(f, "TLB elided flushes  %zu\n", flush_elide);
> -    tcg_dump_info(f, cpu_fprintf);
> +    qemu_printf("TLB full flushes    %zu\n", flush_full);
> +    qemu_printf("TLB partial flushes %zu\n", flush_part);
> +    qemu_printf("TLB elided flushes  %zu\n", flush_elide);
> +    tcg_dump_info();
>  }
>  
>  void dump_opcount_info(void)
> diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h
> index 40f5edf4dc..da07ce311f 100644
> --- a/include/exec/cpu-all.h
> +++ b/include/exec/cpu-all.h
> @@ -362,7 +362,7 @@ static inline bool tlb_hit(target_ulong tlb_addr, target_ulong addr)
>      return tlb_hit_page(tlb_addr, addr & TARGET_PAGE_MASK);
>  }
>  
> -void dump_exec_info(FILE *f, fprintf_function cpu_fprintf);
> +void dump_exec_info(void);
>  void dump_opcount_info(void);
>  #endif /* !CONFIG_USER_ONLY */
>  
> diff --git a/monitor.c b/monitor.c
> index 30a7ffe32b..24e4d49d11 100644
> --- a/monitor.c
> +++ b/monitor.c
> @@ -1318,7 +1318,7 @@ static void hmp_info_jit(Monitor *mon, const QDict *qdict)
>          return;
>      }
>  
> -    dump_exec_info((FILE *)mon, monitor_fprintf);
> +    dump_exec_info();
>      dump_drift_info((FILE *)mon, monitor_fprintf);
>  }
>  
> diff --git a/tcg/tcg.c b/tcg/tcg.c
> index cc5f4e2a03..6a22c8746c 100644
> --- a/tcg/tcg.c
> +++ b/tcg/tcg.c
> @@ -4015,7 +4015,7 @@ int tcg_gen_code(TCGContext *s, TranslationBlock *tb)
>  }
>  
>  #ifdef CONFIG_PROFILER
> -void tcg_dump_info(FILE *f, fprintf_function cpu_fprintf)
> +void tcg_dump_info(void)
>  {
>      TCGProfile prof = {};
>      const TCGProfile *s;
> @@ -4029,52 +4029,53 @@ void tcg_dump_info(FILE *f, fprintf_function cpu_fprintf)
>      tb_div_count = tb_count ? tb_count : 1;
>      tot = s->interm_time + s->code_time;
>  
> -    cpu_fprintf(f, "JIT cycles          %" PRId64 " (%0.3f s at 2.4 GHz)\n",
> +    qemu_printf("JIT cycles          %" PRId64 " (%0.3f s at 2.4 GHz)\n",
>                  tot, tot / 2.4e9);
> -    cpu_fprintf(f, "translated TBs      %" PRId64 " (aborted=%" PRId64 " %0.1f%%)\n", 
> +    qemu_printf("translated TBs      %" PRId64 " (aborted=%" PRId64
> +                " %0.1f%%)\n",
>                  tb_count, s->tb_count1 - tb_count,
>                  (double)(s->tb_count1 - s->tb_count)
>                  / (s->tb_count1 ? s->tb_count1 : 1) * 100.0);
> -    cpu_fprintf(f, "avg ops/TB          %0.1f max=%d\n", 
> +    qemu_printf("avg ops/TB          %0.1f max=%d\n",
>                  (double)s->op_count / tb_div_count, s->op_count_max);
> -    cpu_fprintf(f, "deleted ops/TB      %0.2f\n",
> +    qemu_printf("deleted ops/TB      %0.2f\n",
>                  (double)s->del_op_count / tb_div_count);
> -    cpu_fprintf(f, "avg temps/TB        %0.2f max=%d\n",
> +    qemu_printf("avg temps/TB        %0.2f max=%d\n",
>                  (double)s->temp_count / tb_div_count, s->temp_count_max);
> -    cpu_fprintf(f, "avg host code/TB    %0.1f\n",
> +    qemu_printf("avg host code/TB    %0.1f\n",
>                  (double)s->code_out_len / tb_div_count);
> -    cpu_fprintf(f, "avg search data/TB  %0.1f\n",
> +    qemu_printf("avg search data/TB  %0.1f\n",
>                  (double)s->search_out_len / tb_div_count);
>      
> -    cpu_fprintf(f, "cycles/op           %0.1f\n", 
> +    qemu_printf("cycles/op           %0.1f\n",
>                  s->op_count ? (double)tot / s->op_count : 0);
> -    cpu_fprintf(f, "cycles/in byte      %0.1f\n", 
> +    qemu_printf("cycles/in byte      %0.1f\n",
>                  s->code_in_len ? (double)tot / s->code_in_len : 0);
> -    cpu_fprintf(f, "cycles/out byte     %0.1f\n", 
> +    qemu_printf("cycles/out byte     %0.1f\n",
>                  s->code_out_len ? (double)tot / s->code_out_len : 0);
> -    cpu_fprintf(f, "cycles/search byte     %0.1f\n",
> +    qemu_printf("cycles/search byte     %0.1f\n",
>                  s->search_out_len ? (double)tot / s->search_out_len : 0);
>      if (tot == 0) {
>          tot = 1;
>      }
> -    cpu_fprintf(f, "  gen_interm time   %0.1f%%\n", 
> +    qemu_printf("  gen_interm time   %0.1f%%\n",
>                  (double)s->interm_time / tot * 100.0);
> -    cpu_fprintf(f, "  gen_code time     %0.1f%%\n", 
> +    qemu_printf("  gen_code time     %0.1f%%\n",
>                  (double)s->code_time / tot * 100.0);
> -    cpu_fprintf(f, "optim./code time    %0.1f%%\n",
> +    qemu_printf("optim./code time    %0.1f%%\n",
>                  (double)s->opt_time / (s->code_time ? s->code_time : 1)
>                  * 100.0);
> -    cpu_fprintf(f, "liveness/code time  %0.1f%%\n", 
> +    qemu_printf("liveness/code time  %0.1f%%\n",
>                  (double)s->la_time / (s->code_time ? s->code_time : 1) * 100.0);
> -    cpu_fprintf(f, "cpu_restore count   %" PRId64 "\n",
> +    qemu_printf("cpu_restore count   %" PRId64 "\n",
>                  s->restore_count);
> -    cpu_fprintf(f, "  avg cycles        %0.1f\n",
> +    qemu_printf("  avg cycles        %0.1f\n",
>                  s->restore_count ? (double)s->restore_time / s->restore_count : 0);
>  }
>  #else
> -void tcg_dump_info(FILE *f, fprintf_function cpu_fprintf)
> +void tcg_dump_info(void)
>  {
> -    cpu_fprintf(f, "[TCG profiler not compiled]\n");
> +    qemu_printf("[TCG profiler not compiled]\n");
>  }
>  #endif
>  
> diff --git a/tcg/tcg.h b/tcg/tcg.h
> index 9f2b03f119..a394d78237 100644
> --- a/tcg/tcg.h
> +++ b/tcg/tcg.h
> @@ -1017,7 +1017,7 @@ int tcg_check_temp_count(void);
>  #endif
>  
>  int64_t tcg_cpu_exec_time(void);
> -void tcg_dump_info(FILE *f, fprintf_function cpu_fprintf);
> +void tcg_dump_info(void);
>  void tcg_dump_op_count(void);
>  
>  #define TCG_CT_ALIAS  0x80
> -- 
> 2.17.2
> 
--
Dr. David Alan Gilbert / dgilbert@redhat.com / Manchester, UK

  parent reply	other threads:[~2019-04-12 17:09 UTC|newest]

Thread overview: 82+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2019-04-11 15:25 [Qemu-devel] [PATCH 00/17] Clean up and simplify around fprintf_function Markus Armbruster
2019-04-11 15:25 ` Markus Armbruster
2019-04-11 15:25 ` [Qemu-devel] [PATCH 01/17] include: Include fprintf-fn.h only where needed Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 16:53   ` Dr. David Alan Gilbert
2019-04-12 16:53     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 02/17] trace: Simplify how st_print_trace_file_status() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 16:55   ` Dr. David Alan Gilbert
2019-04-12 16:55     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 03/17] tcg: Simplify how dump_opcount_info() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 16:58   ` Dr. David Alan Gilbert
2019-04-12 16:58     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 04/17] tcg: Simplify how dump_exec_info() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:09   ` Dr. David Alan Gilbert [this message]
2019-04-12 17:09     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 05/17] tcg: Simplify how dump_drift_info() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:18   ` Dr. David Alan Gilbert
2019-04-12 17:18     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 06/17] qsp: Simplify how qsp_report() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:25   ` Dr. David Alan Gilbert
2019-04-12 17:25     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 07/17] block/qapi: Clean up how we print to monitor or stdout Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:59   ` Dr. David Alan Gilbert
2019-04-12 17:59     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 08/17] memory: Clean up how mtree_info() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:44   ` Dr. David Alan Gilbert
2019-04-12 17:44     ` Dr. David Alan Gilbert
2019-04-12 18:25     ` Markus Armbruster
2019-04-12 18:25       ` Markus Armbruster
2019-04-11 15:25 ` [Qemu-devel] [PATCH 09/17] target: Simplify how the TARGET_cpu_list() print Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-15 15:43   ` Dr. David Alan Gilbert
2019-04-15 15:43     ` Dr. David Alan Gilbert
2019-04-16  6:14     ` Markus Armbruster
2019-04-16  6:14       ` Markus Armbruster
2019-04-16  8:20       ` Dr. David Alan Gilbert
2019-04-16  8:20         ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 10/17] target: Clean up how the dump_mmu() print Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-15 15:53   ` Dr. David Alan Gilbert
2019-04-15 15:53     ` Dr. David Alan Gilbert
2019-04-16  6:23     ` Markus Armbruster
2019-04-16  6:23       ` Markus Armbruster
2019-04-11 15:25 ` [Qemu-devel] [PATCH 11/17] target/i386: Simplify how x86_cpu_dump_local_apic_state() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:49   ` Dr. David Alan Gilbert
2019-04-12 17:49     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 12/17] qom/cpu: Simplify how CPUClass::dump_statistics() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:50   ` Dr. David Alan Gilbert
2019-04-12 17:50     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 13/17] qemu-print: New qemu_fprintf(), qemu_vfprintf() Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 17:53   ` Dr. David Alan Gilbert
2019-04-12 17:53     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 14/17] qom/cpu: Simplify how CPUClass:cpu_dump_state() prints Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-15 16:47   ` Dr. David Alan Gilbert
2019-04-15 16:47     ` Dr. David Alan Gilbert
2019-04-16  6:32     ` Markus Armbruster
2019-04-16  6:32       ` Markus Armbruster
2019-04-11 15:25 ` [Qemu-devel] [PATCH 15/17] monitor: Clean up how monitor_disas() funnels output to monitor Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 18:01   ` Dr. David Alan Gilbert
2019-04-12 18:01     ` Dr. David Alan Gilbert
2019-04-11 15:25 ` [Qemu-devel] [PATCH 16/17] disas: Rename include/disas/bfd.h back to include/disas/dis-asm.h Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-11 15:25 ` [Qemu-devel] [PATCH 17/17] include: Move fprintf_function to disas/ Markus Armbruster
2019-04-11 15:25   ` Markus Armbruster
2019-04-12 18:39   ` Dr. David Alan Gilbert
2019-04-12 18:39     ` Dr. David Alan Gilbert
2019-04-13  4:59     ` Markus Armbruster
2019-04-13  4:59       ` Markus Armbruster
2019-04-11 15:49 ` [Qemu-devel] [PATCH 00/17] Clean up and simplify around fprintf_function no-reply
2019-04-11 15:49   ` no-reply

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20190412170939.GJ2906@work-vm \
    --to=dgilbert@redhat.com \
    --cc=armbru@redhat.com \
    --cc=qemu-devel@nongnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).