i915_trace.h 27.7 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 12
#include "gt/intel_engine.h"

13
#include "i915_drv.h"
14
#include "i915_irq.h"
15
#include "intel_drv.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(u32, hw_id)
669
			     __field(u64, ctx)
670 671
			     __field(u16, class)
			     __field(u16, instance)
C
Chris Wilson 已提交
672
			     __field(u32, seqno)
673
			     __field(u32, flags)
C
Chris Wilson 已提交
674 675 676
			     ),

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

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

692 693 694
DECLARE_EVENT_CLASS(i915_request,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq),
C
Chris Wilson 已提交
695 696

	    TP_STRUCT__entry(
697
			     __field(u32, dev)
698
			     __field(u32, hw_id)
699
			     __field(u64, ctx)
700 701
			     __field(u16, class)
			     __field(u16, instance)
C
Chris Wilson 已提交
702 703 704 705
			     __field(u32, seqno)
			     ),

	    TP_fast_assign(
706
			   __entry->dev = rq->i915->drm.primary->index;
C
Chris Wilson 已提交
707
			   __entry->hw_id = rq->gem_context->hw_id;
708 709
			   __entry->class = rq->engine->uabi_class;
			   __entry->instance = rq->engine->instance;
710 711
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
C
Chris Wilson 已提交
712 713
			   ),

714
	    TP_printk("dev=%u, engine=%u:%u, hw_id=%u, ctx=%llu, seqno=%u",
715
		      __entry->dev, __entry->class, __entry->instance,
716
		      __entry->hw_id, __entry->ctx, __entry->seqno)
C
Chris Wilson 已提交
717 718
);

719 720 721
DEFINE_EVENT(i915_request, i915_request_add,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq)
C
Chris Wilson 已提交
722
);
C
Chris Wilson 已提交
723

724
#if defined(CONFIG_DRM_I915_LOW_LEVEL_TRACEPOINTS)
725 726 727
DEFINE_EVENT(i915_request, i915_request_submit,
	     TP_PROTO(struct i915_request *rq),
	     TP_ARGS(rq)
728 729
);

730 731 732
DEFINE_EVENT(i915_request, i915_request_execute,
	     TP_PROTO(struct i915_request *rq),
	     TP_ARGS(rq)
733
);
734

735 736 737 738 739 740 741
TRACE_EVENT(i915_request_in,
	    TP_PROTO(struct i915_request *rq, unsigned int port),
	    TP_ARGS(rq, port),

	    TP_STRUCT__entry(
			     __field(u32, dev)
			     __field(u32, hw_id)
742
			     __field(u64, ctx)
743 744
			     __field(u16, class)
			     __field(u16, instance)
745 746 747 748
			     __field(u32, seqno)
			     __field(u32, port)
			     __field(u32, prio)
			    ),
749

750 751
	    TP_fast_assign(
			   __entry->dev = rq->i915->drm.primary->index;
C
Chris Wilson 已提交
752
			   __entry->hw_id = rq->gem_context->hw_id;
753 754
			   __entry->class = rq->engine->uabi_class;
			   __entry->instance = rq->engine->instance;
755 756 757 758 759 760
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
			   __entry->prio = rq->sched.attr.priority;
			   __entry->port = port;
			   ),

761
	    TP_printk("dev=%u, engine=%u:%u, hw_id=%u, ctx=%llu, seqno=%u, prio=%u, port=%u",
762 763
		      __entry->dev, __entry->class, __entry->instance,
		      __entry->hw_id, __entry->ctx, __entry->seqno,
764
		      __entry->prio, __entry->port)
765 766
);

767 768 769 770 771 772 773
TRACE_EVENT(i915_request_out,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq),

	    TP_STRUCT__entry(
			     __field(u32, dev)
			     __field(u32, hw_id)
774
			     __field(u64, ctx)
775 776
			     __field(u16, class)
			     __field(u16, instance)
777 778 779 780 781 782
			     __field(u32, seqno)
			     __field(u32, completed)
			    ),

	    TP_fast_assign(
			   __entry->dev = rq->i915->drm.primary->index;
C
Chris Wilson 已提交
783
			   __entry->hw_id = rq->gem_context->hw_id;
784 785
			   __entry->class = rq->engine->uabi_class;
			   __entry->instance = rq->engine->instance;
786 787 788 789 790
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
			   __entry->completed = i915_request_completed(rq);
			   ),

