2020-08-26 09:03:09 +02:00
|
|
|
.. SPDX-License-Identifier: GFDL-1.1-no-invariants-or-later
|
2020-09-24 14:04:26 +02:00
|
|
|
.. c:namespace:: V4L
|
2018-08-30 10:15:26 -04:00
|
|
|
|
2016-07-01 13:42:29 -03:00
|
|
|
.. _VIDIOC_QUERYSTD:
|
2016-06-30 15:18:56 +02:00
|
|
|
|
2018-05-17 10:30:16 -04:00
|
|
|
*********************************************
|
|
|
|
ioctl VIDIOC_QUERYSTD, VIDIOC_SUBDEV_QUERYSTD
|
|
|
|
*********************************************
|
2016-06-30 15:18:56 +02:00
|
|
|
|
2016-07-05 15:14:35 -03:00
|
|
|
Name
|
2016-07-05 07:58:48 -03:00
|
|
|
====
|
2016-06-30 15:18:56 +02:00
|
|
|
|
2018-05-17 10:30:16 -04:00
|
|
|
VIDIOC_QUERYSTD - VIDIOC_SUBDEV_QUERYSTD - Sense the video standard received by the current input
|
2016-06-30 15:18:56 +02:00
|
|
|
|
2016-07-05 15:14:35 -03:00
|
|
|
Synopsis
|
2016-06-30 15:18:56 +02:00
|
|
|
========
|
|
|
|
|
2020-09-24 14:04:26 +02:00
|
|
|
.. c:macro:: VIDIOC_QUERYSTD
|
|
|
|
|
|
|
|
``int ioctl(int fd, VIDIOC_QUERYSTD, v4l2_std_id *argp)``
|
2016-06-30 15:18:56 +02:00
|
|
|
|
2020-09-24 14:04:26 +02:00
|
|
|
.. c:macro:: VIDIOC_SUBDEV_QUERYSTD
|
2018-05-17 10:30:16 -04:00
|
|
|
|
2020-09-24 14:04:26 +02:00
|
|
|
``int ioctl(int fd, VIDIOC_SUBDEV_QUERYSTD, v4l2_std_id *argp)``
|
2016-07-05 07:58:48 -03:00
|
|
|
|
2016-07-05 15:14:35 -03:00
|
|
|
Arguments
|
2016-06-30 15:18:56 +02:00
|
|
|
=========
|
|
|
|
|
|
|
|
``fd``
|
2020-09-24 14:04:26 +02:00
|
|
|
File descriptor returned by :c:func:`open()`.
|
2016-06-30 15:18:56 +02:00
|
|
|
|
|
|
|
``argp``
|
2017-09-02 09:54:48 -04:00
|
|
|
Pointer to :c:type:`v4l2_std_id`.
|
2016-06-30 15:18:56 +02:00
|
|
|
|
2016-07-05 15:14:35 -03:00
|
|
|
Description
|
2016-06-30 15:18:56 +02:00
|
|
|
===========
|
|
|
|
|
|
|
|
The hardware may be able to detect the current video standard
|
2016-07-01 14:33:56 -03:00
|
|
|
automatically. To do so, applications call :ref:`VIDIOC_QUERYSTD` with a
|
2016-06-30 15:18:56 +02:00
|
|
|
pointer to a :ref:`v4l2_std_id <v4l2-std-id>` type. The driver
|
|
|
|
stores here a set of candidates, this can be a single flag or a set of
|
|
|
|
supported standards if for example the hardware can only distinguish
|
|
|
|
between 50 and 60 Hz systems. If no signal was detected, then the driver
|
|
|
|
will return V4L2_STD_UNKNOWN. When detection is not possible or fails,
|
|
|
|
the set must contain all standards supported by the current video input
|
|
|
|
or output.
|
|
|
|
|
2016-08-15 17:49:50 -03:00
|
|
|
.. note::
|
|
|
|
|
|
|
|
Drivers shall *not* switch the video standard
|
2016-07-10 11:57:43 -03:00
|
|
|
automatically if a new video standard is detected. Instead, drivers
|
|
|
|
should send the ``V4L2_EVENT_SOURCE_CHANGE`` event (if they support
|
|
|
|
this) and expect that userspace will take action by calling
|
|
|
|
:ref:`VIDIOC_QUERYSTD`. The reason is that a new video standard can mean
|
|
|
|
different buffer sizes as well, and you cannot change buffer sizes on
|
|
|
|
the fly. In general, applications that receive the Source Change event
|
|
|
|
will have to call :ref:`VIDIOC_QUERYSTD`, and if the detected video
|
|
|
|
standard is valid they will have to stop streaming, set the new
|
|
|
|
standard, allocate new buffers and start streaming again.
|
2016-06-30 15:18:56 +02:00
|
|
|
|
2016-07-05 15:14:35 -03:00
|
|
|
Return Value
|
2016-06-30 15:18:56 +02:00
|
|
|
============
|
|
|
|
|
|
|
|
On success 0 is returned, on error -1 and the ``errno`` variable is set
|
|
|
|
appropriately. The generic error codes are described at the
|
|
|
|
:ref:`Generic Error Codes <gen-errors>` chapter.
|
|
|
|
|
|
|
|
ENODATA
|
|
|
|
Standard video timings are not supported for this input or output.
|