Lines Matching +full:0 +full:x154

38 #define PCI_DEVICE_ID_AMD_15H_M70H_NB_F3	0x15b3
41 /* CPUID function 0x80000001, ebx */
43 #define CPUID_PKGTYPE_F 0x00000000
44 #define CPUID_PKGTYPE_AM2R2_AM3 0x10000000
47 #define REG_DCT0_CONFIG_HIGH 0x094
51 #define REG_HARDWARE_THERMAL_CONTROL 0x64
52 #define HTC_ENABLE BIT(0)
54 #define REG_REPORTED_TEMPERATURE 0xa4
56 #define REG_NORTHBRIDGE_CAPABILITIES 0xe8
65 #define F15H_M60H_HARDWARE_TEMP_CTRL_OFFSET 0xd8200c64
66 #define F15H_M60H_REPORTED_TEMP_CTRL_OFFSET 0xd8200ca4
69 #define ZEN_REPORTED_TEMP_CTRL_BASE 0x00059800
74 #define ZEN_CCD_TEMP_MASK GENMASK(10, 0)
99 #define TCTL_BIT 0
113 { 0x17, "AMD Ryzen 5 1600X", 20000 },
114 { 0x17, "AMD Ryzen 7 1700X", 20000 },
115 { 0x17, "AMD Ryzen 7 1800X", 20000 },
116 { 0x17, "AMD Ryzen 7 2700X", 10000 },
117 { 0x17, "AMD Ryzen Threadripper 19", 27000 }, /* 19{00,20,50}X */
118 { 0x17, "AMD Ryzen Threadripper 29", 27000 }, /* 29{20,50,70,90}[W]X */
144 amd_nb_index_read(pdev, PCI_DEVFN(0, 0), 0xb8, in read_htcreg_nb_f15()
150 amd_nb_index_read(pdev, PCI_DEVFN(0, 0), 0xb8, in read_tempreg_nb_f15()
201 return 0; in k10temp_read_labels()
213 case 0: /* Tctl */ in k10temp_read_temp()
215 if (*val < 0 && !data->disp_negative) in k10temp_read_temp()
216 *val = 0; in k10temp_read_temp()
220 if (*val < 0 && !data->disp_negative) in k10temp_read_temp()
221 *val = 0; in k10temp_read_temp()
238 *val = ((regval >> 16) & 0x7f) * 500 + 52000; in k10temp_read_temp()
242 *val = (((regval >> 16) & 0x7f) in k10temp_read_temp()
243 - ((regval >> 24) & 0xf)) * 500 + 52000; in k10temp_read_temp()
248 return 0; in k10temp_read_temp()
275 return 0; in k10temp_is_visible()
279 return 0; in k10temp_is_visible()
284 return 0; in k10temp_is_visible()
290 return 0; in k10temp_is_visible()
294 return 0; in k10temp_is_visible()
299 return 0; in k10temp_is_visible()
302 return 0; in k10temp_is_visible()
306 return 0; in k10temp_is_visible()
315 if (boot_cpu_data.x86 != 0x10) in has_erratum_319()
322 pkg_type = cpuid_ebx(0x80000001) & CPUID_PKGTYPE_MASK; in has_erratum_319()
383 for (i = 0; i < limit; i++) { in k10temp_get_ccd_support()
416 if (boot_cpu_data.x86 == 0x17 && in k10temp_probe()
421 if (boot_cpu_data.x86 == 0x15 && in k10temp_probe()
422 ((boot_cpu_data.x86_model & 0xf0) == 0x60 || in k10temp_probe()
423 (boot_cpu_data.x86_model & 0xf0) == 0x70)) { in k10temp_probe()
426 } else if (boot_cpu_data.x86 == 0x17 || boot_cpu_data.x86 == 0x18) { in k10temp_probe()
432 case 0x1: /* Zen */ in k10temp_probe()
433 case 0x8: /* Zen+ */ in k10temp_probe()
434 case 0x11: /* Zen APU */ in k10temp_probe()
435 case 0x18: /* Zen+ APU */ in k10temp_probe()
436 data->ccd_offset = 0x154; in k10temp_probe()
439 case 0x31: /* Zen2 Threadripper */ in k10temp_probe()
440 case 0x60: /* Renoir */ in k10temp_probe()
441 case 0x68: /* Lucienne */ in k10temp_probe()
442 case 0x71: /* Zen2 */ in k10temp_probe()
443 data->ccd_offset = 0x154; in k10temp_probe()
446 case 0xa0 ... 0xaf: in k10temp_probe()
447 data->ccd_offset = 0x300; in k10temp_probe()
451 } else if (boot_cpu_data.x86 == 0x19) { in k10temp_probe()
457 case 0x0 ... 0x1: /* Zen3 SP3/TR */ in k10temp_probe()
458 case 0x8: /* Zen3 TR Chagall */ in k10temp_probe()
459 case 0x21: /* Zen3 Ryzen Desktop */ in k10temp_probe()
460 case 0x50 ... 0x5f: /* Green Sardine */ in k10temp_probe()
461 data->ccd_offset = 0x154; in k10temp_probe()
464 case 0x40 ... 0x4f: /* Yellow Carp */ in k10temp_probe()
465 data->ccd_offset = 0x300; in k10temp_probe()
468 case 0x60 ... 0x6f: in k10temp_probe()
469 case 0x70 ... 0x7f: in k10temp_probe()
470 data->ccd_offset = 0x308; in k10temp_probe()
473 case 0x10 ... 0x1f: in k10temp_probe()
474 case 0xa0 ... 0xaf: in k10temp_probe()
475 data->ccd_offset = 0x300; in k10temp_probe()
479 } else if (boot_cpu_data.x86 == 0x1a) { in k10temp_probe()
488 for (i = 0; i < ARRAY_SIZE(tctl_offset_table); i++) { in k10temp_probe()