aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc
diff options
context:
space:
mode:
authorHollis Blanchard <hollisb@us.ibm.com>2008-12-02 16:51:58 -0500
committerAvi Kivity <avi@redhat.com>2008-12-31 09:55:41 -0500
commit7b7015914b30ad8d9136d41412c5129b9bc9af70 (patch)
treec0764fff834b784d933126f30ef5562aef0dc55c /arch/powerpc
parent73e75b416ffcfa3a84952d8e389a0eca080f00e1 (diff)
KVM: ppc: mostly cosmetic updates to the exit timing accounting code
The only significant changes were to kvmppc_exit_timing_write() and kvmppc_exit_timing_show(), both of which were dramatically simplified. Signed-off-by: Hollis Blanchard <hollisb@us.ibm.com> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/powerpc')
-rw-r--r--arch/powerpc/include/asm/kvm_host.h8
-rw-r--r--arch/powerpc/kvm/44x_emulate.c4
-rw-r--r--arch/powerpc/kvm/booke.c30
-rw-r--r--arch/powerpc/kvm/timing.c109
-rw-r--r--arch/powerpc/kvm/timing.h6
5 files changed, 66 insertions, 91 deletions
diff --git a/arch/powerpc/include/asm/kvm_host.h b/arch/powerpc/include/asm/kvm_host.h
index 2f5b49f2a98e..c1e436fe7738 100644
--- a/arch/powerpc/include/asm/kvm_host.h
+++ b/arch/powerpc/include/asm/kvm_host.h
@@ -102,9 +102,8 @@ enum kvm_exit_types {
102 __NUMBER_OF_KVM_EXIT_TYPES 102 __NUMBER_OF_KVM_EXIT_TYPES
103}; 103};
104 104
105#ifdef CONFIG_KVM_EXIT_TIMING
106/* allow access to big endian 32bit upper/lower parts and 64bit var */ 105/* allow access to big endian 32bit upper/lower parts and 64bit var */
107struct exit_timing { 106struct kvmppc_exit_timing {
108 union { 107 union {
109 u64 tv64; 108 u64 tv64;
110 struct { 109 struct {
@@ -112,7 +111,6 @@ struct exit_timing {
112 } tv32; 111 } tv32;
113 }; 112 };
114}; 113};
115#endif
116 114
117struct kvm_arch { 115struct kvm_arch {
118}; 116};
@@ -174,8 +172,8 @@ struct kvm_vcpu_arch {
174 u32 dbcr1; 172 u32 dbcr1;
175 173
176#ifdef CONFIG_KVM_EXIT_TIMING 174#ifdef CONFIG_KVM_EXIT_TIMING
177 struct exit_timing timing_exit; 175 struct kvmppc_exit_timing timing_exit;
178 struct exit_timing timing_last_enter; 176 struct kvmppc_exit_timing timing_last_enter;
179 u32 last_exit_type; 177 u32 last_exit_type;
180 u32 timing_count_type[__NUMBER_OF_KVM_EXIT_TYPES]; 178 u32 timing_count_type[__NUMBER_OF_KVM_EXIT_TYPES];
181 u64 timing_sum_duration[__NUMBER_OF_KVM_EXIT_TYPES]; 179 u64 timing_sum_duration[__NUMBER_OF_KVM_EXIT_TYPES];
diff --git a/arch/powerpc/kvm/44x_emulate.c b/arch/powerpc/kvm/44x_emulate.c
index 69f88d53c428..82489a743a6f 100644
--- a/arch/powerpc/kvm/44x_emulate.c
+++ b/arch/powerpc/kvm/44x_emulate.c
@@ -132,7 +132,7 @@ int kvmppc_core_emulate_op(struct kvm_run *run, struct kvm_vcpu *vcpu,
132 run->dcr.is_write = 0; 132 run->dcr.is_write = 0;
133 vcpu->arch.io_gpr = rt; 133 vcpu->arch.io_gpr = rt;
134 vcpu->arch.dcr_needed = 1; 134 vcpu->arch.dcr_needed = 1;
135 account_exit(vcpu, DCR_EXITS); 135 kvmppc_account_exit(vcpu, DCR_EXITS);
136 emulated = EMULATE_DO_DCR; 136 emulated = EMULATE_DO_DCR;
137 } 137 }
138 138
@@ -152,7 +152,7 @@ int kvmppc_core_emulate_op(struct kvm_run *run, struct kvm_vcpu *vcpu,
152 run->dcr.data = vcpu->arch.gpr[rs]; 152 run->dcr.data = vcpu->arch.gpr[rs];
153 run->dcr.is_write = 1; 153 run->dcr.is_write = 1;
154 vcpu->arch.dcr_needed = 1; 154 vcpu->arch.dcr_needed = 1;
155 account_exit(vcpu, DCR_EXITS); 155 kvmppc_account_exit(vcpu, DCR_EXITS);
156 emulated = EMULATE_DO_DCR; 156 emulated = EMULATE_DO_DCR;
157 } 157 }
158 158
diff --git a/arch/powerpc/kvm/booke.c b/arch/powerpc/kvm/booke.c
index 0f171248e450..35485dd6927e 100644
--- a/arch/powerpc/kvm/booke.c
+++ b/arch/powerpc/kvm/booke.c
@@ -202,7 +202,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
202 break; 202 break;
203 203
204 case BOOKE_INTERRUPT_EXTERNAL: 204 case BOOKE_INTERRUPT_EXTERNAL:
205 account_exit(vcpu, EXT_INTR_EXITS); 205 kvmppc_account_exit(vcpu, EXT_INTR_EXITS);
206 if (need_resched()) 206 if (need_resched())
207 cond_resched(); 207 cond_resched();
208 r = RESUME_GUEST; 208 r = RESUME_GUEST;
@@ -212,7 +212,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
212 /* Since we switched IVPR back to the host's value, the host 212 /* Since we switched IVPR back to the host's value, the host
213 * handled this interrupt the moment we enabled interrupts. 213 * handled this interrupt the moment we enabled interrupts.
214 * Now we just offer it a chance to reschedule the guest. */ 214 * Now we just offer it a chance to reschedule the guest. */
215 account_exit(vcpu, DEC_EXITS); 215 kvmppc_account_exit(vcpu, DEC_EXITS);
216 if (need_resched()) 216 if (need_resched())
217 cond_resched(); 217 cond_resched();
218 r = RESUME_GUEST; 218 r = RESUME_GUEST;
@@ -225,7 +225,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
225 vcpu->arch.esr = vcpu->arch.fault_esr; 225 vcpu->arch.esr = vcpu->arch.fault_esr;
226 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_PROGRAM); 226 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_PROGRAM);
227 r = RESUME_GUEST; 227 r = RESUME_GUEST;
228 account_exit(vcpu, USR_PR_INST); 228 kvmppc_account_exit(vcpu, USR_PR_INST);
229 break; 229 break;
230 } 230 }
231 231
@@ -233,7 +233,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
233 switch (er) { 233 switch (er) {
234 case EMULATE_DONE: 234 case EMULATE_DONE:
235 /* don't overwrite subtypes, just account kvm_stats */ 235 /* don't overwrite subtypes, just account kvm_stats */
236 account_exit_stat(vcpu, EMULATED_INST_EXITS); 236 kvmppc_account_exit_stat(vcpu, EMULATED_INST_EXITS);
237 /* Future optimization: only reload non-volatiles if 237 /* Future optimization: only reload non-volatiles if
238 * they were actually modified by emulation. */ 238 * they were actually modified by emulation. */
239 r = RESUME_GUEST_NV; 239 r = RESUME_GUEST_NV;
@@ -259,7 +259,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
259 259
260 case BOOKE_INTERRUPT_FP_UNAVAIL: 260 case BOOKE_INTERRUPT_FP_UNAVAIL:
261 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_FP_UNAVAIL); 261 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_FP_UNAVAIL);
262 account_exit(vcpu, FP_UNAVAIL); 262 kvmppc_account_exit(vcpu, FP_UNAVAIL);
263 r = RESUME_GUEST; 263 r = RESUME_GUEST;
264 break; 264 break;
265 265
@@ -267,20 +267,20 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
267 vcpu->arch.dear = vcpu->arch.fault_dear; 267 vcpu->arch.dear = vcpu->arch.fault_dear;
268 vcpu->arch.esr = vcpu->arch.fault_esr; 268 vcpu->arch.esr = vcpu->arch.fault_esr;
269 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_DATA_STORAGE); 269 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_DATA_STORAGE);
270 account_exit(vcpu, DSI_EXITS); 270 kvmppc_account_exit(vcpu, DSI_EXITS);
271 r = RESUME_GUEST; 271 r = RESUME_GUEST;
272 break; 272 break;
273 273
274 case BOOKE_INTERRUPT_INST_STORAGE: 274 case BOOKE_INTERRUPT_INST_STORAGE:
275 vcpu->arch.esr = vcpu->arch.fault_esr; 275 vcpu->arch.esr = vcpu->arch.fault_esr;
276 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_INST_STORAGE); 276 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_INST_STORAGE);
277 account_exit(vcpu, ISI_EXITS); 277 kvmppc_account_exit(vcpu, ISI_EXITS);
278 r = RESUME_GUEST; 278 r = RESUME_GUEST;
279 break; 279 break;
280 280
281 case BOOKE_INTERRUPT_SYSCALL: 281 case BOOKE_INTERRUPT_SYSCALL:
282 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_SYSCALL); 282 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_SYSCALL);
283 account_exit(vcpu, SYSCALL_EXITS); 283 kvmppc_account_exit(vcpu, SYSCALL_EXITS);
284 r = RESUME_GUEST; 284 r = RESUME_GUEST;
285 break; 285 break;
286 286
@@ -299,7 +299,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
299 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_DTLB_MISS); 299 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_DTLB_MISS);
300 vcpu->arch.dear = vcpu->arch.fault_dear; 300 vcpu->arch.dear = vcpu->arch.fault_dear;
301 vcpu->arch.esr = vcpu->arch.fault_esr; 301 vcpu->arch.esr = vcpu->arch.fault_esr;
302 account_exit(vcpu, DTLB_REAL_MISS_EXITS); 302 kvmppc_account_exit(vcpu, DTLB_REAL_MISS_EXITS);
303 r = RESUME_GUEST; 303 r = RESUME_GUEST;
304 break; 304 break;
305 } 305 }
@@ -317,13 +317,13 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
317 * invoking the guest. */ 317 * invoking the guest. */
318 kvmppc_mmu_map(vcpu, eaddr, vcpu->arch.paddr_accessed, gtlbe->tid, 318 kvmppc_mmu_map(vcpu, eaddr, vcpu->arch.paddr_accessed, gtlbe->tid,
319 gtlbe->word2, get_tlb_bytes(gtlbe), gtlb_index); 319 gtlbe->word2, get_tlb_bytes(gtlbe), gtlb_index);
320 account_exit(vcpu, DTLB_VIRT_MISS_EXITS); 320 kvmppc_account_exit(vcpu, DTLB_VIRT_MISS_EXITS);
321 r = RESUME_GUEST; 321 r = RESUME_GUEST;
322 } else { 322 } else {
323 /* Guest has mapped and accessed a page which is not 323 /* Guest has mapped and accessed a page which is not
324 * actually RAM. */ 324 * actually RAM. */
325 r = kvmppc_emulate_mmio(run, vcpu); 325 r = kvmppc_emulate_mmio(run, vcpu);
326 account_exit(vcpu, MMIO_EXITS); 326 kvmppc_account_exit(vcpu, MMIO_EXITS);
327 } 327 }
328 328
329 break; 329 break;
@@ -345,11 +345,11 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
345 if (gtlb_index < 0) { 345 if (gtlb_index < 0) {
346 /* The guest didn't have a mapping for it. */ 346 /* The guest didn't have a mapping for it. */
347 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_ITLB_MISS); 347 kvmppc_booke_queue_irqprio(vcpu, BOOKE_IRQPRIO_ITLB_MISS);
348 account_exit(vcpu, ITLB_REAL_MISS_EXITS); 348 kvmppc_account_exit(vcpu, ITLB_REAL_MISS_EXITS);
349 break; 349 break;
350 } 350 }
351 351
352 account_exit(vcpu, ITLB_VIRT_MISS_EXITS); 352 kvmppc_account_exit(vcpu, ITLB_VIRT_MISS_EXITS);
353 353
354 gtlbe = &vcpu_44x->guest_tlb[gtlb_index]; 354 gtlbe = &vcpu_44x->guest_tlb[gtlb_index];
355 gpaddr = tlb_xlate(gtlbe, eaddr); 355 gpaddr = tlb_xlate(gtlbe, eaddr);
@@ -383,7 +383,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
383 mtspr(SPRN_DBSR, dbsr); 383 mtspr(SPRN_DBSR, dbsr);
384 384
385 run->exit_reason = KVM_EXIT_DEBUG; 385 run->exit_reason = KVM_EXIT_DEBUG;
386 account_exit(vcpu, DEBUG_EXITS); 386 kvmppc_account_exit(vcpu, DEBUG_EXITS);
387 r = RESUME_HOST; 387 r = RESUME_HOST;
388 break; 388 break;
389 } 389 }
@@ -404,7 +404,7 @@ int kvmppc_handle_exit(struct kvm_run *run, struct kvm_vcpu *vcpu,
404 if (signal_pending(current)) { 404 if (signal_pending(current)) {
405 run->exit_reason = KVM_EXIT_INTR; 405 run->exit_reason = KVM_EXIT_INTR;
406 r = (-EINTR << 2) | RESUME_HOST | (r & RESUME_FLAG_NV); 406 r = (-EINTR << 2) | RESUME_HOST | (r & RESUME_FLAG_NV);
407 account_exit(vcpu, SIGNAL_EXITS); 407 kvmppc_account_exit(vcpu, SIGNAL_EXITS);
408 } 408 }
409 } 409 }
410 410
diff --git a/arch/powerpc/kvm/timing.c b/arch/powerpc/kvm/timing.c
index f42d2728a6a5..47ee603f558e 100644
--- a/arch/powerpc/kvm/timing.c
+++ b/arch/powerpc/kvm/timing.c
@@ -12,7 +12,7 @@
12 * along with this program; if not, write to the Free Software 12 * along with this program; if not, write to the Free Software
13 * Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 13 * Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
14 * 14 *
15 * Copyright IBM Corp. 2007 15 * Copyright IBM Corp. 2008
16 * 16 *
17 * Authors: Hollis Blanchard <hollisb@us.ibm.com> 17 * Authors: Hollis Blanchard <hollisb@us.ibm.com>
18 * Christian Ehrhardt <ehrhardt@linux.vnet.ibm.com> 18 * Christian Ehrhardt <ehrhardt@linux.vnet.ibm.com>
@@ -24,10 +24,11 @@
24#include <linux/debugfs.h> 24#include <linux/debugfs.h>
25#include <linux/uaccess.h> 25#include <linux/uaccess.h>
26 26
27#include "timing.h"
28#include <asm/time.h> 27#include <asm/time.h>
29#include <asm-generic/div64.h> 28#include <asm-generic/div64.h>
30 29
30#include "timing.h"
31
31void kvmppc_init_timing_stats(struct kvm_vcpu *vcpu) 32void kvmppc_init_timing_stats(struct kvm_vcpu *vcpu)
32{ 33{
33 int i; 34 int i;
@@ -52,8 +53,7 @@ void kvmppc_init_timing_stats(struct kvm_vcpu *vcpu)
52 local_irq_enable(); 53 local_irq_enable();
53} 54}
54 55
55static void add_exit_timing(struct kvm_vcpu *vcpu, 56static void add_exit_timing(struct kvm_vcpu *vcpu, u64 duration, int type)
56 u64 duration, int type)
57{ 57{
58 u64 old; 58 u64 old;
59 59
@@ -115,54 +115,46 @@ void kvmppc_update_timing_stats(struct kvm_vcpu *vcpu)
115} 115}
116 116
117static const char *kvm_exit_names[__NUMBER_OF_KVM_EXIT_TYPES] = { 117static const char *kvm_exit_names[__NUMBER_OF_KVM_EXIT_TYPES] = {
118 [MMIO_EXITS] = "MMIO", 118 [MMIO_EXITS] = "MMIO",
119 [DCR_EXITS] = "DCR", 119 [DCR_EXITS] = "DCR",
120 [SIGNAL_EXITS] = "SIGNAL", 120 [SIGNAL_EXITS] = "SIGNAL",
121 [ITLB_REAL_MISS_EXITS] = "ITLBREAL", 121 [ITLB_REAL_MISS_EXITS] = "ITLBREAL",
122 [ITLB_VIRT_MISS_EXITS] = "ITLBVIRT", 122 [ITLB_VIRT_MISS_EXITS] = "ITLBVIRT",
123 [DTLB_REAL_MISS_EXITS] = "DTLBREAL", 123 [DTLB_REAL_MISS_EXITS] = "DTLBREAL",
124 [DTLB_VIRT_MISS_EXITS] = "DTLBVIRT", 124 [DTLB_VIRT_MISS_EXITS] = "DTLBVIRT",
125 [SYSCALL_EXITS] = "SYSCALL", 125 [SYSCALL_EXITS] = "SYSCALL",
126 [ISI_EXITS] = "ISI", 126 [ISI_EXITS] = "ISI",
127 [DSI_EXITS] = "DSI", 127 [DSI_EXITS] = "DSI",
128 [EMULATED_INST_EXITS] = "EMULINST", 128 [EMULATED_INST_EXITS] = "EMULINST",
129 [EMULATED_MTMSRWE_EXITS] = "EMUL_WAIT", 129 [EMULATED_MTMSRWE_EXITS] = "EMUL_WAIT",
130 [EMULATED_WRTEE_EXITS] = "EMUL_WRTEE", 130 [EMULATED_WRTEE_EXITS] = "EMUL_WRTEE",
131 [EMULATED_MTSPR_EXITS] = "EMUL_MTSPR", 131 [EMULATED_MTSPR_EXITS] = "EMUL_MTSPR",
132 [EMULATED_MFSPR_EXITS] = "EMUL_MFSPR", 132 [EMULATED_MFSPR_EXITS] = "EMUL_MFSPR",
133 [EMULATED_MTMSR_EXITS] = "EMUL_MTMSR", 133 [EMULATED_MTMSR_EXITS] = "EMUL_MTMSR",
134 [EMULATED_MFMSR_EXITS] = "EMUL_MFMSR", 134 [EMULATED_MFMSR_EXITS] = "EMUL_MFMSR",
135 [EMULATED_TLBSX_EXITS] = "EMUL_TLBSX", 135 [EMULATED_TLBSX_EXITS] = "EMUL_TLBSX",
136 [EMULATED_TLBWE_EXITS] = "EMUL_TLBWE", 136 [EMULATED_TLBWE_EXITS] = "EMUL_TLBWE",
137 [EMULATED_RFI_EXITS] = "EMUL_RFI", 137 [EMULATED_RFI_EXITS] = "EMUL_RFI",
138 [DEC_EXITS] = "DEC", 138 [DEC_EXITS] = "DEC",
139 [EXT_INTR_EXITS] = "EXTINT", 139 [EXT_INTR_EXITS] = "EXTINT",
140 [HALT_WAKEUP] = "HALT", 140 [HALT_WAKEUP] = "HALT",
141 [USR_PR_INST] = "USR_PR_INST", 141 [USR_PR_INST] = "USR_PR_INST",
142 [FP_UNAVAIL] = "FP_UNAVAIL", 142 [FP_UNAVAIL] = "FP_UNAVAIL",
143 [DEBUG_EXITS] = "DEBUG", 143 [DEBUG_EXITS] = "DEBUG",
144 [TIMEINGUEST] = "TIMEINGUEST" 144 [TIMEINGUEST] = "TIMEINGUEST"
145}; 145};
146 146
147static int kvmppc_exit_timing_show(struct seq_file *m, void *private) 147static int kvmppc_exit_timing_show(struct seq_file *m, void *private)
148{ 148{
149 struct kvm_vcpu *vcpu = m->private; 149 struct kvm_vcpu *vcpu = m->private;
150 int i; 150 int i;
151 u64 min, max; 151
152 seq_printf(m, "%s", "type count min max sum sum_squared\n");
152 153
153 for (i = 0; i < __NUMBER_OF_KVM_EXIT_TYPES; i++) { 154 for (i = 0; i < __NUMBER_OF_KVM_EXIT_TYPES; i++) {
154 if (vcpu->arch.timing_min_duration[i] == 0xFFFFFFFF) 155 seq_printf(m, "%12s %10d %10lld %10lld %20lld %20lld\n",
155 min = 0; 156 kvm_exit_names[i],
156 else 157 vcpu->arch.timing_count_type[i],
157 min = vcpu->arch.timing_min_duration[i];
158 if (vcpu->arch.timing_max_duration[i] == 0)
159 max = 0;
160 else
161 max = vcpu->arch.timing_max_duration[i];
162
163 seq_printf(m, "%12s: count %10d min %10lld "
164 "max %10lld sum %20lld sum_quad %20lld\n",
165 kvm_exit_names[i], vcpu->arch.timing_count_type[i],
166 vcpu->arch.timing_min_duration[i], 158 vcpu->arch.timing_min_duration[i],
167 vcpu->arch.timing_max_duration[i], 159 vcpu->arch.timing_max_duration[i],
168 vcpu->arch.timing_sum_duration[i], 160 vcpu->arch.timing_sum_duration[i],
@@ -171,31 +163,19 @@ static int kvmppc_exit_timing_show(struct seq_file *m, void *private)
171 return 0; 163 return 0;
172} 164}
173 165
166/* Write 'c' to clear the timing statistics. */
174static ssize_t kvmppc_exit_timing_write(struct file *file, 167static ssize_t kvmppc_exit_timing_write(struct file *file,
175 const char __user *user_buf, 168 const char __user *user_buf,
176 size_t count, loff_t *ppos) 169 size_t count, loff_t *ppos)
177{ 170{
178 size_t len; 171 int err = -EINVAL;
179 int err;
180 const char __user *p;
181 char c; 172 char c;
182 173
183 len = 0; 174 if (count > 1) {
184 p = user_buf;
185 while (len < count) {
186 if (get_user(c, p++))
187 err = -EFAULT;
188 if (c == 0 || c == '\n')
189 break;
190 len++;
191 }
192
193 if (len > 1) {
194 err = -EINVAL;
195 goto done; 175 goto done;
196 } 176 }
197 177
198 if (copy_from_user(&c, user_buf, sizeof(c))) { 178 if (get_user(c, user_buf)) {
199 err = -EFAULT; 179 err = -EFAULT;
200 goto done; 180 goto done;
201 } 181 }
@@ -203,16 +183,13 @@ static ssize_t kvmppc_exit_timing_write(struct file *file,
203 if (c == 'c') { 183 if (c == 'c') {
204 struct seq_file *seqf = (struct seq_file *)file->private_data; 184 struct seq_file *seqf = (struct seq_file *)file->private_data;
205 struct kvm_vcpu *vcpu = seqf->private; 185 struct kvm_vcpu *vcpu = seqf->private;
206 /* write does not affect out buffers previsously generated with 186 /* Write does not affect our buffers previously generated with
207 * show. Seq file is locked here to prevent races of init with 187 * show. seq_file is locked here to prevent races of init with
208 * a show call */ 188 * a show call */
209 mutex_lock(&seqf->lock); 189 mutex_lock(&seqf->lock);
210 kvmppc_init_timing_stats(vcpu); 190 kvmppc_init_timing_stats(vcpu);
211 mutex_unlock(&seqf->lock); 191 mutex_unlock(&seqf->lock);
212 err = count; 192 err = count;
213 } else {
214 err = -EINVAL;
215 goto done;
216 } 193 }
217 194
218done: 195done:
@@ -238,7 +215,7 @@ void kvmppc_create_vcpu_debugfs(struct kvm_vcpu *vcpu, unsigned int id)
238 static char dbg_fname[50]; 215 static char dbg_fname[50];
239 struct dentry *debugfs_file; 216 struct dentry *debugfs_file;
240 217
241 snprintf(dbg_fname, sizeof(dbg_fname), "vm%u_vcpu%03u_timing", 218 snprintf(dbg_fname, sizeof(dbg_fname), "vm%u_vcpu%u_timing",
242 current->pid, id); 219 current->pid, id);
243 debugfs_file = debugfs_create_file(dbg_fname, 0666, 220 debugfs_file = debugfs_create_file(dbg_fname, 0666,
244 kvm_debugfs_dir, vcpu, 221 kvm_debugfs_dir, vcpu,
diff --git a/arch/powerpc/kvm/timing.h b/arch/powerpc/kvm/timing.h
index 1af7181fa2b5..bb13b1f3cd5a 100644
--- a/arch/powerpc/kvm/timing.h
+++ b/arch/powerpc/kvm/timing.h
@@ -45,7 +45,7 @@ static inline void kvmppc_set_exit_type(struct kvm_vcpu *vcpu, int type) {}
45#endif /* CONFIG_KVM_EXIT_TIMING */ 45#endif /* CONFIG_KVM_EXIT_TIMING */
46 46
47/* account the exit in kvm_stats */ 47/* account the exit in kvm_stats */
48static inline void account_exit_stat(struct kvm_vcpu *vcpu, int type) 48static inline void kvmppc_account_exit_stat(struct kvm_vcpu *vcpu, int type)
49{ 49{
50 /* type has to be known at build time for optimization */ 50 /* type has to be known at build time for optimization */
51 BUILD_BUG_ON(__builtin_constant_p(type)); 51 BUILD_BUG_ON(__builtin_constant_p(type));
@@ -93,10 +93,10 @@ static inline void account_exit_stat(struct kvm_vcpu *vcpu, int type)
93} 93}
94 94
95/* wrapper to set exit time and account for it in kvm_stats */ 95/* wrapper to set exit time and account for it in kvm_stats */
96static inline void account_exit(struct kvm_vcpu *vcpu, int type) 96static inline void kvmppc_account_exit(struct kvm_vcpu *vcpu, int type)
97{ 97{
98 kvmppc_set_exit_type(vcpu, type); 98 kvmppc_set_exit_type(vcpu, type);
99 account_exit_stat(vcpu, type); 99 kvmppc_account_exit_stat(vcpu, type);
100} 100}
101 101
102#endif /* __POWERPC_KVM_EXITTIMING_H__ */ 102#endif /* __POWERPC_KVM_EXITTIMING_H__ */