mfd: Support for ICs compliant with max8998
authorLukasz Majewski <l.majewski@samsung.com>
Mon, 27 Sep 2010 12:32:24 +0000 (14:32 +0200)
committerSamuel Ortiz <sameo@linux.intel.com>
Thu, 28 Oct 2010 22:30:09 +0000 (00:30 +0200)
Signed-off-by: Lukasz Majewski <l.majewski@samsung.com>
Signed-off-by: Kyungmin Park <kyungmin.park@samsung.com>
Acked-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Signed-off-by: Samuel Ortiz <sameo@linux.intel.com>
drivers/mfd/max8998.c
include/linux/mfd/max8998-private.h

index 310fd8054f35fe8d4ed68d17c360c9602e38b42b..a720f412cd15b0ff13b280f8de2edb1fc3291068 100644 (file)
@@ -133,6 +133,7 @@ static int max8998_i2c_probe(struct i2c_client *i2c,
        max8998->dev = &i2c->dev;
        max8998->i2c = i2c;
        max8998->irq = i2c->irq;
+       max8998->type = id->driver_data;
        if (pdata) {
                max8998->ono = pdata->ono;
                max8998->irq_base = pdata->irq_base;
@@ -169,8 +170,8 @@ static int max8998_i2c_remove(struct i2c_client *i2c)
 }
 
 static const struct i2c_device_id max8998_i2c_id[] = {
-       { "max8998", 0 },
-       { "lp3974", },
+       { "max8998", TYPE_MAX8998 },
+       { "lp3974", TYPE_LP3974},
        { }
 };
 MODULE_DEVICE_TABLE(i2c, max8998_i2c_id);
index 170f665c7cdd2dd8064ff4c0d37f774e5ae99fea..0ff42116d5dd2bad342f4faef9e20291563a6efa 100644 (file)
@@ -101,6 +101,13 @@ enum {
        MAX8998_IRQ_NR,
 };
 
+/* MAX8998 various variants */
+enum {
+       TYPE_MAX8998 = 0, /* Default */
+       TYPE_LP3974,    /* National version of MAX8998 */
+       TYPE_LP3979,    /* Added AVS */
+};
+
 #define MAX8998_IRQ_DCINF_MASK         (1 << 2)
 #define MAX8998_IRQ_DCINR_MASK         (1 << 3)
 #define MAX8998_IRQ_JIGF_MASK          (1 << 4)
@@ -123,6 +130,8 @@ enum {
 #define MAX8998_IRQ_LOBAT1_MASK                (1 << 0)
 #define MAX8998_IRQ_LOBAT2_MASK                (1 << 1)
 
+#define MAX8998_ENRAMP                  (1 << 4)
+
 /**
  * struct max8998_dev - max8998 master device for sub-drivers
  * @dev: master device of the chip (can be used to access platform data)
@@ -135,6 +144,7 @@ enum {
  * @ono: power onoff IRQ number for max8998
  * @irq_masks_cur: currently active value
  * @irq_masks_cache: cached hardware value
+ * @type: indicate which max8998 "variant" is used
  */
 struct max8998_dev {
        struct device *dev;
@@ -148,6 +158,7 @@ struct max8998_dev {
        int ono;
        u8 irq_masks_cur[MAX8998_NUM_IRQ_REGS];
        u8 irq_masks_cache[MAX8998_NUM_IRQ_REGS];
+       int type;
 };
 
 int max8998_irq_init(struct max8998_dev *max8998);