summaryrefslogtreecommitdiffstats
path: root/protocols/software_registers.c
diff options
context:
space:
mode:
authorzilio nicolas <nicolas.zilio@kit.edu>2015-06-12 16:56:21 +0200
committerzilio nicolas <nicolas.zilio@kit.edu>2015-06-12 16:56:21 +0200
commit18e672c04c6b12d51b13f4cf32b9c197245407d6 (patch)
tree459be9e96d1eede956e02465d0180b65d99367ba /protocols/software_registers.c
parent860ca5277c37cc93d8e44e5b7a7757b930b83603 (diff)
downloadpcitool-18e672c04c6b12d51b13f4cf32b9c197245407d6.tar.gz
pcitool-18e672c04c6b12d51b13f4cf32b9c197245407d6.tar.bz2
pcitool-18e672c04c6b12d51b13f4cf32b9c197245407d6.tar.xz
pcitool-18e672c04c6b12d51b13f4cf32b9c197245407d6.zip
added soft_reg
Diffstat (limited to 'protocols/software_registers.c')
-rw-r--r--protocols/software_registers.c90
1 files changed, 90 insertions, 0 deletions
diff --git a/protocols/software_registers.c b/protocols/software_registers.c
new file mode 100644
index 0000000..d3c390f
--- /dev/null
+++ b/protocols/software_registers.c
@@ -0,0 +1,90 @@
+#include <string.h>
+#include <sys/file.h>
+#include <unistd.h>
+
+#include "model.h"
+#include "error.h"
+#include "kmem.h"
+#include "pcilib.h"
+#include "pci.h"
+
+
+/**
+ * pcilib_software_registers_open
+ * this function initializes the kernel space memory and stores in it the default values of the registers of the given bank index, if it was not initialized by a concurrent process, and return a bank context containing the adress of this kernel space. It the kernel space memory was already initialized by a concurrent process, then this function just return the bank context with the adress of this kernel space already used
+ *@param[in] ctx the pcilib_t structure running
+ * @param[in] bank the bank index that will permits to get the bank we want registers from
+ * @param[in] model not used
+ * @param[in] args not used
+ *@return a bank context with the adress of the kernel space memory related to it
+ */
+pcilib_register_bank_context_t* pcilib_software_registers_open(pcilib_t *ctx, pcilib_register_bank_t bank,const char* model, const void *args){
+ pcilib_register_bank_context_t* bank_ctx;
+ pcilib_register_value_t *init=NULL;
+ pcilib_kmem_handle_t *test;
+ int i;
+ int j;
+
+ bank_ctx=calloc(1,sizeof(pcilib_register_bank_context_t));
+ bank_ctx->bank=ctx->banks + bank;
+
+ test=pcilib_alloc_kernel_memory(ctx, 0, 0, 0, 0,PCILIB_KMEM_USE_STANDARD,PCILIB_KMEM_FLAG_REUSE|PCILIB_KMEM_FLAG_PERSISTENT);
+ if (!test)pcilib_error("allocation of kernel memory for registers has failed");
+
+ if(pcilib_kmem_is_reused(ctx,test)== PCILIB_KMEM_REUSE_ALLOCATED){
+ bank_ctx->bank_software_register_adress=test;
+ }else{
+ bank_ctx->bank_software_register_adress=test;
+ init=test;
+ j=0;
+ while(ctx->model_info.registers[j].name!=NULL){
+ if(ctx->model_info.registers[j].bank==(ctx->banks + bank).addr){
+ pcilib_write_register_by_id(ctx,ctx->model_info.registers[j],ctx->model_info.registers[j].defvalue);
+ }
+ j++;
+ }
+ }
+ return bank_ctx;
+}
+
+
+/**
+ * pcilib_software_registers_close
+ * this function clear the kernel memory space that could have been allocated for software registers
+ * @param[in] bank_ctx the bank context running that we get from the initialisation function
+ */
+void pcilib_software_registers_close(pcilib_register_bank_context_t *bank_ctx){
+ int err=1;
+
+ err=pcilib_clean_kernel_memory(bank_ctx->ctx, 0, 0);
+
+ if(err) pcilib_error("Error closing register kernel space");
+}
+
+/**
+ * pcilib_software_registers_read
+ * this function read the value of a said register in the kernel space
+ * @param[in] ctx the pcilib_t structure runnning
+ * @param[in] bank_ctx the bank context that was returned by the initialisation function
+ * @param[in] addr the adress of the register we want to read
+ *@param[out] value the value of the register
+ * @return 0 in case of success
+ */
+int pcilib_software_registers_read(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx,pcilib_register_addr_t addr, pcilib_register_value_t *value){
+ *value= *(pcilib_register_value_t*) bank_ctx->bank_software_register_adress+addr;
+ return 0;
+}
+
+/**
+ * pcilib_software_registers_write
+ * this function write the said value to a said register in the kernel space
+ * @param[in] ctx the pcilib_t structure runnning
+ * @param[in] bank_ctx the bank context that was returned by the initialisation function
+ * @param[in] addr the adress of the register we want to write in
+ *@param[out] value the value we want to write in the register
+ * @return 0 in case of success
+ */
+int pcilib_software_registers_write(pcilib_t *ctx, pcilib_register_bank_context_t *bank_ctx, pcilib_register_addr_t addr, pcilib_register_value_t value){
+ *(pcilib_register_value_t*)(bank_ctx->bank_software_register_adress+addr)=value;
+ return 0;
+}