mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-08 14:13:53 +00:00
08d94c7428
The documentation does not make sufficiently clear that edge polarity is based on changes to the logical line values, and that the physical polarity of edges is dependent on the active low flag. Clarify the relationship between the active low flag and edge polarity for the functions that read edge events. Suggested-by: David C. Rankin <drankinatty@gmail.com> Signed-off-by: Kent Gibson <warthog618@gmail.com> Link: https://lore.kernel.org/r/20240610092157.9147-3-warthog618@gmail.com Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
90 lines
3.0 KiB
ReStructuredText
90 lines
3.0 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0
|
|
|
|
.. _GPIO_LINEEVENT_DATA_READ:
|
|
|
|
************************
|
|
GPIO_LINEEVENT_DATA_READ
|
|
************************
|
|
|
|
.. warning::
|
|
This ioctl is part of chardev_v1.rst and is obsoleted by
|
|
gpio-v2-line-event-read.rst.
|
|
|
|
Name
|
|
====
|
|
|
|
GPIO_LINEEVENT_DATA_READ - Read edge detection events from a line event.
|
|
|
|
Synopsis
|
|
========
|
|
|
|
``int read(int event_fd, void *buf, size_t count)``
|
|
|
|
Arguments
|
|
=========
|
|
|
|
``event_fd``
|
|
The file descriptor of the GPIO character device, as returned in the
|
|
:c:type:`request.fd<gpioevent_request>` by gpio-get-lineevent-ioctl.rst.
|
|
|
|
``buf``
|
|
The buffer to contain the :c:type:`events<gpioevent_data>`.
|
|
|
|
``count``
|
|
The number of bytes available in ``buf``, which must be at
|
|
least the size of a :c:type:`gpioevent_data`.
|
|
|
|
Description
|
|
===========
|
|
|
|
Read edge detection events for a line from a line event.
|
|
|
|
Edge detection must be enabled for the input line using either
|
|
``GPIOEVENT_REQUEST_RISING_EDGE`` or ``GPIOEVENT_REQUEST_FALLING_EDGE``, or
|
|
both. Edge events are then generated whenever edge interrupts are detected on
|
|
the input line.
|
|
|
|
Edges are defined in terms of changes to the logical line value, so an inactive
|
|
to active transition is a rising edge. If ``GPIOHANDLE_REQUEST_ACTIVE_LOW`` is
|
|
set then logical polarity is the opposite of physical polarity, and
|
|
``GPIOEVENT_REQUEST_RISING_EDGE`` then corresponds to a falling physical edge.
|
|
|
|
The kernel captures and timestamps edge events as close as possible to their
|
|
occurrence and stores them in a buffer from where they can be read by
|
|
userspace at its convenience using `read()`.
|
|
|
|
The source of the clock for :c:type:`event.timestamp<gpioevent_data>` is
|
|
``CLOCK_MONOTONIC``, except for kernels earlier than Linux 5.7 when it was
|
|
``CLOCK_REALTIME``. There is no indication in the :c:type:`gpioevent_data`
|
|
as to which clock source is used, it must be determined from either the kernel
|
|
version or sanity checks on the timestamp itself.
|
|
|
|
Events read from the buffer are always in the same order that they were
|
|
detected by the kernel.
|
|
|
|
The size of the kernel event buffer is fixed at 16 events.
|
|
|
|
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.
|
|
|
|
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``).
|
|
|
|
The `read()` will block if no event is available and the ``event_fd`` has not
|
|
been set **O_NONBLOCK**.
|
|
|
|
The presence of an event can be tested for by checking that the ``event_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_lineevent_data` event.
|
|
|
|
On error -1 and the ``errno`` variable is set appropriately.
|
|
Common error codes are described in error-codes.rst.
|