230 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			230 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GFDL-1.1-no-invariants-or-later
 | |
| .. c:namespace:: V4L
 | |
| 
 | |
| .. _VIDIOC_ENUMINPUT:
 | |
| 
 | |
| **********************
 | |
| ioctl VIDIOC_ENUMINPUT
 | |
| **********************
 | |
| 
 | |
| Name
 | |
| ====
 | |
| 
 | |
| VIDIOC_ENUMINPUT - Enumerate video inputs
 | |
| 
 | |
| Synopsis
 | |
| ========
 | |
| 
 | |
| .. c:macro:: VIDIOC_ENUMINPUT
 | |
| 
 | |
| ``int ioctl(int fd, VIDIOC_ENUMINPUT, struct v4l2_input *argp)``
 | |
| 
 | |
| Arguments
 | |
| =========
 | |
| 
 | |
| ``fd``
 | |
|     File descriptor returned by :c:func:`open()`.
 | |
| 
 | |
| ``argp``
 | |
|     Pointer to struct :c:type:`v4l2_input`.
 | |
| 
 | |
| Description
 | |
| ===========
 | |
| 
 | |
| To query the attributes of a video input applications initialize the
 | |
| ``index`` field of struct :c:type:`v4l2_input` and call the
 | |
| :ref:`VIDIOC_ENUMINPUT` with a pointer to this structure. Drivers
 | |
| fill the rest of the structure or return an ``EINVAL`` error code when the
 | |
| index is out of bounds. To enumerate all inputs applications shall begin
 | |
| at index zero, incrementing by one until the driver returns ``EINVAL``.
 | |
| 
 | |
| .. tabularcolumns:: |p{3.0cm}|p{3.5cm}|p{10.8cm}|
 | |
| 
 | |
| .. c:type:: v4l2_input
 | |
| 
 | |
| .. flat-table:: struct v4l2_input
 | |
|     :header-rows:  0
 | |
|     :stub-columns: 0
 | |
|     :widths:       1 1 2
 | |
| 
 | |
|     * - __u32
 | |
|       - ``index``
 | |
|       - Identifies the input, set by the application.
 | |
|     * - __u8
 | |
|       - ``name``\ [32]
 | |
|       - Name of the video input, a NUL-terminated ASCII string, for
 | |
| 	example: "Vin (Composite 2)". This information is intended for the
 | |
| 	user, preferably the connector label on the device itself.
 | |
|     * - __u32
 | |
|       - ``type``
 | |
|       - Type of the input, see :ref:`input-type`.
 | |
|     * - __u32
 | |
|       - ``audioset``
 | |
|       - Drivers can enumerate up to 32 video and audio inputs. This field
 | |
| 	shows which audio inputs were selectable as audio source if this
 | |
| 	was the currently selected video input. It is a bit mask. The LSB
 | |
| 	corresponds to audio input 0, the MSB to input 31. Any number of
 | |
| 	bits can be set, or none.
 | |
| 
 | |
| 	When the driver does not enumerate audio inputs no bits must be
 | |
| 	set. Applications shall not interpret this as lack of audio
 | |
| 	support. Some drivers automatically select audio sources and do
 | |
| 	not enumerate them since there is no choice anyway.
 | |
| 
 | |
| 	For details on audio inputs and how to select the current input
 | |
| 	see :ref:`audio`.
 | |
|     * - __u32
 | |
|       - ``tuner``
 | |
|       - Capture devices can have zero or more tuners (RF demodulators).
 | |
| 	When the ``type`` is set to ``V4L2_INPUT_TYPE_TUNER`` this is an
 | |
| 	RF connector and this field identifies the tuner. It corresponds
 | |
| 	to struct :c:type:`v4l2_tuner` field ``index``. For
 | |
| 	details on tuners see :ref:`tuner`.
 | |
|     * - :ref:`v4l2_std_id <v4l2-std-id>`
 | |
|       - ``std``
 | |
|       - Every video input supports one or more different video standards.
 | |
| 	This field is a set of all supported standards. For details on
 | |
| 	video standards and how to switch see :ref:`standard`.
 | |
|     * - __u32
 | |
|       - ``status``
 | |
|       - This field provides status information about the input. See
 | |
| 	:ref:`input-status` for flags. With the exception of the sensor
 | |
| 	orientation bits ``status`` is only valid when this is the current
 | |
| 	input.
 | |
|     * - __u32
 | |
|       - ``capabilities``
 | |
|       - This field provides capabilities for the input. See
 | |
| 	:ref:`input-capabilities` for flags.
 | |
|     * - __u32
 | |
|       - ``reserved``\ [3]
 | |
|       - Reserved for future extensions. Drivers must set the array to
 | |
| 	zero.
 | |
| 
 | |
| 
 | |
| .. tabularcolumns:: |p{6.6cm}|p{1.0cm}|p{9.7cm}|
 | |
| 
 | |
| .. _input-type:
 | |
| 
 | |
| .. flat-table:: Input Types
 | |
|     :header-rows:  0
 | |
|     :stub-columns: 0
 | |
|     :widths:       3 1 4
 | |
| 
 | |
|     * - ``V4L2_INPUT_TYPE_TUNER``
 | |
|       - 1
 | |
|       - This input uses a tuner (RF demodulator).
 | |
|     * - ``V4L2_INPUT_TYPE_CAMERA``
 | |
|       - 2
 | |
|       - Any non-tuner video input, for example Composite Video,
 | |
