From 10b5e5431d004fe51df30140f20346b2c91248fb Mon Sep 17 00:00:00 2001 From: Curtis Dunham Date: Tue, 23 Dec 2014 11:51:40 -0600 Subject: [PATCH] sim: fix reference counting of PythonEvent When gem5 is a slave to another simulator and the Python is only used to initialize the configuration (and not perform actual simulation), a "debug start" (--debug-start) event will get freed during or immediately after the initial Python frame's execution rather than remaining in the event queue. This tricky patch fixes the GC issue causing this. --- src/python/swig/event.i | 4 ++++ src/python/swig/pyevent.cc | 8 ++++---- src/python/swig/pyevent.hh | 5 +++-- 3 files changed, 11 insertions(+), 6 deletions(-) diff --git a/src/python/swig/event.i b/src/python/swig/event.i index 23bb31364..cc72794ed 100644 --- a/src/python/swig/event.i +++ b/src/python/swig/event.i @@ -71,6 +71,10 @@ } } +%typemap(out) PythonEvent* { + result->object = $result = SWIG_NewPointerObj(SWIG_as_voidptr(result), SWIGTYPE_p_PythonEvent, SWIG_POINTER_NEW); +} + %ignore EventQueue::schedule; %ignore EventQueue::deschedule; diff --git a/src/python/swig/pyevent.cc b/src/python/swig/pyevent.cc index 6d80a00cd..d83d57cbf 100644 --- a/src/python/swig/pyevent.cc +++ b/src/python/swig/pyevent.cc @@ -34,10 +34,10 @@ #include "sim/async.hh" #include "sim/eventq.hh" -PythonEvent::PythonEvent(PyObject *obj, Priority priority) - : Event(priority), object(obj) +PythonEvent::PythonEvent(PyObject *code, Priority priority) + : Event(priority), eventCode(code) { - if (object == NULL) + if (code == NULL) panic("Passed in invalid object"); } @@ -49,7 +49,7 @@ void PythonEvent::process() { PyObject *args = PyTuple_New(0); - PyObject *result = PyObject_Call(object, args, NULL); + PyObject *result = PyObject_Call(eventCode, args, NULL); Py_DECREF(args); if (result) { diff --git a/src/python/swig/pyevent.hh b/src/python/swig/pyevent.hh index f34fbd996..f668c1d9a 100644 --- a/src/python/swig/pyevent.hh +++ b/src/python/swig/pyevent.hh @@ -37,9 +37,10 @@ class PythonEvent : public Event { private: - PyObject *object; - + PyObject *eventCode; // PyObject to call to perform event public: + PyObject *object; // PyObject wrapping this PythonEvent + PythonEvent(PyObject *obj, Event::Priority priority); ~PythonEvent(); -- 2.30.2