SystemTap's dtrace(1) prints the following warning when it encounters long long arguments: Warning: /usr/bin/dtrace:trace/trace-dtrace-hw_virtio.dtrace:76: syntax error near: probe vhost_vdpa_dev_start Warning: Proceeding as if --no-pyparsing was given. Use the uint64_t and int64_t types, respectively. This works with all host CPU 32- and 64-bit data models (ILP32, LP64, and LLP64) that QEMU supports. Reported-by: Markus Armbruster <armbru@redhat.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Reviewed-by: Daniel P. Berrangé <berrange@redhat.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Message-id: 20201020094043.159935-1-stefanha@redhat.com Suggested-by: Daniel P. Berrangé <berrange@redhat.com> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# -*- coding: utf-8 -*-
 | 
						|
 | 
						|
"""
 | 
						|
trace/generated-tracers.dtrace (DTrace only).
 | 
						|
"""
 | 
						|
 | 
						|
__author__     = "Lluís Vilanova <vilanova@ac.upc.edu>"
 | 
						|
__copyright__  = "Copyright 2012-2014, Lluís Vilanova <vilanova@ac.upc.edu>"
 | 
						|
__license__    = "GPL version 2 or (at your option) any later version"
 | 
						|
 | 
						|
__maintainer__ = "Stefan Hajnoczi"
 | 
						|
__email__      = "stefanha@redhat.com"
 | 
						|
 | 
						|
 | 
						|
from tracetool import out
 | 
						|
from sys import platform
 | 
						|
 | 
						|
 | 
						|
# Reserved keywords from
 | 
						|
# https://wikis.oracle.com/display/DTrace/Types,+Operators+and+Expressions
 | 
						|
RESERVED_WORDS = (
 | 
						|
    'auto', 'goto', 'sizeof', 'break', 'if', 'static', 'case', 'import',
 | 
						|
    'string', 'char', 'inline', 'stringof', 'const', 'int', 'struct',
 | 
						|
    'continue', 'long', 'switch', 'counter', 'offsetof', 'this',
 | 
						|
    'default', 'probe', 'translator', 'do', 'provider', 'typedef',
 | 
						|
    'double', 'register', 'union', 'else', 'restrict', 'unsigned',
 | 
						|
    'enum', 'return', 'void', 'extern', 'self', 'volatile', 'float',
 | 
						|
    'short', 'while', 'for', 'signed', 'xlate',
 | 
						|
)
 | 
						|
 | 
						|
 | 
						|
def generate(events, backend, group):
 | 
						|
    events = [e for e in events
 | 
						|
              if "disable" not in e.properties]
 | 
						|
 | 
						|
    # SystemTap's dtrace(1) warns about empty "provider qemu {}" but is happy
 | 
						|
    # with an empty file.  Avoid the warning.
 | 
						|
    # But dtrace on macOS can't deal with empty files.
 | 
						|
    if not events and platform != "darwin":
 | 
						|
        return
 | 
						|
 | 
						|
    out('/* This file is autogenerated by tracetool, do not edit. */'
 | 
						|
        '',
 | 
						|
        'provider qemu {')
 | 
						|
 | 
						|
    for e in events:
 | 
						|
        args = []
 | 
						|
        for type_, name in e.args:
 | 
						|
            if platform == "darwin":
 | 
						|
                # macOS dtrace accepts only C99 _Bool
 | 
						|
                if type_ == 'bool':
 | 
						|
                    type_ = '_Bool'
 | 
						|
                if type_ == 'bool *':
 | 
						|
                    type_ = '_Bool *'
 | 
						|
                # It converts int8_t * in probe points to char * in header
 | 
						|
                # files and introduces [-Wpointer-sign] warning.
 | 
						|
                # Avoid it by changing probe type to signed char * beforehand.
 | 
						|
                if type_ == 'int8_t *':
 | 
						|
                    type_ = 'signed char *'
 | 
						|
 | 
						|
            # SystemTap dtrace(1) emits a warning when long long is used
 | 
						|
            type_ = type_.replace('unsigned long long', 'uint64_t')
 | 
						|
            type_ = type_.replace('signed long long', 'int64_t')
 | 
						|
            type_ = type_.replace('long long', 'int64_t')
 | 
						|
 | 
						|
            if name in RESERVED_WORDS:
 | 
						|
                name += '_'
 | 
						|
            args.append(type_ + ' ' + name)
 | 
						|
 | 
						|
        # Define prototype for probe arguments
 | 
						|
        out('',
 | 
						|
            'probe %(name)s(%(args)s);',
 | 
						|
            name=e.name,
 | 
						|
            args=','.join(args))
 | 
						|
 | 
						|
    out('',
 | 
						|
        '};')
 |