media-ioc-setup-link.xml 3.0 KB
Newer Older
L
Laurent Pinchart 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
<refentry id="media-ioc-setup-link">
  <refmeta>
    <refentrytitle>ioctl MEDIA_IOC_SETUP_LINK</refentrytitle>
    &manvol;
  </refmeta>

  <refnamediv>
    <refname>MEDIA_IOC_SETUP_LINK</refname>
    <refpurpose>Modify the properties of a link</refpurpose>
  </refnamediv>

  <refsynopsisdiv>
    <funcsynopsis>
      <funcprototype>
	<funcdef>int <function>ioctl</function></funcdef>
	<paramdef>int <parameter>fd</parameter></paramdef>
	<paramdef>int <parameter>request</parameter></paramdef>
	<paramdef>struct media_link_desc *<parameter>argp</parameter></paramdef>
      </funcprototype>
    </funcsynopsis>
  </refsynopsisdiv>

  <refsect1>
    <title>Arguments</title>

    <variablelist>
      <varlistentry>
	<term><parameter>fd</parameter></term>
	<listitem>
	  <para>File descriptor returned by
	  <link linkend='media-func-open'><function>open()</function></link>.</para>
	</listitem>
      </varlistentry>
      <varlistentry>
	<term><parameter>request</parameter></term>
	<listitem>
37
	  <para>MEDIA_IOC_SETUP_LINK</para>
L
Laurent Pinchart 已提交
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
	</listitem>
      </varlistentry>
      <varlistentry>
	<term><parameter>argp</parameter></term>
	<listitem>
	  <para></para>
	</listitem>
      </varlistentry>
    </variablelist>
  </refsect1>

  <refsect1>
    <title>Description</title>

    <para>To change link properties applications fill a &media-link-desc; with
    link identification information (source and sink pad) and the new requested
    link flags. They then call the MEDIA_IOC_SETUP_LINK ioctl with a pointer to
    that structure.</para>
    <para>The only configurable property is the <constant>ENABLED</constant>
    link flag to enable/disable a link. Links marked with the
    <constant>IMMUTABLE</constant> link flag can not be enabled or disabled.
    </para>
    <para>Link configuration has no side effect on other links. If an enabled
    link at the sink pad prevents the link from being enabled, the driver
    returns with an &EBUSY;.</para>
63 64 65
    <para>Only links marked with the <constant>DYNAMIC</constant> link flag can
    be enabled/disabled while streaming media data. Attempting to enable or
    disable a streaming non-dynamic link will return an &EBUSY;.</para>
L
Laurent Pinchart 已提交
66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
    <para>If the specified link can't be found the driver returns with an
    &EINVAL;.</para>
  </refsect1>

  <refsect1>
    &return-value;

    <variablelist>
      <varlistentry>
	<term><errorcode>EBUSY</errorcode></term>
	<listitem>
	  <para>The link properties can't be changed because the link is
	  currently busy. This can be caused, for instance, by an active media
	  stream (audio or video) on the link. The ioctl shouldn't be retried if
	  no other action is performed before to fix the problem.</para>
	</listitem>
      </varlistentry>
      <varlistentry>
	<term><errorcode>EINVAL</errorcode></term>
	<listitem>
	  <para>The &media-link-desc; references a non-existing link, or the
	  link is immutable and an attempt to modify its configuration was made.
	  </para>
	</listitem>
      </varlistentry>
    </variablelist>
  </refsect1>
</refentry>