Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

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

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
Loading
Loading
Loading
Loading
+4 −2
Original line number Diff line number Diff line
@@ -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 power_supply *psy = dev_get_drvdata(dev);
	mode_t mode = S_IRUSR | S_IRGRP | S_IROTH;
	int i;

	if (attrno == POWER_SUPPLY_PROP_TYPE)
		return mode;

	for (i = 0; i < psy->num_properties; i++) {
		int property = psy->properties[i];

		if (property == attrno) {
			mode_t mode = S_IRUSR | S_IRGRP | S_IROTH;

			if (psy->property_is_writeable &&
			    psy->property_is_writeable(psy, property) > 0)
				mode |= S_IWUSR;