mirror of https://gitee.com/openkylin/linux.git
180 lines
4.7 KiB
ReStructuredText
180 lines
4.7 KiB
ReStructuredText
.. -*- coding: utf-8; mode: rst -*-
|
|
|
|
.. _VIDIOC_S_HW_FREQ_SEEK:
|
|
|
|
***************************
|
|
ioctl VIDIOC_S_HW_FREQ_SEEK
|
|
***************************
|
|
|
|
Name
|
|
====
|
|
|
|
VIDIOC_S_HW_FREQ_SEEK - Perform a hardware frequency seek
|
|
|
|
|
|
Synopsis
|
|
========
|
|
|
|
.. cpp:function:: int ioctl( int fd, int request, struct v4l2_hw_freq_seek *argp )
|
|
|
|
|
|
Arguments
|
|
=========
|
|
|
|
``fd``
|
|
File descriptor returned by :ref:`open() <func-open>`.
|
|
|
|
``request``
|
|
VIDIOC_S_HW_FREQ_SEEK
|
|
|
|
``argp``
|
|
|
|
|
|
Description
|
|
===========
|
|
|
|
Start a hardware frequency seek from the current frequency. To do this
|
|
applications initialize the ``tuner``, ``type``, ``seek_upward``,
|
|
``wrap_around``, ``spacing``, ``rangelow`` and ``rangehigh`` fields, and
|
|
zero out the ``reserved`` array of a struct
|
|
:ref:`v4l2_hw_freq_seek <v4l2-hw-freq-seek>` and call the
|
|
``VIDIOC_S_HW_FREQ_SEEK`` ioctl with a pointer to this structure.
|
|
|
|
The ``rangelow`` and ``rangehigh`` fields can be set to a non-zero value
|
|
to tell the driver to search a specific band. If the struct
|
|
:ref:`v4l2_tuner <v4l2-tuner>` ``capability`` field has the
|
|
``V4L2_TUNER_CAP_HWSEEK_PROG_LIM`` flag set, these values must fall
|
|
within one of the bands returned by
|
|
:ref:`VIDIOC_ENUM_FREQ_BANDS`. If the
|
|
``V4L2_TUNER_CAP_HWSEEK_PROG_LIM`` flag is not set, then these values
|
|
must exactly match those of one of the bands returned by
|
|
:ref:`VIDIOC_ENUM_FREQ_BANDS`. If the
|
|
current frequency of the tuner does not fall within the selected band it
|
|
will be clamped to fit in the band before the seek is started.
|
|
|
|
If an error is returned, then the original frequency will be restored.
|
|
|
|
This ioctl is supported if the ``V4L2_CAP_HW_FREQ_SEEK`` capability is
|
|
set.
|
|
|
|
If this ioctl is called from a non-blocking filehandle, then ``EAGAIN``
|
|
error code is returned and no seek takes place.
|
|
|
|
|
|
.. _v4l2-hw-freq-seek:
|
|
|
|
.. flat-table:: struct v4l2_hw_freq_seek
|
|
:header-rows: 0
|
|
:stub-columns: 0
|
|
:widths: 1 1 2
|
|
|
|
|
|
- .. row 1
|
|
|
|
- __u32
|
|
|
|
- ``tuner``
|
|
|
|
- The tuner index number. This is the same value as in the struct
|
|
:ref:`v4l2_input <v4l2-input>` ``tuner`` field and the struct
|
|
:ref:`v4l2_tuner <v4l2-tuner>` ``index`` field.
|
|
|
|
- .. row 2
|
|
|
|
- __u32
|
|
|
|
- ``type``
|
|
|
|
- The tuner type. This is the same value as in the struct
|
|
:ref:`v4l2_tuner <v4l2-tuner>` ``type`` field. See
|
|
:ref:`v4l2-tuner-type`
|
|
|
|
- .. row 3
|
|
|
|
- __u32
|
|
|
|
- ``seek_upward``
|
|
|
|
- If non-zero, seek upward from the current frequency, else seek
|
|
downward.
|
|
|
|
- .. row 4
|
|
|
|
- __u32
|
|
|
|
- ``wrap_around``
|
|
|
|
- If non-zero, wrap around when at the end of the frequency range,
|
|
else stop seeking. The struct :ref:`v4l2_tuner <v4l2-tuner>`
|
|
``capability`` field will tell you what the hardware supports.
|
|
|
|
- .. row 5
|
|
|
|
- __u32
|
|
|
|
- ``spacing``
|
|
|
|
- If non-zero, defines the hardware seek resolution in Hz. The
|
|
driver selects the nearest value that is supported by the device.
|
|
If spacing is zero a reasonable default value is used.
|
|
|
|
- .. row 6
|
|
|
|
- __u32
|
|
|
|
- ``rangelow``
|
|
|
|
- If non-zero, the lowest tunable frequency of the band to search in
|
|
units of 62.5 kHz, or if the struct
|
|
:ref:`v4l2_tuner <v4l2-tuner>` ``capability`` field has the
|
|
``V4L2_TUNER_CAP_LOW`` flag set, in units of 62.5 Hz or if the
|
|
struct :ref:`v4l2_tuner <v4l2-tuner>` ``capability`` field has
|
|
the ``V4L2_TUNER_CAP_1HZ`` flag set, in units of 1 Hz. If
|
|
``rangelow`` is zero a reasonable default value is used.
|
|
|
|
- .. row 7
|
|
|
|
- __u32
|
|
|
|
- ``rangehigh``
|
|
|
|
- If non-zero, the highest tunable frequency of the band to search
|
|
in units of 62.5 kHz, or if the struct
|
|
:ref:`v4l2_tuner <v4l2-tuner>` ``capability`` field has the
|
|
``V4L2_TUNER_CAP_LOW`` flag set, in units of 62.5 Hz or if the
|
|
struct :ref:`v4l2_tuner <v4l2-tuner>` ``capability`` field has
|
|
the ``V4L2_TUNER_CAP_1HZ`` flag set, in units of 1 Hz. If
|
|
``rangehigh`` is zero a reasonable default value is used.
|
|
|
|
- .. row 8
|
|
|
|
- __u32
|
|
|
|
- ``reserved``\ [5]
|
|
|
|
- Reserved for future extensions. Applications must set the array to
|
|
zero.
|
|
|
|
|
|
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 ``tuner`` index is out of bounds, the ``wrap_around`` value is
|
|
not supported or one of the values in the ``type``, ``rangelow`` or
|
|
``rangehigh`` fields is wrong.
|
|
|
|
EAGAIN
|
|
Attempted to call ``VIDIOC_S_HW_FREQ_SEEK`` with the filehandle in
|
|
non-blocking mode.
|
|
|
|
ENODATA
|
|
The hardware seek found no channels.
|
|
|
|
EBUSY
|
|
Another hardware seek is already in progress.
|