Bartosz Golaszewski [Fri, 29 Sep 2017 16:27:39 +0000 (18:27 +0200)]
 
core: rework gpiod_line_find()
Use gpiod_chip_find_line() internally for smaller code. Return NULL
if an error occurrs during the lookup. Update the documentation.
While we're at it: update the tests for line lookups.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 16:20:30 +0000 (18:20 +0200)]
 
core: rename gpiod_line_find_by_name()
Shorten the name of the line lookup routine as any other type of
lookup wouldn't make sense anyway.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 15:30:47 +0000 (17:30 +0200)]
 
tests: add parentheses in assert macros
Use parentheses around arguments wherever they can be numerical
values.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 15:25:07 +0000 (17:25 +0200)]
 
tests: chip: add test cases for gpiod_chip_find_line()
Test two use cases: correct lookup and a search for a non-existent
line.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 15:22:16 +0000 (17:22 +0200)]
 
tests: use TEST_ASSERT_ERRNO_IS()
Use the new assert macro wherever we're checking the errno value.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 15:21:15 +0000 (17:21 +0200)]
 
tests: new assertion
Add a helper for checking the current errno value.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 13:24:00 +0000 (15:24 +0200)]
 
core: implement gpiod_chip_find_line()
The low-level line lookup should be more fine-grained. As the first
step: introduce a routine performing a line lookup for specific chip.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 13:47:12 +0000 (15:47 +0200)]
 
gpiomon: fix event counting
We must not increment the events_done variable for events we're not
watching.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 29 Sep 2017 13:31:12 +0000 (15:31 +0200)]
 
gpiomon: correctly handle poll timeouts
We don't check for timeout events in the simple loop event handler.
Fix it and return a correct value.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 28 Sep 2017 07:57:57 +0000 (09:57 +0200)]
 
tests: line: use test_line_close_chip()
Drop the unnecessary chip object.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 28 Sep 2017 07:56:41 +0000 (09:56 +0200)]
 
tests: new cleanup function
Add a new cleanup function which calls gpiod_line_close_chip().
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 28 Sep 2017 07:54:10 +0000 (09:54 +0200)]
 
core: implement gpiod_line_close_chip()
This function works nicely with gpiod_line_find_by_name() which
returns a line object whose owning chip must be later freed by the
caller. With this routine the caller can skip creating a temporary
chip object.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 27 Sep 2017 09:47:09 +0000 (11:47 +0200)]
 
tools: remove the redundant UNUSED define
Use GPIOD_UNUSED instead.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 27 Sep 2017 09:44:09 +0000 (11:44 +0200)]
 
simple-api: improve the naming convention
Discern between the callback arguments and return values by renaming
relevant defines.
Also: prefix all simple API defines with GPIOD_SIMPLE_.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 27 Sep 2017 09:10:38 +0000 (11:10 +0200)]
 
core: new public macro
Export GPIOD_UNUSED in gpiod.h as it may be useful for users not
using all arguments in certain callback functions.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 27 Sep 2017 09:09:37 +0000 (11:09 +0200)]
 
tests: simple-api: new test case
Add a test case for gpiod_simple_event_loop_multiple().
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Tue, 26 Sep 2017 21:58:44 +0000 (23:58 +0200)]
 
gpiomon: use the simple event loop
Switch to using the high-level API. This significantly shrinks the
code while keeping all the functionality.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Mon, 25 Sep 2017 17:13:48 +0000 (19:13 +0200)]
 
simple: rework the event loop
Implement a new routine for monitoring multiple lines with the simple
event loop and extend the simple loop interface with custom polling
capabilities.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Mon, 25 Sep 2017 18:22:03 +0000 (20:22 +0200)]
 
simple: event-loop: fix EINTR handling
We want to handle EINTR as a timeout event. Don't return here.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sun, 24 Sep 2017 20:06:31 +0000 (22:06 +0200)]
 
core: add gpiod_line_bulk_get_line()
Add a getter function for retrieving line handles from bulk objects.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sun, 24 Sep 2017 19:59:45 +0000 (21:59 +0200)]
 
simple: remove redundant line releases
We're closing the chip right after calling the release routines in all
three cases. The chip close function releases all line resources
anyway so no need to do it twice.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sun, 24 Sep 2017 19:11:45 +0000 (21:11 +0200)]
 
simple: fix the active_low switch in gpiod_simple_event_loop()
We're incorrectly passing the boolean active_low argument to
gpiod_line_request_both_edges_events_flags() as flags. Add the same
conversion as in the other simple API routines.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sun, 24 Sep 2017 08:52:55 +0000 (10:52 +0200)]
 
build: fix the kernel version in the 'make check' message
The minimum kernel version for running tests is now 4.12.6. Reflect
that in the message displayed after building the test suite.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sun, 24 Sep 2017 08:48:14 +0000 (10:48 +0200)]
 
core: rename gpiod_line_is_used_by_kernel()
The UAPI flag checked by this routine is called GPIOLINE_FLAG_KERNEL
but its name may be a bit misleading. When set, it can mean that the
line is used by the kernel or by another user space process.
Use a more general name: gpiod_line_is_used().
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 14 Sep 2017 06:06:10 +0000 (08:06 +0200)]
 
README: add info about the subject line for e-mails sent to linux-gpio
For libgpiod-related e-mails the subject line should be prefixed
with [libgpiod].
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 13 Sep 2017 08:52:04 +0000 (10:52 +0200)]
 
README: update the section about contributing
The development will no longer happen on github, but on the linux-gpio
mailing list instead.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 13 Sep 2017 08:30:28 +0000 (10:30 +0200)]
 
build: silence an ar warning
In some configurations ar prints the following warnings:
  ar: `u' modifier ignored since `D' is the default (see `U')
Silence it by setting the ar flags to 'cr' instead of 'cru' which is
the default.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Tue, 12 Sep 2017 16:05:48 +0000 (18:05 +0200)]
 
NEWS: updates for v0.3.1
Add release notes for libgpiod v0.3.1.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Tue, 12 Sep 2017 07:55:56 +0000 (09:55 +0200)]
 
README.md: rename to README
We now host libgpiod at kernel.org, so no need for the .md file.
This also fixes 'make dist' as README.md was not being packaged by
autotools.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sun, 10 Sep 2017 11:24:37 +0000 (13:24 +0200)]
 
tests: gpioset: fix a typo
Fix the spelling of the test case function name.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 12 Aug 2017 19:46:13 +0000 (21:46 +0200)]
 
tests: re-enable a test case for gpiomon
The test case in which we verify if falling-edge events are correctly
ignored was failing due to a bug in the kernel. This has now been
fixed with commit 
df1e76f28ffe ("gpiolib: skip unwanted events, don't
convert them to opposite edge") and released in linux v4.12.6.
Re-enable the test and make this version a hard requirement for
running the test suite.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 28 Jul 2017 11:00:41 +0000 (13:00 +0200)]
 
tools: use program_invocation_name
Remove set_progname() from tools-common and use the global
program_invocation_name variable.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 22 Jul 2017 15:31:47 +0000 (17:31 +0200)]
 
tests: use program_invocation_name
We're using _GNU_SOURCE, so it's ok to use program_invocation_name
instead of storing it manually.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 14 Jul 2017 11:25:40 +0000 (13:25 +0200)]
 
gpiod.h: improve the documentation for gpiod_line_iter_last_offset()
Mention the undefined behavior if gpiod_line_iter_last_offset() is
ever called before gpiod_line_iter_next().
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 14 Jul 2017 10:58:47 +0000 (12:58 +0200)]
 
gpiod.h: extend the introduction to the simple API
Add more info on the simple API functions.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 14 Jul 2017 10:45:51 +0000 (12:45 +0200)]
 
gpiod.h: move the mainpage doxygen comment down
Move it to where the libgpiod declarations begin.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 13 Jul 2017 16:24:54 +0000 (18:24 +0200)]
 
core: readability tweak
Create separate static functions for checking the request type.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 13 Jul 2017 16:09:17 +0000 (18:09 +0200)]
 
core: add the offset argument to the simple event loop callback
In preparation for introducing a multiple lines variant of the simple
event loop routine, add the offset argument to the callback prototype.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 13 Jul 2017 16:07:25 +0000 (18:07 +0200)]
 
core: fix single line event requests with flags
We currently always request rising edge events for the 'flags'
variants. Request correct event types.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 13 Jul 2017 11:53:46 +0000 (13:53 +0200)]
 
