qemu-gpiodev/libgpiod.git
21 months agobindings: rust: add missing license and copyright boilerplate
Bartosz Golaszewski [Tue, 13 Jun 2023 07:24:42 +0000 (09:24 +0200)]
bindings: rust: add missing license and copyright boilerplate

Make reuse happy again by adding appropriate license and copyright info.

Fixes: 1f8085953086 ("bindings: rust: build against pkg-config info")
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Acked-by: Erik Schilling <erik.schilling@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agotools: tests: remove implicit run-time dependency on ncurses
Kent Gibson [Mon, 12 Jun 2023 02:56:42 +0000 (10:56 +0800)]
tools: tests: remove implicit run-time dependency on ncurses

bats has an implicit depencency on ncurses, as I found when trying to
run the tests on a minimal install that lacked ncurses. Rather than make
the dependency explicit, force the output formatting to use the TAP
format which does not require ncurses.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agotools: tests: speed up continuous toggle test
Kent Gibson [Mon, 12 Jun 2023 02:56:41 +0000 (10:56 +0800)]
tools: tests: speed up continuous toggle test

The continuous toggle test was recently changed to poll the line to
check for toggles, and so increase test reliability. Tighten up the
test timings so the test can now also run in a significantly shorter
time.

And, as it is now faster, add an extra edge just to be sure.

Note that the test does not need to catch every edge, it only has to
check that the line is in fact toggling.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agotools: tests: add tests for idle-timeout and debounce period.
Kent Gibson [Mon, 12 Jun 2023 02:56:40 +0000 (10:56 +0800)]
tools: tests: add tests for idle-timeout and debounce period.

There are no tests for the --debounce-period for gpiomon, or the new
idle-timeout option for gpiomon and gpionotify, so add some.

In both cases the focus of the test is not the period itself, which is
problematic to test reliably, but that the options are supported and
have the otherwise anticipated effects.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agotools: gpiomon/gpionotify: add idle-timeout option
Gabriel Matni [Mon, 12 Jun 2023 01:30:49 +0000 (21:30 -0400)]
tools: gpiomon/gpionotify: add idle-timeout option

Add an idle timeout option to gpiomon and gpionotify to exit gracefully
when no event has been detected for a given period.

Signed-off-by: Gabriel Matni <gabriel.matni@exfo.com>
Reviewed-by: Kent Gibson <warthog618@gmail.com>
Tested-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agobindings: python: examples: gpioset: drop redundant []
Bartosz Golaszewski [Mon, 12 Jun 2023 15:55:29 +0000 (17:55 +0200)]
bindings: python: examples: gpioset: drop redundant []

dict() accepts an iterable, so the [] brackets are redundant.

Suggested-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agobindings: python: examples: fix potential glitch in gpioset.py
Kent Gibson [Fri, 9 Jun 2023 15:36:06 +0000 (23:36 +0800)]
bindings: python: examples: fix potential glitch in gpioset.py

gpioset.py requests lines without setting their output value, and so
sets them all inactive, and subsequently sets them to their requested
value. This can result in glitches on lines which were active and
are set active.

As this is example code, it is also important to demonstrate that the
output value can be set by the request itself.

Request the lines with the correct output values set in the request
itself.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agodoc: add doc for opaque structs to link to the relevant page
Kent Gibson [Fri, 9 Jun 2023 07:39:57 +0000 (15:39 +0800)]
doc: add doc for opaque structs to link to the relevant page

The C doxygen documentation is difficult to navigate as the opaque types
do not get linked to anything.

Add doc for each opaque struct that references the relevant page.

While at it: fix a typo in the line-request group.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agodoc: fix line_config documentation generation
Kent Gibson [Fri, 9 Jun 2023 04:07:37 +0000 (12:07 +0800)]
doc: fix line_config documentation generation

The line configuration is missing from the generated documentation as the
comment for the defgroup is a normal comment, not a doc comment.

Add the asterisk to make the section a doc comment.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agotools: tests: modify delays in toggle test
Joe Slater [Tue, 6 Jun 2023 15:04:27 +0000 (08:04 -0700)]
tools: tests: modify delays in toggle test

The test "gpioset: toggle (continuous)" uses fixed delays to test
toggling values. This is not reliable, so we switch to looking
for transitions from one value to another.

We wait for a transition up to 1.5 seconds.

Signed-off-by: Joe Slater <joe.slater@windriver.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
21 months agobuild: drop a reference to libgpiomockup from a comment in Makefile
Bartosz Golaszewski [Tue, 6 Jun 2023 10:12:39 +0000 (12:12 +0200)]
build: drop a reference to libgpiomockup from a comment in Makefile

We no longer use libgpiomockup. Replace the reference to it with
libgpiosim.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agotools: tests: replace egrep with grep -E
Bartosz Golaszewski [Thu, 1 Jun 2023 13:29:45 +0000 (15:29 +0200)]
tools: tests: replace egrep with grep -E

Since version 3.11 egrep emits the following warning to stderr on startup:

  egrep: warning: egrep is obsolescent; using grep -E

This makes the tests fail (though that seems to depend on BATS version)
so replace egrep with grep -E as suggested.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agodoc: remove a stray letter
Bartosz Golaszewski [Wed, 31 May 2023 15:22:54 +0000 (17:22 +0200)]
doc: remove a stray letter

