This patch makes the Versatile Express hwmon driver
use regmap interface, instead of custom vexpress config
one. It will request the regmap resource associated
with the device, which makes it pretty much hardware
agnostic.

Signed-off-by: Pawel Moll <[email protected]>
Cc: Jean Delvare <[email protected]>
Cc: Guenter Roeck <[email protected]>
Cc: [email protected]
---
 drivers/hwmon/Kconfig    |  3 ++-
 drivers/hwmon/vexpress.c | 29 +++++++++++------------------
 2 files changed, 13 insertions(+), 19 deletions(-)

diff --git a/drivers/hwmon/Kconfig b/drivers/hwmon/Kconfig
index 52d548f..7747a47 100644
--- a/drivers/hwmon/Kconfig
+++ b/drivers/hwmon/Kconfig
@@ -1324,7 +1324,8 @@ config SENSORS_TWL4030_MADC
 
 config SENSORS_VEXPRESS
        tristate "Versatile Express"
-       depends on VEXPRESS_CONFIG
+       depends on ARM || ARM64
+       depends on REGMAP
        help
          This driver provides support for hardware sensors available on
          the ARM Ltd's Versatile Express platform. It can provide wide
diff --git a/drivers/hwmon/vexpress.c b/drivers/hwmon/vexpress.c
index d867e6b..b58cf1c 100644
--- a/drivers/hwmon/vexpress.c
+++ b/drivers/hwmon/vexpress.c
@@ -22,11 +22,11 @@
 #include <linux/of.h>
 #include <linux/of_device.h>
 #include <linux/platform_device.h>
-#include <linux/vexpress.h>
+#include <linux/regmap.h>
 
 struct vexpress_hwmon_data {
        struct device *hwmon_dev;
-       struct vexpress_config_func *func;
+       struct regmap *reg;
 };
 
 static ssize_t vexpress_hwmon_name_show(struct device *dev,
@@ -56,7 +56,7 @@ static ssize_t vexpress_hwmon_u32_show(struct device *dev,
        int err;
        u32 value;
 
-       err = vexpress_config_read(data->func, 0, &value);
+       err = regmap_read(data->reg, 0, &value);
        if (err)
                return err;
 
@@ -69,13 +69,13 @@ static ssize_t vexpress_hwmon_u64_show(struct device *dev,
 {
        struct vexpress_hwmon_data *data = dev_get_drvdata(dev);
        int err;
-       u32 value_hi, value_lo;
+       unsigned int value_hi, value_lo;
 
-       err = vexpress_config_read(data->func, 0, &value_lo);
+       err = regmap_read(data->reg, 0, &value_lo);
        if (err)
                return err;
 
-       err = vexpress_config_read(data->func, 1, &value_hi);
+       err = regmap_read(data->reg, 1, &value_hi);
        if (err)
                return err;
 
@@ -175,26 +175,21 @@ static int vexpress_hwmon_probe(struct platform_device 
*pdev)
        if (!match)
                return -ENODEV;
 
-       data->func = vexpress_config_func_get_by_dev(&pdev->dev);
-       if (!data->func)
+       data->reg = dev_get_regmap(&pdev->dev, NULL);
+       if (!data->reg)
                return -ENODEV;
 
        err = sysfs_create_group(&pdev->dev.kobj, match->data);
        if (err)
-               goto error;
+               return err;
 
        data->hwmon_dev = hwmon_device_register(&pdev->dev);
        if (IS_ERR(data->hwmon_dev)) {
-               err = PTR_ERR(data->hwmon_dev);
-               goto error;
+               sysfs_remove_group(&pdev->dev.kobj, match->data);
+               return PTR_ERR(data->hwmon_dev);
        }
 
        return 0;
-
-error:
-       sysfs_remove_group(&pdev->dev.kobj, match->data);
-       vexpress_config_func_put(data->func);
-       return err;
 }
 
 static int vexpress_hwmon_remove(struct platform_device *pdev)
@@ -207,8 +202,6 @@ static int vexpress_hwmon_remove(struct platform_device 
*pdev)
        match = of_match_device(vexpress_hwmon_of_match, &pdev->dev);
        sysfs_remove_group(&pdev->dev.kobj, match->data);
 
-       vexpress_config_func_put(data->func);
-
        return 0;
 }
 
-- 
1.8.3.2


--
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/

Reply via email to