我试图在python脚本中使用C模块,所以当代码到达PyEval_Callobject时,调用程序崩溃/关闭。
C侧代码:
static PyObject *register_inactivity_callback(PyObject *self, PyObject *args)
{
PyObject *temp;
if (!PyTuple_Check(args) || PyTuple_Size(args) < 0)
{
fprintf(stderr, "invalid input parameter\n");
Py_RETURN_NONE;
}
temp = PyTuple_GetItem(args, 0);
if (!PyCallable_Check(temp))
{
fprintf(stderr, "parameter must be callable\n");
Py_RETURN_FALSE;
}
Py_XINCREF(temp);
Py_XDECREF(inactivity_callback);
inactivity_callback = temp;
Py_RETURN_TRUE;
}
void inactivity_callback_internal(void *arg)
{
PyObject *arglist;
struct input_event *event = (struct input_event *)arg;
if (inactivity_callback && event)
{
arglist = Py_BuildValue("()");
PyEval_CallObject(inactivity_callback, arglist);
Py_DECREF(arglist);
}
}
Python方面:
def on_inactivity():
print 'inactivity'
register_inactivity_callback(on_inactivity)
我已经在ubuntu桌面平台上测试了这段代码及其工作,但是当我转移到ARM时,程序开始在PyEval_CallingObject上崩溃/关闭。
我在代码中有什么可疑的吗? 提前谢谢。
答案 0 :(得分:2)
我找到了根本原因。 PyEval_CallObject函数需要由PyGILState_Ensure / Release函数包装。请参阅http://docs.python.org/2/c-api/init.html(非Python创建的线程)。
gstate = PyGILState_Ensure();
PyEval_CallObject(inactivity_callback, arglist);
PyGILState_Release(gstate);