hwmon: (pmbus/zl6100) Add support for ZL2005
authorGuenter Roeck <guenter.roeck@ericsson.com>
Sat, 1 Oct 2011 23:50:36 +0000 (16:50 -0700)
committerGuenter Roeck <guenter.roeck@ericsson.com>
Thu, 5 Jan 2012 16:19:27 +0000 (08:19 -0800)
Add explicit support for ZL2005. Functionality is almost the same as with other
Zilker Labs / Intersil chips, but limit register detection does not work reliably.

Signed-off-by: Guenter Roeck <guenter.roeck@ericsson.com>
Reviewed-by: Robert Coulson <robert.coulson@ericsson.com>
Documentation/hwmon/zl6100
drivers/hwmon/pmbus/Kconfig
drivers/hwmon/pmbus/zl6100.c

index 7617798b5c9736f49f8a69065739de9cb8267bbc..d3bca065cb7ecb988c74c8c975f3fe6bde8e9116 100644 (file)
@@ -6,6 +6,10 @@ Supported chips:
     Prefix: 'zl2004'
     Addresses scanned: -
     Datasheet: http://www.intersil.com/data/fn/fn6847.pdf
+  * Intersil / Zilker Labs ZL2005
+    Prefix: 'zl2005'
+    Addresses scanned: -
+    Datasheet: http://www.intersil.com/data/fn/fn6848.pdf
   * Intersil / Zilker Labs ZL2006
     Prefix: 'zl2006'
     Addresses scanned: -
index 4b26f51920ba8aa291918af49eb9bf4558a482f5..d357ab280263ec912a600d714e17bd15f2f8b909 100644 (file)
@@ -113,8 +113,8 @@ config SENSORS_ZL6100
        default n
        help
          If you say yes here you get hardware monitoring support for Intersil
-         ZL2004, ZL2006, ZL2008, ZL2105, ZL2106, ZL6100, and ZL6105 Digital
-         DC/DC Controllers.
+         ZL2004, ZL2005, ZL2006, ZL2008, ZL2105, ZL2106, ZL6100, and ZL6105
+         Digital DC/DC Controllers.
 
          This driver can also be built as a module. If so, the module will
          be called zl6100.
index 2bc980006f83c3450d820fccbdf427ad1974a08c..d78bdcf467f3e66fb316d95ec66fbfe8a0128a58 100644 (file)
@@ -28,7 +28,7 @@
 #include <linux/delay.h>
 #include "pmbus.h"
 
-enum chips { zl2004, zl2006, zl2008, zl2105, zl2106, zl6100, zl6105 };
+enum chips { zl2004, zl2005, zl2006, zl2008, zl2105, zl2106, zl6100, zl6105 };
 
 struct zl6100_data {
        int id;
@@ -65,6 +65,19 @@ static int zl6100_read_word_data(struct i2c_client *client, int page, int reg)
        if (page || reg >= PMBUS_VIRT_BASE)
                return -ENXIO;
 
+       if (data->id == zl2005) {
+               /*
+                * Limit register detection is not reliable on ZL2005.
+                * Make sure registers are not erroneously detected.
+                */
+               switch (reg) {
+               case PMBUS_VOUT_OV_WARN_LIMIT:
+               case PMBUS_VOUT_UV_WARN_LIMIT:
+               case PMBUS_IOUT_OC_WARN_LIMIT:
+                       return -ENXIO;
+               }
+       }
+
        zl6100_wait(data);
        ret = pmbus_read_word_data(client, page, reg);
        data->access = ktime_get();
@@ -123,6 +136,7 @@ static int zl6100_write_byte(struct i2c_client *client, int page, u8 value)
 
 static const struct i2c_device_id zl6100_id[] = {
        {"zl2004", zl2004},
+       {"zl2005", zl2005},
        {"zl2006", zl2006},
        {"zl2008", zl2008},
        {"zl2105", zl2105},
@@ -177,8 +191,9 @@ static int zl6100_probe(struct i2c_client *client,
        data->id = mid->driver_data;
 
        /*
-        * ZL2008, ZL2105, and ZL6100 are known to require a wait time
+        * ZL2005, ZL2008, ZL2105, and ZL6100 are known to require a wait time
         * between I2C accesses. ZL2004 and ZL6105 are known to be safe.
+        * Other chips have not yet been tested.
         *
         * Only clear the wait time for chips known to be safe. The wait time
         * can be cleared later for additional chips if tests show that it