diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2016-01-11 19:46:20 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-01-11 19:46:20 -0500 |
commit | 671d5532aaad777782b66eff71bc4dfad25f942d (patch) | |
tree | fdd480fbd7bd8078c60e1fe3eea98a8cefb8df67 /arch/x86/lib | |
parent | 67c707e451e12f59e57bca6cf33b5803cb74b022 (diff) | |
parent | 0007bccc3cfd1e69deb0fd73ccc426b4cedb061d (diff) |
Merge branch 'x86-cpu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull x86 cpu updates from Ingo Molnar:
"The main changes in this cycle were:
- Improved CPU ID handling code and related enhancements (Borislav
Petkov)
- RDRAND fix (Len Brown)"
* 'x86-cpu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
x86: Replace RDRAND forced-reseed with simple sanity check
x86/MSR: Chop off lower 32-bit value
x86/cpu: Fix MSR value truncation issue
x86/cpu/amd, kvm: Satisfy guest kernel reads of IC_CFG MSR
kvm: Add accessors for guest CPU's family, model, stepping
x86/cpu: Unify CPU family, model, stepping calculation
Diffstat (limited to 'arch/x86/lib')
-rw-r--r-- | arch/x86/lib/Makefile | 2 | ||||
-rw-r--r-- | arch/x86/lib/cpu.c | 35 |
2 files changed, 36 insertions, 1 deletions
diff --git a/arch/x86/lib/Makefile b/arch/x86/lib/Makefile index f2587888d987..a501fa25da41 100644 --- a/arch/x86/lib/Makefile +++ b/arch/x86/lib/Makefile | |||
@@ -16,7 +16,7 @@ clean-files := inat-tables.c | |||
16 | 16 | ||
17 | obj-$(CONFIG_SMP) += msr-smp.o cache-smp.o | 17 | obj-$(CONFIG_SMP) += msr-smp.o cache-smp.o |
18 | 18 | ||
19 | lib-y := delay.o misc.o cmdline.o | 19 | lib-y := delay.o misc.o cmdline.o cpu.o |
20 | lib-y += usercopy_$(BITS).o usercopy.o getuser.o putuser.o | 20 | lib-y += usercopy_$(BITS).o usercopy.o getuser.o putuser.o |
21 | lib-y += memcpy_$(BITS).o | 21 | lib-y += memcpy_$(BITS).o |
22 | lib-$(CONFIG_RWSEM_XCHGADD_ALGORITHM) += rwsem.o | 22 | lib-$(CONFIG_RWSEM_XCHGADD_ALGORITHM) += rwsem.o |
diff --git a/arch/x86/lib/cpu.c b/arch/x86/lib/cpu.c new file mode 100644 index 000000000000..aa417a97511c --- /dev/null +++ b/arch/x86/lib/cpu.c | |||
@@ -0,0 +1,35 @@ | |||
1 | #include <linux/module.h> | ||
2 | |||
3 | unsigned int x86_family(unsigned int sig) | ||
4 | { | ||
5 | unsigned int x86; | ||
6 | |||
7 | x86 = (sig >> 8) & 0xf; | ||
8 | |||
9 | if (x86 == 0xf) | ||
10 | x86 += (sig >> 20) & 0xff; | ||
11 | |||
12 | return x86; | ||
13 | } | ||
14 | EXPORT_SYMBOL_GPL(x86_family); | ||
15 | |||
16 | unsigned int x86_model(unsigned int sig) | ||
17 | { | ||
18 | unsigned int fam, model; | ||
19 | |||
20 | fam = x86_family(sig); | ||
21 | |||
22 | model = (sig >> 4) & 0xf; | ||
23 | |||
24 | if (fam >= 0x6) | ||
25 | model += ((sig >> 16) & 0xf) << 4; | ||
26 | |||
27 | return model; | ||
28 | } | ||
29 | EXPORT_SYMBOL_GPL(x86_model); | ||
30 | |||
31 | unsigned int x86_stepping(unsigned int sig) | ||
32 | { | ||
33 | return sig & 0xf; | ||
34 | } | ||
35 | EXPORT_SYMBOL_GPL(x86_stepping); | ||