Commit 7a66ecfd authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'backlight-for-linus-4.8' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/backlight

Pull backlight updates from Lee Jones:
 "Add support for an enable regulator to lp855x_bl"

* tag 'backlight-for-linus-4.8' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/backlight:
  backlight: lp855x: Add enable regulator
parents 06e23d51 60255307
...@@ -13,6 +13,7 @@ Optional properties: ...@@ -13,6 +13,7 @@ Optional properties:
- rom-addr: Register address of ROM area to be updated (u8) - rom-addr: Register address of ROM area to be updated (u8)
- rom-val: Register value to be updated (u8) - rom-val: Register value to be updated (u8)
- power-supply: Regulator which controls the 3V rail - power-supply: Regulator which controls the 3V rail
- enable-supply: Regulator which controls the EN/VDDIO input
Example: Example:
...@@ -57,6 +58,7 @@ Example: ...@@ -57,6 +58,7 @@ Example:
backlight@2c { backlight@2c {
compatible = "ti,lp8557"; compatible = "ti,lp8557";
reg = <0x2c>; reg = <0x2c>;
enable-supply = <&backlight_vddio>;
power-supply = <&backlight_vdd>; power-supply = <&backlight_vdd>;
dev-ctrl = /bits/ 8 <0x41>; dev-ctrl = /bits/ 8 <0x41>;
......
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/backlight.h> #include <linux/backlight.h>
#include <linux/delay.h>
#include <linux/err.h> #include <linux/err.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/platform_data/lp855x.h> #include <linux/platform_data/lp855x.h>
...@@ -74,6 +75,7 @@ struct lp855x { ...@@ -74,6 +75,7 @@ struct lp855x {
struct lp855x_platform_data *pdata; struct lp855x_platform_data *pdata;
struct pwm_device *pwm; struct pwm_device *pwm;
struct regulator *supply; /* regulator for VDD input */ struct regulator *supply; /* regulator for VDD input */
struct regulator *enable; /* regulator for EN/VDDIO input */
}; };
static int lp855x_write_byte(struct lp855x *lp, u8 reg, u8 data) static int lp855x_write_byte(struct lp855x *lp, u8 reg, u8 data)
...@@ -433,6 +435,19 @@ static int lp855x_probe(struct i2c_client *cl, const struct i2c_device_id *id) ...@@ -433,6 +435,19 @@ static int lp855x_probe(struct i2c_client *cl, const struct i2c_device_id *id)
lp->supply = NULL; lp->supply = NULL;
} }
lp->enable = devm_regulator_get_optional(lp->dev, "enable");
if (IS_ERR(lp->enable)) {
ret = PTR_ERR(lp->enable);
if (ret == -ENODEV) {
lp->enable = NULL;
} else {
if (ret != -EPROBE_DEFER)
dev_err(lp->dev, "error getting enable regulator: %d\n",
ret);
return ret;
}
}
if (lp->supply) { if (lp->supply) {
ret = regulator_enable(lp->supply); ret = regulator_enable(lp->supply);
if (ret < 0) { if (ret < 0) {
...@@ -441,6 +456,20 @@ static int lp855x_probe(struct i2c_client *cl, const struct i2c_device_id *id) ...@@ -441,6 +456,20 @@ static int lp855x_probe(struct i2c_client *cl, const struct i2c_device_id *id)
} }
} }
if (lp->enable) {
ret = regulator_enable(lp->enable);
if (ret < 0) {
dev_err(lp->dev, "failed to enable vddio: %d\n", ret);
return ret;
}
/*
* LP8555 datasheet says t_RESPONSE (time between VDDIO and
* I2C) is 1ms.
*/
usleep_range(1000, 2000);
}
i2c_set_clientdata(cl, lp); i2c_set_clientdata(cl, lp);
ret = lp855x_configure(lp); ret = lp855x_configure(lp);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment