Commit 9c770108 authored by Dave Young's avatar Dave Young Committed by Greg Kroah-Hartman

scsi: use class iteration api

Convert to use the class iteration api.
Signed-off-by: default avatarDave Young <hidave.darkstar@gmail.com>
Cc: James Bottomley <James.Bottomley@hansenpartnership.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 71da8905
...@@ -429,6 +429,15 @@ void scsi_unregister(struct Scsi_Host *shost) ...@@ -429,6 +429,15 @@ void scsi_unregister(struct Scsi_Host *shost)
} }
EXPORT_SYMBOL(scsi_unregister); EXPORT_SYMBOL(scsi_unregister);
static int __scsi_host_match(struct class_device *cdev, void *data)
{
struct Scsi_Host *p;
unsigned short *hostnum = (unsigned short *)data;
p = class_to_shost(cdev);
return p->host_no == *hostnum;
}
/** /**
* scsi_host_lookup - get a reference to a Scsi_Host by host no * scsi_host_lookup - get a reference to a Scsi_Host by host no
* *
...@@ -439,19 +448,12 @@ EXPORT_SYMBOL(scsi_unregister); ...@@ -439,19 +448,12 @@ EXPORT_SYMBOL(scsi_unregister);
**/ **/
struct Scsi_Host *scsi_host_lookup(unsigned short hostnum) struct Scsi_Host *scsi_host_lookup(unsigned short hostnum)
{ {
struct class *class = &shost_class;
struct class_device *cdev; struct class_device *cdev;
struct Scsi_Host *shost = ERR_PTR(-ENXIO), *p; struct Scsi_Host *shost = ERR_PTR(-ENXIO);
down(&class->sem); cdev = class_find_child(&shost_class, &hostnum, __scsi_host_match);
list_for_each_entry(cdev, &class->children, node) { if (cdev)
p = class_to_shost(cdev); shost = scsi_host_get(class_to_shost(cdev));
if (p->host_no == hostnum) {
shost = scsi_host_get(p);
break;
}
}
up(&class->sem);
return shost; return shost;
} }
......
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