mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-17 18:36:00 +00:00
7f1e45f4ae
In legacy sysfs GPIO, when using poll(2) on the sysfs GPIO value for state change awaiting, a subsequent read(2) is required for consuming the event, which the doc recommends the use of lseek(2) or close-and-reopen to reset the file offset afterwards. The recommendations however, require at least 2 syscalls to consume the event. Gladly, use of pread(2) require only 1 syscall for the consumption. Let's advertise this usage by prioritizing its placement. Signed-off-by: Huichun Feng <foxhoundsk.tw@gmail.com> Link: https://lore.kernel.org/r/20240609173728.2950808-1-foxhoundsk.tw@gmail.com Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
172 lines
6.5 KiB
ReStructuredText
172 lines
6.5 KiB
ReStructuredText
GPIO Sysfs Interface for Userspace
|
|
==================================
|
|
|
|
.. warning::
|
|
This API is obsoleted by the chardev.rst and the ABI documentation has
|
|
been moved to Documentation/ABI/obsolete/sysfs-gpio.
|
|
|
|
New developments should use the chardev.rst, and existing developments are
|
|
encouraged to migrate as soon as possible, as this API will be removed
|
|
in the future.
|
|
|
|
This interface will continue to be maintained for the migration period,
|
|
but new features will only be added to the new API.
|
|
|
|
The obsolete sysfs ABI
|
|
----------------------
|
|
Platforms which use the "gpiolib" implementors framework may choose to
|
|
configure a sysfs user interface to GPIOs. This is different from the
|
|
debugfs interface, since it provides control over GPIO direction and
|
|
value instead of just showing a gpio state summary. Plus, it could be
|
|
present on production systems without debugging support.
|
|
|
|
Given appropriate hardware documentation for the system, userspace could
|
|
know for example that GPIO #23 controls the write protect line used to
|
|
protect boot loader segments in flash memory. System upgrade procedures
|
|
may need to temporarily remove that protection, first importing a GPIO,
|
|
then changing its output state, then updating the code before re-enabling
|
|
the write protection. In normal use, GPIO #23 would never be touched,
|
|
and the kernel would have no need to know about it.
|
|
|
|
Again depending on appropriate hardware documentation, on some systems
|
|
userspace GPIO can be used to determine system configuration data that
|
|
standard kernels won't know about. And for some tasks, simple userspace
|
|
GPIO drivers could be all that the system really needs.
|
|
|
|
.. note::
|
|
Do NOT abuse sysfs to control hardware that has proper kernel drivers.
|
|
Please read Documentation/driver-api/gpio/drivers-on-gpio.rst
|
|
to avoid reinventing kernel wheels in userspace.
|
|
|
|
I MEAN IT. REALLY.
|
|
|
|
Paths in Sysfs
|
|
--------------
|
|
There are three kinds of entries in /sys/class/gpio:
|
|
|
|
- Control interfaces used to get userspace control over GPIOs;
|
|
|
|
- GPIOs themselves; and
|
|
|
|
- GPIO controllers ("gpio_chip" instances).
|
|
|
|
That's in addition to standard files including the "device" symlink.
|
|
|
|
The control interfaces are write-only:
|
|
|
|
/sys/class/gpio/
|
|
|
|
"export" ...
|
|
Userspace may ask the kernel to export control of
|
|
a GPIO to userspace by writing its number to this file.
|
|
|
|
Example: "echo 19 > export" will create a "gpio19" node
|
|
for GPIO #19, if that's not requested by kernel code.
|
|
|
|
"unexport" ...
|
|
Reverses the effect of exporting to userspace.
|
|
|
|
Example: "echo 19 > unexport" will remove a "gpio19"
|
|
node exported using the "export" file.
|
|
|
|
GPIO signals have paths like /sys/class/gpio/gpio42/ (for GPIO #42)
|
|
and have the following read/write attributes:
|
|
|
|
/sys/class/gpio/gpioN/
|
|
|
|
"direction" ...
|
|
reads as either "in" or "out". This value may
|
|
normally be written. Writing as "out" defaults to
|
|
initializing the value as low. To ensure glitch free
|
|
operation, values "low" and "high" may be written to
|
|
configure the GPIO as an output with that initial value.
|
|
|
|
Note that this attribute *will not exist* if the kernel
|
|
doesn't support changing the direction of a GPIO, or
|
|
it was exported by kernel code that didn't explicitly
|
|
allow userspace to reconfigure this GPIO's direction.
|
|
|
|
"value" ...
|
|
reads as either 0 (inactive) or 1 (active). If the GPIO
|
|
is configured as an output, this value may be written;
|
|
any nonzero value is treated as active.
|
|
|
|
If the pin can be configured as interrupt-generating interrupt
|
|
and if it has been configured to generate interrupts (see the
|
|
description of "edge"), you can poll(2) on that file and
|
|
poll(2) will return whenever the interrupt was triggered. If
|
|
you use poll(2), set the events POLLPRI and POLLERR. If you
|
|
use select(2), set the file descriptor in exceptfds. After
|
|
poll(2) returns, use pread(2) to read the value at offset
|
|
zero. Alternatively, either lseek(2) to the beginning of the
|
|
sysfs file and read the new value or close the file and
|
|
re-open it to read the value.
|
|
|
|
"edge" ...
|
|
reads as either "none", "rising", "falling", or
|
|
"both". Write these strings to select the signal edge(s)
|
|
that will make poll(2) on the "value" file return.
|
|
|
|
This file exists only if the pin can be configured as an
|
|
interrupt generating input pin.
|
|
|
|
"active_low" ...
|
|
reads as either 0 (false) or 1 (true). Write
|
|
any nonzero value to invert the value attribute both
|
|
for reading and writing. Existing and subsequent
|
|
poll(2) support configuration via the edge attribute
|
|
for "rising" and "falling" edges will follow this
|
|
setting.
|
|
|
|
GPIO controllers have paths like /sys/class/gpio/gpiochip42/ (for the
|
|
controller implementing GPIOs starting at #42) and have the following
|
|
read-only attributes:
|
|
|
|
/sys/class/gpio/gpiochipN/
|
|
|
|
"base" ...
|
|
same as N, the first GPIO managed by this chip
|
|
|
|
"label" ...
|
|
provided for diagnostics (not always unique)
|
|
|
|
"ngpio" ...
|
|
how many GPIOs this manages (N to N + ngpio - 1)
|
|
|
|
Board documentation should in most cases cover what GPIOs are used for
|
|
what purposes. However, those numbers are not always stable; GPIOs on
|
|
a daughtercard might be different depending on the base board being used,
|
|
or other cards in the stack. In such cases, you may need to use the
|
|
gpiochip nodes (possibly in conjunction with schematics) to determine
|
|
the correct GPIO number to use for a given signal.
|
|
|
|
|
|
Exporting from Kernel code
|
|
--------------------------
|
|
Kernel code can explicitly manage exports of GPIOs which have already been
|
|
requested using gpio_request()::
|
|
|
|
/* export the GPIO to userspace */
|
|
int gpiod_export(struct gpio_desc *desc, bool direction_may_change);
|
|
|
|
/* reverse gpiod_export() */
|
|
void gpiod_unexport(struct gpio_desc *desc);
|
|
|
|
/* create a sysfs link to an exported GPIO node */
|
|
int gpiod_export_link(struct device *dev, const char *name,
|
|
struct gpio_desc *desc);
|
|
|
|
After a kernel driver requests a GPIO, it may only be made available in
|
|
the sysfs interface by gpiod_export(). The driver can control whether the
|
|
signal direction may change. This helps drivers prevent userspace code
|
|
from accidentally clobbering important system state.
|
|
|
|
This explicit exporting can help with debugging (by making some kinds
|
|
of experiments easier), or can provide an always-there interface that's
|
|
suitable for documenting as part of a board support package.
|
|
|
|
After the GPIO has been exported, gpiod_export_link() allows creating
|
|
symlinks from elsewhere in sysfs to the GPIO sysfs node. Drivers can
|
|
use this to provide the interface under their own device in sysfs with
|
|
a descriptive name.
|