There's a stray 'q' in the docs, remove it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agodoc: add missing @return entries
Bartosz Golaszewski [Wed, 31 May 2023 15:21:47 +0000 (17:21 +0200)]
doc: add missing @return entries

There are two line-request functions that don't have their return values
documented. Fix it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agobindings: rust: build against pkg-config info
Erik Schilling [Fri, 26 May 2023 15:27:33 +0000 (17:27 +0200)]
bindings: rust: build against pkg-config info

This change replaces building against "bundled" headers by always
building agains system headers (while following standard conventions to
allow users to specify the version to build against).

Reasoning:

Previously, the code generated the bindings based on the headers, but
then links against `-lgpiod` without further specifying where that is
coming from.

This results in some challenges and problems:

1. Packaging a Rust crate with `cargo package` requires the folder
   containing the Cargo.toml to be self-contained. Essentially, a tar
   ball with all the sources of that folder is created. Building against
   that tar ball fails, since the headers files passed to bindgen are
   a relative path pointing outside of that folder.

2. While, for example, the cxx bindings are built AND linked against
   the build results, the packaging situation for C++ libraries is a
   bit different compared to Rust libs. The C++ libs will likely get
   built as part of the larger libgpiod build and published together
   with the C variant.

   In Rust, the vast majority of people will want to build the glue-code
   during the compilation of the applications that consume this lib.

   This may lead to inconsistencies between the bundled headers and the
   libraries shipped by the user's distro. While ABI should hopefully
   be forward-compatible within the same MAJOR number of the .so,
   using too new headers will likely quickly lead to mismatches with
   symbols defined in the lib.

3. Trying to build the core lib as part of the Rust build quickly runs
   into similar packaging issues as the existing solution. The source
   code of the C lib would need to become part of some package
   (often people opt to pull it in as a submodule under their -sys crate
   or even create a separate -src package [1]). This clearly does not
   work well with the current setup...

Since building against system libs is probably? what 90%+ of the people
want, this change hopefully addresses the problems above. The
system-deps dependency honors pkg-config conventions, but also allows
users flexible ways to override the defaults [2]. Overall, this keeps
things simple while still allowing maximum flexibility.

Since the pkg-config interface is just telling us which include paths to
use, we switch back to a wrapper.h file that includes the real gpiod.h.

Once Rust bindings require a lower version floor, the version metadata
can also be updated to help telling users that their system library is
too old.

In order to support people hacking on the Rust bindings, building with
make will automatically set the right set of environment variables.
In case people want to customize it when building without `make`, a
reference to the system_deps documentation is given in the README.md.

[1] https://github.com/alexcrichton/openssl-src-rs
[2] https://docs.rs/system-deps/latest/system_deps/#overriding-build-flags

Signed-off-by: Erik Schilling <erik.schilling@linaro.org>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agorust: bindings: turn SPDX tags into comments
Erik Schilling [Fri, 26 May 2023 15:27:32 +0000 (17:27 +0200)]
rust: bindings: turn SPDX tags into comments

In markdown `# Foo` generates a top-level heading. This leads to to some
weird, huge SPDX tags being rendered before the start of the actual
content.

Lacking good examples, I just took the syntax that `reuse addheader`[1]
outputs.

[1] https://github.com/fsfe/reuse-tool

Signed-off-by: Erik Schilling <erik.schilling@linaro.org>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agobindings: python: specify the symbols to export explicitly
Bartosz Golaszewski [Thu, 25 May 2023 12:02:10 +0000 (14:02 +0200)]
bindings: python: specify the symbols to export explicitly

We're currently unintentionally exporting a bunch of symbols that should
remain local to sub-modules. Use __all__ where appropriate so that we
don't re-export standard library functions such as select() etc. in the
gpiod module.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agobindings: rust: remove unneeded cc dependency
Erik Schilling [Tue, 23 May 2023 11:25:47 +0000 (13:25 +0200)]
bindings: rust: remove unneeded cc dependency

It was never used in upstream. The use was dropped during review [1], but
this dependency did not get removed.

[1] https://lore.kernel.org/r/cover.1659442066.git.viresh.kumar@linaro.org/

Signed-off-by: Erik Schilling <erik.schilling@linaro.org>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agobindings: rust: drop legacy extern crate syntax
Erik Schilling [Wed, 24 May 2023 09:15:42 +0000 (11:15 +0200)]
bindings: rust: drop legacy extern crate syntax

This is a relict from old Rust standards and no longer requires [1].

[1] https://doc.rust-lang.org/edition-guide/rust-2018/path-changes.html#no-more-extern-crate

Signed-off-by: Erik Schilling <erik.schilling@linaro.org>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agobindings: python: change the interpretation of None in event wait
Bartosz Golaszewski [Tue, 23 May 2023 13:29:29 +0000 (15:29 +0200)]
bindings: python: change the interpretation of None in event wait

The docs don't mention it but currently passing None as the timeout to
one of the event wait methods works like passing 0 to select() - the wait
method returns immediately. Change it to a more standard behavior - None
makes the method block indefinitely until an event becomes available for
reading.

This is a slight change in the behavior but let's hope nobody complains
as libgpiod v2 is still pretty recent and its adoption is (hopegully)
not wide-spread yet.

