summaryrefslogtreecommitdiff
path: root/plugins/pychrysalide/arch
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/pychrysalide/arch')
-rw-r--r--plugins/pychrysalide/arch/processor.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/plugins/pychrysalide/arch/processor.c b/plugins/pychrysalide/arch/processor.c
index b59e59b..78109ee 100644
--- a/plugins/pychrysalide/arch/processor.c
+++ b/plugins/pychrysalide/arch/processor.c
@@ -321,12 +321,15 @@ static int py_arch_processor_init(PyObject *self, PyObject *args, PyObject *kwds
static GProcContext *py_arch_processor_get_context_wrapper(const GArchProcessor *proc)
{
GProcContext *result; /* Instance à retourner */
+ PyGILState_STATE gstate; /* Sauvegarde d'environnement */
PyObject *pyobj; /* Objet Python concerné */
PyObject *pyctx; /* Contexte en objet Python */
int ret; /* Bilan d'une conversion */
GArchProcessorClass *class; /* Classe de l'objet courant */
GArchProcessorClass *parent; /* Classe parente */
+ gstate = PyGILState_Ensure();
+
pyobj = pygobject_new(G_OBJECT(proc));
if (has_python_method(pyobj, "_get_context"))
@@ -363,6 +366,8 @@ static GProcContext *py_arch_processor_get_context_wrapper(const GArchProcessor
}
+ PyGILState_Release(gstate);
+
return result;
}
@@ -387,12 +392,15 @@ static GProcContext *py_arch_processor_get_context_wrapper(const GArchProcessor
static GArchInstruction *py_arch_processor_disassemble_wrapper(const GArchProcessor *proc, GProcContext *ctx, const GBinContent *content, vmpa2t *pos, GExeFormat *format)
{
GArchInstruction *result; /* Instance à retourner */
+ PyGILState_STATE gstate; /* Sauvegarde d'environnement */
PyObject *pyobj; /* Objet Python concerné */
PyObject *pypos; /* Position en objet Python */
PyObject *args; /* Arguments pour l'appel */
PyObject *pyins; /* Instruction en objet Python */
int ret; /* Bilan d'une conversion */
+ gstate = PyGILState_Ensure();
+
pyobj = pygobject_new(G_OBJECT(proc));
if (has_python_method(pyobj, "_disassemble"))
@@ -438,6 +446,8 @@ static GArchInstruction *py_arch_processor_disassemble_wrapper(const GArchProces
else
result = NULL;
+ PyGILState_Release(gstate);
+
return result;
}