From b96f22da8b0b21b24c20027bca26880d99046da7 Mon Sep 17 00:00:00 2001
From: "alexey.stratulat" <alexey.stratulat@demlabs.net>
Date: Fri, 4 Feb 2022 11:58:17 +0000
Subject: [PATCH] Fix python function call when processing cli command created
 from Python.

---
 modules/cellframe-sdk/net/src/wrapping_dap_app_cli_server.c | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/modules/cellframe-sdk/net/src/wrapping_dap_app_cli_server.c b/modules/cellframe-sdk/net/src/wrapping_dap_app_cli_server.c
index b98191cd..d8ebafb6 100644
--- a/modules/cellframe-sdk/net/src/wrapping_dap_app_cli_server.c
+++ b/modules/cellframe-sdk/net/src/wrapping_dap_app_cli_server.c
@@ -100,6 +100,7 @@ void element_py_func_del_all(){
 }
 
 static int wrapping_cmdfunc(int argc, char **argv, char **str_reply){
+    PyGILState_STATE state = PyGILState_Ensure();
     size_t id_str_replay = elements_str_reply_add(str_reply);
     PyObject *obj_argv = stringToPyList(argc, argv);
     PyObject *obj_id_str_replay = PyLong_FromSize_t(id_str_replay);
@@ -114,6 +115,7 @@ static int wrapping_cmdfunc(int argc, char **argv, char **str_reply){
     Py_XDECREF(arglist);
     Py_XDECREF(obj_argv);
     elements_str_reply_delete(id_str_replay);
+    PyGILState_Release(state);
     return 0;
 }
 
-- 
GitLab