summaryrefslogtreecommitdiff
path: root/drivers/leds
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/leds')
-rw-r--r--drivers/leds/leds-lm3530.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/drivers/leds/leds-lm3530.c b/drivers/leds/leds-lm3530.c
index e3acd8583e5..c3d4a69655f 100644
--- a/drivers/leds/leds-lm3530.c
+++ b/drivers/leds/leds-lm3530.c
@@ -22,6 +22,7 @@
#include <linux/types.h>
#include <linux/regulator/consumer.h>
#include <linux/module.h>
+#include <linux/gpio.h>
#define LM3530_LED_DEV "lcd-backlight"
#define LM3530_NAME "lm3530-led"
@@ -92,6 +93,7 @@ struct lm3530_mode_map {
static struct lm3530_mode_map mode_map[] = {
{ "man", LM3530_BL_MODE_MANUAL },
+ { "man", LM3530_BL_MODE_SIMPLE_MANUAL },
{ "als", LM3530_BL_MODE_ALS },
{ "pwm", LM3530_BL_MODE_PWM },
};
@@ -246,6 +248,11 @@ static int lm3530_init_registers(struct lm3530_data *drvdata)
case LM3530_BL_MODE_MANUAL:
gen_config |= LM3530_ENABLE_I2C;
break;
+ case LM3530_BL_MODE_SIMPLE_MANUAL:
+ gen_config |= LM3530_ENABLE_I2C | LM3530_ENABLE_PWM_SIMPLE |
+ LM3530_ENABLE_PWM |
+ (pdata->pwm_pol_hi << LM3530_PWM_POL_SHIFT);
+ break;
case LM3530_BL_MODE_ALS:
gen_config |= LM3530_ENABLE_I2C;
lm3530_als_configure(pdata, &als);
@@ -317,6 +324,7 @@ static void lm3530_brightness_set(struct led_classdev *led_cdev,
switch (drvdata->mode) {
case LM3530_BL_MODE_MANUAL:
+ case LM3530_BL_MODE_SIMPLE_MANUAL:
if (!drvdata->enable) {
err = lm3530_init_registers(drvdata);
@@ -471,6 +479,11 @@ static int lm3530_probe(struct i2c_client *client,
goto err_create_file;
}
+ if (gpio_request_one(drvdata->pdata->pwm_gpio,
+ GPIOF_DIR_OUT | GPIOF_EXPORT | GPIOF_INIT_HIGH,
+ "backlight gpio"))
+ dev_err(&client->dev, "Failed to request gpio:\n");
+
return 0;
err_create_file: