Commit 05f832e3 authored by Joseph Schuchart's avatar Joseph Schuchart Committed by Arnaldo Carvalho de Melo

perf script: Add missing calls to Py_DECREF for return values

Signed-off-by: default avatarJoseph 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.deSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 3be8e2a0
...@@ -50,10 +50,14 @@ static int zero_flag_atom; ...@@ -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, ...@@ -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, ...@@ -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, ...@@ -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, ...@@ -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, ...@@ -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) ...@@ -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);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment