~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/userspace-api/media/mediactl/media-request-ioc-queue.rst

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /Documentation/userspace-api/media/mediactl/media-request-ioc-queue.rst (Version linux-6.12-rc7) and /Documentation/userspace-api/media/mediactl/media-request-ioc-queue.rst (Version linux-5.9.16)


  1 .. SPDX-License-Identifier: GPL-2.0 OR GFDL-1. !!   1 .. This file is dual-licensed: you can use it either under the terms
  2 .. c:namespace:: MC                            !!   2 .. of the GPL 2.0 or the GFDL 1.1+ license, at your option. Note that this
                                                   >>   3 .. dual licensing only applies to this file, and not this project as a
                                                   >>   4 .. whole.
                                                   >>   5 ..
                                                   >>   6 .. a) This file is free software; you can redistribute it and/or
                                                   >>   7 ..    modify it under the terms of the GNU General Public License as
                                                   >>   8 ..    published by the Free Software Foundation version 2 of
                                                   >>   9 ..    the License.
                                                   >>  10 ..
                                                   >>  11 ..    This file is distributed in the hope that it will be useful,
                                                   >>  12 ..    but WITHOUT ANY WARRANTY; without even the implied warranty of
                                                   >>  13 ..    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                                                   >>  14 ..    GNU General Public License for more details.
                                                   >>  15 ..
                                                   >>  16 .. Or, alternatively,
                                                   >>  17 ..
                                                   >>  18 .. b) Permission is granted to copy, distribute and/or modify this
                                                   >>  19 ..    document under the terms of the GNU Free Documentation License,
                                                   >>  20 ..    Version 1.1 or any later version published by the Free Software
                                                   >>  21 ..    Foundation, with no Invariant Sections, no Front-Cover Texts
                                                   >>  22 ..    and no Back-Cover Texts. A copy of the license is included at
                                                   >>  23 ..    Documentation/userspace-api/media/fdl-appendix.rst.
                                                   >>  24 ..
                                                   >>  25 .. TODO: replace it to GPL-2.0 OR GFDL-1.1-or-later WITH no-invariant-sections
  3                                                    26 
  4 .. _media_request_ioc_queue:                       27 .. _media_request_ioc_queue:
  5                                                    28 
  6 *****************************                      29 *****************************
  7 ioctl MEDIA_REQUEST_IOC_QUEUE                      30 ioctl MEDIA_REQUEST_IOC_QUEUE
  8 *****************************                      31 *****************************
  9                                                    32 
 10 Name                                               33 Name
 11 ====                                               34 ====
 12                                                    35 
 13 MEDIA_REQUEST_IOC_QUEUE - Queue a request          36 MEDIA_REQUEST_IOC_QUEUE - Queue a request
 14                                                    37 
                                                   >>  38 
 15 Synopsis                                           39 Synopsis
 16 ========                                           40 ========
 17                                                    41 
 18 .. c:macro:: MEDIA_REQUEST_IOC_QUEUE           !!  42 .. c:function:: int ioctl( int request_fd, MEDIA_REQUEST_IOC_QUEUE )
                                                   >>  43     :name: MEDIA_REQUEST_IOC_QUEUE
 19                                                    44 
 20 ``int ioctl(int request_fd, MEDIA_REQUEST_IOC_ << 
 21                                                    45 
 22 Arguments                                          46 Arguments
 23 =========                                          47 =========
 24                                                    48 
 25 ``request_fd``                                     49 ``request_fd``
 26     File descriptor returned by :ref:`MEDIA_IO     50     File descriptor returned by :ref:`MEDIA_IOC_REQUEST_ALLOC`.
                                                   >>  51 
 27                                                    52 
 28 Description                                        53 Description
 29 ===========                                        54 ===========
 30                                                    55 
 31 If the media device supports :ref:`requests <m     56 If the media device supports :ref:`requests <media-request-api>`, then
 32 this request ioctl can be used to queue a prev     57 this request ioctl can be used to queue a previously allocated request.
 33                                                    58 
 34 If the request was successfully queued, then t     59 If the request was successfully queued, then the file descriptor can be
 35 :ref:`polled <request-func-poll>` to wait for      60 :ref:`polled <request-func-poll>` to wait for the request to complete.
 36                                                    61 
 37 If the request was already queued before, then     62 If the request was already queued before, then ``EBUSY`` is returned.
 38 Other errors can be returned if the contents o     63 Other errors can be returned if the contents of the request contained
 39 invalid or inconsistent data, see the next sec     64 invalid or inconsistent data, see the next section for a list of
 40 common error codes. On error both the request      65 common error codes. On error both the request and driver state are unchanged.
 41                                                    66 
 42 Once a request is queued, then the driver is r     67 Once a request is queued, then the driver is required to gracefully handle
 43 errors that occur when the request is applied      68 errors that occur when the request is applied to the hardware. The
 44 exception is the ``EIO`` error which signals a     69 exception is the ``EIO`` error which signals a fatal error that requires
 45 the application to stop streaming to reset the     70 the application to stop streaming to reset the hardware state.
 46                                                    71 
 47 It is not allowed to mix queuing requests with     72 It is not allowed to mix queuing requests with queuing buffers directly
 48 (without a request). ``EBUSY`` will be returne     73 (without a request). ``EBUSY`` will be returned if the first buffer was
 49 queued directly and you next try to queue a re     74 queued directly and you next try to queue a request, or vice versa.
 50                                                    75 
 51 A request must contain at least one buffer, ot     76 A request must contain at least one buffer, otherwise this ioctl will
 52 return an ``ENOENT`` error.                        77 return an ``ENOENT`` error.
 53                                                    78 
 54 Return Value                                       79 Return Value
 55 ============                                       80 ============
 56                                                    81 
 57 On success 0 is returned, on error -1 and the      82 On success 0 is returned, on error -1 and the ``errno`` variable is set
 58 appropriately. The generic error codes are des     83 appropriately. The generic error codes are described at the
 59 :ref:`Generic Error Codes <gen-errors>` chapte     84 :ref:`Generic Error Codes <gen-errors>` chapter.
 60                                                    85 
 61 EBUSY                                              86 EBUSY
 62     The request was already queued or the appl     87     The request was already queued or the application queued the first
 63     buffer directly, but later attempted to us     88     buffer directly, but later attempted to use a request. It is not permitted
 64     to mix the two APIs.                           89     to mix the two APIs.
 65 ENOENT                                             90 ENOENT
 66     The request did not contain any buffers. A     91     The request did not contain any buffers. All requests are required
 67     to have at least one buffer. This can also     92     to have at least one buffer. This can also be returned if some required
 68     configuration is missing in the request.       93     configuration is missing in the request.
 69 ENOMEM                                             94 ENOMEM
 70     Out of memory when allocating internal dat     95     Out of memory when allocating internal data structures for this
 71     request.                                       96     request.
 72 EINVAL                                             97 EINVAL
 73     The request has invalid data.                  98     The request has invalid data.
 74 EIO                                                99 EIO
 75     The hardware is in a bad state. To recover    100     The hardware is in a bad state. To recover, the application needs to
 76     stop streaming to reset the hardware state    101     stop streaming to reset the hardware state and then try to restart
 77     streaming.                                    102     streaming.
                                                      

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php