Commit 5ed2c832 authored by Dave Young's avatar Dave Young Committed by Greg Kroah-Hartman

spi: use class iteration api

Convert to use the class iteration api.
Signed-off-by: default avatarDave Young <hidave.darkstar@gmail.com>
Acked-by: default avatarDavid Brownell <david-b@pacbell.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 9c770108
...@@ -485,6 +485,15 @@ void spi_unregister_master(struct spi_master *master) ...@@ -485,6 +485,15 @@ void spi_unregister_master(struct spi_master *master)
} }
EXPORT_SYMBOL_GPL(spi_unregister_master); EXPORT_SYMBOL_GPL(spi_unregister_master);
static int __spi_master_match(struct device *dev, void *data)
{
struct spi_master *m;
u16 *bus_num = data;
m = container_of(dev, struct spi_master, dev);
return m->bus_num == *bus_num;
}
/** /**
* spi_busnum_to_master - look up master associated with bus_num * spi_busnum_to_master - look up master associated with bus_num
* @bus_num: the master's bus number * @bus_num: the master's bus number
...@@ -499,17 +508,12 @@ struct spi_master *spi_busnum_to_master(u16 bus_num) ...@@ -499,17 +508,12 @@ struct spi_master *spi_busnum_to_master(u16 bus_num)
{ {
struct device *dev; struct device *dev;
struct spi_master *master = NULL; struct spi_master *master = NULL;
struct spi_master *m;
down(&spi_master_class.sem); dev = class_find_device(&spi_master_class, &bus_num,
list_for_each_entry(dev, &spi_master_class.children, node) { __spi_master_match);
m = container_of(dev, struct spi_master, dev); if (dev)
if (m->bus_num == bus_num) { master = container_of(dev, struct spi_master, dev);
master = spi_master_get(m); /* reference got in class_find_device */
break;
}
}
up(&spi_master_class.sem);
return master; return master;
} }
EXPORT_SYMBOL_GPL(spi_busnum_to_master); EXPORT_SYMBOL_GPL(spi_busnum_to_master);
......
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