1 <refentry id="vidioc-expbuf">
4 <refentrytitle>ioctl VIDIOC_EXPBUF</refentrytitle>
9 <refname>VIDIOC_EXPBUF</refname>
10 <refpurpose>Export a buffer as a DMABUF file descriptor.</refpurpose>
16 <funcdef>int <function>ioctl</function></funcdef>
17 <paramdef>int <parameter>fd</parameter></paramdef>
18 <paramdef>int <parameter>request</parameter></paramdef>
19 <paramdef>struct v4l2_exportbuffer *<parameter>argp</parameter></paramdef>
25 <title>Arguments</title>
29 <term><parameter>fd</parameter></term>
35 <term><parameter>request</parameter></term>
37 <para>VIDIOC_EXPBUF</para>
41 <term><parameter>argp</parameter></term>
50 <title>Description</title>
53 <title>Experimental</title>
54 <para>This is an <link linkend="experimental"> experimental </link>
55 interface and may change in the future.</para>
58 <para>This ioctl is an extension to the <link linkend="mmap">memory
59 mapping</link> I/O method, therefore it is available only for
60 <constant>V4L2_MEMORY_MMAP</constant> buffers. It can be used to export a
61 buffer as a DMABUF file at any time after buffers have been allocated with the
62 &VIDIOC-REQBUFS; ioctl.</para>
64 <para> To export a buffer, applications fill &v4l2-exportbuffer;. The
65 <structfield>type</structfield> field is set to the same buffer type as was
66 previously used with &v4l2-requestbuffers; <structfield>type</structfield>.
67 Applications must also set the <structfield>index</structfield> field. Valid
68 index numbers range from zero to the number of buffers allocated with
69 &VIDIOC-REQBUFS; (&v4l2-requestbuffers; <structfield>count</structfield>)
70 minus one. For the multi-planar API, applications set the <structfield>plane</structfield>
71 field to the index of the plane to be exported. Valid planes
72 range from zero to the maximal number of valid planes for the currently active
73 format. For the single-planar API, applications must set <structfield>plane</structfield>
74 to zero. Additional flags may be posted in the <structfield>flags</structfield>
75 field. Refer to a manual for open() for details.
76 Currently only O_CLOEXEC, O_RDONLY, O_WRONLY, and O_RDWR are supported. All
77 other fields must be set to zero.
78 In the case of multi-planar API, every plane is exported separately using
79 multiple <constant>VIDIOC_EXPBUF</constant> calls.</para>
81 <para>After calling <constant>VIDIOC_EXPBUF</constant> the <structfield>fd</structfield>
82 field will be set by a driver. This is a DMABUF file
83 descriptor. The application may pass it to other DMABUF-aware devices. Refer to
84 <link linkend="dmabuf">DMABUF importing</link> for details about importing
85 DMABUF files into V4L2 nodes. It is recommended to close a DMABUF file when it
86 is no longer used to allow the associated memory to be reclaimed.</para>
90 <title>Examples</title>
93 <title>Exporting a buffer.</title>
95 int buffer_export(int v4lfd, &v4l2-buf-type; bt, int index, int *dmafd)
97 &v4l2-exportbuffer; expbuf;
99 memset(&expbuf, 0, sizeof(expbuf));
101 expbuf.index = index;
102 if (ioctl(v4lfd, &VIDIOC-EXPBUF;, &expbuf) == -1) {
103 perror("VIDIOC_EXPBUF");
115 <title>Exporting a buffer using the multi-planar API.</title>
117 int buffer_export_mp(int v4lfd, &v4l2-buf-type; bt, int index,
118 int dmafd[], int n_planes)
122 for (i = 0; i < n_planes; ++i) {
123 &v4l2-exportbuffer; expbuf;
125 memset(&expbuf, 0, sizeof(expbuf));
127 expbuf.index = index;
129 if (ioctl(v4lfd, &VIDIOC-EXPBUF;, &expbuf) == -1) {
130 perror("VIDIOC_EXPBUF");
135 dmafd[i] = expbuf.fd;
143 <table pgwide="1" frame="none" id="v4l2-exportbuffer">
144 <title>struct <structname>v4l2_exportbuffer</structname></title>
150 <entry><structfield>type</structfield></entry>
151 <entry>Type of the buffer, same as &v4l2-format;
152 <structfield>type</structfield> or &v4l2-requestbuffers;
153 <structfield>type</structfield>, set by the application. See <xref
154 linkend="v4l2-buf-type" /></entry>
158 <entry><structfield>index</structfield></entry>
159 <entry>Number of the buffer, set by the application. This field is
160 only used for <link linkend="mmap">memory mapping</link> I/O and can range from
161 zero to the number of buffers allocated with the &VIDIOC-REQBUFS; and/or
162 &VIDIOC-CREATE-BUFS; ioctls. </entry>
166 <entry><structfield>plane</structfield></entry>
167 <entry>Index of the plane to be exported when using the
168 multi-planar API. Otherwise this value must be set to zero. </entry>
172 <entry><structfield>flags</structfield></entry>
173 <entry>Flags for the newly created file, currently only
174 <constant>O_CLOEXEC</constant>, <constant>O_RDONLY</constant>, <constant>O_WRONLY</constant>,
175 and <constant>O_RDWR</constant> are supported, refer to the manual
176 of open() for more details.</entry>
180 <entry><structfield>fd</structfield></entry>
181 <entry>The DMABUF file descriptor associated with a buffer. Set by
186 <entry><structfield>reserved[11]</structfield></entry>
187 <entry>Reserved field for future use. Drivers and applications must
188 set the array to zero.</entry>
200 <term><errorcode>EINVAL</errorcode></term>
202 <para>A queue is not in MMAP mode or DMABUF exporting is not
203 supported or <structfield>flags</structfield> or <structfield>type</structfield>
204 or <structfield>index</structfield> or <structfield>plane</structfield> fields