• Tom Zanussi's avatar
    perf/scripts: Tuple was set from long in both branches in python_process_event() · b1dcc03c
    Tom Zanussi authored
    This is a fix to the signed/unsigned field handling in the
    Python scripting engine, based on a patch from Roel Kluin.
    
    Basically, Python wants to use a PyInt (which is internally a
    long) if it can i.e. if the value will fit into that type.  If
    not, it stores it into a PyLong, which isn't actually a long,
    but an arbitrary-precision integer variable.
    
    The code below is similar to to what Python does internally, and
    it seems to work as expected on the x86 and x86_64 sytems I
    tested it on.
    Signed-off-by: default avatarTom Zanussi <tzanussi@gmail.com>
    Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
    Cc: Roel Kluin <roel.kluin@gmail.com>
    Cc: Frederic Weisbecker <fweisbec@gmail.com>
    Cc: rostedt@goodmis.org
    LKML-Reference: <1270184305.6422.10.camel@tropicana>
    Signed-off-by: default avatarIngo Molnar <mingo@elte.hu>
    b1dcc03c
trace-event-python.c 14.2 KB