i915_trace.h 27.2 KB
Newer Older
1
/* SPDX-License-Identifier: GPL-2.0 */
C
Chris Wilson 已提交
2 3 4 5 6 7 8
#if !defined(_I915_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
#define _I915_TRACE_H_

#include <linux/stringify.h>
#include <linux/types.h>
#include <linux/tracepoint.h>

9 10
#include <drm/drm_drv.h>

11
#include "display/intel_display_types.h"
12 13
#include "gt/intel_engine.h"

14
#include "i915_drv.h"
15
#include "i915_irq.h"
C
Chris Wilson 已提交
16 17 18 19 20

#undef TRACE_SYSTEM
#define TRACE_SYSTEM i915
#define TRACE_INCLUDE_FILE i915_trace

21 22
/* watermark/fifo updates */

23
TRACE_EVENT(intel_pipe_enable,
24 25
	    TP_PROTO(struct intel_crtc *crtc),
	    TP_ARGS(crtc),
26 27 28 29 30 31 32

	    TP_STRUCT__entry(
			     __array(u32, frame, 3)
			     __array(u32, scanline, 3)
			     __field(enum pipe, pipe)
			     ),
	    TP_fast_assign(
33 34 35 36 37
			   struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
			   struct intel_crtc *it__;
			   for_each_intel_crtc(&dev_priv->drm, it__) {
				   __entry->frame[it__->pipe] = intel_crtc_get_vblank_counter(it__);
				   __entry->scanline[it__->pipe] = intel_get_crtc_scanline(it__);
38
			   }
39
			   __entry->pipe = crtc->pipe;
40 41 42 43 44 45 46 47 48 49
			   ),

	    TP_printk("pipe %c enable, pipe A: frame=%u, scanline=%u, pipe B: frame=%u, scanline=%u, pipe C: frame=%u, scanline=%u",
		      pipe_name(__entry->pipe),
		      __entry->frame[PIPE_A], __entry->scanline[PIPE_A],
		      __entry->frame[PIPE_B], __entry->scanline[PIPE_B],
		      __entry->frame[PIPE_C], __entry->scanline[PIPE_C])
);

TRACE_EVENT(intel_pipe_disable,
50 51
	    TP_PROTO(struct intel_crtc *crtc),
	    TP_ARGS(crtc),
52 53 54 55 56 57 58 59

	    TP_STRUCT__entry(
			     __array(u32, frame, 3)
			     __array(u32, scanline, 3)
			     __field(enum pipe, pipe)
			     ),

	    TP_fast_assign(
60 61 62 63 64
			   struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
			   struct intel_crtc *it__;
			   for_each_intel_crtc(&dev_priv->drm, it__) {
				   __entry->frame[it__->pipe] = intel_crtc_get_vblank_counter(it__);
				   __entry->scanline[it__->pipe] = intel_get_crtc_scanline(it__);
65
			   }
66
			   __entry->pipe = crtc->pipe;
67 68 69 70 71 72 73 74 75
			   ),

	    TP_printk("pipe %c disable, pipe A: frame=%u, scanline=%u, pipe B: frame=%u, scanline=%u, pipe C: frame=%u, scanline=%u",
		      pipe_name(__entry->pipe),
		      __entry->frame[PIPE_A], __entry->scanline[PIPE_A],
		      __entry->frame[PIPE_B], __entry->scanline[PIPE_B],
		      __entry->frame[PIPE_C], __entry->scanline[PIPE_C])
);

76 77 78 79 80 81 82 83 84 85 86 87 88
TRACE_EVENT(intel_pipe_crc,
	    TP_PROTO(struct intel_crtc *crtc, const u32 *crcs),
	    TP_ARGS(crtc, crcs),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     __array(u32, crcs, 5)
			     ),

	    TP_fast_assign(
			   __entry->pipe = crtc->pipe;
89
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
90 91 92 93 94 95 96 97 98 99
			   __entry->scanline = intel_get_crtc_scanline(crtc);
			   memcpy(__entry->crcs, crcs, sizeof(__entry->crcs));
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u crc=%08x %08x %08x %08x %08x",
		      pipe_name(__entry->pipe), __entry->frame, __entry->scanline,
		      __entry->crcs[0], __entry->crcs[1], __entry->crcs[2],
		      __entry->crcs[3], __entry->crcs[4])
);

100 101 102 103 104 105 106 107 108 109 110
TRACE_EVENT(intel_cpu_fifo_underrun,
	    TP_PROTO(struct drm_i915_private *dev_priv, enum pipe pipe),
	    TP_ARGS(dev_priv, pipe),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     ),

	    TP_fast_assign(
111
			    struct intel_crtc *crtc = intel_get_crtc_for_pipe(dev_priv, pipe);
112
			   __entry->pipe = pipe;
113 114
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
			   __entry->scanline = intel_get_crtc_scanline(crtc);
115 116 117 118 119 120 121 122
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u",
		      pipe_name(__entry->pipe),
		      __entry->frame, __entry->scanline)
);

