summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--pcilib/py.h48
-rw-r--r--pywrap/pcipywrap.h64
2 files changed, 103 insertions, 9 deletions
diff --git a/pcilib/py.h b/pcilib/py.h
index 549eddf..62ce7db 100644
--- a/pcilib/py.h
+++ b/pcilib/py.h
@@ -125,23 +125,55 @@ int pcilib_py_eval_func(pcilib_t *ctx, const char *script, const char *func, pci
* @return - NULL or cloned pcilib_py_t content pointer on success
*/
pcilib_py_t* pcilib_init_py_ctx(pcilib_py_t* in, int *err);
+
+/**
+ * @brief pcilib_t independent variant pcilib_free_py
+ * @param ctx_py[in,out] - pcilib_py_t context
+ */
+void pcilib_free_py_ctx(pcilib_py_t *ctx_py);
+
+/** pcilib_t independent variant of pcilib_py_eval_func()
+ * @param ctx_py[in,out] - pcilib_py_t context
+ * @param name[in] - script name
+ * @param name[in] - function name
+ * @param pyval[in] - input value (will be decref in this fucntion)
+ * @param err[out] - error
+ * @return value returned by python function
+ */
pcilib_py_object* pcilib_py_ctx_eval_func(pcilib_py_t *ctx_py,
- const char *script_name,
+ const char *name,
const char *func_name,
pcilib_py_object *pyval,
int *err);
-int pcilib_py_ctx_add_script_dir(pcilib_py_t *ctx_py, const char *dir);
-void pcilib_free_py_ctx(pcilib_py_t *ctx_py);
-int pcilib_py_ctx_load_script(pcilib_py_t *ctx_py, const char *script_name);
+
+/**
+ * @brief pcilib_t independent variant of pcilib_py_add_script_dir
+ * @param ctx_py[in,out] - pcilib_py_t context
+ * @param[in] location - NULL or path to additional scripts
+ * @return
+ */
+int pcilib_py_ctx_add_script_dir(pcilib_py_t *ctx_py, const char *location);
+
+/**
+ * @brief pcilib_t independent variant of pcilib_py_load_script
+ * @param ctx_py[in,out] - pcilib_py_t context
+ * @param[in] name - script name, the passed variable is referenced and, hence, should have static duration
+ * @return
+ */
+int pcilib_py_ctx_load_script(pcilib_py_t *ctx_py, const char *name);
+
+/**
+ * @brief Returns information about scripts aviable in model
+ * @param ctx_py[in,out] - pcilib_py_t context
+ * @return List with information about scripts
+ */
pcilib_py_object *pcilib_py_ctx_get_scripts_info(pcilib_py_t *ctx_py);
-/*!
- * \brief Wrap for PyDict_SetItem, with decrease reference counting after set.
+/** Wrap for PyDict_SetItem, with decrease reference counting after set.
*/
void pcilib_pydict_set_item(pcilib_py_object* dict, pcilib_py_object* name, pcilib_py_object* value);
-/*!
- * \brief Wrap for PyList_Append, with decrease reference counting after append.
+/** Wrap for PyList_Append, with decrease reference counting after append.
*/
void pcilib_pylist_append(pcilib_py_object* list, pcilib_py_object* value);
#ifdef __cplusplus
diff --git a/pywrap/pcipywrap.h b/pywrap/pcipywrap.h
index cfb5651..fa7e4f4 100644
--- a/pywrap/pcipywrap.h
+++ b/pywrap/pcipywrap.h
@@ -73,18 +73,55 @@ PyObject* Pcipywrap_get_property(Pcipywrap *self, const char *prop);
* \return 1, serialized to PyObject or NULL with exeption text, if failed.
*/
PyObject* Pcipywrap_set_property(Pcipywrap *self, PyObject* val, const char *prop);
+
+
+/*!
+ * \brief Wrap for pcilib_get_register_list function.
+ * \param bank [in] bank - if set, only register within the specified bank will be returned
+ * \return list of registers, serialized to Python object
+ */
PyObject* Pcipywrap_get_registers_list(Pcipywrap *self, const char *bank);
+
+/*!
+ * \brief Returns the information about the specified register. Wrap for pcilib_get_register_info
+ * \param[in] reg the name of the register
+ * \param[in] bank indicates the bank where to look for register, autodetected if NULL is passed
+ * \return information about the specified register, serialized to Python object
+ */
PyObject* Pcipywrap_get_register_info(Pcipywrap *self, const char* reg,const char *bank);
+
+/*!
+ * \brief Returns the list of properties available under the specified path. Wrap for pcilib_get_property_list
+ * \param[in] branch path or NULL to return the top-level properties
+ * \return the list of the properties, serialized to Python object
+ */
PyObject* Pcipywrap_get_property_list(Pcipywrap *self, const char* branch);
+/*!
+ * \brief Reads data from DMA until timeout is hit, a full DMA packet is read, or the specified number of bytes are read.
+ * Wrap for pcilib_read_dma.
+ * \param dma ID of DMA engine
+ * \param size specifies how many bytes should be read
+ * \return DMA data, serialierd to Python bytearray
+ * \warning This function has not been tested.
+ * \todo Test this fucntion
+ */
PyObject* Pcipywrap_read_dma(Pcipywrap *self, unsigned char dma, size_t size);
+/*!
+ * \brief Wrap for pcilib_lock_global
+ * \return 1, serialized to PyObject or NULL with exeption text, if failed.
+ */
PyObject* Pcipywrap_lock_global(Pcipywrap *self);
+
+/*!
+ * \brief Wrap for pcilib_unlock_global
+ */
void Pcipywrap_unlock_global(Pcipywrap *self);
/*!
* \brief Wrap for pcilib_lock
- * \param lock_id lock identificator
+ * \param[in] lock_id lock identificator
* \warning This function should be called only under Python standart threading lock.
* Otherwise it will stuck with more than 1 threads. See /xml/test/test_prop_mt.py
* for example.
@@ -92,10 +129,35 @@ void Pcipywrap_unlock_global(Pcipywrap *self);
*/
PyObject* Pcipywrap_lock(Pcipywrap *self, const char *lock_id);
+/*!
+ * \brief This function will try to take a lock for the mutex pointed by
+ * lockfunction to acquire a lock, but that returns immediatly if the lock can't be
+ * acquired on first try. Wrap for pcilib_try_lock.
+ * \param[in] lock_id lock id
+ * \return 1, serialized to PyObject or NULL with exeption text, if failed.
+ */
PyObject* Pcipywrap_try_lock(Pcipywrap *self, const char *lock_id);
+
+/*!
+ * \brief This function unlocks the lock with specified id. Wrap for pcilib_unlock.
+ * \param[in] lock_id lock id
+ * \return 1, serialized to PyObject or NULL with exeption text, if failed.
+ */
PyObject* Pcipywrap_unlock(Pcipywrap *self, const char *lock_id);
+/*!
+ * \brief Returns list with information about aviable scripts
+ * \return list with information about scripts, aviable in model
+ */
PyObject* Pcipywrap_get_scripts_list(Pcipywrap *self);
+
+/*!
+ * \brief Runs script with specified name
+ * \param script_name script name (with extension); name could be found by
+ * Pcipywrap_get_scripts_list fucntion
+ * \param[in] value input value
+ * \return value returned by script
+ */
PyObject* Pcipywrap_run_script(Pcipywrap *self, const char* script_name, PyObject* value);
#endif /* PCIPYWRAP_H */