2
0

tracetool.py 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. Command-line wrapper for the tracetool machinery.
  5. """
  6. __author__ = "Lluís Vilanova <vilanova@ac.upc.edu>"
  7. __copyright__ = "Copyright 2012-2014, 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@redhat.com"
  11. import sys
  12. import getopt
  13. from tracetool import error_write, out, out_open
  14. import tracetool.backend
  15. import tracetool.format
  16. _SCRIPT = ""
  17. def error_opt(msg = None):
  18. if msg is not None:
  19. error_write("Error: " + msg + "\n")
  20. backend_descr = "\n".join([ " %-15s %s" % (n, d)
  21. for n,d in tracetool.backend.get_list() ])
  22. format_descr = "\n".join([ " %-15s %s" % (n, d)
  23. for n,d in tracetool.format.get_list() ])
  24. error_write("""\
  25. Usage: %(script)s --format=<format> --backends=<backends> [<options>] <trace-events> ... <output>
  26. Backends:
  27. %(backends)s
  28. Formats:
  29. %(formats)s
  30. Options:
  31. --help This help message.
  32. --list-backends Print list of available backends.
  33. --check-backends Check if the given backend is valid.
  34. --binary <path> Full path to QEMU binary (required for 'stap' backend).
  35. --group <name> Name of the event group.
  36. --probe-prefix <prefix> Prefix for dtrace probe names (required for 'stap' backend).
  37. """ % {
  38. "script" : _SCRIPT,
  39. "backends" : backend_descr,
  40. "formats" : format_descr,
  41. })
  42. if msg is None:
  43. sys.exit(0)
  44. else:
  45. sys.exit(1)
  46. def main(args):
  47. global _SCRIPT
  48. _SCRIPT = args[0]
  49. long_opts = ["backends=", "format=", "help", "list-backends",
  50. "check-backends", "group="]
  51. long_opts += ["binary=", "probe-prefix="]
  52. try:
  53. opts, args = getopt.getopt(args[1:], "", long_opts)
  54. except getopt.GetoptError as err:
  55. error_opt(str(err))
  56. check_backends = False
  57. arg_backends = []
  58. arg_format = ""
  59. arg_group = None
  60. binary = None
  61. probe_prefix = None
  62. for opt, arg in opts:
  63. if opt == "--help":
  64. error_opt()
  65. elif opt == "--backends":
  66. arg_backends = arg.split(",")
  67. elif opt == "--group":
  68. arg_group = arg
  69. elif opt == "--format":
  70. arg_format = arg
  71. elif opt == "--list-backends":
  72. public_backends = tracetool.backend.get_list(only_public = True)
  73. out(", ".join([ b for b,_ in public_backends ]))
  74. sys.exit(0)
  75. elif opt == "--check-backends":
  76. check_backends = True
  77. elif opt == "--binary":
  78. binary = arg
  79. elif opt == '--probe-prefix':
  80. probe_prefix = arg
  81. else:
  82. error_opt("unhandled option: %s" % opt)
  83. if len(arg_backends) == 0:
  84. error_opt("no backends specified")
  85. if check_backends:
  86. for backend in arg_backends:
  87. if not tracetool.backend.exists(backend):
  88. sys.exit(1)
  89. sys.exit(0)
  90. if arg_group is None:
  91. error_opt("group name is required")
  92. if arg_format == "stap":
  93. if binary is None:
  94. error_opt("--binary is required for SystemTAP tapset generator")
  95. if probe_prefix is None:
  96. error_opt("--probe-prefix is required for SystemTAP tapset generator")
  97. if len(args) < 2:
  98. error_opt("missing trace-events and output filepaths")
  99. events = []
  100. for arg in args[:-1]:
  101. with open(arg, "r") as fh:
  102. events.extend(tracetool.read_events(fh, arg))
  103. out_open(args[-1])
  104. try:
  105. tracetool.generate(events, arg_group, arg_format, arg_backends,
  106. binary=binary, probe_prefix=probe_prefix)
  107. except tracetool.TracetoolError as e:
  108. error_opt(str(e))
  109. if __name__ == "__main__":
  110. main(sys.argv)