791
		    TP_printk("dev=%u, engine=%u:%u, hw_id=%u, ctx=%llu, seqno=%u, completed?=%u",
792 793
			      __entry->dev, __entry->class, __entry->instance,
			      __entry->hw_id, __entry->ctx, __entry->seqno,
794
			      __entry->completed)
795
);
796

797 798 799
#else
#if !defined(TRACE_HEADER_MULTI_READ)
static inline void
800
trace_i915_request_submit(struct i915_request *rq)
801 802 803 804
{
}

static inline void
805
trace_i915_request_execute(struct i915_request *rq)
806 807
{
}
808 809

static inline void
810
trace_i915_request_in(struct i915_request *rq, unsigned int port)
811 812 813 814
{
}

static inline void
815
trace_i915_request_out(struct i915_request *rq)
816 817
{
}
818 819 820
#endif
#endif

821 822 823
DEFINE_EVENT(i915_request, i915_request_retire,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq)
C
Chris Wilson 已提交
824 825
);

826 827 828
TRACE_EVENT(i915_request_wait_begin,
	    TP_PROTO(struct i915_request *rq, unsigned int flags),
	    TP_ARGS(rq, flags),
829 830 831

	    TP_STRUCT__entry(
			     __field(u32, dev)
832
			     __field(u32, hw_id)
833
			     __field(u64, ctx)
834 835
			     __field(u16, class)
			     __field(u16, instance)
836
			     __field(u32, seqno)
837
			     __field(unsigned int, flags)
838 839 840 841 842 843 844 845 846
			     ),

	    /* 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(
847
			   __entry->dev = rq->i915->drm.primary->index;
C
Chris Wilson 已提交
848
			   __entry->hw_id = rq->gem_context->hw_id;
849 850
			   __entry->class = rq->engine->uabi_class;
			   __entry->instance = rq->engine->instance;
851 852
			   __entry->ctx = rq->fence.context;
			   __entry->seqno = rq->fence.seqno;
853
			   __entry->flags = flags;
854 855
			   ),

856
	    TP_printk("dev=%u, engine=%u:%u, hw_id=%u, ctx=%llu, seqno=%u, flags=0x%x",
857 858
		      __entry->dev, __entry->class, __entry->instance,
		      __entry->hw_id, __entry->ctx, __entry->seqno,
859
		      __entry->flags)
860
);
C
Chris Wilson 已提交
861

862 863 864
DEFINE_EVENT(i915_request, i915_request_wait_end,
	    TP_PROTO(struct i915_request *rq),
	    TP_ARGS(rq)
C
Chris Wilson 已提交
865 866
);

867
TRACE_EVENT_CONDITION(i915_reg_rw,
868
	TP_PROTO(bool write, i915_reg_t reg, u64 val, int len, bool trace),
869

870 871 872
	TP_ARGS(write, reg, val, len, trace),

	TP_CONDITION(trace),
873 874 875 876 877 878 879 880 881 882

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

	TP_fast_assign(
		__entry->val = (u64)val;
883
		__entry->reg = i915_mmio_reg_offset(reg);
884 885 886 887 888 889 890 891 892
		__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))
893 894
);

895 896 897 898 899 900 901 902 903 904 905 906 907 908 909
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)
);

910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930
/**
 * 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;
931
			__entry->dev = vm->i915->drm.primary->index;
932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954
	),

	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,
955
	TP_PROTO(struct i915_gem_context *ctx),
956 957 958 959
	TP_ARGS(ctx),

	TP_STRUCT__entry(
			__field(u32, dev)
960
			__field(struct i915_gem_context *, ctx)
961
			__field(u32, hw_id)
962 963 964 965
			__field(struct i915_address_space *, vm)
	),

	TP_fast_assign(
966
			__entry->dev = ctx->i915->drm.primary->index;
967
			__entry->ctx = ctx;
968
			__entry->hw_id = ctx->hw_id;
969
			__entry->vm = ctx->vm;
970 971
	),

972 973
	TP_printk("dev=%u, ctx=%p, ctx_vm=%p, hw_id=%u",
		  __entry->dev, __entry->ctx, __entry->vm, __entry->hw_id)
974 975 976
)

DEFINE_EVENT(i915_context, i915_context_create,
977
	TP_PROTO(struct i915_gem_context *ctx),
978 979 980 981
	TP_ARGS(ctx)
);

DEFINE_EVENT(i915_context, i915_context_free,
982
	TP_PROTO(struct i915_gem_context *ctx),
983 984 985
	TP_ARGS(ctx)
);

C
Chris Wilson 已提交
986 987 988 989
#endif /* _I915_TRACE_H_ */

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