cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

media-request-ioc-queue.rst (2550B)


      1.. SPDX-License-Identifier: GPL-2.0 OR GFDL-1.1-no-invariants-or-later
      2.. c:namespace:: MC
      3
      4.. _media_request_ioc_queue:
      5
      6*****************************
      7ioctl MEDIA_REQUEST_IOC_QUEUE
      8*****************************
      9
     10Name
     11====
     12
     13MEDIA_REQUEST_IOC_QUEUE - Queue a request
     14
     15Synopsis
     16========
     17
     18.. c:macro:: MEDIA_REQUEST_IOC_QUEUE
     19
     20``int ioctl(int request_fd, MEDIA_REQUEST_IOC_QUEUE)``
     21
     22Arguments
     23=========
     24
     25``request_fd``
     26    File descriptor returned by :ref:`MEDIA_IOC_REQUEST_ALLOC`.
     27
     28Description
     29===========
     30
     31If the media device supports :ref:`requests <media-request-api>`, then
     32this request ioctl can be used to queue a previously allocated request.
     33
     34If the request was successfully queued, then the file descriptor can be
     35:ref:`polled <request-func-poll>` to wait for the request to complete.
     36
     37If the request was already queued before, then ``EBUSY`` is returned.
     38Other errors can be returned if the contents of the request contained
     39invalid or inconsistent data, see the next section for a list of
     40common error codes. On error both the request and driver state are unchanged.
     41
     42Once a request is queued, then the driver is required to gracefully handle
     43errors that occur when the request is applied to the hardware. The
     44exception is the ``EIO`` error which signals a fatal error that requires
     45the application to stop streaming to reset the hardware state.
     46
     47It is not allowed to mix queuing requests with queuing buffers directly
     48(without a request). ``EBUSY`` will be returned if the first buffer was
     49queued directly and you next try to queue a request, or vice versa.
     50
     51A request must contain at least one buffer, otherwise this ioctl will
     52return an ``ENOENT`` error.
     53
     54Return Value
     55============
     56
     57On success 0 is returned, on error -1 and the ``errno`` variable is set
     58appropriately. The generic error codes are described at the
     59:ref:`Generic Error Codes <gen-errors>` chapter.
     60
     61EBUSY
     62    The request was already queued or the application queued the first
     63    buffer directly, but later attempted to use a request. It is not permitted
     64    to mix the two APIs.
     65ENOENT
     66    The request did not contain any buffers. All requests are required
     67    to have at least one buffer. This can also be returned if some required
     68    configuration is missing in the request.
     69ENOMEM
     70    Out of memory when allocating internal data structures for this
     71    request.
     72EINVAL
     73    The request has invalid data.
     74EIO
     75    The hardware is in a bad state. To recover, the application needs to
     76    stop streaming to reset the hardware state and then try to restart
     77    streaming.