Linux Audio

Check our new training course

Loading...
v4.6
 
 
 
 
 
  1#if !defined(_I915_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
  2#define _I915_TRACE_H_
  3
  4#include <linux/stringify.h>
  5#include <linux/types.h>
  6#include <linux/tracepoint.h>
  7
  8#include <drm/drmP.h>
  9#include "i915_drv.h"
 10#include "intel_drv.h"
 11#include "intel_ringbuffer.h"
 12
 13#undef TRACE_SYSTEM
 14#define TRACE_SYSTEM i915
 15#define TRACE_INCLUDE_FILE i915_trace
 16
 17/* pipe updates */
 18
 19TRACE_EVENT(i915_pipe_update_start,
 20	    TP_PROTO(struct intel_crtc *crtc),
 21	    TP_ARGS(crtc),
 22
 23	    TP_STRUCT__entry(
 24			     __field(enum pipe, pipe)
 25			     __field(u32, frame)
 26			     __field(u32, scanline)
 27			     __field(u32, min)
 28			     __field(u32, max)
 29			     ),
 30
 31	    TP_fast_assign(
 32			   __entry->pipe = crtc->pipe;
 33			   __entry->frame = crtc->base.dev->driver->get_vblank_counter(crtc->base.dev,
 34										       crtc->pipe);
 35			   __entry->scanline = intel_get_crtc_scanline(crtc);
 36			   __entry->min = crtc->debug.min_vbl;
 37			   __entry->max = crtc->debug.max_vbl;
 38			   ),
 39
 40	    TP_printk("pipe %c, frame=%u, scanline=%u, min=%u, max=%u",
 41		      pipe_name(__entry->pipe), __entry->frame,
 42		       __entry->scanline, __entry->min, __entry->max)
 43);
 44
 45TRACE_EVENT(i915_pipe_update_vblank_evaded,
 46	    TP_PROTO(struct intel_crtc *crtc),
 47	    TP_ARGS(crtc),
 48
 49	    TP_STRUCT__entry(
 50			     __field(enum pipe, pipe)
 51			     __field(u32, frame)
 52			     __field(u32, scanline)
 53			     __field(u32, min)
 54			     __field(u32, max)
 55			     ),
 56
 57	    TP_fast_assign(
 58			   __entry->pipe = crtc->pipe;
 59			   __entry->frame = crtc->debug.start_vbl_count;
 60			   __entry->scanline = crtc->debug.scanline_start;
 61			   __entry->min = crtc->debug.min_vbl;
 62			   __entry->max = crtc->debug.max_vbl;
 63			   ),
 64
 65	    TP_printk("pipe %c, frame=%u, scanline=%u, min=%u, max=%u",
 66		      pipe_name(__entry->pipe), __entry->frame,
 67		       __entry->scanline, __entry->min, __entry->max)
 68);
 69
 70TRACE_EVENT(i915_pipe_update_end,
 71	    TP_PROTO(struct intel_crtc *crtc, u32 frame, int scanline_end),
 72	    TP_ARGS(crtc, frame, scanline_end),
 73
 74	    TP_STRUCT__entry(
 75			     __field(enum pipe, pipe)
 76			     __field(u32, frame)
 77			     __field(u32, scanline)
 78			     ),
 79
 80	    TP_fast_assign(
 81			   __entry->pipe = crtc->pipe;
 82			   __entry->frame = frame;
 83			   __entry->scanline = scanline_end;
 84			   ),
 85
 86	    TP_printk("pipe %c, frame=%u, scanline=%u",
 87		      pipe_name(__entry->pipe), __entry->frame,
 88		      __entry->scanline)
 89);
 90
 91/* object tracking */
 92
 93TRACE_EVENT(i915_gem_object_create,
 94	    TP_PROTO(struct drm_i915_gem_object *obj),
 95	    TP_ARGS(obj),
 96
 97	    TP_STRUCT__entry(
 98			     __field(struct drm_i915_gem_object *, obj)
 99			     __field(u32, size)
100			     ),
101
102	    TP_fast_assign(
103			   __entry->obj = obj;
104			   __entry->size = obj->base.size;
105			   ),
106
107	    TP_printk("obj=%p, size=%u", __entry->obj, __entry->size)
108);
109
110TRACE_EVENT(i915_gem_shrink,
111	    TP_PROTO(struct drm_i915_private *i915, unsigned long target, unsigned flags),
112	    TP_ARGS(i915, target, flags),
113
114	    TP_STRUCT__entry(
115			     __field(int, dev)
116			     __field(unsigned long, target)
117			     __field(unsigned, flags)
118			     ),
119
120	    TP_fast_assign(
121			   __entry->dev = i915->dev->primary->index;
122			   __entry->target = target;
123			   __entry->flags = flags;
124			   ),
125
126	    TP_printk("dev=%d, target=%lu, flags=%x",
127		      __entry->dev, __entry->target, __entry->flags)
128);
129
130TRACE_EVENT(i915_vma_bind,
131	    TP_PROTO(struct i915_vma *vma, unsigned flags),
132	    TP_ARGS(vma, flags),
133
134	    TP_STRUCT__entry(
135			     __field(struct drm_i915_gem_object *, obj)
136			     __field(struct i915_address_space *, vm)
137			     __field(u64, offset)
138			     __field(u32, size)
139			     __field(unsigned, flags)
140			     ),
141
142	    TP_fast_assign(
143			   __entry->obj = vma->obj;
144			   __entry->vm = vma->vm;
145			   __entry->offset = vma->node.start;
146			   __entry->size = vma->node.size;
147			   __entry->flags = flags;
148			   ),
149
150	    TP_printk("obj=%p, offset=%016llx size=%x%s vm=%p",
151		      __entry->obj, __entry->offset, __entry->size,
152		      __entry->flags & PIN_MAPPABLE ? ", mappable" : "",
153		      __entry->vm)
154);
155
156TRACE_EVENT(i915_vma_unbind,
157	    TP_PROTO(struct i915_vma *vma),
158	    TP_ARGS(vma),
159
160	    TP_STRUCT__entry(
161			     __field(struct drm_i915_gem_object *, obj)
162			     __field(struct i915_address_space *, vm)
163			     __field(u64, offset)
164			     __field(u32, size)
165			     ),
166
167	    TP_fast_assign(
168			   __entry->obj = vma->obj;
169			   __entry->vm = vma->vm;
170			   __entry->offset = vma->node.start;
171			   __entry->size = vma->node.size;
172			   ),
173
174	    TP_printk("obj=%p, offset=%016llx size=%x vm=%p",
175		      __entry->obj, __entry->offset, __entry->size, __entry->vm)
176);
177
178TRACE_EVENT(i915_va_alloc,
179	TP_PROTO(struct i915_vma *vma),
180	TP_ARGS(vma),
181
182	TP_STRUCT__entry(
183		__field(struct i915_address_space *, vm)
184		__field(u64, start)
185		__field(u64, end)
186	),
187
188	TP_fast_assign(
189		__entry->vm = vma->vm;
190		__entry->start = vma->node.start;
191		__entry->end = vma->node.start + vma->node.size - 1;
192	),
193
194	TP_printk("vm=%p (%c), 0x%llx-0x%llx",
195		  __entry->vm, i915_is_ggtt(__entry->vm) ? 'G' : 'P',  __entry->start, __entry->end)
196);
197
198DECLARE_EVENT_CLASS(i915_px_entry,
199	TP_PROTO(struct i915_address_space *vm, u32 px, u64 start, u64 px_shift),
200	TP_ARGS(vm, px, start, px_shift),
201
202	TP_STRUCT__entry(
203		__field(struct i915_address_space *, vm)
204		__field(u32, px)
205		__field(u64, start)
206		__field(u64, end)
207	),
208
209	TP_fast_assign(
210		__entry->vm = vm;
211		__entry->px = px;
212		__entry->start = start;
213		__entry->end = ((start + (1ULL << px_shift)) & ~((1ULL << px_shift)-1)) - 1;
214	),
215
216	TP_printk("vm=%p, pde=%d (0x%llx-0x%llx)",
217		  __entry->vm, __entry->px, __entry->start, __entry->end)
218);
219
220DEFINE_EVENT(i915_px_entry, i915_page_table_entry_alloc,
221	     TP_PROTO(struct i915_address_space *vm, u32 pde, u64 start, u64 pde_shift),
222	     TP_ARGS(vm, pde, start, pde_shift)
223);
224
225DEFINE_EVENT_PRINT(i915_px_entry, i915_page_directory_entry_alloc,
226		   TP_PROTO(struct i915_address_space *vm, u32 pdpe, u64 start, u64 pdpe_shift),
227		   TP_ARGS(vm, pdpe, start, pdpe_shift),
228
229		   TP_printk("vm=%p, pdpe=%d (0x%llx-0x%llx)",
230			     __entry->vm, __entry->px, __entry->start, __entry->end)
231);
232
233DEFINE_EVENT_PRINT(i915_px_entry, i915_page_directory_pointer_entry_alloc,
234		   TP_PROTO(struct i915_address_space *vm, u32 pml4e, u64 start, u64 pml4e_shift),
235		   TP_ARGS(vm, pml4e, start, pml4e_shift),
236
237		   TP_printk("vm=%p, pml4e=%d (0x%llx-0x%llx)",
238			     __entry->vm, __entry->px, __entry->start, __entry->end)
239);
240
241/* Avoid extra math because we only support two sizes. The format is defined by
242 * bitmap_scnprintf. Each 32 bits is 8 HEX digits followed by comma */
243#define TRACE_PT_SIZE(bits) \
244	((((bits) == 1024) ? 288 : 144) + 1)
245
246DECLARE_EVENT_CLASS(i915_page_table_entry_update,
247	TP_PROTO(struct i915_address_space *vm, u32 pde,
248		 struct i915_page_table *pt, u32 first, u32 count, u32 bits),
249	TP_ARGS(vm, pde, pt, first, count, bits),
250
251	TP_STRUCT__entry(
252		__field(struct i915_address_space *, vm)
253		__field(u32, pde)
254		__field(u32, first)
255		__field(u32, last)
256		__dynamic_array(char, cur_ptes, TRACE_PT_SIZE(bits))
257	),
258
259	TP_fast_assign(
260		__entry->vm = vm;
261		__entry->pde = pde;
262		__entry->first = first;
263		__entry->last = first + count - 1;
264		scnprintf(__get_str(cur_ptes),
265			  TRACE_PT_SIZE(bits),
266			  "%*pb",
267			  bits,
268			  pt->used_ptes);
269	),
270
271	TP_printk("vm=%p, pde=%d, updating %u:%u\t%s",
272		  __entry->vm, __entry->pde, __entry->last, __entry->first,
273		  __get_str(cur_ptes))
274);
275
276DEFINE_EVENT(i915_page_table_entry_update, i915_page_table_entry_map,
277	TP_PROTO(struct i915_address_space *vm, u32 pde,
278		 struct i915_page_table *pt, u32 first, u32 count, u32 bits),
279	TP_ARGS(vm, pde, pt, first, count, bits)
280);
281
282TRACE_EVENT(i915_gem_object_change_domain,
283	    TP_PROTO(struct drm_i915_gem_object *obj, u32 old_read, u32 old_write),
284	    TP_ARGS(obj, old_read, old_write),
285
286	    TP_STRUCT__entry(
287			     __field(struct drm_i915_gem_object *, obj)
288			     __field(u32, read_domains)
289			     __field(u32, write_domain)
290			     ),
291
292	    TP_fast_assign(
293			   __entry->obj = obj;
294			   __entry->read_domains = obj->base.read_domains | (old_read << 16);
295			   __entry->write_domain = obj->base.write_domain | (old_write << 16);
296			   ),
297
298	    TP_printk("obj=%p, read=%02x=>%02x, write=%02x=>%02x",
299		      __entry->obj,
300		      __entry->read_domains >> 16,
301		      __entry->read_domains & 0xffff,
302		      __entry->write_domain >> 16,
303		      __entry->write_domain & 0xffff)
304);
305
306TRACE_EVENT(i915_gem_object_pwrite,
307	    TP_PROTO(struct drm_i915_gem_object *obj, u32 offset, u32 len),
308	    TP_ARGS(obj, offset, len),
309
310	    TP_STRUCT__entry(
311			     __field(struct drm_i915_gem_object *, obj)
312			     __field(u32, offset)
313			     __field(u32, len)
314			     ),
315
316	    TP_fast_assign(
317			   __entry->obj = obj;
318			   __entry->offset = offset;
319			   __entry->len = len;
320			   ),
321
322	    TP_printk("obj=%p, offset=%u, len=%u",
323		      __entry->obj, __entry->offset, __entry->len)
324);
325
326TRACE_EVENT(i915_gem_object_pread,
327	    TP_PROTO(struct drm_i915_gem_object *obj, u32 offset, u32 len),
328	    TP_ARGS(obj, offset, len),
329
330	    TP_STRUCT__entry(
331			     __field(struct drm_i915_gem_object *, obj)
332			     __field(u32, offset)
333			     __field(u32, len)
334			     ),
335
336	    TP_fast_assign(
337			   __entry->obj = obj;
338			   __entry->offset = offset;
339			   __entry->len = len;
340			   ),
341
342	    TP_printk("obj=%p, offset=%u, len=%u",
343		      __entry->obj, __entry->offset, __entry->len)
344);
345
346TRACE_EVENT(i915_gem_object_fault,
347	    TP_PROTO(struct drm_i915_gem_object *obj, u32 index, bool gtt, bool write),
348	    TP_ARGS(obj, index, gtt, write),
349
350	    TP_STRUCT__entry(
351			     __field(struct drm_i915_gem_object *, obj)
352			     __field(u32, index)
353			     __field(bool, gtt)
354			     __field(bool, write)
355			     ),
356
357	    TP_fast_assign(
358			   __entry->obj = obj;
359			   __entry->index = index;
360			   __entry->gtt = gtt;
361			   __entry->write = write;
362			   ),
363
364	    TP_printk("obj=%p, %s index=%u %s",
365		      __entry->obj,
366		      __entry->gtt ? "GTT" : "CPU",
367		      __entry->index,
368		      __entry->write ? ", writable" : "")
369);
370
371DECLARE_EVENT_CLASS(i915_gem_object,
372	    TP_PROTO(struct drm_i915_gem_object *obj),
373	    TP_ARGS(obj),
374
375	    TP_STRUCT__entry(
376			     __field(struct drm_i915_gem_object *, obj)
377			     ),
378
379	    TP_fast_assign(
380			   __entry->obj = obj;
381			   ),
382
383	    TP_printk("obj=%p", __entry->obj)
384);
385
386DEFINE_EVENT(i915_gem_object, i915_gem_object_clflush,
387	     TP_PROTO(struct drm_i915_gem_object *obj),
388	     TP_ARGS(obj)
389);
390
391DEFINE_EVENT(i915_gem_object, i915_gem_object_destroy,
392	    TP_PROTO(struct drm_i915_gem_object *obj),
393	    TP_ARGS(obj)
394);
395
396TRACE_EVENT(i915_gem_evict,
397	    TP_PROTO(struct drm_device *dev, u32 size, u32 align, unsigned flags),
398	    TP_ARGS(dev, size, align, flags),
399
400	    TP_STRUCT__entry(
401			     __field(u32, dev)
402			     __field(u32, size)
403			     __field(u32, align)
404			     __field(unsigned, flags)
 
405			    ),
406
407	    TP_fast_assign(
408			   __entry->dev = dev->primary->index;
 
409			   __entry->size = size;
410			   __entry->align = align;
411			   __entry->flags = flags;
412			  ),
413
414	    TP_printk("dev=%d, size=%d, align=%d %s",
415		      __entry->dev, __entry->size, __entry->align,
416		      __entry->flags & PIN_MAPPABLE ? ", mappable" : "")
417);
418
419TRACE_EVENT(i915_gem_evict_everything,
420	    TP_PROTO(struct drm_device *dev),
421	    TP_ARGS(dev),
422
423	    TP_STRUCT__entry(
424			     __field(u32, dev)
 
 
 
 
 
425			    ),
426
427	    TP_fast_assign(
428			   __entry->dev = dev->primary->index;
 
 
 
 
 
429			  ),
430
431	    TP_printk("dev=%d", __entry->dev)
 
 
 
432);
433
434TRACE_EVENT(i915_gem_evict_vm,
435	    TP_PROTO(struct i915_address_space *vm),
436	    TP_ARGS(vm),
437
438	    TP_STRUCT__entry(
439			     __field(u32, dev)
440			     __field(struct i915_address_space *, vm)
441			    ),
442
443	    TP_fast_assign(
444			   __entry->dev = vm->dev->primary->index;
445			   __entry->vm = vm;
446			  ),
447
448	    TP_printk("dev=%d, vm=%p", __entry->dev, __entry->vm)
449);
450
451TRACE_EVENT(i915_gem_ring_sync_to,
452	    TP_PROTO(struct drm_i915_gem_request *to_req,
453		     struct intel_engine_cs *from,
454		     struct drm_i915_gem_request *req),
455	    TP_ARGS(to_req, from, req),
456
457	    TP_STRUCT__entry(
458			     __field(u32, dev)
459			     __field(u32, sync_from)
460			     __field(u32, sync_to)
 
461			     __field(u32, seqno)
 
462			     ),
463
464	    TP_fast_assign(
465			   __entry->dev = from->dev->primary->index;
466			   __entry->sync_from = from->id;
467			   __entry->sync_to = to_req->ring->id;
468			   __entry->seqno = i915_gem_request_get_seqno(req);
 
 
469			   ),
470
471	    TP_printk("dev=%u, sync-from=%u, sync-to=%u, seqno=%u",
472		      __entry->dev,
473		      __entry->sync_from, __entry->sync_to,
474		      __entry->seqno)
475);
476
477TRACE_EVENT(i915_gem_ring_dispatch,
478	    TP_PROTO(struct drm_i915_gem_request *req, u32 flags),
479	    TP_ARGS(req, flags),
480
481	    TP_STRUCT__entry(
482			     __field(u32, dev)
483			     __field(u32, ring)
 
 
484			     __field(u32, seqno)
485			     __field(u32, flags)
486			     ),
487
488	    TP_fast_assign(
489			   struct intel_engine_cs *ring =
490						i915_gem_request_get_ring(req);
491			   __entry->dev = ring->dev->primary->index;
492			   __entry->ring = ring->id;
493			   __entry->seqno = i915_gem_request_get_seqno(req);
494			   __entry->flags = flags;
495			   i915_trace_irq_get(ring, req);
496			   ),
497
498	    TP_printk("dev=%u, ring=%u, seqno=%u, flags=%x",
499		      __entry->dev, __entry->ring, __entry->seqno, __entry->flags)
 
500);
501
502TRACE_EVENT(i915_gem_ring_flush,
503	    TP_PROTO(struct drm_i915_gem_request *req, u32 invalidate, u32 flush),
504	    TP_ARGS(req, invalidate, flush),
 
505
506	    TP_STRUCT__entry(
507			     __field(u32, dev)
508			     __field(u32, ring)
509			     __field(u32, invalidate)
510			     __field(u32, flush)
511			     ),
512
513	    TP_fast_assign(
514			   __entry->dev = req->ring->dev->primary->index;
515			   __entry->ring = req->ring->id;
516			   __entry->invalidate = invalidate;
517			   __entry->flush = flush;
518			   ),
519
520	    TP_printk("dev=%u, ring=%x, invalidate=%04x, flush=%04x",
521		      __entry->dev, __entry->ring,
522		      __entry->invalidate, __entry->flush)
523);
524
525DECLARE_EVENT_CLASS(i915_gem_request,
526	    TP_PROTO(struct drm_i915_gem_request *req),
527	    TP_ARGS(req),
528
529	    TP_STRUCT__entry(
530			     __field(u32, dev)
531			     __field(u32, ring)
 
 
532			     __field(u32, seqno)
533			     ),
 
 
534
535	    TP_fast_assign(
536			   struct intel_engine_cs *ring =
537						i915_gem_request_get_ring(req);
538			   __entry->dev = ring->dev->primary->index;
539			   __entry->ring = ring->id;
540			   __entry->seqno = i915_gem_request_get_seqno(req);
541			   ),
 
 
 
 
 
 
 
 
 
 
 
 
542
543	    TP_printk("dev=%u, ring=%u, seqno=%u",
544		      __entry->dev, __entry->ring, __entry->seqno)
545);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
546
547DEFINE_EVENT(i915_gem_request, i915_gem_request_add,
548	    TP_PROTO(struct drm_i915_gem_request *req),
549	    TP_ARGS(req)
550);
551
552TRACE_EVENT(i915_gem_request_notify,
553	    TP_PROTO(struct intel_engine_cs *ring),
554	    TP_ARGS(ring),
555
556	    TP_STRUCT__entry(
557			     __field(u32, dev)
558			     __field(u32, ring)
559			     __field(u32, seqno)
 
560			     ),
561
562	    TP_fast_assign(
563			   __entry->dev = ring->dev->primary->index;
564			   __entry->ring = ring->id;
565			   __entry->seqno = ring->get_seqno(ring, false);
 
566			   ),
567
568	    TP_printk("dev=%u, ring=%u, seqno=%u",
569		      __entry->dev, __entry->ring, __entry->seqno)
 
 
570);
571
572DEFINE_EVENT(i915_gem_request, i915_gem_request_retire,
573	    TP_PROTO(struct drm_i915_gem_request *req),
574	    TP_ARGS(req)
575);
576
577DEFINE_EVENT(i915_gem_request, i915_gem_request_complete,
578	    TP_PROTO(struct drm_i915_gem_request *req),
579	    TP_ARGS(req)
580);
581
582TRACE_EVENT(i915_gem_request_wait_begin,
583	    TP_PROTO(struct drm_i915_gem_request *req),
584	    TP_ARGS(req),
 
585
586	    TP_STRUCT__entry(
587			     __field(u32, dev)
588			     __field(u32, ring)
589			     __field(u32, seqno)
590			     __field(bool, blocking)
591			     ),
592
593	    /* NB: the blocking information is racy since mutex_is_locked
594	     * doesn't check that the current thread holds the lock. The only
595	     * other option would be to pass the boolean information of whether
596	     * or not the class was blocking down through the stack which is
597	     * less desirable.
598	     */
599	    TP_fast_assign(
600			   struct intel_engine_cs *ring =
601						i915_gem_request_get_ring(req);
602			   __entry->dev = ring->dev->primary->index;
603			   __entry->ring = ring->id;
604			   __entry->seqno = i915_gem_request_get_seqno(req);
605			   __entry->blocking =
606				     mutex_is_locked(&ring->dev->struct_mutex);
607			   ),
608
609	    TP_printk("dev=%u, ring=%u, seqno=%u, blocking=%s",
610		      __entry->dev, __entry->ring,
611		      __entry->seqno, __entry->blocking ?  "yes (NB)" : "no")
612);
613
614DEFINE_EVENT(i915_gem_request, i915_gem_request_wait_end,
615	    TP_PROTO(struct drm_i915_gem_request *req),
616	    TP_ARGS(req)
617);
618
619TRACE_EVENT(i915_flip_request,
620	    TP_PROTO(int plane, struct drm_i915_gem_object *obj),
 
 
621
622	    TP_ARGS(plane, obj),
 
 
 
623
624	    TP_STRUCT__entry(
625		    __field(int, plane)
626		    __field(struct drm_i915_gem_object *, obj)
627		    ),
628
629	    TP_fast_assign(
630		    __entry->plane = plane;
631		    __entry->obj = obj;
632		    ),
 
 
 
 
 
 
 
 
 
 
633
634	    TP_printk("plane=%d, obj=%p", __entry->plane, __entry->obj)
 
 
635);
636
637TRACE_EVENT(i915_flip_complete,
638	    TP_PROTO(int plane, struct drm_i915_gem_object *obj),
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
639
640	    TP_ARGS(plane, obj),
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
641
642	    TP_STRUCT__entry(
643		    __field(int, plane)
644		    __field(struct drm_i915_gem_object *, obj)
645		    ),
 
 
 
 
646
 
 
 
 
 
 
647	    TP_fast_assign(
648		    __entry->plane = plane;
649		    __entry->obj = obj;
650		    ),
 
 
 
 
 
 
 
 
 
 
651
652	    TP_printk("plane=%d, obj=%p", __entry->plane, __entry->obj)
 
 
653);
654
655TRACE_EVENT_CONDITION(i915_reg_rw,
656	TP_PROTO(bool write, i915_reg_t reg, u64 val, int len, bool trace),
657
658	TP_ARGS(write, reg, val, len, trace),
659
660	TP_CONDITION(trace),
661
662	TP_STRUCT__entry(
663		__field(u64, val)
664		__field(u32, reg)
665		__field(u16, write)
666		__field(u16, len)
667		),
668
669	TP_fast_assign(
670		__entry->val = (u64)val;
671		__entry->reg = i915_mmio_reg_offset(reg);
672		__entry->write = write;
673		__entry->len = len;
674		),
675
676	TP_printk("%s reg=0x%x, len=%d, val=(0x%x, 0x%x)",
677		__entry->write ? "write" : "read",
678		__entry->reg, __entry->len,
679		(u32)(__entry->val & 0xffffffff),
680		(u32)(__entry->val >> 32))
681);
682
683TRACE_EVENT(intel_gpu_freq_change,
684	    TP_PROTO(u32 freq),
685	    TP_ARGS(freq),
686
687	    TP_STRUCT__entry(
688			     __field(u32, freq)
689			     ),
690
691	    TP_fast_assign(
692			   __entry->freq = freq;
693			   ),
694
695	    TP_printk("new_freq=%u", __entry->freq)
696);
697
698/**
699 * DOC: i915_ppgtt_create and i915_ppgtt_release tracepoints
700 *
701 * With full ppgtt enabled each process using drm will allocate at least one
702 * translation table. With these traces it is possible to keep track of the
703 * allocation and of the lifetime of the tables; this can be used during
704 * testing/debug to verify that we are not leaking ppgtts.
705 * These traces identify the ppgtt through the vm pointer, which is also printed
706 * by the i915_vma_bind and i915_vma_unbind tracepoints.
707 */
708DECLARE_EVENT_CLASS(i915_ppgtt,
709	TP_PROTO(struct i915_address_space *vm),
710	TP_ARGS(vm),
711
712	TP_STRUCT__entry(
713			__field(struct i915_address_space *, vm)
714			__field(u32, dev)
715	),
716
717	TP_fast_assign(
718			__entry->vm = vm;
719			__entry->dev = vm->dev->primary->index;
720	),
721
722	TP_printk("dev=%u, vm=%p", __entry->dev, __entry->vm)
723)
724
725DEFINE_EVENT(i915_ppgtt, i915_ppgtt_create,
726	TP_PROTO(struct i915_address_space *vm),
727	TP_ARGS(vm)
728);
729
730DEFINE_EVENT(i915_ppgtt, i915_ppgtt_release,
731	TP_PROTO(struct i915_address_space *vm),
732	TP_ARGS(vm)
733);
734
735/**
736 * DOC: i915_context_create and i915_context_free tracepoints
737 *
738 * These tracepoints are used to track creation and deletion of contexts.
739 * If full ppgtt is enabled, they also print the address of the vm assigned to
740 * the context.
741 */
742DECLARE_EVENT_CLASS(i915_context,
743	TP_PROTO(struct intel_context *ctx),
744	TP_ARGS(ctx),
745
746	TP_STRUCT__entry(
747			__field(u32, dev)
748			__field(struct intel_context *, ctx)
749			__field(struct i915_address_space *, vm)
750	),
751
752	TP_fast_assign(
 
753			__entry->ctx = ctx;
754			__entry->vm = ctx->ppgtt ? &ctx->ppgtt->base : NULL;
755			__entry->dev = ctx->i915->dev->primary->index;
756	),
757
758	TP_printk("dev=%u, ctx=%p, ctx_vm=%p",
759		  __entry->dev, __entry->ctx, __entry->vm)
760)
761
762DEFINE_EVENT(i915_context, i915_context_create,
763	TP_PROTO(struct intel_context *ctx),
764	TP_ARGS(ctx)
765);
766
767DEFINE_EVENT(i915_context, i915_context_free,
768	TP_PROTO(struct intel_context *ctx),
769	TP_ARGS(ctx)
770);
771
772/**
773 * DOC: switch_mm tracepoint
774 *
775 * This tracepoint allows tracking of the mm switch, which is an important point
776 * in the lifetime of the vm in the legacy submission path. This tracepoint is
777 * called only if full ppgtt is enabled.
778 */
779TRACE_EVENT(switch_mm,
780	TP_PROTO(struct intel_engine_cs *ring, struct intel_context *to),
781
782	TP_ARGS(ring, to),
783
784	TP_STRUCT__entry(
785			__field(u32, ring)
786			__field(struct intel_context *, to)
787			__field(struct i915_address_space *, vm)
788			__field(u32, dev)
789	),
790
791	TP_fast_assign(
792			__entry->ring = ring->id;
793			__entry->to = to;
794			__entry->vm = to->ppgtt? &to->ppgtt->base : NULL;
795			__entry->dev = ring->dev->primary->index;
796	),
797
798	TP_printk("dev=%u, ring=%u, ctx=%p, ctx_vm=%p",
799		  __entry->dev, __entry->ring, __entry->to, __entry->vm)
800);
801
802#endif /* _I915_TRACE_H_ */
803
804/* This part must be outside protection */
805#undef TRACE_INCLUDE_PATH
806#define TRACE_INCLUDE_PATH .
 
 
807#include <trace/define_trace.h>
v6.13.7
  1/* SPDX-License-Identifier: GPL-2.0 */
  2
  3#undef TRACE_SYSTEM
  4#define TRACE_SYSTEM i915
  5
  6#if !defined(_I915_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
  7#define _I915_TRACE_H_
  8
  9#include <linux/stringify.h>
 10#include <linux/types.h>
 11#include <linux/tracepoint.h>
 12
 13#include <drm/drm_drv.h>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 14
 15#include "gt/intel_engine.h"
 
 
 16
 17#include "i915_drv.h"
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 18
 19/* object tracking */
 20
 21TRACE_EVENT(i915_gem_object_create,
 22	    TP_PROTO(struct drm_i915_gem_object *obj),
 23	    TP_ARGS(obj),
 24
 25	    TP_STRUCT__entry(
 26			     __field(struct drm_i915_gem_object *, obj)
 27			     __field(u64, size)
 28			     ),
 29
 30	    TP_fast_assign(
 31			   __entry->obj = obj;
 32			   __entry->size = obj->base.size;
 33			   ),
 34
 35	    TP_printk("obj=%p, size=0x%llx", __entry->obj, __entry->size)
 36);
 37
 38TRACE_EVENT(i915_gem_shrink,
 39	    TP_PROTO(struct drm_i915_private *i915, unsigned long target, unsigned flags),
 40	    TP_ARGS(i915, target, flags),
 41
 42	    TP_STRUCT__entry(
 43			     __field(int, dev)
 44			     __field(unsigned long, target)
 45			     __field(unsigned, flags)
 46			     ),
 47
 48	    TP_fast_assign(
 49			   __entry->dev = i915->drm.primary->index;
 50			   __entry->target = target;
 51			   __entry->flags = flags;
 52			   ),
 53
 54	    TP_printk("dev=%d, target=%lu, flags=%x",
 55		      __entry->dev, __entry->target, __entry->flags)
 56);
 57
 58TRACE_EVENT(i915_vma_bind,
 59	    TP_PROTO(struct i915_vma *vma, unsigned flags),
 60	    TP_ARGS(vma, flags),
 61
 62	    TP_STRUCT__entry(
 63			     __field(struct drm_i915_gem_object *, obj)
 64			     __field(struct i915_address_space *, vm)
 65			     __field(u64, offset)
 66			     __field(u64, size)
 67			     __field(unsigned, flags)
 68			     ),
 69
 70	    TP_fast_assign(
 71			   __entry->obj = vma->obj;
 72			   __entry->vm = vma->vm;
 73			   __entry->offset = vma->node.start;
 74			   __entry->size = vma->node.size;
 75			   __entry->flags = flags;
 76			   ),
 77
 78	    TP_printk("obj=%p, offset=0x%016llx size=0x%llx%s vm=%p",
 79		      __entry->obj, __entry->offset, __entry->size,
 80		      __entry->flags & PIN_MAPPABLE ? ", mappable" : "",
 81		      __entry->vm)
 82);
 83
 84TRACE_EVENT(i915_vma_unbind,
 85	    TP_PROTO(struct i915_vma *vma),
 86	    TP_ARGS(vma),
 87
 88	    TP_STRUCT__entry(
 89			     __field(struct drm_i915_gem_object *, obj)
 90			     __field(struct i915_address_space *, vm)
 91			     __field(u64, offset)
 92			     __field(u64, size)
 93			     ),
 94
 95	    TP_fast_assign(
 96			   __entry->obj = vma->obj;
 97			   __entry->vm = vma->vm;
 98			   __entry->offset = vma->node.start;
 99			   __entry->size = vma->node.size;
100			   ),
101
102	    TP_printk("obj=%p, offset=0x%016llx size=0x%llx vm=%p",
103		      __entry->obj, __entry->offset, __entry->size, __entry->vm)
104);
105
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
106TRACE_EVENT(i915_gem_object_pwrite,
107	    TP_PROTO(struct drm_i915_gem_object *obj, u64 offset, u64 len),
108	    TP_ARGS(obj, offset, len),
109
110	    TP_STRUCT__entry(
111			     __field(struct drm_i915_gem_object *, obj)
112			     __field(u64, offset)
113			     __field(u64, len)
114			     ),
115
116	    TP_fast_assign(
117			   __entry->obj = obj;
118			   __entry->offset = offset;
119			   __entry->len = len;
120			   ),
121
122	    TP_printk("obj=%p, offset=0x%llx, len=0x%llx",
123		      __entry->obj, __entry->offset, __entry->len)
124);
125
126TRACE_EVENT(i915_gem_object_pread,
127	    TP_PROTO(struct drm_i915_gem_object *obj, u64 offset, u64 len),
128	    TP_ARGS(obj, offset, len),
129
130	    TP_STRUCT__entry(
131			     __field(struct drm_i915_gem_object *, obj)
132			     __field(u64, offset)
133			     __field(u64, len)
134			     ),
135
136	    TP_fast_assign(
137			   __entry->obj = obj;
138			   __entry->offset = offset;
139			   __entry->len = len;
140			   ),
141
142	    TP_printk("obj=%p, offset=0x%llx, len=0x%llx",
143		      __entry->obj, __entry->offset, __entry->len)
144);
145
146TRACE_EVENT(i915_gem_object_fault,
147	    TP_PROTO(struct drm_i915_gem_object *obj, u64 index, bool gtt, bool write),
148	    TP_ARGS(obj, index, gtt, write),
149
150	    TP_STRUCT__entry(
151			     __field(struct drm_i915_gem_object *, obj)
152			     __field(u64, index)
153			     __field(bool, gtt)
154			     __field(bool, write)
155			     ),
156
157	    TP_fast_assign(
158			   __entry->obj = obj;
159			   __entry->index = index;
160			   __entry->gtt = gtt;
161			   __entry->write = write;
162			   ),
163
164	    TP_printk("obj=%p, %s index=%llu %s",
165		      __entry->obj,
166		      __entry->gtt ? "GTT" : "CPU",
167		      __entry->index,
168		      __entry->write ? ", writable" : "")
169);
170
171DECLARE_EVENT_CLASS(i915_gem_object,
172	    TP_PROTO(struct drm_i915_gem_object *obj),
173	    TP_ARGS(obj),
174
175	    TP_STRUCT__entry(
176			     __field(struct drm_i915_gem_object *, obj)
177			     ),
178
179	    TP_fast_assign(
180			   __entry->obj = obj;
181			   ),
182
183	    TP_printk("obj=%p", __entry->obj)
184);
185
186DEFINE_EVENT(i915_gem_object, i915_gem_object_clflush,
187	     TP_PROTO(struct drm_i915_gem_object *obj),
188	     TP_ARGS(obj)
189);
190
191DEFINE_EVENT(i915_gem_object, i915_gem_object_destroy,
192	    TP_PROTO(struct drm_i915_gem_object *obj),
193	    TP_ARGS(obj)
194);
195
196TRACE_EVENT(i915_gem_evict,
197	    TP_PROTO(struct i915_address_space *vm, u64 size, u64 align, unsigned int flags),
198	    TP_ARGS(vm, size, align, flags),
199
200	    TP_STRUCT__entry(
201			     __field(u32, dev)
202			     __field(struct i915_address_space *, vm)
203			     __field(u64, size)
204			     __field(u64, align)
205			     __field(unsigned int, flags)
206			    ),
207
208	    TP_fast_assign(
209			   __entry->dev = vm->i915->drm.primary->index;
210			   __entry->vm = vm;
211			   __entry->size = size;
212			   __entry->align = align;
213			   __entry->flags = flags;
214			  ),
215
216	    TP_printk("dev=%d, vm=%p, size=0x%llx, align=0x%llx %s",
217		      __entry->dev, __entry->vm, __entry->size, __entry->align,
218		      __entry->flags & PIN_MAPPABLE ? ", mappable" : "")
219);
220
221TRACE_EVENT(i915_gem_evict_node,
222	    TP_PROTO(struct i915_address_space *vm, struct drm_mm_node *node, unsigned int flags),
223	    TP_ARGS(vm, node, flags),
224
225	    TP_STRUCT__entry(
226			     __field(u32, dev)
227			     __field(struct i915_address_space *, vm)
228			     __field(u64, start)
229			     __field(u64, size)
230			     __field(unsigned long, color)
231			     __field(unsigned int, flags)
232			    ),
233
234	    TP_fast_assign(
235			   __entry->dev = vm->i915->drm.primary->index;
236			   __entry->vm = vm;
237			   __entry->start = node->start;
238			   __entry->size = node->size;
239			   __entry->color = node->color;
240			   __entry->flags = flags;
241			  ),
242
243	    TP_printk("dev=%d, vm=%p, start=0x%llx size=0x%llx, color=0x%lx, flags=%x",
244		      __entry->dev, __entry->vm,
245		      __entry->start, __entry->size,
246		      __entry->color, __entry->flags)
247);
248
249TRACE_EVENT(i915_gem_evict_vm,
250	    TP_PROTO(struct i915_address_space *vm),
251	    TP_ARGS(vm),
252
253	    TP_STRUCT__entry(
254			     __field(u32, dev)
255			     __field(struct i915_address_space *, vm)
256			    ),
257
258	    TP_fast_assign(
259			   __entry->dev = vm->i915->drm.primary->index;
260			   __entry->vm = vm;
261			  ),
262
263	    TP_printk("dev=%d, vm=%p", __entry->dev, __entry->vm)
264);
265
266TRACE_EVENT(i915_request_queue,
267	    TP_PROTO(struct i915_request *rq, u32 flags),
268	    TP_ARGS(rq, flags),
 
 
269
270	    TP_STRUCT__entry(
271			     __field(u32, dev)
272			     __field(u64, ctx)
273			     __field(u16, class)
274			     __field(u16, instance)
275			     __field(u32, seqno)
276			     __field(u32, flags)
277			     ),
278
279	    TP_fast_assign(
280			   __entry->dev = rq->i915->drm.primary->index;
281			   __entry->class = rq->engine->uabi_class;
282			   __entry->instance = rq->engine->uabi_instance;
283			   __entry->ctx = rq->fence.context;
284			   __entry->seqno = rq->fence.seqno;
285			   __entry->flags = flags;
286			   ),
287
288	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, flags=0x%x",
289		      __entry->dev, __entry->class, __entry->instance,
290		      __entry->ctx, __entry->seqno, __entry->flags)
 