core: add bulk event requests
Add functions for requesting events for line bulk objects. Both with
and without additional flags.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 13 Jul 2017 11:29:27 +0000 (13:29 +0200)]
 
core: remove the active_low argument from line bulk requests
We previously removed this argument from routines dealing with single
line requests. Do the same for bulk requests.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 13 Jul 2017 11:15:39 +0000 (13:15 +0200)]
 
core: group the line request code together
Put both the regular input & output requests as well as event requests
together in the same place in core.c.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 13 Jul 2017 10:57:14 +0000 (12:57 +0200)]
 
core: move the chip-related code to the top of core.c
Just as with the public header - move the chip code above the line
definitions.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 18:37:43 +0000 (20:37 +0200)]
 
core: remove the active_low boolean argument from single-line requests
Remove the separate argument for setting the active-state to low in
helper functions doing the single GPIO line requests.
Introduce new variants of these helpers that allow to pass
a combination of all available flags to the request.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 18:17:01 +0000 (20:17 +0200)]
 
core: set the active state using the request flags
Having to always set the active state in the line request config
structure makes users create unnecessary boilerplate code. Remove the
active state field from the config structure and add a new flag, which
when set, sets the active state to low, while high is the default.
This patch updates the main request function and all the callers - we
still need to update all the helper request routines.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 18:09:45 +0000 (20:09 +0200)]
 
line: add a test case for empty consumer strings
Check that both libgpiod and the kernel behave correctly when passed
an empty string as the consumer name.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 17:46:50 +0000 (19:46 +0200)]
 
core: accept NULL consumer strings
If the user passes a NULL pointer as the consumer name to any of the
line request functions, pass an empty string to the kernel instead of
segfaulting. The kernel code will then set the consumer string to "?".
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 17:18:24 +0000 (19:18 +0200)]
 
gpiod.h: remove the separate doxygen group for events
Much of the event functionality has been merged with regular GPIO line
definitions. We no longer need a separate group for events in the
documentation.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 17:15:40 +0000 (19:15 +0200)]
 
gpiod.h: move the chip operations before line definitions
Chip operations should come earlier in the public header.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 15:47:07 +0000 (17:47 +0200)]
 
core: merge chip.c and line.c
Splitting the line and chip functionality led to unnecessary bloat.
Just put the code together into a single file.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 12 Jul 2017 15:22:09 +0000 (17:22 +0200)]
 
libgpiod: unify the header comments
Make the header comment look the same in every file. Move additional
descriptions of files' contents below the header.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Mon, 10 Jul 2017 08:15:05 +0000 (10:15 +0200)]
 
event: rename event requests routines
The event request functionality is now merged with the regular
requests. Change the naming pattern for event requests and move the
prototypes under the input and output requests.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 1 Jul 2017 17:50:11 +0000 (19:50 +0200)]
 
core: merge event requests with regular line requests
Requesting the lines both for reading/setting values as well as for
watching events will now be done using the gpiod_line_request_*()
family of functions.
This is the first part of changes required to fully convert the API.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 1 Jul 2017 12:11:40 +0000 (14:11 +0200)]
 
chip: lazily allocate lines
Only allocate the array of line pointers is they're actually needed.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 1 Jul 2017 11:54:33 +0000 (13:54 +0200)]
 
core: don't duplicate chip-related data structures
Introduce an internal structure - line_chip_ctx - used to store the
chip-related information. This structure is shared among all line
objects exposed by a single chip.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 1 Jul 2017 09:14:52 +0000 (11:14 +0200)]
 
simple-api: reposition the prototypes in the public header
Move the 'multiple' variants below the single value ones.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 1 Jul 2017 09:07:13 +0000 (11:07 +0200)]
 
tests: line: new test case
Verify that a consumer string over 31 characters long is correctly
cropped.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 1 Jul 2017 08:56:06 +0000 (10:56 +0200)]
 
line: remove an unnecessary check
We have changed the way line objects are allocated. This check is no
longer needed.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 30 Jun 2017 14:28:30 +0000 (16:28 +0200)]
 
chip: use a temporary variable in gpiod_chip_close()
The code looks better if we use a temporary pointer to gpiod_line.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 30 Jun 2017 10:55:36 +0000 (12:55 +0200)]
 
core: separate the chip and line logic
Lazily allocate memory for line objects in chip.c. This eliminates the
need for chip routines to know the size of a line object.
Line objects now contain the chip file descriptor as well, so that we
don't need to access the chip object in any way from line.c.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 29 Jun 2017 15:10:57 +0000 (17:10 +0200)]
 