TRACE_EVENT(intel_pch_fifo_underrun,
123
	    TP_PROTO(struct drm_i915_private *dev_priv, enum pipe pch_transcoder),
124 125 126 127 128 129 130 131 132
	    TP_ARGS(dev_priv, pch_transcoder),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     ),

	    TP_fast_assign(
133
			   enum pipe pipe = pch_transcoder;
134
			   struct intel_crtc *crtc = intel_get_crtc_for_pipe(dev_priv, pipe);
135
			   __entry->pipe = pipe;
136 137
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
			   __entry->scanline = intel_get_crtc_scanline(crtc);
138 139 140 141 142 143 144
			   ),

	    TP_printk("pch transcoder %c, frame=%u, scanline=%u",
		      pipe_name(__entry->pipe),
		      __entry->frame, __entry->scanline)
);

145 146 147 148 149 150 151 152 153 154 155 156
TRACE_EVENT(intel_memory_cxsr,
	    TP_PROTO(struct drm_i915_private *dev_priv, bool old, bool new),
	    TP_ARGS(dev_priv, old, new),

	    TP_STRUCT__entry(
			     __array(u32, frame, 3)
			     __array(u32, scanline, 3)
			     __field(bool, old)
			     __field(bool, new)
			     ),

	    TP_fast_assign(
157 158 159 160
			   struct intel_crtc *crtc;
			   for_each_intel_crtc(&dev_priv->drm, crtc) {
				   __entry->frame[crtc->pipe] = intel_crtc_get_vblank_counter(crtc);
				   __entry->scanline[crtc->pipe] = intel_get_crtc_scanline(crtc);
161 162 163 164 165 166 167 168 169 170 171 172
			   }
			   __entry->old = old;
			   __entry->new = new;
			   ),

	    TP_printk("%s->%s, pipe A: frame=%u, scanline=%u, pipe B: frame=%u, scanline=%u, pipe C: frame=%u, scanline=%u",
		      onoff(__entry->old), onoff(__entry->new),
		      __entry->frame[PIPE_A], __entry->scanline[PIPE_A],
		      __entry->frame[PIPE_B], __entry->scanline[PIPE_B],
		      __entry->frame[PIPE_C], __entry->scanline[PIPE_C])
);

173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196
TRACE_EVENT(g4x_wm,
	    TP_PROTO(struct intel_crtc *crtc, const struct g4x_wm_values *wm),
	    TP_ARGS(crtc, wm),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     __field(u16, primary)
			     __field(u16, sprite)
			     __field(u16, cursor)
			     __field(u16, sr_plane)
			     __field(u16, sr_cursor)
			     __field(u16, sr_fbc)
			     __field(u16, hpll_plane)
			     __field(u16, hpll_cursor)
			     __field(u16, hpll_fbc)
			     __field(bool, cxsr)
			     __field(bool, hpll)
			     __field(bool, fbc)
			     ),

	    TP_fast_assign(
			   __entry->pipe = crtc->pipe;
197
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220
			   __entry->scanline = intel_get_crtc_scanline(crtc);
			   __entry->primary = wm->pipe[crtc->pipe].plane[PLANE_PRIMARY];
			   __entry->sprite = wm->pipe[crtc->pipe].plane[PLANE_SPRITE0];
			   __entry->cursor = wm->pipe[crtc->pipe].plane[PLANE_CURSOR];
			   __entry->sr_plane = wm->sr.plane;
			   __entry->sr_cursor = wm->sr.cursor;
			   __entry->sr_fbc = wm->sr.fbc;
			   __entry->hpll_plane = wm->hpll.plane;
			   __entry->hpll_cursor = wm->hpll.cursor;
			   __entry->hpll_fbc = wm->hpll.fbc;
			   __entry->cxsr = wm->cxsr;
			   __entry->hpll = wm->hpll_en;
			   __entry->fbc = wm->fbc_en;
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u, wm %d/%d/%d, sr %s/%d/%d/%d, hpll %s/%d/%d/%d, fbc %s",
		      pipe_name(__entry->pipe), __entry->frame, __entry->scanline,
		      __entry->primary, __entry->sprite, __entry->cursor,
		      yesno(__entry->cxsr), __entry->sr_plane, __entry->sr_cursor, __entry->sr_fbc,
		      yesno(__entry->hpll), __entry->hpll_plane, __entry->hpll_cursor, __entry->hpll_fbc,
		      yesno(__entry->fbc))
);

