| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- .. SPDX-License-Identifier: GPL-2.0
- The Virtual Stateless Decoder Driver (visl)
- ===========================================
- A virtual stateless decoder device for stateless uAPI development
- purposes.
- This tool's objective is to help the development and testing of
- userspace applications that use the V4L2 stateless API to decode media.
- A userspace implementation can use visl to run a decoding loop even when
- no hardware is available or when the kernel uAPI for the codec has not
- been upstreamed yet. This can reveal bugs at an early stage.
- This driver can also trace the contents of the V4L2 controls submitted
- to it. It can also dump the contents of the vb2 buffers through a
- debugfs interface. This is in many ways similar to the tracing
- infrastructure available for other popular encode/decode APIs out there
- and can help develop a userspace application by using another (working)
- one as a reference.
- .. note::
- No actual decoding of video frames is performed by visl. The
- V4L2 test pattern generator is used to write various debug information
- to the capture buffers instead.
- Module parameters
- -----------------
- - visl_debug: Activates debug info, printing various debug messages through
- dprintk. Also controls whether per-frame debug info is shown. Defaults to off.
- Note that enabling this feature can result in slow performance through serial.
- - visl_transtime_ms: Simulated process time in milliseconds. Slowing down the
- decoding speed can be useful for debugging.
- - visl_dprintk_frame_start, visl_dprintk_frame_nframes: Dictates a range of
- frames where dprintk is activated. This only controls the dprintk tracing on a
- per-frame basis. Note that printing a lot of data can be slow through serial.
- - keep_bitstream_buffers: Controls whether bitstream (i.e. OUTPUT) buffers are
- kept after a decoding session. Defaults to false so as to reduce the amount of
- clutter. keep_bitstream_buffers == false works well when live debugging the
- client program with GDB.
- - bitstream_trace_frame_start, bitstream_trace_nframes: Similar to
- visl_dprintk_frame_start, visl_dprintk_nframes, but controls the dumping of
- buffer data through debugfs instead.
- - tpg_verbose: Write extra information on each output frame to ease debugging
- the API. When set to true, the output frames are not stable for a given input
- as some information like pointers or queue status will be added to them.
- What is the default use case for this driver?
- ---------------------------------------------
- This driver can be used as a way to compare different userspace implementations.
- This assumes that a working client is run against visl and that the ftrace and
- OUTPUT buffer data is subsequently used to debug a work-in-progress
- implementation.
- Even though no video decoding is actually done, the output frames can be used
- against a reference for a given input, except if tpg_verbose is set to true.
- Depending on the tpg_verbose parameter value, information on reference frames,
- their timestamps, the status of the OUTPUT and CAPTURE queues and more can be
- read directly from the CAPTURE buffers.
- Supported codecs
- ----------------
- The following codecs are supported:
- - FWHT
- - MPEG2
- - VP8
- - VP9
- - H.264
- - HEVC
- - AV1
- visl trace events
- -----------------
- The trace events are defined on a per-codec basis, e.g.:
- .. code-block:: bash
- $ ls /sys/kernel/tracing/events/ | grep visl
- visl_av1_controls
- visl_fwht_controls
- visl_h264_controls
- visl_hevc_controls
- visl_mpeg2_controls
- visl_vp8_controls
- visl_vp9_controls
- For example, in order to dump HEVC SPS data:
- .. code-block:: bash
- $ echo 1 > /sys/kernel/tracing/events/visl_hevc_controls/v4l2_ctrl_hevc_sps/enable
- The SPS data will be dumped to the trace buffer, i.e.:
- .. code-block:: bash
- $ cat /sys/kernel/tracing/trace
- video_parameter_set_id 0
- seq_parameter_set_id 0
- pic_width_in_luma_samples 1920
- pic_height_in_luma_samples 1080
- bit_depth_luma_minus8 0
- bit_depth_chroma_minus8 0
- log2_max_pic_order_cnt_lsb_minus4 4
- sps_max_dec_pic_buffering_minus1 6
- sps_max_num_reorder_pics 2
- sps_max_latency_increase_plus1 0
- log2_min_luma_coding_block_size_minus3 0
- log2_diff_max_min_luma_coding_block_size 3
- log2_min_luma_transform_block_size_minus2 0
- log2_diff_max_min_luma_transform_block_size 3
- max_transform_hierarchy_depth_inter 2
- max_transform_hierarchy_depth_intra 2
- pcm_sample_bit_depth_luma_minus1 0
- pcm_sample_bit_depth_chroma_minus1 0
- log2_min_pcm_luma_coding_block_size_minus3 0
- log2_diff_max_min_pcm_luma_coding_block_size 0
- num_short_term_ref_pic_sets 0
- num_long_term_ref_pics_sps 0
- chroma_format_idc 1
- sps_max_sub_layers_minus1 0
- flags AMP_ENABLED|SAMPLE_ADAPTIVE_OFFSET|TEMPORAL_MVP_ENABLED|STRONG_INTRA_SMOOTHING_ENABLED
- Dumping OUTPUT buffer data through debugfs
- ------------------------------------------
- If the **VISL_DEBUGFS** Kconfig is enabled, visl will populate
- **/sys/kernel/debug/visl/bitstream** with OUTPUT buffer data according to the
- values of bitstream_trace_frame_start and bitstream_trace_nframes. This can
- highlight errors as broken clients may fail to fill the buffers properly.
- A single file is created for each processed OUTPUT buffer. Its name contains an
- integer that denotes the buffer sequence, i.e.:
- .. code-block:: c
- snprintf(name, 32, "bitstream%d", run->src->sequence);
- Dumping the values is simply a matter of reading from the file, i.e.:
- For the buffer with sequence == 0:
- .. code-block:: bash
- $ xxd /sys/kernel/debug/visl/bitstream/bitstream0
- 00000000: 2601 af04 d088 bc25 a173 0e41 a4f2 3274 &......%.s.A..2t
- 00000010: c668 cb28 e775 b4ac f53a ba60 f8fd 3aa1 .h.(.u...:.`..:.
- 00000020: 46b4 bcfc 506c e227 2372 e5f5 d7ea 579f F...Pl.'#r....W.
- 00000030: 6371 5eb5 0eb8 23b5 ca6a 5de5 983a 19e4 cq^...#..j]..:..
- 00000040: e8c3 4320 b4ba a226 cbc1 4138 3a12 32d6 ..C ...&..A8:.2.
- 00000050: fef3 247b 3523 4e90 9682 ac8e eb0c a389 ..${5#N.........
- 00000060: ddd0 6cfc 0187 0e20 7aae b15b 1812 3d33 ..l.... z..[..=3
- 00000070: e1c5 f425 a83a 00b7 4f18 8127 3c4c aefb ...%.:..O..'<L..
- For the buffer with sequence == 1:
- .. code-block:: bash
- $ xxd /sys/kernel/debug/visl/bitstream/bitstream1
- 00000000: 0201 d021 49e1 0c40 aa11 1449 14a6 01dc ...!I..@...I....
- 00000010: 7023 889a c8cd 2cd0 13b4 dab0 e8ca 21fe p#....,.......!.
- 00000020: c4c8 ab4c 486e 4e2f b0df 96cc c74e 8dde ...LHnN/.....N..
- 00000030: 8ce7 ee36 d880 4095 4d64 30a0 ff4f 0c5e ...6..@.Md0..O.^
- 00000040: f16b a6a1 d806 ca2a 0ece a673 7bea 1f37 .k.....*...s{..7
- 00000050: 370f 5bb9 1dc4 ba21 6434 bc53 0173 cba0 7.[....!d4.S.s..
- 00000060: dfe6 bc99 01ea b6e0 346b 92b5 c8de 9f5d ........4k.....]
- 00000070: e7cc 3484 1769 fef2 a693 a945 2c8b 31da ..4..i.....E,.1.
- And so on.
- By default, the files are removed during STREAMOFF. This is to reduce the amount
- of clutter.
|