| 	S-Video, HDMI, camera sensor. The naming as ``_TYPE_CAMERA`` is historical,
 | |
| 	today we would have called it ``_TYPE_VIDEO``.
 | |
|     * - ``V4L2_INPUT_TYPE_TOUCH``
 | |
|       - 3
 | |
|       - This input is a touch device for capturing raw touch data.
 | |
| 
 | |
| 
 | |
| .. tabularcolumns:: |p{5.6cm}|p{2.6cm}|p{9.1cm}|
 | |
| 
 | |
| .. _input-status:
 | |
| 
 | |
| .. flat-table:: Input Status Flags
 | |
|     :header-rows:  0
 | |
|     :stub-columns: 0
 | |
| 
 | |
|     * - :cspan:`2` General
 | |
|     * - ``V4L2_IN_ST_NO_POWER``
 | |
|       - 0x00000001
 | |
|       - Attached device is off.
 | |
|     * - ``V4L2_IN_ST_NO_SIGNAL``
 | |
|       - 0x00000002
 | |
|       -
 | |
|     * - ``V4L2_IN_ST_NO_COLOR``
 | |
|       - 0x00000004
 | |
|       - The hardware supports color decoding, but does not detect color
 | |
| 	modulation in the signal.
 | |
|     * - :cspan:`2` Sensor Orientation
 | |
|     * - ``V4L2_IN_ST_HFLIP``
 | |
|       - 0x00000010
 | |
|       - The input is connected to a device that produces a signal that is
 | |
| 	flipped horizontally and does not correct this before passing the
 | |
| 	signal to userspace.
 | |
|     * - ``V4L2_IN_ST_VFLIP``
 | |
|       - 0x00000020
 | |
|       - The input is connected to a device that produces a signal that is
 | |
| 	flipped vertically and does not correct this before passing the
 | |
| 	signal to userspace.
 | |
| 	.. note:: A 180 degree rotation is the same as HFLIP | VFLIP
 | |
|     * - :cspan:`2` Analog Video
 | |
|     * - ``V4L2_IN_ST_NO_H_LOCK``
 | |
|       - 0x00000100
 | |
|       - No horizontal sync lock.
 | |
|     * - ``V4L2_IN_ST_COLOR_KILL``
 | |
|       - 0x00000200
 | |
|       - A color killer circuit automatically disables color decoding when
 | |
| 	it detects no color modulation. When this flag is set the color
 | |
| 	killer is enabled *and* has shut off color decoding.
 | |
|     * - ``V4L2_IN_ST_NO_V_LOCK``
 | |
|       - 0x00000400
 | |
|       - No vertical sync lock.
 | |
|     * - ``V4L2_IN_ST_NO_STD_LOCK``
 | |
|       - 0x00000800
 | |
|       - No standard format lock in case of auto-detection format
 | |
| 	by the component.
 | |
|     * - :cspan:`2` Digital Video
 | |
|     * - ``V4L2_IN_ST_NO_SYNC``
 | |
|       - 0x00010000
 | |
|       - No synchronization lock.
 | |
|     * - ``V4L2_IN_ST_NO_EQU``
 | |
|       - 0x00020000
 | |
|       - No equalizer lock.
 | |
|     * - ``V4L2_IN_ST_NO_CARRIER``
 | |
|       - 0x00040000
 | |
|       - Carrier recovery failed.
 | |
|     * - :cspan:`2` VCR and Set-Top Box
 | |
|     * - ``V4L2_IN_ST_MACROVISION``
 | |
|       - 0x01000000
 | |
|       - Macrovision is an analog copy prevention system mangling the video
 | |
| 	signal to confuse video recorders. When this flag is set
 | |
| 	Macrovision has been detected.
 | |
|     * - ``V4L2_IN_ST_NO_ACCESS``
 | |
|       - 0x02000000
 | |
|       - Conditional access denied.
 | |
|     * - ``V4L2_IN_ST_VTR``
 | |
|       - 0x04000000
 | |
|       - VTR time constant. [?]
 | |
| 
 | |
| 
 | |
| .. tabularcolumns:: |p{6.6cm}|p{2.4cm}|p{8.3cm}|
 | |
| 
 | |
| .. _input-capabilities:
 | |
| 
 | |
| .. flat-table:: Input capabilities
 | |
|     :header-rows:  0
 | |
|     :stub-columns: 0
 | |
|     :widths:       3 1 4
 | |
| 
 | |
|     * - ``V4L2_IN_CAP_DV_TIMINGS``
 | |
|       - 0x00000002
 | |
|       - This input supports setting video timings by using
 | |
| 	``VIDIOC_S_DV_TIMINGS``.
 | |
|     * - ``V4L2_IN_CAP_STD``
 | |
|       - 0x00000004
 | |
|       - This input supports setting the TV standard by using
 | |
| 	``VIDIOC_S_STD``.
 | |
|     * - ``V4L2_IN_CAP_NATIVE_SIZE``
 | |
|       - 0x00000008
 | |
|       - This input supports setting the native size using the
 | |
| 	``V4L2_SEL_TGT_NATIVE_SIZE`` selection target, see
 | |
| 	:ref:`v4l2-selections-common`.
 | |
| 
 | |
| 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
 | |
| :ref:`Generic Error Codes <gen-errors>` chapter.
 | |
| 
 | |
| EINVAL
 | |
|     The struct :c:type:`v4l2_input` ``index`` is out of
 | |
|     bounds.
 |