221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240
TRACE_EVENT(vlv_wm,
	    TP_PROTO(struct intel_crtc *crtc, const struct vlv_wm_values *wm),
	    TP_ARGS(crtc, wm),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     __field(u32, level)
			     __field(u32, cxsr)
			     __field(u32, primary)
			     __field(u32, sprite0)
			     __field(u32, sprite1)
			     __field(u32, cursor)
			     __field(u32, sr_plane)
			     __field(u32, sr_cursor)
			     ),

	    TP_fast_assign(
			   __entry->pipe = crtc->pipe;
241
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274
			   __entry->scanline = intel_get_crtc_scanline(crtc);
			   __entry->level = wm->level;
			   __entry->cxsr = wm->cxsr;
			   __entry->primary = wm->pipe[crtc->pipe].plane[PLANE_PRIMARY];
			   __entry->sprite0 = wm->pipe[crtc->pipe].plane[PLANE_SPRITE0];
			   __entry->sprite1 = wm->pipe[crtc->pipe].plane[PLANE_SPRITE1];
			   __entry->cursor = wm->pipe[crtc->pipe].plane[PLANE_CURSOR];
			   __entry->sr_plane = wm->sr.plane;
			   __entry->sr_cursor = wm->sr.cursor;
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u, level=%d, cxsr=%d, wm %d/%d/%d/%d, sr %d/%d",
		      pipe_name(__entry->pipe), __entry->frame,
		      __entry->scanline, __entry->level, __entry->cxsr,
		      __entry->primary, __entry->sprite0, __entry->sprite1, __entry->cursor,
		      __entry->sr_plane, __entry->sr_cursor)
);

TRACE_EVENT(vlv_fifo_size,
	    TP_PROTO(struct intel_crtc *crtc, u32 sprite0_start, u32 sprite1_start, u32 fifo_size),
	    TP_ARGS(crtc, sprite0_start, sprite1_start, fifo_size),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     __field(u32, sprite0_start)
			     __field(u32, sprite1_start)
			     __field(u32, fifo_size)
			     ),

	    TP_fast_assign(
			   __entry->pipe = crtc->pipe;
275
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
276 277 278 279 280 281 282 283 284 285 286 287
			   __entry->scanline = intel_get_crtc_scanline(crtc);
			   __entry->sprite0_start = sprite0_start;
			   __entry->sprite1_start = sprite1_start;
			   __entry->fifo_size = fifo_size;
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u, %d/%d/%d",
		      pipe_name(__entry->pipe), __entry->frame,
		      __entry->scanline, __entry->sprite0_start,
		      __entry->sprite1_start, __entry->fifo_size)
);

288 289 290 291 292 293 294 295 296 297 298 299
/* plane updates */

TRACE_EVENT(intel_update_plane,
	    TP_PROTO(struct drm_plane *plane, struct intel_crtc *crtc),
	    TP_ARGS(plane, crtc),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     __array(int, src, 4)
			     __array(int, dst, 4)
300
			     __string(name, plane->name)
301 302 303
			     ),

	    TP_fast_assign(
304
			   __assign_str(name, plane->name);
305
			   __entry->pipe = crtc->pipe;
306
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
307 308 309 310 311 312
			   __entry->scanline = intel_get_crtc_scanline(crtc);
			   memcpy(__entry->src, &plane->state->src, sizeof(__entry->src));
			   memcpy(__entry->dst, &plane->state->dst, sizeof(__entry->dst));
			   ),

	    TP_printk("pipe %c, plane %s, frame=%u, scanline=%u, " DRM_RECT_FP_FMT " -> " DRM_RECT_FMT,
313
		      pipe_name(__entry->pipe), __get_str(name),
314 315 316 317 318 319 320 321 322 323 324 325 326
		      __entry->frame, __entry->scanline,
		      DRM_RECT_FP_ARG((const struct drm_rect *)__entry->src),
		      DRM_RECT_ARG((const struct drm_rect *)__entry->dst))
);

TRACE_EVENT(intel_disable_plane,
	    TP_PROTO(struct drm_plane *plane, struct intel_crtc *crtc),
	    TP_ARGS(plane, crtc),

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
327
			     __string(name, plane->name)
328 329 330
			     ),

	    TP_fast_assign(
331
			   __assign_str(name, plane->name);
332
			   __entry->pipe = crtc->pipe;
333
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
334 335 336 337
			   __entry->scanline = intel_get_crtc_scanline(crtc);
			   ),

	    TP_printk("pipe %c, plane %s, frame=%u, scanline=%u",
338
		      pipe_name(__entry->pipe), __get_str(name),
339 340 341
		      __entry->frame, __entry->scanline)
);

342 343 344
/* pipe updates */

TRACE_EVENT(i915_pipe_update_start,
345 346
	    TP_PROTO(struct intel_crtc *crtc),
	    TP_ARGS(crtc),
347 348 349 350 351 352 353 354 355 356 357

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     __field(u32, min)
			     __field(u32, max)
			     ),

	    TP_fast_assign(
			   __entry->pipe = crtc->pipe;
358
			   __entry->frame = intel_crtc_get_vblank_counter(crtc);
359
			   __entry->scanline = intel_get_crtc_scanline(crtc);
360 361
			   __entry->min = crtc->debug.min_vbl;
			   __entry->max = crtc->debug.max_vbl;
362 363 364 365 366 367 368 369
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u, min=%u, max=%u",
		      pipe_name(__entry->pipe), __entry->frame,
		       __entry->scanline, __entry->min, __entry->max)
);

