aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/amd/amdgpu
diff options
context:
space:
mode:
authorChristian König <christian.koenig@amd.com>2016-02-26 10:18:36 -0500
committerAlex Deucher <alexander.deucher@amd.com>2016-02-29 11:33:59 -0500
commit22073fe764c9ff2742c27a8c06f28ef6cd9a56e3 (patch)
treeff3d2d7ad4c30da80d995284c182262c1c4cdbcb /drivers/gpu/drm/amd/amdgpu
parent4ff37a83f19dab4e67299325ee22e98346eee857 (diff)
drm/amdgpu: trace the pd_addr in vm_grab_id as well
Makes matching it to the flushes much easier. Signed-off-by: Christian König <christian.koenig@amd.com> Reviewed-by: Chunming Zhou <david1.zhou@amd.com> Acked-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu')
-rw-r--r--drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h19
-rw-r--r--drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c5
2 files changed, 14 insertions, 10 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h b/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h
index 9ca3735c563c..26a5f4acf584 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_trace.h
@@ -100,21 +100,24 @@ TRACE_EVENT(amdgpu_sched_run_job,
100 100
101 101
102TRACE_EVENT(amdgpu_vm_grab_id, 102TRACE_EVENT(amdgpu_vm_grab_id,
103 TP_PROTO(struct amdgpu_vm *vm, unsigned vmid, int ring), 103 TP_PROTO(struct amdgpu_vm *vm, int ring, unsigned vmid,
104 TP_ARGS(vm, vmid, ring), 104 uint64_t pd_addr),
105 TP_ARGS(vm, ring, vmid, pd_addr),
105 TP_STRUCT__entry( 106 TP_STRUCT__entry(
106 __field(struct amdgpu_vm *, vm) 107 __field(struct amdgpu_vm *, vm)
107 __field(u32, vmid)
108 __field(u32, ring) 108 __field(u32, ring)
109 __field(u32, vmid)
110 __field(u64, pd_addr)
109 ), 111 ),
110 112
111 TP_fast_assign( 113 TP_fast_assign(
112 __entry->vm = vm; 114 __entry->vm = vm;
113 __entry->vmid = vmid;
114 __entry->ring = ring; 115 __entry->ring = ring;
116 __entry->vmid = vmid;
117 __entry->pd_addr = pd_addr;
115 ), 118 ),
116 TP_printk("vm=%p, id=%u, ring=%u", __entry->vm, __entry->vmid, 119 TP_printk("vm=%p, ring=%u, id=%u, pd_addr=%010Lx", __entry->vm,
117 __entry->ring) 120 __entry->ring, __entry->vmid, __entry->pd_addr)
118); 121);
119 122
120TRACE_EVENT(amdgpu_vm_bo_map, 123TRACE_EVENT(amdgpu_vm_bo_map,
@@ -231,8 +234,8 @@ TRACE_EVENT(amdgpu_vm_flush,
231 __entry->ring = ring; 234 __entry->ring = ring;
232 __entry->id = id; 235 __entry->id = id;
233 ), 236 ),
234 TP_printk("pd_addr=%010Lx, ring=%u, id=%u", 237 TP_printk("ring=%u, id=%u, pd_addr=%010Lx",
235 __entry->pd_addr, __entry->ring, __entry->id) 238 __entry->ring, __entry->id, __entry->pd_addr)
236); 239);
237 240
238TRACE_EVENT(amdgpu_bo_list_set, 241TRACE_EVENT(amdgpu_bo_list_set,
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
index ba909245fef5..d9dc8bea5e98 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c
@@ -196,7 +196,8 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring,
196 196
197 *vm_id = id->mgr_id - adev->vm_manager.ids; 197 *vm_id = id->mgr_id - adev->vm_manager.ids;
198 *vm_pd_addr = AMDGPU_VM_NO_FLUSH; 198 *vm_pd_addr = AMDGPU_VM_NO_FLUSH;
199 trace_amdgpu_vm_grab_id(vm, *vm_id, ring->idx); 199 trace_amdgpu_vm_grab_id(vm, ring->idx, *vm_id,
200 *vm_pd_addr);
200 201
201 mutex_unlock(&adev->vm_manager.lock); 202 mutex_unlock(&adev->vm_manager.lock);
202 return 0; 203 return 0;
@@ -222,7 +223,7 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring,
222 223
223 *vm_id = id->mgr_id - adev->vm_manager.ids; 224 *vm_id = id->mgr_id - adev->vm_manager.ids;
224 *vm_pd_addr = pd_addr; 225 *vm_pd_addr = pd_addr;
225 trace_amdgpu_vm_grab_id(vm, *vm_id, ring->idx); 226 trace_amdgpu_vm_grab_id(vm, ring->idx, *vm_id, *vm_pd_addr);
226 } 227 }
227 228
228 mutex_unlock(&adev->vm_manager.lock); 229 mutex_unlock(&adev->vm_manager.lock);