2015-12-09 09:29:47 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2015 Takuo Yonezawa <Yonezawa-T2@mail.dnp.co.jp>
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for
|
|
|
|
* more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2018-06-01 12:17:51 +02:00
|
|
|
* @ingroup cpu_native
|
2015-12-09 09:29:47 +01:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Multiple asynchronus read on file descriptors
|
|
|
|
*
|
|
|
|
* @author Takuo Yonezawa <Yonezawa-T2@mail.dnp.co.jp>
|
|
|
|
*/
|
|
|
|
#ifndef ASYNC_READ_H
|
|
|
|
#define ASYNC_READ_H
|
|
|
|
|
2017-08-20 10:49:49 +02:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <poll.h>
|
|
|
|
|
2015-12-09 09:29:47 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Maximum number of file descriptors
|
|
|
|
*/
|
|
|
|
#ifndef ASYNC_READ_NUMOF
|
|
|
|
#define ASYNC_READ_NUMOF 2
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief asynchronus read callback type
|
|
|
|
*/
|
2016-07-07 17:24:55 +02:00
|
|
|
typedef void (*native_async_read_callback_t)(int fd, void *arg);
|
2015-12-09 09:29:47 +01:00
|
|
|
|
2017-08-20 10:49:49 +02:00
|
|
|
/**
|
|
|
|
* @brief Interrupt callback information structure
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
pid_t child_pid; /**< PID of the interrupt listener */
|
2020-10-02 07:57:27 +02:00
|
|
|
native_async_read_callback_t cb; /**< Interrupt callback function */
|
2017-08-20 10:49:49 +02:00
|
|
|
void *arg; /**< Argument ptr for the callback */
|
|
|
|
struct pollfd *fd; /**< sysfs gpio fd */
|
|
|
|
} async_read_t;
|
|
|
|
|
2015-12-09 09:29:47 +01:00
|
|
|
/**
|
|
|
|
* @brief initialize asynchronus read system
|
|
|
|
*
|
|
|
|
* This registers SIGIO signal handler.
|
|
|
|
*/
|
|
|
|
void native_async_read_setup(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief shutdown asynchronus read system
|
|
|
|
*
|
|
|
|
* This deregisters SIGIO signal handler.
|
|
|
|
*/
|
|
|
|
void native_async_read_cleanup(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief resume monitoring of file descriptors
|
|
|
|
*
|
|
|
|
* Call this function after reading file descriptors.
|
|
|
|
*
|
|
|
|
* @param[in] fd The file descriptor to monitor
|
|
|
|
*/
|
|
|
|
void native_async_read_continue(int fd);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief start monitoring of file descriptor
|
|
|
|
*
|
|
|
|
* @param[in] fd The file descriptor to monitor
|
2016-07-07 17:24:55 +02:00
|
|
|
* @param[in] arg Pointer to be passed as arguments to the callback
|
2015-12-09 09:29:47 +01:00
|
|
|
* @param[in] handler The callback function to be called when the file
|
|
|
|
* descriptor is ready to read.
|
|
|
|
*/
|
2016-07-07 17:24:55 +02:00
|
|
|
void native_async_read_add_handler(int fd, void *arg, native_async_read_callback_t handler);
|
2015-12-09 09:29:47 +01:00
|
|
|
|
2017-08-20 14:43:58 +02:00
|
|
|
/**
|
|
|
|
* @brief start monitoring of file descriptor as interrupt
|
|
|
|
*
|
|
|
|
* @param[in] fd The file descriptor to monitor
|
|
|
|
* @param[in] arg Pointer to be passed as arguments to the callback
|
|
|
|
* @param[in] handler The callback function to be called when the file
|
|
|
|
* descriptor is ready to read.
|
|
|
|
*/
|
|
|
|
void native_async_read_add_int_handler(int fd, void *arg, native_async_read_callback_t handler);
|
|
|
|
|
2015-12-09 09:29:47 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2017-05-23 18:19:52 +02:00
|
|
|
#endif /* ASYNC_READ_H */
|
2015-12-09 09:29:47 +01:00
|
|
|
/** @} */
|