diff options
author | Robert Richter <robert.richter@amd.com> | 2009-06-03 13:09:27 -0400 |
---|---|---|
committer | Robert Richter <robert.richter@amd.com> | 2009-06-11 14:12:57 -0400 |
commit | 95e74e62c1540b1115fe8cec5b592f22960f2bb2 (patch) | |
tree | c9f821446c4e50642b29cf0618168ba839ff7735 /arch | |
parent | bbc5986d2db427fdd61b6116ff8b9ed988e663a8 (diff) |
x86/oprofile: use 64 bit values to save MSR states
This patch removes struct op_saved_msr and replaces it by an u64
variable. This makes code easier and it is possible to use 64 bit MSR
functions.
Signed-off-by: Robert Richter <robert.richter@amd.com>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/x86/oprofile/nmi_int.c | 28 | ||||
-rw-r--r-- | arch/x86/oprofile/op_x86_model.h | 9 |
2 files changed, 10 insertions, 27 deletions
diff --git a/arch/x86/oprofile/nmi_int.c b/arch/x86/oprofile/nmi_int.c index 388ee15e0e42..3b84b789de0b 100644 --- a/arch/x86/oprofile/nmi_int.c +++ b/arch/x86/oprofile/nmi_int.c | |||
@@ -78,19 +78,13 @@ static void nmi_cpu_save_registers(struct op_msrs *msrs) | |||
78 | unsigned int i; | 78 | unsigned int i; |
79 | 79 | ||
80 | for (i = 0; i < nr_ctrs; ++i) { | 80 | for (i = 0; i < nr_ctrs; ++i) { |
81 | if (counters[i].addr) { | 81 | if (counters[i].addr) |
82 | rdmsr(counters[i].addr, | 82 | rdmsrl(counters[i].addr, counters[i].saved); |
83 | counters[i].saved.low, | ||
84 | counters[i].saved.high); | ||
85 | } | ||
86 | } | 83 | } |
87 | 84 | ||
88 | for (i = 0; i < nr_ctrls; ++i) { | 85 | for (i = 0; i < nr_ctrls; ++i) { |
89 | if (controls[i].addr) { | 86 | if (controls[i].addr) |
90 | rdmsr(controls[i].addr, | 87 | rdmsrl(controls[i].addr, controls[i].saved); |
91 | controls[i].saved.low, | ||
92 | controls[i].saved.high); | ||
93 | } | ||
94 | } | 88 | } |
95 | } | 89 | } |
96 | 90 | ||
@@ -204,19 +198,13 @@ static void nmi_restore_registers(struct op_msrs *msrs) | |||
204 | unsigned int i; | 198 | unsigned int i; |
205 | 199 | ||
206 | for (i = 0; i < nr_ctrls; ++i) { | 200 | for (i = 0; i < nr_ctrls; ++i) { |
207 | if (controls[i].addr) { | 201 | if (controls[i].addr) |
208 | wrmsr(controls[i].addr, | 202 | wrmsrl(controls[i].addr, controls[i].saved); |
209 | controls[i].saved.low, | ||
210 | controls[i].saved.high); | ||
211 | } | ||
212 | } | 203 | } |
213 | 204 | ||
214 | for (i = 0; i < nr_ctrs; ++i) { | 205 | for (i = 0; i < nr_ctrs; ++i) { |
215 | if (counters[i].addr) { | 206 | if (counters[i].addr) |
216 | wrmsr(counters[i].addr, | 207 | wrmsrl(counters[i].addr, counters[i].saved); |
217 | counters[i].saved.low, | ||
218 | counters[i].saved.high); | ||
219 | } | ||
220 | } | 208 | } |
221 | } | 209 | } |
222 | 210 | ||
diff --git a/arch/x86/oprofile/op_x86_model.h b/arch/x86/oprofile/op_x86_model.h index 69f1eb46e1b3..fda52b4c1b95 100644 --- a/arch/x86/oprofile/op_x86_model.h +++ b/arch/x86/oprofile/op_x86_model.h | |||
@@ -15,14 +15,9 @@ | |||
15 | #include <asm/types.h> | 15 | #include <asm/types.h> |
16 | #include <asm/intel_arch_perfmon.h> | 16 | #include <asm/intel_arch_perfmon.h> |
17 | 17 | ||
18 | struct op_saved_msr { | ||
19 | unsigned int high; | ||
20 | unsigned int low; | ||
21 | }; | ||
22 | |||
23 | struct op_msr { | 18 | struct op_msr { |
24 | unsigned long addr; | 19 | unsigned long addr; |
25 | struct op_saved_msr saved; | 20 | u64 saved; |
26 | }; | 21 | }; |
27 | 22 | ||
28 | struct op_msrs { | 23 | struct op_msrs { |