TRACE_EVENT(i915_pipe_update_vblank_evaded,
370 371
	    TP_PROTO(struct intel_crtc *crtc),
	    TP_ARGS(crtc),
372 373 374 375 376 377 378 379 380 381 382

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     __field(u32, min)
			     __field(u32, max)
			     ),

	    TP_fast_assign(
			   __entry->pipe = crtc->pipe;
383 384 385 386
			   __entry->frame = crtc->debug.start_vbl_count;
			   __entry->scanline = crtc->debug.scanline_start;
			   __entry->min = crtc->debug.min_vbl;
			   __entry->max = crtc->debug.max_vbl;
387 388 389 390 391 392 393 394
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u, min=%u, max=%u",
		      pipe_name(__entry->pipe), __entry->frame,
		       __entry->scanline, __entry->min, __entry->max)
);

TRACE_EVENT(i915_pipe_update_end,
395 396
	    TP_PROTO(struct intel_crtc *crtc, u32 frame, int scanline_end),
	    TP_ARGS(crtc, frame, scanline_end),
397 398 399 400 401 402 403 404 405 406

	    TP_STRUCT__entry(
			     __field(enum pipe, pipe)
			     __field(u32, frame)
			     __field(u32, scanline)
			     ),

	    TP_fast_assign(
			   __entry->pipe = crtc->pipe;
			   __entry->frame = frame;
407
			   __entry->scanline = scanline_end;
408 409 410 411 412 413 414
			   ),

	    TP_printk("pipe %c, frame=%u, scanline=%u",
		      pipe_name(__entry->pipe), __entry->frame,
		      __entry->scanline)
);

C
Chris Wilson 已提交
415 416 417
/* object tracking */

TRACE_EVENT(i915_gem_object_create,
418
	    TP_PROTO(struct drm_i915_gem_object *obj),
C
Chris Wilson 已提交
419 420 421
	    TP_ARGS(obj),

	    TP_STRUCT__entry(
422
			     __field(struct drm_i915_gem_object *, obj)
423
			     __field(u64, size)
C
Chris Wilson 已提交
424 425 426 427
			     ),

	    TP_fast_assign(
			   __entry->obj = obj;
428
			   __entry->size = obj->base.size;
C
Chris Wilson 已提交
429 430
			   ),

431
	    TP_printk("obj=%p, size=0x%llx", __entry->obj, __entry->size)
C
Chris Wilson 已提交
432 433
);

434 435 436 437 438 439 440 441 442 443 444
TRACE_EVENT(i915_gem_shrink,
	    TP_PROTO(struct drm_i915_private *i915, unsigned long target, unsigned flags),
	    TP_ARGS(i915, target, flags),

	    TP_STRUCT__entry(
			     __field(int, dev)
			     __field(unsigned long, target)
			     __field(unsigned, flags)
			     ),

	    TP_fast_assign(
445
			   __entry->dev = i915->drm.primary->index;
446 447 448 449 450 451 452 453
			   __entry->target = target;
			   __entry->flags = flags;
			   ),

	    TP_printk("dev=%d, target=%lu, flags=%x",
		      __entry->dev, __entry->target, __entry->flags)
);

454
TRACE_EVENT(i915_vma_bind,
455 456
	    TP_PROTO(struct i915_vma *vma, unsigned flags),
	    TP_ARGS(vma, flags),
C
Chris Wilson 已提交
457 458

	    TP_STRUCT__entry(
459
			     __field(struct drm_i915_gem_object *, obj)
460
			     __field(struct i915_address_space *, vm)
461
			     __field(u64, offset)
462
			     __field(u64, size)
463
			     __field(unsigned, flags)
C
Chris Wilson 已提交
464 465 466
			     ),

	    TP_fast_assign(
467 468 469 470
			   __entry->obj = vma->obj;
			   __entry->vm = vma->vm;
			   __entry->offset = vma->node.start;
			   __entry->size = vma->node.size;
471
			   __entry->flags = flags;
C
Chris Wilson 已提交
472 473
			   ),

474
	    TP_printk("obj=%p, offset=0x%016llx size=0x%llx%s vm=%p",
C
Chris Wilson 已提交
475
		      __entry->obj, __entry->offset, __entry->size,
476
		      __entry->flags & PIN_MAPPABLE ? ", mappable" : "",
477
		      __entry->vm)
C
Chris Wilson 已提交
478 479
);

