1 | /* SPDX-License-Identifier: GPL-2.0 */ |
2 | #if !defined(_VISL_TRACE_VP8_H_) || defined(TRACE_HEADER_MULTI_READ) |
3 | #define _VISL_TRACE_VP8_H_ |
4 | |
5 | #include <linux/tracepoint.h> |
6 | #include "visl.h" |
7 | |
8 | #undef TRACE_SYSTEM |
9 | #define TRACE_SYSTEM visl_vp8_controls |
10 | |
11 | DECLARE_EVENT_CLASS(v4l2_ctrl_vp8_entropy_tmpl, |
12 | TP_PROTO(const struct v4l2_ctrl_vp8_frame *f), |
13 | TP_ARGS(f), |
14 | TP_STRUCT__entry(__field_struct(struct v4l2_ctrl_vp8_frame, f)), |
15 | TP_fast_assign(__entry->f = *f;), |
16 | TP_printk("\nentropy.coeff_probs {%s}\n" |
17 | "entropy.y_mode_probs %s\n" |
18 | "entropy.uv_mode_probs %s\n" |
19 | "entropy.mv_probs {%s}" , |
20 | __print_hex_dump("" , DUMP_PREFIX_NONE, 32, 1, |
21 | __entry->f.entropy.coeff_probs, |
22 | sizeof(__entry->f.entropy.coeff_probs), |
23 | false), |
24 | __print_array(__entry->f.entropy.y_mode_probs, |
25 | ARRAY_SIZE(__entry->f.entropy.y_mode_probs), |
26 | sizeof(__entry->f.entropy.y_mode_probs[0])), |
27 | __print_array(__entry->f.entropy.uv_mode_probs, |
28 | ARRAY_SIZE(__entry->f.entropy.uv_mode_probs), |
29 | sizeof(__entry->f.entropy.uv_mode_probs[0])), |
30 | __print_hex_dump("" , DUMP_PREFIX_NONE, 32, 1, |
31 | __entry->f.entropy.mv_probs, |
32 | sizeof(__entry->f.entropy.mv_probs), |
33 | false) |
34 | ) |
35 | ) |
36 | |
37 | DECLARE_EVENT_CLASS(v4l2_ctrl_vp8_frame_tmpl, |
38 | TP_PROTO(const struct v4l2_ctrl_vp8_frame *f), |
39 | TP_ARGS(f), |
40 | TP_STRUCT__entry(__field_struct(struct v4l2_ctrl_vp8_frame, f)), |
41 | TP_fast_assign(__entry->f = *f;), |
42 | TP_printk("\nsegment.quant_update %s\n" |
43 | "segment.lf_update %s\n" |
44 | "segment.segment_probs %s\n" |
45 | "segment.flags %s\n" |
46 | "lf.ref_frm_delta %s\n" |
47 | "lf.mb_mode_delta %s\n" |
48 | "lf.sharpness_level %u\n" |
49 | "lf.level %u\n" |
50 | "lf.flags %s\n" |
51 | "quant.y_ac_qi %u\n" |
52 | "quant.y_dc_delta %d\n" |
53 | "quant.y2_dc_delta %d\n" |
54 | "quant.y2_ac_delta %d\n" |
55 | "quant.uv_dc_delta %d\n" |
56 | "quant.uv_ac_delta %d\n" |
57 | "coder_state.range %u\n" |
58 | "coder_state.value %u\n" |
59 | "coder_state.bit_count %u\n" |
60 | "width %u\n" |
61 | "height %u\n" |
62 | "horizontal_scale %u\n" |
63 | "vertical_scale %u\n" |
64 | "version %u\n" |
65 | "prob_skip_false %u\n" |
66 | "prob_intra %u\n" |
67 | "prob_last %u\n" |
68 | "prob_gf %u\n" |
69 | "num_dct_parts %u\n" |
70 | "first_part_size %u\n" |
71 | "first_part_header_bits %u\n" |
72 | "dct_part_sizes %s\n" |
73 | "last_frame_ts %llu\n" |
74 | "golden_frame_ts %llu\n" |
75 | "alt_frame_ts %llu\n" |
76 | "flags %s" , |
77 | __print_array(__entry->f.segment.quant_update, |
78 | ARRAY_SIZE(__entry->f.segment.quant_update), |
79 | sizeof(__entry->f.segment.quant_update[0])), |
80 | __print_array(__entry->f.segment.lf_update, |
81 | ARRAY_SIZE(__entry->f.segment.lf_update), |
82 | sizeof(__entry->f.segment.lf_update[0])), |
83 | __print_array(__entry->f.segment.segment_probs, |
84 | ARRAY_SIZE(__entry->f.segment.segment_probs), |
85 | sizeof(__entry->f.segment.segment_probs[0])), |
86 | __print_flags(__entry->f.segment.flags, "|" , |
87 | {V4L2_VP8_SEGMENT_FLAG_ENABLED, "SEGMENT_ENABLED" }, |
88 | {V4L2_VP8_SEGMENT_FLAG_UPDATE_MAP, "SEGMENT_UPDATE_MAP" }, |
89 | {V4L2_VP8_SEGMENT_FLAG_UPDATE_FEATURE_DATA, "SEGMENT_UPDATE_FEATURE_DATA" }, |
90 | {V4L2_VP8_SEGMENT_FLAG_DELTA_VALUE_MODE, "SEGMENT_DELTA_VALUE_MODE" }), |
91 | __print_array(__entry->f.lf.ref_frm_delta, |
92 | ARRAY_SIZE(__entry->f.lf.ref_frm_delta), |
93 | sizeof(__entry->f.lf.ref_frm_delta[0])), |
94 | __print_array(__entry->f.lf.mb_mode_delta, |
95 | ARRAY_SIZE(__entry->f.lf.mb_mode_delta), |
96 | sizeof(__entry->f.lf.mb_mode_delta[0])), |
97 | __entry->f.lf.sharpness_level, |
98 | __entry->f.lf.level, |
99 | __print_flags(__entry->f.lf.flags, "|" , |
100 | {V4L2_VP8_LF_ADJ_ENABLE, "LF_ADJ_ENABLED" }, |
101 | {V4L2_VP8_LF_DELTA_UPDATE, "LF_DELTA_UPDATE" }, |
102 | {V4L2_VP8_LF_FILTER_TYPE_SIMPLE, "LF_FILTER_TYPE_SIMPLE" }), |
103 | __entry->f.quant.y_ac_qi, |
104 | __entry->f.quant.y_dc_delta, |
105 | __entry->f.quant.y2_dc_delta, |
106 | __entry->f.quant.y2_ac_delta, |
107 | __entry->f.quant.uv_dc_delta, |
108 | __entry->f.quant.uv_ac_delta, |
109 | __entry->f.coder_state.range, |
110 | __entry->f.coder_state.value, |
111 | __entry->f.coder_state.bit_count, |
112 | __entry->f.width, |
113 | __entry->f.height, |
114 | __entry->f.horizontal_scale, |
115 | __entry->f.vertical_scale, |
116 | __entry->f.version, |
117 | __entry->f.prob_skip_false, |
118 | __entry->f.prob_intra, |
119 | __entry->f.prob_last, |
120 | __entry->f.prob_gf, |
121 | __entry->f.num_dct_parts, |
122 | __entry->f.first_part_size, |
123 | __entry->f.first_part_header_bits, |
124 | __print_array(__entry->f.dct_part_sizes, |
125 | ARRAY_SIZE(__entry->f.dct_part_sizes), |
126 | sizeof(__entry->f.dct_part_sizes[0])), |
127 | __entry->f.last_frame_ts, |
128 | __entry->f.golden_frame_ts, |
129 | __entry->f.alt_frame_ts, |
130 | __print_flags(__entry->f.flags, "|" , |
131 | {V4L2_VP8_FRAME_FLAG_KEY_FRAME, "KEY_FRAME" }, |
132 | {V4L2_VP8_FRAME_FLAG_EXPERIMENTAL, "EXPERIMENTAL" }, |
133 | {V4L2_VP8_FRAME_FLAG_SHOW_FRAME, "SHOW_FRAME" }, |
134 | {V4L2_VP8_FRAME_FLAG_MB_NO_SKIP_COEFF, "MB_NO_SKIP_COEFF" }, |
135 | {V4L2_VP8_FRAME_FLAG_SIGN_BIAS_GOLDEN, "SIGN_BIAS_GOLDEN" }, |
136 | {V4L2_VP8_FRAME_FLAG_SIGN_BIAS_ALT, "SIGN_BIAS_ALT" }) |
137 | ) |
138 | ); |
139 | |
140 | DEFINE_EVENT(v4l2_ctrl_vp8_frame_tmpl, v4l2_ctrl_vp8_frame, |
141 | TP_PROTO(const struct v4l2_ctrl_vp8_frame *f), |
142 | TP_ARGS(f) |
143 | ); |
144 | |
145 | DEFINE_EVENT(v4l2_ctrl_vp8_entropy_tmpl, v4l2_ctrl_vp8_entropy, |
146 | TP_PROTO(const struct v4l2_ctrl_vp8_frame *f), |
147 | TP_ARGS(f) |
148 | ); |
149 | |
150 | #endif |
151 | |
152 | #undef TRACE_INCLUDE_PATH |
153 | #undef TRACE_INCLUDE_FILE |
154 | #define TRACE_INCLUDE_PATH ../../drivers/media/test-drivers/visl |
155 | #define TRACE_INCLUDE_FILE visl-trace-vp8 |
156 | #include <trace/define_trace.h> |
157 | |