This patch should handle the case when scsi_add_host() fails. Signed-Off-By: Daniel Walker <[EMAIL PROTECTED]>
Index: linux-2.6.13/drivers/scsi/aic7xxx/aic7xxx_osm.c =================================================================== --- linux-2.6.13.orig/drivers/scsi/aic7xxx/aic7xxx_osm.c 2005-08-28 23:41:01.000000000 +0000 +++ linux-2.6.13/drivers/scsi/aic7xxx/aic7xxx_osm.c 2005-08-31 18:45:20.000000000 +0000 @@ -996,6 +996,7 @@ ahc_linux_register_host(struct ahc_softc struct Scsi_Host *host; char *new_name; u_long s; + int error = 0; template->name = ahc->description; host = scsi_host_alloc(template, sizeof(struct ahc_softc *)); @@ -1029,8 +1030,16 @@ ahc_linux_register_host(struct ahc_softc host->transportt = ahc_linux_transport_template; - scsi_add_host(host, (ahc->dev_softc ? &ahc->dev_softc->dev : NULL)); /* XXX handle failure */ - scsi_scan_host(host); + error = scsi_add_host(host, (ahc->dev_softc ? &ahc->dev_softc->dev : NULL)); + if (error) { + /* + * Discard host variable on error. + */ + scsi_host_put(host); + return (error); + } + scsi_scan_host(host); + return (0); } - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/