123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (c) 2014-2019, The Linux Foundation. All rights reserved.
- */
- #if !defined(TRACE_SDE_ROTATOR_H) || defined(TRACE_HEADER_MULTI_READ)
- #define TRACE_SDE_ROTATOR_H
- #undef TRACE_SYSTEM
- #define TRACE_SYSTEM sde_rotator
- #undef TRACE_INCLUDE_PATH
- #define TRACE_INCLUDE_PATH .
- #undef TRACE_INCLUDE_FILE
- #define TRACE_INCLUDE_FILE sde_rotator_trace
- #include <linux/tracepoint.h>
- #include <sde_rotator_core.h>
- DECLARE_EVENT_CLASS(rot_entry_template,
- TP_PROTO(u32 ss_id, u32 sq_id, struct sde_rot_trace_entry *rot),
- TP_ARGS(ss_id, sq_id, rot),
- TP_STRUCT__entry(
- __field(u32, ss_id)
- __field(u32, sq_id)
- __field(u32, pr_id)
- __field(u32, flags)
- __field(u32, src_fmt)
- __field(u16, src_bw)
- __field(u16, src_bh)
- __field(u16, src_x)
- __field(u16, src_y)
- __field(u16, src_w)
- __field(u16, src_h)
- __field(u32, dst_fmt)
- __field(u16, dst_bw)
- __field(u16, dst_bh)
- __field(u16, dst_x)
- __field(u16, dst_y)
- __field(u16, dst_w)
- __field(u16, dst_h)
- ),
- TP_fast_assign(
- __entry->ss_id = ss_id;
- __entry->sq_id = sq_id;
- __entry->pr_id = rot->wb_idx;
- __entry->flags = rot->flags;
- __entry->src_fmt = rot->input_format;
- __entry->src_bw = rot->input_width;
- __entry->src_bh = rot->input_height;
- __entry->src_x = rot->src_x;
- __entry->src_y = rot->src_y;
- __entry->src_w = rot->src_w;
- __entry->src_h = rot->src_h;
- __entry->dst_fmt = rot->output_format;
- __entry->dst_bw = rot->output_width;
- __entry->dst_bh = rot->output_height;
- __entry->dst_x = rot->dst_x;
- __entry->dst_y = rot->dst_y;
- __entry->dst_w = rot->dst_w;
- __entry->dst_h = rot->dst_h;
- ),
- TP_printk("%d.%d|%d|%x|%x|%u,%u|%u,%u,%u,%u|%x|%u,%u|%u,%u,%u,%u|",
- __entry->ss_id, __entry->sq_id, __entry->pr_id,
- __entry->flags,
- __entry->src_fmt, __entry->src_bw, __entry->src_bh,
- __entry->src_x, __entry->src_y,
- __entry->src_w, __entry->src_h,
- __entry->dst_fmt, __entry->dst_bw, __entry->dst_bh,
- __entry->dst_x, __entry->dst_y,
- __entry->dst_w, __entry->dst_h)
- );
- DEFINE_EVENT(rot_entry_template, rot_entry_fence,
- TP_PROTO(u32 ss_id, u32 sq_id, struct sde_rot_trace_entry *rot),
- TP_ARGS(ss_id, sq_id, rot)
- );
- DEFINE_EVENT(rot_entry_template, rot_entry_commit,
- TP_PROTO(u32 ss_id, u32 sq_id, struct sde_rot_trace_entry *rot),
- TP_ARGS(ss_id, sq_id, rot)
- );
- DEFINE_EVENT(rot_entry_template, rot_entry_done,
- TP_PROTO(u32 ss_id, u32 sq_id, struct sde_rot_trace_entry *rot),
- TP_ARGS(ss_id, sq_id, rot)
- );
- TRACE_EVENT(rot_perf_set_qos_luts,
- TP_PROTO(u32 pnum, u32 fmt, u32 lut, bool linear),
- TP_ARGS(pnum, fmt, lut, linear),
- TP_STRUCT__entry(
- __field(u32, pnum)
- __field(u32, fmt)
- __field(u32, lut)
- __field(bool, linear)
- ),
- TP_fast_assign(
- __entry->pnum = pnum;
- __entry->fmt = fmt;
- __entry->lut = lut;
- __entry->linear = linear;
- ),
- TP_printk("pnum=%d fmt=%d lut=0x%x lin:%d",
- __entry->pnum, __entry->fmt,
- __entry->lut, __entry->linear)
- );
- TRACE_EVENT(rot_perf_set_panic_luts,
- TP_PROTO(u32 pnum, u32 fmt, u32 mode, u32 panic_lut,
- u32 robust_lut),
- TP_ARGS(pnum, fmt, mode, panic_lut, robust_lut),
- TP_STRUCT__entry(
- __field(u32, pnum)
- __field(u32, fmt)
- __field(u32, mode)
- __field(u32, panic_lut)
- __field(u32, robust_lut)
- ),
- TP_fast_assign(
- __entry->pnum = pnum;
- __entry->fmt = fmt;
- __entry->mode = mode;
- __entry->panic_lut = panic_lut;
- __entry->robust_lut = robust_lut;
- ),
- TP_printk("pnum=%d fmt=%d mode=%d luts[0x%x, 0x%x]",
- __entry->pnum, __entry->fmt,
- __entry->mode, __entry->panic_lut,
- __entry->robust_lut)
- );
- TRACE_EVENT(rot_perf_set_wm_levels,
- TP_PROTO(u32 pnum, u32 use_space, u32 priority_bytes, u32 wm0, u32 wm1,
- u32 wm2, u32 mb_cnt, u32 mb_size),
- TP_ARGS(pnum, use_space, priority_bytes, wm0, wm1, wm2, mb_cnt,
- mb_size),
- TP_STRUCT__entry(
- __field(u32, pnum)
- __field(u32, use_space)
- __field(u32, priority_bytes)
- __field(u32, wm0)
- __field(u32, wm1)
- __field(u32, wm2)
- __field(u32, mb_cnt)
- __field(u32, mb_size)
- ),
- TP_fast_assign(
- __entry->pnum = pnum;
- __entry->use_space = use_space;
- __entry->priority_bytes = priority_bytes;
- __entry->wm0 = wm0;
- __entry->wm1 = wm1;
- __entry->wm2 = wm2;
- __entry->mb_cnt = mb_cnt;
- __entry->mb_size = mb_size;
- ),
- TP_printk(
- "pnum:%d useable_space:%d priority_bytes:%d watermark:[%d | %d | %d] nmb=%d mb_size=%d",
- __entry->pnum, __entry->use_space,
- __entry->priority_bytes, __entry->wm0, __entry->wm1,
- __entry->wm2, __entry->mb_cnt, __entry->mb_size)
- );
- TRACE_EVENT(rot_perf_set_ot,
- TP_PROTO(u32 pnum, u32 xin_id, u32 rd_lim),
- TP_ARGS(pnum, xin_id, rd_lim),
- TP_STRUCT__entry(
- __field(u32, pnum)
- __field(u32, xin_id)
- __field(u32, rd_lim)
- ),
- TP_fast_assign(
- __entry->pnum = pnum;
- __entry->xin_id = xin_id;
- __entry->rd_lim = rd_lim;
- ),
- TP_printk("pnum:%d xin_id:%d ot:%d",
- __entry->pnum, __entry->xin_id, __entry->rd_lim)
- );
- TRACE_EVENT(rot_perf_prefill_calc,
- TP_PROTO(u32 pnum, u32 latency_buf, u32 ot, u32 y_buf, u32 y_scaler,
- u32 pp_lines, u32 pp_bytes, u32 post_sc, u32 fbc_bytes,
- u32 prefill_bytes),
- TP_ARGS(pnum, latency_buf, ot, y_buf, y_scaler, pp_lines, pp_bytes,
- post_sc, fbc_bytes, prefill_bytes),
- TP_STRUCT__entry(
- __field(u32, pnum)
- __field(u32, latency_buf)
- __field(u32, ot)
- __field(u32, y_buf)
- __field(u32, y_scaler)
- __field(u32, pp_lines)
- __field(u32, pp_bytes)
- __field(u32, post_sc)
- __field(u32, fbc_bytes)
- __field(u32, prefill_bytes)
- ),
- TP_fast_assign(
- __entry->pnum = pnum;
- __entry->latency_buf = latency_buf;
- __entry->ot = ot;
- __entry->y_buf = y_buf;
- __entry->y_scaler = y_scaler;
- __entry->pp_lines = pp_lines;
- __entry->pp_bytes = pp_bytes;
- __entry->post_sc = post_sc;
- __entry->fbc_bytes = fbc_bytes;
- __entry->prefill_bytes = prefill_bytes;
- ),
- TP_printk(
- "pnum:%d latency_buf:%d ot:%d y_buf:%d y_scaler:%d pp_lines:%d, pp_bytes=%d post_sc:%d fbc_bytes:%d prefill:%d",
- __entry->pnum, __entry->latency_buf, __entry->ot,
- __entry->y_buf, __entry->y_scaler, __entry->pp_lines,
- __entry->pp_bytes, __entry->post_sc,
- __entry->fbc_bytes, __entry->prefill_bytes)
- );
- TRACE_EVENT(rot_mark_write,
- TP_PROTO(int pid, const char *name, bool trace_begin),
- TP_ARGS(pid, name, trace_begin),
- TP_STRUCT__entry(
- __field(int, pid)
- __string(trace_name, name)
- __field(bool, trace_begin)
- ),
- TP_fast_assign(
- __entry->pid = pid;
- __assign_str(trace_name, name);
- __entry->trace_begin = trace_begin;
- ),
- TP_printk("%s|%d|%s", __entry->trace_begin ? "B" : "E",
- __entry->pid, __get_str(trace_name))
- );
- TRACE_EVENT(rot_trace_counter,
- TP_PROTO(int pid, char *name, s64 value),
- TP_ARGS(pid, name, value),
- TP_STRUCT__entry(
- __field(int, pid)
- __string(counter_name, name)
- __field(s64, value)
- ),
- TP_fast_assign(
- __entry->pid = current->tgid;
- __assign_str(counter_name, name);
- __entry->value = value;
- ),
- TP_printk("%d|%s|%lld", __entry->pid,
- __get_str(counter_name), __entry->value)
- );
- TRACE_EVENT(rot_bw_ao_as_context,
- TP_PROTO(u32 state),
- TP_ARGS(state),
- TP_STRUCT__entry(
- __field(u32, state)
- ),
- TP_fast_assign(
- __entry->state = state;
- ),
- TP_printk("Rotator bw context %s",
- __entry->state ? "Active Only" : "Active+Sleep")
- );
- #define SDE_ROT_TRACE_EVTLOG_SIZE 15
- TRACE_EVENT(sde_rot_evtlog,
- TP_PROTO(const char *tag, u32 tag_id, u32 cnt, u32 *data),
- TP_ARGS(tag, tag_id, cnt, data),
- TP_STRUCT__entry(
- __field(int, pid)
- __string(evtlog_tag, tag)
- __field(u32, tag_id)
- __array(u32, data, SDE_ROT_TRACE_EVTLOG_SIZE)
- ),
- TP_fast_assign(
- __entry->pid = current->tgid;
- __assign_str(evtlog_tag, tag);
- __entry->tag_id = tag_id;
- if (cnt > SDE_ROT_TRACE_EVTLOG_SIZE)
- cnt = SDE_ROT_TRACE_EVTLOG_SIZE;
- memcpy(__entry->data, data, cnt * sizeof(u32));
- memset(&__entry->data[cnt], 0,
- (SDE_ROT_TRACE_EVTLOG_SIZE - cnt) *
- sizeof(u32));
- ),
- TP_printk("%d|%s:%d|%x|%x|%x|%x|%x|%x|%x|%x|%x|%x|%x|%x|%x|%x|%x",
- __entry->pid, __get_str(evtlog_tag),
- __entry->tag_id,
- __entry->data[0], __entry->data[1],
- __entry->data[2], __entry->data[3],
- __entry->data[4], __entry->data[5],
- __entry->data[6], __entry->data[7],
- __entry->data[8], __entry->data[9],
- __entry->data[10], __entry->data[11],
- __entry->data[12], __entry->data[13],
- __entry->data[14])
- )
- #endif /* if !defined(TRACE_SDE_ROTATOR_H) ||
- * defined(TRACE_HEADER_MULTI_READ)
- */
- /* This part must be outside protection */
- #include <trace/define_trace.h>
|