diff options
| author | Pierre LALET <pierre.lalet@cea.fr> | 2015-02-16 19:00:59 +0100 |
|---|---|---|
| committer | Pierre LALET <pierre.lalet@cea.fr> | 2015-02-17 12:50:05 +0100 |
| commit | 0c4dde0602f79fcfbd75b2c6e0a01bbfd1371126 (patch) | |
| tree | d81dade687e89fd19f46293219f3e315d6599498 /miasm2/jitter/jitload.py | |
| parent | 773a0e9a43163d84a619496863c3136e63eafc16 (diff) | |
| download | miasm-0c4dde0602f79fcfbd75b2c6e0a01bbfd1371126.tar.gz miasm-0c4dde0602f79fcfbd75b2c6e0a01bbfd1371126.zip | |
Use wrapper `named_arguments` to log function calls
Diffstat (limited to 'miasm2/jitter/jitload.py')
| -rw-r--r-- | miasm2/jitter/jitload.py | 30 |
1 files changed, 25 insertions, 5 deletions
diff --git a/miasm2/jitter/jitload.py b/miasm2/jitter/jitload.py index defc139a..ccd0a35f 100644 --- a/miasm2/jitter/jitload.py +++ b/miasm2/jitter/jitload.py @@ -9,11 +9,14 @@ from miasm2.core.utils import * from miasm2.core.bin_stream import bin_stream_vm from miasm2.ir.ir2C import init_arch_C -log = logging.getLogger('jitload.py') hnd = logging.StreamHandler() hnd.setFormatter(logging.Formatter("[%(levelname)s]: %(message)s")) +log = logging.getLogger('jitload.py') log.addHandler(hnd) log.setLevel(logging.CRITICAL) +log_func = logging.getLogger('jit function call') +log_func.addHandler(hnd) +log_func.setLevel(logging.CRITICAL) try: from miasm2.jitter.jitcore_tcc import JitCore_Tcc @@ -31,21 +34,38 @@ except ImportError: log.error('cannot import jit python') def named_arguments(func): - """Function decorator to allow the use of .func_args_stdcall() - methods with either the number of arguments or the list of the - argument names. + """Function decorator to allow the use of .func_args_*() methods + with either the number of arguments or the list of the argument + names. + + The wrapper is also used to log the argument values. @func: function + """ @wraps(func) def newfunc(self, args): if isinstance(args, Sequence): ret_ad, arg_vals = func(self, len(args)) + arg_vals = namedtuple("args", args)(*arg_vals) + # func_name(arguments) return address + log_func.info('%s(%s) ret addr: %s' % ( + whoami(), + ', '.join("%s=0x%x" % (field, value) + for field, value in arg_vals._asdict().iteritems()), + hex(ret_ad))) return ret_ad, namedtuple("args", args)(*arg_vals) else: - return func(self, args) + ret_ad, arg_vals = func(self, args) + # func_name(arguments) return address + log_func.info('%s(%s) ret addr: %s' % ( + whoami(), + ', '.join(hex(arg) for arg in arg_vals), + hex(ret_ad))) + return ret_ad, arg_vals return newfunc + class CallbackHandler(object): "Handle a list of callback" |