Re: [PATCH 6/6] spi : use class iteration api
On Monday 21 January 2008, Dave Young wrote: > Convert to use the class iteration api. > > Signed-off-by: Dave Young <[EMAIL PROTECTED]> Ack. > --- > drivers/spi/spi.c | 24 ++-- > 1 file changed, 14 insertions(+), 10 deletions(-) > > diff -upr linux/drivers/spi/spi.c linux.new/drivers/spi/spi.c > --- linux/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 > +++ linux.new/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 > @@ -485,6 +485,15 @@ void spi_unregister_master(struct spi_ma > } > 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 > * @bus_num: the master's bus number > @@ -499,17 +508,12 @@ struct spi_master *spi_busnum_to_master( > { > struct device *dev; > struct spi_master *master = NULL; > - struct spi_master *m; > > - down(_master_class.sem); > - list_for_each_entry(dev, _master_class.children, node) { > - m = container_of(dev, struct spi_master, dev); > - if (m->bus_num == bus_num) { > - master = spi_master_get(m); > - break; > - } > - } > - up(_master_class.sem); > + dev = class_find_device(_master_class, _num, > + __spi_master_match); > + if (dev) > + master = container_of(dev, struct spi_master, dev); > + /* reference got in class_find_device */ > return master; > } > EXPORT_SYMBOL_GPL(spi_busnum_to_master); > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 6/6] spi : use class iteration api
Convert to use the class iteration api. Signed-off-by: Dave Young <[EMAIL PROTECTED]> --- drivers/spi/spi.c | 24 ++-- 1 file changed, 14 insertions(+), 10 deletions(-) diff -upr linux/drivers/spi/spi.c linux.new/drivers/spi/spi.c --- linux/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 +++ linux.new/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 @@ -485,6 +485,15 @@ void spi_unregister_master(struct spi_ma } 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 * @bus_num: the master's bus number @@ -499,17 +508,12 @@ struct spi_master *spi_busnum_to_master( { struct device *dev; struct spi_master *master = NULL; - struct spi_master *m; - down(_master_class.sem); - list_for_each_entry(dev, _master_class.children, node) { - m = container_of(dev, struct spi_master, dev); - if (m->bus_num == bus_num) { - master = spi_master_get(m); - break; - } - } - up(_master_class.sem); + dev = class_find_device(_master_class, _num, + __spi_master_match); + if (dev) + master = container_of(dev, struct spi_master, dev); + /* reference got in class_find_device */ return master; } EXPORT_SYMBOL_GPL(spi_busnum_to_master); -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 6/6] spi : use class iteration api
On Jan 22, 2008 2:56 PM, David Brownell <[EMAIL PROTECTED]> wrote: > On Monday 21 January 2008, Dave Young wrote: > > +static int __spi_master_match(struct device *dev, void *data) > > +{ > > +struct spi_master *m; > > +u16 *bus_num = (u16 *)data; > > That's "void *data" so "u16 *bus_num = data" is preferred. > Fine. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 6/6] spi : use class iteration api
On Monday 21 January 2008, Dave Young wrote: > +static int __spi_master_match(struct device *dev, void *data) > +{ > + struct spi_master *m; > + u16 *bus_num = (u16 *)data; That's "void *data" so "u16 *bus_num = data" is preferred. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 6/6] spi : use class iteration api
On Monday 21 January 2008, Dave Young wrote: +static int __spi_master_match(struct device *dev, void *data) +{ + struct spi_master *m; + u16 *bus_num = (u16 *)data; That's void *data so u16 *bus_num = data is preferred. -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 6/6] spi : use class iteration api
On Jan 22, 2008 2:56 PM, David Brownell [EMAIL PROTECTED] wrote: On Monday 21 January 2008, Dave Young wrote: +static int __spi_master_match(struct device *dev, void *data) +{ +struct spi_master *m; +u16 *bus_num = (u16 *)data; That's void *data so u16 *bus_num = data is preferred. Fine. -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 6/6] spi : use class iteration api
Convert to use the class iteration api. Signed-off-by: Dave Young [EMAIL PROTECTED] --- drivers/spi/spi.c | 24 ++-- 1 file changed, 14 insertions(+), 10 deletions(-) diff -upr linux/drivers/spi/spi.c linux.new/drivers/spi/spi.c --- linux/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 +++ linux.new/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 @@ -485,6 +485,15 @@ void spi_unregister_master(struct spi_ma } 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 * @bus_num: the master's bus number @@ -499,17 +508,12 @@ struct spi_master *spi_busnum_to_master( { struct device *dev; struct spi_master *master = NULL; - struct spi_master *m; - down(spi_master_class.sem); - list_for_each_entry(dev, spi_master_class.children, node) { - m = container_of(dev, struct spi_master, dev); - if (m-bus_num == bus_num) { - master = spi_master_get(m); - break; - } - } - up(spi_master_class.sem); + dev = class_find_device(spi_master_class, bus_num, + __spi_master_match); + if (dev) + master = container_of(dev, struct spi_master, dev); + /* reference got in class_find_device */ return master; } EXPORT_SYMBOL_GPL(spi_busnum_to_master); -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Re: [PATCH 6/6] spi : use class iteration api
On Monday 21 January 2008, Dave Young wrote: Convert to use the class iteration api. Signed-off-by: Dave Young [EMAIL PROTECTED] Ack. --- drivers/spi/spi.c | 24 ++-- 1 file changed, 14 insertions(+), 10 deletions(-) diff -upr linux/drivers/spi/spi.c linux.new/drivers/spi/spi.c --- linux/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 +++ linux.new/drivers/spi/spi.c 2008-01-22 15:09:49.0 +0800 @@ -485,6 +485,15 @@ void spi_unregister_master(struct spi_ma } 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 * @bus_num: the master's bus number @@ -499,17 +508,12 @@ struct spi_master *spi_busnum_to_master( { struct device *dev; struct spi_master *master = NULL; - struct spi_master *m; - down(spi_master_class.sem); - list_for_each_entry(dev, spi_master_class.children, node) { - m = container_of(dev, struct spi_master, dev); - if (m-bus_num == bus_num) { - master = spi_master_get(m); - break; - } - } - up(spi_master_class.sem); + dev = class_find_device(spi_master_class, bus_num, + __spi_master_match); + if (dev) + master = container_of(dev, struct spi_master, dev); + /* reference got in class_find_device */ return master; } EXPORT_SYMBOL_GPL(spi_busnum_to_master); -- To unsubscribe from this list: send the line unsubscribe linux-kernel in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/