diff options
| author | zilio nicolas <nicolas.zilio@kit.edu> | 2015-06-18 19:47:17 +0200 | 
|---|---|---|
| committer | zilio nicolas <nicolas.zilio@kit.edu> | 2015-06-18 19:47:17 +0200 | 
| commit | 907559d880de032deb31aa5e648c11029bbf9cce (patch) | |
| tree | 5c58f5fdbdfd5810e2ad2cc844210f5c2a7d8239 | |
| parent | 8f194817bf33fef401093868fbbbf25a0588d00d (diff) | |
| download | pcitool-907559d880de032deb31aa5e648c11029bbf9cce.tar.gz pcitool-907559d880de032deb31aa5e648c11029bbf9cce.tar.bz2 pcitool-907559d880de032deb31aa5e648c11029bbf9cce.tar.xz pcitool-907559d880de032deb31aa5e648c11029bbf9cce.zip | |
new version of software_registers
| -rw-r--r-- | dma/ipe.h | 8 | ||||
| -rw-r--r-- | pcilib/bank.h | 3 | ||||
| -rw-r--r-- | pcilib/pcilib.h | 1 | ||||
| -rw-r--r-- | protocols/software_registers.c | 55 | 
4 files changed, 47 insertions, 20 deletions
| @@ -39,7 +39,7 @@ static const pcilib_dma_engine_description_t ipe_dma_engines[] = {  static const pcilib_register_bank_description_t ipe_dma_banks[] = {      { PCILIB_REGISTER_BANK_DMA, PCILIB_REGISTER_PROTOCOL_DEFAULT, PCILIB_BAR0, 0, 0, 32, 0x0200, PCILIB_LITTLE_ENDIAN, PCILIB_LITTLE_ENDIAN, "0x%lx", "dma", "DMA Registers"}, -    { PCILIB_REGISTER_BANK0, PCILIB_REGISTER_PROTOCOL_SOFTWARE_REGISTERS, PCILIB_BAR1, 0, 0, 32, 0x0003, PCILIB_LITTLE_ENDIAN, PCILIB_LITTLE_ENDIAN, "0x%lx", "test", "test Registers"}, +    { PCILIB_REGISTER_BANK_DMA + 1, PCILIB_REGISTER_PROTOCOL_SOFTWARE_REGISTERS, PCILIB_BARUNDEF, 0, 0, 32, 0x0003, PCILIB_LITTLE_ENDIAN, PCILIB_LITTLE_ENDIAN, "0x%lx", "test", "test Registers"},      { 0, 0, 0, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL }  }; @@ -78,9 +78,9 @@ static const pcilib_register_description_t ipe_dma_registers[] = {      {0x0058, 	0, 	32, 	0, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK_DMA, "last_descriptor_read",	"Last descriptor read by the host"},      {0x005C, 	0, 	32, 	0, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK_DMA, "desc_mem_addr", 		"Number of descriptors configured"},      {0x0060, 	0, 	32, 	0, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK_DMA, "update_thresh",  		"Update threshold of progress register"}, -    {0x0001, 	0, 	32, 	0x1, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK0, "test1",  		"ister"}, -    {0x0002, 	0, 	32, 	0, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK0, "test2",  		"ter"}, -    {0x0003, 	0, 	32, 	0x020, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK0, "test3",  		"er"}, +   {0x0001, 	0, 	32, 	0x1, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK_DMA +1, "test1",  		"ister"}, +    {0x0002, 	0, 	32, 	0, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK_DMA +1, "test2",  		"ter"}, +    {0x0003, 	0, 	32, 	0x020, 	0x00000000,	PCILIB_REGISTER_RW  , PCILIB_REGISTER_STANDARD, PCILIB_REGISTER_BANK_DMA +1, "test3",  		"er"},      {0,		0,	0,	0,	0x00000000,	0,                                           0,                        0, NULL, 			NULL}  };  #endif /* _PCILIB_EXPORT_C */ diff --git a/pcilib/bank.h b/pcilib/bank.h index df4df83..dfd2adb 100644 --- a/pcilib/bank.h +++ b/pcilib/bank.h @@ -15,7 +15,6 @@  #define PCILIB_REGISTER_PROTOCOL_INVALID	((pcilib_register_protocol_t)-1)  #define PCILIB_REGISTER_PROTOCOL0		0					/**< First PROTOCOL address to be used in the event engine */  #define PCILIB_REGISTER_PROTOCOL_DEFAULT	64					/**< Default memmap based protocol */ -#define PCILIB_REGISTER_PROTOCOL_KERNEL 32		/**< Protocol with registers registered in kernel directly*/  #define PCILIB_REGISTER_PROTOCOL_DMA		96					/**< First PROTOCOL address to be used by DMA engines */  #define PCILIB_REGISTER_PROTOCOL_DYNAMIC	128					/**< First PROTOCOL address to be used by plugins */  #define PCILIB_REGISTER_PROTOCOL_SOFTWARE_REGISTERS 32 @@ -88,7 +87,7 @@ struct pcilib_register_bank_context_s {      const pcilib_register_bank_description_t *bank;				/**< Corresponding bank description */      const pcilib_register_protocol_api_description_t *api;			/**< API functions */  	xmlNodeSetPtr banks_nodes; -	void *bank_software_register_adress; +	void *kmem_base_address;  	pcilib_t *ctx;  }; diff --git a/pcilib/pcilib.h b/pcilib/pcilib.h index 6d241c6..6c1d592 100644 --- a/pcilib/pcilib.h +++ b/pcilib/pcilib.h @@ -87,6 +87,7 @@ typedef struct {  #define PCILIB_BAR_INVALID		((pcilib_bar_t)-1)  #define PCILIB_BAR0			0  #define PCILIB_BAR1			1 +#define PCILIB_BARUNDEF		-1  #define PCILIB_DMA_ENGINE_INVALID	((pcilib_dma_engine_t)-1)  #define PCILIB_DMA_ENGINE_ALL		((pcilib_dma_engine_t)-1)  #define PCILIB_DMA_FLAGS_DEFAULT	((pcilib_dma_flags_t)0) diff --git a/protocols/software_registers.c b/protocols/software_registers.c index 68655e0..ab5d31d 100644 --- a/protocols/software_registers.c +++ b/protocols/software_registers.c @@ -8,6 +8,7 @@  #include "pcilib.h"  #include "pci.h" +#include <stdio.h>  /**   * pcilib_software_registers_open @@ -20,27 +21,39 @@   */  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_kmem_handle_t *test; +	pcilib_kmem_handle_t *handle;  	int j; +	/* the protocol thing is here to make sure to avoid segfault in write_registers_internal, but is not useful as it is now*/ +	pcilib_register_protocol_t protocol; +	protocol = pcilib_find_register_protocol_by_addr(ctx, ctx->banks[bank].protocol);  	bank_ctx=calloc(1,sizeof(pcilib_register_bank_context_t));  	bank_ctx->bank=ctx->banks + bank; +	bank_ctx->ctx=ctx; +	bank_ctx->api=ctx->protocols[protocol].api; +	ctx->bank_ctx[bank]=bank_ctx; + +	handle=pcilib_alloc_kernel_memory(ctx, PCILIB_KMEM_TYPE_PAGE, 1, 0, 1,PCILIB_KMEM_USE_STANDARD,PCILIB_KMEM_FLAG_REUSE|PCILIB_KMEM_FLAG_PERSISTENT); + +	if (!handle)pcilib_error("allocation of kernel memory for registers has failed"); -	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"); +	bank_ctx->kmem_base_address=handle; -	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; +	if(pcilib_kmem_is_reused(ctx,handle)!= PCILIB_KMEM_REUSE_ALLOCATED){  		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].addr,ctx->model_info.registers[j].defvalue); +		/* !!!!!warning!!!!!  +		hey suren, +		you may check here too  :the programm seems to always go this path, so pcilib_write_register_by_id always write the original value, kmem_is_reused working? +		*/ +		pcilib_write_register_by_id(ctx,j,ctx->model_info.registers[j].defvalue); +			  			}	  			j++;  		}		  	} +  	return bank_ctx;  } @@ -51,11 +64,11 @@ pcilib_register_bank_context_t* pcilib_software_registers_open(pcilib_t *ctx, pc   * @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); +	/*!!!!! to check!!!! -	if(err) pcilib_error("Error closing register kernel space"); +	ps: i am using uint32_t to calculate registers adress, may it change in the future? should we define some #define?	 +	*/ +	pcilib_free_kernel_memory(bank_ctx->ctx,bank_ctx->kmem_base_address, 0);  }  /** @@ -68,7 +81,14 @@ void pcilib_software_registers_close(pcilib_register_bank_context_t *bank_ctx){   * @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; +	int i; +	void* base_addr; +	 +	base_addr=pcilib_kmem_get_block_ua(ctx,bank_ctx->kmem_base_address,0); +	for(i=0;ctx->registers[i].name!=NULL;i++){ +		if(ctx->registers[i].addr==addr) break; +	} +	*value=*(pcilib_register_value_t*)(base_addr+i*sizeof(uint32_t));  	return 0;  } @@ -82,6 +102,13 @@ int pcilib_software_registers_read(pcilib_t *ctx, pcilib_register_bank_context_t   * @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; +	int i; +	void* base_addr; +	 +	base_addr=pcilib_kmem_get_block_ua(ctx,bank_ctx->kmem_base_address,0); +	for(i=0;ctx->registers[i].name!=NULL;i++){ +		if(ctx->registers[i].addr==addr) break; +	} +	*(pcilib_register_value_t*)(base_addr+i*sizeof(uint32_t))=value;  	return 0;  } | 
