diff options
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/leds/leds-lm3530.c | 13 | 
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:  |