Message ID | 7ac1176497a246b59316efecef9912dcf9b1e48a.1585944770.git.mirq-linux@rere.qmqm.pl (mailing list archive) |
---|---|
State | Not Applicable, archived |
Headers | show |
Series | extensions and fixes | expand |
Hi, On Fri, Apr 03, 2020 at 10:20:34PM +0200, Michał Mirosław wrote: > Currently HWMON emulation shows all labels (temp and ambient temp) > regardless if power supply supports reading the values. Check that at > least one property is enabled for each label. > > Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl> > --- Thanks, queued. -- Sebastian > v3: use a tabule for type checking instead of switch() sequence > --- > drivers/power/supply/power_supply_hwmon.c | 42 +++++++++++++++++++++-- > 1 file changed, 39 insertions(+), 3 deletions(-) > > diff --git a/drivers/power/supply/power_supply_hwmon.c b/drivers/power/supply/power_supply_hwmon.c > index 5621e72a39f0..1b473deaf391 100644 > --- a/drivers/power/supply/power_supply_hwmon.c > +++ b/drivers/power/supply/power_supply_hwmon.c > @@ -103,6 +103,39 @@ static bool power_supply_hwmon_is_a_label(enum hwmon_sensor_types type, > return type == hwmon_temp && attr == hwmon_temp_label; > } > > +struct hwmon_type_attr_list { > + const u32 *attrs; > + size_t n_attrs; > +}; > + > +static const u32 ps_temp_attrs[] = { > + hwmon_temp_input, > + hwmon_temp_min, hwmon_temp_max, > + hwmon_temp_min_alarm, hwmon_temp_max_alarm, > +}; > + > +static const struct hwmon_type_attr_list ps_type_attrs[hwmon_max] = { > + [hwmon_temp] = { ps_temp_attrs, ARRAY_SIZE(ps_temp_attrs) }, > +}; > + > +static bool power_supply_hwmon_has_input( > + const struct power_supply_hwmon *psyhw, > + enum hwmon_sensor_types type, int channel) > +{ > + const struct hwmon_type_attr_list *attr_list = &ps_type_attrs[type]; > + size_t i; > + > + for (i = 0; i < attr_list->n_attrs; ++i) { > + int prop = power_supply_hwmon_to_property(type, > + attr_list->attrs[i], channel); > + > + if (prop >= 0 && test_bit(prop, psyhw->props)) > + return true; > + } > + > + return false; > +} > + > static bool power_supply_hwmon_is_writable(enum hwmon_sensor_types type, > u32 attr) > { > @@ -129,9 +162,12 @@ static umode_t power_supply_hwmon_is_visible(const void *data, > const struct power_supply_hwmon *psyhw = data; > int prop; > > - > - if (power_supply_hwmon_is_a_label(type, attr)) > - return 0444; > + if (power_supply_hwmon_is_a_label(type, attr)) { > + if (power_supply_hwmon_has_input(psyhw, type, channel)) > + return 0444; > + else > + return 0; > + } > > prop = power_supply_hwmon_to_property(type, attr, channel); > if (prop < 0 || !test_bit(prop, psyhw->props)) > -- > 2.20.1 >
diff --git a/drivers/power/supply/power_supply_hwmon.c b/drivers/power/supply/power_supply_hwmon.c index 5621e72a39f0..1b473deaf391 100644 --- a/drivers/power/supply/power_supply_hwmon.c +++ b/drivers/power/supply/power_supply_hwmon.c @@ -103,6 +103,39 @@ static bool power_supply_hwmon_is_a_label(enum hwmon_sensor_types type, return type == hwmon_temp && attr == hwmon_temp_label; } +struct hwmon_type_attr_list { + const u32 *attrs; + size_t n_attrs; +}; + +static const u32 ps_temp_attrs[] = { + hwmon_temp_input, + hwmon_temp_min, hwmon_temp_max, + hwmon_temp_min_alarm, hwmon_temp_max_alarm, +}; + +static const struct hwmon_type_attr_list ps_type_attrs[hwmon_max] = { + [hwmon_temp] = { ps_temp_attrs, ARRAY_SIZE(ps_temp_attrs) }, +}; + +static bool power_supply_hwmon_has_input( + const struct power_supply_hwmon *psyhw, + enum hwmon_sensor_types type, int channel) +{ + const struct hwmon_type_attr_list *attr_list = &ps_type_attrs[type]; + size_t i; + + for (i = 0; i < attr_list->n_attrs; ++i) { + int prop = power_supply_hwmon_to_property(type, + attr_list->attrs[i], channel); + + if (prop >= 0 && test_bit(prop, psyhw->props)) + return true; + } + + return false; +} + static bool power_supply_hwmon_is_writable(enum hwmon_sensor_types type, u32 attr) { @@ -129,9 +162,12 @@ static umode_t power_supply_hwmon_is_visible(const void *data, const struct power_supply_hwmon *psyhw = data; int prop; - - if (power_supply_hwmon_is_a_label(type, attr)) - return 0444; + if (power_supply_hwmon_is_a_label(type, attr)) { + if (power_supply_hwmon_has_input(psyhw, type, channel)) + return 0444; + else + return 0; + } prop = power_supply_hwmon_to_property(type, attr, channel); if (prop < 0 || !test_bit(prop, psyhw->props))
Currently HWMON emulation shows all labels (temp and ambient temp) regardless if power supply supports reading the values. Check that at least one property is enabled for each label. Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl> --- v3: use a tabule for type checking instead of switch() sequence --- drivers/power/supply/power_supply_hwmon.c | 42 +++++++++++++++++++++-- 1 file changed, 39 insertions(+), 3 deletions(-)