Reported-by: Nicolas Frattaroli <frattaroli.nicolas@gmail.com>
Suggested-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Reviewed-by: Kent Gibson <warthog618@gmail.com>
22 months agobindings: cxx: clarify the meaning of negative timeouts in event wait
Bartosz Golaszewski [Tue, 23 May 2023 13:01:34 +0000 (15:01 +0200)]
bindings: cxx: clarify the meaning of negative timeouts in event wait

chip::wait_info_event() and line_request::wait_edge_events() behave the
same as their C counterparts in that they block indefinitely when passed
a negative timeout value. State it explicitly in the docs.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agoREADME: provide more info in Contributing
Kent Gibson [Tue, 23 May 2023 08:03:34 +0000 (16:03 +0800)]
README: provide more info in Contributing

Add more detail to Contributing to make it easier for new users to
contribute.

Signed-off-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agobindings: fix typo "SPDX-FileCopyrightTest" in copyright headers
Viresh Kumar [Tue, 23 May 2023 07:59:29 +0000 (13:29 +0530)]
bindings: fix typo "SPDX-FileCopyrightTest" in copyright headers

It should be SPDX-FileCopyrightText instead. Fix it.

Reported-by: Erik Schilling <erik.schilling@linaro.org>
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Reviewed-by: Erik Schilling <erik.schilling@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
22 months agobindings: cxx: shrink the doxygen conditional section
Bartosz Golaszewski [Mon, 22 May 2023 08:34:07 +0000 (10:34 +0200)]
bindings: cxx: shrink the doxygen conditional section

The conditional section around the GPIOD_CXX_API symbol should end right
after its definition, not wrap around the sub-headers inclusions.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: rust: skip building all rust crates by default
Viresh Kumar [Thu, 4 May 2023 06:13:44 +0000 (11:43 +0530)]
bindings: rust: skip building all rust crates by default

We don't really need to build all the available rust crates here by
default, but only what's required by the libgpiod crate.

Currently we try to build gpiosim-sys crate as well, even if
"--enable-tests" isn't passed to autogen.sh, which results in following
build failure:

  error: could not find native static library `gpiosim`, perhaps an -L flag is missing?

Fix this by building just the libgpiod crate instead, which can force
building of the other crates based on the enabled configuration options.

Reported-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: move the test case for duplicate configured offsets
Bartosz Golaszewski [Thu, 27 Apr 2023 13:28:18 +0000 (15:28 +0200)]
tests: move the test case for duplicate configured offsets

This test case lives in tests-line-request.c but it doesn't really test
request functionality but rather only the behavior of line-config. Limit
it to only testing struct gpiod_line_config and move it to
tests-line-config.c.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: add MANIFEST.in to EXTRA_DIST
Bartosz Golaszewski [Tue, 25 Apr 2023 16:02:46 +0000 (18:02 +0200)]
bindings: python: add MANIFEST.in to EXTRA_DIST

The manifest is not being bundled with the distribution tarball. Add it
to EXTRA_DIST.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: don't segfault if gpio-sim is unavailable
Bartosz Golaszewski [Thu, 20 Apr 2023 07:32:56 +0000 (09:32 +0200)]
tests: don't segfault if gpio-sim is unavailable

The GLib wrapper for libgpiosim tries to create the gpiosim context and
bank objects in the class's init() function but the constructed()
callback doesn't check if that operation succeeded, leading to a crash
when it dereferences the bank pointer.

As init() should only perform operations that cannot fail, let's move all
the gpiosim initialization code to constructed() and bail-out of it if
any of the steps fails.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: don't install test-specific C extension binaries
Bartosz Golaszewski [Tue, 18 Apr 2023 09:58:57 +0000 (11:58 +0200)]
bindings: python: don't install test-specific C extension binaries

We want to ship the source code for C extensions used by the test suite
but not install the built shared objects or put them into the bdist.
Extend the build_ext command to delete the tests from the build directory
right after the extensions have been built and - possibly - installed
into the source tree (if --inplace is set).

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agoRevert "bindings: python: fix out-of-tree build"
Bartosz Golaszewski [Mon, 17 Apr 2023 14:34:20 +0000 (16:34 +0200)]
Revert "bindings: python: fix out-of-tree build"

This reverts commit addf968c7321132a8c659e06cc06c76534ec31f5.

We're moving towards being compatible with PEP 517 for building and
currently the following error happens when running setup.py build_py:

running build_py
error: Error: setup script specifies an absolute path:

    <snip>/libgpiod/bindings/python/./gpiod/ext/chip.c

setup() arguments must *always* be /-separated paths relative to the
setup.py directory, *never* absolute paths.

As the Makefile build should only be used for development purposes, I
think we can safely drop support for out-of-tree build. Python bindings
have now been spun out into their own tarball and are available to
install from pip.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: exclude test submodules from the package list
Bartosz Golaszewski [Mon, 17 Apr 2023 11:12:54 +0000 (13:12 +0200)]
bindings: python: exclude test submodules from the package list

We already exclude 'tests' but 'tests.*' must be excluded as well if we
don't want to install the gpiosim and procname submodules.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: don't install test executables
Bartosz Golaszewski [Mon, 17 Apr 2023 08:48:48 +0000 (10:48 +0200)]
tests: don't install test executables

I'm not sure what historical reasons there were to install test programs
if they are built but now I can't see any anymore. Tests can be run from
the build directory and users such as meta-openembedded can install them
and the relevant libraries (libgpiosim) manually into the filesystem as
they don't usually live in ${bindir} anyway. Installing test binaries just
pollutes the filesystem now so stop doing it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: update .gitignore
Bartosz Golaszewski [Mon, 17 Apr 2023 08:25:35 +0000 (10:25 +0200)]
bindings: python: update .gitignore

The name of the project has changed so the egg-info directory is no
longer ignored. Update .gitignore but make the entry more general.

Fixes: d5a454cda504 ("bindings: python: change the project name to libgpiod")
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: check the return value of gpiod_line_config_add_line_settings()
Bartosz Golaszewski [Thu, 13 Apr 2023 14:49:58 +0000 (16:49 +0200)]
tests: check the return value of gpiod_line_config_add_line_settings()

The call to gpiod_line_config_add_line_settings() can fail in the thread
function used by info-event test cases so check its return value and act
accordingly.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: bump version to v2.0.1
Bartosz Golaszewski [Thu, 13 Apr 2023 07:49:41 +0000 (09:49 +0200)]
bindings: python: bump version to v2.0.1

Update the version of python bindings to v2.0.1. I treat it as a bug-fix
release as the changes only apply to packaging and building (in
preparation for making the package available on pypi) and there are no
functional changes in the bindings.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: add missing test package files to the manifest
Bartosz Golaszewski [Wed, 12 Apr 2023 20:34:16 +0000 (22:34 +0200)]
bindings: python: add missing test package files to the manifest

__main__.py and __init__.py are omitted with the default source discovery
so add an explicit recursive include for tests in order to package them.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: add a long description to setup.py
Bartosz Golaszewski [Wed, 12 Apr 2023 19:53:57 +0000 (21:53 +0200)]
bindings: python: add a long description to setup.py

Add a long description that will be displayed on the main page once we
make the project available on pypi.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: add test extension sources to the manifest
Bartosz Golaszewski [Wed, 12 Apr 2023 19:52:42 +0000 (21:52 +0200)]
bindings: python: add test extension sources to the manifest

We want to package the .c sources for test-specific extensions so add
them to the manifest.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: exclude tests from the wheel
Bartosz Golaszewski [Wed, 12 Apr 2023 19:51:01 +0000 (21:51 +0200)]
bindings: python: exclude tests from the wheel

We currently "include" the gpiod package in find_packages() which does
nothing as it would be discovered anyway. We want to package the test
sources but exclude it from the binary wheel so use the "exclude"
argument.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: change the project name to libgpiod
Bartosz Golaszewski [Wed, 12 Apr 2023 19:40:56 +0000 (21:40 +0200)]
bindings: python: change the project name to libgpiod

The name 'gpiod' is already taken on pypi. Switch to using 'libgpiod'
as the name of the project. Keep 'gpiod' as the package name which
maintains code compatibility.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agobindings: python: add MANIFEST.in
Bartosz Golaszewski [Wed, 12 Apr 2023 15:19:52 +0000 (17:19 +0200)]
bindings: python: add MANIFEST.in

In order to allow building sdist and wheel packages for python bindings
with python3-build, add a proper MANIFEST.in file.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: fix the test case for gpiod_line_config_get_line_settings()
Bartosz Golaszewski [Wed, 12 Apr 2023 13:10:45 +0000 (15:10 +0200)]
tests: fix the test case for gpiod_line_config_get_line_settings()

We should compare the values stored by the 'retrieved' line settings
object, not the original 'settings'.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: simplify and reduce the strictness of version string regex patterns
Bartosz Golaszewski [Tue, 11 Apr 2023 14:47:20 +0000 (16:47 +0200)]
tests: simplify and reduce the strictness of version string regex patterns

It seems like every release there's some new problem with parsing the
version strings in tests. Let's reduce the strictness of the patterns
to avoid future test failures and accept the following version schemes:

X.Y
X.Y.Z
X.Y-devel
X.Y-rcZ

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: fix version regex treewide
Bartosz Golaszewski [Tue, 11 Apr 2023 11:53:32 +0000 (13:53 +0200)]
tests: fix version regex treewide

The square bracket is in the wrong place which makes the regex not match
version strings of the form: x.y.z. Fix the pattern in core and bindings
tests.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: provide and use gpiod_test_chip_watch_line_info_or_fail()
Bartosz Golaszewski [Fri, 7 Apr 2023 14:32:22 +0000 (16:32 +0200)]
tests: provide and use gpiod_test_chip_watch_line_info_or_fail()

We can shrink the code a bit by wrapping the call to
gpiod_chip_watch_line_info() and the subsequent checks in a helper macro.
This also fixes a potential null-pointer dereference in one of the info
event test cases.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
23 months agotests: fix inconsistent naming of test helpers
Bartosz Golaszewski [Fri, 7 Apr 2023 11:27:52 +0000 (13:27 +0200)]
tests: fix inconsistent naming of test helpers

Some of the helpers' names don't refer to the objects they're acting
upon. Make the naming consistent. While at it: fix line breaking in the
helpers header.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotools: replace alphasort() with versionsort()
Bartosz Golaszewski [Mon, 3 Apr 2023 14:20:09 +0000 (16:20 +0200)]
tools: replace alphasort() with versionsort()

Sorting chip names with alphasort() results in gpiochip2 coming after
gpiochip19 as it only find the lexicographic order of strings. Switching
to using versionsort() makes it look better and the order is more logical
with the numbering being taken into account.

Reviewed-by: Kent Gibson <warthog618@gmail.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotools: tests: update the kernel version required to run tests
Bartosz Golaszewski [Fri, 31 Mar 2023 08:53:46 +0000 (10:53 +0200)]
tools: tests: update the kernel version required to run tests

The v5.16 kernel requirement is a leftover from when the tests were
developed to work with gpio-sim before the module was actually released
in v5.17. Update the kernel requirement to v5.17.4 which includes fixes
to set/get_multiple() callbacks in gpio-sim.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agoman: update the email address shown on man pages
Bartosz Golaszewski [Fri, 31 Mar 2023 08:16:59 +0000 (10:16 +0200)]
man: update the email address shown on man pages

I mainly use brgl@bgdev.pl for my open-source work so update the man
pages accordingly.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobuild: use AM_V_GEN when calling external programs
Bartosz Golaszewski [Mon, 27 Mar 2023 10:09:34 +0000 (12:09 +0200)]
build: use AM_V_GEN when calling external programs

In order to output a status line in silent mode and the whole command in
default mode, use the AM_V_GEN predefined automake variable when executing
external programs like doxygen and help2man.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: tests: fix the test case for chip::unwatch_line_info()
Bartosz Golaszewski [Thu, 16 Mar 2023 10:59:13 +0000 (11:59 +0100)]
bindings: cxx: tests: fix the test case for chip::unwatch_line_info()

We need to actually trigger a line-info event before making sure the watch
has been disabled.

Fixes: f2245fa32c1b ("bindings: cxx: tests: add a test case for chip::unwatch_line_info()")
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: tests: add a test case for chip::unwatch_line_info()
Bartosz Golaszewski [Thu, 16 Mar 2023 09:03:10 +0000 (10:03 +0100)]
bindings: cxx: tests: add a test case for chip::unwatch_line_info()

We don't have any test case for chip::unwatch_line_info() so add a simple
one similar to the one we have for the core C library.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: tests: drop profiling flags from CXXFLAGS and LDFLAGS
Bartosz Golaszewski [Thu, 16 Mar 2023 08:35:34 +0000 (09:35 +0100)]
bindings: cxx: tests: drop profiling flags from CXXFLAGS and LDFLAGS

We only need to generate gcov data for the library, not the test
executable.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: drop the profiling CFLAGS from tests' Makefile
Bartosz Golaszewski [Thu, 16 Mar 2023 08:24:47 +0000 (09:24 +0100)]
tests: drop the profiling CFLAGS from tests' Makefile

We only need the profiling flags on the library, we don't need to
generate gcov data for the test objects.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: fix the test case for gpiod_line_request_reconfigure_lines()
Bartosz Golaszewski [Wed, 15 Mar 2023 21:04:06 +0000 (22:04 +0100)]
tests: fix the test case for gpiod_line_request_reconfigure_lines()

We need to actually pass the line config with different offsets to
gpiod_line_request_reconfigure_lines() for the test to make sense.

Fixes: 8ef0ca0fae8f ("tests: add more test cases for gpiod_line_request_reconfigure_lines()")
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add a test case for gpiod_chip_request_lines()
Bartosz Golaszewski [Wed, 15 Mar 2023 20:53:00 +0000 (21:53 +0100)]
tests: add a test case for gpiod_chip_request_lines()

Add a test case which verifies that gpiod_chip_request_lines() fails
when supplied with a NULL line config.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: extend the test case for gpiod_request_config_set_consumer()
Bartosz Golaszewski [Wed, 15 Mar 2023 20:29:35 +0000 (21:29 +0100)]
tests: extend the test case for gpiod_request_config_set_consumer()

Also check that passing a NULL consumer string works as expected.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add more test cases for gpiod_line_request_reconfigure_lines()
Bartosz Golaszewski [Wed, 15 Mar 2023 20:18:18 +0000 (21:18 +0100)]
tests: add more test cases for gpiod_line_request_reconfigure_lines()

Add two new test cases for gpiod_line_request_reconfigure_lines(). One
verifies that NULL line config is handled correctly, the other checks
that reconfigured offsets must be the same as the ones requested.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: remove commented-out code
Bartosz Golaszewski [Wed, 15 Mar 2023 20:08:33 +0000 (21:08 +0100)]
tests: remove commented-out code

This is a leftover line and can be removed.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add a test case for gpiod_line_config_get_num_configured_offsets()
Bartosz Golaszewski [Wed, 15 Mar 2023 20:04:39 +0000 (21:04 +0100)]
tests: add a test case for gpiod_line_config_get_num_configured_offsets()

There are no tests calling gpiod_line_config_get_num_configured_offsets()
yet so add a simple one for more coverage.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add a test case for incorrect retrieving of edge events from buffer
Bartosz Golaszewski [Wed, 15 Mar 2023 19:54:52 +0000 (20:54 +0100)]
tests: add a test case for incorrect retrieving of edge events from buffer

Add a test case that makes sure we don't crash when trying to access an
out-of-bounds edge event in an edge event buffer.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add a test case for gpiod_line_config_add_line_settings()
Bartosz Golaszewski [Wed, 15 Mar 2023 19:53:23 +0000 (20:53 +0100)]
tests: add a test case for gpiod_line_config_add_line_settings()

Add a more detailed test case for input arguments sanitization for
gpiod_line_config_add_line_settings().

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add more test cases for gpiod_line_config_set_output_values()
Bartosz Golaszewski [Wed, 15 Mar 2023 19:52:53 +0000 (20:52 +0100)]
tests: add more test cases for gpiod_line_config_set_output_values()

Add test cases that check proper sanitization of input arguments of
gpiod_line_config_set_output_values().

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agocore: remove dead code
Bartosz Golaszewski [Wed, 15 Mar 2023 19:50:57 +0000 (20:50 +0100)]
core: remove dead code

gpiod_line_mask_fill() is unused, so remove it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotools: gpiomon: fix setting event clock type
Bartosz Golaszewski [Wed, 15 Mar 2023 08:34:56 +0000 (09:34 +0100)]
tools: gpiomon: fix setting event clock type

Fix an inverted logic bug when parsing event clock type in gpiomon.

Fixes: 8ffb6489286f ("tools: line name focussed rework")
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Reported-by: Wes Tarro <wes.tarro@azuresummit.com>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
2 years agocore: sanitize arguments in gpiod_line_config_set_output_values()
Bartosz Golaszewski [Mon, 13 Mar 2023 15:28:51 +0000 (16:28 +0100)]
core: sanitize arguments in gpiod_line_config_set_output_values()

Add an assert() for the line config structure and check the rest of the
arguments for invalid values.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: rust: examples: add a reimplementation of gpionotify
Bartosz Golaszewski [Fri, 10 Mar 2023 10:16:30 +0000 (11:16 +0100)]
bindings: rust: examples: add a reimplementation of gpionotify

Add a new rust example - a simplified reimplementation of the gpionotify
tool.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
2 years agobindings: python: examples: add gpionotify.py
Bartosz Golaszewski [Fri, 10 Mar 2023 09:59:47 +0000 (10:59 +0100)]
bindings: python: examples: add gpionotify.py

Add a new Python code examples - gpionotify.py - which is a simplified
reimplementation of the gpionotify tool.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: examples: implement gpionotify using C++ bindings
Bartosz Golaszewski [Fri, 10 Mar 2023 09:32:47 +0000 (10:32 +0100)]
bindings: cxx: examples: implement gpionotify using C++ bindings

Add a new C++ code example - gpionotifycxx - which is a simplified
reimplementation of the gpionotify tool.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agocore: make the chip file descriptor blocking
Bartosz Golaszewski [Fri, 10 Mar 2023 09:24:04 +0000 (10:24 +0100)]
core: make the chip file descriptor blocking

After discussing this a while back we removed the call to fcntl() that
would make the request file descriptor non-blocking so that a call to
gpiod_line_request_read_edge_events() would block if no events are
pending. We agreed that the same behavior should apply to info events and
made the docs state that. Unfortunately we still pass the O_NONBLOCK flag
to open() making read() called on the chip file descriptor return
immediately if no info events are pending. Fix it by removing this flag.

Fixes: b7ba732e6a93 ("treewide: libgpiod v2 implementation")
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: examples: gpiomoncxx: drop unused header include
Bartosz Golaszewski [Fri, 10 Mar 2023 09:47:28 +0000 (10:47 +0100)]
bindings: cxx: examples: gpiomoncxx: drop unused header include

We don't need to include <chrono> in the gpiomon C++ example.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: examples: reserve correct amount of space for offsets
Bartosz Golaszewski [Fri, 10 Mar 2023 08:49:41 +0000 (09:49 +0100)]
bindings: cxx: examples: reserve correct amount of space for offsets

In gpiomoncxx we only need to reserve space for (argc - 2) offsets.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agocontrib: add sample Android.bp to build within an Android tree
Benjamin Li [Mon, 6 Mar 2023 18:45:45 +0000 (10:45 -0800)]
contrib: add sample Android.bp to build within an Android tree

Add an Android.bp file for Soong, the Android build system, to build
the library including C++ bindings along with all the CLI tools.

This reference Android build file will live in a contrib/ folder to
indiciate it is a less-maintained part of libgpiod. It will need to
be moved to the root directory in order to use it, though, as Soong
doesn't let Blueprint files reference sources in a parent directory.

  error: external/libgpiod/contrib/Android.bp:5:1: module "libgpiod" variant "...": Path is outside directory: ../include
  error: external/libgpiod/contrib/Android.bp:5:1: module "libgpiod" variant "...": Path is outside directory: ../bindings/cxx
  error: external/libgpiod/contrib/Android.bp:5:1: module "libgpiod" variant "...": Path is outside directory: ../lib/*.c
  error: external/libgpiod/contrib/Android.bp:5:1: module "libgpiod" variant "...": Path is outside directory: ../bindings/cxx/*.cpp

Signed-off-by: Benjamin Li <benl@squareup.com>
[Bartosz: add the build file to the release tarball generated by 'make dist']
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotools: remove dependency on glibc program_invocation_[short_]name
Benjamin Li [Mon, 6 Mar 2023 18:45:44 +0000 (10:45 -0800)]
tools: remove dependency on glibc program_invocation_[short_]name

Platforms like Bionic libc don't have program_invocation_[short_]name,
which is a GNU extension. It does have getprogname(), a BSD extension,
but rather than supporting multiple extensions let's just introduce
our own local helpers.

We derive the short name ourselves rather than calling basename(),
as the POSIX version takes char *, not const char *, and is thus
not guaranteed to avoid modifying its input. (The GNU version does
take const char * but we are avoiding extensions here.)

Signed-off-by: Benjamin Li <benl@squareup.com>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agocore: sanitize the output values in gpiod_line_config_set_output_values()
Bartosz Golaszewski [Fri, 3 Mar 2023 16:23:38 +0000 (17:23 +0100)]
core: sanitize the output values in gpiod_line_config_set_output_values()

We check the output values for invalid ones in
gpiod_line_settings_set_output_value() but in
gpiod_line_config_set_output_values() we just accept all indiscriminately.
Factor out the common checking code into a helper function, use it in both
functions and add a relevant test case.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: make edge_event's impl struct implementations final
Bartosz Golaszewski [Mon, 27 Feb 2023 10:03:50 +0000 (11:03 +0100)]
bindings: cxx: make edge_event's impl struct implementations final

The implementations of the abstract edge_event's base impl private struct
can be made final and their destructors non-virtual. As these types are
entirely private, it does not affect the ABI.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agocore: fix line breaking in the public header
Bartosz Golaszewski [Wed, 1 Mar 2023 09:23:37 +0000 (10:23 +0100)]
core: fix line breaking in the public header

Align the function parameters when breaking lines wherever possible.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add a test-case for looking up non-standard GPIO line names
Bartosz Golaszewski [Mon, 27 Feb 2023 09:33:36 +0000 (10:33 +0100)]
tests: add a test-case for looking up non-standard GPIO line names

Make sure line names with whitespaces or some less common characters (that
can be found in real-life names in mainline .dts files) can be correctly
mapped to offsets.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agolibgpiod: start v2.1 development cycle
Bartosz Golaszewski [Fri, 3 Mar 2023 14:02:54 +0000 (15:02 +0100)]
libgpiod: start v2.1 development cycle

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agolibgpiod v2.0
Bartosz Golaszewski [Thu, 2 Mar 2023 14:09:51 +0000 (15:09 +0100)]
libgpiod v2.0

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: python: tests: fix the version parsing regex
Bartosz Golaszewski [Thu, 2 Mar 2023 14:36:07 +0000 (15:36 +0100)]
bindings: python: tests: fix the version parsing regex

Two-digit versions are not correctly parsed as the last "segment" is not
optional as it should.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: python: remove unneeded setup.py argument
Bartosz Golaszewski [Thu, 2 Mar 2023 14:34:36 +0000 (15:34 +0100)]
bindings: python: remove unneeded setup.py argument

GPIOD_VERSION_STRING environment variable is no longer used by setup.py.
It's been replaced by reading the version from the variable defined in
version.py.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotools: remove unneeded #include
Bartosz Golaszewski [Sat, 25 Feb 2023 14:15:34 +0000 (15:15 +0100)]
tools: remove unneeded #include

We don't use dirname() nor basename() anymore so pulling in libgen.h
is not necessary.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agolibgpiod v2.0-rc3
Bartosz Golaszewski [Thu, 23 Feb 2023 18:49:52 +0000 (19:49 +0100)]
libgpiod v2.0-rc3

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: mark public classes as final
Bartosz Golaszewski [Tue, 21 Feb 2023 13:28:12 +0000 (14:28 +0100)]
bindings: cxx: mark public classes as final

libgpiod C++ types are not meant to be inherited from. They already don't
even provide virtual destructors so mark them explicitly as final. With
that the destructors of throwable types can also be made non-virtual.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: fix a potential assert() abort()
Bartosz Golaszewski [Sun, 19 Feb 2023 20:39:03 +0000 (21:39 +0100)]
tests: fix a potential assert() abort()

If info is NULL in one of the line-info test cases, we'll still try to
read its property leading to an abort() triggered from assert(info). Just
bail out of the test function if gpiod_chip_get_line_info() fails.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: use C++-style compiler attributes
Bartosz Golaszewski [Fri, 17 Feb 2023 13:17:34 +0000 (14:17 +0100)]
bindings: cxx: use C++-style compiler attributes

C++ provides a unified syntax for compiler extensions so use them
instead of redefining our own.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: remove unused define
Bartosz Golaszewski [Fri, 17 Feb 2023 13:15:08 +0000 (14:15 +0100)]
bindings: cxx: remove unused define

Remove GPIOD_CXX_NORETURN as nobody is using it anymore.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agogpiosim: remove unused define
Bartosz Golaszewski [Fri, 17 Feb 2023 13:05:30 +0000 (14:05 +0100)]
gpiosim: remove unused define

ARRAY_SIZE() is defined but unused so remove it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotools: remove unused defines
Bartosz Golaszewski [Fri, 17 Feb 2023 12:54:05 +0000 (13:54 +0100)]
tools: remove unused defines

The UNUSED define is unused (sic!). Drop it. Same for ARRAY_SIZE().

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agolibgpiod v2.0-rc2
Bartosz Golaszewski [Wed, 15 Feb 2023 19:59:16 +0000 (20:59 +0100)]
libgpiod v2.0-rc2

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: python: tests: release the request before removing GPIO sim
Bartosz Golaszewski [Wed, 15 Feb 2023 13:46:16 +0000 (14:46 +0100)]
bindings: python: tests: release the request before removing GPIO sim

One of the test cases doesn't release the request object leading to the
following warning in the kernel log:

REMOVING GPIOCHIP WITH GPIOS STILL REQUESTED

Fix it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: fix the enum type in line-request tests
Bartosz Golaszewski [Wed, 15 Feb 2023 12:46:30 +0000 (13:46 +0100)]
tests: fix the enum type in line-request tests

Use the correct enumeration type for GPIO simulator line values.

Fixes: 67ffa262e393 ("tests: add line value enums for gpiosim GLib wrapper")
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: add line value enums for gpiosim GLib wrapper
Bartosz Golaszewski [Mon, 13 Feb 2023 10:53:42 +0000 (11:53 +0100)]
tests: add line value enums for gpiosim GLib wrapper

libgpiosim has a dedicated enum type for line values but the GLib wrapper
still uses magic numbers (0 and 1). Add an enum type for the wrapper and
use it across all test cases.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agotests: use GLib typedef conventions for line names and hogs
Bartosz Golaszewski [Mon, 13 Feb 2023 10:03:47 +0000 (11:03 +0100)]
tests: use GLib typedef conventions for line names and hogs

The GVariant packaging works in the context of GLib unit testing so use
GLib conventions for declaring data types.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: cxx: drop the re-export guard of visible symbols
Bartosz Golaszewski [Tue, 14 Feb 2023 10:10:56 +0000 (11:10 +0100)]
bindings: cxx: drop the re-export guard of visible symbols

The ifdef guard that changes the definition of GPIOD_CXX_API between
"default" and "hidden" is there to prevent libraries that would include
gpiod.hpp from re-exporting libgpiodcxx symbols.

Unfortunately the hidden linkage only works for translation units within
the same ELF object. At static linking time we must always mark the
throwable types as visible or we'll get the following errors:

/usr/bin/ld: tests-chip.o:(.data+0x0): undefined reference to `typeinfo for gpiod::chip_closed'
/usr/bin/ld: tests-line-request.o:(.data+0x0): undefined reference to `typeinfo for gpiod::request_released'
/usr/bin/ld: .libs/gpiod-cxx-test: hidden symbol `_ZTIN5gpiod11chip_closedE' isn't defined
/usr/bin/ld: final link failed: bad value

On top of that we actually WANT to re-export typeinfo for throwable types
as they can be propagated to external callers when an exception is thrown.

The above error can only be triggered on clang. GCC seems to be
incorrectly omitting the "hidden" attribute in this case.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: rust: update bindgen's version
Viresh Kumar [Tue, 14 Feb 2023 06:45:35 +0000 (12:15 +0530)]
bindings: rust: update bindgen's version

The currently selected version of bindgen has a unmaintained dependency
and generates the following build warning while building vhost-device
crate:

Crate:     ansi_term
Version:   0.12.1
Warning:   unmaintained
Title:     ansi_term is Unmaintained
Date:      2021-08-18
ID:        RUSTSEC-2021-0139
URL:       https://rustsec.org/advisories/RUSTSEC-2021-0139
Dependency tree:
ansi_term 0.12.1
└── clap 2.34.0
    └── bindgen 0.59.2
        └── libgpiod-sys 0.1.0
            └── libgpiod 0.1.0
                └── vhost-device-gpio 0.1.0

error: 1 denied warning found!

Fix it by moving to a later version of bindgen, which updates the types
of few of the arguments to the FFI helpers and so required changes to
few of explicit type conversions.

Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: rust: align formatting to what's suggested by 'cargo fmt'
Viresh Kumar [Tue, 14 Feb 2023 06:45:34 +0000 (12:15 +0530)]
bindings: rust: align formatting to what's suggested by 'cargo fmt'

Align code to follow what 'cargo fmt' suggests.

Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agogpiosim: use twalk() instead of twalk_r()
Bartosz Golaszewski [Fri, 10 Feb 2023 21:11:11 +0000 (22:11 +0100)]
gpiosim: use twalk() instead of twalk_r()

twalk_r() is a GNU extension for the binary search tree API. Musl libc
doesn't provide it and after inquiring with the maintainer it turned out
it won't provide it anytime soon as musl strives to only implement well
standardized functions.

In order to not limit building libgpiosim and tests to glibc only, let's
replace twalk_r() with twalk() and use global variables for the state.
It's not a big deal as we're already using a global root node and a mutex
to protect it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
2 years agobindings: python: don't pass GPIOD_WITH_TESTS to 'setup.py install'
Bartosz Golaszewski [Mon, 13 Feb 2023 17:10:32 +0000 (18:10 +0100)]
bindings: python: don't pass GPIOD_WITH_TESTS to 'setup.py install'

The GPIOD_WITH_TESTS environment variable is not used by setup.py install
command. Drop it.

Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>