480 481 482
TRACE_EVENT(i915_vma_unbind,
	    TP_PROTO(struct i915_vma *vma),
	    TP_ARGS(vma),
C
Chris Wilson 已提交
483 484 485

	    TP_STRUCT__entry(
			     __field(struct drm_i915_gem_object *, obj)
486
			     __field(struct i915_address_space *, vm)
487
			     __field(u64, offset)
488
			     __field(u64, size)
C
Chris Wilson 已提交
489
			     ),
C
Chris Wilson 已提交
490

C
Chris Wilson 已提交
491
	    TP_fast_assign(
492 493 494 495
			   __entry->obj = vma->obj;
			   __entry->vm = vma->vm;
			   __entry->offset = vma->node.start;
			   __entry->size = vma->node.size;
C
Chris Wilson 已提交
496
			   ),
C
Chris Wilson 已提交
497

498
	    TP_printk("obj=%p, offset=0x%016llx size=0x%llx vm=%p",
499
		      __entry->obj, __entry->offset, __entry->size, __entry->vm)
C
Chris Wilson 已提交
500 501 502
);

TRACE_EVENT(i915_gem_object_pwrite,
503
	    TP_PROTO(struct drm_i915_gem_object *obj, u64 offset, u64 len),
C
Chris Wilson 已提交
504
	    TP_ARGS(obj, offset, len),
C
Chris Wilson 已提交
505

C
Chris Wilson 已提交
506 507
	    TP_STRUCT__entry(
			     __field(struct drm_i915_gem_object *, obj)
508 509
			     __field(u64, offset)
			     __field(u64, len)
C
Chris Wilson 已提交
510
			     ),
C
Chris Wilson 已提交
511

C
Chris Wilson 已提交
512 513 514 515 516 517
	    TP_fast_assign(
			   __entry->obj = obj;
			   __entry->offset = offset;
			   __entry->len = len;
			   ),

518
	    TP_printk("obj=%p, offset=0x%llx, len=0x%llx",
C
Chris Wilson 已提交
519 520 521 522
		      __entry->obj, __entry->offset, __entry->len)
);

TRACE_EVENT(i915_gem_object_pread,
523
	    TP_PROTO(struct drm_i915_gem_object *obj, u64 offset, u64 len),
C
Chris Wilson 已提交
524
	    TP_ARGS(obj, offset, len),
C
Chris Wilson 已提交
525 526

	    TP_STRUCT__entry(
527
			     __field(struct drm_i915_gem_object *, obj)
528 529
			     __field(u64, offset)
			     __field(u64, len)
C
Chris Wilson 已提交
530 531 532 533
			     ),

	    TP_fast_assign(
			   __entry->obj = obj;
C
Chris Wilson 已提交
534 535
			   __entry->offset = offset;
			   __entry->len = len;
C
Chris Wilson 已提交
536 537
			   ),

538
	    TP_printk("obj=%p, offset=0x%llx, len=0x%llx",
C
Chris Wilson 已提交
539
		      __entry->obj, __entry->offset, __entry->len)
C
Chris Wilson 已提交
540 541
);

C
Chris Wilson 已提交
542
TRACE_EVENT(i915_gem_object_fault,
543
	    TP_PROTO(struct drm_i915_gem_object *obj, u64 index, bool gtt, bool write),
C
Chris Wilson 已提交
544 545 546 547
	    TP_ARGS(obj, index, gtt, write),

	    TP_STRUCT__entry(
			     __field(struct drm_i915_gem_object *, obj)
548
			     __field(u64, index)
C
Chris Wilson 已提交
549 550 551 552 553 554 555 556 557 558
			     __field(bool, gtt)
			     __field(bool, write)
			     ),

	    TP_fast_assign(
			   __entry->obj = obj;
			   __entry->index = index;
			   __entry->gtt = gtt;
			   __entry->write = write;
			   ),
559

560
	    TP_printk("obj=%p, %s index=%llu %s",
C
Chris Wilson 已提交
561 562 563 564 565 566 567
		      __entry->obj,
		      __entry->gtt ? "GTT" : "CPU",
		      __entry->index,
		      __entry->write ? ", writable" : "")
);

DECLARE_EVENT_CLASS(i915_gem_object,
568
	    TP_PROTO(struct drm_i915_gem_object *obj),
C
Chris Wilson 已提交
569
	    TP_ARGS(obj),
570

C
Chris Wilson 已提交
571 572 573 574 575 576 577 578 579
	    TP_STRUCT__entry(
			     __field(struct drm_i915_gem_object *, obj)
			     ),

	    TP_fast_assign(
			   __entry->obj = obj;
			   ),

	    TP_printk("obj=%p", __entry->obj)
580 581
);

C
Chris Wilson 已提交
582 583 584 585
DEFINE_EVENT(i915_gem_object, i915_gem_object_clflush,
	     TP_PROTO(struct drm_i915_gem_object *obj),
	     TP_ARGS(obj)
);
C
Chris Wilson 已提交
586

C
Chris Wilson 已提交
587
DEFINE_EVENT(i915_gem_object, i915_gem_object_destroy,
588
	    TP_PROTO(struct drm_i915_gem_object *obj),
589 590
	    TP_ARGS(obj)
);
C
Chris Wilson 已提交
591

