mirror of https://gitee.com/openkylin/linux.git
127 lines
4.7 KiB
XML
127 lines
4.7 KiB
XML
<title>Software Defined Radio Interface (SDR)</title>
|
|
|
|
<para>
|
|
SDR is an abbreviation of Software Defined Radio, the radio device
|
|
which uses application software for modulation or demodulation. This interface
|
|
is intended for controlling and data streaming of such devices.
|
|
</para>
|
|
|
|
<para>
|
|
SDR devices are accessed through character device special files named
|
|
<filename>/dev/swradio0</filename> to <filename>/dev/swradio255</filename>
|
|
with major number 81 and dynamically allocated minor numbers 0 to 255.
|
|
</para>
|
|
|
|
<section>
|
|
<title>Querying Capabilities</title>
|
|
|
|
<para>
|
|
Devices supporting the SDR receiver interface set the
|
|
<constant>V4L2_CAP_SDR_CAPTURE</constant> and
|
|
<constant>V4L2_CAP_TUNER</constant> flag in the
|
|
<structfield>capabilities</structfield> field of &v4l2-capability;
|
|
returned by the &VIDIOC-QUERYCAP; ioctl. That flag means the device has an
|
|
Analog to Digital Converter (ADC), which is a mandatory element for the SDR receiver.
|
|
</para>
|
|
<para>
|
|
Devices supporting the SDR transmitter interface set the
|
|
<constant>V4L2_CAP_SDR_OUTPUT</constant> and
|
|
<constant>V4L2_CAP_MODULATOR</constant> flag in the
|
|
<structfield>capabilities</structfield> field of &v4l2-capability;
|
|
returned by the &VIDIOC-QUERYCAP; ioctl. That flag means the device has an
|
|
Digital to Analog Converter (DAC), which is a mandatory element for the SDR transmitter.
|
|
</para>
|
|
<para>
|
|
At least one of the read/write, streaming or asynchronous I/O methods must
|
|
be supported.
|
|
</para>
|
|
</section>
|
|
|
|
<section>
|
|
<title>Supplemental Functions</title>
|
|
|
|
<para>
|
|
SDR devices can support <link linkend="control">controls</link>, and must
|
|
support the <link linkend="tuner">tuner</link> ioctls. Tuner ioctls are used
|
|
for setting the ADC/DAC sampling rate (sampling frequency) and the possible
|
|
radio frequency (RF).
|
|
</para>
|
|
|
|
<para>
|
|
The <constant>V4L2_TUNER_SDR</constant> tuner type is used for setting SDR
|
|
device ADC/DAC frequency, and the <constant>V4L2_TUNER_RF</constant>
|
|
tuner type is used for setting radio frequency.
|
|
The tuner index of the RF tuner (if any) must always follow the SDR tuner index.
|
|
Normally the SDR tuner is #0 and the RF tuner is #1.
|
|
</para>
|
|
|
|
<para>
|
|
The &VIDIOC-S-HW-FREQ-SEEK; ioctl is not supported.
|
|
</para>
|
|
</section>
|
|
|
|
<section>
|
|
<title>Data Format Negotiation</title>
|
|
|
|
<para>
|
|
The SDR device uses the <link linkend="format">format</link> ioctls to
|
|
select the capture and output format. Both the sampling resolution and the data
|
|
streaming format are bound to that selectable format. In addition to the basic
|
|
<link linkend="format">format</link> ioctls, the &VIDIOC-ENUM-FMT; ioctl
|
|
must be supported as well.
|
|
</para>
|
|
|
|
<para>
|
|
To use the <link linkend="format">format</link> ioctls applications set the
|
|
<structfield>type</structfield> field of a &v4l2-format; to
|
|
<constant>V4L2_BUF_TYPE_SDR_CAPTURE</constant> or
|
|
<constant>V4L2_BUF_TYPE_SDR_OUTPUT</constant> and use the &v4l2-sdr-format;
|
|
<structfield>sdr</structfield> member of the <structfield>fmt</structfield>
|
|
union as needed per the desired operation.
|
|
Currently there is two fields, <structfield>pixelformat</structfield> and
|
|
<structfield>buffersize</structfield>, of struct &v4l2-sdr-format; which are
|
|
used. Content of the <structfield>pixelformat</structfield> is V4L2 FourCC
|
|
code of the data format. The <structfield>buffersize</structfield> field is
|
|
maximum buffer size in bytes required for data transfer, set by the driver in
|
|
order to inform application.
|
|
</para>
|
|
|
|
<table pgwide="1" frame="none" id="v4l2-sdr-format">
|
|
<title>struct <structname>v4l2_sdr_format</structname></title>
|
|
<tgroup cols="3">
|
|
&cs-str;
|
|
<tbody valign="top">
|
|
<row>
|
|
<entry>__u32</entry>
|
|
<entry><structfield>pixelformat</structfield></entry>
|
|
<entry>
|
|
The data format or type of compression, set by the application. This is a
|
|
little endian <link linkend="v4l2-fourcc">four character code</link>.
|
|
V4L2 defines SDR formats in <xref linkend="sdr-formats" />.
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>__u32</entry>
|
|
<entry><structfield>buffersize</structfield></entry>
|
|
<entry>
|
|
Maximum size in bytes required for data. Value is set by the driver.
|
|
</entry>
|
|
</row>
|
|
<row>
|
|
<entry>__u8</entry>
|
|
<entry><structfield>reserved[24]</structfield></entry>
|
|
<entry>This array is reserved for future extensions.
|
|
Drivers and applications must set it to zero.</entry>
|
|
</row>
|
|
</tbody>
|
|
</tgroup>
|
|
</table>
|
|
|
|
<para>
|
|
An SDR device may support <link linkend="rw">read/write</link>
|
|
and/or streaming (<link linkend="mmap">memory mapping</link>
|
|
or <link linkend="userp">user pointer</link>) I/O.
|
|
</para>
|
|
|
|
</section>
|