Commit bbabb158 authored by Daniel Mack's avatar Daniel Mack Committed by Anton Vorontsov

power_supply: Fix regression for 'type' property

Commit 5f487cd3 (power_supply: Use
attribute groups) causes a regression the power supply core does not
export the 'type' attribute anymore.

POWER_SUPPLY_PROP_TYPE is handled by the power supply core without the
low-level driver, so power_supply_attr_is_visible() must always return
the entry as readable.
Reported-by: default avatarRafael J. Wysocki <rjw@sisk.pl>
Signed-off-by: default avatarDaniel Mack <daniel@caiaq.de>
Tested-by: default avatarRafael J. Wysocki <rjw@sisk.pl>
Signed-off-by: default avatarAnton Vorontsov <cbouatmailru@gmail.com>
parent 24af3202
...@@ -179,14 +179,16 @@ static mode_t power_supply_attr_is_visible(struct kobject *kobj, ...@@ -179,14 +179,16 @@ static mode_t power_supply_attr_is_visible(struct kobject *kobj,
{ {
struct device *dev = container_of(kobj, struct device, kobj); struct device *dev = container_of(kobj, struct device, kobj);
struct power_supply *psy = dev_get_drvdata(dev); struct power_supply *psy = dev_get_drvdata(dev);
mode_t mode = S_IRUSR | S_IRGRP | S_IROTH;
int i; int i;
if (attrno == POWER_SUPPLY_PROP_TYPE)
return mode;
for (i = 0; i < psy->num_properties; i++) { for (i = 0; i < psy->num_properties; i++) {
int property = psy->properties[i]; int property = psy->properties[i];
if (property == attrno) { if (property == attrno) {
mode_t mode = S_IRUSR | S_IRGRP | S_IROTH;
if (psy->property_is_writeable && if (psy->property_is_writeable &&
psy->property_is_writeable(psy, property) > 0) psy->property_is_writeable(psy, property) > 0)
mode |= S_IWUSR; mode |= S_IWUSR;
......
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