157 lines
5.2 KiB
C
157 lines
5.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#if !defined(_VISL_TRACE_VP8_H_) || defined(TRACE_HEADER_MULTI_READ)
|
|
#define _VISL_TRACE_VP8_H_
|
|
|
|
#include <linux/tracepoint.h>
|
|
#include "visl.h"
|
|
|
|
#undef TRACE_SYSTEM
|
|
#define TRACE_SYSTEM visl_vp8_controls
|
|
|
|
DECLARE_EVENT_CLASS(v4l2_ctrl_vp8_entropy_tmpl,
|
|
TP_PROTO(const struct v4l2_ctrl_vp8_frame *f),
|
|
TP_ARGS(f),
|
|
TP_STRUCT__entry(__field_struct(struct v4l2_ctrl_vp8_frame, f)),
|
|
TP_fast_assign(__entry->f = *f;),
|
|
TP_printk("\nentropy.coeff_probs {%s}\n"
|
|
"entropy.y_mode_probs %s\n"
|
|
"entropy.uv_mode_probs %s\n"
|
|
"entropy.mv_probs {%s}",
|
|
__print_hex_dump("", DUMP_PREFIX_NONE, 32, 1,
|
|
__entry->f.entropy.coeff_probs,
|
|
sizeof(__entry->f.entropy.coeff_probs),
|
|
false),
|
|
__print_array(__entry->f.entropy.y_mode_probs,
|
|
ARRAY_SIZE(__entry->f.entropy.y_mode_probs),
|
|
sizeof(__entry->f.entropy.y_mode_probs[0])),
|
|
__print_array(__entry->f.entropy.uv_mode_probs,
|
|
ARRAY_SIZE(__entry->f.entropy.uv_mode_probs),
|
|
sizeof(__entry->f.entropy.uv_mode_probs[0])),
|
|
__print_hex_dump("", DUMP_PREFIX_NONE, 32, 1,
|
|
__entry->f.entropy.mv_probs,
|
|
sizeof(__entry->f.entropy.mv_probs),
|
|
false)
|
|
)
|
|
)
|
|
|
|
DECLARE_EVENT_CLASS(v4l2_ctrl_vp8_frame_tmpl,
|
|
TP_PROTO(const struct v4l2_ctrl_vp8_frame *f),
|
|
TP_ARGS(f),
|
|
TP_STRUCT__entry(__field_struct(struct v4l2_ctrl_vp8_frame, f)),
|
|
TP_fast_assign(__entry->f = *f;),
|
|
TP_printk("\nsegment.quant_update %s\n"
|
|
"segment.lf_update %s\n"
|
|
"segment.segment_probs %s\n"
|
|
"segment.flags %s\n"
|
|
"lf.ref_frm_delta %s\n"
|
|
"lf.mb_mode_delta %s\n"
|
|
"lf.sharpness_level %u\n"
|
|
"lf.level %u\n"
|
|
"lf.flags %s\n"
|
|
"quant.y_ac_qi %u\n"
|
|
"quant.y_dc_delta %d\n"
|
|
"quant.y2_dc_delta %d\n"
|
|
"quant.y2_ac_delta %d\n"
|
|
"quant.uv_dc_delta %d\n"
|
|
"quant.uv_ac_delta %d\n"
|
|
"coder_state.range %u\n"
|
|
"coder_state.value %u\n"
|
|
"coder_state.bit_count %u\n"
|
|
"width %u\n"
|
|
"height %u\n"
|
|
"horizontal_scale %u\n"
|
|
"vertical_scale %u\n"
|
|
"version %u\n"
|
|
"prob_skip_false %u\n"
|
|
"prob_intra %u\n"
|
|
"prob_last %u\n"
|
|
"prob_gf %u\n"
|
|
"num_dct_parts %u\n"
|
|
"first_part_size %u\n"
|
|
"first_part_header_bits %u\n"
|
|
"dct_part_sizes %s\n"
|
|
"last_frame_ts %llu\n"
|
|
"golden_frame_ts %llu\n"
|
|
"alt_frame_ts %llu\n"
|
|
"flags %s",
|
|
__print_array(__entry->f.segment.quant_update,
|
|
ARRAY_SIZE(__entry->f.segment.quant_update),
|
|
sizeof(__entry->f.segment.quant_update[0])),
|
|
__print_array(__entry->f.segment.lf_update,
|
|
ARRAY_SIZE(__entry->f.segment.lf_update),
|
|
sizeof(__entry->f.segment.lf_update[0])),
|
|
__print_array(__entry->f.segment.segment_probs,
|
|
ARRAY_SIZE(__entry->f.segment.segment_probs),
|
|
sizeof(__entry->f.segment.segment_probs[0])),
|
|
__print_flags(__entry->f.segment.flags, "|",
|
|
{V4L2_VP8_SEGMENT_FLAG_ENABLED, "SEGMENT_ENABLED"},
|
|
{V4L2_VP8_SEGMENT_FLAG_UPDATE_MAP, "SEGMENT_UPDATE_MAP"},
|
|
{V4L2_VP8_SEGMENT_FLAG_UPDATE_FEATURE_DATA, "SEGMENT_UPDATE_FEATURE_DATA"},
|
|
{V4L2_VP8_SEGMENT_FLAG_DELTA_VALUE_MODE, "SEGMENT_DELTA_VALUE_MODE"}),
|
|
__print_array(__entry->f.lf.ref_frm_delta,
|
|
ARRAY_SIZE(__entry->f.lf.ref_frm_delta),
|
|
sizeof(__entry->f.lf.ref_frm_delta[0])),
|
|
__print_array(__entry->f.lf.mb_mode_delta,
|
|
ARRAY_SIZE(__entry->f.lf.mb_mode_delta),
|
|
sizeof(__entry->f.lf.mb_mode_delta[0])),
|
|
__entry->f.lf.sharpness_level,
|
|
__entry->f.lf.level,
|
|
__print_flags(__entry->f.lf.flags, "|",
|
|
{V4L2_VP8_LF_ADJ_ENABLE, "LF_ADJ_ENABLED"},
|
|
{V4L2_VP8_LF_DELTA_UPDATE, "LF_DELTA_UPDATE"},
|
|
{V4L2_VP8_LF_FILTER_TYPE_SIMPLE, "LF_FILTER_TYPE_SIMPLE"}),
|
|
__entry->f.quant.y_ac_qi,
|
|
__entry->f.quant.y_dc_delta,
|
|
__entry->f.quant.y2_dc_delta,
|
|
__entry->f.quant.y2_ac_delta,
|
|
__entry->f.quant.uv_dc_delta,
|
|
__entry->f.quant.uv_ac_delta,
|
|
__entry->f.coder_state.range,
|
|
__entry->f.coder_state.value,
|
|
__entry->f.coder_state.bit_count,
|
|
__entry->f.width,
|
|
__entry->f.height,
|
|
__entry->f.horizontal_scale,
|
|
__entry->f.vertical_scale,
|
|
__entry->f.version,
|
|
__entry->f.prob_skip_false,
|
|
__entry->f.prob_intra,
|
|
__entry->f.prob_last,
|
|
__entry->f.prob_gf,
|
|
__entry->f.num_dct_parts,
|
|
__entry->f.first_part_size,
|
|
__entry->f.first_part_header_bits,
|
|
__print_array(__entry->f.dct_part_sizes,
|
|
ARRAY_SIZE(__entry->f.dct_part_sizes),
|
|
sizeof(__entry->f.dct_part_sizes[0])),
|
|
__entry->f.last_frame_ts,
|
|
__entry->f.golden_frame_ts,
|
|
__entry->f.alt_frame_ts,
|
|
__print_flags(__entry->f.flags, "|",
|
|
{V4L2_VP8_FRAME_FLAG_KEY_FRAME, "KEY_FRAME"},
|
|
{V4L2_VP8_FRAME_FLAG_EXPERIMENTAL, "EXPERIMENTAL"},
|
|
{V4L2_VP8_FRAME_FLAG_SHOW_FRAME, "SHOW_FRAME"},
|
|
{V4L2_VP8_FRAME_FLAG_MB_NO_SKIP_COEFF, "MB_NO_SKIP_COEFF"},
|
|
{V4L2_VP8_FRAME_FLAG_SIGN_BIAS_GOLDEN, "SIGN_BIAS_GOLDEN"},
|
|
{V4L2_VP8_FRAME_FLAG_SIGN_BIAS_ALT, "SIGN_BIAS_ALT"})
|
|
)
|
|
);
|
|
|
|
DEFINE_EVENT(v4l2_ctrl_vp8_frame_tmpl, v4l2_ctrl_vp8_frame,
|
|
TP_PROTO(const struct v4l2_ctrl_vp8_frame *f),
|
|
TP_ARGS(f)
|
|
);
|
|
|
|
DEFINE_EVENT(v4l2_ctrl_vp8_entropy_tmpl, v4l2_ctrl_vp8_entropy,
|
|
TP_PROTO(const struct v4l2_ctrl_vp8_frame *f),
|
|
TP_ARGS(f)
|
|
);
|
|
|
|
#endif
|
|
|
|
#undef TRACE_INCLUDE_PATH
|
|
#undef TRACE_INCLUDE_FILE
|
|
#define TRACE_INCLUDE_PATH ../../drivers/media/test-drivers/visl
|
|
#define TRACE_INCLUDE_FILE visl-trace-vp8
|
|
#include <trace/define_trace.h>
|