82 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. SPDX-License-Identifier: GPL-2.0
 | |
| 
 | |
| .. _GPIO_V2_LINEINFO_CHANGED_READ:
 | |
| 
 | |
| *****************************
 | |
| GPIO_V2_LINEINFO_CHANGED_READ
 | |
| *****************************
 | |
| 
 | |
| Name
 | |
| ====
 | |
| 
 | |
| GPIO_V2_LINEINFO_CHANGED_READ - Read line info changed events for watched
 | |
| lines from the chip.
 | |
| 
 | |
| Synopsis
 | |
| ========
 | |
| 
 | |
| ``int read(int chip_fd, void *buf, size_t count)``
 | |
| 
 | |
| Arguments
 | |
| =========
 | |
| 
 | |
| ``chip_fd``
 | |
|     The file descriptor of the GPIO character device returned by `open()`.
 | |
| 
 | |
| ``buf``
 | |
|     The buffer to contain the :c:type:`events<gpio_v2_line_info_changed>`.
 | |
| 
 | |
| ``count``
 | |
|     The number of bytes available in ``buf``, which must be at least the size
 | |
|     of a :c:type:`gpio_v2_line_info_changed` event.
 | |
| 
 | |
| Description
 | |
| ===========
 | |
| 
 | |
| Read line info changed events for watched lines from the chip.
 | |
| 
 | |
| .. note::
 | |
|     Monitoring line info changes is not generally required, and would typically
 | |
|     only be performed by a system monitoring component.
 | |
| 
 | |
|     These events relate to changes in a line's request state or configuration,
 | |
|     not its value. Use gpio-v2-line-event-read.rst to receive events when a
 | |
|     line changes value.
 | |
| 
 | |
| A line must be watched using gpio-v2-get-lineinfo-watch-ioctl.rst to generate
 | |
| info changed events.  Subsequently, a request, release, or reconfiguration
 | |
| of the line will generate an info changed event.
 | |
| 
 | |
| The kernel timestamps events when they occur and stores them in a buffer
 | |
| from where they can be read by userspace at its convenience using `read()`.
 | |
| 
 | |
| The size of the kernel event buffer is fixed at 32 events per ``chip_fd``.
 | |
| 
 | |
| The buffer may overflow if bursts of events occur quicker than they are read
 | |
| by userspace. If an overflow occurs then the most recent event is discarded.
 | |
| Overflow cannot be detected from userspace.
 | |
| 
 | |
| Events read from the buffer are always in the same order that they were
 | |
| detected by the kernel, including when multiple lines are being monitored by
 | |
| the one ``chip_fd``.
 | |
| 
 | |
| To minimize the number of calls required to copy events from the kernel to
 | |
| userspace, `read()` supports copying multiple events. The number of events
 | |
| copied is the lower of the number available in the kernel buffer and the
 | |
| number that will fit in the userspace buffer (``buf``).
 | |
| 
 | |
| A `read()` will block if no event is available and the ``chip_fd`` has not
 | |
| been set **O_NONBLOCK**.
 | |
| 
 | |
| The presence of an event can be tested for by checking that the ``chip_fd`` is
 | |
| readable using `poll()` or an equivalent.
 | |
| 
 | |
| Return Value
 | |
| ============
 | |
| 
 | |
| On success the number of bytes read, which will be a multiple of the size
 | |
| of a :c:type:`gpio_v2_line_info_changed` event.
 | |
| 
 | |
| On error -1 and the ``errno`` variable is set appropriately.
 | |
| Common error codes are described in error-codes.rst.
 |