tcg: Simplify how dump_opcount_info() prints
dump_opcount_info() takes an fprintf()-like callback and a FILE * to pass to it. Its only caller hmp_info_opcount() 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> Message-Id: <20190417191805.28198-4-armbru@redhat.com>
This commit is contained in:
		
							parent
							
								
									ba4912cb0d
								
							
						
					
					
						commit
						d4c51a0af3
					
				| @ -2333,9 +2333,9 @@ void dump_exec_info(FILE *f, fprintf_function cpu_fprintf) | |||||||
|     tcg_dump_info(f, cpu_fprintf); |     tcg_dump_info(f, cpu_fprintf); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void dump_opcount_info(FILE *f, fprintf_function cpu_fprintf) | void dump_opcount_info(void) | ||||||
| { | { | ||||||
|     tcg_dump_op_count(f, cpu_fprintf); |     tcg_dump_op_count(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #else /* CONFIG_USER_ONLY */ | #else /* CONFIG_USER_ONLY */ | ||||||
|  | |||||||
| @ -363,7 +363,7 @@ static inline bool tlb_hit(target_ulong tlb_addr, target_ulong addr) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void dump_exec_info(FILE *f, fprintf_function cpu_fprintf); | void dump_exec_info(FILE *f, fprintf_function cpu_fprintf); | ||||||
| void dump_opcount_info(FILE *f, fprintf_function cpu_fprintf); | void dump_opcount_info(void); | ||||||
| #endif /* !CONFIG_USER_ONLY */ | #endif /* !CONFIG_USER_ONLY */ | ||||||
| 
 | 
 | ||||||
| int cpu_memory_rw_debug(CPUState *cpu, target_ulong addr, | int cpu_memory_rw_debug(CPUState *cpu, target_ulong addr, | ||||||
|  | |||||||
| @ -1324,7 +1324,7 @@ static void hmp_info_jit(Monitor *mon, const QDict *qdict) | |||||||
| 
 | 
 | ||||||
| static void hmp_info_opcount(Monitor *mon, const QDict *qdict) | static void hmp_info_opcount(Monitor *mon, const QDict *qdict) | ||||||
| { | { | ||||||
|     dump_opcount_info((FILE *)mon, monitor_fprintf); |     dump_opcount_info(); | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -33,6 +33,7 @@ | |||||||
| #include "qemu/error-report.h" | #include "qemu/error-report.h" | ||||||
| #include "qemu/cutils.h" | #include "qemu/cutils.h" | ||||||
| #include "qemu/host-utils.h" | #include "qemu/host-utils.h" | ||||||
|  | #include "qemu/qemu-print.h" | ||||||
| #include "qemu/timer.h" | #include "qemu/timer.h" | ||||||
| 
 | 
 | ||||||
| /* Note: the long term plan is to reduce the dependencies on the QEMU
 | /* Note: the long term plan is to reduce the dependencies on the QEMU
 | ||||||
| @ -3768,14 +3769,14 @@ static void tcg_profile_snapshot_table(TCGProfile *prof) | |||||||
|     tcg_profile_snapshot(prof, false, true); |     tcg_profile_snapshot(prof, false, true); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void tcg_dump_op_count(FILE *f, fprintf_function cpu_fprintf) | void tcg_dump_op_count(void) | ||||||
| { | { | ||||||
|     TCGProfile prof = {}; |     TCGProfile prof = {}; | ||||||
|     int i; |     int i; | ||||||
| 
 | 
 | ||||||
|     tcg_profile_snapshot_table(&prof); |     tcg_profile_snapshot_table(&prof); | ||||||
|     for (i = 0; i < NB_OPS; i++) { |     for (i = 0; i < NB_OPS; i++) { | ||||||
|         cpu_fprintf(f, "%s %" PRId64 "\n", tcg_op_defs[i].name, |         qemu_printf("%s %" PRId64 "\n", tcg_op_defs[i].name, | ||||||
|                     prof.table_op_count[i]); |                     prof.table_op_count[i]); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -3795,9 +3796,9 @@ int64_t tcg_cpu_exec_time(void) | |||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
| #else | #else | ||||||
| void tcg_dump_op_count(FILE *f, fprintf_function cpu_fprintf) | void tcg_dump_op_count(void) | ||||||
| { | { | ||||||
|     cpu_fprintf(f, "[TCG profiler not compiled]\n"); |     qemu_printf("[TCG profiler not compiled]\n"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int64_t tcg_cpu_exec_time(void) | int64_t tcg_cpu_exec_time(void) | ||||||
|  | |||||||
| @ -1018,7 +1018,7 @@ int tcg_check_temp_count(void); | |||||||
| 
 | 
 | ||||||
| int64_t tcg_cpu_exec_time(void); | int64_t tcg_cpu_exec_time(void); | ||||||
| void tcg_dump_info(FILE *f, fprintf_function cpu_fprintf); | void tcg_dump_info(FILE *f, fprintf_function cpu_fprintf); | ||||||
| void tcg_dump_op_count(FILE *f, fprintf_function cpu_fprintf); | void tcg_dump_op_count(void); | ||||||
| 
 | 
 | ||||||
| #define TCG_CT_ALIAS  0x80 | #define TCG_CT_ALIAS  0x80 | ||||||
| #define TCG_CT_IALIAS 0x40 | #define TCG_CT_IALIAS 0x40 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Markus Armbruster
						Markus Armbruster