C
Chris Wilson 已提交
592
TRACE_EVENT(i915_gem_evict,
593
	    TP_PROTO(struct i915_address_space *vm, u64 size, u64 align, unsigned int flags),
594
	    TP_ARGS(vm, size, align, flags),
C
Chris Wilson 已提交
595

C
Chris Wilson 已提交
596 597
	    TP_STRUCT__entry(
			     __field(u32, dev)
598
			     __field(struct i915_address_space *, vm)
599 600
			     __field(u64, size)
			     __field(u64, align)
601
			     __field(unsigned int, flags)
C
Chris Wilson 已提交
602
			    ),
C
Chris Wilson 已提交
603

C
Chris Wilson 已提交
604
	    TP_fast_assign(
605
			   __entry->dev = vm->i915->drm.primary->index;
606
			   __entry->vm = vm;
C
Chris Wilson 已提交
607 608
			   __entry->size = size;
			   __entry->align = align;
609
			   __entry->flags = flags;
C
Chris Wilson 已提交
610 611
			  ),

612
	    TP_printk("dev=%d, vm=%p, size=0x%llx, align=0x%llx %s",
613
		      __entry->dev, __entry->vm, __entry->size, __entry->align,
614
		      __entry->flags & PIN_MAPPABLE ? ", mappable" : "")
C
Chris Wilson 已提交
615 616
);

617 618 619
TRACE_EVENT(i915_gem_evict_node,
	    TP_PROTO(struct i915_address_space *vm, struct drm_mm_node *node, unsigned int flags),
	    TP_ARGS(vm, node, flags),
620 621 622 623 624 625 626 627 628 629 630

	    TP_STRUCT__entry(
			     __field(u32, dev)
			     __field(struct i915_address_space *, vm)
			     __field(u64, start)
			     __field(u64, size)
			     __field(unsigned long, color)
			     __field(unsigned int, flags)
			    ),

	    TP_fast_assign(
631 632 633 634 635
			   __entry->dev = vm->i915->drm.primary->index;
			   __entry->vm = vm;
			   __entry->start = node->start;
			   __entry->size = node->size;
			   __entry->color = node->color;
636 637 638
			   __entry->flags = flags;
			  ),

639
	    TP_printk("dev=%d, vm=%p, start=0x%llx size=0x%llx, color=0x%lx, flags=%x",
640 641 642 643 644
		      __entry->dev, __entry->vm,
		      __entry->start, __entry->size,
		      __entry->color, __entry->flags)
);

645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661
TRACE_EVENT(i915_gem_evict_vm,
	    TP_PROTO(struct i915_address_space *vm),
	    TP_ARGS(vm),

	    TP_STRUCT__entry(
			     __field(u32, dev)
			     __field(struct i915_address_space *, vm)
			    ),

	    TP_fast_assign(
			   __entry->dev = vm->i915->drm.primary->index;
			   __entry->vm = vm;
			  ),

	    TP_printk("dev=%d, vm=%p", __entry->dev, __entry->vm)
);

662 663 664
TRACE_EVENT(i915_request_queue,
	    TP_PROTO(struct i915_request *rq, u32 flags),
	    TP_ARGS(rq, flags),
C
Chris Wilson 已提交
665 666

	    TP_STRUCT__entry(
667
			     __field(u32, dev)
668
			     __field(u64, ctx)
669 670
			     __field(u16, class)
			     __field(u16, instance)
C
Chris Wilson 已提交
671
			     __field(u32, seqno)
672
			     __field(u32, flags)
C
Chris Wilson 已提交
673 674 675
			     ),

	    TP_fast_assign(
676
			   __entry->dev = rq->i915->drm.primary->index;
677
			   __entry->class = rq->engine->uabi_class;
678
			   __entry->instance = rq->engine->uabi_instance;
679 680
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
681
			   __entry->flags = flags;
C
Chris Wilson 已提交
682 683
			   ),

C
Chris Wilson 已提交
684
	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, flags=0x%x",
685
		      __entry->dev, __entry->class, __entry->instance,
C
Chris Wilson 已提交
686
		      __entry->ctx, __entry->seqno, __entry->flags)
C
Chris Wilson 已提交
687 688
);

689 690 691
DECLARE_EVENT_CLASS(i915_request,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq),
C
Chris Wilson 已提交
692 693

	    TP_STRUCT__entry(
694
			     __field(u32, dev)
695
			     __field(u64, ctx)
696 697
			     __field(u16, class)
			     __field(u16, instance)
C
Chris Wilson 已提交
698 699 700 701
			     __field(u32, seqno)
			     ),

	    TP_fast_assign(
702
			   __entry->dev = rq->i915->drm.primary->index;
703
			   __entry->class = rq->engine->uabi_class;
704
			   __entry->instance = rq->engine->uabi_instance;
705 706
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
C
Chris Wilson 已提交
707 708
			   ),

