summaryrefslogtreecommitdiffstats
path: root/pcilib
diff options
context:
space:
mode:
authorVasilii Chernov <vchernov@inr.ru>2016-02-12 14:43:20 +0100
committerVasilii Chernov <vchernov@inr.ru>2016-02-12 14:43:20 +0100
commit55eab7196d0104c71e40136b3b22e9501d234e17 (patch)
treeb0fbfd40812e39cde3e5ef7a5ebddfc384102c24 /pcilib
parentd7fc669bf0dbe37f46d2efec4940feb8504017c2 (diff)
downloadpcitool-55eab7196d0104c71e40136b3b22e9501d234e17.tar.gz
pcitool-55eab7196d0104c71e40136b3b22e9501d234e17.tar.bz2
pcitool-55eab7196d0104c71e40136b3b22e9501d234e17.tar.xz
pcitool-55eab7196d0104c71e40136b3b22e9501d234e17.zip
1. Cmakelists - move copy xml folder command to root file
2. - Move set python paths code to python module init funtction - pci.c move python module init block code after checking model to get paths before it runs. - Fix set python path code to work with PYTHONPATH - Update pci run script to work with PYTHONPATH - Fix python finalize code 3. Change pcilib_script_s interacting method. Now it stores in hash. 4. Change names of some fucntions to more unified ones 5. Remove old unused function pcilib_xml_create_script_or_transform_view 6. cli - disable reading register after set if write_verification flag is off 7. Remove uninformative error messages fro Python wrap. 8. - Server.py - add read/write property/register command handling - Add help message - Correcting paths
Diffstat (limited to 'pcilib')
-rw-r--r--pcilib/pci.c14
-rw-r--r--pcilib/py.c194
-rw-r--r--pcilib/py.h13
-rw-r--r--pcilib/xml.c53
4 files changed, 134 insertions, 140 deletions
diff --git a/pcilib/pci.c b/pcilib/pci.c
index eaf41ac..cc2a67a 100644
--- a/pcilib/pci.c
+++ b/pcilib/pci.c
@@ -144,13 +144,6 @@ pcilib_t *pcilib_open(const char *device, const char *model) {
pcilib_close(ctx);
return NULL;
}
-
- err = pcilib_init_py(ctx);
- if (err) {
- pcilib_error("Error (%i) initializing python subsystem", err);
- pcilib_close(ctx);
- return NULL;
- }
ctx->alloc_reg = PCILIB_DEFAULT_REGISTER_SPACE;
ctx->alloc_views = PCILIB_DEFAULT_VIEW_SPACE;
@@ -191,6 +184,13 @@ pcilib_t *pcilib_open(const char *device, const char *model) {
if (!ctx->model)
ctx->model = strdup(model?model:"pci");
+
+ err = pcilib_init_py(ctx);
+ if (err) {
+ pcilib_error("Error (%i) initializing python subsystem", err);
+ pcilib_close(ctx);
+ return NULL;
+ }
xmlerr = pcilib_init_xml(ctx, ctx->model);
if ((xmlerr)&&(xmlerr != PCILIB_ERROR_NOTFOUND)) {
diff --git a/pcilib/py.c b/pcilib/py.c
index 664e170..7b1ae79 100644
--- a/pcilib/py.c
+++ b/pcilib/py.c
@@ -11,24 +11,37 @@
#include "py.h"
#include "error.h"
+
+
struct pcilib_py_s {
PyObject *main_module;
PyObject *global_dict;
+ int py_initialized_inside; ///< Flag, shows that Py_Initialize has been called inside class
};
-struct pcilib_script_s {
+typedef struct pcilib_script_s {
+ char* script_name;
PyObject *py_script_module; /**< PyModule object, contains script enviroment */
PyObject *dict;
- char* script_name;
-};
+ pcilib_access_mode_t mode;
+
+ UT_hash_handle hh;
+} pcilib_script_s;
+
+struct pcilib_script_s *scripts = NULL;
int pcilib_init_py(pcilib_t *ctx) {
ctx->py = (pcilib_py_t*)malloc(sizeof(pcilib_py_t));
if (!ctx->py) return PCILIB_ERROR_MEMORY;
if(!Py_IsInitialized())
+ {
Py_Initialize();
-
+ ctx->py->py_initialized_inside = 1;
+ }
+ else
+ ctx->py->py_initialized_inside = 0;
+
ctx->py->main_module = PyImport_AddModule("__parser__");
if (!ctx->py->main_module)
return PCILIB_ERROR_FAILED;
@@ -36,17 +49,45 @@ int pcilib_init_py(pcilib_t *ctx) {
ctx->py->global_dict = PyModule_GetDict(ctx->py->main_module);
if (!ctx->py->global_dict)
return PCILIB_ERROR_FAILED;
-
+
+
+ //create path string, where the model scripts should be
+ static int model_dir_added = 0;
+ if(!model_dir_added)
+ {
+ char* model_dir = getenv("PCILIB_MODEL_DIR");
+ char* model_path = malloc(strlen(model_dir) + strlen(ctx->model) + 2);
+ if (!model_path) return PCILIB_ERROR_MEMORY;
+ sprintf(model_path, "%s/%s", model_dir, ctx->model);
+ //add path to python
+ PyObject* path = PySys_GetObject("path");
+ if(PyList_Append(path, PyString_FromString(model_path)) == -1)
+ {
+ pcilib_error("Cant set PCILIB_MODEL_DIR library path to python.");
+ free(model_path);
+ return PCILIB_ERROR_FAILED;
+ }
+ free(model_path);
+ model_dir_added = 1;
+ }
return 0;
}
void pcilib_free_py(pcilib_t *ctx) {
- if (ctx->py) {
+
+ int py_initialized_inside = 0;
+
+ if (ctx->py) {
+ if(ctx->py->py_initialized_inside)
+ py_initialized_inside = 1;
+
// Dict and module references are borrowed
free(ctx->py);
ctx->py = NULL;
}
- //Py_Finalize();
+
+ if(py_initialized_inside)
+ Py_Finalize();
}
/*
@@ -196,7 +237,7 @@ int pcilib_py_eval_string(pcilib_t *ctx, const char *codestr, pcilib_value_t *va
return pcilib_set_value_from_float(ctx, value, PyFloat_AsDouble(obj));
}
-void* pcilib_convert_val_to_pyobject(pcilib_t* ctx, pcilib_value_t *val)
+void* pcilib_get_value_as_pyobject(pcilib_t* ctx, pcilib_value_t *val)
{
int err;
@@ -242,7 +283,7 @@ void* pcilib_convert_val_to_pyobject(pcilib_t* ctx, pcilib_value_t *val)
}
}
-int pcilib_convert_pyobject_to_val(pcilib_t* ctx, void* pyObjVal, pcilib_value_t *val)
+int pcilib_set_value_from_pyobject(pcilib_t* ctx, void* pyObjVal, pcilib_value_t *val)
{
PyObject* pyVal = pyObjVal;
int err;
@@ -268,61 +309,30 @@ int pcilib_convert_pyobject_to_val(pcilib_t* ctx, void* pyObjVal, pcilib_value_t
return 0;
}
-int pcilib_init_py_script(pcilib_t *ctx, char* module_name, pcilib_script_t **module, pcilib_access_mode_t *mode)
+int pcilib_py_init_script(pcilib_t *ctx, char* module_name, pcilib_access_mode_t *mode)
{
- //Initialize python script, if it has not initialized already.
- if(!module_name)
+ //extract module name from script name
+ char* py_module_name = strtok(module_name, ".");
+ if(!py_module_name)
{
- pcilib_error("Invalid script name specified in XML property (NULL)");
+ pcilib_error("Invalid script name specified in XML property (%s)."
+ " Seems like name doesnt contains extension", module_name);
return PCILIB_ERROR_INVALID_DATA;
}
- //create path string to scripts
- char* model_dir = getenv("PCILIB_MODEL_DIR");
- char* model_path = malloc(strlen(model_dir) + strlen(ctx->model) + 2);
- if (!model_path) return PCILIB_ERROR_MEMORY;
- sprintf(model_path, "%s/%s", model_dir, ctx->model);
-
- //set model path to python
- PySys_SetPath(model_path);
- free(model_path);
- model_path = NULL;
-
- //create path string to pcipywrap library
- char* app_dir = getenv("APP_PATH");
- char* pcipywrap_path;
- if(app_dir)
- {
- pcipywrap_path = malloc(strlen(app_dir) + strlen("/pywrap"));
- if (!pcipywrap_path) return PCILIB_ERROR_MEMORY;
- sprintf(pcipywrap_path, "%s/%s", "/pywrap", ctx->model);
- }
- else
- {
- pcipywrap_path = malloc(strlen("./pywrap"));
- if (!pcipywrap_path) return PCILIB_ERROR_MEMORY;
- sprintf(pcipywrap_path, "%s", "./pywrap");
-
- }
-
- //set pcipywrap library path to python
- PyObject* path = PySys_GetObject("path");
- if(PyList_Append(path, PyString_FromString(pcipywrap_path)) == -1)
+ pcilib_script_s* module = NULL;
+ HASH_FIND_STR( scripts, module_name, module);
+ if(module)
{
- pcilib_error("Cant set pcipywrap library path to python.");
- return PCILIB_ERROR_FAILED;
+ pcilib_warning("Python module %s is already in hash. Skip init step", module_name);
+ mode[0] = module->mode;
+ return 0;
}
- free(pcipywrap_path);
- pcipywrap_path = NULL;
-
-
- //extract module name from script name
- char* py_module_name = strtok(module_name, ".");
- if(!py_module_name)
+ //Initialize python module
+ if(!module_name)
{
- pcilib_error("Invalid script name specified in XML property (%s)."
- " Seems like name doesnt contains extension", module_name);
+ pcilib_error("Invalid script name specified in XML property (NULL)");
return PCILIB_ERROR_INVALID_DATA;
}
@@ -336,7 +346,6 @@ int pcilib_init_py_script(pcilib_t *ctx, char* module_name, pcilib_script_t **mo
return PCILIB_ERROR_INVALID_DATA;
}
-
//Initializing pcipywrap module if script use it
PyObject* dict = PyModule_GetDict(py_script_module);
if(PyDict_Contains(dict, PyString_FromString("pcipywrap")))
@@ -350,16 +359,18 @@ int pcilib_init_py_script(pcilib_t *ctx, char* module_name, pcilib_script_t **mo
//setting pcilib_t instance
PyObject_CallMethodObjArgs(pcipywrap_module,
- PyUnicode_FromString("setPcilib"),
+ PyUnicode_FromString("set_pcilib"),
PyByteArray_FromStringAndSize((const char*)&ctx, sizeof(pcilib_t*)),
NULL);
}
//Success. Create struct and initialize values
- module[0] = (pcilib_script_t*)malloc(sizeof(pcilib_script_t));
- module[0]->py_script_module = py_script_module;
- module[0]->script_name = module_name;
- module[0]->dict = dict;
+ module = malloc(sizeof(pcilib_script_s));
+ module->py_script_module = py_script_module;
+ module->script_name = malloc(strlen(module_name));
+ sprintf(module->script_name, "%s", module_name);
+ module->dict = dict;
+
//Setting correct mode
mode[0] = 0;
@@ -367,32 +378,52 @@ int pcilib_init_py_script(pcilib_t *ctx, char* module_name, pcilib_script_t **mo
mode[0] |= PCILIB_ACCESS_R;
if(PyDict_Contains(dict, PyString_FromString("write_to_register")))
mode[0] |= PCILIB_ACCESS_W;
+
+ module->mode = mode[0];
+ HASH_ADD_STR( scripts, script_name, module);
return 0;
}
-int pcilib_free_py_script(pcilib_script_t *module)
+int pcilib_py_free_script(char* module_name)
{
- if(module)
+ pcilib_script_s *module;
+ HASH_FIND_STR(scripts, module_name, module);
+
+ if(!module)
{
- if(module->script_name)
- {
- free(module->script_name);
- module->script_name = NULL;
- }
+ //For some reason it will crash if uncomment. printf same warning is ok
+ //pcilib_warning("Cant find Python module %s in hash. Seems it has already deleted.", module_name);
+ return 0;
+ }
+
+ if(module->script_name)
+ {
+ free(module->script_name);
+ module->script_name = NULL;
+ }
- if(module->py_script_module)
- {
- //PyObject_Free(module->py_script_module);
- module->py_script_module = NULL;
- }
+ if(module->py_script_module)
+ {
+ //PyObject_Free(module->py_script_module);
+ module->py_script_module = NULL;
}
+ HASH_DEL(scripts, module);
+ free(module);
return 0;
}
-int pcilib_script_read(pcilib_t *ctx, pcilib_script_t *module, pcilib_value_t *val)
+int pcilib_script_read(pcilib_t *ctx, char* module_name, pcilib_value_t *val)
{
+ pcilib_script_s *module;
+ HASH_FIND_STR(scripts, module_name, module);
+
+ if(!module)
+ {
+ pcilib_error("Failed to find script module (%s) in hash", module_name);
+ return PCILIB_ERROR_NOTFOUND;
+ }
int err;
@@ -404,7 +435,7 @@ int pcilib_script_read(pcilib_t *ctx, pcilib_script_t *module, pcilib_value_t *v
return PCILIB_ERROR_FAILED;
}
- err = pcilib_convert_pyobject_to_val(ctx, ret, val);
+ err = pcilib_set_value_from_pyobject(ctx, ret, val);
if(err)
{
@@ -414,9 +445,18 @@ int pcilib_script_read(pcilib_t *ctx, pcilib_script_t *module, pcilib_value_t *v
return 0;
}
-int pcilib_script_write(pcilib_t *ctx, pcilib_script_t *module, pcilib_value_t *val)
+int pcilib_script_write(pcilib_t *ctx, char* module_name, pcilib_value_t *val)
{
- PyObject *input = pcilib_convert_val_to_pyobject(ctx, val);
+ pcilib_script_s *module;
+ HASH_FIND_STR(scripts, module_name, module);
+
+ if(!module)
+ {
+ pcilib_error("Failed to find script module (%s) in hash", module_name);
+ return PCILIB_ERROR_NOTFOUND;
+ }
+
+ PyObject *input = pcilib_get_value_as_pyobject(ctx, val);
if(!input)
{
printf("Failed to convert input value to Python object");
diff --git a/pcilib/py.h b/pcilib/py.h
index d0f1328..09e2b87 100644
--- a/pcilib/py.h
+++ b/pcilib/py.h
@@ -4,7 +4,6 @@
#include "pcilib.h"
typedef struct pcilib_py_s pcilib_py_t;
-typedef struct pcilib_script_s pcilib_script_t;
#ifdef __cplusplus
extern "C" {
@@ -15,10 +14,10 @@ int pcilib_py_eval_string(pcilib_t *ctx, const char *codestr, pcilib_value_t *va
void pcilib_free_py(pcilib_t *ctx);
-int pcilib_init_py_script(pcilib_t *ctx, char* module_name, pcilib_script_t **module, pcilib_access_mode_t *mode);
-int pcilib_free_py_script(pcilib_script_t *module);
-int pcilib_script_read(pcilib_t *ctx, pcilib_script_t *module, pcilib_value_t *val);
-int pcilib_script_write(pcilib_t *ctx, pcilib_script_t *module, pcilib_value_t *val);
+int pcilib_py_init_script(pcilib_t *ctx, char* module_name, pcilib_access_mode_t *mode);
+int pcilib_py_free_script(char* module_name);
+int pcilib_script_read(pcilib_t *ctx, char* module_name, pcilib_value_t *val);
+int pcilib_script_write(pcilib_t *ctx, char* module_name, pcilib_value_t *val);
/*!
@@ -27,7 +26,7 @@ int pcilib_script_write(pcilib_t *ctx, pcilib_script_t *module, pcilib_value_t *
* \param val pointer to pcilib_value_t to convert
* \return PyObject, containing value. NULL with error message, sended to errstream.
*/
-void* pcilib_convert_val_to_pyobject(pcilib_t* ctx, pcilib_value_t *val);
+void* pcilib_get_value_as_pyobject(pcilib_t* ctx, pcilib_value_t *val);
/*!
@@ -37,7 +36,7 @@ void* pcilib_convert_val_to_pyobject(pcilib_t* ctx, pcilib_value_t *val);
* \param val initialized polymorphic value
* \return 0 on success or memory error
*/
-int pcilib_convert_pyobject_to_val(pcilib_t* ctx, void* pyVal, pcilib_value_t *val);
+int pcilib_set_value_from_pyobject(pcilib_t* ctx, void* pyVal, pcilib_value_t *val);
#ifdef __cplusplus
diff --git a/pcilib/xml.c b/pcilib/xml.c
index ca07ad3..f118491 100644
--- a/pcilib/xml.c
+++ b/pcilib/xml.c
@@ -569,7 +569,6 @@ static int pcilib_xml_create_transform_view(pcilib_t *ctx, xmlXPathContextPtr xp
desc.base.api = &pcilib_transform_view_api;
desc.base.type = PCILIB_TYPE_DOUBLE;
desc.base.mode = PCILIB_ACCESS_RW;
- desc.script = NULL;
err = pcilib_xml_parse_view(ctx, xpath, doc, node, (pcilib_view_description_t*)&desc);
if (err) return err;
@@ -601,10 +600,10 @@ static int pcilib_xml_create_transform_view(pcilib_t *ctx, xmlXPathContextPtr xp
desc.write_to_reg = value;
if ((value)&&(*value)) mode |= PCILIB_ACCESS_W;
} else if (!strcasecmp(name, "script")) {
- char* script_name = malloc(strlen(value));
- sprintf(script_name, "%s", value);
+ desc.module = malloc(strlen(value));
+ sprintf(desc.module, "%s", value);
- err = pcilib_init_py_script(ctx, script_name, &(desc.script), &mode);
+ err = pcilib_py_init_script(ctx, desc.module, &mode);
if(err) return err;
mode |= PCILIB_REGISTER_INCONSISTENT;
break;
@@ -620,50 +619,6 @@ static int pcilib_xml_create_transform_view(pcilib_t *ctx, xmlXPathContextPtr xp
return 0;
}
-static int pcilib_xml_create_script_or_transform_view(pcilib_t *ctx, xmlXPathContextPtr xpath, xmlDocPtr doc, xmlNodePtr node) {
- /*
- int err;
- xmlAttrPtr cur;
- const char *name;
-
- int has_read_from_register = 0;
- int has_write_to_register = 0;
- int has_script = 0;
-
- //getting transform name in case of error
- pcilib_view_description_t desc = {0};
- err = pcilib_xml_parse_view(ctx, xpath, doc, node, &desc);
-
- for (cur = node->properties; cur != NULL; cur = cur->next) {
- if (!cur->children) continue;
- if (!xmlNodeIsText(cur->children)) continue;
-
- name = (char*)cur->name;
-
- if (!strcasecmp(name, "read_from_register"))
- has_read_from_register = 1;
- if (!strcasecmp(name, "write_to_register"))
- has_write_to_register = 1;
- if (!strcasecmp(name, "script"))
- has_script = 1;
- }
-
- if (has_script && (has_read_from_register || has_write_to_register)) {
- pcilib_error("Invalid transform group attributes specified in XML property (%s)."
- "Transform could not contains both script and read_from_register"
- " or write_to_register attributes at same time.", desc.name);
- return PCILIB_ERROR_INVALID_DATA;
- }
-
- if(has_script)
-
- return pcilib_xml_create_script_view(ctx, xpath, doc, node);
- else
- */
- return pcilib_xml_create_transform_view(ctx, xpath, doc, node);
-}
-
-
static int pcilib_xml_parse_value_name(pcilib_t *ctx, xmlXPathContextPtr xpath, xmlDocPtr doc, xmlNodePtr node, pcilib_register_value_name_t *desc) {
xmlAttr *cur;
char *value, *name;
@@ -921,7 +876,7 @@ static int pcilib_xml_process_document(pcilib_t *ctx, xmlDocPtr doc, xmlXPathCon
nodeset = transform_nodes->nodesetval;
if (!xmlXPathNodeSetIsEmpty(nodeset)) {
for(i=0; i < nodeset->nodeNr; i++) {
- err = pcilib_xml_create_script_or_transform_view(ctx, xpath, doc, nodeset->nodeTab[i]);
+ err = pcilib_xml_create_transform_view(ctx, xpath, doc, nodeset->nodeTab[i]);
if (err) pcilib_error("Error (%i) creating register transform", err);
}
}