Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

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

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.de


Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 3be8e2a0
Loading
Loading
Loading
Loading
+10 −2
Original line number Diff line number Diff line
@@ -50,10 +50,14 @@ static int zero_flag_atom;

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)
{
	PyErr_Print();
	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);
		if (retval == NULL)
			handler_call_die(handler_name);
		Py_DECREF(retval);
	}

	Py_DECREF(t);
@@ -143,6 +148,7 @@ static void define_field(enum print_arg_type field_type,
		retval = PyObject_CallObject(handler, t);
		if (retval == NULL)
			handler_call_die(handler_name);
		Py_DECREF(retval);
	}

	Py_DECREF(t);
@@ -361,6 +367,7 @@ static void python_process_tracepoint(struct perf_sample *sample,
		retval = PyObject_CallObject(handler, t);
		if (retval == NULL)
			handler_call_die(handler_name);
		Py_DECREF(retval);
	} else {
		handler = PyDict_GetItemString(main_dict, "trace_unhandled");
		if (handler && PyCallable_Check(handler)) {
@@ -368,6 +375,7 @@ static void python_process_tracepoint(struct perf_sample *sample,
			retval = PyObject_CallObject(handler, t);
			if (retval == NULL)
				handler_call_die("trace_unhandled");
			Py_DECREF(retval);
		}
		Py_DECREF(dict);
	}
@@ -427,6 +435,7 @@ static void python_process_general_event(struct perf_sample *sample,
	retval = PyObject_CallObject(handler, t);
	if (retval == NULL)
		handler_call_die(handler_name);
	Py_DECREF(retval);
exit:
	Py_DECREF(dict);
	Py_DECREF(t);
@@ -548,7 +557,6 @@ static int python_stop_script(void)
	retval = PyObject_CallObject(handler, NULL);
	if (retval == NULL)
		handler_call_die("trace_end");
	else
	Py_DECREF(retval);
out:
	Py_XDECREF(main_dict);