Lines Matching full:hwmon
3 * thermal_hwmon.c - Generic Thermal Management hwmon support.
15 #include <linux/hwmon.h>
22 /* hwmon sys I/F */
23 /* thermal zone devices with the same type share one hwmon device */
41 struct thermal_hwmon_attr temp_input; /* hwmon sys attr */
42 struct thermal_hwmon_attr temp_crit; /* hwmon sys attr */
94 struct thermal_hwmon_device *hwmon; in thermal_hwmon_lookup_by_type() local
98 list_for_each_entry(hwmon, &thermal_hwmon_list, node) { in thermal_hwmon_lookup_by_type()
101 if (!strcmp(hwmon->type, type)) { in thermal_hwmon_lookup_by_type()
103 return hwmon; in thermal_hwmon_lookup_by_type()
113 thermal_hwmon_lookup_temp(const struct thermal_hwmon_device *hwmon, in thermal_hwmon_lookup_temp() argument
119 list_for_each_entry(temp, &hwmon->tz_list, hwmon_node) in thermal_hwmon_lookup_temp()
137 struct thermal_hwmon_device *hwmon; in thermal_add_hwmon_sysfs() local
142 hwmon = thermal_hwmon_lookup_by_type(tz); in thermal_add_hwmon_sysfs()
143 if (hwmon) { in thermal_add_hwmon_sysfs()
148 hwmon = kzalloc(sizeof(*hwmon), GFP_KERNEL); in thermal_add_hwmon_sysfs()
149 if (!hwmon) in thermal_add_hwmon_sysfs()
152 INIT_LIST_HEAD(&hwmon->tz_list); in thermal_add_hwmon_sysfs()
153 strscpy(hwmon->type, tz->type, THERMAL_NAME_LENGTH); in thermal_add_hwmon_sysfs()
154 strreplace(hwmon->type, '-', '_'); in thermal_add_hwmon_sysfs()
155 hwmon->device = hwmon_device_register_for_thermal(&tz->device, in thermal_add_hwmon_sysfs()
156 hwmon->type, hwmon); in thermal_add_hwmon_sysfs()
157 if (IS_ERR(hwmon->device)) { in thermal_add_hwmon_sysfs()
158 result = PTR_ERR(hwmon->device); in thermal_add_hwmon_sysfs()
170 hwmon->count++; in thermal_add_hwmon_sysfs()
173 "temp%d_input", hwmon->count); in thermal_add_hwmon_sysfs()
178 result = device_create_file(hwmon->device, &temp->temp_input.attr); in thermal_add_hwmon_sysfs()
185 "temp%d_crit", hwmon->count); in thermal_add_hwmon_sysfs()
190 result = device_create_file(hwmon->device, in thermal_add_hwmon_sysfs()
198 list_add_tail(&hwmon->node, &thermal_hwmon_list); in thermal_add_hwmon_sysfs()
199 list_add_tail(&temp->hwmon_node, &hwmon->tz_list); in thermal_add_hwmon_sysfs()
205 device_remove_file(hwmon->device, &temp->temp_input.attr); in thermal_add_hwmon_sysfs()
210 hwmon_device_unregister(hwmon->device); in thermal_add_hwmon_sysfs()
212 kfree(hwmon); in thermal_add_hwmon_sysfs()
220 struct thermal_hwmon_device *hwmon; in thermal_remove_hwmon_sysfs() local
223 hwmon = thermal_hwmon_lookup_by_type(tz); in thermal_remove_hwmon_sysfs()
224 if (unlikely(!hwmon)) { in thermal_remove_hwmon_sysfs()
226 dev_dbg(&tz->device, "hwmon device lookup failed!\n"); in thermal_remove_hwmon_sysfs()
230 temp = thermal_hwmon_lookup_temp(hwmon, tz); in thermal_remove_hwmon_sysfs()
237 device_remove_file(hwmon->device, &temp->temp_input.attr); in thermal_remove_hwmon_sysfs()
239 device_remove_file(hwmon->device, &temp->temp_crit.attr); in thermal_remove_hwmon_sysfs()
244 if (!list_empty(&hwmon->tz_list)) { in thermal_remove_hwmon_sysfs()
248 list_del(&hwmon->node); in thermal_remove_hwmon_sysfs()
251 hwmon_device_unregister(hwmon->device); in thermal_remove_hwmon_sysfs()
252 kfree(hwmon); in thermal_remove_hwmon_sysfs()
275 dev_warn(dev, "Failed to add hwmon sysfs attributes\n"); in devm_thermal_add_hwmon_sysfs()