chip: release lines in bulk on close()
When closing the chip use a bulk operation to release all lines.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 29 Jun 2017 15:05:27 +0000 (17:05 +0200)]
 
line: remove stray semicolons
These got introduced accidentally when adding chip_get_fd().
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 29 Jun 2017 13:36:01 +0000 (15:36 +0200)]
 
chip: rename is_unsigned_int()
Use a shorter name for this simple routine.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 29 Jun 2017 13:27:27 +0000 (15:27 +0200)]
 
line: coding style fix
Correctly align a broken line.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 29 Jun 2017 13:23:55 +0000 (15:23 +0200)]
 
core: tweak some comments
Minor changes to the file header comments in the core library.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 29 Jun 2017 13:12:22 +0000 (15:12 +0200)]
 
core: move all line-related code to line.c and remove core.c
This is the final stage of splitting the core library code into
separate files.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 28 Jun 2017 15:33:51 +0000 (17:33 +0200)]
 
core: move chip definitions to a separate file
Move all chip-related code to chip.c and create temporary glue-code
header for chip.c and core.c.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 28 Jun 2017 14:39:36 +0000 (16:39 +0200)]
 
core: kill gpiod_line_event_release()
We can (and already do in gpiod_chip_close()) easily figure out if
a GPIO line was configured for events or values, so there's no need
to have a separate release function for events.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 28 Jun 2017 14:15:04 +0000 (16:15 +0200)]
 
core: move gpiod_version_string() to misc.c
Create a separate .c file for misc definitions.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 11:05:34 +0000 (13:05 +0200)]
 
core: move iterator definitions to a separate file
Move all iterator-related code to iter.c.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 10:54:20 +0000 (12:54 +0200)]
 
simple API: un-inline simple API routines
Try to avoid inline functions in the public header wherever possible.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 10:48:54 +0000 (12:48 +0200)]
 
core: move the simple API definitions into a separate file
This is the first step in splitting up the core library code.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 10:43:00 +0000 (12:43 +0200)]
 
core: kill nsec_to_timespec()
This function is tiny and only used in one place.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 10:37:50 +0000 (12:37 +0200)]
 
core: kill zalloc() and use calloc() where applicable
Remove zalloc() and use malloc() + memset() in the code. When
allocating an array of elements, use calloc(). This is done in
preparation for splitting up the core library code into separate
files.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 10:32:01 +0000 (12:32 +0200)]
 
core: kill gpio_ioctl()
We used this wrapper around ioctl() to set the libgpiod-specific error
number if the ioctl() call failed.
We no longer use custom error numbers, so remove this function.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 10:21:57 +0000 (12:21 +0200)]
 
core: kill custom error handling
The libgpiod-specific error codes are not really necessary and can be
easily replaced with regular libc error numbers defined in errno.h.
Remove all routines and definitions dealing with error numbers and
switch to using errnos in the library code.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 6 Jul 2017 08:41:15 +0000 (10:41 +0200)]
 
tests: fix checking the kernel version
Previous check was incorrect and would break at major version change.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Sat, 24 Jun 2017 09:41:19 +0000 (11:41 +0200)]
 
libgpiod: start 1.0 development cycle
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 23 Jun 2017 14:56:09 +0000 (16:56 +0200)]
 
libgpiod v0.3
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 23 Jun 2017 14:52:07 +0000 (16:52 +0200)]
 
NEWS: updates for v0.3
Add release notes for libgpiod v0.3.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 23 Jun 2017 14:42:07 +0000 (16:42 +0200)]
 
tests: gpiomon: new test case
Verify that gpiomon bails out if the same line offset is given more
than once.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 23 Jun 2017 14:38:56 +0000 (16:38 +0200)]
 
tests: gpiomon: new test case for watching multiple lines
Make sure gpiomon behaves correctly when the requested line offsets
are not in order.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 23 Jun 2017 09:25:13 +0000 (11:25 +0200)]
 
gpiomon: implement monitoring multiple lines at the same time
Switch from the simple API to low-level libgpiod routines and
implement watching multiple lines at the same time.
Update tests and README.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 23 Jun 2017 10:37:21 +0000 (12:37 +0200)]
 
