1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /* Copyright (c) 2014-2018, The Linux Foundation. All rights reserved.
5 #if !defined(_DPU_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
8 #include <linux/stringify.h>
9 #include <linux/types.h>
10 #include <linux/tracepoint.h>
12 #include <drm/drm_rect.h>
14 #include "dpu_encoder_phys.h"
15 #include "dpu_hw_mdss.h"
16 #include "dpu_hw_vbif.h"
17 #include "dpu_plane.h"
20 #define TRACE_SYSTEM dpu
21 #undef TRACE_INCLUDE_FILE
22 #define TRACE_INCLUDE_FILE dpu_trace
24 TRACE_EVENT(dpu_perf_set_qos_luts
,
25 TP_PROTO(u32 pnum
, u32 fmt
, bool rt
, u32 fl
,
26 u32 lut
, u32 lut_usage
),
27 TP_ARGS(pnum
, fmt
, rt
, fl
, lut
, lut_usage
),
34 __field(u32
, lut_usage
)
42 __entry
->lut_usage
= lut_usage
;
44 TP_printk("pnum=%d fmt=%x rt=%d fl=%d lut=0x%llx lut_usage=%d",
45 __entry
->pnum
, __entry
->fmt
,
46 __entry
->rt
, __entry
->fl
,
47 __entry
->lut
, __entry
->lut_usage
)
50 TRACE_EVENT(dpu_perf_set_danger_luts
,
51 TP_PROTO(u32 pnum
, u32 fmt
, u32 mode
, u32 danger_lut
,
53 TP_ARGS(pnum
, fmt
, mode
, danger_lut
, safe_lut
),
58 __field(u32
, danger_lut
)
59 __field(u32
, safe_lut
)
65 __entry
->danger_lut
= danger_lut
;
66 __entry
->safe_lut
= safe_lut
;
68 TP_printk("pnum=%d fmt=%x mode=%d luts[0x%x, 0x%x]",
69 __entry
->pnum
, __entry
->fmt
,
70 __entry
->mode
, __entry
->danger_lut
,
74 TRACE_EVENT(dpu_perf_set_ot
,
75 TP_PROTO(u32 pnum
, u32 xin_id
, u32 rd_lim
, u32 vbif_idx
),
76 TP_ARGS(pnum
, xin_id
, rd_lim
, vbif_idx
),
81 __field(u32
, vbif_idx
)
85 __entry
->xin_id
= xin_id
;
86 __entry
->rd_lim
= rd_lim
;
87 __entry
->vbif_idx
= vbif_idx
;
89 TP_printk("pnum:%d xin_id:%d ot:%d vbif:%d",
90 __entry
->pnum
, __entry
->xin_id
, __entry
->rd_lim
,
94 TRACE_EVENT(dpu_cmd_release_bw
,
95 TP_PROTO(u32 crtc_id
),
101 __entry
->crtc_id
= crtc_id
;
103 TP_printk("crtc:%d", __entry
->crtc_id
)
106 TRACE_EVENT(tracing_mark_write
,
107 TP_PROTO(int pid
, const char *name
, bool trace_begin
),
108 TP_ARGS(pid
, name
, trace_begin
),
111 __string(trace_name
, name
)
112 __field(bool, trace_begin
)
116 __assign_str(trace_name
, name
);
117 __entry
->trace_begin
= trace_begin
;
119 TP_printk("%s|%d|%s", __entry
->trace_begin
? "B" : "E",
120 __entry
->pid
, __get_str(trace_name
))
123 TRACE_EVENT(dpu_trace_counter
,
124 TP_PROTO(int pid
, char *name
, int value
),
125 TP_ARGS(pid
, name
, value
),
128 __string(counter_name
, name
)
132 __entry
->pid
= current
->tgid
;
133 __assign_str(counter_name
, name
);
134 __entry
->value
= value
;
136 TP_printk("%d|%s|%d", __entry
->pid
,
137 __get_str(counter_name
), __entry
->value
)
140 TRACE_EVENT(dpu_perf_crtc_update
,
141 TP_PROTO(u32 crtc
, u64 bw_ctl
, u32 core_clk_rate
,
142 bool stop_req
, bool update_bus
, bool update_clk
),
143 TP_ARGS(crtc
, bw_ctl
, core_clk_rate
, stop_req
, update_bus
, update_clk
),
147 __field(u32
, core_clk_rate
)
148 __field(bool, stop_req
)
149 __field(u32
, update_bus
)
150 __field(u32
, update_clk
)
153 __entry
->crtc
= crtc
;
154 __entry
->bw_ctl
= bw_ctl
;
155 __entry
->core_clk_rate
= core_clk_rate
;
156 __entry
->stop_req
= stop_req
;
157 __entry
->update_bus
= update_bus
;
158 __entry
->update_clk
= update_clk
;
161 "crtc=%d bw_ctl=%llu clk_rate=%u stop_req=%d u_bus=%d u_clk=%d",
164 __entry
->core_clk_rate
,
170 DECLARE_EVENT_CLASS(dpu_enc_irq_template
,
171 TP_PROTO(uint32_t drm_id
, enum dpu_intr_idx intr_idx
, int hw_idx
,
173 TP_ARGS(drm_id
, intr_idx
, hw_idx
, irq_idx
),
175 __field( uint32_t, drm_id
)
176 __field( enum dpu_intr_idx
, intr_idx
)
177 __field( int, hw_idx
)
178 __field( int, irq_idx
)
181 __entry
->drm_id
= drm_id
;
182 __entry
->intr_idx
= intr_idx
;
183 __entry
->hw_idx
= hw_idx
;
184 __entry
->irq_idx
= irq_idx
;
186 TP_printk("id=%u, intr=%d, hw=%d, irq=%d",
187 __entry
->drm_id
, __entry
->intr_idx
, __entry
->hw_idx
,
190 DEFINE_EVENT(dpu_enc_irq_template
, dpu_enc_irq_register_success
,
191 TP_PROTO(uint32_t drm_id
, enum dpu_intr_idx intr_idx
, int hw_idx
,
193 TP_ARGS(drm_id
, intr_idx
, hw_idx
, irq_idx
)
195 DEFINE_EVENT(dpu_enc_irq_template
, dpu_enc_irq_unregister_success
,
196 TP_PROTO(uint32_t drm_id
, enum dpu_intr_idx intr_idx
, int hw_idx
,
198 TP_ARGS(drm_id
, intr_idx
, hw_idx
, irq_idx
)
201 TRACE_EVENT(dpu_enc_irq_wait_success
,
202 TP_PROTO(uint32_t drm_id
, enum dpu_intr_idx intr_idx
, int hw_idx
,
203 int irq_idx
, enum dpu_pingpong pp_idx
, int atomic_cnt
),
204 TP_ARGS(drm_id
, intr_idx
, hw_idx
, irq_idx
, pp_idx
, atomic_cnt
),
206 __field( uint32_t, drm_id
)
207 __field( enum dpu_intr_idx
, intr_idx
)
208 __field( int, hw_idx
)
209 __field( int, irq_idx
)
210 __field( enum dpu_pingpong
, pp_idx
)
211 __field( int, atomic_cnt
)
214 __entry
->drm_id
= drm_id
;
215 __entry
->intr_idx
= intr_idx
;
216 __entry
->hw_idx
= hw_idx
;
217 __entry
->irq_idx
= irq_idx
;
218 __entry
->pp_idx
= pp_idx
;
219 __entry
->atomic_cnt
= atomic_cnt
;
221 TP_printk("id=%u, intr=%d, hw=%d, irq=%d, pp=%d, atomic_cnt=%d",
222 __entry
->drm_id
, __entry
->intr_idx
, __entry
->hw_idx
,
223 __entry
->irq_idx
, __entry
->pp_idx
, __entry
->atomic_cnt
)
226 DECLARE_EVENT_CLASS(dpu_drm_obj_template
,
227 TP_PROTO(uint32_t drm_id
),
230 __field( uint32_t, drm_id
)
233 __entry
->drm_id
= drm_id
;
235 TP_printk("id=%u", __entry
->drm_id
)
237 DEFINE_EVENT(dpu_drm_obj_template
, dpu_enc_atomic_check
,
238 TP_PROTO(uint32_t drm_id
),
241 DEFINE_EVENT(dpu_drm_obj_template
, dpu_enc_mode_set
,
242 TP_PROTO(uint32_t drm_id
),
245 DEFINE_EVENT(dpu_drm_obj_template
, dpu_enc_disable
,
246 TP_PROTO(uint32_t drm_id
),
249 DEFINE_EVENT(dpu_drm_obj_template
, dpu_enc_kickoff
,
250 TP_PROTO(uint32_t drm_id
),
253 DEFINE_EVENT(dpu_drm_obj_template
, dpu_enc_prepare_kickoff
,
254 TP_PROTO(uint32_t drm_id
),
257 DEFINE_EVENT(dpu_drm_obj_template
, dpu_enc_prepare_kickoff_reset
,
258 TP_PROTO(uint32_t drm_id
),
261 DEFINE_EVENT(dpu_drm_obj_template
, dpu_crtc_complete_flip
,
262 TP_PROTO(uint32_t drm_id
),
265 DEFINE_EVENT(dpu_drm_obj_template
, dpu_crtc_vblank_cb
,
266 TP_PROTO(uint32_t drm_id
),
269 DEFINE_EVENT(dpu_drm_obj_template
, dpu_crtc_complete_commit
,
270 TP_PROTO(uint32_t drm_id
),
273 DEFINE_EVENT(dpu_drm_obj_template
, dpu_kms_enc_enable
,
274 TP_PROTO(uint32_t drm_id
),
277 DEFINE_EVENT(dpu_drm_obj_template
, dpu_kms_commit
,
278 TP_PROTO(uint32_t drm_id
),
281 DEFINE_EVENT(dpu_drm_obj_template
, dpu_kms_wait_for_commit_done
,
282 TP_PROTO(uint32_t drm_id
),
285 DEFINE_EVENT(dpu_drm_obj_template
, dpu_crtc_runtime_resume
,
286 TP_PROTO(uint32_t drm_id
),
290 TRACE_EVENT(dpu_enc_enable
,
291 TP_PROTO(uint32_t drm_id
, int hdisplay
, int vdisplay
),
292 TP_ARGS(drm_id
, hdisplay
, vdisplay
),
294 __field( uint32_t, drm_id
)
295 __field( int, hdisplay
)
296 __field( int, vdisplay
)
299 __entry
->drm_id
= drm_id
;
300 __entry
->hdisplay
= hdisplay
;
301 __entry
->vdisplay
= vdisplay
;
303 TP_printk("id=%u, mode=%dx%d",
304 __entry
->drm_id
, __entry
->hdisplay
, __entry
->vdisplay
)
307 DECLARE_EVENT_CLASS(dpu_enc_keyval_template
,
308 TP_PROTO(uint32_t drm_id
, int val
),
309 TP_ARGS(drm_id
, val
),
311 __field( uint32_t, drm_id
)
315 __entry
->drm_id
= drm_id
;
318 TP_printk("id=%u, val=%d", __entry
->drm_id
, __entry
->val
)
320 DEFINE_EVENT(dpu_enc_keyval_template
, dpu_enc_underrun_cb
,
321 TP_PROTO(uint32_t drm_id
, int count
),
322 TP_ARGS(drm_id
, count
)
324 DEFINE_EVENT(dpu_enc_keyval_template
, dpu_enc_trigger_start
,
325 TP_PROTO(uint32_t drm_id
, int ctl_idx
),
326 TP_ARGS(drm_id
, ctl_idx
)
329 TRACE_EVENT(dpu_enc_atomic_check_flags
,
330 TP_PROTO(uint32_t drm_id
, unsigned int flags
, int private_flags
),
331 TP_ARGS(drm_id
, flags
, private_flags
),
333 __field( uint32_t, drm_id
)
334 __field( unsigned int, flags
)
335 __field( int, private_flags
)
338 __entry
->drm_id
= drm_id
;
339 __entry
->flags
= flags
;
340 __entry
->private_flags
= private_flags
;
342 TP_printk("id=%u, flags=%u, private_flags=%d",
343 __entry
->drm_id
, __entry
->flags
, __entry
->private_flags
)
346 DECLARE_EVENT_CLASS(dpu_enc_id_enable_template
,
347 TP_PROTO(uint32_t drm_id
, bool enable
),
348 TP_ARGS(drm_id
, enable
),
350 __field( uint32_t, drm_id
)
351 __field( bool, enable
)
354 __entry
->drm_id
= drm_id
;
355 __entry
->enable
= enable
;
357 TP_printk("id=%u, enable=%s",
358 __entry
->drm_id
, __entry
->enable
? "true" : "false")
360 DEFINE_EVENT(dpu_enc_id_enable_template
, dpu_enc_rc_helper
,
361 TP_PROTO(uint32_t drm_id
, bool enable
),
362 TP_ARGS(drm_id
, enable
)
364 DEFINE_EVENT(dpu_enc_id_enable_template
, dpu_enc_vblank_cb
,
365 TP_PROTO(uint32_t drm_id
, bool enable
),
366 TP_ARGS(drm_id
, enable
)
368 DEFINE_EVENT(dpu_enc_id_enable_template
, dpu_enc_frame_event_cb
,
369 TP_PROTO(uint32_t drm_id
, bool enable
),
370 TP_ARGS(drm_id
, enable
)
372 DEFINE_EVENT(dpu_enc_id_enable_template
, dpu_enc_phys_cmd_connect_te
,
373 TP_PROTO(uint32_t drm_id
, bool enable
),
374 TP_ARGS(drm_id
, enable
)
377 TRACE_EVENT(dpu_enc_rc
,
378 TP_PROTO(uint32_t drm_id
, u32 sw_event
, bool idle_pc_supported
,
379 int rc_state
, const char *stage
),
380 TP_ARGS(drm_id
, sw_event
, idle_pc_supported
, rc_state
, stage
),
382 __field( uint32_t, drm_id
)
383 __field( u32
, sw_event
)
384 __field( bool, idle_pc_supported
)
385 __field( int, rc_state
)
386 __string( stage_str
, stage
)
389 __entry
->drm_id
= drm_id
;
390 __entry
->sw_event
= sw_event
;
391 __entry
->idle_pc_supported
= idle_pc_supported
;
392 __entry
->rc_state
= rc_state
;
393 __assign_str(stage_str
, stage
);
395 TP_printk("%s: id:%u, sw_event:%d, idle_pc_supported:%s, rc_state:%d",
396 __get_str(stage_str
), __entry
->drm_id
, __entry
->sw_event
,
397 __entry
->idle_pc_supported
? "true" : "false",
401 TRACE_EVENT(dpu_enc_frame_done_cb_not_busy
,
402 TP_PROTO(uint32_t drm_id
, u32 event
, enum dpu_intf intf_idx
),
403 TP_ARGS(drm_id
, event
, intf_idx
),
405 __field( uint32_t, drm_id
)
406 __field( u32
, event
)
407 __field( enum dpu_intf
, intf_idx
)
410 __entry
->drm_id
= drm_id
;
411 __entry
->event
= event
;
412 __entry
->intf_idx
= intf_idx
;
414 TP_printk("id=%u, event=%u, intf=%d", __entry
->drm_id
, __entry
->event
,
418 TRACE_EVENT(dpu_enc_frame_done_cb
,
419 TP_PROTO(uint32_t drm_id
, unsigned int idx
,
420 unsigned long frame_busy_mask
),
421 TP_ARGS(drm_id
, idx
, frame_busy_mask
),
423 __field( uint32_t, drm_id
)
424 __field( unsigned int, idx
)
425 __field( unsigned long, frame_busy_mask
)
428 __entry
->drm_id
= drm_id
;
430 __entry
->frame_busy_mask
= frame_busy_mask
;
432 TP_printk("id=%u, idx=%u, frame_busy_mask=%lx", __entry
->drm_id
,
433 __entry
->idx
, __entry
->frame_busy_mask
)
436 TRACE_EVENT(dpu_enc_trigger_flush
,
437 TP_PROTO(uint32_t drm_id
, enum dpu_intf intf_idx
,
438 int pending_kickoff_cnt
, int ctl_idx
, u32 extra_flush_bits
,
439 u32 pending_flush_ret
),
440 TP_ARGS(drm_id
, intf_idx
, pending_kickoff_cnt
, ctl_idx
,
441 extra_flush_bits
, pending_flush_ret
),
443 __field( uint32_t, drm_id
)
444 __field( enum dpu_intf
, intf_idx
)
445 __field( int, pending_kickoff_cnt
)
446 __field( int, ctl_idx
)
447 __field( u32
, extra_flush_bits
)
448 __field( u32
, pending_flush_ret
)
451 __entry
->drm_id
= drm_id
;
452 __entry
->intf_idx
= intf_idx
;
453 __entry
->pending_kickoff_cnt
= pending_kickoff_cnt
;
454 __entry
->ctl_idx
= ctl_idx
;
455 __entry
->extra_flush_bits
= extra_flush_bits
;
456 __entry
->pending_flush_ret
= pending_flush_ret
;
458 TP_printk("id=%u, intf_idx=%d, pending_kickoff_cnt=%d ctl_idx=%d "
459 "extra_flush_bits=0x%x pending_flush_ret=0x%x",
460 __entry
->drm_id
, __entry
->intf_idx
,
461 __entry
->pending_kickoff_cnt
, __entry
->ctl_idx
,
462 __entry
->extra_flush_bits
, __entry
->pending_flush_ret
)
465 DECLARE_EVENT_CLASS(dpu_enc_ktime_template
,
466 TP_PROTO(uint32_t drm_id
, ktime_t time
),
467 TP_ARGS(drm_id
, time
),
469 __field( uint32_t, drm_id
)
470 __field( ktime_t
, time
)
473 __entry
->drm_id
= drm_id
;
474 __entry
->time
= time
;
476 TP_printk("id=%u, time=%lld", __entry
->drm_id
,
477 ktime_to_ms(__entry
->time
))
479 DEFINE_EVENT(dpu_enc_ktime_template
, dpu_enc_vsync_event_work
,
480 TP_PROTO(uint32_t drm_id
, ktime_t time
),
481 TP_ARGS(drm_id
, time
)
483 DEFINE_EVENT(dpu_enc_ktime_template
, dpu_enc_early_kickoff
,
484 TP_PROTO(uint32_t drm_id
, ktime_t time
),
485 TP_ARGS(drm_id
, time
)
488 DECLARE_EVENT_CLASS(dpu_id_event_template
,
489 TP_PROTO(uint32_t drm_id
, u32 event
),
490 TP_ARGS(drm_id
, event
),
492 __field( uint32_t, drm_id
)
493 __field( u32
, event
)
496 __entry
->drm_id
= drm_id
;
497 __entry
->event
= event
;
499 TP_printk("id=%u, event=%u", __entry
->drm_id
, __entry
->event
)
501 DEFINE_EVENT(dpu_id_event_template
, dpu_enc_frame_done_timeout
,
502 TP_PROTO(uint32_t drm_id
, u32 event
),
503 TP_ARGS(drm_id
, event
)
505 DEFINE_EVENT(dpu_id_event_template
, dpu_crtc_frame_event_cb
,
506 TP_PROTO(uint32_t drm_id
, u32 event
),
507 TP_ARGS(drm_id
, event
)
509 DEFINE_EVENT(dpu_id_event_template
, dpu_crtc_frame_event_done
,
510 TP_PROTO(uint32_t drm_id
, u32 event
),
511 TP_ARGS(drm_id
, event
)
513 DEFINE_EVENT(dpu_id_event_template
, dpu_crtc_frame_event_more_pending
,
514 TP_PROTO(uint32_t drm_id
, u32 event
),
515 TP_ARGS(drm_id
, event
)
518 TRACE_EVENT(dpu_enc_wait_event_timeout
,
519 TP_PROTO(uint32_t drm_id
, int32_t hw_id
, int rc
, s64 time
,
520 s64 expected_time
, int atomic_cnt
),
521 TP_ARGS(drm_id
, hw_id
, rc
, time
, expected_time
, atomic_cnt
),
523 __field( uint32_t, drm_id
)
524 __field( int32_t, hw_id
)
527 __field( s64
, expected_time
)
528 __field( int, atomic_cnt
)
531 __entry
->drm_id
= drm_id
;
532 __entry
->hw_id
= hw_id
;
534 __entry
->time
= time
;
535 __entry
->expected_time
= expected_time
;
536 __entry
->atomic_cnt
= atomic_cnt
;
538 TP_printk("id=%u, hw_id=%d, rc=%d, time=%lld, expected=%lld cnt=%d",
539 __entry
->drm_id
, __entry
->hw_id
, __entry
->rc
, __entry
->time
,
540 __entry
->expected_time
, __entry
->atomic_cnt
)
543 TRACE_EVENT(dpu_enc_phys_cmd_irq_ctrl
,
544 TP_PROTO(uint32_t drm_id
, enum dpu_pingpong pp
, bool enable
,
546 TP_ARGS(drm_id
, pp
, enable
, refcnt
),
548 __field( uint32_t, drm_id
)
549 __field( enum dpu_pingpong
, pp
)
550 __field( bool, enable
)
551 __field( int, refcnt
)
554 __entry
->drm_id
= drm_id
;
556 __entry
->enable
= enable
;
557 __entry
->refcnt
= refcnt
;
559 TP_printk("id=%u, pp=%d, enable=%s, refcnt=%d", __entry
->drm_id
,
560 __entry
->pp
, __entry
->enable
? "true" : "false",
564 TRACE_EVENT(dpu_enc_phys_cmd_pp_tx_done
,
565 TP_PROTO(uint32_t drm_id
, enum dpu_pingpong pp
, int new_count
,
567 TP_ARGS(drm_id
, pp
, new_count
, event
),
569 __field( uint32_t, drm_id
)
570 __field( enum dpu_pingpong
, pp
)
571 __field( int, new_count
)
572 __field( u32
, event
)
575 __entry
->drm_id
= drm_id
;
577 __entry
->new_count
= new_count
;
578 __entry
->event
= event
;
580 TP_printk("id=%u, pp=%d, new_count=%d, event=%u", __entry
->drm_id
,
581 __entry
->pp
, __entry
->new_count
, __entry
->event
)
584 TRACE_EVENT(dpu_enc_phys_cmd_pdone_timeout
,
585 TP_PROTO(uint32_t drm_id
, enum dpu_pingpong pp
, int timeout_count
,
586 int kickoff_count
, u32 event
),
587 TP_ARGS(drm_id
, pp
, timeout_count
, kickoff_count
, event
),
589 __field( uint32_t, drm_id
)
590 __field( enum dpu_pingpong
, pp
)
591 __field( int, timeout_count
)
592 __field( int, kickoff_count
)
593 __field( u32
, event
)
596 __entry
->drm_id
= drm_id
;
598 __entry
->timeout_count
= timeout_count
;
599 __entry
->kickoff_count
= kickoff_count
;
600 __entry
->event
= event
;
602 TP_printk("id=%u, pp=%d, timeout_count=%d, kickoff_count=%d, event=%u",
603 __entry
->drm_id
, __entry
->pp
, __entry
->timeout_count
,
604 __entry
->kickoff_count
, __entry
->event
)
607 TRACE_EVENT(dpu_enc_phys_vid_post_kickoff
,
608 TP_PROTO(uint32_t drm_id
, enum dpu_intf intf_idx
),
609 TP_ARGS(drm_id
, intf_idx
),
611 __field( uint32_t, drm_id
)
612 __field( enum dpu_intf
, intf_idx
)
615 __entry
->drm_id
= drm_id
;
616 __entry
->intf_idx
= intf_idx
;
618 TP_printk("id=%u, intf_idx=%d", __entry
->drm_id
, __entry
->intf_idx
)
621 TRACE_EVENT(dpu_enc_phys_vid_irq_ctrl
,
622 TP_PROTO(uint32_t drm_id
, enum dpu_intf intf_idx
, bool enable
,
624 TP_ARGS(drm_id
, intf_idx
, enable
, refcnt
),
626 __field( uint32_t, drm_id
)
627 __field( enum dpu_intf
, intf_idx
)
628 __field( bool, enable
)
629 __field( int, refcnt
)
632 __entry
->drm_id
= drm_id
;
633 __entry
->intf_idx
= intf_idx
;
634 __entry
->enable
= enable
;
635 __entry
->refcnt
= refcnt
;
637 TP_printk("id=%u, intf_idx=%d enable=%s refcnt=%d", __entry
->drm_id
,
638 __entry
->intf_idx
, __entry
->enable
? "true" : "false",
642 TRACE_EVENT(dpu_crtc_setup_mixer
,
643 TP_PROTO(uint32_t crtc_id
, uint32_t plane_id
,
644 struct drm_plane_state
*state
, struct dpu_plane_state
*pstate
,
645 uint32_t stage_idx
, enum dpu_sspp sspp
, uint32_t pixel_format
,
647 TP_ARGS(crtc_id
, plane_id
, state
, pstate
, stage_idx
, sspp
,
648 pixel_format
, modifier
),
650 __field( uint32_t, crtc_id
)
651 __field( uint32_t, plane_id
)
652 __field( uint32_t, fb_id
)
653 __field_struct( struct drm_rect
, src_rect
)
654 __field_struct( struct drm_rect
, dst_rect
)
655 __field( uint32_t, stage_idx
)
656 __field( enum dpu_stage
, stage
)
657 __field( enum dpu_sspp
, sspp
)
658 __field( uint32_t, multirect_idx
)
659 __field( uint32_t, multirect_mode
)
660 __field( uint32_t, pixel_format
)
661 __field( uint64_t, modifier
)
664 __entry
->crtc_id
= crtc_id
;
665 __entry
->plane_id
= plane_id
;
666 __entry
->fb_id
= state
? state
->fb
->base
.id
: 0;
667 __entry
->src_rect
= drm_plane_state_src(state
);
668 __entry
->dst_rect
= drm_plane_state_dest(state
);
669 __entry
->stage_idx
= stage_idx
;
670 __entry
->stage
= pstate
->stage
;
671 __entry
->sspp
= sspp
;
672 __entry
->multirect_idx
= pstate
->multirect_index
;
673 __entry
->multirect_mode
= pstate
->multirect_mode
;
674 __entry
->pixel_format
= pixel_format
;
675 __entry
->modifier
= modifier
;
677 TP_printk("crtc_id:%u plane_id:%u fb_id:%u src:" DRM_RECT_FP_FMT
678 " dst:" DRM_RECT_FMT
" stage_idx:%u stage:%d, sspp:%d "
679 "multirect_index:%d multirect_mode:%u pix_format:%u "
681 __entry
->crtc_id
, __entry
->plane_id
, __entry
->fb_id
,
682 DRM_RECT_FP_ARG(&__entry
->src_rect
),
683 DRM_RECT_ARG(&__entry
->dst_rect
),
684 __entry
->stage_idx
, __entry
->stage
, __entry
->sspp
,
685 __entry
->multirect_idx
, __entry
->multirect_mode
,
686 __entry
->pixel_format
, __entry
->modifier
)
689 TRACE_EVENT(dpu_crtc_setup_lm_bounds
,
690 TP_PROTO(uint32_t drm_id
, int mixer
, struct drm_rect
*bounds
),
691 TP_ARGS(drm_id
, mixer
, bounds
),
693 __field( uint32_t, drm_id
)
694 __field( int, mixer
)
695 __field_struct( struct drm_rect
, bounds
)
698 __entry
->drm_id
= drm_id
;
699 __entry
->mixer
= mixer
;
700 __entry
->bounds
= *bounds
;
702 TP_printk("id:%u mixer:%d bounds:" DRM_RECT_FMT
, __entry
->drm_id
,
703 __entry
->mixer
, DRM_RECT_ARG(&__entry
->bounds
))
706 TRACE_EVENT(dpu_crtc_vblank_enable
,
707 TP_PROTO(uint32_t drm_id
, uint32_t enc_id
, bool enable
,
708 struct dpu_crtc
*crtc
),
709 TP_ARGS(drm_id
, enc_id
, enable
, crtc
),
711 __field( uint32_t, drm_id
)
712 __field( uint32_t, enc_id
)
713 __field( bool, enable
)
714 __field( bool, enabled
)
717 __entry
->drm_id
= drm_id
;
718 __entry
->enc_id
= enc_id
;
719 __entry
->enable
= enable
;
720 __entry
->enabled
= crtc
->enabled
;
722 TP_printk("id:%u encoder:%u enable:%s state{enabled:%s}",
723 __entry
->drm_id
, __entry
->enc_id
,
724 __entry
->enable
? "true" : "false",
725 __entry
->enabled
? "true" : "false")
728 DECLARE_EVENT_CLASS(dpu_crtc_enable_template
,
729 TP_PROTO(uint32_t drm_id
, bool enable
, struct dpu_crtc
*crtc
),
730 TP_ARGS(drm_id
, enable
, crtc
),
732 __field( uint32_t, drm_id
)
733 __field( bool, enable
)
734 __field( bool, enabled
)
737 __entry
->drm_id
= drm_id
;
738 __entry
->enable
= enable
;
739 __entry
->enabled
= crtc
->enabled
;
741 TP_printk("id:%u enable:%s state{enabled:%s}",
742 __entry
->drm_id
, __entry
->enable
? "true" : "false",
743 __entry
->enabled
? "true" : "false")
745 DEFINE_EVENT(dpu_crtc_enable_template
, dpu_crtc_enable
,
746 TP_PROTO(uint32_t drm_id
, bool enable
, struct dpu_crtc
*crtc
),
747 TP_ARGS(drm_id
, enable
, crtc
)
749 DEFINE_EVENT(dpu_crtc_enable_template
, dpu_crtc_disable
,
750 TP_PROTO(uint32_t drm_id
, bool enable
, struct dpu_crtc
*crtc
),
751 TP_ARGS(drm_id
, enable
, crtc
)
753 DEFINE_EVENT(dpu_crtc_enable_template
, dpu_crtc_vblank
,
754 TP_PROTO(uint32_t drm_id
, bool enable
, struct dpu_crtc
*crtc
),
755 TP_ARGS(drm_id
, enable
, crtc
)
758 TRACE_EVENT(dpu_crtc_disable_frame_pending
,
759 TP_PROTO(uint32_t drm_id
, int frame_pending
),
760 TP_ARGS(drm_id
, frame_pending
),
762 __field( uint32_t, drm_id
)
763 __field( int, frame_pending
)
766 __entry
->drm_id
= drm_id
;
767 __entry
->frame_pending
= frame_pending
;
769 TP_printk("id:%u frame_pending:%d", __entry
->drm_id
,
770 __entry
->frame_pending
)
773 TRACE_EVENT(dpu_plane_set_scanout
,
774 TP_PROTO(enum dpu_sspp index
, struct dpu_hw_fmt_layout
*layout
,
775 enum dpu_sspp_multirect_index multirect_index
),
776 TP_ARGS(index
, layout
, multirect_index
),
778 __field( enum dpu_sspp
, index
)
779 __field_struct( struct dpu_hw_fmt_layout
, layout
)
780 __field( enum dpu_sspp_multirect_index
, multirect_index
)
783 __entry
->index
= index
;
784 __entry
->layout
= *layout
;
785 __entry
->multirect_index
= multirect_index
;
787 TP_printk("index:%d layout:{%ux%u @ [%u/%u, %u/%u, %u/%u, %u/%u]} "
788 "multirect_index:%d", __entry
->index
, __entry
->layout
.width
,
789 __entry
->layout
.height
, __entry
->layout
.plane_addr
[0],
790 __entry
->layout
.plane_size
[0],
791 __entry
->layout
.plane_addr
[1],
792 __entry
->layout
.plane_size
[1],
793 __entry
->layout
.plane_addr
[2],
794 __entry
->layout
.plane_size
[2],
795 __entry
->layout
.plane_addr
[3],
796 __entry
->layout
.plane_size
[3], __entry
->multirect_index
)
799 TRACE_EVENT(dpu_plane_disable
,
800 TP_PROTO(uint32_t drm_id
, bool is_virtual
, uint32_t multirect_mode
),
801 TP_ARGS(drm_id
, is_virtual
, multirect_mode
),
803 __field( uint32_t, drm_id
)
804 __field( bool, is_virtual
)
805 __field( uint32_t, multirect_mode
)
808 __entry
->drm_id
= drm_id
;
809 __entry
->is_virtual
= is_virtual
;
810 __entry
->multirect_mode
= multirect_mode
;
812 TP_printk("id:%u is_virtual:%s multirect_mode:%u", __entry
->drm_id
,
813 __entry
->is_virtual
? "true" : "false",
814 __entry
->multirect_mode
)
817 DECLARE_EVENT_CLASS(dpu_rm_iter_template
,
818 TP_PROTO(uint32_t id
, uint32_t enc_id
),
821 __field( uint32_t, id
)
822 __field( uint32_t, enc_id
)
826 __entry
->enc_id
= enc_id
;
828 TP_printk("id:%d enc_id:%u", __entry
->id
, __entry
->enc_id
)
830 DEFINE_EVENT(dpu_rm_iter_template
, dpu_rm_reserve_intf
,
831 TP_PROTO(uint32_t id
, uint32_t enc_id
),
834 DEFINE_EVENT(dpu_rm_iter_template
, dpu_rm_reserve_ctls
,
835 TP_PROTO(uint32_t id
, uint32_t enc_id
),
839 TRACE_EVENT(dpu_rm_reserve_lms
,
840 TP_PROTO(uint32_t id
, uint32_t enc_id
, uint32_t pp_id
),
841 TP_ARGS(id
, enc_id
, pp_id
),
843 __field( uint32_t, id
)
844 __field( uint32_t, enc_id
)
845 __field( uint32_t, pp_id
)
849 __entry
->enc_id
= enc_id
;
850 __entry
->pp_id
= pp_id
;
852 TP_printk("id:%d enc_id:%u pp_id:%u", __entry
->id
,
853 __entry
->enc_id
, __entry
->pp_id
)
856 TRACE_EVENT(dpu_vbif_wait_xin_halt_fail
,
857 TP_PROTO(enum dpu_vbif index
, u32 xin_id
),
858 TP_ARGS(index
, xin_id
),
860 __field( enum dpu_vbif
, index
)
861 __field( u32
, xin_id
)
864 __entry
->index
= index
;
865 __entry
->xin_id
= xin_id
;
867 TP_printk("index:%d xin_id:%u", __entry
->index
, __entry
->xin_id
)
870 TRACE_EVENT(dpu_pp_connect_ext_te
,
871 TP_PROTO(enum dpu_pingpong pp
, u32 cfg
),
874 __field( enum dpu_pingpong
, pp
)
881 TP_printk("pp:%d cfg:%u", __entry
->pp
, __entry
->cfg
)
884 DECLARE_EVENT_CLASS(dpu_core_irq_idx_cnt_template
,
885 TP_PROTO(int irq_idx
, int enable_count
),
886 TP_ARGS(irq_idx
, enable_count
),
888 __field( int, irq_idx
)
889 __field( int, enable_count
)
892 __entry
->irq_idx
= irq_idx
;
893 __entry
->enable_count
= enable_count
;
895 TP_printk("irq_idx:%d enable_count:%u", __entry
->irq_idx
,
896 __entry
->enable_count
)
898 DEFINE_EVENT(dpu_core_irq_idx_cnt_template
, dpu_core_irq_enable_idx
,
899 TP_PROTO(int irq_idx
, int enable_count
),
900 TP_ARGS(irq_idx
, enable_count
)
902 DEFINE_EVENT(dpu_core_irq_idx_cnt_template
, dpu_core_irq_disable_idx
,
903 TP_PROTO(int irq_idx
, int enable_count
),
904 TP_ARGS(irq_idx
, enable_count
)
907 DECLARE_EVENT_CLASS(dpu_core_irq_callback_template
,
908 TP_PROTO(int irq_idx
, struct dpu_irq_callback
*callback
),
909 TP_ARGS(irq_idx
, callback
),
911 __field( int, irq_idx
)
912 __field( struct dpu_irq_callback
*, callback
)
915 __entry
->irq_idx
= irq_idx
;
916 __entry
->callback
= callback
;
918 TP_printk("irq_idx:%d callback:%pK", __entry
->irq_idx
,
921 DEFINE_EVENT(dpu_core_irq_callback_template
, dpu_core_irq_register_callback
,
922 TP_PROTO(int irq_idx
, struct dpu_irq_callback
*callback
),
923 TP_ARGS(irq_idx
, callback
)
925 DEFINE_EVENT(dpu_core_irq_callback_template
, dpu_core_irq_unregister_callback
,
926 TP_PROTO(int irq_idx
, struct dpu_irq_callback
*callback
),
927 TP_ARGS(irq_idx
, callback
)
930 TRACE_EVENT(dpu_core_perf_update_clk
,
931 TP_PROTO(struct drm_device
*dev
, bool stop_req
, u64 clk_rate
),
932 TP_ARGS(dev
, stop_req
, clk_rate
),
934 __string( dev_name
, dev
->unique
)
935 __field( bool, stop_req
)
936 __field( u64
, clk_rate
)
939 __assign_str(dev_name
, dev
->unique
);
940 __entry
->stop_req
= stop_req
;
941 __entry
->clk_rate
= clk_rate
;
943 TP_printk("dev:%s stop_req:%s clk_rate:%llu", __get_str(dev_name
),
944 __entry
->stop_req
? "true" : "false", __entry
->clk_rate
)
947 TRACE_EVENT(dpu_hw_ctl_update_pending_flush
,
948 TP_PROTO(u32 new_bits
, u32 pending_mask
),
949 TP_ARGS(new_bits
, pending_mask
),
951 __field( u32
, new_bits
)
952 __field( u32
, pending_mask
)
955 __entry
->new_bits
= new_bits
;
956 __entry
->pending_mask
= pending_mask
;
958 TP_printk("new=%x existing=%x", __entry
->new_bits
,
959 __entry
->pending_mask
)
962 DECLARE_EVENT_CLASS(dpu_hw_ctl_pending_flush_template
,
963 TP_PROTO(u32 pending_mask
, u32 ctl_flush
),
964 TP_ARGS(pending_mask
, ctl_flush
),
966 __field( u32
, pending_mask
)
967 __field( u32
, ctl_flush
)
970 __entry
->pending_mask
= pending_mask
;
971 __entry
->ctl_flush
= ctl_flush
;
973 TP_printk("pending_mask=%x CTL_FLUSH=%x", __entry
->pending_mask
,
976 DEFINE_EVENT(dpu_hw_ctl_pending_flush_template
, dpu_hw_ctl_clear_pending_flush
,
977 TP_PROTO(u32 pending_mask
, u32 ctl_flush
),
978 TP_ARGS(pending_mask
, ctl_flush
)
980 DEFINE_EVENT(dpu_hw_ctl_pending_flush_template
,
981 dpu_hw_ctl_trigger_pending_flush
,
982 TP_PROTO(u32 pending_mask
, u32 ctl_flush
),
983 TP_ARGS(pending_mask
, ctl_flush
)
985 DEFINE_EVENT(dpu_hw_ctl_pending_flush_template
, dpu_hw_ctl_trigger_prepare
,
986 TP_PROTO(u32 pending_mask
, u32 ctl_flush
),
987 TP_ARGS(pending_mask
, ctl_flush
)
989 DEFINE_EVENT(dpu_hw_ctl_pending_flush_template
, dpu_hw_ctl_trigger_start
,
990 TP_PROTO(u32 pending_mask
, u32 ctl_flush
),
991 TP_ARGS(pending_mask
, ctl_flush
)
994 #define DPU_ATRACE_END(name) trace_tracing_mark_write(current->tgid, name, 0)
995 #define DPU_ATRACE_BEGIN(name) trace_tracing_mark_write(current->tgid, name, 1)
996 #define DPU_ATRACE_FUNC() DPU_ATRACE_BEGIN(__func__)
998 #define DPU_ATRACE_INT(name, value) \
999 trace_dpu_trace_counter(current->tgid, name, value)
1001 #endif /* _DPU_TRACE_H_ */
1003 /* This part must be outside protection */
1004 #undef TRACE_INCLUDE_PATH
1005 #define TRACE_INCLUDE_PATH .
1006 #include <trace/define_trace.h>