291);
292
293DECLARE_EVENT_CLASS(i915_request,
294	    TP_PROTO(struct i915_request *rq),
295	    TP_ARGS(rq),
296
297	    TP_STRUCT__entry(
298			     __field(u32, dev)
299			     __field(u64, ctx)
300			     __field(u16, class)
301			     __field(u16, instance)
302			     __field(u32, seqno)
303			     __field(u32, tail)
304			     ),
305
306	    TP_fast_assign(
307			   __entry->dev = rq->i915->drm.primary->index;
308			   __entry->class = rq->engine->uabi_class;
309			   __entry->instance = rq->engine->uabi_instance;
310			   __entry->ctx = rq->fence.context;
311			   __entry->seqno = rq->fence.seqno;
312			   __entry->tail = rq->tail;
 
313			   ),
314
315	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, tail=%u",
316		      __entry->dev, __entry->class, __entry->instance,
317		      __entry->ctx, __entry->seqno, __entry->tail)
318);
319
320DEFINE_EVENT(i915_request, i915_request_add,
321	     TP_PROTO(struct i915_request *rq),
322	     TP_ARGS(rq)
323);
324
325#if IS_ENABLED(CONFIG_DRM_I915_LOW_LEVEL_TRACEPOINTS)
326DEFINE_EVENT(i915_request, i915_request_guc_submit,
327	     TP_PROTO(struct i915_request *rq),
328	     TP_ARGS(rq)
329);
 