C
Chris Wilson 已提交
709
	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u",
710
		      __entry->dev, __entry->class, __entry->instance,
C
Chris Wilson 已提交
711
		      __entry->ctx, __entry->seqno)
C
Chris Wilson 已提交
712 713
);

714 715 716
DEFINE_EVENT(i915_request, i915_request_add,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq)
C
Chris Wilson 已提交
717
);
C
Chris Wilson 已提交
718

719
#if defined(CONFIG_DRM_I915_LOW_LEVEL_TRACEPOINTS)
720 721 722
DEFINE_EVENT(i915_request, i915_request_submit,
	     TP_PROTO(struct i915_request *rq),
	     TP_ARGS(rq)
723 724
);

725 726 727
DEFINE_EVENT(i915_request, i915_request_execute,
	     TP_PROTO(struct i915_request *rq),
	     TP_ARGS(rq)
728
);
729

730 731 732 733 734 735
TRACE_EVENT(i915_request_in,
	    TP_PROTO(struct i915_request *rq, unsigned int port),
	    TP_ARGS(rq, port),

	    TP_STRUCT__entry(
			     __field(u32, dev)
736
			     __field(u64, ctx)
737 738
			     __field(u16, class)
			     __field(u16, instance)
739 740 741 742
			     __field(u32, seqno)
			     __field(u32, port)
			     __field(u32, prio)
			    ),
743

744 745
	    TP_fast_assign(
			   __entry->dev = rq->i915->drm.primary->index;
746
			   __entry->class = rq->engine->uabi_class;
747
			   __entry->instance = rq->engine->uabi_instance;
748 749 750 751 752 753
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
			   __entry->prio = rq->sched.attr.priority;
			   __entry->port = port;
			   ),

C
Chris Wilson 已提交
754
	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, prio=%u, port=%u",
755
		      __entry->dev, __entry->class, __entry->instance,
C
Chris Wilson 已提交
756
		      __entry->ctx, __entry->seqno,
757
		      __entry->prio, __entry->port)
758 759
);

760 761 762 763 764 765
TRACE_EVENT(i915_request_out,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq),

	    TP_STRUCT__entry(
			     __field(u32, dev)
766
			     __field(u64, ctx)
767 768
			     __field(u16, class)
			     __field(u16, instance)
769 770 771 772 773 774
			     __field(u32, seqno)
			     __field(u32, completed)
			    ),

	    TP_fast_assign(
			   __entry->dev = rq->i915->drm.primary->index;
775
			   __entry->class = rq->engine->uabi_class;
776
			   __entry->instance = rq->engine->uabi_instance;
777 778 779 780 781
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
			   __entry->completed = i915_request_completed(rq);
			   ),

C
Chris Wilson 已提交
782
		    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, completed?=%u",
783
			      __entry->dev, __entry->class, __entry->instance,
C
Chris Wilson 已提交
784
			      __entry->ctx, __entry->seqno, __entry->completed)
785
);
786

787 788 789
#else
#if !defined(TRACE_HEADER_MULTI_READ)
static inline void
790
trace_i915_request_submit(struct i915_request *rq)
791 792 793 794
{
}

static inline void
795
trace_i915_request_execute(struct i915_request *rq)
796 797
{
}
798 799

static inline void
800
trace_i915_request_in(struct i915_request *rq, unsigned int port)
801 802 803 804
{
}

static inline void
805
trace_i915_request_out(struct i915_request *rq)
806 807
{
}
808 809 810
#endif
#endif

811 812 813
DEFINE_EVENT(i915_request, i915_request_retire,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq)
C
Chris Wilson 已提交
814 815
);

816 817 818
TRACE_EVENT(i915_request_wait_begin,
	    TP_PROTO(struct i915_request *rq, unsigned int flags),
	    TP_ARGS(rq, flags),
819 820 821

	    TP_STRUCT__entry(
			     __field(u32, dev)
822
			     __field(u64, ctx)
823 824
			     __field(u16, class)
			     __field(u16, instance)
825
			     __field(u32, seqno)
826
			     __field(unsigned int, flags)
827 828 829 830 831 832 833 834 835
			     ),

	    /* NB: the blocking information is racy since mutex_is_locked
	     * doesn't check that the current thread holds the lock. The only
	     * other option would be to pass the boolean information of whether
	     * or not the class was blocking down through the stack which is
	     * less desirable.
	     */
	    TP_fast_assign(
836
			   __entry->dev = rq->i915->drm.primary->index;
837
			   __entry->class = rq->engine->uabi_class;
838
			   __entry->instance = rq->engine->uabi_instance;
839 840
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
841
			   __entry->flags = flags;
842 843
			   ),

C
Chris Wilson 已提交
844
	    TP_printk("dev=%u, engine=%u:%u, ctx=%llu, seqno=%u, flags=0x%x",
845
		      __entry->dev, __entry->class, __entry->instance,
C
Chris Wilson 已提交
846
		      __entry->ctx, __entry->seqno,
847
		      __entry->flags)
848
);
C
Chris Wilson 已提交
849