core: event: use correct flags when requesting events
We must use the GPIOEVENT_REQUEST_* flags, not GPIOEVENT_EVENT_* since
the latter are only meaningful when receiving event info.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Fri, 23 Jun 2017 09:04:18 +0000 (11:04 +0200)]
 
gpioset: improve error messages
Say more than just the name of the failed function.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 22 Jun 2017 19:16:40 +0000 (21:16 +0200)]
 
README: improve readability of examples
We're using the same character for comments and the command prompt.
That's not very readable. Use '$' as prompt.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 22 Jun 2017 19:11:18 +0000 (21:11 +0200)]
 
README: add an example of gpiomon custom output formats
In the examples section: show how to specify a custom, easily parsable
output in gpiomon.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 22 Jun 2017 18:56:36 +0000 (20:56 +0200)]
 
tests: gpiomon: new test case
Verify that we actually ignore events we're not watching.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 22 Jun 2017 18:42:11 +0000 (20:42 +0200)]
 
README: update the building section
Commit 
6876721f7407 ("build: use a more standard autogen.sh") made
the supplied autogen execute ./configure unless the NOCONFIGURE
environment variable is set. Reflect that in the README file.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 21 Jun 2017 11:47:30 +0000 (13:47 +0200)]
 
gpiomon: simplify custom formats
Instead of replacing the format specifiers in a separate buffer, just
make use of the output stream buffering.
Also: update the gpiomon tests with some corner cases.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 21 Jun 2017 09:46:42 +0000 (11:46 +0200)]
 
tests: don't allocate the subprocess output buffer everytime
It's more efficient to just allocate it at testing suite's startup and
reuse it for all child processes.
While we're at it: verify that the output of subprocesses consists
of ASCII characters only.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 21 Jun 2017 08:21:44 +0000 (10:21 +0200)]
 
tests: gpiomon: use a different unknown custom format specifier
We previously used a character that is not interpreted by
printf()-like functions due to a bug in the testing framework.
This is now fixed, so just use %x so that we self-test the test suite
at the same time.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Wed, 21 Jun 2017 08:16:36 +0000 (10:16 +0200)]
 
tests: fix reading the output of subprocesses
We're currently using vasprintf() internally when reading the output
streams of terminated subprocesses. This routine interprets the buffer
as a printf() format string, so substrings like '%x' get converted
unintentionally.
Instead allocate a big enough buffer and just read the output without
any modifications.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Tue, 20 Jun 2017 18:03:33 +0000 (20:03 +0200)]
 
gpiomon: fix parsing of custom output formats
The '%%e' string should be printed as '%e' - the same as for printf()
format specifiers - but gpiomon prints '%%e' in this case. Fix it.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Tue, 20 Jun 2017 13:00:03 +0000 (15:00 +0200)]
 
configure: tests: require versions of libkmod & libudev known to work
When building tests: require libkmod and libudev versions to be at
least 18 & 215 respectively. These versions are shipped with debian
jessie and are known to work.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Tue, 20 Jun 2017 08:36:16 +0000 (10:36 +0200)]
 
configure: check for regex functions when building tests
Check if regexec() is available if we need to build the test suite.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Mon, 19 Jun 2017 19:26:29 +0000 (21:26 +0200)]
 
tests: add a FIXME comment
Reading output from child processes should be fixed at some point to
ignore printf() format specifiers.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 15 Jun 2017 07:23:13 +0000 (09:23 +0200)]
 
gpiomon: implement custom output formats
Add a new argument allowing the user to specify the format of the
output string printed on GPIO line events.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 15 Jun 2017 06:31:49 +0000 (08:31 +0200)]
 
tests: fix subprocess cleanup when dying
We need to kill the tool subprocess when bailing out during tests
everytime, not only when an error during test_tool_wait() occurs.
Also: we need to wait() for killed processes too as otherwise we may
end up calling delete_module() before the process actually stops using
gpio-mockup giving us a nasty error message from libkmod and leaving
the module in memory.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>
Bartosz Golaszewski [Thu, 15 Jun 2017 05:52:42 +0000 (07:52 +0200)]
 
tests: fix the error message when dying during test's execution
If die() or die_perr() is called during a test case, print an
additional newline character so that the error message is displayed
below the test description.
Signed-off-by: Bartosz Golaszewski <bartekgola@gmail.com>