dtrace.py 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. """
  4. DTrace/SystemTAP backend.
  5. """
  6. __author__ = "Lluís Vilanova <vilanova@ac.upc.edu>"
  7. __copyright__ = "Copyright 2012-2017, Lluís Vilanova <vilanova@ac.upc.edu>"
  8. __license__ = "GPL version 2 or (at your option) any later version"
  9. __maintainer__ = "Stefan Hajnoczi"
  10. __email__ = "stefanha@linux.vnet.ibm.com"
  11. from tracetool import out
  12. PUBLIC = True
  13. PROBEPREFIX = None
  14. def probeprefix():
  15. if PROBEPREFIX is None:
  16. raise ValueError("you must set PROBEPREFIX")
  17. return PROBEPREFIX
  18. BINARY = None
  19. def binary():
  20. if BINARY is None:
  21. raise ValueError("you must set BINARY")
  22. return BINARY
  23. def generate_h_begin(events, group):
  24. if group == "root":
  25. header = "trace-dtrace-root.h"
  26. else:
  27. header = "trace-dtrace.h"
  28. out('#include "%s"' % header,
  29. '')
  30. # SystemTap defines <provider>_<name>_ENABLED() but other DTrace
  31. # implementations might not.
  32. for e in events:
  33. out('#ifndef QEMU_%(uppername)s_ENABLED',
  34. '#define QEMU_%(uppername)s_ENABLED() true',
  35. '#endif',
  36. uppername=e.name.upper())
  37. def generate_h(event, group):
  38. out(' QEMU_%(uppername)s(%(argnames)s);',
  39. uppername=event.name.upper(),
  40. argnames=", ".join(event.args.names()))
  41. def generate_h_backend_dstate(event, group):
  42. out(' QEMU_%(uppername)s_ENABLED() || \\',
  43. uppername=event.name.upper())