mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-23 08:54:34 +00:00 
			
		
		
		
	 864a2178d4
			
		
	
	
		864a2178d4
		
	
	
	
	
		
			
			If an event is dynamically disabled, the TCG code that calls the execution-time tracer is not generated. Removes the overheads of execution-time tracers for dynamically disabled events. As a bonus, also avoids checking the event state when the execution-time tracer is called from TCG-generated code (since otherwise TCG would simply not call it). Signed-off-by: Lluís Vilanova <vilanova@ac.upc.edu> Signed-off-by: Emilio G. Cota <cota@braap.org> Message-id: 149915799921.6295.13067154430923434035.stgit@frigg.lan Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/env python
 | |
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| """
 | |
| Generate .h file for TCG code generation.
 | |
| """
 | |
| 
 | |
| __author__     = "Lluís Vilanova <vilanova@ac.upc.edu>"
 | |
| __copyright__  = "Copyright 2012-2017, Lluís Vilanova <vilanova@ac.upc.edu>"
 | |
| __license__    = "GPL version 2 or (at your option) any later version"
 | |
| 
 | |
| __maintainer__ = "Stefan Hajnoczi"
 | |
| __email__      = "stefanha@linux.vnet.ibm.com"
 | |
| 
 | |
| 
 | |
| from tracetool import out, Arguments
 | |
| import tracetool.vcpu
 | |
| 
 | |
| 
 | |
| def vcpu_transform_args(args):
 | |
|     assert len(args) == 1
 | |
|     return Arguments([
 | |
|         args,
 | |
|         # NOTE: this name must be kept in sync with the one in "tcg_h"
 | |
|         # NOTE: Current helper code uses TCGv_env (CPUArchState*)
 | |
|         ("TCGv_env", "__tcg_" + args.names()[0]),
 | |
|     ])
 | |
| 
 | |
| 
 | |
| def generate(events, backend, group):
 | |
|     if group == "root":
 | |
|         header = "trace-root.h"
 | |
|     else:
 | |
|         header = "trace.h"
 | |
| 
 | |
|     out('/* This file is autogenerated by tracetool, do not edit. */',
 | |
|         '/* You must include this file after the inclusion of helper.h */',
 | |
|         '',
 | |
|         '#ifndef TRACE_%s_GENERATED_TCG_TRACERS_H' % group.upper(),
 | |
|         '#define TRACE_%s_GENERATED_TCG_TRACERS_H' % group.upper(),
 | |
|         '',
 | |
|         '#include "exec/helper-proto.h"',
 | |
|         '#include "%s"' % header,
 | |
|         '',
 | |
|         )
 | |
| 
 | |
|     for e in events:
 | |
|         # just keep one of them
 | |
|         if "tcg-exec" not in e.properties:
 | |
|             continue
 | |
| 
 | |
|         out('static inline void %(name_tcg)s(%(args)s)',
 | |
|             '{',
 | |
|             name_tcg=e.original.api(e.QEMU_TRACE_TCG),
 | |
|             args=tracetool.vcpu.transform_args("tcg_h", e.original))
 | |
| 
 | |
|         if "disable" not in e.properties:
 | |
|             args_trans = e.original.event_trans.args
 | |
|             args_exec = tracetool.vcpu.transform_args(
 | |
|                 "tcg_helper_c", e.original.event_exec, "wrapper")
 | |
|             if "vcpu" in e.properties:
 | |
|                 trace_cpu = e.args.names()[0]
 | |
|                 cond = "trace_event_get_vcpu_state(%(cpu)s,"\
 | |
|                        " TRACE_%(id)s)"\
 | |
|                        % dict(
 | |
|                            cpu=trace_cpu,
 | |
|                            id=e.original.event_exec.name.upper())
 | |
|             else:
 | |
|                 cond = "true"
 | |
| 
 | |
|             out('    %(name_trans)s(%(argnames_trans)s);',
 | |
|                 '    if (%(cond)s) {',
 | |
|                 '        gen_helper_%(name_exec)s(%(argnames_exec)s);',
 | |
|                 '    }',
 | |
|                 name_trans=e.original.event_trans.api(e.QEMU_TRACE),
 | |
|                 name_exec=e.original.event_exec.api(e.QEMU_TRACE),
 | |
|                 argnames_trans=", ".join(args_trans.names()),
 | |
|                 argnames_exec=", ".join(args_exec.names()),
 | |
|                 cond=cond)
 | |
| 
 | |
|         out('}')
 | |
| 
 | |
|     out('',
 | |
|         '#endif /* TRACE_%s_GENERATED_TCG_TRACERS_H */' % group.upper())
 |