drivers-hwmon-coretemp-c-detect-the-thermal-sensors-by-cpuid.patch (#625734)
This commit is contained in:
parent
905bf1d52c
commit
7533b162d1
|
@ -0,0 +1,67 @@
|
||||||
|
From: Carsten Emde <C.Emde@osadl.org>
|
||||||
|
Date: Mon, 24 May 2010 21:33:39 +0000 (-0700)
|
||||||
|
Subject: drivers/hwmon/coretemp.c: detect the thermal sensors by CPUID
|
||||||
|
X-Git-Tag: v2.6.35-rc1~297
|
||||||
|
X-Git-Url: http://git.kernel.org/?p=linux%2Fkernel%2Fgit%2Ftorvalds%2Flinux-2.6.git;a=commitdiff_plain;h=5db47b009d17d69a2f8d84357e7b24c3e3c2edec
|
||||||
|
|
||||||
|
drivers/hwmon/coretemp.c: detect the thermal sensors by CPUID
|
||||||
|
|
||||||
|
The thermal sensors of Intel(R) CPUs can be detected by CPUID instruction,
|
||||||
|
indicated by CPUID.06H.EAX[0].
|
||||||
|
|
||||||
|
Signed-off-by: Huaxu Wan <huaxu.wan@linux.intel.com>
|
||||||
|
Signed-off-by: Carsten Emde <C.Emde@osadl.org>
|
||||||
|
Reviewed-by: Valdis Kletnieks <valdis.kletnieks@vt.edu>
|
||||||
|
Cc: Jean Delvare <khali@linux-fr.org>
|
||||||
|
Cc: Henrique de Moraes Holschuh <hmh@hmh.eng.br>
|
||||||
|
Cc: Yong Wang <yong.y.wang@linux.intel.com>
|
||||||
|
Cc: Rudolf Marek <r.marek@assembler.cz>
|
||||||
|
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
|
||||||
|
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
|
||||||
|
---
|
||||||
|
|
||||||
|
diff --git a/drivers/hwmon/coretemp.c b/drivers/hwmon/coretemp.c
|
||||||
|
index e9b7fbc..9fae7cb 100644
|
||||||
|
--- a/drivers/hwmon/coretemp.c
|
||||||
|
+++ b/drivers/hwmon/coretemp.c
|
||||||
|
@@ -451,28 +451,20 @@ static int __init coretemp_init(void)
|
||||||
|
|
||||||
|
for_each_online_cpu(i) {
|
||||||
|
struct cpuinfo_x86 *c = &cpu_data(i);
|
||||||
|
+ /*
|
||||||
|
+ * CPUID.06H.EAX[0] indicates whether the CPU has thermal
|
||||||
|
+ * sensors. We check this bit only, all the early CPUs
|
||||||
|
+ * without thermal sensors will be filtered out.
|
||||||
|
+ */
|
||||||
|
+ if (c->cpuid_level >= 6 && (cpuid_eax(0x06) & 0x01)) {
|
||||||
|
+ err = coretemp_device_add(i);
|
||||||
|
+ if (err)
|
||||||
|
+ goto exit_devices_unreg;
|
||||||
|
|
||||||
|
- /* check if family 6, models 0xe (Pentium M DC),
|
||||||
|
- 0xf (Core 2 DC 65nm), 0x16 (Core 2 SC 65nm),
|
||||||
|
- 0x17 (Penryn 45nm), 0x1a (Nehalem), 0x1c (Atom),
|
||||||
|
- 0x1e (Lynnfield) */
|
||||||
|
- if ((c->cpuid_level < 0) || (c->x86 != 0x6) ||
|
||||||
|
- !((c->x86_model == 0xe) || (c->x86_model == 0xf) ||
|
||||||
|
- (c->x86_model == 0x16) || (c->x86_model == 0x17) ||
|
||||||
|
- (c->x86_model == 0x1a) || (c->x86_model == 0x1c) ||
|
||||||
|
- (c->x86_model == 0x1e))) {
|
||||||
|
-
|
||||||
|
- /* supported CPU not found, but report the unknown
|
||||||
|
- family 6 CPU */
|
||||||
|
- if ((c->x86 == 0x6) && (c->x86_model > 0xf))
|
||||||
|
- printk(KERN_WARNING DRVNAME ": Unknown CPU "
|
||||||
|
- "model 0x%x\n", c->x86_model);
|
||||||
|
- continue;
|
||||||
|
+ } else {
|
||||||
|
+ printk(KERN_INFO DRVNAME ": CPU (model=0x%x)"
|
||||||
|
+ " has no thermal sensor.\n", c->x86_model);
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- err = coretemp_device_add(i);
|
||||||
|
- if (err)
|
||||||
|
- goto exit_devices_unreg;
|
||||||
|
}
|
||||||
|
if (list_empty(&pdev_list)) {
|
||||||
|
err = -ENODEV;
|
|
@ -763,6 +763,8 @@ Patch12440: direct-io-move-aio_complete-into-end_io.patch
|
||||||
Patch12450: ext4-move-aio-completion-after-unwritten-extent-conversion.patch
|
Patch12450: ext4-move-aio-completion-after-unwritten-extent-conversion.patch
|
||||||
Patch12460: xfs-move-aio-completion-after-unwritten-extent-conversion.patch
|
Patch12460: xfs-move-aio-completion-after-unwritten-extent-conversion.patch
|
||||||
|
|
||||||
|
Patch12470: drivers-hwmon-coretemp-c-detect-the-thermal-sensors-by-cpuid.patch
|
||||||
|
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
BuildRoot: %{_tmppath}/kernel-%{KVERREL}-root
|
BuildRoot: %{_tmppath}/kernel-%{KVERREL}-root
|
||||||
|
@ -1415,6 +1417,9 @@ ApplyPatch direct-io-move-aio_complete-into-end_io.patch
|
||||||
ApplyPatch ext4-move-aio-completion-after-unwritten-extent-conversion.patch
|
ApplyPatch ext4-move-aio-completion-after-unwritten-extent-conversion.patch
|
||||||
ApplyPatch xfs-move-aio-completion-after-unwritten-extent-conversion.patch
|
ApplyPatch xfs-move-aio-completion-after-unwritten-extent-conversion.patch
|
||||||
|
|
||||||
|
# bz #625734
|
||||||
|
ApplyPatch drivers-hwmon-coretemp-c-detect-the-thermal-sensors-by-cpuid.patch
|
||||||
|
|
||||||
# END OF PATCH APPLICATIONS
|
# END OF PATCH APPLICATIONS
|
||||||
|
|
||||||
%endif
|
%endif
|
||||||
|
@ -2038,6 +2043,7 @@ fi
|
||||||
%changelog
|
%changelog
|
||||||
* Fri Aug 27 2010 Chuck Ebbert <cebbert@redhat.com> 2.6.34.6-47
|
* Fri Aug 27 2010 Chuck Ebbert <cebbert@redhat.com> 2.6.34.6-47
|
||||||
- Linux 2.6.34.6
|
- Linux 2.6.34.6
|
||||||
|
- drivers-hwmon-coretemp-c-detect-the-thermal-sensors-by-cpuid.patch (#625734)
|
||||||
|
|
||||||
* Wed Aug 25 2010 Chuck Ebbert <cebbert@redhat.com> 2.6.34.6-46.rc1
|
* Wed Aug 25 2010 Chuck Ebbert <cebbert@redhat.com> 2.6.34.6-46.rc1
|
||||||
- Linux 2.6.34.6-rc1
|
- Linux 2.6.34.6-rc1
|
||||||
|
|
Loading…
Reference in New Issue