7.7. ioctl VIDIOC_DECODER_CMD, VIDIOC_TRY_DECODER_CMD¶
7.7.1. Name¶
VIDIOC_DECODER_CMD - VIDIOC_TRY_DECODER_CMD - Execute an decoder command
7.7.2. Synopsis¶
-
VIDIOC_DECODER_CMD¶
int ioctl(int fd, VIDIOC_DECODER_CMD, struct v4l2_decoder_cmd *argp)
-
VIDIOC_TRY_DECODER_CMD¶
int ioctl(int fd, VIDIOC_TRY_DECODER_CMD, struct v4l2_decoder_cmd *argp)
7.7.3. Arguments¶
fd
File descriptor returned by
open()
.argp
pointer to struct
v4l2_decoder_cmd
.
7.7.4. Description¶
These ioctls control an audio/video (usually MPEG-) decoder.
VIDIOC_DECODER_CMD
sends a command to the decoder,
VIDIOC_TRY_DECODER_CMD
can be used to try a command without actually
executing it. To send a command applications must initialize all fields
of a struct v4l2_decoder_cmd
and call
VIDIOC_DECODER_CMD
or VIDIOC_TRY_DECODER_CMD
with a pointer to
this structure.
The cmd
field must contain the command code. Some commands use the
flags
field for additional information.
A write()
or ioctl VIDIOC_STREAMON, VIDIOC_STREAMOFF
call sends an implicit START command to the decoder if it has not been
started yet. Applies to both queues of mem2mem decoders.
A close()
or VIDIOC_STREAMOFF
call of a streaming file descriptor sends an implicit immediate STOP
command to the decoder, and all buffered data is discarded. Applies to both
queues of mem2mem decoders.
In principle, these ioctls are optional, not all drivers may support them. They were introduced in Linux 3.3. They are, however, mandatory for stateful mem2mem decoders (as further documented in Memory-to-Memory Stateful Video Decoder Interface).
-
type v4l2_decoder_cmd¶
__u32 |
|
The decoder command, see Decoder Commands. |
|
__u32 |
|
Flags to go with the command. If no flags are defined for this command, drivers and applications must set this field to zero. |
|
union { |
(anonymous) |
||
struct |
|
Structure containing additional data for the
|
|
__s32 |
|
Playback speed and direction. The playback speed is defined as
|
|
__u32 |
|
Format restrictions. This field is set by the driver, not the
application. Possible values are |
|
struct |
|
Structure containing additional data for the |
|
__u64 |
|
Stop playback at this |
|
struct |
|
||
__u32 |
|
Reserved for future extensions. Drivers and applications must set the array to zero. |
|
} |
|
0 |
Start the decoder. When the decoder is already running or paused,
this command will just change the playback speed. That means that
calling For a device implementing the Memory-to-Memory Stateful Video Decoder Interface, once the drain sequence
is initiated with the |
|
1 |
Stop the decoder. When the decoder is already stopped, this
command does nothing. This command has two flags: if
For a device implementing the Memory-to-Memory Stateful Video Decoder Interface, the command will initiate
the drain sequence as documented in Memory-to-Memory Stateful Video Decoder Interface. No flags or other
arguments are accepted in this case. Any attempt to invoke the command
again before the sequence completes will trigger an |
|
2 |
Pause the decoder. When the decoder has not been started yet, the
driver will return an |
|
3 |
Resume decoding after a PAUSE command. When the decoder has not
been started yet, the driver will return an |
|
4 |
Flush any held capture buffers. Only valid for stateless decoders.
This command is typically used when the application reached the
end of the stream and the last output buffer had the
|
7.7.5. Return Value¶
On success 0 is returned, on error -1 and the errno
variable is set
appropriately. The generic error codes are described at the
Generic Error Codes chapter.
- EBUSY
A drain sequence of a device implementing the Memory-to-Memory Stateful Video Decoder Interface is still in progress. It is not allowed to issue another decoder command until it completes.
- EINVAL
The
cmd
field is invalid.- EPERM
The application sent a PAUSE or RESUME command when the decoder was not running.