2020-08-26 09:03:09 +02:00
.. SPDX-License-Identifier: GFDL-1.1-no-invariants-or-later
2018-08-30 10:15:26 -04:00
2016-07-07 11:05:38 -03:00
.. _VIDIOC_G_AUDOUT:
2016-06-30 15:18:56 +02:00
***** ***** ***** ***** ***** ***** ***** ***
ioctl VIDIOC_G_AUDOUT, VIDIOC_S_AUDOUT
***** ***** ***** ***** ***** ***** ***** ***
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
2016-07-05 07:58:48 -03:00
VIDIOC_G_AUDOUT - VIDIOC_S_AUDOUT - Query or select the current audio output
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
========
2016-08-19 16:53:38 -03:00
.. c:function :: int ioctl( int fd, VIDIOC_G_AUDOUT, struct v4l2_audioout *argp )
:name: VIDIOC_G_AUDOUT
2016-06-30 15:18:56 +02:00
2016-08-19 16:53:38 -03:00
.. c:function :: int ioctl( int fd, VIDIOC_S_AUDOUT, const struct v4l2_audioout *argp )
:name: VIDIOC_S_AUDOUT
2016-06-30 15:18:56 +02:00
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 ``
File descriptor returned by :ref: `open() <func-open>` .
`` argp ``
2017-09-02 09:54:48 -04:00
Pointer to struct :c:type: `v4l2_audioout` .
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
===========
To query the current audio output applications zero out the `` reserved ``
2016-08-29 17:37:59 -03:00
array of a struct :c:type: `v4l2_audioout` and call the
2016-06-30 15:18:56 +02:00
`` VIDIOC_G_AUDOUT `` ioctl with a pointer to this structure. Drivers fill
2016-07-03 11:53:09 -03:00
the rest of the structure or return an `` EINVAL `` error code when the device
2016-06-30 15:18:56 +02:00
has no audio inputs, or none which combine with the current video
output.
Audio outputs have no writable properties. Nevertheless, to select the
current audio output applications can initialize the `` index `` field and
`` reserved `` array (which in the future may contain writable properties)
2016-09-08 05:43:01 -03:00
of a struct :c:type: `v4l2_audioout` structure and call the
2016-06-30 15:18:56 +02:00
`` VIDIOC_S_AUDOUT `` ioctl. Drivers switch to the requested output or
2016-07-03 11:53:09 -03:00
return the `` EINVAL `` error code when the index is out of bounds. This is a
2016-06-30 15:18:56 +02:00
write-only ioctl, it does not return the current audio output attributes
as `` VIDIOC_G_AUDOUT `` does.
2016-08-15 17:49:50 -03:00
.. note ::
Connectors on a TV card to loop back the received audio signal
2016-07-10 11:57:43 -03:00
to a sound card are not audio outputs in this sense.
2016-06-30 15:18:56 +02:00
2016-08-29 17:37:59 -03:00
.. c:type :: v4l2_audioout
2016-06-30 15:18:56 +02:00
[media] docs-rst: add tabularcolumns to all tables
LaTeX doesn't handle too well auto-width on tables, and ReST
markup requires an special tag to give it the needed hints.
As we're using A4 paper, we have 17cm of useful spaces. As
most media tables have widths, let's use it to generate the
needed via the following perl script:
my ($line_size, $table_header, $has_cols) = (17.5, 0, 0);
my $out;
my $header = "";
my @widths = ();
sub round { $_[0] > 0 ? int($_[0] + .5) : -int(-$_[0] + .5) }
while (<>) {
if (!$table_header) {
$has_cols = 1 if (m/..\s+tabularcolumns::/);
if (m/..\s+flat-table::/) {
$table_header = 1;
$header = $_;
next;
}
$out .= $_;
next;
}
$header .= $_;
@widths = split(/ /, $1) if (m/:widths:\s+(.*)/);
if (m/^\n$/) {
if (!$has_cols && @widths) {
my ($tot, $t, $i) = (0, 0, 0);
foreach my $v(@widths) { $tot += $v; };
$out .= ".. tabularcolumns:: |";
for ($i = 0; $i < scalar @widths - 1; $i++) {
my $v = $widths[$i];
my $w = round(10 * ($v * $line_size) / $tot) / 10;
$out .= sprintf "p{%.1fcm}|", $w;
$t += $w;
}
my $w = $line_size - $t;
$out .= sprintf "p{%.1fcm}|\n\n", $w;
}
$out .= $header;
$table_header = 0;
$has_cols = 0;
$header = "";
@widths = ();
}
}
print $out;
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
2016-08-17 08:14:19 -03:00
.. tabularcolumns :: |p{4.4cm}|p{4.4cm}|p{8.7cm}|
2016-06-30 15:18:56 +02:00
.. flat-table :: struct v4l2_audioout
:header-rows: 0
:stub-columns: 0
:widths: 1 1 2
[media] v4l: doc: Remove row numbers from tables
Shorten the tables by removing row numbers in comments, allowing for
later insertion of rows with minimal diffs.
All changes have been generated by the following script.
import io
import re
import sys
def process_table(fname, data):
if fname.endswith('hist-v4l2.rst'):
data = re.sub(u'\n{1,2}\t( ?) -( ?) ?', u'\n\t\\1 -\\2', data, flags = re.MULTILINE)
data = re.sub(u'\n(\t| )- \.\. row [0-9]+\n\t ?-( ?) ?', u'\\1* -\\2', data, flags = re.MULTILINE)
else:
data = re.sub(u'\n{1,2} -( ?) ?', u'\n -\\1', data, flags = re.MULTILINE)
data = re.sub(u'(\n?)(\n\n - \.\. row 1\n)', u'\n\\2', data, flags = re.MULTILINE)
data = re.sub(u'\n - \.\. row [0-9]+\n -( ?) ?', u' * -\\1', data, flags = re.MULTILINE)
data = re.sub(u'\n - \.\. row [0-9]+\n \.\. (_[A-Z0-9_`-]*:)', u'\n - .. \\1', data, flags = re.MULTILINE)
data = re.sub(u'\n - \.\. (_[A-Z0-9_`-]*:)\n -', u' * .. \\1\n\n -', data, flags = re.MULTILINE)
data = re.sub(u'^ - ', u' -', data, flags = re.MULTILINE)
data = re.sub(u'^(\t{1,2}) ', u'\\1', data, flags = re.MULTILINE)
return data
def process_file(fname, data):
buf = io.StringIO(data)
output = ''
in_table = False
table_separator = 0
for line in buf.readlines():
if line.find('.. flat-table::') != -1:
in_table = True
table = ''
elif in_table and not re.match('^[\t\n]|( )', line):
in_table = False
output += process_table(fname, table)
if in_table:
table += line
else:
output += line
if in_table:
in_table = False
output += process_table(fname, table)
return output
fname = sys.argv[1]
data = file(fname, 'rb').read().decode('utf-8')
data = process_file(fname, data)
file(fname, 'wb').write(data.encode('utf-8'))
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
2016-09-05 08:44:34 -03:00
* - __u32
- `` index ``
- Identifies the audio output, set by the driver or application.
* - __u8
- `` name ` ` \ [32]
- Name of the audio output, a NUL-terminated ASCII string, for
example: "Line Out". This information is intended for the user,
preferably the connector label on the device itself.
* - __u32
- `` capability ``
- Audio capability flags, none defined yet. Drivers must set this
field to zero.
* - __u32
- `` mode ``
- Audio mode, none defined yet. Drivers and applications (on
`` VIDIOC_S_AUDOUT `` ) must set this field to zero.
* - __u32
- `` reserved ` ` \ [2]
- Reserved for future extensions. Drivers and applications must set
the array to zero.
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.
EINVAL
No audio outputs combine with the current video output, or the
number of the selected audio output is out of bounds or it does not
combine.