Commit 915d4664 authored by Michael Shych's avatar Michael Shych Committed by Guenter Roeck

hwmon: (powr1220) Upgrade driver to support hwmon info infrastructure

Reduce code by using devm_hwmon_device_register_with_groups() API by
devm_hwmon_device_register_with_info() API.
The motivation is to reduce code and to allow easy support for similar
devices by the same driver.
Signed-off-by: default avatarMichael Shych <michaelsh@nvidia.com>
Reviewed-by: default avatarVadim Pasternak <vadimp@nvidia.com>
Link: https://lore.kernel.org/r/20220118075611.10665-3-michaelsh@nvidia.comSigned-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
parent 15b1c188
...@@ -167,135 +167,109 @@ static int powr1220_read_adc(struct device *dev, int ch_num) ...@@ -167,135 +167,109 @@ static int powr1220_read_adc(struct device *dev, int ch_num)
return result; return result;
} }
/* Shows the voltage associated with the specified ADC channel */ static umode_t
static ssize_t powr1220_voltage_show(struct device *dev, powr1220_is_visible(const void *data, enum hwmon_sensor_types type, u32
struct device_attribute *dev_attr, attr, int channel)
char *buf)
{ {
struct sensor_device_attribute *attr = to_sensor_dev_attr(dev_attr); switch (type) {
int adc_val = powr1220_read_adc(dev, attr->index); case hwmon_in:
switch (attr) {
if (adc_val < 0) case hwmon_in_input:
return adc_val; case hwmon_in_highest:
case hwmon_in_label:
return 0444;
default:
break;
}
break;
default:
break;
}
return sprintf(buf, "%d\n", adc_val); return 0;
} }
/* Shows the maximum setting associated with the specified ADC channel */ static int
static ssize_t powr1220_max_show(struct device *dev, powr1220_read_string(struct device *dev, enum hwmon_sensor_types type, u32 attr,
struct device_attribute *dev_attr, char *buf) int channel, const char **str)
{ {
struct sensor_device_attribute *attr = to_sensor_dev_attr(dev_attr); switch (type) {
struct powr1220_data *data = dev_get_drvdata(dev); case hwmon_in:
switch (attr) {
case hwmon_in_label:
*str = input_names[channel];
return 0;
default:
return -EOPNOTSUPP;
}
break;
default:
return -EOPNOTSUPP;
}
return sprintf(buf, "%d\n", data->adc_maxes[attr->index]); return -EOPNOTSUPP;
} }
/* Shows the label associated with the specified ADC channel */ static int
static ssize_t powr1220_label_show(struct device *dev, powr1220_read(struct device *dev, enum hwmon_sensor_types type, u32
struct device_attribute *dev_attr, attr, int channel, long *val)
char *buf)
{ {
struct sensor_device_attribute *attr = to_sensor_dev_attr(dev_attr); struct powr1220_data *data = dev_get_drvdata(dev);
int ret;
switch (type) {
case hwmon_in:
switch (attr) {
case hwmon_in_input:
ret = powr1220_read_adc(dev, channel);
if (ret < 0)
return ret;
*val = ret;
break;
case hwmon_in_highest:
*val = data->adc_maxes[channel];
break;
default:
return -EOPNOTSUPP;
}
break;
default:
return -EOPNOTSUPP;
}
return sprintf(buf, "%s\n", input_names[attr->index]); return 0;
} }
static SENSOR_DEVICE_ATTR_RO(in0_input, powr1220_voltage, VMON1); static const struct hwmon_channel_info *powr1220_info[] = {
static SENSOR_DEVICE_ATTR_RO(in1_input, powr1220_voltage, VMON2); HWMON_CHANNEL_INFO(in,
static SENSOR_DEVICE_ATTR_RO(in2_input, powr1220_voltage, VMON3); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in3_input, powr1220_voltage, VMON4); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in4_input, powr1220_voltage, VMON5); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in5_input, powr1220_voltage, VMON6); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in6_input, powr1220_voltage, VMON7); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in7_input, powr1220_voltage, VMON8); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in8_input, powr1220_voltage, VMON9); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in9_input, powr1220_voltage, VMON10); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in10_input, powr1220_voltage, VMON11); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in11_input, powr1220_voltage, VMON12); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in12_input, powr1220_voltage, VCCA); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in13_input, powr1220_voltage, VCCINP); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL,
static SENSOR_DEVICE_ATTR_RO(in0_highest, powr1220_max, VMON1); HWMON_I_INPUT | HWMON_I_HIGHEST | HWMON_I_LABEL),
static SENSOR_DEVICE_ATTR_RO(in1_highest, powr1220_max, VMON2);
static SENSOR_DEVICE_ATTR_RO(in2_highest, powr1220_max, VMON3);
static SENSOR_DEVICE_ATTR_RO(in3_highest, powr1220_max, VMON4);
static SENSOR_DEVICE_ATTR_RO(in4_highest, powr1220_max, VMON5);
static SENSOR_DEVICE_ATTR_RO(in5_highest, powr1220_max, VMON6);
static SENSOR_DEVICE_ATTR_RO(in6_highest, powr1220_max, VMON7);
static SENSOR_DEVICE_ATTR_RO(in7_highest, powr1220_max, VMON8);
static SENSOR_DEVICE_ATTR_RO(in8_highest, powr1220_max, VMON9);
static SENSOR_DEVICE_ATTR_RO(in9_highest, powr1220_max, VMON10);
static SENSOR_DEVICE_ATTR_RO(in10_highest, powr1220_max, VMON11);
static SENSOR_DEVICE_ATTR_RO(in11_highest, powr1220_max, VMON12);
static SENSOR_DEVICE_ATTR_RO(in12_highest, powr1220_max, VCCA);
static SENSOR_DEVICE_ATTR_RO(in13_highest, powr1220_max, VCCINP);
static SENSOR_DEVICE_ATTR_RO(in0_label, powr1220_label, VMON1);
static SENSOR_DEVICE_ATTR_RO(in1_label, powr1220_label, VMON2);
static SENSOR_DEVICE_ATTR_RO(in2_label, powr1220_label, VMON3);
static SENSOR_DEVICE_ATTR_RO(in3_label, powr1220_label, VMON4);
static SENSOR_DEVICE_ATTR_RO(in4_label, powr1220_label, VMON5);
static SENSOR_DEVICE_ATTR_RO(in5_label, powr1220_label, VMON6);
static SENSOR_DEVICE_ATTR_RO(in6_label, powr1220_label, VMON7);
static SENSOR_DEVICE_ATTR_RO(in7_label, powr1220_label, VMON8);
static SENSOR_DEVICE_ATTR_RO(in8_label, powr1220_label, VMON9);
static SENSOR_DEVICE_ATTR_RO(in9_label, powr1220_label, VMON10);
static SENSOR_DEVICE_ATTR_RO(in10_label, powr1220_label, VMON11);
static SENSOR_DEVICE_ATTR_RO(in11_label, powr1220_label, VMON12);
static SENSOR_DEVICE_ATTR_RO(in12_label, powr1220_label, VCCA);
static SENSOR_DEVICE_ATTR_RO(in13_label, powr1220_label, VCCINP);
static struct attribute *powr1220_attrs[] = {
&sensor_dev_attr_in0_input.dev_attr.attr,
&sensor_dev_attr_in1_input.dev_attr.attr,
&sensor_dev_attr_in2_input.dev_attr.attr,
&sensor_dev_attr_in3_input.dev_attr.attr,
&sensor_dev_attr_in4_input.dev_attr.attr,
&sensor_dev_attr_in5_input.dev_attr.attr,
&sensor_dev_attr_in6_input.dev_attr.attr,
&sensor_dev_attr_in7_input.dev_attr.attr,
&sensor_dev_attr_in8_input.dev_attr.attr,
&sensor_dev_attr_in9_input.dev_attr.attr,
&sensor_dev_attr_in10_input.dev_attr.attr,
&sensor_dev_attr_in11_input.dev_attr.attr,
&sensor_dev_attr_in12_input.dev_attr.attr,
&sensor_dev_attr_in13_input.dev_attr.attr,
&sensor_dev_attr_in0_highest.dev_attr.attr,
&sensor_dev_attr_in1_highest.dev_attr.attr,
&sensor_dev_attr_in2_highest.dev_attr.attr,
&sensor_dev_attr_in3_highest.dev_attr.attr,
&sensor_dev_attr_in4_highest.dev_attr.attr,
&sensor_dev_attr_in5_highest.dev_attr.attr,
&sensor_dev_attr_in6_highest.dev_attr.attr,
&sensor_dev_attr_in7_highest.dev_attr.attr,
&sensor_dev_attr_in8_highest.dev_attr.attr,
&sensor_dev_attr_in9_highest.dev_attr.attr,
&sensor_dev_attr_in10_highest.dev_attr.attr,
&sensor_dev_attr_in11_highest.dev_attr.attr,
&sensor_dev_attr_in12_highest.dev_attr.attr,
&sensor_dev_attr_in13_highest.dev_attr.attr,
&sensor_dev_attr_in0_label.dev_attr.attr,
&sensor_dev_attr_in1_label.dev_attr.attr,
&sensor_dev_attr_in2_label.dev_attr.attr,
&sensor_dev_attr_in3_label.dev_attr.attr,
&sensor_dev_attr_in4_label.dev_attr.attr,
&sensor_dev_attr_in5_label.dev_attr.attr,
&sensor_dev_attr_in6_label.dev_attr.attr,
&sensor_dev_attr_in7_label.dev_attr.attr,
&sensor_dev_attr_in8_label.dev_attr.attr,
&sensor_dev_attr_in9_label.dev_attr.attr,
&sensor_dev_attr_in10_label.dev_attr.attr,
&sensor_dev_attr_in11_label.dev_attr.attr,
&sensor_dev_attr_in12_label.dev_attr.attr,
&sensor_dev_attr_in13_label.dev_attr.attr,
NULL NULL
}; };
ATTRIBUTE_GROUPS(powr1220); static const struct hwmon_ops powr1220_hwmon_ops = {
.read = powr1220_read,
.read_string = powr1220_read_string,
.is_visible = powr1220_is_visible,
};
static const struct hwmon_chip_info powr1220_chip_info = {
.ops = &powr1220_hwmon_ops,
.info = powr1220_info,
};
static int powr1220_probe(struct i2c_client *client) static int powr1220_probe(struct i2c_client *client)
{ {
...@@ -312,8 +286,11 @@ static int powr1220_probe(struct i2c_client *client) ...@@ -312,8 +286,11 @@ static int powr1220_probe(struct i2c_client *client)
mutex_init(&data->update_lock); mutex_init(&data->update_lock);
data->client = client; data->client = client;
hwmon_dev = devm_hwmon_device_register_with_groups(&client->dev, hwmon_dev = devm_hwmon_device_register_with_info(&client->dev,
client->name, data, powr1220_groups); client->name,
data,
&powr1220_chip_info,
NULL);
return PTR_ERR_OR_ZERO(hwmon_dev); return PTR_ERR_OR_ZERO(hwmon_dev);
} }
......
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