diff options
Diffstat (limited to 'arch/x86/lib/msr.c')
| -rw-r--r-- | arch/x86/lib/msr.c | 46 | 
1 files changed, 19 insertions, 27 deletions
| diff --git a/arch/x86/lib/msr.c b/arch/x86/lib/msr.c index 33a1e3ca22d8..41628b104b9e 100644 --- a/arch/x86/lib/msr.c +++ b/arch/x86/lib/msr.c | |||
| @@ -71,14 +71,9 @@ int wrmsr_on_cpu(unsigned int cpu, u32 msr_no, u32 l, u32 h) | |||
| 71 | } | 71 | } | 
| 72 | EXPORT_SYMBOL(wrmsr_on_cpu); | 72 | EXPORT_SYMBOL(wrmsr_on_cpu); | 
| 73 | 73 | ||
| 74 | /* rdmsr on a bunch of CPUs | 74 | static void __rwmsr_on_cpus(const struct cpumask *mask, u32 msr_no, | 
| 75 | * | 75 | struct msr *msrs, | 
| 76 | * @mask: which CPUs | 76 | void (*msr_func) (void *info)) | 
| 77 | * @msr_no: which MSR | ||
| 78 | * @msrs: array of MSR values | ||
| 79 | * | ||
| 80 | */ | ||
| 81 | void rdmsr_on_cpus(const cpumask_t *mask, u32 msr_no, struct msr *msrs) | ||
| 82 | { | 77 | { | 
| 83 | struct msr_info rv; | 78 | struct msr_info rv; | 
| 84 | int this_cpu; | 79 | int this_cpu; | 
| @@ -92,11 +87,23 @@ void rdmsr_on_cpus(const cpumask_t *mask, u32 msr_no, struct msr *msrs) | |||
| 92 | this_cpu = get_cpu(); | 87 | this_cpu = get_cpu(); | 
| 93 | 88 | ||
| 94 | if (cpumask_test_cpu(this_cpu, mask)) | 89 | if (cpumask_test_cpu(this_cpu, mask)) | 
| 95 | __rdmsr_on_cpu(&rv); | 90 | msr_func(&rv); | 
| 96 | 91 | ||
| 97 | smp_call_function_many(mask, __rdmsr_on_cpu, &rv, 1); | 92 | smp_call_function_many(mask, msr_func, &rv, 1); | 
| 98 | put_cpu(); | 93 | put_cpu(); | 
| 99 | } | 94 | } | 
| 95 | |||
| 96 | /* rdmsr on a bunch of CPUs | ||
| 97 | * | ||
| 98 | * @mask: which CPUs | ||
| 99 | * @msr_no: which MSR | ||
| 100 | * @msrs: array of MSR values | ||
| 101 | * | ||
| 102 | */ | ||
| 103 | void rdmsr_on_cpus(const struct cpumask *mask, u32 msr_no, struct msr *msrs) | ||
| 104 | { | ||
| 105 | __rwmsr_on_cpus(mask, msr_no, msrs, __rdmsr_on_cpu); | ||
| 106 | } | ||
| 100 | EXPORT_SYMBOL(rdmsr_on_cpus); | 107 | EXPORT_SYMBOL(rdmsr_on_cpus); | 
| 101 | 108 | ||
| 102 | /* | 109 | /* | 
| @@ -107,24 +114,9 @@ EXPORT_SYMBOL(rdmsr_on_cpus); | |||
| 107 | * @msrs: array of MSR values | 114 | * @msrs: array of MSR values | 
| 108 | * | 115 | * | 
| 109 | */ | 116 | */ | 
| 110 | void wrmsr_on_cpus(const cpumask_t *mask, u32 msr_no, struct msr *msrs) | 117 | void wrmsr_on_cpus(const struct cpumask *mask, u32 msr_no, struct msr *msrs) | 
| 111 | { | 118 | { | 
| 112 | struct msr_info rv; | 119 | __rwmsr_on_cpus(mask, msr_no, msrs, __wrmsr_on_cpu); | 
| 113 | int this_cpu; | ||
| 114 | |||
| 115 | memset(&rv, 0, sizeof(rv)); | ||
| 116 | |||
| 117 | rv.off = cpumask_first(mask); | ||
| 118 | rv.msrs = msrs; | ||
| 119 | rv.msr_no = msr_no; | ||
| 120 | |||
| 121 | this_cpu = get_cpu(); | ||
| 122 | |||
| 123 | if (cpumask_test_cpu(this_cpu, mask)) | ||
| 124 | __wrmsr_on_cpu(&rv); | ||
| 125 | |||
| 126 | smp_call_function_many(mask, __wrmsr_on_cpu, &rv, 1); | ||
| 127 | put_cpu(); | ||
| 128 | } | 120 | } | 
| 129 | EXPORT_SYMBOL(wrmsr_on_cpus); | 121 | EXPORT_SYMBOL(wrmsr_on_cpus); | 
| 130 | 122 | ||
