[go: up one dir, main page]

File: dump.py

package info (click to toggle)
uftrace 0.18.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,356 kB
  • sloc: ansic: 49,770; python: 11,181; asm: 837; makefile: 769; sh: 637; cpp: 627; javascript: 191
file content (70 lines) | stat: -rw-r--r-- 2,225 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#
# dump.py
#
# Target program is executed with the given uftrace options below.
# uftrace-option: --auto-args --nest-libcall
#

# uftrace_entry and uftrace_exit are executed only for listed functions.
# UFTRACE_FUNCS = [ "foo", "bar" ]

# uftrace_begin is optional, so can be omitted.
def uftrace_begin(ctx):
    print("uftrace_begin(ctx)")
    print("  record  : %s" % ctx["record"])
    print("  version : %s" % ctx["version"])
    if "cmds" in ctx:
        print("  cmds    : %s" % " ".join(ctx["cmds"]))
    print("")

# uftrace_entry is executed at the entry of each function.
# if UFTRACE_FUNCS is defined, only the listed functions enter here.
def uftrace_entry(ctx):
    _tid        = ctx["tid"]
    _depth      = ctx["depth"]
    _time       = ctx["timestamp"]
    # _duration = ctx["duration"]        # exit only
    _address    = ctx["address"]
    _name       = ctx["name"]

    unit = 10 ** 9
    print("%d.%09d %7d: [entry] %s(%x) depth: %d" %
            (_time / unit, _time % unit, _tid, _name, _address, _depth))

    if "args" in ctx:
        for i in range(len(ctx["args"])):
            arg = ctx["args"][i]
            print("  args[%d] %s: %s" % (i, type(arg), arg))

# uftrace_exit is executed at the exit of each function.
# if UFTRACE_FUNCS is defined, only the listed functions enter here.
def uftrace_exit(ctx):
    _tid        = ctx["tid"]
    _depth      = ctx["depth"]
    _time       = ctx["timestamp"]
    _duration   = ctx["duration"]        # not used here
    _address    = ctx["address"]
    _name       = ctx["name"]

    unit = 10 ** 9
    print("%d.%09d %7d: [exit ] %s(%x) depth: %d" %
            (_time / unit, _time % unit, _tid, _name, _address, _depth))

    if "retval" in ctx:
        ret = ctx["retval"]
        print("  retval  %s: %s" % (type(ret), ret))

# uftrace_event is executed for each event.
def uftrace_event(ctx):
    _tid        = ctx["tid"]
    _time       = ctx["timestamp"]
    _address    = ctx["address"]
    _name       = ctx["name"]

    unit = 10 ** 9
    print("%d.%09d %7d: [event] %s(%x)" %
            (_time / unit, _time % unit, _tid, _name, _address))

# uftrace_end is optional, so can be omitted.
def uftrace_end():
    print("\nuftrace_end()")