diff options
| author | Russell King <rmk+kernel@arm.linux.org.uk> | 2009-12-06 12:00:33 -0500 |
|---|---|---|
| committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2009-12-06 12:00:33 -0500 |
| commit | 3d14b5beba35250c548d3851a2b84fce742d8311 (patch) | |
| tree | 065e3d93c3fcbc5ee4c44fa78662393cddbdf6de /arch/x86/lib/msr.c | |
| parent | 0719dc341389882cc834ed18fc9b7fc6006b2b85 (diff) | |
| parent | 1bf8e6219552d5dd27012d567ec8c4bb9c2d86b4 (diff) | |
Merge branch 'sa1100' into devel
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 | ||
