scsi: g_NCR5380: Fix release_region in error handling
When a SW-configurable card is specified but not found, the driver
releases wrong region, causing the following message in kernel log:
Trying to free nonexistent resource <0000000000000000-000000000000000f>
Fix it by assigning base earlier.
Signed-off-by: Ondrej Zary <linux@rainbow-software.org>
Fixes: a8cfbcaec0
("scsi: g_NCR5380: Stop using scsi_module.c")
Signed-off-by: Finn Thain <fthain@telegraphics.com.au>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
parent
ee32c9098f
commit
7b93ca43b7
|
@ -164,12 +164,12 @@ static int generic_NCR5380_init_one(struct scsi_host_template *tpnt,
|
|||
if (ports[i]) {
|
||||
/* At this point we have our region reserved */
|
||||
magic_configure(i, 0, magic); /* no IRQ yet */
|
||||
outb(0xc0, ports[i] + 9);
|
||||
if (inb(ports[i] + 9) != 0x80) {
|
||||
base = ports[i];
|
||||
outb(0xc0, base + 9);
|
||||
if (inb(base + 9) != 0x80) {
|
||||
ret = -ENODEV;
|
||||
goto out_release;
|
||||
}
|
||||
base = ports[i];
|
||||
port_idx = i;
|
||||
} else
|
||||
return -EINVAL;
|
||||
|
|
Loading…
Reference in New Issue