All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] lpfc: hgp/pgp cleanups
@ 2005-04-24 12:18 Christoph Hellwig
  0 siblings, 0 replies; 2+ messages in thread
From: Christoph Hellwig @ 2005-04-24 12:18 UTC (permalink / raw)
  To: James.Smart; +Cc: linux-scsi

 - rename PGP/HPH to lpfc_pgp/lpfc_hgp
 - use __le32 types for the members to start fixing sparse -Wbitwise
   issues
 - remove lpfc_sli.MBhostaddr, we can always use the pointer from
   SLI2_DESC directly


--- 1.1/drivers/scsi/lpfc/lpfc_hw.h	2005-04-17 17:05:02 +02:00
+++ edited/drivers/scsi/lpfc/lpfc_hw.h	2005-04-24 13:05:57 +02:00
@@ -2214,20 +2214,20 @@
  * SLI-2 specific structures
  */
 
-typedef struct {
-	uint32_t cmdPutInx;
-	uint32_t rspGetInx;
-} HGP;
+struct lpfc_hgp {
+	__le32 cmdPutInx;
+	__le32 rspGetInx;
+};
 
-typedef struct {
-	uint32_t cmdGetInx;
-	uint32_t rspPutInx;
-} PGP;
+struct lpfc_pgp {
+	__le32 cmdGetInx;
+	__le32 rspPutInx;
+};
 
 typedef struct _SLI2_DESC {
-	HGP host[MAX_RINGS];
+	struct lpfc_hgp host[MAX_RINGS];
 	uint32_t unused1[16];
-	PGP port[MAX_RINGS];
+	struct lpfc_pgp port[MAX_RINGS];
 } SLI2_DESC;
 
 typedef union {
===== drivers/scsi/lpfc/lpfc_mbox.c 1.1 vs edited =====
--- 1.1/drivers/scsi/lpfc/lpfc_mbox.c	2005-04-17 17:05:05 +02:00
+++ edited/drivers/scsi/lpfc/lpfc_mbox.c	2005-04-24 13:04:52 +02:00
@@ -422,7 +422,6 @@
 	uint32_t iocbCnt;
 	int i;
 
-	psli->MBhostaddr = (uint32_t *)&phba->slim2p->mbx;
 	pcbp->maxRing = (psli->num_rings - 1);
 
 	iocbCnt = 0;
@@ -528,7 +527,7 @@
 	dma_addr_t pdma_addr;
 	uint32_t bar_low, bar_high;
 	size_t offset;
-	HGP hgp;
+	struct lpfc_hgp hgp;
 	void __iomem *to_slim;
 
 	memset(pmb, 0, sizeof(LPFC_MBOXQ_t));
@@ -584,9 +583,9 @@
 	else
 		phba->slim2p->pcb.hgpAddrHigh = 0;
 	/* write HGP data to SLIM at the required longword offset */
-	memset(&hgp, 0, sizeof(HGP));
+	memset(&hgp, 0, sizeof(struct lpfc_hgp));
 	to_slim = phba->MBslimaddr + (SLIMOFF*sizeof (uint32_t));
-	lpfc_memcpy_to_slim(to_slim, &hgp, sizeof (HGP));
+	lpfc_memcpy_to_slim(to_slim, &hgp, sizeof(struct lpfc_hgp));
 
 	/* Setup Port Group ring pointer */
 	offset = (uint8_t *)&phba->slim2p->mbx.us.s2.port -
===== drivers/scsi/lpfc/lpfc_sli.c 1.1 vs edited =====
--- 1.1/drivers/scsi/lpfc/lpfc_sli.c	2005-04-17 17:05:12 +02:00
+++ edited/drivers/scsi/lpfc/lpfc_sli.c	2005-04-24 13:03:13 +02:00
@@ -225,8 +225,7 @@
 static IOCB_t *
 lpfc_sli_next_iocb_slot (struct lpfc_hba *phba, struct lpfc_sli_ring *pring)
 {
-	MAILBOX_t *mbox = (MAILBOX_t *)phba->sli.MBhostaddr;
-	PGP *pgp = (PGP *)&mbox->us.s2.port[pring->ringno];
+	struct lpfc_pgp *pgp = &phba->slim2p->mbx.us.s2.port[pring->ringno];
 	uint32_t  max_cmd_idx = pring->numCiocb;
 	IOCB_t *iocb = NULL;
 
@@ -411,9 +410,7 @@
 static void
 lpfc_sli_turn_on_ring(struct lpfc_hba * phba, int ringno)
 {
-	PGP *pgp =
-		((PGP *) &
-		 (((MAILBOX_t *)phba->sli.MBhostaddr)->us.s2.port[ringno]));
+	struct lpfc_pgp *pgp = &phba->slim2p->mbx.us.s2.port[ringno];
 
 	/* If the ring is active, flag it */
 	if (phba->sli.ring[ringno].cmdringaddr) {
@@ -537,7 +534,7 @@
 	/* Get a Mailbox buffer to setup mailbox commands for callback */
 	if ((pmb = phba->sli.mbox_active)) {
 		pmbox = &pmb->mb;
-		mbox = (MAILBOX_t *) phba->sli.MBhostaddr;
+		mbox = &phba->slim2p->mbx;
 
 		/* First check out the status word */
 		lpfc_sli_pcimem_bcopy(mbox, pmbox, sizeof (uint32_t));
@@ -905,10 +902,10 @@
 lpfc_sli_handle_fast_ring_event(struct lpfc_hba * phba,
 				struct lpfc_sli_ring * pring, uint32_t mask)
 {
+	struct lpfc_pgp *pgp = &phba->slim2p->mbx.us.s2.port[pring->ringno];
 	IOCB_t *irsp = NULL;
 	struct lpfc_iocbq *cmdiocbq = NULL;
 	struct lpfc_iocbq rspiocbq;
-	PGP *pgp;
 	uint32_t status;
 	uint32_t portRspPut, portRspMax;
 	int rc = 1;
@@ -920,10 +917,6 @@
 	spin_lock_irqsave(phba->host->host_lock, iflag);
 	pring->stats.iocb_event++;
 
-	/* The driver assumes SLI-2 mode */
-	pgp = (PGP *) &((MAILBOX_t *) phba->sli.MBhostaddr)
-		->us.s2.port[pring->ringno];
-
 	/*
 	 * The next available response entry should never exceed the maximum
 	 * entries.  If it does, treat it as an adapter hardware error.
@@ -1075,9 +1068,7 @@
 	struct lpfc_iocbq *cmdiocbp;
 	struct lpfc_iocbq *saveq;
 	struct list_head *lpfc_iocb_list = &phba->lpfc_iocb_list;
-	HGP *hgp;
-	PGP *pgp;
-	MAILBOX_t *mbox;
+	struct lpfc_pgp *pgp = &phba->slim2p->mbx.us.s2.port[pring->ringno];
 	uint8_t iocb_cmd_type;
 	lpfc_iocb_type type;
 	uint32_t status, free_saveq;
@@ -1089,11 +1080,6 @@
 	spin_lock_irqsave(phba->host->host_lock, iflag);
 	pring->stats.iocb_event++;
 
-	/* The driver assumes SLI-2 mode */
-	mbox = (MAILBOX_t *) phba->sli.MBhostaddr;
-	pgp = (PGP *) & mbox->us.s2.port[pring->ringno];
-	hgp = (HGP *) & mbox->us.s2.host[pring->ringno];
-
 	/*
 	 * The next available response entry should never exceed the maximum
 	 * entries.  If it does, treat it as an adapter hardware error.
@@ -1771,7 +1757,6 @@
 int
 lpfc_sli_issue_mbox(struct lpfc_hba * phba, LPFC_MBOXQ_t * pmbox, uint32_t flag)
 {
-	MAILBOX_t *mbox;
 	MAILBOX_t *mb;
 	struct lpfc_sli *psli;
 	uint32_t status, evtctr;
@@ -1901,15 +1886,13 @@
 	mb->mbxOwner = OWN_CHIP;
 
 	if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
-
 		/* First copy command data to host SLIM area */
-		mbox = (MAILBOX_t *) psli->MBhostaddr;
-		lpfc_sli_pcimem_bcopy(mb, mbox, MAILBOX_CMD_SIZE);
+		lpfc_sli_pcimem_bcopy(mb, &phba->slim2p->mbx, MAILBOX_CMD_SIZE);
 	} else {
 		if (mb->mbxCommand == MBX_CONFIG_PORT) {
 			/* copy command data into host mbox for cmpl */
-			mbox = (MAILBOX_t *) psli->MBhostaddr;
-			lpfc_sli_pcimem_bcopy(mb, mbox, MAILBOX_CMD_SIZE);
+			lpfc_sli_pcimem_bcopy(mb, &phba->slim2p->mbx,
+					MAILBOX_CMD_SIZE);
 		}
 
 		/* First copy mbox command data to HBA SLIM, skip past first
@@ -1946,8 +1929,7 @@
 		psli->mbox_active = NULL;
 		if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
 			/* First read mbox status word */
-			mbox = (MAILBOX_t *) psli->MBhostaddr;
-			word0 = *((volatile uint32_t *)mbox);
+			word0 = *((volatile uint32_t *)&phba->slim2p->mbx);
 			word0 = le32_to_cpu(word0);
 		} else {
 			/* First read mbox status word */
@@ -1984,8 +1966,8 @@
 
 			if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
 				/* First copy command data */
-				mbox = (MAILBOX_t *) psli->MBhostaddr;
-				word0 = *((volatile uint32_t *)mbox);
+				word0 = *((volatile uint32_t *)
+						&phba->slim2p->mbx);
 				word0 = le32_to_cpu(word0);
 				if (mb->mbxCommand == MBX_CONFIG_PORT) {
 					MAILBOX_t *slimmb;
@@ -2009,10 +1991,9 @@
 		}
 
 		if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
-			/* First copy command data */
-			mbox = (MAILBOX_t *) psli->MBhostaddr;
 			/* copy results back to user */
-			lpfc_sli_pcimem_bcopy(mbox, mb, MAILBOX_CMD_SIZE);
+			lpfc_sli_pcimem_bcopy(&phba->slim2p->mbx, mb,
+					MAILBOX_CMD_SIZE);
 		} else {
 			/* First copy command data */
 			lpfc_memcpy_from_slim(mb, phba->MBslimaddr,

^ permalink raw reply	[flat|nested] 2+ messages in thread

* RE: [PATCH] lpfc: hgp/pgp cleanups
@ 2005-04-27 20:37 James.Smart
  0 siblings, 0 replies; 2+ messages in thread
From: James.Smart @ 2005-04-27 20:37 UTC (permalink / raw)
  To: hch; +Cc: linux-scsi

This patch is fine...  Thanks Christoph.

-- james s


> -----Original Message-----
> From: Christoph Hellwig [mailto:hch@lst.de]
> Sent: Sunday, April 24, 2005 8:19 AM
> To: Smart, James
> Cc: linux-scsi@vger.kernel.org
> Subject: [PATCH] lpfc: hgp/pgp cleanups
> 
> 
>  - rename PGP/HPH to lpfc_pgp/lpfc_hgp
>  - use __le32 types for the members to start fixing sparse -Wbitwise
>    issues
>  - remove lpfc_sli.MBhostaddr, we can always use the pointer from
>    SLI2_DESC directly
> 
> 
> --- 1.1/drivers/scsi/lpfc/lpfc_hw.h	2005-04-17 17:05:02 +02:00
> +++ edited/drivers/scsi/lpfc/lpfc_hw.h	2005-04-24 
> 13:05:57 +02:00
> @@ -2214,20 +2214,20 @@
>   * SLI-2 specific structures
>   */
>  
> -typedef struct {
> -	uint32_t cmdPutInx;
> -	uint32_t rspGetInx;
> -} HGP;
> +struct lpfc_hgp {
> +	__le32 cmdPutInx;
> +	__le32 rspGetInx;
> +};
>  
> -typedef struct {
> -	uint32_t cmdGetInx;
> -	uint32_t rspPutInx;
> -} PGP;
> +struct lpfc_pgp {
> +	__le32 cmdGetInx;
> +	__le32 rspPutInx;
> +};
>  
>  typedef struct _SLI2_DESC {
> -	HGP host[MAX_RINGS];
> +	struct lpfc_hgp host[MAX_RINGS];
>  	uint32_t unused1[16];
> -	PGP port[MAX_RINGS];
> +	struct lpfc_pgp port[MAX_RINGS];
>  } SLI2_DESC;
>  
>  typedef union {
> ===== drivers/scsi/lpfc/lpfc_mbox.c 1.1 vs edited =====
> --- 1.1/drivers/scsi/lpfc/lpfc_mbox.c	2005-04-17 17:05:05 +02:00
> +++ edited/drivers/scsi/lpfc/lpfc_mbox.c	2005-04-24 
> 13:04:52 +02:00
> @@ -422,7 +422,6 @@
>  	uint32_t iocbCnt;
>  	int i;
>  
> -	psli->MBhostaddr = (uint32_t *)&phba->slim2p->mbx;
>  	pcbp->maxRing = (psli->num_rings - 1);
>  
>  	iocbCnt = 0;
> @@ -528,7 +527,7 @@
>  	dma_addr_t pdma_addr;
>  	uint32_t bar_low, bar_high;
>  	size_t offset;
> -	HGP hgp;
> +	struct lpfc_hgp hgp;
>  	void __iomem *to_slim;
>  
>  	memset(pmb, 0, sizeof(LPFC_MBOXQ_t));
> @@ -584,9 +583,9 @@
>  	else
>  		phba->slim2p->pcb.hgpAddrHigh = 0;
>  	/* write HGP data to SLIM at the required longword offset */
> -	memset(&hgp, 0, sizeof(HGP));
> +	memset(&hgp, 0, sizeof(struct lpfc_hgp));
>  	to_slim = phba->MBslimaddr + (SLIMOFF*sizeof (uint32_t));
> -	lpfc_memcpy_to_slim(to_slim, &hgp, sizeof (HGP));
> +	lpfc_memcpy_to_slim(to_slim, &hgp, sizeof(struct lpfc_hgp));
>  
>  	/* Setup Port Group ring pointer */
>  	offset = (uint8_t *)&phba->slim2p->mbx.us.s2.port -
> ===== drivers/scsi/lpfc/lpfc_sli.c 1.1 vs edited =====
> --- 1.1/drivers/scsi/lpfc/lpfc_sli.c	2005-04-17 17:05:12 +02:00
> +++ edited/drivers/scsi/lpfc/lpfc_sli.c	2005-04-24 
> 13:03:13 +02:00
> @@ -225,8 +225,7 @@
>  static IOCB_t *
>  lpfc_sli_next_iocb_slot (struct lpfc_hba *phba, struct 
> lpfc_sli_ring *pring)
>  {
> -	MAILBOX_t *mbox = (MAILBOX_t *)phba->sli.MBhostaddr;
> -	PGP *pgp = (PGP *)&mbox->us.s2.port[pring->ringno];
> +	struct lpfc_pgp *pgp = 
> &phba->slim2p->mbx.us.s2.port[pring->ringno];
>  	uint32_t  max_cmd_idx = pring->numCiocb;
>  	IOCB_t *iocb = NULL;
>  
> @@ -411,9 +410,7 @@
>  static void
>  lpfc_sli_turn_on_ring(struct lpfc_hba * phba, int ringno)
>  {
> -	PGP *pgp =
> -		((PGP *) &
> -		 (((MAILBOX_t 
> *)phba->sli.MBhostaddr)->us.s2.port[ringno]));
> +	struct lpfc_pgp *pgp = &phba->slim2p->mbx.us.s2.port[ringno];
>  
>  	/* If the ring is active, flag it */
>  	if (phba->sli.ring[ringno].cmdringaddr) {
> @@ -537,7 +534,7 @@
>  	/* Get a Mailbox buffer to setup mailbox commands for 
> callback */
>  	if ((pmb = phba->sli.mbox_active)) {
>  		pmbox = &pmb->mb;
> -		mbox = (MAILBOX_t *) phba->sli.MBhostaddr;
> +		mbox = &phba->slim2p->mbx;
>  
>  		/* First check out the status word */
>  		lpfc_sli_pcimem_bcopy(mbox, pmbox, sizeof (uint32_t));
> @@ -905,10 +902,10 @@
>  lpfc_sli_handle_fast_ring_event(struct lpfc_hba * phba,
>  				struct lpfc_sli_ring * pring, 
> uint32_t mask)
>  {
> +	struct lpfc_pgp *pgp = 
> &phba->slim2p->mbx.us.s2.port[pring->ringno];
>  	IOCB_t *irsp = NULL;
>  	struct lpfc_iocbq *cmdiocbq = NULL;
>  	struct lpfc_iocbq rspiocbq;
> -	PGP *pgp;
>  	uint32_t status;
>  	uint32_t portRspPut, portRspMax;
>  	int rc = 1;
> @@ -920,10 +917,6 @@
>  	spin_lock_irqsave(phba->host->host_lock, iflag);
>  	pring->stats.iocb_event++;
>  
> -	/* The driver assumes SLI-2 mode */
> -	pgp = (PGP *) &((MAILBOX_t *) phba->sli.MBhostaddr)
> -		->us.s2.port[pring->ringno];
> -
>  	/*
>  	 * The next available response entry should never 
> exceed the maximum
>  	 * entries.  If it does, treat it as an adapter hardware error.
> @@ -1075,9 +1068,7 @@
>  	struct lpfc_iocbq *cmdiocbp;
>  	struct lpfc_iocbq *saveq;
>  	struct list_head *lpfc_iocb_list = &phba->lpfc_iocb_list;
> -	HGP *hgp;
> -	PGP *pgp;
> -	MAILBOX_t *mbox;
> +	struct lpfc_pgp *pgp = 
> &phba->slim2p->mbx.us.s2.port[pring->ringno];
>  	uint8_t iocb_cmd_type;
>  	lpfc_iocb_type type;
>  	uint32_t status, free_saveq;
> @@ -1089,11 +1080,6 @@
>  	spin_lock_irqsave(phba->host->host_lock, iflag);
>  	pring->stats.iocb_event++;
>  
> -	/* The driver assumes SLI-2 mode */
> -	mbox = (MAILBOX_t *) phba->sli.MBhostaddr;
> -	pgp = (PGP *) & mbox->us.s2.port[pring->ringno];
> -	hgp = (HGP *) & mbox->us.s2.host[pring->ringno];
> -
>  	/*
>  	 * The next available response entry should never 
> exceed the maximum
>  	 * entries.  If it does, treat it as an adapter hardware error.
> @@ -1771,7 +1757,6 @@
>  int
>  lpfc_sli_issue_mbox(struct lpfc_hba * phba, LPFC_MBOXQ_t * 
> pmbox, uint32_t flag)
>  {
> -	MAILBOX_t *mbox;
>  	MAILBOX_t *mb;
>  	struct lpfc_sli *psli;
>  	uint32_t status, evtctr;
> @@ -1901,15 +1886,13 @@
>  	mb->mbxOwner = OWN_CHIP;
>  
>  	if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
> -
>  		/* First copy command data to host SLIM area */
> -		mbox = (MAILBOX_t *) psli->MBhostaddr;
> -		lpfc_sli_pcimem_bcopy(mb, mbox, MAILBOX_CMD_SIZE);
> +		lpfc_sli_pcimem_bcopy(mb, &phba->slim2p->mbx, 
> MAILBOX_CMD_SIZE);
>  	} else {
>  		if (mb->mbxCommand == MBX_CONFIG_PORT) {
>  			/* copy command data into host mbox for cmpl */
> -			mbox = (MAILBOX_t *) psli->MBhostaddr;
> -			lpfc_sli_pcimem_bcopy(mb, mbox, 
> MAILBOX_CMD_SIZE);
> +			lpfc_sli_pcimem_bcopy(mb, &phba->slim2p->mbx,
> +					MAILBOX_CMD_SIZE);
>  		}
>  
>  		/* First copy mbox command data to HBA SLIM, 
> skip past first
> @@ -1946,8 +1929,7 @@
>  		psli->mbox_active = NULL;
>  		if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
>  			/* First read mbox status word */
> -			mbox = (MAILBOX_t *) psli->MBhostaddr;
> -			word0 = *((volatile uint32_t *)mbox);
> +			word0 = *((volatile uint32_t 
> *)&phba->slim2p->mbx);
>  			word0 = le32_to_cpu(word0);
>  		} else {
>  			/* First read mbox status word */
> @@ -1984,8 +1966,8 @@
>  
>  			if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
>  				/* First copy command data */
> -				mbox = (MAILBOX_t *) psli->MBhostaddr;
> -				word0 = *((volatile uint32_t *)mbox);
> +				word0 = *((volatile uint32_t *)
> +						&phba->slim2p->mbx);
>  				word0 = le32_to_cpu(word0);
>  				if (mb->mbxCommand == MBX_CONFIG_PORT) {
>  					MAILBOX_t *slimmb;
> @@ -2009,10 +1991,9 @@
>  		}
>  
>  		if (psli->sli_flag & LPFC_SLI2_ACTIVE) {
> -			/* First copy command data */
> -			mbox = (MAILBOX_t *) psli->MBhostaddr;
>  			/* copy results back to user */
> -			lpfc_sli_pcimem_bcopy(mbox, mb, 
> MAILBOX_CMD_SIZE);
> +			lpfc_sli_pcimem_bcopy(&phba->slim2p->mbx, mb,
> +					MAILBOX_CMD_SIZE);
>  		} else {
>  			/* First copy command data */
>  			lpfc_memcpy_from_slim(mb, phba->MBslimaddr,
> 

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2005-04-27 20:37 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-04-24 12:18 [PATCH] lpfc: hgp/pgp cleanups Christoph Hellwig
2005-04-27 20:37 James.Smart

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.