850 851 852
DEFINE_EVENT(i915_request, i915_request_wait_end,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq)
C
Chris Wilson 已提交
853 854
);

855
TRACE_EVENT_CONDITION(i915_reg_rw,
856
	TP_PROTO(bool write, i915_reg_t reg, u64 val, int len, bool trace),
857

858 859 860
	TP_ARGS(write, reg, val, len, trace),

	TP_CONDITION(trace),
861 862 863 864 865 866 867 868 869 870

	TP_STRUCT__entry(
		__field(u64, val)
		__field(u32, reg)
		__field(u16, write)
		__field(u16, len)
		),

	TP_fast_assign(
		__entry->val = (u64)val;
871
		__entry->reg = i915_mmio_reg_offset(reg);
872 873 874 875 876 877 878 879 880
		__entry->write = write;
		__entry->len = len;
		),

	TP_printk("%s reg=0x%x, len=%d, val=(0x%x, 0x%x)",
		__entry->write ? "write" : "read",
		__entry->reg, __entry->len,
		(u32)(__entry->val & 0xffffffff),
		(u32)(__entry->val >> 32))
881 882
);

883 884 885 886 887 888 889 890 891 892 893 894 895 896 897
TRACE_EVENT(intel_gpu_freq_change,
	    TP_PROTO(u32 freq),
	    TP_ARGS(freq),

	    TP_STRUCT__entry(
			     __field(u32, freq)
			     ),

	    TP_fast_assign(
			   __entry->freq = freq;
			   ),

	    TP_printk("new_freq=%u", __entry->freq)
);

898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914 915 916 917 918
/**
 * DOC: i915_ppgtt_create and i915_ppgtt_release tracepoints
 *
 * With full ppgtt enabled each process using drm will allocate at least one
 * translation table. With these traces it is possible to keep track of the
 * allocation and of the lifetime of the tables; this can be used during
 * testing/debug to verify that we are not leaking ppgtts.
 * These traces identify the ppgtt through the vm pointer, which is also printed
 * by the i915_vma_bind and i915_vma_unbind tracepoints.
 */
DECLARE_EVENT_CLASS(i915_ppgtt,
	TP_PROTO(struct i915_address_space *vm),
	TP_ARGS(vm),

	TP_STRUCT__entry(
			__field(struct i915_address_space *, vm)
			__field(u32, dev)
	),

	TP_fast_assign(
			__entry->vm = vm;
919
			__entry->dev = vm->i915->drm.primary->index;
920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942
	),

	TP_printk("dev=%u, vm=%p", __entry->dev, __entry->vm)
)

DEFINE_EVENT(i915_ppgtt, i915_ppgtt_create,
	TP_PROTO(struct i915_address_space *vm),
	TP_ARGS(vm)
);

DEFINE_EVENT(i915_ppgtt, i915_ppgtt_release,
	TP_PROTO(struct i915_address_space *vm),
	TP_ARGS(vm)
);

/**
 * DOC: i915_context_create and i915_context_free tracepoints
 *
 * These tracepoints are used to track creation and deletion of contexts.
 * If full ppgtt is enabled, they also print the address of the vm assigned to
 * the context.
 */
DECLARE_EVENT_CLASS(i915_context,
943
	TP_PROTO(struct i915_gem_context *ctx),
944 945 946 947
	TP_ARGS(ctx),

	TP_STRUCT__entry(
			__field(u32, dev)
948
			__field(struct i915_gem_context *, ctx)
949 950 951 952
			__field(struct i915_address_space *, vm)
	),

	TP_fast_assign(
953
			__entry->dev = ctx->i915->drm.primary->index;
954
			__entry->ctx = ctx;
955
			__entry->vm = ctx->vm;
956 957
	),

C
Chris Wilson 已提交
958 959
	TP_printk("dev=%u, ctx=%p, ctx_vm=%p",
		  __entry->dev, __entry->ctx, __entry->vm)
960 961 962
)

DEFINE_EVENT(i915_context, i915_context_create,
963
	TP_PROTO(struct i915_gem_context *ctx),
964 965 966 967
	TP_ARGS(ctx)
);

DEFINE_EVENT(i915_context, i915_context_free,
968
	TP_PROTO(struct i915_gem_context *ctx),
969 970 971
	TP_ARGS(ctx)
);

C
Chris Wilson 已提交
972 973 974 975
#endif /* _I915_TRACE_H_ */

/* This part must be outside protection */
#undef TRACE_INCLUDE_PATH
976
#define TRACE_INCLUDE_PATH ../../drivers/gpu/drm/i915
C
Chris Wilson 已提交
977
#include <trace/define_trace.h>