330
331DEFINE_EVENT(i915_request, i915_request_submit,
332	     TP_PROTO(struct i915_request *rq),
333	     TP_ARGS(rq)
334);
 
 
335
336DEFINE_EVENT(i915_request, i915_request_execute,
337	     TP_PROTO(struct i915_request *rq),
338	     TP_ARGS(rq)
339);
340
341TRACE_EVENT(i915_request_in,
342	    TP_PROTO(struct i915_request *rq, unsigned int port),
343	    TP_ARGS(rq, port),
344
345	    TP_STRUCT__entry(
346			     __field(u32, dev)
347			     __field(u64, ctx)
348			     __field(u16, class)
349			     __field(u16, instance)
350			     __field(u32, seqno)
351			     __field(u32, port)
352			     __field(s32, prio)
353			    ),
354
355	    TP_fast_assign(
356			   __entry->dev = rq->i915->drm.primary->index;
357			   __entry->class = rq->engine->uabi_class;
358			   __entry->instance = rq->engine->uabi_instance;
359			   __entry->ctx = rq->fence.context;
360			   __entry->seqno = rq->fence.seqno;
361			   __entry->prio = rq->sched.attr.priority;
362			   __entry->port = port;
363			   ),
364
365	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, prio=%d, port=%u",
366		      __entry->dev, __entry->class, __entry->instance,
367		      __entry->ctx, __entry->seqno,
368		      __entry->prio, __entry->port)
369);
370
371TRACE_EVENT(i915_request_out,
372	    TP_PROTO(struct i915_request *rq),
373	    TP_ARGS(rq),
374
375	    TP_STRUCT__entry(
376			     __field(u32, dev)
377			     __field(u64, ctx)
378			     __field(u16, class)
379			     __field(u16, instance)
380			     __field(u32, seqno)
381			     __field(u32, completed)
382			    ),
383
384	    TP_fast_assign(
385			   __entry->dev = rq->i915->drm.primary->index;
386			   __entry->class = rq->engine->uabi_class;
387			   __entry->instance = rq->engine->uabi_instance;
388			   __entry->ctx = rq->fence.context;
389			   __entry->seqno = rq->fence.seqno;
390			   __entry->completed = i915_request_completed(rq);
391			   ),
392
393		    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, completed?=%u",
394			      __entry->dev, __entry->class, __entry->instance,
395			      __entry->ctx, __entry->seqno, __entry->completed)
396);
397
398DECLARE_EVENT_CLASS(intel_context,
399		    TP_PROTO(struct intel_context *ce),
400		    TP_ARGS(ce),
401
402		    TP_STRUCT__entry(
403			     __field(u32, guc_id)
404			     __field(int, pin_count)
405			     __field(u32, sched_state)
406			     __field(u8, guc_prio)
407			     ),
408
409		    TP_fast_assign(
410			   __entry->guc_id = ce->guc_id.id;
411			   __entry->pin_count = atomic_read(&ce->pin_count);
412			   __entry->sched_state = ce->guc_state.sched_state;
413			   __entry->guc_prio = ce->guc_state.prio;
414			   ),
415
416		    TP_printk("guc_id=%d, pin_count=%d sched_state=0x%x, guc_prio=%u",
417			      __entry->guc_id, __entry->pin_count,
418			      __entry->sched_state,
419			      __entry->guc_prio)
420);
421
422DEFINE_EVENT(intel_context, intel_context_set_prio,
423	     TP_PROTO(struct intel_context *ce),
424	     TP_ARGS(ce)
425);
426
427DEFINE_EVENT(intel_context, intel_context_reset,
428	     TP_PROTO(struct intel_context *ce),
429	     TP_ARGS(ce)
430);
431
432DEFINE_EVENT(intel_context, intel_context_ban,
433	     TP_PROTO(struct intel_context *ce),
434	     TP_ARGS(ce)
435);
436
437DEFINE_EVENT(intel_context, intel_context_register,
438	     TP_PROTO(struct intel_context *ce),
439	     TP_ARGS(ce)
440);
 
 
441
442DEFINE_EVENT(intel_context, intel_context_deregister,
443	     TP_PROTO(struct intel_context *ce),
444	     TP_ARGS(ce)
445);
 
 
 
 
 
 
 
 
 
 
 
