Lines Matching refs:tdata
124 struct temp_data *tdata = pdata->core_data[attr->index]; in show_label() local
126 if (tdata->is_pkg_data) in show_label()
129 return sprintf(buf, "Core %u\n", tdata->cpu_core_id); in show_label()
138 struct temp_data *tdata = pdata->core_data[attr->index]; in show_crit_alarm() local
140 rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx); in show_crit_alarm()
169 struct temp_data *tdata = pdata->core_data[attr->index]; in show_temp() local
171 mutex_lock(&tdata->update_lock); in show_temp()
174 if (!tdata->valid || time_after(jiffies, tdata->last_updated + HZ)) { in show_temp()
175 rdmsr_on_cpu(tdata->cpu, tdata->status_reg, &eax, &edx); in show_temp()
182 tdata->temp = tdata->tjmax - ((eax >> 16) & 0x7f) * 1000; in show_temp()
183 tdata->valid = 1; in show_temp()
184 tdata->last_updated = jiffies; in show_temp()
187 mutex_unlock(&tdata->update_lock); in show_temp()
188 return sprintf(buf, "%d\n", tdata->temp); in show_temp()
392 static int create_core_attrs(struct temp_data *tdata, struct device *dev, in create_core_attrs() argument
404 for (i = 0; i < tdata->attr_size; i++) { in create_core_attrs()
405 snprintf(tdata->attr_name[i], CORETEMP_NAME_LENGTH, in create_core_attrs()
407 sysfs_attr_init(&tdata->sd_attrs[i].dev_attr.attr); in create_core_attrs()
408 tdata->sd_attrs[i].dev_attr.attr.name = tdata->attr_name[i]; in create_core_attrs()
409 tdata->sd_attrs[i].dev_attr.attr.mode = S_IRUGO; in create_core_attrs()
410 tdata->sd_attrs[i].dev_attr.show = rd_ptr[i]; in create_core_attrs()
411 tdata->sd_attrs[i].index = attr_no; in create_core_attrs()
412 tdata->attrs[i] = &tdata->sd_attrs[i].dev_attr.attr; in create_core_attrs()
414 tdata->attr_group.attrs = tdata->attrs; in create_core_attrs()
415 return sysfs_create_group(&dev->kobj, &tdata->attr_group); in create_core_attrs()
454 struct temp_data *tdata; in init_temp_data() local
456 tdata = kzalloc(sizeof(struct temp_data), GFP_KERNEL); in init_temp_data()
457 if (!tdata) in init_temp_data()
460 tdata->status_reg = pkg_flag ? MSR_IA32_PACKAGE_THERM_STATUS : in init_temp_data()
462 tdata->is_pkg_data = pkg_flag; in init_temp_data()
463 tdata->cpu = cpu; in init_temp_data()
464 tdata->cpu_core_id = TO_CORE_ID(cpu); in init_temp_data()
465 tdata->attr_size = MAX_CORE_ATTRS; in init_temp_data()
466 mutex_init(&tdata->update_lock); in init_temp_data()
467 return tdata; in init_temp_data()
473 struct temp_data *tdata; in create_core_data() local
500 tdata = init_temp_data(cpu, pkg_flag); in create_core_data()
501 if (!tdata) in create_core_data()
505 err = rdmsr_safe_on_cpu(cpu, tdata->status_reg, &eax, &edx); in create_core_data()
510 tdata->tjmax = get_tjmax(c, cpu, &pdev->dev); in create_core_data()
521 tdata->ttarget in create_core_data()
522 = tdata->tjmax - ((eax >> 8) & 0xff) * 1000; in create_core_data()
523 tdata->attr_size++; in create_core_data()
527 pdata->core_data[attr_no] = tdata; in create_core_data()
530 err = create_core_attrs(tdata, pdata->hwmon_dev, attr_no); in create_core_data()
537 kfree(tdata); in create_core_data()
557 struct temp_data *tdata = pdata->core_data[indx]; in coretemp_remove_core() local
560 sysfs_remove_group(&pdata->hwmon_dev->kobj, &tdata->attr_group); in coretemp_remove_core()