iio:magnetometer:ak8975: power regulator support
authorGregor Boirie <gregor.boirie@parrot.com>
Thu, 3 Mar 2016 10:44:05 +0000 (11:44 +0100)
committerJonathan Cameron <jic23@kernel.org>
Sat, 5 Mar 2016 15:25:58 +0000 (15:25 +0000)
Add support for an optional regulator which, if found into device-tree,
will power on device at probing time.
The regulator is declared into ak8975 DTS entry as a "vdd-supply" property.

Signed-off-by: Gregor Boirie <gregor.boirie@parrot.com>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
Documentation/devicetree/bindings/iio/magnetometer/ak8975.txt
drivers/iio/magnetometer/ak8975.c

index 011679f1a4259bd14847207c93361bdc1f3d41af..34a3206eefdf847a26200f71e6d2b715fd021e8d 100644 (file)
@@ -8,6 +8,7 @@ Required properties:
 Optional properties:
 
   - gpios : should be device tree identifier of the magnetometer DRDY pin
+  - vdd-supply: an optional regulator that needs to be on to provide VDD
 
 Example:
 
@@ -15,4 +16,5 @@ ak8975@0c {
         compatible = "asahi-kasei,ak8975";
         reg = <0x0c>;
         gpios = <&gpj0 7 0>;
+        vdd-supply = <&ldo_3v3_gnss>;
 };
index 896b13e39daedd61b6d8acbad6d2873df2473cd3..72c03d9fbeb22ffe1ec542a1f39d53ce7418a9c6 100644 (file)
@@ -32,6 +32,7 @@
 #include <linux/gpio.h>
 #include <linux/of_gpio.h>
 #include <linux/acpi.h>
+#include <linux/regulator/consumer.h>
 
 #include <linux/iio/iio.h>
 #include <linux/iio/sysfs.h>
@@ -379,8 +380,23 @@ static int ak8975_who_i_am(struct i2c_client *client,
                           enum asahi_compass_chipset type)
 {
        u8 wia_val[2];
+       struct regulator *vdd = devm_regulator_get_optional(&client->dev,
+                                                           "vdd");
        int ret;
 
+       /* Enable attached regulator if any. */
+       if (!IS_ERR(vdd)) {
+               ret = regulator_enable(vdd);
+               if (ret) {
+                       dev_err(&client->dev, "Failed to enable Vdd supply\n");
+                       return ret;
+               }
+       } else {
+               ret = PTR_ERR(vdd);
+               if (ret != -ENODEV)
+                       return ret;
+       }
+
        /*
         * Signature for each device:
         * Device   |  WIA1      |  WIA2