Commit df5ef181 authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Ben Hutchings

mfd: adp5520: Restore mode bits on resume

commit c6cc25fd upstream.

The adp5520 unfortunately also clears the BL_EN bit when the nSTNDBY bit is
cleared. So we need to make sure to restore it during resume if it was set
before suspend.
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Acked-by: default avatarMichael Hennerich <michael.hennerich@analog.com>
Signed-off-by: default avatarSamuel Ortiz <sameo@linux.intel.com>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 9126ab0c
...@@ -36,6 +36,7 @@ struct adp5520_chip { ...@@ -36,6 +36,7 @@ struct adp5520_chip {
struct blocking_notifier_head notifier_list; struct blocking_notifier_head notifier_list;
int irq; int irq;
unsigned long id; unsigned long id;
uint8_t mode;
}; };
static int __adp5520_read(struct i2c_client *client, static int __adp5520_read(struct i2c_client *client,
...@@ -326,7 +327,10 @@ static int adp5520_suspend(struct device *dev) ...@@ -326,7 +327,10 @@ static int adp5520_suspend(struct device *dev)
struct i2c_client *client = to_i2c_client(dev); struct i2c_client *client = to_i2c_client(dev);
struct adp5520_chip *chip = dev_get_drvdata(&client->dev); struct adp5520_chip *chip = dev_get_drvdata(&client->dev);
adp5520_clr_bits(chip->dev, ADP5520_MODE_STATUS, ADP5520_nSTNBY); adp5520_read(chip->dev, ADP5520_MODE_STATUS, &chip->mode);
/* All other bits are W1C */
chip->mode &= ADP5520_BL_EN | ADP5520_DIM_EN | ADP5520_nSTNBY;
adp5520_write(chip->dev, ADP5520_MODE_STATUS, 0);
return 0; return 0;
} }
...@@ -335,7 +339,7 @@ static int adp5520_resume(struct device *dev) ...@@ -335,7 +339,7 @@ static int adp5520_resume(struct device *dev)
struct i2c_client *client = to_i2c_client(dev); struct i2c_client *client = to_i2c_client(dev);
struct adp5520_chip *chip = dev_get_drvdata(&client->dev); struct adp5520_chip *chip = dev_get_drvdata(&client->dev);
adp5520_set_bits(chip->dev, ADP5520_MODE_STATUS, ADP5520_nSTNBY); adp5520_write(chip->dev, ADP5520_MODE_STATUS, chip->mode);
return 0; return 0;
} }
#endif #endif
......
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