/**
* @brief Open a chip by path.
* @param path Path to the gpiochip device file.
- * @return GPIO chip object or NULL if an error occurred. The returned object
- * must be closed by the caller using ::gpiod_chip_close.
+ * @return GPIO chip object or NULL if an error occurred. The returned object
+ * must be closed by the caller using ::gpiod_chip_close.
*/
struct gpiod_chip *gpiod_chip_open(const char *path);
/**
* @brief Get the path used to open the chip.
* @param chip GPIO chip object.
- * @return Path to the file passed as argument to ::gpiod_chip_open. The
- * returned pointer is valid for the lifetime of the chip object and
- * must not be freed by the caller.
+ * @return Path to the file passed as argument to ::gpiod_chip_open. The
+ * returned pointer is valid for the lifetime of the chip object and
+ * must not be freed by the caller.
*/
const char *gpiod_chip_get_path(struct gpiod_chip *chip);
* @param chip GPIO chip object.
* @param offset The offset of the GPIO line.
* @return New GPIO line info object or NULL if an error occurred. The returned
- * object must be freed by the caller using ::gpiod_line_info_free.
+ * object must be freed by the caller using ::gpiod_line_info_free.
*/
struct gpiod_line_info *gpiod_chip_get_line_info(struct gpiod_chip *chip,
unsigned int offset);
/**
* @brief Get a snapshot of the status of a line and start watching it for
- * future changes.
+ * future changes.
* @param chip GPIO chip object.
* @param offset The offset of the GPIO line.
* @return New GPIO line info object or NULL if an error occurred. The returned
- * object must be freed by the caller using ::gpiod_line_info_free.
- * @note Line status does not include the line value. To monitor the line
- * value the line must be requested as an input with edge detection set.
+ * object must be freed by the caller using ::gpiod_line_info_free.
+ * @note Line status does not include the line value. To monitor the line
+ * value the line must be requested as an input with edge detection set.
*/
struct gpiod_line_info *gpiod_chip_watch_line_info(struct gpiod_chip *chip,
unsigned int offset);
* @brief Get the file descriptor associated with the chip.
* @param chip GPIO chip object.
* @return File descriptor number for the chip.
- * This function never fails.
- * The returned file descriptor must not be closed by the caller.
- * Call ::gpiod_chip_close to close the file descriptor.
+ *
+ * This function never fails. The returned file descriptor must not be closed
+ * by the caller. Call ::gpiod_chip_close to close the file descriptor by
+ * closing the chip owning it.
*/
int gpiod_chip_get_fd(struct gpiod_chip *chip);
/**
* @brief Wait for line status change events on any of the watched lines
- * on the chip.
+ * on the chip.
* @param chip GPIO chip object.
* @param timeout_ns Wait time limit in nanoseconds. If set to 0, the function
- * returns immediatelly. If set to a negative number, the
- * function blocks indefinitely until an event becomes
- * available.
+ * returns immediatelly. If set to a negative number, the
+ * function blocks indefinitely until an event becomes
+ * available.
* @return 0 if wait timed out, -1 if an error occurred, 1 if an event is
- * pending.
+ * pending.
*/
int gpiod_chip_wait_info_event(struct gpiod_chip *chip, int64_t timeout_ns);
* @brief Read a single line status change event from the chip.
* @param chip GPIO chip object.
* @return Newly read watch event object or NULL on error. The event must be
- * freed by the caller using ::gpiod_info_event_free.
+ * freed by the caller using ::gpiod_info_event_free.
* @note If no events are pending, this function will block.
*/
struct gpiod_info_event *gpiod_chip_read_info_event(struct gpiod_chip *chip);
* @param req_cfg Request config object. Can be NULL for default settings.
* @param line_cfg Line config object.
* @return New line request object or NULL if an error occurred. The request
- * must be released by the caller using ::gpiod_line_request_release.
+ * must be released by the caller using ::gpiod_line_request_release.
*/
struct gpiod_line_request *
gpiod_chip_request_lines(struct gpiod_chip *chip,
* The chip info contains all the publicly available information about a
* chip.
*
- * Some accessor methods return pointers. Those pointers refer to internal
- * fields. The lifetimes of those fields are tied to the lifetime of the
- * containing chip info object.
- * Such pointers remain valid until ::gpiod_chip_info_free is called on the
- * containing chip info object. They must not be freed by the caller.
+ * Some accessor methods return pointers. Those pointers refer to internal
+ * fields. The lifetimes of those fields are tied to the lifetime of the
+ * containing chip info object. Such pointers remain valid until
+ * ::gpiod_chip_info_free is called on the containing chip info object. They
+ * must not be freed by the caller.
*/
/**
* @brief Get the name of the chip as represented in the kernel.
* @param info GPIO chip info object.
* @return Valid pointer to a human-readable string containing the chip name.
- * The string lifetime is tied to the chip info object so the pointer
- * must not be freed by the caller.
+ * The string lifetime is tied to the chip info object so the pointer
+ * must not be freed by the caller.
*/
const char *gpiod_chip_info_get_name(struct gpiod_chip_info *info);
* @brief Get the label of the chip as represented in the kernel.
* @param info GPIO chip info object.
* @return Valid pointer to a human-readable string containing the chip label.
- * The string lifetime is tied to the chip info object so the pointer
- * must not be freed by the caller.
+ * The string lifetime is tied to the chip info object so the pointer
+ * must not be freed by the caller.
*/
const char *gpiod_chip_info_get_label(struct gpiod_chip_info *info);
* Line info object contains an immutable snapshot of a line's status.
*
* The line info contains all the publicly available information about a
- * line, which does not include the line value. The line must be requested
+ * line, which does not include the line value. The line must be requested
* to access the line value.
*
- * Some accessor methods return pointers. Those pointers refer to internal
- * fields. The lifetimes of those fields are tied to the lifetime of the
- * containing line info object.
- * Such pointers remain valid until ::gpiod_line_info_free is called on the
- * containing line info object. They must not be freed by the caller.
+ * Some accessor methods return pointers. Those pointers refer to internal
+ * fields. The lifetimes of those fields are tied to the lifetime of the
+ * containing line info object. Such pointers remain valid until
+ * ::gpiod_line_info_free is called on the containing line info object. They
+ * must not be freed by the caller.
*/
/**
* @brief Copy a line info object.
* @param info Line info to copy.
* @return Copy of the line info or NULL on error. The returned object must
- * be freed by the caller using :gpiod_line_info_free.
+ * be freed by the caller using :gpiod_line_info_free.
*/
struct gpiod_line_info *gpiod_line_info_copy(struct gpiod_line_info *info);
* @param info GPIO line info object.
* @return Offset of the line within the parent chip.
*
- * The offset uniquely identifies the line on the chip.
- * The combination of the chip and offset uniquely identifies the line within
- * the system.
+ * The offset uniquely identifies the line on the chip. The combination of the
+ * chip and offset uniquely identifies the line within the system.
*/
unsigned int gpiod_line_info_get_offset(struct gpiod_line_info *info);
* @brief Get the name of the line.
* @param info GPIO line info object.
* @return Name of the GPIO line as it is represented in the kernel.
- * This function returns a valid pointer to a null-terminated string
- * or NULL if the line is unnamed.
- * The string lifetime is tied to the line info object so the pointer
- * must not be freed.
+ * This function returns a valid pointer to a null-terminated string
+ * or NULL if the line is unnamed. The string lifetime is tied to the
+ * line info object so the pointer must not be freed.
*/
const char *gpiod_line_info_get_name(struct gpiod_line_info *info);
* @brief Get the name of the consumer of the line.
* @param info GPIO line info object.
* @return Name of the GPIO consumer as it is represented in the kernel.
- * This function returns a valid pointer to a null-terminated string
- * or NULL if the consumer name is not set.
- * The string lifetime is tied to the line info object so the pointer
- * must not be freed.
+ * This function returns a valid pointer to a null-terminated string
+ * or NULL if the consumer name is not set.
+ * The string lifetime is tied to the line info object so the pointer
+ * must not be freed.
*/
const char *gpiod_line_info_get_consumer(struct gpiod_line_info *info);
* @brief Get the direction setting of the line.
* @param info GPIO line info object.
* @return Returns ::GPIOD_LINE_DIRECTION_INPUT or
- * ::GPIOD_LINE_DIRECTION_OUTPUT.
+ * ::GPIOD_LINE_DIRECTION_OUTPUT.
*/
enum gpiod_line_direction
gpiod_line_info_get_direction(struct gpiod_line_info *info);
* @brief Get the edge detection setting of the line.
* @param info GPIO line info object.
* @return Returns ::GPIOD_LINE_EDGE_NONE, ::GPIOD_LINE_EDGE_RISING,
- * ::GPIOD_LINE_EDGE_FALLING or ::GPIOD_LINE_EDGE_BOTH.
+ * ::GPIOD_LINE_EDGE_FALLING or ::GPIOD_LINE_EDGE_BOTH.
*/
enum gpiod_line_edge
gpiod_line_info_get_edge_detection(struct gpiod_line_info *info);
* @brief Get the bias setting of the line.
* @param info GPIO line object.
* @return Returns ::GPIOD_LINE_BIAS_PULL_UP, ::GPIOD_LINE_BIAS_PULL_DOWN,
- * ::GPIOD_LINE_BIAS_DISABLED or ::GPIOD_LINE_BIAS_UNKNOWN.
+ * ::GPIOD_LINE_BIAS_DISABLED or ::GPIOD_LINE_BIAS_UNKNOWN.
*/
enum gpiod_line_bias
gpiod_line_info_get_bias(struct gpiod_line_info *info);
* @brief Get the drive setting of the line.
* @param info GPIO line info object.
* @return Returns ::GPIOD_LINE_DRIVE_PUSH_PULL, ::GPIOD_LINE_DRIVE_OPEN_DRAIN
- * or ::GPIOD_LINE_DRIVE_OPEN_SOURCE.
+ * or ::GPIOD_LINE_DRIVE_OPEN_SOURCE.
*/
enum gpiod_line_drive
gpiod_line_info_get_drive(struct gpiod_line_info *info);
/**
* @brief Check if the logical value of the line is inverted compared to the
- * physical.
+ * physical.
* @param info GPIO line object.
* @return True if the line is "active-low", false otherwise.
*/
/**
* @brief Check if the line is debounced (either by hardware or by the kernel
- * software debouncer).
+ * software debouncer).
* @param info GPIO line info object.
* @return True if the line is debounced, false otherwise.
*/
* @brief Get the debounce period of the line, in microseconds.
* @param info GPIO line info object.
* @return Debounce period in microseconds.
- * 0 if the line is not debounced.
+ * 0 if the line is not debounced.
*/
unsigned long
gpiod_line_info_get_debounce_period_us(struct gpiod_line_info *info);
/**
* @brief Get the event clock setting used for edge event timestamps for the
- * line.
+ * line.
* @param info GPIO line info object.
* @return Returns ::GPIOD_LINE_CLOCK_MONOTONIC, ::GPIOD_LINE_CLOCK_HTE or
- * ::GPIOD_LINE_CLOCK_REALTIME.
+ * ::GPIOD_LINE_CLOCK_REALTIME.
*/
enum gpiod_line_clock
gpiod_line_info_get_event_clock(struct gpiod_line_info *info);
* @brief Get the event type of the status change event.
* @param event Line status watch event.
* @return One of ::GPIOD_INFO_EVENT_LINE_REQUESTED,
- * ::GPIOD_INFO_EVENT_LINE_RELEASED or
- * ::GPIOD_INFO_EVENT_LINE_CONFIG_CHANGED.
+ * ::GPIOD_INFO_EVENT_LINE_RELEASED or
+ * ::GPIOD_INFO_EVENT_LINE_CONFIG_CHANGED.
*/
enum gpiod_info_event_type
gpiod_info_event_get_event_type(struct gpiod_info_event *event);
* @brief Get the snapshot of line-info associated with the event.
* @param event Line info event object.
* @return Returns a pointer to the line-info object associated with the event.
- * The object lifetime is tied to the event object, so the pointer must
- * be not be freed by the caller.
+ * The object lifetime is tied to the event object, so the pointer must
+ * be not be freed by the caller.
*/
struct gpiod_line_info *
gpiod_info_event_get_line_info(struct gpiod_info_event *event);
/**
* @brief Create a new line config object.
- * @return New line config object or NULL on error. The returned object must
- * be freed by the caller using ::gpiod_line_config_free.
+ * @return New line config object or NULL on error. The returned object must
+ * be freed by the caller using ::gpiod_line_config_free.
*/
struct gpiod_line_config *gpiod_line_config_new(void);
/**
* @brief Create a new request config object.
- * @return New request config object or NULL on error. The returned object must
- * be freed by the caller using ::gpiod_request_config_free.
+ * @return New request config object or NULL on error. The returned object must
+ * be freed by the caller using ::gpiod_request_config_free.
*/
struct gpiod_request_config *gpiod_request_config_new(void);
* @note The kernel may adjust the value if it's too high. If set to 0, the
* default value will be used.
* @note The kernel buffer is distinct from and independent of the user space
- * buffer (::gpiod_edge_event_buffer_new).
+ * buffer (::gpiod_edge_event_buffer_new).
*/
void
gpiod_request_config_set_event_buffer_size(struct gpiod_request_config *config,
* @param request GPIO line request.
* @param num_values Number of lines for which to read values.
* @param offsets Array of offsets identifying the subset of requested lines
- * from which to read values.
- * @param values Array in which the values will be stored. Must be sized
- * to hold \p num_values entries. Each value is associated with
- * the line identified by the corresponding entry in \p offsets.
+ * from which to read values.
+ * @param values Array in which the values will be stored. Must be sized
+ * to hold \p num_values entries. Each value is associated with
+ * the line identified by the corresponding entry in \p offsets.
* @return 0 on success, -1 on failure.
*/
int gpiod_line_request_get_values_subset(struct gpiod_line_request *request,
* @brief Get the values of all requested lines.
* @param request GPIO line request.
* @param values Array in which the values will be stored. Must be sized to
- * hold the number of lines filled by
- * ::gpiod_line_request_get_num_requested_lines.
- * Each value is associated with the line identified by the
- * corresponding entry in the offset array filled by
- * ::gpiod_line_request_get_requested_offsets.
+ * hold the number of lines filled by
+ * ::gpiod_line_request_get_num_requested_lines.
+ * Each value is associated with the line identified by the
+ * corresponding entry in the offset array filled by
+ * ::gpiod_line_request_get_requested_offsets.
* @return 0 on success, -1 on failure.
*/
int gpiod_line_request_get_values(struct gpiod_line_request *request,
* @param request GPIO line request.
* @param num_values Number of lines for which to set values.
* @param offsets Array of offsets, containing the number of entries specified
- * by \p num_values, identifying the requested lines for
- * which to set values.
+ * by \p num_values, identifying the requested lines for
+ * which to set values.
* @param values Array of values to set, containing the number of entries
- * specified by \p num_values. Each value is associated with the
- * line identified by the corresponding entry in \p offsets.
+ * specified by \p num_values. Each value is associated with the
+ * line identified by the corresponding entry in \p offsets.
* @return 0 on success, -1 on failure.
*/
int gpiod_line_request_set_values_subset(struct gpiod_line_request *request,
* @brief Set the values of all lines associated with a request.
* @param request GPIO line request.
* @param values Array containing the values to set. Must be sized to
- * contain the number of lines filled by
- * ::gpiod_line_request_get_num_requested_lines.
- * Each value is associated with the line identified by the
- * corresponding entry in the offset array filled by
- * ::gpiod_line_request_get_requested_offsets.
+ * contain the number of lines filled by
+ * ::gpiod_line_request_get_num_requested_lines.
+ * Each value is associated with the line identified by the
+ * corresponding entry in the offset array filled by
+ * ::gpiod_line_request_get_requested_offsets.
*/
int gpiod_line_request_set_values(struct gpiod_line_request *request,
const enum gpiod_line_value *values);
* @return 0 on success, -1 on failure.
* @note The new line configuration completely replaces the old.
* @note Any requested lines without overrides are configured to the requested
- * defaults.
+ * defaults.
* @note Any configured overrides for lines that have not been requested
- * are silently ignored.
+ * are silently ignored.
*/
int gpiod_line_request_reconfigure_lines(struct gpiod_line_request *request,
struct gpiod_line_config *config);
* @brief Get the file descriptor associated with a line request.
* @param request GPIO line request.
* @return The file descriptor associated with the request.
- * This function never fails.
- * The returned file descriptor must not be closed by the caller.
- * Call ::gpiod_line_request_release to close the file.
+ * This function never fails.
+ * The returned file descriptor must not be closed by the caller.
+ * Call ::gpiod_line_request_release to close the file.
*/
int gpiod_line_request_get_fd(struct gpiod_line_request *request);
* @brief Wait for edge events on any of the requested lines.
* @param request GPIO line request.
* @param timeout_ns Wait time limit in nanoseconds. If set to 0, the function
- * returns immediatelly. If set to a negative number, the
- * function blocks indefinitely until an event becomes
- * available.
+ * returns immediatelly. If set to a negative number, the
+ * function blocks indefinitely until an event becomes
+ * available.
* @return 0 if wait timed out, -1 if an error occurred, 1 if an event is
- * pending.
+ * pending.
*q
* Lines must have edge detection set for edge events to be emitted.
* By default edge detection is disabled.
* @param buffer Edge event buffer, sized to hold at least \p max_events.
* @param max_events Maximum number of events to read.
* @return On success returns the number of events read from the file
- * descriptor, on failure return -1.
+ * descriptor, on failure return -1.
* @note This function will block if no event was queued for the line request.
- * @note Any exising events in the buffer are overwritten. This is not an
+ * @note Any exising events in the buffer are overwritten. This is not an
* append operation.
*/
int gpiod_line_request_read_edge_events(struct gpiod_line_request *request,
* @brief Copy the edge event object.
* @param event Edge event to copy.
* @return Copy of the edge event or NULL on error. The returned object must
- * be freed by the caller using ::gpiod_edge_event_free.
+ * be freed by the caller using ::gpiod_edge_event_free.
*/
struct gpiod_edge_event *gpiod_edge_event_copy(struct gpiod_edge_event *event);
* @brief Get the event type.
* @param event GPIO edge event.
* @return The event type (::GPIOD_EDGE_EVENT_RISING_EDGE or
- * ::GPIOD_EDGE_EVENT_FALLING_EDGE).
+ * ::GPIOD_EDGE_EVENT_FALLING_EDGE).
*/
enum gpiod_edge_event_type
gpiod_edge_event_get_event_type(struct gpiod_edge_event *event);
* @param event GPIO edge event.
* @return Timestamp in nanoseconds.
* @note The source clock for the timestamp depends on the event_clock
- * setting for the line.
+ * setting for the line.
*/
uint64_t gpiod_edge_event_get_timestamp_ns(struct gpiod_edge_event *event);
* @brief Get the global sequence number of the event.
* @param event GPIO edge event.
* @return Sequence number of the event in the series of events for all lines
- * in the associated line request.
+ * in the associated line request.
*/
unsigned long gpiod_edge_event_get_global_seqno(struct gpiod_edge_event *event);
* @brief Get the event sequence number specific to the line.
* @param event GPIO edge event.
* @return Sequence number of the event in the series of events only for this
- * line within the lifetime of the associated line request.
+ * line within the lifetime of the associated line request.
*/
unsigned long gpiod_edge_event_get_line_seqno(struct gpiod_edge_event *event);
* @param capacity Number of events the buffer can store (min = 1, max = 1024).
* @return New edge event buffer or NULL on error.
* @note If capacity equals 0, it will be set to a default value of 64. If
- * capacity is larger than 1024, it will be limited to 1024.
+ * capacity is larger than 1024, it will be limited to 1024.
* @note The user space buffer is independent of the kernel buffer
- * (::gpiod_request_config_set_event_buffer_size). As the user space
- * buffer is filled from the kernel buffer, there is no benefit making
- * the user space buffer larger than the kernel buffer.
- * The default kernel buffer size for each request is 16*num_lines.
+ * (::gpiod_request_config_set_event_buffer_size). As the user space
+ * buffer is filled from the kernel buffer, there is no benefit making
+ * the user space buffer larger than the kernel buffer.
+ * The default kernel buffer size for each request is (16 * num_lines).
*/
struct gpiod_edge_event_buffer *
gpiod_edge_event_buffer_new(size_t capacity);
/**
* @brief Get the capacity (the max number of events that can be stored) of
- * the event buffer.
+ * the event buffer.
* @param buffer Edge event buffer.
* @return The capacity of the buffer.
*/
* @param buffer Edge event buffer.
* @param index Index of the event in the buffer.
* @return Pointer to an event stored in the buffer. The lifetime of the
- * event is tied to the buffer object. Users must not free the event
- * returned by this function.
+ * event is tied to the buffer object. Users must not free the event
+ * returned by this function.
*/
struct gpiod_edge_event *
gpiod_edge_event_buffer_get_event(struct gpiod_edge_event_buffer *buffer,
* @brief Check if the file pointed to by path is a GPIO chip character device.
* @param path Path to check.
* @return True if the file exists and is either a GPIO chip character device
- * or a symbolic link to one.
+ * or a symbolic link to one.
*/
bool gpiod_is_gpiochip_device(const char *path);
/**
* @brief Get the API version of the library as a human-readable string.
* @return A valid pointer to a human-readable string containing the library
- * version. The pointer is valid for the lifetime of the program and
- * must not be freed by the caller.
+ * version. The pointer is valid for the lifetime of the program and
+ * must not be freed by the caller.
*/
const char *gpiod_api_version(void);