diff options
Diffstat (limited to 'Documentation/userspace-api/gpio/sysfs.rst')
| -rw-r--r-- | Documentation/userspace-api/gpio/sysfs.rst | 170 | 
1 files changed, 170 insertions, 0 deletions
diff --git a/Documentation/userspace-api/gpio/sysfs.rst b/Documentation/userspace-api/gpio/sysfs.rst new file mode 100644 index 000000000000..116921048b18 --- /dev/null +++ b/Documentation/userspace-api/gpio/sysfs.rst @@ -0,0 +1,170 @@ +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, 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.  |