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 */
100 struct thermal_hwmon_device *hwmon; in thermal_hwmon_lookup_by_type() local
104 list_for_each_entry(hwmon, &thermal_hwmon_list, node) { in thermal_hwmon_lookup_by_type()
107 if (!strcmp(hwmon->type, type)) { in thermal_hwmon_lookup_by_type()
109 return hwmon; in thermal_hwmon_lookup_by_type()
119 thermal_hwmon_lookup_temp(const struct thermal_hwmon_device *hwmon, in thermal_hwmon_lookup_temp() argument
125 list_for_each_entry(temp, &hwmon->tz_list, hwmon_node) in thermal_hwmon_lookup_temp()
143 struct thermal_hwmon_device *hwmon; in thermal_add_hwmon_sysfs() local
148 hwmon = thermal_hwmon_lookup_by_type(tz); in thermal_add_hwmon_sysfs()
149 if (hwmon) { in thermal_add_hwmon_sysfs()
154 hwmon = kzalloc(sizeof(*hwmon), GFP_KERNEL); in thermal_add_hwmon_sysfs()
155 if (!hwmon) in thermal_add_hwmon_sysfs()
158 INIT_LIST_HEAD(&hwmon->tz_list); in thermal_add_hwmon_sysfs()
159 strscpy(hwmon->type, tz->type, THERMAL_NAME_LENGTH); in thermal_add_hwmon_sysfs()
160 strreplace(hwmon->type, '-', '_'); in thermal_add_hwmon_sysfs()
161 hwmon->device = hwmon_device_register_for_thermal(&tz->device, in thermal_add_hwmon_sysfs()
162 hwmon->type, hwmon); in thermal_add_hwmon_sysfs()
163 if (IS_ERR(hwmon->device)) { in thermal_add_hwmon_sysfs()
164 result = PTR_ERR(hwmon->device); in thermal_add_hwmon_sysfs()
176 hwmon->count++; in thermal_add_hwmon_sysfs()
179 "temp%d_input", hwmon->count); in thermal_add_hwmon_sysfs()
184 result = device_create_file(hwmon->device, &temp->temp_input.attr); in thermal_add_hwmon_sysfs()
191 "temp%d_crit", hwmon->count); in thermal_add_hwmon_sysfs()
196 result = device_create_file(hwmon->device, in thermal_add_hwmon_sysfs()
204 list_add_tail(&hwmon->node, &thermal_hwmon_list); in thermal_add_hwmon_sysfs()
205 list_add_tail(&temp->hwmon_node, &hwmon->tz_list); in thermal_add_hwmon_sysfs()
211 device_remove_file(hwmon->device, &temp->temp_input.attr); in thermal_add_hwmon_sysfs()
216 hwmon_device_unregister(hwmon->device); in thermal_add_hwmon_sysfs()
218 kfree(hwmon); in thermal_add_hwmon_sysfs()
226 struct thermal_hwmon_device *hwmon; in thermal_remove_hwmon_sysfs() local
229 hwmon = thermal_hwmon_lookup_by_type(tz); in thermal_remove_hwmon_sysfs()
230 if (unlikely(!hwmon)) { in thermal_remove_hwmon_sysfs()
232 dev_dbg(&tz->device, "hwmon device lookup failed!\n"); in thermal_remove_hwmon_sysfs()
236 temp = thermal_hwmon_lookup_temp(hwmon, tz); in thermal_remove_hwmon_sysfs()
243 device_remove_file(hwmon->device, &temp->temp_input.attr); in thermal_remove_hwmon_sysfs()
245 device_remove_file(hwmon->device, &temp->temp_crit.attr); in thermal_remove_hwmon_sysfs()
250 if (!list_empty(&hwmon->tz_list)) { in thermal_remove_hwmon_sysfs()
254 list_del(&hwmon->node); in thermal_remove_hwmon_sysfs()
257 hwmon_device_unregister(hwmon->device); in thermal_remove_hwmon_sysfs()
258 kfree(hwmon); in thermal_remove_hwmon_sysfs()
281 dev_warn(dev, "Failed to add hwmon sysfs attributes\n"); in devm_thermal_add_hwmon_sysfs()