mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Koen Zandberg
47e2885f80
fcntl(fd, F_SETOWN, getpid()); doesn't seem to work on Linux to get generate a signal when an event on the GPIO fd occurs. So fall back to the same method as on OS X and call poll() in a child process.
99 lines
2.5 KiB
C
99 lines
2.5 KiB
C
/*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup cpu_native
|
|
* @{
|
|
*
|
|
* @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
|
|
|
|
#include <stdlib.h>
|
|
#include <poll.h>
|
|
|
|
#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
|
|
*/
|
|
typedef void (*native_async_read_callback_t)(int fd, void *arg);
|
|
|
|
/**
|
|
* @brief Interrupt callback information structure
|
|
*/
|
|
typedef struct {
|
|
pid_t child_pid; /**< PID of the interrupt listener */
|
|
native_async_read_callback_t cb; /**< Interrupt callback funtion */
|
|
void *arg; /**< Argument ptr for the callback */
|
|
struct pollfd *fd; /**< sysfs gpio fd */
|
|
} async_read_t;
|
|
|
|
/**
|
|
* @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
|
|
* @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_handler(int fd, void *arg, native_async_read_callback_t handler);
|
|
|
|
/**
|
|
* @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);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* ASYNC_READ_H */
|
|
/** @} */
|