提交 d2a5c10f 编写于 作者: A Anton Vorontsov 提交者: Linus Torvalds

hwmon: adxx: convert to device table matching

Make the code a little bit nicer, and shorter.
Signed-off-by: NAnton Vorontsov <avorontsov@ru.mvista.com>
Cc: Marc Pignat <marc.pignat@hevs.ch>
Cc: David Brownell <dbrownell@users.sourceforge.net>
Cc: David Woodhouse <dwmw2@infradead.org>
Cc: Grant Likely <grant.likely@secretlab.ca>
Cc: Jean Delvare <khali@linux-fr.org>
Cc: Ben Dooks <ben-linux@fluff.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Acked-by: NMarc Pignat <marc.pignat@hevs.ch>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 225d8b24
...@@ -43,6 +43,7 @@ ...@@ -43,6 +43,7 @@
#include <linux/hwmon.h> #include <linux/hwmon.h>
#include <linux/hwmon-sysfs.h> #include <linux/hwmon-sysfs.h>
#include <linux/mutex.h> #include <linux/mutex.h>
#include <linux/mod_devicetable.h>
#include <linux/spi/spi.h> #include <linux/spi/spi.h>
#define DRVNAME "adcxx" #define DRVNAME "adcxx"
...@@ -157,8 +158,9 @@ static struct sensor_device_attribute ad_input[] = { ...@@ -157,8 +158,9 @@ static struct sensor_device_attribute ad_input[] = {
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
static int __devinit adcxx_probe(struct spi_device *spi, int channels) static int __devinit adcxx_probe(struct spi_device *spi)
{ {
int channels = spi_get_device_id(spi)->driver_data;
struct adcxx *adc; struct adcxx *adc;
int status; int status;
int i; int i;
...@@ -204,26 +206,6 @@ static int __devinit adcxx_probe(struct spi_device *spi, int channels) ...@@ -204,26 +206,6 @@ static int __devinit adcxx_probe(struct spi_device *spi, int channels)
return status; return status;
} }
static int __devinit adcxx1s_probe(struct spi_device *spi)
{
return adcxx_probe(spi, 1);
}
static int __devinit adcxx2s_probe(struct spi_device *spi)
{
return adcxx_probe(spi, 2);
}
static int __devinit adcxx4s_probe(struct spi_device *spi)
{
return adcxx_probe(spi, 4);
}
static int __devinit adcxx8s_probe(struct spi_device *spi)
{
return adcxx_probe(spi, 8);
}
static int __devexit adcxx_remove(struct spi_device *spi) static int __devexit adcxx_remove(struct spi_device *spi)
{ {
struct adcxx *adc = dev_get_drvdata(&spi->dev); struct adcxx *adc = dev_get_drvdata(&spi->dev);
...@@ -241,79 +223,33 @@ static int __devexit adcxx_remove(struct spi_device *spi) ...@@ -241,79 +223,33 @@ static int __devexit adcxx_remove(struct spi_device *spi)
return 0; return 0;
} }
static struct spi_driver adcxx1s_driver = { static const struct spi_device_id adcxx_ids[] = {
.driver = { { "adcxx1s", 1 },
.name = "adcxx1s", { "adcxx2s", 2 },
.owner = THIS_MODULE, { "adcxx4s", 4 },
}, { "adcxx8s", 8 },
.probe = adcxx1s_probe, { },
.remove = __devexit_p(adcxx_remove),
}; };
MODULE_DEVICE_TABLE(spi, adcxx_ids);
static struct spi_driver adcxx2s_driver = { static struct spi_driver adcxx_driver = {
.driver = { .driver = {
.name = "adcxx2s", .name = "adcxx",
.owner = THIS_MODULE, .owner = THIS_MODULE,
}, },
.probe = adcxx2s_probe, .id_table = adcxx_ids,
.remove = __devexit_p(adcxx_remove), .probe = adcxx_probe,
};
static struct spi_driver adcxx4s_driver = {
.driver = {
.name = "adcxx4s",
.owner = THIS_MODULE,
},
.probe = adcxx4s_probe,
.remove = __devexit_p(adcxx_remove),
};
static struct spi_driver adcxx8s_driver = {
.driver = {
.name = "adcxx8s",
.owner = THIS_MODULE,
},
.probe = adcxx8s_probe,
.remove = __devexit_p(adcxx_remove), .remove = __devexit_p(adcxx_remove),
}; };
static int __init init_adcxx(void) static int __init init_adcxx(void)
{ {
int status; return spi_register_driver(&adcxx_driver);
status = spi_register_driver(&adcxx1s_driver);
if (status)
goto reg_1_failed;
status = spi_register_driver(&adcxx2s_driver);
if (status)
goto reg_2_failed;
status = spi_register_driver(&adcxx4s_driver);
if (status)
goto reg_4_failed;
status = spi_register_driver(&adcxx8s_driver);
if (status)
goto reg_8_failed;
return status;
reg_8_failed:
spi_unregister_driver(&adcxx4s_driver);
reg_4_failed:
spi_unregister_driver(&adcxx2s_driver);
reg_2_failed:
spi_unregister_driver(&adcxx1s_driver);
reg_1_failed:
return status;
} }
static void __exit exit_adcxx(void) static void __exit exit_adcxx(void)
{ {
spi_unregister_driver(&adcxx1s_driver); spi_unregister_driver(&adcxx_driver);
spi_unregister_driver(&adcxx2s_driver);
spi_unregister_driver(&adcxx4s_driver);
spi_unregister_driver(&adcxx8s_driver);
} }
module_init(init_adcxx); module_init(init_adcxx);
...@@ -322,8 +258,3 @@ module_exit(exit_adcxx); ...@@ -322,8 +258,3 @@ module_exit(exit_adcxx);
MODULE_AUTHOR("Marc Pignat"); MODULE_AUTHOR("Marc Pignat");
MODULE_DESCRIPTION("National Semiconductor adcxx8sxxx Linux driver"); MODULE_DESCRIPTION("National Semiconductor adcxx8sxxx Linux driver");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
MODULE_ALIAS("adcxx1s");
MODULE_ALIAS("adcxx2s");
MODULE_ALIAS("adcxx4s");
MODULE_ALIAS("adcxx8s");
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册