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¶
-
int
ioctl
(int fd, VIDIOC_DECODER_CMD, struct v4l2_decoder_cmd *argp)¶
-
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.
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.
These ioctls are optional, not all drivers may support them. They were introduced in Linux 3.3.
-
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 |
|
1 |
Stop the decoder. When the decoder is already stopped, this
command does nothing. This command has two flags: if
|
|
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 |
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.
- EINVAL
The
cmd
field is invalid.- EPERM
The application sent a PAUSE or RESUME command when the decoder was not running.