Commit 3f141653 authored by Christoph Hellwig's avatar Christoph Hellwig

[PATCH] introduce scsi_host_alloc

Rediffed version, with Mike's isp fix and taking the new
scsi_add_host users in usb in account.

Currently this is juist a new name for scsi_register, but we make
sure new-style drivers never call scsi_register/scsi_unregister
but always scsi_host_alloc/scsi_host_put in this patch so the
next patch can introduce code specific to legacy drivers in
the former.  Also cleanup scsi_register/scsi_host_alloc a bit.
parent 6d2b81d7
...@@ -698,7 +698,7 @@ cciss_scsi_detect(int ctlr) ...@@ -698,7 +698,7 @@ cciss_scsi_detect(int ctlr)
{ {
struct Scsi_Host *sh; struct Scsi_Host *sh;
sh = scsi_register(&cciss_driver_template, sizeof(struct ctlr_info *)); sh = scsi_host_alloc(&cciss_driver_template, sizeof(struct ctlr_info *));
if (sh == NULL) if (sh == NULL)
return 0; return 0;
...@@ -1357,7 +1357,7 @@ cciss_unregister_scsi(int ctlr) ...@@ -1357,7 +1357,7 @@ cciss_unregister_scsi(int ctlr)
if (sa->registered) { if (sa->registered) {
spin_unlock_irqrestore(CCISS_LOCK(ctlr), flags); spin_unlock_irqrestore(CCISS_LOCK(ctlr), flags);
scsi_remove_host(sa->scsi_host); scsi_remove_host(sa->scsi_host);
scsi_unregister(sa->scsi_host); scsi_host_put(sa->scsi_host);
spin_lock_irqsave(CCISS_LOCK(ctlr), flags); spin_lock_irqsave(CCISS_LOCK(ctlr), flags);
} }
......
...@@ -707,7 +707,7 @@ static struct sbp2scsi_host_info *sbp2_add_host(struct hpsb_host *host) ...@@ -707,7 +707,7 @@ static struct sbp2scsi_host_info *sbp2_add_host(struct hpsb_host *host)
return hi; return hi;
/* Register our host with the SCSI stack. */ /* Register our host with the SCSI stack. */
scsi_host = scsi_register (&scsi_driver_template, 0); scsi_host = scsi_host_alloc(&scsi_driver_template, 0);
if (!scsi_host) { if (!scsi_host) {
SBP2_ERR("failed to register scsi host"); SBP2_ERR("failed to register scsi host");
return NULL; return NULL;
...@@ -716,7 +716,7 @@ static struct sbp2scsi_host_info *sbp2_add_host(struct hpsb_host *host) ...@@ -716,7 +716,7 @@ static struct sbp2scsi_host_info *sbp2_add_host(struct hpsb_host *host)
hi = hpsb_create_hostinfo(&sbp2_highlevel, host, sizeof(*hi)); hi = hpsb_create_hostinfo(&sbp2_highlevel, host, sizeof(*hi));
if (!hi) { if (!hi) {
SBP2_ERR("failed to allocate hostinfo"); SBP2_ERR("failed to allocate hostinfo");
scsi_unregister(hi->scsi_host); scsi_host_put(hi->scsi_host);
} }
hpsb_set_hostinfo_key(&sbp2_highlevel, host, (unsigned long)scsi_host); hpsb_set_hostinfo_key(&sbp2_highlevel, host, (unsigned long)scsi_host);
...@@ -732,7 +732,7 @@ static struct sbp2scsi_host_info *sbp2_add_host(struct hpsb_host *host) ...@@ -732,7 +732,7 @@ static struct sbp2scsi_host_info *sbp2_add_host(struct hpsb_host *host)
* enabled (scsi-host uses classdata member of the device). */ * enabled (scsi-host uses classdata member of the device). */
if (scsi_add_host(hi->scsi_host, NULL)) { if (scsi_add_host(hi->scsi_host, NULL)) {
SBP2_ERR("failed to add scsi host"); SBP2_ERR("failed to add scsi host");
scsi_unregister(hi->scsi_host); scsi_host_put(hi->scsi_host);
hpsb_destroy_hostinfo(&sbp2_highlevel, host); hpsb_destroy_hostinfo(&sbp2_highlevel, host);
} }
...@@ -753,7 +753,7 @@ static void sbp2_remove_host(struct hpsb_host *host) ...@@ -753,7 +753,7 @@ static void sbp2_remove_host(struct hpsb_host *host)
if (hi) { if (hi) {
scsi_remove_host(hi->scsi_host); scsi_remove_host(hi->scsi_host);
scsi_unregister(hi->scsi_host); scsi_host_put(hi->scsi_host);
} }
} }
......
...@@ -293,7 +293,8 @@ NCR_700_detect(Scsi_Host_Template *tpnt, ...@@ -293,7 +293,8 @@ NCR_700_detect(Scsi_Host_Template *tpnt,
tpnt->proc_name = "53c700"; tpnt->proc_name = "53c700";
if((host = scsi_register(tpnt, 4)) == NULL) host = scsi_host_alloc(tpnt, 4);
if (!host)
return NULL; return NULL;
memset(hostdata->slots, 0, sizeof(struct NCR_700_command_slot) memset(hostdata->slots, 0, sizeof(struct NCR_700_command_slot)
* NCR_700_COMMAND_SLOTS_PER_HOST); * NCR_700_COMMAND_SLOTS_PER_HOST);
......
...@@ -223,7 +223,7 @@ NCR_D700_probe_one(struct NCR_D700_private *p, int siop, ...@@ -223,7 +223,7 @@ NCR_D700_probe_one(struct NCR_D700_private *p, int siop,
return 0; return 0;
irq_failed: irq_failed:
scsi_unregister(host); scsi_host_put(host);
NCR_700_release(host); NCR_700_release(host);
detect_failed: detect_failed:
release_region(host->base, 64); release_region(host->base, 64);
......
...@@ -2098,7 +2098,7 @@ ahd_linux_register_host(struct ahd_softc *ahd, Scsi_Host_Template *template) ...@@ -2098,7 +2098,7 @@ ahd_linux_register_host(struct ahd_softc *ahd, Scsi_Host_Template *template)
u_long target; u_long target;
template->name = ahd->description; template->name = ahd->description;
host = scsi_register(template, sizeof(struct ahd_softc *)); host = scsi_host_alloc(template, sizeof(struct ahd_softc *));
if (host == NULL) if (host == NULL)
return (ENOMEM); return (ENOMEM);
...@@ -2308,7 +2308,7 @@ ahd_platform_free(struct ahd_softc *ahd) ...@@ -2308,7 +2308,7 @@ ahd_platform_free(struct ahd_softc *ahd)
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)
scsi_remove_host(ahd->platform_data->host); scsi_remove_host(ahd->platform_data->host);
#endif #endif
scsi_unregister(ahd->platform_data->host); scsi_host_put(ahd->platform_data->host);
} }
/* destroy all of the device and target objects */ /* destroy all of the device and target objects */
......
...@@ -1725,7 +1725,7 @@ ahc_linux_register_host(struct ahc_softc *ahc, Scsi_Host_Template *template) ...@@ -1725,7 +1725,7 @@ ahc_linux_register_host(struct ahc_softc *ahc, Scsi_Host_Template *template)
u_int targ_offset; u_int targ_offset;
template->name = ahc->description; template->name = ahc->description;
host = scsi_register(template, sizeof(struct ahc_softc *)); host = scsi_host_alloc(template, sizeof(struct ahc_softc *));
if (host == NULL) if (host == NULL)
return (ENOMEM); return (ENOMEM);
...@@ -1978,7 +1978,7 @@ ahc_platform_free(struct ahc_softc *ahc) ...@@ -1978,7 +1978,7 @@ ahc_platform_free(struct ahc_softc *ahc)
#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0) #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,5,0)
scsi_remove_host(ahc->platform_data->host); scsi_remove_host(ahc->platform_data->host);
#endif #endif
scsi_unregister(ahc->platform_data->host); scsi_host_put(ahc->platform_data->host);
} }
/* destroy all of the device and target objects */ /* destroy all of the device and target objects */
......
...@@ -2993,7 +2993,7 @@ acornscsi_probe(struct expansion_card *ec, const struct ecard_id *id) ...@@ -2993,7 +2993,7 @@ acornscsi_probe(struct expansion_card *ec, const struct ecard_id *id)
AS_Host *ashost; AS_Host *ashost;
int ret = -ENOMEM; int ret = -ENOMEM;
host = scsi_register(&acornscsi_template, sizeof(AS_Host)); host = scsi_host_alloc(&acornscsi_template, sizeof(AS_Host));
if (!host) if (!host)
goto out; goto out;
...@@ -3060,7 +3060,7 @@ acornscsi_probe(struct expansion_card *ec, const struct ecard_id *id) ...@@ -3060,7 +3060,7 @@ acornscsi_probe(struct expansion_card *ec, const struct ecard_id *id)
err_2: err_2:
release_region(host->io_port + 0x800, 2); release_region(host->io_port + 0x800, 2);
err_1: err_1:
scsi_unregister(host); scsi_host_put(host);
out: out:
return ret; return ret;
} }
...@@ -3089,6 +3089,7 @@ static void __devexit acornscsi_remove(struct expansion_card *ec) ...@@ -3089,6 +3089,7 @@ static void __devexit acornscsi_remove(struct expansion_card *ec)
msgqueue_free(&ashost->scsi.msgs); msgqueue_free(&ashost->scsi.msgs);
queue_free(&ashost->queues.disconnected); queue_free(&ashost->queues.disconnected);
queue_free(&ashost->queues.issue); queue_free(&ashost->queues.issue);
scsi_host_put(host);
} }
static const struct ecard_id acornscsi_cids[] = { static const struct ecard_id acornscsi_cids[] = {
......
...@@ -262,7 +262,7 @@ cumanascsi1_probe(struct expansion_card *ec, const struct ecard_id *id) ...@@ -262,7 +262,7 @@ cumanascsi1_probe(struct expansion_card *ec, const struct ecard_id *id)
struct Scsi_Host *host; struct Scsi_Host *host;
int ret = -ENOMEM; int ret = -ENOMEM;
host = scsi_register(&cumanascsi_template, sizeof(struct NCR5380_hostdata)); host = scsi_host_alloc(&cumanascsi_template, sizeof(struct NCR5380_hostdata));
if (!host) if (!host)
goto out; goto out;
...@@ -304,7 +304,7 @@ cumanascsi1_probe(struct expansion_card *ec, const struct ecard_id *id) ...@@ -304,7 +304,7 @@ cumanascsi1_probe(struct expansion_card *ec, const struct ecard_id *id)
out_release: out_release:
release_region(host->io_port, host->n_io_port); release_region(host->io_port, host->n_io_port);
out_free: out_free:
scsi_unregister(host); scsi_host_put(host);
out: out:
return ret; return ret;
} }
...@@ -318,7 +318,7 @@ static void __devexit cumanascsi1_remove(struct expansion_card *ec) ...@@ -318,7 +318,7 @@ static void __devexit cumanascsi1_remove(struct expansion_card *ec)
scsi_remove_host(host); scsi_remove_host(host);
free_irq(host->irq, host); free_irq(host->irq, host);
release_region(host->io_port, host->n_io_port); release_region(host->io_port, host->n_io_port);
scsi_unregister(host); scsi_host_put(host);
} }
static const struct ecard_id cumanascsi1_cids[] = { static const struct ecard_id cumanascsi1_cids[] = {
......
...@@ -177,7 +177,7 @@ static struct Scsi_Host *host; ...@@ -177,7 +177,7 @@ static struct Scsi_Host *host;
static int __init ecoscsi_init(void) static int __init ecoscsi_init(void)
{ {
host = scsi_register(tpnt, sizeof(struct NCR5380_hostdata)); host = scsi_host_alloc(tpnt, sizeof(struct NCR5380_hostdata));
if (!host) if (!host)
return 0; return 0;
...@@ -211,7 +211,7 @@ static int __init ecoscsi_init(void) ...@@ -211,7 +211,7 @@ static int __init ecoscsi_init(void)
release_reg: release_reg:
release_region(host->io_port, host->n_io_port); release_region(host->io_port, host->n_io_port);
unregister_scsi: unregister_scsi:
scsi_unregister(host); scsi_host_put(host);
return -ENODEV; return -ENODEV;
} }
...@@ -224,7 +224,7 @@ static void __exit ecoscsi_exit(void) ...@@ -224,7 +224,7 @@ static void __exit ecoscsi_exit(void)
if (shpnt->io_port) if (shpnt->io_port)
release_region(shpnt->io_port, shpnt->n_io_port); release_region(shpnt->io_port, shpnt->n_io_port);
scsi_unregister(host); scsi_host_put(host);
return 0; return 0;
} }
......
...@@ -2942,6 +2942,7 @@ void fas216_remove(struct Scsi_Host *host) ...@@ -2942,6 +2942,7 @@ void fas216_remove(struct Scsi_Host *host)
scsi_remove_host(host); scsi_remove_host(host);
fas216_writeb(info, REG_CMD, CMD_RESETCHIP); fas216_writeb(info, REG_CMD, CMD_RESETCHIP);
scsi_host_put(host);
} }
/** /**
......
...@@ -135,7 +135,7 @@ oakscsi_probe(struct expansion_card *ec, const struct ecard_id *id) ...@@ -135,7 +135,7 @@ oakscsi_probe(struct expansion_card *ec, const struct ecard_id *id)
struct Scsi_Host *host; struct Scsi_Host *host;
int ret = -ENOMEM; int ret = -ENOMEM;
host = scsi_register(&oakscsi_template, sizeof(struct NCR5380_hostdata)); host = scsi_host_alloc(&oakscsi_template, sizeof(struct NCR5380_hostdata));
if (!host) if (!host)
goto out; goto out;
...@@ -163,7 +163,7 @@ oakscsi_probe(struct expansion_card *ec, const struct ecard_id *id) ...@@ -163,7 +163,7 @@ oakscsi_probe(struct expansion_card *ec, const struct ecard_id *id)
release_region(host->io_port, host->n_io_port); release_region(host->io_port, host->n_io_port);
unreg: unreg:
scsi_unregister(host); scsi_host_put(host);
out: out:
return ret; return ret;
} }
...@@ -176,7 +176,7 @@ static void __devexit oakscsi_remove(struct expansion_card *ec) ...@@ -176,7 +176,7 @@ static void __devexit oakscsi_remove(struct expansion_card *ec)
scsi_remove_host(host); scsi_remove_host(host);
release_region(host->io_port, host->n_io_port); release_region(host->io_port, host->n_io_port);
scsi_unregister(host); scsi_host_put(host);
} }
static const struct ecard_id oakscsi_cids[] = { static const struct ecard_id oakscsi_cids[] = {
......
...@@ -134,15 +134,6 @@ int scsi_add_host(struct Scsi_Host *shost, struct device *dev) ...@@ -134,15 +134,6 @@ int scsi_add_host(struct Scsi_Host *shost, struct device *dev)
return error; return error;
} }
/**
* scsi_unregister - unregister a scsi host
* @shost: scsi host to be unregistered
**/
void scsi_unregister(struct Scsi_Host *shost)
{
scsi_host_put(shost);
}
/** /**
* scsi_free_sdev - free a scsi hosts resources * scsi_free_sdev - free a scsi hosts resources
* @shost: scsi host to free * @shost: scsi host to free
...@@ -172,60 +163,59 @@ void scsi_free_shost(struct Scsi_Host *shost) ...@@ -172,60 +163,59 @@ void scsi_free_shost(struct Scsi_Host *shost)
} }
/** /**
* scsi_register - register a scsi host adapter instance. * scsi_host_alloc - register a scsi host adapter instance.
* @shost_tp: pointer to scsi host template * @sht: pointer to scsi host template
* @xtr_bytes: extra bytes to allocate for driver * @privsize: extra bytes to allocate for driver
* *
* Note: * Note:
* We call this when we come across a new host adapter. We only do * Allocate a new Scsi_Host and perform basic initialization.
* this once we are 100% sure that we want to use this host adapter - * The host is not published to the scsi midlayer until scsi_add_host
* it is a pain to reverse this, so we try to avoid it * is called.
* *
* Return value: * Return value:
* Pointer to a new Scsi_Host * Pointer to a new Scsi_Host
**/ **/
extern int blk_nohighio; struct Scsi_Host *scsi_host_alloc(Scsi_Host_Template *sht, int privsize)
struct Scsi_Host * scsi_register(Scsi_Host_Template *shost_tp, int xtr_bytes)
{ {
struct Scsi_Host *shost, *shost_scr; extern int blk_nohighio;
int gfp_mask, rval; struct Scsi_Host *shost;
DECLARE_COMPLETION(sem); int gfp_mask = GFP_KERNEL, rval;
DECLARE_COMPLETION(complete);
if (sht->unchecked_isa_dma && privsize)
gfp_mask |= __GFP_DMA;
/* Check to see if this host has any error handling facilities */ /* Check to see if this host has any error handling facilities */
if(shost_tp->eh_strategy_handler == NULL && if (!sht->eh_strategy_handler && !sht->eh_abort_handler &&
shost_tp->eh_abort_handler == NULL && !sht->eh_device_reset_handler && !sht->eh_bus_reset_handler &&
shost_tp->eh_device_reset_handler == NULL && !sht->eh_host_reset_handler) {
shost_tp->eh_bus_reset_handler == NULL && printk(KERN_ERR "ERROR: SCSI host `%s' has no error handling\n"
shost_tp->eh_host_reset_handler == NULL) { "ERROR: This is not a safe way to run your "
printk(KERN_ERR "ERROR: SCSI host `%s' has no error handling\nERROR: This is not a safe way to run your SCSI host\nERROR: The error handling must be added to this driver\n", shost_tp->proc_name); "SCSI host\n"
"ERROR: The error handling must be added to "
"this driver\n", sht->proc_name);
dump_stack(); dump_stack();
} }
if(shost_tp->shost_attrs == NULL)
/* if its not set in the template, use the default */ /* if its not set in the template, use the default */
shost_tp->shost_attrs = scsi_sysfs_shost_attrs; if (!sht->shost_attrs)
if(shost_tp->sdev_attrs == NULL) sht->shost_attrs = scsi_sysfs_shost_attrs;
shost_tp->sdev_attrs = scsi_sysfs_sdev_attrs; if (!sht->sdev_attrs)
gfp_mask = GFP_KERNEL; sht->sdev_attrs = scsi_sysfs_sdev_attrs;
if (shost_tp->unchecked_isa_dma && xtr_bytes)
gfp_mask |= __GFP_DMA;
shost = kmalloc(sizeof(struct Scsi_Host) + xtr_bytes, gfp_mask); shost = kmalloc(sizeof(struct Scsi_Host) + privsize, gfp_mask);
if (!shost) { if (!shost)
printk(KERN_ERR "%s: out of memory.\n", __FUNCTION__);
return NULL; return NULL;
} memset(shost, 0, sizeof(struct Scsi_Host) + privsize);
memset(shost, 0, sizeof(struct Scsi_Host) + xtr_bytes);
shost->host_no = scsi_host_next_hn++; /* XXX(hch): still racy */
spin_lock_init(&shost->default_lock); spin_lock_init(&shost->default_lock);
scsi_assign_lock(shost, &shost->default_lock); scsi_assign_lock(shost, &shost->default_lock);
INIT_LIST_HEAD(&shost->my_devices); INIT_LIST_HEAD(&shost->my_devices);
INIT_LIST_HEAD(&shost->eh_cmd_q); INIT_LIST_HEAD(&shost->eh_cmd_q);
INIT_LIST_HEAD(&shost->starved_list); INIT_LIST_HEAD(&shost->starved_list);
init_waitqueue_head(&shost->host_wait); init_waitqueue_head(&shost->host_wait);
shost->host_no = scsi_host_next_hn++; /* XXX(hch): still racy */
shost->dma_channel = 0xff; shost->dma_channel = 0xff;
/* These three are default values which can be overridden */ /* These three are default values which can be overridden */
...@@ -240,53 +230,33 @@ struct Scsi_Host * scsi_register(Scsi_Host_Template *shost_tp, int xtr_bytes) ...@@ -240,53 +230,33 @@ struct Scsi_Host * scsi_register(Scsi_Host_Template *shost_tp, int xtr_bytes)
* they actually do something sensible with such commands. * they actually do something sensible with such commands.
*/ */
shost->max_cmd_len = 12; shost->max_cmd_len = 12;
shost->hostt = shost_tp; shost->hostt = sht;
shost->host_blocked = 0; shost->this_id = sht->this_id;
shost->host_self_blocked = FALSE; shost->can_queue = sht->can_queue;
shost->max_host_blocked = shost_tp->max_host_blocked ? shost_tp->max_host_blocked : SCSI_DEFAULT_HOST_BLOCKED; shost->sg_tablesize = sht->sg_tablesize;
shost->cmd_per_lun = sht->cmd_per_lun;
shost->unchecked_isa_dma = sht->unchecked_isa_dma;
shost->use_clustering = sht->use_clustering;
shost->use_blk_tcq = sht->use_blk_tcq;
if (!blk_nohighio)
shost->highmem_io = sht->highmem_io;
#ifdef DEBUG if (!sht->max_host_blocked)
printk("%s: %x %x: %d\n", __FUNCTION_ (int)shost, shost->max_host_blocked = sht->max_host_blocked;
(int)shost->hostt, xtr_bytes); else
#endif shost->max_host_blocked = SCSI_DEFAULT_HOST_BLOCKED;
/* /*
* The next six are the default values which can be overridden if * If the driver imposes no hard sector transfer limit, start at
* need be * machine infinity initially.
*/
shost->this_id = shost_tp->this_id;
shost->can_queue = shost_tp->can_queue;
shost->sg_tablesize = shost_tp->sg_tablesize;
shost->cmd_per_lun = shost_tp->cmd_per_lun;
shost->unchecked_isa_dma = shost_tp->unchecked_isa_dma;
shost->use_clustering = shost_tp->use_clustering;
if (!blk_nohighio)
shost->highmem_io = shost_tp->highmem_io;
if (!shost_tp->max_sectors) {
/*
* Driver imposes no hard sector transfer limit.
* start at machine infinity initially.
*/ */
if (sht->max_sectors)
shost->max_sectors = sht->max_sectors;
else
shost->max_sectors = SCSI_DEFAULT_MAX_SECTORS; shost->max_sectors = SCSI_DEFAULT_MAX_SECTORS;
} else
shost->max_sectors = shost_tp->max_sectors;
shost->use_blk_tcq = shost_tp->use_blk_tcq;
spin_lock(&scsi_host_list_lock); spin_lock(&scsi_host_list_lock);
/*
* FIXME When device naming is complete remove this step that
* orders the scsi_host_list by host number and just do a
* list_add_tail.
*/
list_for_each_entry(shost_scr, &scsi_host_list, sh_list) {
if (shost->host_no < shost_scr->host_no) {
__list_add(&shost->sh_list, shost_scr->sh_list.prev,
&shost_scr->sh_list);
goto found;
}
}
list_add_tail(&shost->sh_list, &scsi_host_list); list_add_tail(&shost->sh_list, &scsi_host_list);
found:
spin_unlock(&scsi_host_list_lock); spin_unlock(&scsi_host_list_lock);
rval = scsi_setup_command_freelist(shost); rval = scsi_setup_command_freelist(shost);
...@@ -295,18 +265,14 @@ struct Scsi_Host * scsi_register(Scsi_Host_Template *shost_tp, int xtr_bytes) ...@@ -295,18 +265,14 @@ struct Scsi_Host * scsi_register(Scsi_Host_Template *shost_tp, int xtr_bytes)
scsi_sysfs_init_host(shost); scsi_sysfs_init_host(shost);
shost->eh_notify = &sem; shost->eh_notify = &complete;
kernel_thread((int (*)(void *)) scsi_error_handler, (void *) shost, 0); /* XXX(hch): handle error return */
/* kernel_thread((int (*)(void *))scsi_error_handler, shost, 0);
* Now wait for the kernel error thread to initialize itself wait_for_completion(&complete);
* as it might be needed when we scan the bus.
*/
wait_for_completion(&sem);
shost->eh_notify = NULL; shost->eh_notify = NULL;
shost->hostt->present++; shost->hostt->present++;
return shost; return shost;
fail:
fail:
spin_lock(&scsi_host_list_lock); spin_lock(&scsi_host_list_lock);
list_del(&shost->sh_list); list_del(&shost->sh_list);
spin_unlock(&scsi_host_list_lock); spin_unlock(&scsi_host_list_lock);
...@@ -314,6 +280,16 @@ struct Scsi_Host * scsi_register(Scsi_Host_Template *shost_tp, int xtr_bytes) ...@@ -314,6 +280,16 @@ struct Scsi_Host * scsi_register(Scsi_Host_Template *shost_tp, int xtr_bytes)
return NULL; return NULL;
} }
struct Scsi_Host *scsi_register(Scsi_Host_Template *sht, int privsize)
{
return scsi_host_alloc(sht, privsize);
}
void scsi_unregister(struct Scsi_Host *shost)
{
scsi_host_put(shost);
}
/** /**
* scsi_register_host - register a low level host driver * scsi_register_host - register a low level host driver
* @shost_tp: pointer to a scsi host driver template * @shost_tp: pointer to a scsi host driver template
......
...@@ -560,23 +560,20 @@ extern int scsi_register_interface(struct class_interface *); ...@@ -560,23 +560,20 @@ extern int scsi_register_interface(struct class_interface *);
#define scsi_unregister_interface(intf) \ #define scsi_unregister_interface(intf) \
class_interface_unregister(intf) class_interface_unregister(intf)
/*
* HBA allocation/freeing.
*/
extern struct Scsi_Host * scsi_register(Scsi_Host_Template *, int);
extern void scsi_unregister(struct Scsi_Host *);
/* extern struct Scsi_Host *scsi_host_alloc(Scsi_Host_Template *, int);
* HBA registration/unregistration.
*/
extern int scsi_add_host(struct Scsi_Host *, struct device *); extern int scsi_add_host(struct Scsi_Host *, struct device *);
extern int scsi_remove_host(struct Scsi_Host *); extern int scsi_remove_host(struct Scsi_Host *);
extern void scsi_host_get(struct Scsi_Host *);
extern void scsi_host_put(struct Scsi_Host *t);
extern struct Scsi_Host *scsi_host_lookup(unsigned short);
/* /* legacy interfaces */
* Legacy HBA template registration/unregistration.
*/
extern int scsi_register_host(Scsi_Host_Template *); extern int scsi_register_host(Scsi_Host_Template *);
extern int scsi_unregister_host(Scsi_Host_Template *); extern int scsi_unregister_host(Scsi_Host_Template *);
extern struct Scsi_Host *scsi_register(Scsi_Host_Template *, int);
extern void scsi_unregister(struct Scsi_Host *);
/** /**
* scsi_find_device - find a device given the host * scsi_find_device - find a device given the host
......
...@@ -612,7 +612,7 @@ static int idescsi_cleanup (ide_drive_t *drive) ...@@ -612,7 +612,7 @@ static int idescsi_cleanup (ide_drive_t *drive)
drive->disk->fops = ide_fops; drive->disk->fops = ide_fops;
scsi_remove_host(scsihost); scsi_remove_host(scsihost);
scsi_unregister(scsihost); scsi_host_put(scsihost);
return 0; return 0;
} }
...@@ -964,7 +964,7 @@ static int idescsi_attach(ide_drive_t *drive) ...@@ -964,7 +964,7 @@ static int idescsi_attach(ide_drive_t *drive)
if (!strstr("ide-scsi", drive->driver_req) || if (!strstr("ide-scsi", drive->driver_req) ||
!drive->present || !drive->present ||
drive->media == ide_disk || drive->media == ide_disk ||
!(host = scsi_register(&idescsi_template,sizeof(idescsi_scsi_t)))) !(host = scsi_host_alloc(&idescsi_template,sizeof(idescsi_scsi_t))))
return 1; return 1;
host->max_id = 1; host->max_id = 1;
...@@ -984,7 +984,7 @@ static int idescsi_attach(ide_drive_t *drive) ...@@ -984,7 +984,7 @@ static int idescsi_attach(ide_drive_t *drive)
ide_unregister_subdriver(drive); ide_unregister_subdriver(drive);
} }
scsi_unregister(host); scsi_host_put(host);
return err; return err;
} }
......
...@@ -186,7 +186,7 @@ lasi700_driver_callback(struct parisc_device *dev) ...@@ -186,7 +186,7 @@ lasi700_driver_callback(struct parisc_device *dev)
if(request_irq(dev->irq, NCR_700_intr, SA_SHIRQ, driver_name, host)) { if(request_irq(dev->irq, NCR_700_intr, SA_SHIRQ, driver_name, host)) {
printk(KERN_ERR "%s: irq problem, detaching\n", printk(KERN_ERR "%s: irq problem, detaching\n",
driver_name); driver_name);
scsi_unregister(host); scsi_host_put(host);
NCR_700_release(host); NCR_700_release(host);
return 1; return 1;
} }
......
...@@ -1621,7 +1621,7 @@ static int nsp32_detect(struct pci_dev *pdev) ...@@ -1621,7 +1621,7 @@ static int nsp32_detect(struct pci_dev *pdev)
/* /*
* register this HBA as SCSI device * register this HBA as SCSI device
*/ */
host = scsi_register(&nsp32_template, sizeof(nsp32_hw_data)); host = scsi_host_alloc(&nsp32_template, sizeof(nsp32_hw_data));
if (host == NULL) { if (host == NULL) {
nsp32_msg (KERN_ERR, "failed to scsi register"); nsp32_msg (KERN_ERR, "failed to scsi register");
goto err; goto err;
...@@ -1840,7 +1840,7 @@ static int nsp32_detect(struct pci_dev *pdev) ...@@ -1840,7 +1840,7 @@ static int nsp32_detect(struct pci_dev *pdev)
kfree(data->lunt_list); kfree(data->lunt_list);
scsi_unregister: scsi_unregister:
scsi_unregister(host); scsi_host_put(host);
err: err:
return 1; return 1;
......
...@@ -1222,7 +1222,7 @@ static struct Scsi_Host *__nsp_detect(Scsi_Host_Template *sht) ...@@ -1222,7 +1222,7 @@ static struct Scsi_Host *__nsp_detect(Scsi_Host_Template *sht)
DEBUG(0, "%s: this_id=%d\n", __FUNCTION__, sht->this_id); DEBUG(0, "%s: this_id=%d\n", __FUNCTION__, sht->this_id);
request_region(data->BaseAddress, data->NumAddress, "nsp_cs"); request_region(data->BaseAddress, data->NumAddress, "nsp_cs");
host = scsi_register(sht, 0); host = scsi_host_alloc(sht, 0);
if(host == NULL) if(host == NULL)
return NULL; return NULL;
......
...@@ -1681,7 +1681,7 @@ static int sdebug_driver_probe(struct device * dev) ...@@ -1681,7 +1681,7 @@ static int sdebug_driver_probe(struct device * dev)
sdbg_host = to_sdebug_host(dev); sdbg_host = to_sdebug_host(dev);
hpnt = scsi_register(&sdebug_driver_template, sizeof(sdbg_host)); hpnt = scsi_host_alloc(&sdebug_driver_template, sizeof(sdbg_host));
if (NULL == hpnt) { if (NULL == hpnt) {
printk(KERN_ERR "%s: scsi_register failed\n", __FUNCTION__); printk(KERN_ERR "%s: scsi_register failed\n", __FUNCTION__);
error = -ENODEV; error = -ENODEV;
...@@ -1700,7 +1700,7 @@ static int sdebug_driver_probe(struct device * dev) ...@@ -1700,7 +1700,7 @@ static int sdebug_driver_probe(struct device * dev)
if (error) { if (error) {
printk(KERN_ERR "%s: scsi_add_host failed\n", __FUNCTION__); printk(KERN_ERR "%s: scsi_add_host failed\n", __FUNCTION__);
error = -ENODEV; error = -ENODEV;
scsi_unregister(hpnt); scsi_host_put(hpnt);
} }
...@@ -1726,8 +1726,6 @@ static int sdebug_driver_remove(struct device * dev) ...@@ -1726,8 +1726,6 @@ static int sdebug_driver_remove(struct device * dev)
return -EBUSY; return -EBUSY;
} }
scsi_unregister(sdbg_host->shost);
list_for_each_safe(lh, lh_sf, &sdbg_host->dev_info_list) { list_for_each_safe(lh, lh_sf, &sdbg_host->dev_info_list) {
sdbg_devinfo = list_entry(lh, struct sdebug_dev_info, sdbg_devinfo = list_entry(lh, struct sdebug_dev_info,
dev_list); dev_list);
...@@ -1735,5 +1733,6 @@ static int sdebug_driver_remove(struct device * dev) ...@@ -1735,5 +1733,6 @@ static int sdebug_driver_remove(struct device * dev)
kfree(sdbg_devinfo); kfree(sdbg_devinfo);
} }
scsi_host_put(sdbg_host->shost);
return 0; return 0;
} }
...@@ -55,9 +55,6 @@ struct scsi_target { ...@@ -55,9 +55,6 @@ struct scsi_target {
/* hosts.c */ /* hosts.c */
extern void scsi_host_busy_inc(struct Scsi_Host *, Scsi_Device *); extern void scsi_host_busy_inc(struct Scsi_Host *, Scsi_Device *);
extern void scsi_host_busy_dec_and_test(struct Scsi_Host *, Scsi_Device *); extern void scsi_host_busy_dec_and_test(struct Scsi_Host *, Scsi_Device *);
extern struct Scsi_Host *scsi_host_lookup(unsigned short);
extern void scsi_host_put(struct Scsi_Host *);
extern void scsi_host_init(void);
/* scsi.c */ /* scsi.c */
extern int scsi_dispatch_cmd(struct scsi_cmnd *cmd); extern int scsi_dispatch_cmd(struct scsi_cmnd *cmd);
...@@ -107,12 +104,11 @@ extern void scsi_exit_procfs(void); ...@@ -107,12 +104,11 @@ extern void scsi_exit_procfs(void);
#endif /* CONFIG_PROC_FS */ #endif /* CONFIG_PROC_FS */
/* scsi_scan.c */ /* scsi_scan.c */
extern void scsi_scan_host(struct Scsi_Host *shost); extern void scsi_scan_host(struct Scsi_Host *);
extern void scsi_forget_host(struct Scsi_Host *shost); extern void scsi_forget_host(struct Scsi_Host *);
extern void scsi_free_sdev(struct scsi_device *); extern void scsi_free_sdev(struct scsi_device *);
extern void scsi_free_shost(struct Scsi_Host *); extern void scsi_free_shost(struct Scsi_Host *);
extern void scsi_host_get(struct Scsi_Host *); extern void scsi_rescan_device(struct device *);
extern void scsi_rescan_device(struct device *dev);
/* scsi_sysfs.c */ /* scsi_sysfs.c */
extern int scsi_device_register(struct scsi_device *); extern int scsi_device_register(struct scsi_device *);
......
...@@ -33,8 +33,12 @@ EXPORT_SYMBOL(scsi_register_driver); ...@@ -33,8 +33,12 @@ EXPORT_SYMBOL(scsi_register_driver);
EXPORT_SYMBOL(scsi_register_interface); EXPORT_SYMBOL(scsi_register_interface);
EXPORT_SYMBOL(scsi_register_host); EXPORT_SYMBOL(scsi_register_host);
EXPORT_SYMBOL(scsi_unregister_host); EXPORT_SYMBOL(scsi_unregister_host);
EXPORT_SYMBOL(scsi_host_alloc);
EXPORT_SYMBOL(scsi_add_host); EXPORT_SYMBOL(scsi_add_host);
EXPORT_SYMBOL(scsi_remove_host); EXPORT_SYMBOL(scsi_remove_host);
EXPORT_SYMBOL(scsi_host_get);
EXPORT_SYMBOL(scsi_host_put);
EXPORT_SYMBOL(scsi_host_lookup);
EXPORT_SYMBOL(scsi_register); EXPORT_SYMBOL(scsi_register);
EXPORT_SYMBOL(scsi_unregister); EXPORT_SYMBOL(scsi_unregister);
EXPORT_SYMBOL(scsicam_bios_param); EXPORT_SYMBOL(scsicam_bios_param);
......
...@@ -143,7 +143,7 @@ sim710_probe_common(struct device *dev, unsigned long base_addr, ...@@ -143,7 +143,7 @@ sim710_probe_common(struct device *dev, unsigned long base_addr,
return 0; return 0;
out_unregister: out_unregister:
scsi_unregister(host); scsi_host_put(host);
out_release: out_release:
release_region(host->base, 64); release_region(host->base, 64);
out_free: out_free:
......
...@@ -874,7 +874,7 @@ static int storage_probe(struct usb_interface *intf, ...@@ -874,7 +874,7 @@ static int storage_probe(struct usb_interface *intf,
up(&(us->dev_semaphore)); up(&(us->dev_semaphore));
/* now register */ /* now register */
us->host = scsi_register(&usb_stor_host_template, sizeof(us)); us->host = scsi_host_alloc(&usb_stor_host_template, sizeof(us));
if (!us->host) { if (!us->host) {
printk(KERN_WARNING USB_STORAGE printk(KERN_WARNING USB_STORAGE
"Unable to register the scsi host\n"); "Unable to register the scsi host\n");
...@@ -965,7 +965,7 @@ static void storage_disconnect(struct usb_interface *intf) ...@@ -965,7 +965,7 @@ static void storage_disconnect(struct usb_interface *intf)
}; };
/* finish SCSI host removal sequence */ /* finish SCSI host removal sequence */
scsi_unregister(us->host); scsi_host_put(us->host);
/* Kill the control threads /* Kill the control threads
* *
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment