qemu-gpiodev/libgpiod.git
5 years agoREADME: remove the reference to v4.8 kernel headers
Bartosz Golaszewski [Sat, 25 Jan 2020 18:20:51 +0000 (19:20 +0100)]
README: remove the reference to v4.8 kernel headers

The project now depends on v5.5 kernel headers to build. Drop the
reference to v4.8 headers and instead refer readers to the contents
of configure.ac for the exact required version.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobuild: increment the revision in libgpiomockup's ABI version
Bartosz Golaszewski [Wed, 15 Jan 2020 16:33:12 +0000 (17:33 +0100)]
build: increment the revision in libgpiomockup's ABI version

This helper library too has a separate ABI version, but we missed it
when incrementing other ABI numbers for v1.5-rc1. Increment the revision
only as no new interfaces were added or old ones removed.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agolibgpiod v1.5-rc2
Bartosz Golaszewski [Tue, 14 Jan 2020 07:48:13 +0000 (08:48 +0100)]
libgpiod v1.5-rc2

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: tests: package the python test-suite in the dist tarball
Bartosz Golaszewski [Mon, 6 Jan 2020 14:31:10 +0000 (15:31 +0100)]
bindings: python: tests: package the python test-suite in the dist tarball

The test-suite python scripts is added to bin_SCRIPTS in Makefile.am.
This means it's not distributed by default. Add it to dist_bin_SCRIPTS
and make it part of the distribution tarball.

Fixes: 452696601ae5 ("bindings: python: use unittest to implement a proper test-suite")
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agolibgpiod v1.5-rc1
Bartosz Golaszewski [Mon, 6 Jan 2020 14:20:57 +0000 (15:20 +0100)]
libgpiod v1.5-rc1

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agoNEWS: updates for v1.5
Bartosz Golaszewski [Mon, 6 Jan 2020 11:11:01 +0000 (12:11 +0100)]
NEWS: updates for v1.5

Add release notes for libgpiod v1.5.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotools: add a newline between the usage and summary sections of help text
Bartosz Golaszewski [Mon, 6 Jan 2020 10:31:21 +0000 (11:31 +0100)]
tools: add a newline between the usage and summary sections of help text

Improve the readability of help messages in all tools by adding
a newline between the usage and summary sections.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotreewide: split .gitignore into separate files
Bartosz Golaszewski [Fri, 3 Jan 2020 09:03:48 +0000 (10:03 +0100)]
treewide: split .gitignore into separate files

Cleanup the main .gitignore: remove explicit filenames which are already
implicitly ignored with pattern entries and move all the specific
entries into appropriate sub-directories.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: tests: add a test-case for reading multiple line events
Bartosz Golaszewski [Wed, 18 Dec 2019 13:26:33 +0000 (14:26 +0100)]
bindings: python: tests: add a test-case for reading multiple line events

Extend the test coverage of Python bindings with tests of reading of
multiple line events at once.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: add a method for reading multiple line events
Bartosz Golaszewski [Wed, 18 Dec 2019 12:54:46 +0000 (13:54 +0100)]
bindings: python: add a method for reading multiple line events

Add a new method to the Line class allowing to read up to 16 line
events at once.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: tests: add a test-case for reading multiple line events
Bartosz Golaszewski [Wed, 18 Dec 2019 12:32:09 +0000 (13:32 +0100)]
bindings: cxx: tests: add a test-case for reading multiple line events

Extend the test coverage of C++ bindings with tests of reading of
multiple line events at once.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: provide a method for reading multiple line events
Bartosz Golaszewski [Wed, 18 Dec 2019 08:31:35 +0000 (09:31 +0100)]
bindings: cxx: provide a method for reading multiple line events

Add a new method to gpiod::line class allowing to read up to 16 line
events at once.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotests: event: extend test coverage for reading multiple line events at once
Bartosz Golaszewski [Mon, 16 Dec 2019 17:34:38 +0000 (18:34 +0100)]
tests: event: extend test coverage for reading multiple line events at once

Add test cases for new helpers allowing users to read multiple events
at once.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: provide functions for reading multiple line events at once
Bartosz Golaszewski [Mon, 16 Dec 2019 17:34:17 +0000 (18:34 +0100)]
core: provide functions for reading multiple line events at once

The kernel allows us to read multiple (up to 16) line events with
a single read() call, but up to this point libgpiod only supported
reading one event at a time. Add two new functions that allow users
to read more events at the same time.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: use gpiod_line_event_get_fd() in gpiod_line_event_read()
Bartosz Golaszewski [Mon, 16 Dec 2019 13:17:59 +0000 (14:17 +0100)]
core: use gpiod_line_event_get_fd() in gpiod_line_event_read()

We can drop the redundant line state check if we directly call
gpiod_line_event_get_fd() from gpiod_line_event_read(). As opposed
to line_get_fd() it checks if the line was requested for events.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agogitignore: ignore libtool scripts created when cross-compiling
Bartosz Golaszewski [Mon, 16 Dec 2019 17:25:14 +0000 (18:25 +0100)]
gitignore: ignore libtool scripts created when cross-compiling

When '--host' option is passed to configure, the name of the generated
libtool script will be prefixed with the value used as argument for
'--host'. Add a pattern for prefixed 'libtool' scripts to .gitignore.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobuild: drop a redundant check for linux/version.h header
Bartosz Golaszewski [Sat, 14 Dec 2019 21:33:33 +0000 (22:33 +0100)]
build: drop a redundant check for linux/version.h header

We're now checking for linux/version.h on every build - not only when
building tests. Drop the redundant check.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobuild: check linux headers version at build-time
Bartosz Golaszewski [Wed, 11 Dec 2019 15:39:53 +0000 (16:39 +0100)]
build: check linux headers version at build-time

Original libgpiod relied on linux headers v4.8 to build but it was only
documented in README and not enforced at build-time. We now support
features first available in linux v5.5. Add a check to configure.ac that
verifies if recent enough kernel headers are available - otherwise we'd
fail only when trying to build the library.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: fix segfault when calling Line.request()
Joel Savitz [Tue, 3 Dec 2019 19:23:05 +0000 (14:23 -0500)]
bindings: python: fix segfault when calling Line.request()

When Line.request() is called without the required 'consumer=value'
argument, the module attempts access an empty dictionary object
resulting in a segfault. This patch avoids such access when the
dictionary is empty and maintains the current design where the
LineBulk object is responsible for validation of arguments.

Signed-off-by: Joel Savitz <jsavitz@redhat.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: make vals in gpiod_Line_set_value consistent with other functions
Kent Gibson [Sun, 1 Dec 2019 03:24:07 +0000 (11:24 +0800)]
bindings: python: make vals in gpiod_Line_set_value consistent with other functions

Change the vals in gpiod_Line_set_value from a tuple of tuples to just a
tuple. This brings it into line with other vals in the module such as
gpiod_Line_set_config and gpiod_Line_set_direction_output.

The previous usage made the vals equivalent to an args (a tuple of
arguments equivalent to argc,argv in C), as per gpiod_Line_set_flags.

Renaming vals to args in gpiod_Line_set_value was not an option as there
is already an args parameter.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: fix indentation of wrapped field descriptions
Kent Gibson [Sun, 1 Dec 2019 03:24:06 +0000 (11:24 +0800)]
bindings: cxx: fix indentation of wrapped field descriptions

Minor formatting fix to make long text descriptions of params wrap under
the text, not under the param name.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agodoc: document gpiod_line_set_value_bulk NULL values behaviour
Kent Gibson [Sun, 1 Dec 2019 03:24:05 +0000 (11:24 +0800)]
doc: document gpiod_line_set_value_bulk NULL values behaviour

The handling of NULL values by gpiod_line_set_value_bulk has been changed
to interpret NULL as low values for all lines. This patch updates the
documentation of the function to describe that.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotools: add tests for drive flags
Kent Gibson [Sun, 1 Dec 2019 03:24:04 +0000 (11:24 +0800)]
tools: add tests for drive flags

Add tests for drive flags in gpioset.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotools: gpioset: add support for drive flags
Kent Gibson [Sun, 1 Dec 2019 03:24:03 +0000 (11:24 +0800)]
tools: gpioset: add support for drive flags

Add support for drive flags to gpioset so that line drive flags
(open-drain,open-source) can be set from the command line.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotools: add tests for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:24:02 +0000 (11:24 +0800)]
tools: add tests for bias flags

Add tests for bias flags to applicable tools - gpioget, gpioset, and
gpiomon.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotools: add support for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:24:01 +0000 (11:24 +0800)]
tools: add support for bias flags

Add support for bias flags to applicable tools - gpioget, gpioset, and
gpiomon.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: tests: add tests for SET_CONFIG methods
Kent Gibson [Sun, 1 Dec 2019 03:24:00 +0000 (11:24 +0800)]
bindings: python: tests: add tests for SET_CONFIG methods

Extend test coverage over set_config, set_flags, set_direction_input, and
set_direction_output methods.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: add support for SET_CONFIG
Kent Gibson [Sun, 1 Dec 2019 03:23:59 +0000 (11:23 +0800)]
bindings: python: add support for SET_CONFIG

Add methods to support setting line configuration.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: move tuple to int array conversion into helper function
Kent Gibson [Sun, 1 Dec 2019 03:23:58 +0000 (11:23 +0800)]
bindings: python: move tuple to int array conversion into helper function

Restructured gpiod_LineBulk_set_values to move the conversion of values
from Python tuple to int array into a helper function as it is useful for
similar functions.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: tests: add tests for SET_CONFIG methods
Kent Gibson [Sun, 1 Dec 2019 03:23:57 +0000 (11:23 +0800)]
bindings: cxx: tests: add tests for SET_CONFIG methods

Extend test coverage over set_config, set_flags, set_direction_input, and
set_direction_output methods.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: add support for SET_CONFIG
Kent Gibson [Sun, 1 Dec 2019 03:23:56 +0000 (11:23 +0800)]
bindings: cxx: add support for SET_CONFIG

Add methods to support setting line configuration.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotests: add tests for SET_CONFIG
Kent Gibson [Sun, 1 Dec 2019 03:23:55 +0000 (11:23 +0800)]
tests: add tests for SET_CONFIG

Extend test coverage over the SET_CONFIG functions.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: add support for SET_CONFIG
Kent Gibson [Sun, 1 Dec 2019 03:23:54 +0000 (11:23 +0800)]
core: add support for SET_CONFIG

Extend the libgpiod API to support the setting line configuration using the
GPIO GPIOHANDLE_SET_CONFIG_IOCTL uAPI ioctl.

The core change is the addition of gpiod_line_set_config, which provides a
low level wrapper around the ioctl.

Additionally, higher level helper functions, gpiod_line_set_flags,
gpiod_line_set_direction_input, and gpiod_line_set_direction_output provide
slightly simplified APIs for common use cases.

Bulk forms of all functions are also provided.

Documented the fields of gpiod_line to better identify the purpose of
each where the field name alone is not sufficiently clear, and to
indicate which flags are applicable to each field.

Implementation includes a few helper functions that serve to keep the
code tidier and are consistent with similar helper functions already
present.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: tests: add tests for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:23:53 +0000 (11:23 +0800)]
bindings: python: tests: add tests for bias flags

Extend test coverage to cover the bias flags in requests and the bias
setting returned by line.bias().

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: python: add support for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:23:52 +0000 (11:23 +0800)]
bindings: python: add support for bias flags

Add support for bias flags in line requests and returning the line bias
setting via a bias accessor.

Based on initial work by Drew Fustini <drew@pdp7.com>.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: tests: add tests for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:23:51 +0000 (11:23 +0800)]
bindings: cxx: tests: add tests for bias flags

Extend test coverage over the bias flags in requests and the bias setting
returned by line.bias().

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: add support for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:23:50 +0000 (11:23 +0800)]
bindings: cxx: add support for bias flags

Add support for bias flags in line requests and returning the line bias
setting via a bias accessor.

Based on initial work by Drew Fustini <drew@pdp7.com>.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotests: add tests for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:23:49 +0000 (11:23 +0800)]
tests: add tests for bias flags

Extend test coverage over the bias flags, gpiod_line_bias and the extended
ctxless functions.

Also update existing tests to check bias flags where line state is checked.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: add support for bias flags
Kent Gibson [Sun, 1 Dec 2019 03:23:48 +0000 (11:23 +0800)]
core: add support for bias flags

Extend the libgpiod API to support the bias flags recently added to the
kernel GPIO uAPI.  The core change is the addition of
GPIOD_LINE_REQUEST_FLAG_BIAS_DISABLE, GPIOD_LINE_REQUEST_FLAG_BIAS_PULL_UP
and GPIOD_LINE_REQUEST_FLAG_BIAS_PULL_DOWN flags to be passed into
line_request functions, and the addition of gpiod_line_bias to return the
bias state of lines.

Variants of the ctxless functions that accept an active_low flag
are added to also accept other flags. The variant names add a "_ext"
suffix to the name of the original function.

Based on initial work by Drew Fustini <drew@pdp7.com>.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotests: fix a typo in comment
Bartosz Golaszewski [Tue, 26 Nov 2019 10:01:56 +0000 (11:01 +0100)]
tests: fix a typo in comment

s/There/These.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobuild: use AC_CHECK_PROG() instead of AC_CHECK_FILE() for python3-config
Bartosz Golaszewski [Mon, 25 Nov 2019 08:41:08 +0000 (09:41 +0100)]
build: use AC_CHECK_PROG() instead of AC_CHECK_FILE() for python3-config

Commit 9ed02fc793b3 ("build: check for python-config in configure")
breaks cross-compilation because AC_CHECK_FILE() only checks the host
machine. Use AC_CHECK_PROG() instead.

Cc: Joel Savitz <joelsavitz@gmail.com>
Fixes: 9ed02fc793b3 ("build: check for python-config in configure")
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: deprecate gpiod_needs_update()
Bartosz Golaszewski [Fri, 22 Nov 2019 10:35:12 +0000 (11:35 +0100)]
core: deprecate gpiod_needs_update()

This function and the logic behind have been introduced in an early
version of libgpiod for reasons that have been long forgotten.

When updating the line info after a line request fails, just propagate
the error out of the request function instead of setting the internal
needs_update variable. Drop the entire logic behind gpiod_needs_update(),
make this routine always return false and mark it as deprecated in the
header.

Suggested-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agotreewide: change "correspond with" to "correspond to"
Kent Gibson [Mon, 18 Nov 2019 14:46:12 +0000 (15:46 +0100)]
treewide: change "correspond with" to "correspond to"

Trivial grammar fix. "correspond with" can mean either being in agreement
with, happening at the same time, or communication between parties.
"correspond to" is used to mean equivalance, which is the intended use
throughout the documentation.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: allow gpiod_line_set_value_bulk() to accept null values
Kent Gibson [Mon, 18 Nov 2019 14:41:04 +0000 (15:41 +0100)]
core: allow gpiod_line_set_value_bulk() to accept null values

Change gpiod_line_set_value_bulk to interpret a NULL values pointer as an
array of zero, as per gpiod_line_request_bulk, gpiod_line_set_config_bulk,
and gpiod_line_set_direction_bulk_output.

The old behaviour was to segfault.

Add a corresponding test case for gpiod_line_set_value_bulk().

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: initialize bitset with integer instead of string
Kent Gibson [Fri, 15 Nov 2019 14:43:42 +0000 (22:43 +0800)]
bindings: cxx: initialize bitset with integer instead of string

Initializing bitsets with string is inefficient and confusing.
Initialize them with the corresponding int instead.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: drop noexcept from direction() and active_state()
Kent Gibson [Fri, 15 Nov 2019 14:43:41 +0000 (22:43 +0800)]
bindings: cxx: drop noexcept from direction() and active_state()

Both line::direction() and line::active_state() methods can throw and
so should not be declared as noexcept.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agobindings: cxx: tests: fix misspelling of parameter
Bartosz Golaszewski [Mon, 18 Nov 2019 14:26:23 +0000 (15:26 +0100)]
bindings: cxx: tests: fix misspelling of parameter

Trivial misspelling fix: s/paramter/parameter.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: fix misspelling of parameter
Kent Gibson [Fri, 15 Nov 2019 14:43:39 +0000 (22:43 +0800)]
core: fix misspelling of parameter

Trivial fix to bring gpiod_ctxless_event_monitor_multiple() documentation
into line with gpiod_ctxless_event_monitor_multiple_ext().

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
5 years agocore: move request flag to handle flag conversion into a separate function
Kent Gibson [Fri, 15 Nov 2019 14:43:37 +0000 (22:43 +0800)]
core: move request flag to handle flag conversion into a separate function

Move common conversion code from line_request_values and
line_request_event_single() into a separate function to simplify adding
additional flags.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobuild: check for python-config in configure
Joel Savitz [Fri, 4 Oct 2019 16:11:26 +0000 (12:11 -0400)]
build: check for python-config in configure

Currently, configure succeeds when python is installed without its
development components, i.e. python-config and headers. The subsequent
make will fail when gcc cannot locate Python.h.

This patch fixes that behavior by throwing an error at configure-time if
python-config cannot be found.

Signed-off-by: Joel Savitz <joelsavitz@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: directly return the value from PyErr_SetFromErrno()
Bartosz Golaszewski [Thu, 19 Sep 2019 16:51:27 +0000 (18:51 +0200)]
bindings: python: directly return the value from PyErr_SetFromErrno()

PyErr_SetFromErrno() always returns NULL. We can return from functions
on failure directly instead of calling it and then returning NULL in
the next line.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agoREADME: update the testing section
Bartosz Golaszewski [Thu, 19 Sep 2019 16:31:00 +0000 (18:31 +0200)]
README: update the testing section

Add information about the tests included in Python and C++ bindings.
Move the BINDINGS section above TESTING so that the user first knows
that bindings exist before learning they also provide their own
test-suites.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agoTODO: add a task for a re-write of python bindings
Bartosz Golaszewski [Tue, 17 Sep 2019 14:50:31 +0000 (16:50 +0200)]
TODO: add a task for a re-write of python bindings

The python bindings should be improved but without breaking the existing
programs. Add an appropriate task to the TODO list.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: provide Line.update()
Bartosz Golaszewski [Sat, 14 Sep 2019 13:29:48 +0000 (15:29 +0200)]
bindings: python: provide Line.update()

Python bindings are missing the functionality provided by the core C
library's gpiod_line_update(). Extend the Line class with the update()
method that allows to re-read the line information from the kernel.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: provide line::update()
Bartosz Golaszewski [Sat, 14 Sep 2019 13:18:20 +0000 (15:18 +0200)]
bindings: cxx: provide line::update()

The C++ bindings are missing the functionality provided by the core C
library's gpiod_line_update(). Extend the line class with the update()
method that allows to re-read the line information from the kernel.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobuild: tweak formatting of multi-line variables in Makefiles
Bartosz Golaszewski [Fri, 6 Sep 2019 13:51:04 +0000 (15:51 +0200)]
build: tweak formatting of multi-line variables in Makefiles

Don't put a tab between the asignment and the first string - just move
the whole list one line below.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: examples: check if '__main__' is set
Bartosz Golaszewski [Thu, 5 Sep 2019 15:00:24 +0000 (17:00 +0200)]
bindings: python: examples: check if '__main__' is set

The examples are programs meant to be executed directly and not
imported. Use the standard "if __name__ == '__main__':" before
any code.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agoTODO: remove the task for running external processes in gpiomon
Bartosz Golaszewski [Sun, 8 Sep 2019 17:19:54 +0000 (19:19 +0200)]
TODO: remove the task for running external processes in gpiomon

This functionality can be achieved with a shell oneliner, for example:

  gpiomon --line-buffered --format="%o %e" 0 0 | while read line; \
do cut -d" " -f2; done

There's no need to add this to the program. It would make the code
much more complicated without any real benefit.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agocore: rename up_to_date to needs_update in struct gpiod_line
Bartosz Golaszewski [Thu, 5 Sep 2019 12:48:57 +0000 (14:48 +0200)]
core: rename up_to_date to needs_update in struct gpiod_line

This variable is called up_to_date which can lead readers to the wrong
conclusion that libgpiod can somehow know when external actors (such as
a different process or a kernel driver) change the state of a GPIO line.

This is not the case and libgpiod only ever knows if a line needs info
update when a previous internal call to gpiod_line_update() fails.

The kernel does not provide any notification mechanism currently.

For that reason: rename the variable to needs_update.

While at it: clarify the documentation for gpiod_line_needs_update().

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: tests: fix checking the kernel version
Bartosz Golaszewski [Tue, 10 Sep 2019 08:39:12 +0000 (10:39 +0200)]
bindings: python: tests: fix checking the kernel version

Kernel release candidate version strings seem to not be working
correctly with python's version.parse() function. Split the string
retrieved with os.uname().release using '-' as delimiter and pass
only the first part - 'major.minor.release' - to version.parse().

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agocore: fix the major:minor number comparison between the device and sysfs
Bartosz Golaszewski [Tue, 3 Sep 2019 10:00:25 +0000 (12:00 +0200)]
core: fix the major:minor number comparison between the device and sysfs

Current code will incorrectly conclude that a device "1:1" matches
a sysfs device "1:10" as the length it reads from sysfsp is based on
the devstr length, which in this example is 3.

Always read the whole sysfs attribute and compare the string generated
from actual major:minor numbers against it (minus the trailing newline).

Fixes: d9b1c1f14c6b ("core: harden gpiod_chip_open()")
Reported-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotreewide: tests: uncomment previously failing test assertions
Bartosz Golaszewski [Thu, 29 Aug 2019 07:41:37 +0000 (09:41 +0200)]
treewide: tests: uncomment previously failing test assertions

Mainline commit 2c60e6b5c924 ("gpiolib: never report open-drain/source
lines as 'input' to user-space") in the linux kernel has now been
backported to v5.2 stable branch and released in linux v5.2.11. We can
now enable back the assertions that were previously failed in test
suites (core, C++ and python). The required kernel versions must be
updated as well.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: specify G_LOG_DOMAIN
Bartosz Golaszewski [Wed, 21 Aug 2019 07:47:41 +0000 (09:47 +0200)]
tests: specify G_LOG_DOMAIN

We're using GLib for tests so let's specify a log domain for the
test-suit code.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agogitignore: ignore all files with .pc extension
Bartosz Golaszewski [Mon, 19 Aug 2019 13:27:39 +0000 (15:27 +0200)]
gitignore: ignore all files with .pc extension

We now have two .pc generated files and a third one will be added for
the GLib bindings, so ignore all files with this extension.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobuild: move libgpiod.pc.in into lib/
Bartosz Golaszewski [Mon, 19 Aug 2019 09:52:22 +0000 (11:52 +0200)]
build: move libgpiod.pc.in into lib/

This file is specific to the core library. Move it into the lib/ source
directory.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: tests: verify the errno field of OSError exceptions
Bartosz Golaszewski [Wed, 14 Aug 2019 12:24:29 +0000 (14:24 +0200)]
bindings: python: tests: verify the errno field of OSError exceptions

When a call is expected to raise the OSError exception, verify that its
errno field is set to the expected value.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: tests: simplify the event fd polling test case
Bartosz Golaszewski [Mon, 12 Aug 2019 14:44:48 +0000 (16:44 +0200)]
bindings: cxx: tests: simplify the event fd polling test case

The mapping of file descriptors to lines was copied over from the
pre-catch2 set of C++ examples. It's not needed here as we know which
line the event will be generated on.

While at it: use a vector for the pollfd array.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: examples: wait for ENTER press in gpioset.py
Bartosz Golaszewski [Mon, 12 Aug 2019 12:27:32 +0000 (14:27 +0200)]
bindings: python: examples: wait for ENTER press in gpioset.py

After setting the line values in gpioset.py: don't exit until the user
presses ENTER. This makes the example work the same as the 'wait' mode
in the original gpioset utility.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: examples: don't store the return value unnecessarily
Bartosz Golaszewski [Mon, 12 Aug 2019 12:18:54 +0000 (14:18 +0200)]
bindings: python: examples: don't store the return value unnecessarily

In gpioset.py: when calling lines.set_values(), there's no point in
storing the return value as it's always None. It's also not used
anywhere.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: examples: make gpiomon.py output resemble the original
Bartosz Golaszewski [Mon, 12 Aug 2019 12:12:13 +0000 (14:12 +0200)]
bindings: python: examples: make gpiomon.py output resemble the original

Modify the gpiomon.py example to describe the detected events in
a format similar to the one used by the original gpiomon tool.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: use unittest to implement a proper test-suite
Bartosz Golaszewski [Wed, 7 Aug 2019 12:28:30 +0000 (14:28 +0200)]
bindings: python: use unittest to implement a proper test-suite

Currently the only tests we have for python bindings are in a simple
script that makes a lot of assumptions about the environment and
doesn't even work anymore with recent kernels.

Remove it and replace it with a proper test-suite implemented using
libgpiod and the standard python unittest package.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: python: fix the default_val argument name in the doc string
Bartosz Golaszewski [Fri, 9 Aug 2019 09:47:24 +0000 (11:47 +0200)]
bindings: python: fix the default_val argument name in the doc string

The argument in Line.request() is called default_val, not default_vals.
For backward compatibility with older versions default_vals would still
work if it was passed a tuple or list, but let's not confuse users:
default_val is the preferred way for single lines.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: add a workaround for --success run
Alexander Stein [Wed, 7 Aug 2019 19:51:32 +0000 (21:51 +0200)]
bindings: cxx: add a workaround for --success run

If run with --success, all expressions are evaluated and printed out.
But REQUIRE_FALSE(chip) tries to iterate over the chip resulting in this
backtrace:

[...]

Work around this by forcing catch2 to call gpiod::chip::operator bool().

Signed-off-by: Alexander Stein <alexander.stein@mailbox.org>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: vix compile errors
Alexander Stein [Wed, 7 Aug 2019 19:51:31 +0000 (21:51 +0200)]
bindings: cxx: vix compile errors

This fixes the following compile errors:
tests-event.cpp:152:3: error: cannot declare reference to
'class std::system_error&', which is not a typedef or a template type
argument
  152 |   REQUIRE_THROWS_AS(line.event_get_fd(), ::std::system_error&);

This occurs on catch2 but not on catch.

Signed-off-by: Alexander Stein <alexander.stein@mailbox.org>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: split out catch's main()
Alexander Stein [Wed, 7 Aug 2019 19:51:30 +0000 (21:51 +0200)]
bindings: cxx: split out catch's main()

Compiling the source using CATCH_CONFIG_MAIN to provide main() takes
several seconds, so split it out from any library testing code, so it
really needs to be built once only.

Signed-off-by: Alexander Stein <alexander.stein@mailbox.org>
[Bartosz: added the copyright notice for consistency with other files]
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: try using pkg-config to detect catch2
Alexander Stein [Wed, 7 Aug 2019 19:51:29 +0000 (21:51 +0200)]
bindings: cxx: try using pkg-config to detect catch2

If there is no system wide package, try using a regular header as before.

Signed-off-by: Alexander Stein <alexander.stein@mailbox.org>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: use 'upstream' include path
Alexander Stein [Wed, 7 Aug 2019 19:51:28 +0000 (21:51 +0200)]
bindings: cxx: use 'upstream' include path

According to https://github.com/catchorg/Catch2/issues/1202 the
regular include is 'catch2/catch.hpp'. Also CMake and pkg-config
provide include paths for this include name.

Signed-off-by: Alexander Stein <alexander.stein@mailbox.org>
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: tests: extend the test case for global find_line()
Bartosz Golaszewski [Thu, 8 Aug 2019 15:06:44 +0000 (17:06 +0200)]
bindings: cxx: tests: extend the test case for global find_line()

Split the test into sections and also test the case where the line
is not found.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: don't use 'index' as a name for variables
Bartosz Golaszewski [Wed, 7 Aug 2019 17:12:40 +0000 (19:12 +0200)]
tests: don't use 'index' as a name for variables

The standard library provides index() as a function. Don't use it as
a name for variables, arguments, etc.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotools: tests: restore the bats shebang in the bats source file
Bartosz Golaszewski [Wed, 7 Aug 2019 12:18:45 +0000 (14:18 +0200)]
tools: tests: restore the bats shebang in the bats source file

In commit f52e12eafd17 ("tools: tests: run the bats script indirectly
from a shell script") we removed the bats shebang and dropped the
execute permission from the .bats test-suite file.

While the preferred method of running the gpio-tools tests is using
the helper bash script, the .bats file should still be executable on
its own. Restore the execute permissions and the shebang.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: event: add two additional test cases for both edge events
Bartosz Golaszewski [Wed, 7 Aug 2019 12:09:37 +0000 (14:09 +0200)]
tests: event: add two additional test cases for both edge events

Add two test cases explicitly verifying that watching events of both
types works correctly (in active-high and active-low modes).

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: use catch2 to implement a proper test-suite
Bartosz Golaszewski [Tue, 6 Aug 2019 16:05:30 +0000 (18:05 +0200)]
bindings: cxx: use catch2 to implement a proper test-suite

Currently the only tests we have for C++ bindings are in a simple
program that makes a lot of assumptions about the environment and
doesn't even work anymore with recent kernels.

Remove it and replace it with a proper test-suite implemented using
libgpiomockup and Catch2.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: add a missing throw to line::event_get_fd()
Bartosz Golaszewski [Wed, 7 Aug 2019 08:51:41 +0000 (10:51 +0200)]
bindings: cxx: add a missing throw to line::event_get_fd()

If the call to gpiod_line_event_get_fd() fails, we're not actually
throwing the exception - we're only creating it on stack. Add the
missing throw keyword.

Fixes: 8078a4a2ad90 ("bindings: implement C++ bindings")
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: event: fix the active-low switch test case
Bartosz Golaszewski [Wed, 7 Aug 2019 08:16:40 +0000 (10:16 +0200)]
tests: event: fix the active-low switch test case

Kernel commit 223ecaf140b1 ("gpiolib: fix incorrect IRQ requesting of
an active-low lineevent") fixed an issue with line events not being
inverted with the GPIOHANDLE_REQUEST_ACTIVE_LOW flag. This change has
now been released in linux v5.2.7 and the relevant test case must be
adjusted.

Convert the test case to expect a falling edge event. Since the first
pull change will be 0->1, it will be interpreted as such when the
active-low flag is used.

The minimum kernel version to run the core test-suite is now set to
v5.2.7.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: mockup: don't fail at init-time if gpio-mockup is already loaded
Bartosz Golaszewski [Wed, 7 Aug 2019 08:01:50 +0000 (10:01 +0200)]
tests: mockup: don't fail at init-time if gpio-mockup is already loaded

The comment in gpio_mockup_new() says we can deal with gpio-mockup
already being loaded, but it's wrong - we'd actually fail in the call
to kmod_module_probe_insert_module().

Pass the KMOD_PROBE_IGNORE_LOADED flag to the insert function to fix
that.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotools: tests: fix the gpiomon test case with --active-low switch
Bartosz Golaszewski [Wed, 7 Aug 2019 07:46:41 +0000 (09:46 +0200)]
tools: tests: fix the gpiomon test case with --active-low switch

Kernel commit 223ecaf140b1 ("gpiolib: fix incorrect IRQ requesting of
an active-low lineevent") fixed an issue with line events not being
inverted with the GPIOHANDLE_REQUEST_ACTIVE_LOW flag. This change has
now been released in linux v5.2.7 and the relevant test case for
gpiomon needs to be adjusted.

Since the line going down will now be interpreted as a rising edge
event, set the pull to 1 before running gpiomon and then set it to 0
after starting it to trigger a rising edge event.

The minimum kernel version to run tests must be set to v5.2.7.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotools: tests: drop the .sh extension from the testing script's name
Bartosz Golaszewski [Tue, 6 Aug 2019 16:06:26 +0000 (18:06 +0200)]
tools: tests: drop the .sh extension from the testing script's name

This script requires bash, so .sh extension is not accurate. Also: it's
executable, so there's no need to indicate the interpreter in the
extension.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotools: tests: pass command-line arguments to the underlying bats script
Bartosz Golaszewski [Tue, 6 Aug 2019 15:52:56 +0000 (17:52 +0200)]
tools: tests: pass command-line arguments to the underlying bats script

Command-line arguments need to be forwarded to the bats test-suite if
we want to control bats' execution.

Fixes: f52e12eafd17 ("tools: tests: run the bats script indirectly from a shell script")
Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotools: tests: run the bats script indirectly from a shell script
Bartosz Golaszewski [Tue, 6 Aug 2019 15:01:53 +0000 (17:01 +0200)]
tools: tests: run the bats script indirectly from a shell script

Bats makes it very difficult to run some initial code once, perform
checks for requirements and optionally exit if they are not satisfied.

Instead of working around it in the .bats script, just create
a separate shell script that does all the initial checks and then
execs the actual bats test-suite.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: add a test case for using misc line flags together
Bartosz Golaszewski [Tue, 6 Aug 2019 09:52:31 +0000 (11:52 +0200)]
tests: add a test case for using misc line flags together

This adds a test case that verifies that the ACTIVE_LOW flag works
correctly when used together with OPEN_SOURCE and OPEN_DRAIN flags.

Note: a bug has been discovered in the kernel that makes the LINEINFO
ioctl() incorrectly report the direction of lines requested with
open-drain or open-source flags as 'input' if the underlying hardware
doesn't support these config options. A patch fixing it has been sent
and once it's released, the FIXME's added by this patch will be
removed.

While at it: extend the previous misc flags test with additional checks
of the reported direction, but disable the one that fails due to the
bug mentioned above.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotools: tests: remove some development leftovers
Bartosz Golaszewski [Tue, 6 Aug 2019 12:09:18 +0000 (14:09 +0200)]
tools: tests: remove some development leftovers

Remove a leftover debugging command from the testing script that got
accidentally commited.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agobindings: cxx: examples: use seconds for timeout in line.event_wait()
Bartosz Golaszewski [Mon, 5 Aug 2019 19:33:27 +0000 (21:33 +0200)]
bindings: cxx: examples: use seconds for timeout in line.event_wait()

While the event_wait() method takes ::std::chrono::nanoseconds as the
timeout argument, we don't actually need to use the same type - we can
use less fine-grained duration types. Switch to using seconds in the
gpiomoncxx example to showcase this implicit conversion.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: mockup: make sure the gpio-mockup debugfs directory is writable
Bartosz Golaszewski [Sun, 4 Aug 2019 07:48:13 +0000 (09:48 +0200)]
tests: mockup: make sure the gpio-mockup debugfs directory is writable

The gpio-mockup library needs write permissions to make full use of
the debugfs interface. Add the W_OK flag to the call to access() when
preparing the context structure.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: mockup: add a comment explaining the kernel version definition
Bartosz Golaszewski [Sun, 4 Aug 2019 08:07:57 +0000 (10:07 +0200)]
tests: mockup: add a comment explaining the kernel version definition

The library only works on newer kernels. The specific features we're
using have only available since linux v5.1.0. Add a comment explaining
this limitation to the library code.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: free the GList linking test cases once it's no longer needed
Bartosz Golaszewski [Sun, 4 Aug 2019 07:46:40 +0000 (09:46 +0200)]
tests: free the GList linking test cases once it's no longer needed

Once we registered all the test cases, the GList linking them is no
longer used. We can free it before running the test suite.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: mockup: fix a typo in comment
Bartosz Golaszewski [Sun, 4 Aug 2019 07:43:09 +0000 (09:43 +0200)]
tests: mockup: fix a typo in comment

It should have been 'check' not 'chech'.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agoREADME: update the tests section
Bartosz Golaszewski [Sat, 3 Aug 2019 16:28:44 +0000 (18:28 +0200)]
README: update the tests section

The tests underwent significant changes recently. Reflect those in the
README file.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: mockup: validate the chip index where applicable
Bartosz Golaszewski [Sat, 3 Aug 2019 16:14:32 +0000 (18:14 +0200)]
tests: mockup: validate the chip index where applicable

In functions that take the chip index as argument: let's verify that
its value is valid i.e. it refers to an existing chip to avoid potential
segfaults.

While we're at it: delegate the validation of arguments in mockup getter
helpers to a separate routine.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: drop manual test case links and use GList
Bartosz Golaszewski [Fri, 2 Aug 2019 18:40:12 +0000 (20:40 +0200)]
tests: drop manual test case links and use GList

Let's not handcode a linked list if GLib already provides us with
a robust implementation. Use GList to link the tests at registration.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>
6 years agotests: mockup: add extern "C" to the header
Bartosz Golaszewski [Fri, 2 Aug 2019 12:22:29 +0000 (14:22 +0200)]
tests: mockup: add extern "C" to the header

The gpio-mockup support library should be usable from C++ code too.
Add extern "C" to the header.

Signed-off-by: Bartosz Golaszewski <bgolaszewski@baylibre.com>