提交 dffe807c 编写于 作者: M Matthew Wilcox 提交者: James Bottomley

[SCSI] ncr53c8xx: Call scsi_host_put in release

Since ncr53c8xx_attach() calls scsi_host_put(), make ncr53c8xx_release()
call scsi_host_put() too, for symmetry.  Both callers already expect
it to put the host for them, so that works out nicely.  While the zalon
driver does 'use' the host pointer afterwards, it only compares it for
equality and doesn't dereference it, so that's safe.

While I'm at it, get rid of pointless checks for NULL, use shost_priv()
and change ncr53c8xx_release to return void.
Signed-off-by: NMatthew Wilcox <matthew@wil.cx>
Signed-off-by: NJames Bottomley <James.Bottomley@SteelEye.com>
上级 6fdea8db
...@@ -8528,18 +8528,15 @@ struct Scsi_Host * __init ncr_attach(struct scsi_host_template *tpnt, ...@@ -8528,18 +8528,15 @@ struct Scsi_Host * __init ncr_attach(struct scsi_host_template *tpnt,
} }
int ncr53c8xx_release(struct Scsi_Host *host) void ncr53c8xx_release(struct Scsi_Host *host)
{ {
struct host_data *host_data; struct host_data *host_data = shost_priv(host);
#ifdef DEBUG_NCR53C8XX #ifdef DEBUG_NCR53C8XX
printk("ncr53c8xx: release\n"); printk("ncr53c8xx: release\n");
#endif #endif
if (!host) if (host_data->ncb)
return 1;
host_data = (struct host_data *)host->hostdata;
if (host_data && host_data->ncb)
ncr_detach(host_data->ncb); ncr_detach(host_data->ncb);
return 1; scsi_host_put(host);
} }
static void ncr53c8xx_set_period(struct scsi_target *starget, int period) static void ncr53c8xx_set_period(struct scsi_target *starget, int period)
......
...@@ -1321,7 +1321,7 @@ struct ncr_device { ...@@ -1321,7 +1321,7 @@ struct ncr_device {
}; };
extern struct Scsi_Host *ncr_attach(struct scsi_host_template *tpnt, int unit, struct ncr_device *device); extern struct Scsi_Host *ncr_attach(struct scsi_host_template *tpnt, int unit, struct ncr_device *device);
extern int ncr53c8xx_release(struct Scsi_Host *host); extern void ncr53c8xx_release(struct Scsi_Host *host);
irqreturn_t ncr53c8xx_intr(int irq, void *dev_id); irqreturn_t ncr53c8xx_intr(int irq, void *dev_id);
extern int ncr53c8xx_init(void); extern int ncr53c8xx_init(void);
extern void ncr53c8xx_exit(void); extern void ncr53c8xx_exit(void);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册