|
|
|
@@ -66,6 +66,15 @@ for the GPIO. Values can be:
|
|
|
|
|
* GPIOD_IN to initialize the GPIO as input.
|
|
|
|
|
* GPIOD_OUT_LOW to initialize the GPIO as output with a value of 0.
|
|
|
|
|
* GPIOD_OUT_HIGH to initialize the GPIO as output with a value of 1.
|
|
|
|
|
* GPIOD_OUT_LOW_OPEN_DRAIN same as GPIOD_OUT_LOW but also enforce the line
|
|
|
|
|
to be electrically used with open drain.
|
|
|
|
|
* GPIOD_OUT_HIGH_OPEN_DRAIN same as GPIOD_OUT_HIGH but also enforce the line
|
|
|
|
|
to be electrically used with open drain.
|
|
|
|
|
|
|
|
|
|
The two last flags are used for use cases where open drain is mandatory, such
|
|
|
|
|
as I2C: if the line is not already configured as open drain in the mappings
|
|
|
|
|
(see board.txt), then open drain will be enforced anyway and a warning will be
|
|
|
|
|
printed that the board configuration needs to be updated to match the use case.
|
|
|
|
|
|
|
|
|
|
Both functions return either a valid GPIO descriptor, or an error code checkable
|
|
|
|
|
with IS_ERR() (they will never return a NULL pointer). -ENOENT will be returned
|
|
|
|
@@ -240,13 +249,58 @@ that can't be accessed from hardIRQ handlers, these calls act the same as the
|
|
|
|
|
spinlock-safe calls.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Active-low State and Raw GPIO Values
|
|
|
|
|
------------------------------------
|
|
|
|
|
Device drivers like to manage the logical state of a GPIO, i.e. the value their
|
|
|
|
|
device will actually receive, no matter what lies between it and the GPIO line.
|
|
|
|
|
In some cases, it might make sense to control the actual GPIO line value. The
|
|
|
|
|
following set of calls ignore the active-low property of a GPIO and work on the
|
|
|
|
|
raw line value:
|
|
|
|
|
The active low and open drain semantics
|
|
|
|
|
---------------------------------------
|
|
|
|
|
As a consumer should not have to care about the physical line level, all of the
|
|
|
|
|
gpiod_set_value_xxx() or gpiod_set_array_value_xxx() functions operate with
|
|
|
|
|
the *logical* value. With this they take the active low property into account.
|
|
|
|
|
This means that they check whether the GPIO is configured to be active low,
|
|
|
|
|
and if so, they manipulate the passed value before the physical line level is
|
|
|
|
|
driven.
|
|
|
|
|
|
|
|
|
|
The same is applicable for open drain or open source output lines: those do not
|
|
|
|
|
actively drive their output high (open drain) or low (open source), they just
|
|
|
|
|
switch their output to a high impedance value. The consumer should not need to
|
|
|
|
|
care. (For details read about open drain in driver.txt.)
|
|
|
|
|
|
|
|
|
|
With this, all the gpiod_set_(array)_value_xxx() functions interpret the
|
|
|
|
|
parameter "value" as "asserted" ("1") or "de-asserted" ("0"). The physical line
|
|
|
|
|
level will be driven accordingly.
|
|
|
|
|
|
|
|
|
|
As an example, if the active low property for a dedicated GPIO is set, and the
|
|
|
|
|
gpiod_set_(array)_value_xxx() passes "asserted" ("1"), the physical line level
|
|
|
|
|
will be driven low.
|
|
|
|
|
|
|
|
|
|
To summarize:
|
|
|
|
|
|
|
|
|
|
Function (example) line property physical line
|
|
|
|
|
gpiod_set_raw_value(desc, 0); don't care low
|
|
|
|
|
gpiod_set_raw_value(desc, 1); don't care high
|
|
|
|
|
gpiod_set_value(desc, 0); default (active high) low
|
|
|
|
|
gpiod_set_value(desc, 1); default (active high) high
|
|
|
|
|
gpiod_set_value(desc, 0); active low high
|
|
|
|
|
gpiod_set_value(desc, 1); active low low
|
|
|
|
|
gpiod_set_value(desc, 0); default (active high) low
|
|
|
|
|
gpiod_set_value(desc, 1); default (active high) high
|
|
|
|
|
gpiod_set_value(desc, 0); open drain low
|
|
|
|
|
gpiod_set_value(desc, 1); open drain high impedance
|
|
|
|
|
gpiod_set_value(desc, 0); open source high impedance
|
|
|
|
|
gpiod_set_value(desc, 1); open source high
|
|
|
|
|
|
|
|
|
|
It is possible to override these semantics using the *set_raw/'get_raw functions
|
|
|
|
|
but it should be avoided as much as possible, especially by system-agnostic drivers
|
|
|
|
|
which should not need to care about the actual physical line level and worry about
|
|
|
|
|
the logical value instead.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Accessing raw GPIO values
|
|
|
|
|
-------------------------
|
|
|
|
|
Consumers exist that need to manage the logical state of a GPIO line, i.e. the value
|
|
|
|
|
their device will actually receive, no matter what lies between it and the GPIO
|
|
|
|
|
line.
|
|
|
|
|
|
|
|
|
|
The following set of calls ignore the active-low or open drain property of a GPIO and
|
|
|
|
|
work on the raw line value:
|
|
|
|
|
|
|
|
|
|
int gpiod_get_raw_value(const struct gpio_desc *desc)
|
|
|
|
|
void gpiod_set_raw_value(struct gpio_desc *desc, int value)
|
|
|
|
@@ -254,45 +308,12 @@ raw line value:
|
|
|
|
|
void gpiod_set_raw_value_cansleep(struct gpio_desc *desc, int value)
|
|
|
|
|
int gpiod_direction_output_raw(struct gpio_desc *desc, int value)
|
|
|
|
|
|
|
|
|
|
The active-low state of a GPIO can also be queried using the following call:
|
|
|
|
|
The active low state of a GPIO can also be queried using the following call:
|
|
|
|
|
|
|
|
|
|
int gpiod_is_active_low(const struct gpio_desc *desc)
|
|
|
|
|
|
|
|
|
|
Note that these functions should only be used with great moderation ; a driver
|
|
|
|
|
should not have to care about the physical line level.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The active-low property
|
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
|
|
As a driver should not have to care about the physical line level, all of the
|
|
|
|
|
gpiod_set_value_xxx() or gpiod_set_array_value_xxx() functions operate with
|
|
|
|
|
the *logical* value. With this they take the active-low property into account.
|
|
|
|
|
This means that they check whether the GPIO is configured to be active-low,
|
|
|
|
|
and if so, they manipulate the passed value before the physical line level is
|
|
|
|
|
driven.
|
|
|
|
|
|
|
|
|
|
With this, all the gpiod_set_(array)_value_xxx() functions interpret the
|
|
|
|
|
parameter "value" as "active" ("1") or "inactive" ("0"). The physical line
|
|
|
|
|
level will be driven accordingly.
|
|
|
|
|
|
|
|
|
|
As an example, if the active-low property for a dedicated GPIO is set, and the
|
|
|
|
|
gpiod_set_(array)_value_xxx() passes "active" ("1"), the physical line level
|
|
|
|
|
will be driven low.
|
|
|
|
|
|
|
|
|
|
To summarize:
|
|
|
|
|
|
|
|
|
|
Function (example) active-low property physical line
|
|
|
|
|
gpiod_set_raw_value(desc, 0); don't care low
|
|
|
|
|
gpiod_set_raw_value(desc, 1); don't care high
|
|
|
|
|
gpiod_set_value(desc, 0); default (active-high) low
|
|
|
|
|
gpiod_set_value(desc, 1); default (active-high) high
|
|
|
|
|
gpiod_set_value(desc, 0); active-low high
|
|
|
|
|
gpiod_set_value(desc, 1); active-low low
|
|
|
|
|
|
|
|
|
|
Please note again that the set_raw/get_raw functions should be avoided as much
|
|
|
|
|
as possible, especially by drivers which should not care about the actual
|
|
|
|
|
physical line level and worry about the logical value instead.
|
|
|
|
|
Note that these functions should only be used with great moderation; a driver
|
|
|
|
|
should not have to care about the physical line level or open drain semantics.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Access multiple GPIOs with a single function call
|
|
|
|
|