]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - drivers/mfd/ab8500-i2c.c
mfd: mc13xxx core should not be user visible
[karo-tx-linux.git] / drivers / mfd / ab8500-i2c.c
index 087fecd71ce032b2ad459467c02aef47197f13ea..89b31a3409cdcf6e2e0aceb0fe790ae00ea4d32c 100644 (file)
@@ -11,7 +11,7 @@
 #include <linux/module.h>
 #include <linux/platform_device.h>
 #include <linux/mfd/abx500/ab8500.h>
-#include <linux/mfd/db8500-prcmu.h>
+#include <linux/mfd/dbx500-prcmu.h>
 
 static int ab8500_i2c_write(struct ab8500 *ab8500, u16 addr, u8 data)
 {
@@ -23,6 +23,18 @@ static int ab8500_i2c_write(struct ab8500 *ab8500, u16 addr, u8 data)
        return ret;
 }
 
+static int ab8500_i2c_write_masked(struct ab8500 *ab8500, u16 addr, u8 mask,
+       u8 data)
+{
+       int ret;
+
+       ret = prcmu_abb_write_masked((u8)(addr >> 8), (u8)(addr & 0xFF), &data,
+               &mask, 1);
+       if (ret < 0)
+               dev_err(ab8500->dev, "prcmu i2c error %d\n", ret);
+       return ret;
+}
+
 static int ab8500_i2c_read(struct ab8500 *ab8500, u16 addr)
 {
        int ret;
@@ -38,6 +50,7 @@ static int ab8500_i2c_read(struct ab8500 *ab8500, u16 addr)
 
 static int __devinit ab8500_i2c_probe(struct platform_device *plf)
 {
+       const struct platform_device_id *platid = platform_get_device_id(plf);
        struct ab8500 *ab8500;
        struct resource *resource;
        int ret;
@@ -58,13 +71,15 @@ static int __devinit ab8500_i2c_probe(struct platform_device *plf)
 
        ab8500->read = ab8500_i2c_read;
        ab8500->write = ab8500_i2c_write;
+       ab8500->write_masked = ab8500_i2c_write_masked;
 
        platform_set_drvdata(plf, ab8500);
 
-       ret = ab8500_init(ab8500);
+       ret = ab8500_init(ab8500, platid->driver_data);
        if (ret)
                kfree(ab8500);
 
+
        return ret;
 }
 
@@ -78,13 +93,54 @@ static int __devexit ab8500_i2c_remove(struct platform_device *plf)
        return 0;
 }
 
+static const struct platform_device_id ab8500_id[] = {
+       { "ab8500-i2c", AB8500_VERSION_AB8500 },
+       { "ab8505-i2c", AB8500_VERSION_AB8505 },
+       { "ab9540-i2c", AB8500_VERSION_AB9540 },
+       { "ab8540-i2c", AB8500_VERSION_AB8540 },
+       { }
+};
+
+#ifdef CONFIG_PM
+static int ab8500_i2c_suspend(struct device *dev)
+{
+       struct ab8500 *ab = dev_get_drvdata(dev);
+
+       disable_irq(ab->irq);
+       enable_irq_wake(ab->irq);
+
+       return 0;
+}
+
+static int ab8500_i2c_resume(struct device *dev)
+{
+       struct ab8500 *ab = dev_get_drvdata(dev);
+
+       disable_irq_wake(ab->irq);
+       enable_irq(ab->irq);
+
+       return 0;
+}
+
+static const struct dev_pm_ops ab8500_i2c_pm_ops = {
+       .suspend        = ab8500_i2c_suspend,
+       .resume         = ab8500_i2c_resume,
+};
+
+#define AB8500_I2C_PM_OPS      (&ab8500_i2c_pm_ops)
+#else
+#define AB8500_I2C_PM_OPS      NULL
+#endif
+
 static struct platform_driver ab8500_i2c_driver = {
        .driver = {
                .name = "ab8500-i2c",
                .owner = THIS_MODULE,
+               .pm     = AB8500_I2C_PM_OPS,
        },
        .probe  = ab8500_i2c_probe,
-       .remove = __devexit_p(ab8500_i2c_remove)
+       .remove = __devexit_p(ab8500_i2c_remove),
+       .id_table = ab8500_id,
 };
 
 static int __init ab8500_i2c_init(void)