446
447DEFINE_EVENT(intel_context, intel_context_deregister_done,
448	     TP_PROTO(struct intel_context *ce),
449	     TP_ARGS(ce)
450);
451
452DEFINE_EVENT(intel_context, intel_context_sched_enable,
453	     TP_PROTO(struct intel_context *ce),
454	     TP_ARGS(ce)
455);
456
457DEFINE_EVENT(intel_context, intel_context_sched_disable,
458	     TP_PROTO(struct intel_context *ce),
459	     TP_ARGS(ce)
460);
461
462DEFINE_EVENT(intel_context, intel_context_sched_done,
463	     TP_PROTO(struct intel_context *ce),
464	     TP_ARGS(ce)
465);
466
467DEFINE_EVENT(intel_context, intel_context_create,
468	     TP_PROTO(struct intel_context *ce),
469	     TP_ARGS(ce)
470);
471
472DEFINE_EVENT(intel_context, intel_context_fence_release,
473	     TP_PROTO(struct intel_context *ce),
474	     TP_ARGS(ce)
475);
476
477DEFINE_EVENT(intel_context, intel_context_free,
478	     TP_PROTO(struct intel_context *ce),
479	     TP_ARGS(ce)
480);
481
482DEFINE_EVENT(intel_context, intel_context_steal_guc_id,
483	     TP_PROTO(struct intel_context *ce),
484	     TP_ARGS(ce)
485);
486
487DEFINE_EVENT(intel_context, intel_context_do_pin,
488	     TP_PROTO(struct intel_context *ce),
489	     TP_ARGS(ce)
490);
491
492DEFINE_EVENT(intel_context, intel_context_do_unpin,
493	     TP_PROTO(struct intel_context *ce),
494	     TP_ARGS(ce)
495);
496
497#else
498#if !defined(TRACE_HEADER_MULTI_READ)
499static inline void
500trace_i915_request_guc_submit(struct i915_request *rq)
501{
502}
503
504static inline void
505trace_i915_request_submit(struct i915_request *rq)
506{
507}
508
509static inline void
510trace_i915_request_execute(struct i915_request *rq)
511{
512}
513
514static inline void
515trace_i915_request_in(struct i915_request *rq, unsigned int port)
516{
517}
518
519static inline void
520trace_i915_request_out(struct i915_request *rq)
521{
522}
523
524static inline void
525trace_intel_context_set_prio(struct intel_context *ce)
526{
527}
528
529static inline void
530trace_intel_context_reset(struct intel_context *ce)
531{
532}
533
534static inline void
535trace_intel_context_ban(struct intel_context *ce)
536{
537}
538
539static inline void
540trace_intel_context_register(struct intel_context *ce)
541{
542}
543
544static inline void
545trace_intel_context_deregister(struct intel_context *ce)
546{
547}
548
549static inline void
550trace_intel_context_deregister_done(struct intel_context *ce)
551{
552}
553
554static inline void
555trace_intel_context_sched_enable(struct intel_context *ce)
556{
557}
558
559static inline void
560trace_intel_context_sched_disable(struct intel_context *ce)
561{
562}
563
564static inline void
565trace_intel_context_sched_done(struct intel_context *ce)
566{
567}
568
569static inline void
570trace_intel_context_create(struct intel_context *ce)
571{
572}
573
574static inline void
575trace_intel_context_fence_release(struct intel_context *ce)
576{
577}
578
579static inline void
580trace_intel_context_free(struct intel_context *ce)
581{
582}
583
584static inline void
585trace_intel_context_steal_guc_id(struct intel_context *ce)
586{
587}
588
589static inline void
590trace_intel_context_do_pin(struct intel_context *ce)
591{
592}
593
594static inline void
595trace_intel_context_do_unpin(struct intel_context *ce)
596{
597}
598#endif
599#endif
600
601DEFINE_EVENT(i915_request, i915_request_retire,
602	    TP_PROTO(struct i915_request *rq),
603	    TP_ARGS(rq)
604);
605
606TRACE_EVENT(i915_request_wait_begin,
607	    TP_PROTO(struct i915_request *rq, unsigned int flags),
608	    TP_ARGS(rq, flags),
609
610	    TP_STRUCT__entry(
611			     __field(u32, dev)
612			     __field(u64, ctx)
613			     __field(u16, class)
614			     __field(u16, instance)
615			     __field(u32, seqno)
616			     __field(unsigned int, flags)
617			     ),
618
619	    /* NB: the blocking information is racy since mutex_is_locked
620	     * doesn't check that the current thread holds the lock. The only
621	     * other option would be to pass the boolean information of whether
622	     * or not the class was blocking down through the stack which is
623	     * less desirable.
624	     */
625	    TP_fast_assign(
626			   __entry->dev = rq->i915->drm.primary->index;
627			   __entry->class = rq->engine->uabi_class;
628			   __entry->instance = rq->engine->uabi_instance;
629			   __entry->ctx = rq->fence.context;
630			   __entry->seqno = rq->fence.seqno;
631			   __entry->flags = flags;
632			   ),
633
634	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, flags=0x%x",
635		      __entry->dev, __entry->class, __entry->instance,
636		      __entry->ctx, __entry->seqno,
637		      __entry->flags)
638);
639
640DEFINE_EVENT(i915_request, i915_request_wait_end,
641	    TP_PROTO(struct i915_request *rq),
642	    TP_ARGS(rq)
643);
644
645TRACE_EVENT_CONDITION(i915_reg_rw,
646	TP_PROTO(bool write, i915_reg_t reg, u64 val, int len, bool trace),
647
648	TP_ARGS(write, reg, val, len, trace),
649
650	TP_CONDITION(trace),
651
652	TP_STRUCT__entry(
653		__field(u64, val)
654		__field(u32, reg)
655		__field(u16, write)
656		__field(u16, len)
657		),
658
659	TP_fast_assign(
660		__entry->val = (u64)val;
661		__entry->reg = i915_mmio_reg_offset(reg);
662		__entry->write = write;
663		__entry->len = len;
664		),
665
666	TP_printk("%s reg=0x%x, len=%d, val=(0x%x, 0x%x)",
667		__entry->write ? "write" : "read",
668		__entry->reg, __entry->len,
669		(u32)(__entry->val & 0xffffffff),
670		(u32)(__entry->val >> 32))
671);
672
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
673/**
674 * DOC: i915_ppgtt_create and i915_ppgtt_release tracepoints
675 *
676 * With full ppgtt enabled each process using drm will allocate at least one
677 * translation table. With these traces it is possible to keep track of the
678 * allocation and of the lifetime of the tables; this can be used during
679 * testing/debug to verify that we are not leaking ppgtts.
680 * These traces identify the ppgtt through the vm pointer, which is also printed
681 * by the i915_vma_bind and i915_vma_unbind tracepoints.
682 */
683DECLARE_EVENT_CLASS(i915_ppgtt,
684	TP_PROTO(struct i915_address_space *vm),
685	TP_ARGS(vm),
686
687	TP_STRUCT__entry(
688			__field(struct i915_address_space *, vm)
689			__field(u32, dev)
690	),
691
692	TP_fast_assign(
693			__entry->vm = vm;
694			__entry->dev = vm->i915->drm.primary->index;
695	),
696
697	TP_printk("dev=%u, vm=%p", __entry->dev, __entry->vm)
698)
699
700DEFINE_EVENT(i915_ppgtt, i915_ppgtt_create,
701	TP_PROTO(struct i915_address_space *vm),
702	TP_ARGS(vm)
703);
704
705DEFINE_EVENT(i915_ppgtt, i915_ppgtt_release,
706	TP_PROTO(struct i915_address_space *vm),
707	TP_ARGS(vm)
708);
709
710/**
711 * DOC: i915_context_create and i915_context_free tracepoints
712 *
713 * These tracepoints are used to track creation and deletion of contexts.
714 * If full ppgtt is enabled, they also print the address of the vm assigned to
715 * the context.
716 */
717DECLARE_EVENT_CLASS(i915_context,
718	TP_PROTO(struct i915_gem_context *ctx),
719	TP_ARGS(ctx),
720
721	TP_STRUCT__entry(
722			__field(u32, dev)
723			__field(struct i915_gem_context *, ctx)
724			__field(struct i915_address_space *, vm)
725	),
726
727	TP_fast_assign(
728			__entry->dev = ctx->i915->drm.primary->index;
729			__entry->ctx = ctx;
730			__entry->vm = ctx->vm;
 
731	),
732
733	TP_printk("dev=%u, ctx=%p, ctx_vm=%p",
734		  __entry->dev, __entry->ctx, __entry->vm)
735)
736
737DEFINE_EVENT(i915_context, i915_context_create,
738	TP_PROTO(struct i915_gem_context *ctx),
739	TP_ARGS(ctx)
740);
741
742DEFINE_EVENT(i915_context, i915_context_free,
743	TP_PROTO(struct i915_gem_context *ctx),
744	TP_ARGS(ctx)
745);
746
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
747#endif /* _I915_TRACE_H_ */
748
749/* This part must be outside protection */
750#undef TRACE_INCLUDE_PATH
751#undef TRACE_INCLUDE_FILE
752#define TRACE_INCLUDE_PATH ../../drivers/gpu/drm/i915
753#define TRACE_INCLUDE_FILE i915_trace
754#include <trace/define_trace.h>