public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19
@ 2006-09-14 21:12 James Bottomley
  2006-09-14 21:20 ` Andrew Morton
  2006-09-14 21:51 ` Douglas Gilbert
  0 siblings, 2 replies; 7+ messages in thread
From: James Bottomley @ 2006-09-14 21:12 UTC (permalink / raw)
  To: Linus Torvalds, Andrew Morton; +Cc: linux-kernel, linux-scsi

The patch is here

master.kernel.org:/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6.git

However, as there's only a single patch in there, I attach it in case
you'd prefer simply to apply it as a patch rather than merge a single
patch tree.

James

---

commit 15d100224c123f0f993ef88e95fd5d46bb0bd085
Author: James Smart <James.Smart@Emulex.Com>
Date:   Thu Aug 31 12:27:57 2006 -0400

    [SCSI] lpfc: don't free mempool if mailbox is busy
    
    Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>

diff --git a/drivers/scsi/lpfc/lpfc_init.c b/drivers/scsi/lpfc/lpfc_init.c
index f6948ff..c31fe41 100644
--- a/drivers/scsi/lpfc/lpfc_init.c
+++ b/drivers/scsi/lpfc/lpfc_init.c
@@ -387,7 +387,8 @@ lpfc_config_port_post(struct lpfc_hba * 
 
 	lpfc_init_link(phba, pmb, phba->cfg_topology, phba->cfg_link_speed);
 	pmb->mbox_cmpl = lpfc_sli_def_mbox_cmpl;
-	if (lpfc_sli_issue_mbox(phba, pmb, MBX_NOWAIT) != MBX_SUCCESS) {
+	rc = lpfc_sli_issue_mbox(phba, pmb, MBX_NOWAIT);
+	if (rc != MBX_SUCCESS) {
 		lpfc_printf_log(phba,
 				KERN_ERR,
 				LOG_INIT,
@@ -404,7 +405,8 @@ lpfc_config_port_post(struct lpfc_hba * 
 		readl(phba->HAregaddr); /* flush */
 
 		phba->hba_state = LPFC_HBA_ERROR;
-		mempool_free(pmb, phba->mbox_mem_pool);
+		if (rc != MBX_BUSY)
+			mempool_free(pmb, phba->mbox_mem_pool);
 		return -EIO;
 	}
 	/* MBOX buffer will be freed in mbox compl */



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

* Re: [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19
  2006-09-14 21:12 [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19 James Bottomley
@ 2006-09-14 21:20 ` Andrew Morton
  2006-09-14 21:37   ` James Bottomley
  2006-09-14 21:51 ` Douglas Gilbert
  1 sibling, 1 reply; 7+ messages in thread
From: Andrew Morton @ 2006-09-14 21:20 UTC (permalink / raw)
  To: James Bottomley; +Cc: Linus Torvalds, linux-kernel, linux-scsi

On Thu, 14 Sep 2006 16:12:58 -0500
James Bottomley <James.Bottomley@SteelEye.com> wrote:

> The patch is here
> 
> master.kernel.org:/pub/scm/linux/kernel/git/jejb/scsi-rc-fixes-2.6.git
> 
> However, as there's only a single patch in there, I attach it in case
> you'd prefer simply to apply it as a patch rather than merge a single
> patch tree.

<digs around>

ftp://ftp.kernel.org/pub/linux/kernel/people/akpm/patches/2.6/2.6.18-rc6/2.6.18-rc6-mm2/broken-out/fix-panic-when-reinserting-adaptec-pcmcia-scsi-card.patch
might be handy too.  Your ack is my command.

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

* Re: [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19
  2006-09-14 21:20 ` Andrew Morton
@ 2006-09-14 21:37   ` James Bottomley
  2006-09-14 21:47     ` Andrew Morton
  0 siblings, 1 reply; 7+ messages in thread
From: James Bottomley @ 2006-09-14 21:37 UTC (permalink / raw)
  To: Andrew Morton; +Cc: Linus Torvalds, linux-kernel, linux-scsi

On Thu, 2006-09-14 at 14:20 -0700, Andrew Morton wrote:
> ftp://ftp.kernel.org/pub/linux/kernel/people/akpm/patches/2.6/2.6.18-rc6/2.6.18-rc6-mm2/broken-out/fix-panic-when-reinserting-adaptec-pcmcia-scsi-card.patch
> might be handy too.  Your ack is my command.

Well ... no, not really, on the grounds that the patch is wrong.

The correct fix is to eliminate the aha152x_host array by converting the
driver to the correct driver model ... I just haven't had time to look
at doing that yet.

James



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

* Re: [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19
  2006-09-14 21:37   ` James Bottomley
@ 2006-09-14 21:47     ` Andrew Morton
  2006-09-14 22:04       ` James Bottomley
  0 siblings, 1 reply; 7+ messages in thread
From: Andrew Morton @ 2006-09-14 21:47 UTC (permalink / raw)
  To: James Bottomley, Alex Davis; +Cc: Linus Torvalds, linux-kernel, linux-scsi

On Thu, 14 Sep 2006 16:37:39 -0500
James Bottomley <James.Bottomley@SteelEye.com> wrote:

> On Thu, 2006-09-14 at 14:20 -0700, Andrew Morton wrote:
> > ftp://ftp.kernel.org/pub/linux/kernel/people/akpm/patches/2.6/2.6.18-rc6/2.6.18-rc6-mm2/broken-out/fix-panic-when-reinserting-adaptec-pcmcia-scsi-card.patch
> > might be handy too.  Your ack is my command.
> 
> Well ... no, not really, on the grounds that the patch is wrong.

So is oopsing ;)

> The correct fix is to eliminate the aha152x_host array by converting the
> driver to the correct driver model ... I just haven't had time to look
> at doing that yet.

<lachrymose>If we'd been told that on July 8 and/or August 14, this might
be fixed by now</>

Perhaps Alex might like to take a look into doing this (please)?

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

* Re: [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19
  2006-09-14 21:12 [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19 James Bottomley
  2006-09-14 21:20 ` Andrew Morton
@ 2006-09-14 21:51 ` Douglas Gilbert
  2006-09-14 22:12   ` James Bottomley
  1 sibling, 1 reply; 7+ messages in thread
From: Douglas Gilbert @ 2006-09-14 21:51 UTC (permalink / raw)
  To: James Bottomley; +Cc: Linus Torvalds, Andrew Morton, linux-kernel, linux-scsi

James,
Is the door already closed for patches to lk 2.6.19 ?

Doug Gilbert

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

* Re: [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19
  2006-09-14 21:47     ` Andrew Morton
@ 2006-09-14 22:04       ` James Bottomley
  0 siblings, 0 replies; 7+ messages in thread
From: James Bottomley @ 2006-09-14 22:04 UTC (permalink / raw)
  To: Andrew Morton; +Cc: Alex Davis, Linus Torvalds, linux-kernel, linux-scsi

On Thu, 2006-09-14 at 14:47 -0700, Andrew Morton wrote:
> <lachrymose>If we'd been told that on July 8 and/or August 14, this might
> be fixed by now</>

OK, so mea culpa, I'll make amends

> Perhaps Alex might like to take a look into doing this (please)?

Just test out this patch, please ...

James

diff --git a/drivers/scsi/aha152x.c b/drivers/scsi/aha152x.c
index f974869..7fd56b8 100644
--- a/drivers/scsi/aha152x.c
+++ b/drivers/scsi/aha152x.c
@@ -253,6 +253,7 @@ #include <linux/kernel.h>
 #include <linux/isapnp.h>
 #include <linux/spinlock.h>
 #include <linux/workqueue.h>
+#include <linux/list.h>
 #include <asm/semaphore.h>
 #include <scsi/scsicam.h>
 
@@ -262,6 +263,8 @@ #include <scsi/scsi_host.h>
 #include <scsi/scsi_transport_spi.h>
 #include "aha152x.h"
 
+static LIST_HEAD(aha152x_host_list);
+
 
 /* DEFINES */
 
@@ -423,8 +426,6 @@ #endif /* ISAPNP */
 
 #endif /* !PCMCIA */
 
-static int registered_count=0;
-static struct Scsi_Host *aha152x_host[2];
 static struct scsi_host_template aha152x_driver_template;
 
 /*
@@ -541,6 +542,7 @@ #endif
 #ifdef __ISAPNP__
 	struct pnp_dev *pnpdev;
 #endif
+	struct list_head host_list;
 };
 
 
@@ -755,20 +757,9 @@ static inline Scsi_Cmnd *remove_SC(Scsi_
 	return ptr;
 }
 
-static inline struct Scsi_Host *lookup_irq(int irqno)
-{
-	int i;
-
-	for(i=0; i<ARRAY_SIZE(aha152x_host); i++)
-		if(aha152x_host[i] && aha152x_host[i]->irq==irqno)
-			return aha152x_host[i];
-
-	return NULL;
-}
-
 static irqreturn_t swintr(int irqno, void *dev_id, struct pt_regs *regs)
 {
-	struct Scsi_Host *shpnt = lookup_irq(irqno);
+	struct Scsi_Host *shpnt = (struct Scsi_Host *)dev_id;
 
 	if (!shpnt) {
         	printk(KERN_ERR "aha152x: catched software interrupt %d for unknown controller.\n", irqno);
@@ -791,10 +782,11 @@ struct Scsi_Host *aha152x_probe_one(stru
 		return NULL;
 	}
 
-	/* need to have host registered before triggering any interrupt */
-	aha152x_host[registered_count] = shpnt;
-
 	memset(HOSTDATA(shpnt), 0, sizeof *HOSTDATA(shpnt));
+	INIT_LIST_HEAD(&HOSTDATA(shpnt)->host_list);
+
+	/* need to have host registered before triggering any interrupt */
+	list_add_tail(&HOSTDATA(shpnt)->host_list, &aha152x_host_list);
 
 	shpnt->io_port   = setup->io_port;
 	shpnt->n_io_port = IO_RANGE;
@@ -907,12 +899,10 @@ #endif
 
 	scsi_scan_host(shpnt);
 
-	registered_count++;
-
 	return shpnt;
 
 out_host_put:
-	aha152x_host[registered_count]=NULL;
+	list_del(&HOSTDATA(shpnt)->host_list);
 	scsi_host_put(shpnt);
 
 	return NULL;
@@ -937,6 +927,7 @@ #ifdef __ISAPNP__
 #endif
 
 	scsi_remove_host(shpnt);
+	list_del(&HOSTDATA(shpnt)->host_list);
 	scsi_host_put(shpnt);
 }
 
@@ -1459,9 +1450,12 @@ static struct work_struct aha152x_tq;
  */
 static void run(void)
 {
-	int i;
-	for (i = 0; i<ARRAY_SIZE(aha152x_host); i++) {
-		is_complete(aha152x_host[i]);
+	struct aha152x_hostdata *hd;
+
+	list_for_each_entry(hd, &aha152x_host_list, host_list) {
+		struct Scsi_Host *shost = container_of((void *)hd, struct Scsi_Host, hostdata);
+		
+		is_complete(shost);
 	}
 }
 
@@ -1471,7 +1465,7 @@ static void run(void)
  */
 static irqreturn_t intr(int irqno, void *dev_id, struct pt_regs *regs)
 {
-	struct Scsi_Host *shpnt = lookup_irq(irqno);
+	struct Scsi_Host *shpnt = (struct Scsi_Host *)dev_id;
 	unsigned long flags;
 	unsigned char rev, dmacntrl0;
 
@@ -3953,16 +3947,17 @@ #if defined(__ISAPNP__)
 #endif
 	}
 
-	return registered_count>0;
+	return 1;
 }
 
 static void __exit aha152x_exit(void)
 {
-	int i;
+	struct aha152x_hostdata *hd;
 
-	for(i=0; i<ARRAY_SIZE(setup); i++) {
-		aha152x_release(aha152x_host[i]);
-		aha152x_host[i]=NULL;
+	list_for_each_entry(hd, &aha152x_host_list, host_list) {
+		struct Scsi_Host *shost = container_of((void *)hd, struct Scsi_Host, hostdata);
+		
+		aha152x_release(shost);
 	}
 }
 



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

* Re: [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19
  2006-09-14 21:51 ` Douglas Gilbert
@ 2006-09-14 22:12   ` James Bottomley
  0 siblings, 0 replies; 7+ messages in thread
From: James Bottomley @ 2006-09-14 22:12 UTC (permalink / raw)
  To: dougg; +Cc: Linus Torvalds, Andrew Morton, linux-kernel, linux-scsi

On Thu, 2006-09-14 at 17:51 -0400, Douglas Gilbert wrote:
> Is the door already closed for patches to lk 2.6.19 ?

It ain't over until the fat penguin sings.

But I know of no major outstanding issues which would justify an
emergency fix at this stage.

James



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

end of thread, other threads:[~2006-09-14 22:12 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-09-14 21:12 [GIT PATCH] (hopefully) final SCSI fixes for 2.6.19 James Bottomley
2006-09-14 21:20 ` Andrew Morton
2006-09-14 21:37   ` James Bottomley
2006-09-14 21:47     ` Andrew Morton
2006-09-14 22:04       ` James Bottomley
2006-09-14 21:51 ` Douglas Gilbert
2006-09-14 22:12   ` James Bottomley

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox