diff options
Diffstat (limited to 'drivers/s390/scsi/zfcp_qdio.h')
| -rw-r--r-- | drivers/s390/scsi/zfcp_qdio.h | 77 | 
1 files changed, 57 insertions, 20 deletions
diff --git a/drivers/s390/scsi/zfcp_qdio.h b/drivers/s390/scsi/zfcp_qdio.h index 2297d8d3e94..497cd379b0d 100644 --- a/drivers/s390/scsi/zfcp_qdio.h +++ b/drivers/s390/scsi/zfcp_qdio.h @@ -3,7 +3,7 @@   *   * Header file for zfcp qdio interface   * - * Copyright IBM Corporation 2010 + * Copyright IBM Corp. 2010   */  #ifndef ZFCP_QDIO_H @@ -13,20 +13,9 @@  #define ZFCP_QDIO_SBALE_LEN	PAGE_SIZE -/* DMQ bug workaround: don't use last SBALE */ -#define ZFCP_QDIO_MAX_SBALES_PER_SBAL	(QDIO_MAX_ELEMENTS_PER_BUFFER - 1) - -/* index of last SBALE (with respect to DMQ bug workaround) */ -#define ZFCP_QDIO_LAST_SBALE_PER_SBAL	(ZFCP_QDIO_MAX_SBALES_PER_SBAL - 1) -  /* Max SBALS for chaining */  #define ZFCP_QDIO_MAX_SBALS_PER_REQ	36 -/* max. number of (data buffer) SBALEs in largest SBAL chain - * request ID + QTCB in SBALE 0 + 1 of first SBAL in chain   */ -#define ZFCP_QDIO_MAX_SBALES_PER_REQ     \ -	(ZFCP_QDIO_MAX_SBALS_PER_REQ * ZFCP_QDIO_MAX_SBALES_PER_SBAL - 2) -  /**   * struct zfcp_qdio - basic qdio data structure   * @res_q: response queue @@ -53,6 +42,8 @@ struct zfcp_qdio {  	atomic_t		req_q_full;  	wait_queue_head_t	req_q_wq;  	struct zfcp_adapter	*adapter; +	u16			max_sbale_per_sbal; +	u16			max_sbale_per_req;  };  /** @@ -67,7 +58,7 @@ struct zfcp_qdio {   * @qdio_outb_usage: usage of outbound queue   */  struct zfcp_qdio_req { -	u32	sbtype; +	u8	sbtype;  	u8	sbal_number;  	u8	sbal_first;  	u8	sbal_last; @@ -116,7 +107,7 @@ zfcp_qdio_sbale_curr(struct zfcp_qdio *qdio, struct zfcp_qdio_req *q_req)   */  static inline  void zfcp_qdio_req_init(struct zfcp_qdio *qdio, struct zfcp_qdio_req *q_req, -			unsigned long req_id, u32 sbtype, void *data, u32 len) +			unsigned long req_id, u8 sbtype, void *data, u32 len)  {  	struct qdio_buffer_element *sbale;  	int count = min(atomic_read(&qdio->req_q_free), @@ -131,7 +122,8 @@ void zfcp_qdio_req_init(struct zfcp_qdio *qdio, struct zfcp_qdio_req *q_req,  	sbale = zfcp_qdio_sbale_req(qdio, q_req);  	sbale->addr = (void *) req_id; -	sbale->flags = SBAL_FLAGS0_COMMAND | sbtype; +	sbale->eflags = 0; +	sbale->sflags = SBAL_SFLAGS0_COMMAND | sbtype;  	if (unlikely(!data))  		return; @@ -154,7 +146,7 @@ void zfcp_qdio_fill_next(struct zfcp_qdio *qdio, struct zfcp_qdio_req *q_req,  {  	struct qdio_buffer_element *sbale; -	BUG_ON(q_req->sbale_curr == ZFCP_QDIO_LAST_SBALE_PER_SBAL); +	BUG_ON(q_req->sbale_curr == qdio->max_sbale_per_sbal - 1);  	q_req->sbale_curr++;  	sbale = zfcp_qdio_sbale_curr(qdio, q_req);  	sbale->addr = data; @@ -173,7 +165,7 @@ void zfcp_qdio_set_sbale_last(struct zfcp_qdio *qdio,  	struct qdio_buffer_element *sbale;  	sbale = zfcp_qdio_sbale_curr(qdio, q_req); -	sbale->flags |= SBAL_FLAGS_LAST_ENTRY; +	sbale->eflags |= SBAL_EFLAGS_LAST_ENTRY;  }  /** @@ -194,9 +186,10 @@ int zfcp_qdio_sg_one_sbale(struct scatterlist *sg)   * @q_req: The current zfcp_qdio_req   */  static inline -void zfcp_qdio_skip_to_last_sbale(struct zfcp_qdio_req *q_req) +void zfcp_qdio_skip_to_last_sbale(struct zfcp_qdio *qdio, +				  struct zfcp_qdio_req *q_req)  { -	q_req->sbale_curr = ZFCP_QDIO_LAST_SBALE_PER_SBAL; +	q_req->sbale_curr = qdio->max_sbale_per_sbal - 1;  }  /** @@ -227,8 +220,52 @@ void zfcp_qdio_set_data_div(struct zfcp_qdio *qdio,  {  	struct qdio_buffer_element *sbale; -	sbale = &qdio->req_q[q_req->sbal_first]->element[0]; +	sbale = qdio->req_q[q_req->sbal_first]->element;  	sbale->length = count;  } +/** + * zfcp_qdio_sbale_count - count sbale used + * @sg: pointer to struct scatterlist + */ +static inline +unsigned int zfcp_qdio_sbale_count(struct scatterlist *sg) +{ +	unsigned int count = 0; + +	for (; sg; sg = sg_next(sg)) +		count++; + +	return count; +} + +/** + * zfcp_qdio_real_bytes - count bytes used + * @sg: pointer to struct scatterlist + */ +static inline +unsigned int zfcp_qdio_real_bytes(struct scatterlist *sg) +{ +	unsigned int real_bytes = 0; + +	for (; sg; sg = sg_next(sg)) +		real_bytes += sg->length; + +	return real_bytes; +} + +/** + * zfcp_qdio_set_scount - set SBAL count value + * @qdio: pointer to struct zfcp_qdio + * @q_req: The current zfcp_qdio_req + */ +static inline +void zfcp_qdio_set_scount(struct zfcp_qdio *qdio, struct zfcp_qdio_req *q_req) +{ +	struct qdio_buffer_element *sbale; + +	sbale = qdio->req_q[q_req->sbal_first]->element; +	sbale->scount = q_req->sbal_number - 1; +} +  #endif /* ZFCP_QDIO_H */  | 
