perf script: Add missing calls to Py_DECREF for return values
Signed-off-by: Joseph Schuchart <joseph.schuchart@tu-dresden.de> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Namhyung Kim <namhyung@gmail.com> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Thomas Ilsche <thomas.ilsche@tu-dresden.de> Link: http://lkml.kernel.org/r/53BD4EBF.5050407@tu-dresden.de Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
committed by
Arnaldo Carvalho de Melo
parent
3be8e2a0a5
commit
05f832e3a2
@@ -50,10 +50,14 @@ static int zero_flag_atom;
|
|||||||
|
|
||||||
static PyObject *main_module, *main_dict;
|
static PyObject *main_module, *main_dict;
|
||||||
|
|
||||||
|
static void handler_call_die(const char *handler_name) NORETURN;
|
||||||
static void handler_call_die(const char *handler_name)
|
static void handler_call_die(const char *handler_name)
|
||||||
{
|
{
|
||||||
PyErr_Print();
|
PyErr_Print();
|
||||||
Py_FatalError("problem in Python trace event handler");
|
Py_FatalError("problem in Python trace event handler");
|
||||||
|
// Py_FatalError does not return
|
||||||
|
// but we have to make the compiler happy
|
||||||
|
abort();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -97,6 +101,7 @@ static void define_value(enum print_arg_type field_type,
|
|||||||
retval = PyObject_CallObject(handler, t);
|
retval = PyObject_CallObject(handler, t);
|
||||||
if (retval == NULL)
|
if (retval == NULL)
|
||||||
handler_call_die(handler_name);
|
handler_call_die(handler_name);
|
||||||
|
Py_DECREF(retval);
|
||||||
}
|
}
|
||||||
|
|
||||||
Py_DECREF(t);
|
Py_DECREF(t);
|
||||||
@@ -143,6 +148,7 @@ static void define_field(enum print_arg_type field_type,
|
|||||||
retval = PyObject_CallObject(handler, t);
|
retval = PyObject_CallObject(handler, t);
|
||||||
if (retval == NULL)
|
if (retval == NULL)
|
||||||
handler_call_die(handler_name);
|
handler_call_die(handler_name);
|
||||||
|
Py_DECREF(retval);
|
||||||
}
|
}
|
||||||
|
|
||||||
Py_DECREF(t);
|
Py_DECREF(t);
|
||||||
@@ -361,6 +367,7 @@ static void python_process_tracepoint(struct perf_sample *sample,
|
|||||||
retval = PyObject_CallObject(handler, t);
|
retval = PyObject_CallObject(handler, t);
|
||||||
if (retval == NULL)
|
if (retval == NULL)
|
||||||
handler_call_die(handler_name);
|
handler_call_die(handler_name);
|
||||||
|
Py_DECREF(retval);
|
||||||
} else {
|
} else {
|
||||||
handler = PyDict_GetItemString(main_dict, "trace_unhandled");
|
handler = PyDict_GetItemString(main_dict, "trace_unhandled");
|
||||||
if (handler && PyCallable_Check(handler)) {
|
if (handler && PyCallable_Check(handler)) {
|
||||||
@@ -368,6 +375,7 @@ static void python_process_tracepoint(struct perf_sample *sample,
|
|||||||
retval = PyObject_CallObject(handler, t);
|
retval = PyObject_CallObject(handler, t);
|
||||||
if (retval == NULL)
|
if (retval == NULL)
|
||||||
handler_call_die("trace_unhandled");
|
handler_call_die("trace_unhandled");
|
||||||
|
Py_DECREF(retval);
|
||||||
}
|
}
|
||||||
Py_DECREF(dict);
|
Py_DECREF(dict);
|
||||||
}
|
}
|
||||||
@@ -427,6 +435,7 @@ static void python_process_general_event(struct perf_sample *sample,
|
|||||||
retval = PyObject_CallObject(handler, t);
|
retval = PyObject_CallObject(handler, t);
|
||||||
if (retval == NULL)
|
if (retval == NULL)
|
||||||
handler_call_die(handler_name);
|
handler_call_die(handler_name);
|
||||||
|
Py_DECREF(retval);
|
||||||
exit:
|
exit:
|
||||||
Py_DECREF(dict);
|
Py_DECREF(dict);
|
||||||
Py_DECREF(t);
|
Py_DECREF(t);
|
||||||
@@ -548,8 +557,7 @@ static int python_stop_script(void)
|
|||||||
retval = PyObject_CallObject(handler, NULL);
|
retval = PyObject_CallObject(handler, NULL);
|
||||||
if (retval == NULL)
|
if (retval == NULL)
|
||||||
handler_call_die("trace_end");
|
handler_call_die("trace_end");
|
||||||
else
|
Py_DECREF(retval);
|
||||||
Py_DECREF(retval);
|
|
||||||
out:
|
out:
|
||||||
Py_XDECREF(main_dict);
|
Py_XDECREF(main_dict);
|
||||||
Py_XDECREF(main_module);
|
Py_XDECREF(main_module);
|
||||||
|
|||||||
Reference in New Issue
Block a user