| .. SPDX-License-Identifier: GFDL-1.1-no-invariants-or-later |
| .. c:namespace:: MC |
| |
| .. _media_ioc_setup_link: |
| |
| ************************** |
| ioctl MEDIA_IOC_SETUP_LINK |
| ************************** |
| |
| Name |
| ==== |
| |
| MEDIA_IOC_SETUP_LINK - Modify the properties of a link |
| |
| Synopsis |
| ======== |
| |
| .. c:macro:: MEDIA_IOC_SETUP_LINK |
| |
| ``int ioctl(int fd, MEDIA_IOC_SETUP_LINK, struct media_link_desc *argp)`` |
| |
| Arguments |
| ========= |
| |
| ``fd`` |
| File descriptor returned by :c:func:`open()`. |
| |
| ``argp`` |
| Pointer to struct :c:type:`media_link_desc`. |
| |
| Description |
| =========== |
| |
| To change link properties applications fill a struct |
| :c:type:`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. |
| |
| The only configurable property is the ``ENABLED`` link flag to |
| enable/disable a link. Links marked with the ``IMMUTABLE`` link flag can |
| not be enabled or disabled. |
| |
| 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`` error code. |
| |
| Only links marked with the ``DYNAMIC`` link flag can be enabled/disabled |
| while streaming media data. Attempting to enable or disable a streaming |
| non-dynamic link will return an ``EBUSY`` error code. |
| |
| If the specified link can't be found the driver returns with an ``EINVAL`` |
| error code. |
| |
| Return Value |
| ============ |
| |
| 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 |
| The struct :c:type:`media_link_desc` references a |
| non-existing link, or the link is immutable and an attempt to modify |
| its configuration was made. |