diff options
author | Alexander Graf <agraf@suse.de> | 2010-08-02 15:25:33 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2010-10-24 04:52:07 -0400 |
commit | 928d78be54014e65498e289fdc3f82acc4b804a9 (patch) | |
tree | fea2b1f5c4c322d3381f32ba43a4a77ec82936af /arch/powerpc/kvm | |
parent | e7c1d14e3bf40b87e6a3f68964b36dbb2c875c0f (diff) |
KVM: PPC: Move slb debugging to tracepoints
This patch moves debugging printks for shadow SLB debugging over to tracepoints.
Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'arch/powerpc/kvm')
-rw-r--r-- | arch/powerpc/kvm/book3s_64_mmu_host.c | 22 | ||||
-rw-r--r-- | arch/powerpc/kvm/trace.h | 73 |
2 files changed, 78 insertions, 17 deletions
diff --git a/arch/powerpc/kvm/book3s_64_mmu_host.c b/arch/powerpc/kvm/book3s_64_mmu_host.c index ebb1b5ddabf..321c931f691 100644 --- a/arch/powerpc/kvm/book3s_64_mmu_host.c +++ b/arch/powerpc/kvm/book3s_64_mmu_host.c | |||
@@ -33,14 +33,6 @@ | |||
33 | #define PTE_SIZE 12 | 33 | #define PTE_SIZE 12 |
34 | #define VSID_ALL 0 | 34 | #define VSID_ALL 0 |
35 | 35 | ||
36 | /* #define DEBUG_SLB */ | ||
37 | |||
38 | #ifdef DEBUG_SLB | ||
39 | #define dprintk_slb(a, ...) printk(KERN_INFO a, __VA_ARGS__) | ||
40 | #else | ||
41 | #define dprintk_slb(a, ...) do { } while(0) | ||
42 | #endif | ||
43 | |||
44 | void kvmppc_mmu_invalidate_pte(struct kvm_vcpu *vcpu, struct hpte_cache *pte) | 36 | void kvmppc_mmu_invalidate_pte(struct kvm_vcpu *vcpu, struct hpte_cache *pte) |
45 | { | 37 | { |
46 | ppc_md.hpte_invalidate(pte->slot, pte->host_va, | 38 | ppc_md.hpte_invalidate(pte->slot, pte->host_va, |
@@ -66,20 +58,17 @@ static struct kvmppc_sid_map *find_sid_vsid(struct kvm_vcpu *vcpu, u64 gvsid) | |||
66 | sid_map_mask = kvmppc_sid_hash(vcpu, gvsid); | 58 | sid_map_mask = kvmppc_sid_hash(vcpu, gvsid); |
67 | map = &to_book3s(vcpu)->sid_map[sid_map_mask]; | 59 | map = &to_book3s(vcpu)->sid_map[sid_map_mask]; |
68 | if (map->valid && (map->guest_vsid == gvsid)) { | 60 | if (map->valid && (map->guest_vsid == gvsid)) { |
69 | dprintk_slb("SLB: Searching: 0x%llx -> 0x%llx\n", | 61 | trace_kvm_book3s_slb_found(gvsid, map->host_vsid); |
70 | gvsid, map->host_vsid); | ||
71 | return map; | 62 | return map; |
72 | } | 63 | } |
73 | 64 | ||
74 | map = &to_book3s(vcpu)->sid_map[SID_MAP_MASK - sid_map_mask]; | 65 | map = &to_book3s(vcpu)->sid_map[SID_MAP_MASK - sid_map_mask]; |
75 | if (map->valid && (map->guest_vsid == gvsid)) { | 66 | if (map->valid && (map->guest_vsid == gvsid)) { |
76 | dprintk_slb("SLB: Searching 0x%llx -> 0x%llx\n", | 67 | trace_kvm_book3s_slb_found(gvsid, map->host_vsid); |
77 | gvsid, map->host_vsid); | ||
78 | return map; | 68 | return map; |
79 | } | 69 | } |
80 | 70 | ||
81 | dprintk_slb("SLB: Searching %d/%d: 0x%llx -> not found\n", | 71 | trace_kvm_book3s_slb_fail(sid_map_mask, gvsid); |
82 | sid_map_mask, SID_MAP_MASK - sid_map_mask, gvsid); | ||
83 | return NULL; | 72 | return NULL; |
84 | } | 73 | } |
85 | 74 | ||
@@ -205,8 +194,7 @@ static struct kvmppc_sid_map *create_sid_map(struct kvm_vcpu *vcpu, u64 gvsid) | |||
205 | map->guest_vsid = gvsid; | 194 | map->guest_vsid = gvsid; |
206 | map->valid = true; | 195 | map->valid = true; |
207 | 196 | ||
208 | dprintk_slb("SLB: New mapping at %d: 0x%llx -> 0x%llx\n", | 197 | trace_kvm_book3s_slb_map(sid_map_mask, gvsid, map->host_vsid); |
209 | sid_map_mask, gvsid, map->host_vsid); | ||
210 | 198 | ||
211 | return map; | 199 | return map; |
212 | } | 200 | } |
@@ -278,7 +266,7 @@ int kvmppc_mmu_map_segment(struct kvm_vcpu *vcpu, ulong eaddr) | |||
278 | to_svcpu(vcpu)->slb[slb_index].esid = slb_esid; | 266 | to_svcpu(vcpu)->slb[slb_index].esid = slb_esid; |
279 | to_svcpu(vcpu)->slb[slb_index].vsid = slb_vsid; | 267 | to_svcpu(vcpu)->slb[slb_index].vsid = slb_vsid; |
280 | 268 | ||
281 | dprintk_slb("slbmte %#llx, %#llx\n", slb_vsid, slb_esid); | 269 | trace_kvm_book3s_slbmte(slb_vsid, slb_esid); |
282 | 270 | ||
283 | return 0; | 271 | return 0; |
284 | } | 272 | } |
diff --git a/arch/powerpc/kvm/trace.h b/arch/powerpc/kvm/trace.h index 23f757a6916..3aca1b042b8 100644 --- a/arch/powerpc/kvm/trace.h +++ b/arch/powerpc/kvm/trace.h | |||
@@ -262,6 +262,79 @@ TRACE_EVENT(kvm_book3s_mmu_flush, | |||
262 | __entry->count, __entry->type, __entry->p1, __entry->p2) | 262 | __entry->count, __entry->type, __entry->p1, __entry->p2) |
263 | ); | 263 | ); |
264 | 264 | ||
265 | TRACE_EVENT(kvm_book3s_slb_found, | ||
266 | TP_PROTO(unsigned long long gvsid, unsigned long long hvsid), | ||
267 | TP_ARGS(gvsid, hvsid), | ||
268 | |||
269 | TP_STRUCT__entry( | ||
270 | __field( unsigned long long, gvsid ) | ||
271 | __field( unsigned long long, hvsid ) | ||
272 | ), | ||
273 | |||
274 | TP_fast_assign( | ||
275 | __entry->gvsid = gvsid; | ||
276 | __entry->hvsid = hvsid; | ||
277 | ), | ||
278 | |||
279 | TP_printk("%llx -> %llx", __entry->gvsid, __entry->hvsid) | ||
280 | ); | ||
281 | |||
282 | TRACE_EVENT(kvm_book3s_slb_fail, | ||
283 | TP_PROTO(u16 sid_map_mask, unsigned long long gvsid), | ||
284 | TP_ARGS(sid_map_mask, gvsid), | ||
285 | |||
286 | TP_STRUCT__entry( | ||
287 | __field( unsigned short, sid_map_mask ) | ||
288 | __field( unsigned long long, gvsid ) | ||
289 | ), | ||
290 | |||
291 | TP_fast_assign( | ||
292 | __entry->sid_map_mask = sid_map_mask; | ||
293 | __entry->gvsid = gvsid; | ||
294 | ), | ||
295 | |||
296 | TP_printk("%x/%x: %llx", __entry->sid_map_mask, | ||
297 | SID_MAP_MASK - __entry->sid_map_mask, __entry->gvsid) | ||
298 | ); | ||
299 | |||
300 | TRACE_EVENT(kvm_book3s_slb_map, | ||
301 | TP_PROTO(u16 sid_map_mask, unsigned long long gvsid, | ||
302 | unsigned long long hvsid), | ||
303 | TP_ARGS(sid_map_mask, gvsid, hvsid), | ||
304 | |||
305 | TP_STRUCT__entry( | ||
306 | __field( unsigned short, sid_map_mask ) | ||
307 | __field( unsigned long long, guest_vsid ) | ||
308 | __field( unsigned long long, host_vsid ) | ||
309 | ), | ||
310 | |||
311 | TP_fast_assign( | ||
312 | __entry->sid_map_mask = sid_map_mask; | ||
313 | __entry->guest_vsid = gvsid; | ||
314 | __entry->host_vsid = hvsid; | ||
315 | ), | ||
316 | |||
317 | TP_printk("%x: %llx -> %llx", __entry->sid_map_mask, | ||
318 | __entry->guest_vsid, __entry->host_vsid) | ||
319 | ); | ||
320 | |||
321 | TRACE_EVENT(kvm_book3s_slbmte, | ||
322 | TP_PROTO(u64 slb_vsid, u64 slb_esid), | ||
323 | TP_ARGS(slb_vsid, slb_esid), | ||
324 | |||
325 | TP_STRUCT__entry( | ||
326 | __field( u64, slb_vsid ) | ||
327 | __field( u64, slb_esid ) | ||
328 | ), | ||
329 | |||
330 | TP_fast_assign( | ||
331 | __entry->slb_vsid = slb_vsid; | ||
332 | __entry->slb_esid = slb_esid; | ||
333 | ), | ||
334 | |||
335 | TP_printk("%llx, %llx", __entry->slb_vsid, __entry->slb_esid) | ||
336 | ); | ||
337 | |||
265 | #endif /* CONFIG_PPC_BOOK3S */ | 338 | #endif /* CONFIG_PPC_BOOK3S */ |
266 | 339 | ||
267 | #endif /* _TRACE_KVM_H */ | 340 | #endif /* _TRACE_KVM_H */ |