diff options
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" |