Lines Matching refs:tdata

109 	struct temp_data *tdata = pdata->core_data[attr->index];  in show_label()  local
111 if (tdata->is_pkg_data) in show_label()
114 return sprintf(buf, "Core %u\n", tdata->cpu_core_id); in show_label()
123 struct temp_data *tdata = pdata->core_data[attr->index]; in show_crit_alarm() local
125 mutex_lock(&tdata->update_lock); in show_crit_alarm()
126 rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx); in show_crit_alarm()
127 mutex_unlock(&tdata->update_lock); in show_crit_alarm()
156 struct temp_data *tdata = pdata->core_data[attr->index]; in show_temp() local
158 mutex_lock(&tdata->update_lock); in show_temp()
161 if (!tdata->valid || time_after(jiffies, tdata->last_updated + HZ)) { in show_temp()
162 rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx); in show_temp()
169 tdata->temp = tdata->tjmax - ((eax >> 16) & 0x7f) * 1000; in show_temp()
170 tdata->valid = true; in show_temp()
171 tdata->last_updated = jiffies; in show_temp()
174 mutex_unlock(&tdata->update_lock); in show_temp()
175 return sprintf(buf, "%d\n", tdata->temp); in show_temp()
380 static int create_core_attrs(struct temp_data *tdata, struct device *dev, in create_core_attrs() argument
392 for (i = 0; i < tdata->attr_size; i++) { in create_core_attrs()
393 snprintf(tdata->attr_name[i], CORETEMP_NAME_LENGTH, in create_core_attrs()
395 sysfs_attr_init(&tdata->sd_attrs[i].dev_attr.attr); in create_core_attrs()
396 tdata->sd_attrs[i].dev_attr.attr.name = tdata->attr_name[i]; in create_core_attrs()
397 tdata->sd_attrs[i].dev_attr.attr.mode = 0444; in create_core_attrs()
398 tdata->sd_attrs[i].dev_attr.show = rd_ptr[i]; in create_core_attrs()
399 tdata->sd_attrs[i].index = attr_no; in create_core_attrs()
400 tdata->attrs[i] = &tdata->sd_attrs[i].dev_attr.attr; in create_core_attrs()
402 tdata->attr_group.attrs = tdata->attrs; in create_core_attrs()
403 return sysfs_create_group(&dev->kobj, &tdata->attr_group); in create_core_attrs()
434 struct temp_data *tdata; in init_temp_data() local
436 tdata = kzalloc(sizeof(struct temp_data), GFP_KERNEL); in init_temp_data()
437 if (!tdata) in init_temp_data()
440 tdata->status_reg = pkg_flag ? MSR_IA32_PACKAGE_THERM_STATUS : in init_temp_data()
442 tdata->is_pkg_data = pkg_flag; in init_temp_data()
443 tdata->cpu = cpu; in init_temp_data()
444 tdata->cpu_core_id = TO_CORE_ID(cpu); in init_temp_data()
445 tdata->attr_size = MAX_CORE_ATTRS; in init_temp_data()
446 mutex_init(&tdata->update_lock); in init_temp_data()
447 return tdata; in init_temp_data()
453 struct temp_data *tdata; in create_core_data() local
470 tdata = init_temp_data(cpu, pkg_flag); in create_core_data()
471 if (!tdata) in create_core_data()
475 err = rdmsr_safe_on_cpu(cpu, tdata->status_reg, &eax, &edx); in create_core_data()
480 tdata->tjmax = get_tjmax(c, cpu, &pdev->dev); in create_core_data()
491 tdata->ttarget in create_core_data()
492 = tdata->tjmax - ((eax >> 8) & 0xff) * 1000; in create_core_data()
493 tdata->attr_size++; in create_core_data()
497 pdata->core_data[attr_no] = tdata; in create_core_data()
500 err = create_core_attrs(tdata, pdata->hwmon_dev, attr_no); in create_core_data()
507 kfree(tdata); in create_core_data()
520 struct temp_data *tdata = pdata->core_data[indx]; in coretemp_remove_core() local
523 sysfs_remove_group(&pdata->hwmon_dev->kobj, &tdata->attr_group); in coretemp_remove_core()
649 struct temp_data *tdata; in coretemp_cpu_offline() local
669 tdata = pd->core_data[indx]; in coretemp_cpu_offline()
681 } else if (tdata && tdata->cpu == cpu) { in coretemp_cpu_offline()
682 mutex_lock(&tdata->update_lock); in coretemp_cpu_offline()
683 tdata->cpu = target; in coretemp_cpu_offline()
684 mutex_unlock(&tdata->update_lock); in coretemp_cpu_offline()
702 tdata = pd->core_data[PKG_SYSFS_ATTR_NO]; in coretemp_cpu_offline()
703 if (tdata && tdata->cpu == cpu) { in coretemp_cpu_offline()
705 mutex_lock(&tdata->update_lock); in coretemp_cpu_offline()
706 tdata->cpu = target; in coretemp_cpu_offline()
707 mutex_unlock(&tdata->update_lock); in coretemp_cpu_offline()