/* * Copyright (C) 2016 Kaspar Schleiser * * 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. */ /** * @defgroup isr_pipe ISR Pipe * @ingroup sys * @brief ISR -> userspace pipe * * @{ * @file * @brief isrpipe Interface * * @author Kaspar Schleiser * */ #ifndef ISRPIPE_H #define ISRPIPE_H #include #include "mutex.h" #include "tsrb.h" #ifdef __cplusplus extern "C" { #endif /** * @brief Context structure for isrpipe */ typedef struct { tsrb_t tsrb; /**< isrpipe thread safe ringbuffer */ mutex_t mutex; /**< isrpipe mutex */ } isrpipe_t; /** * @brief Static initializer for irspipe */ #define ISRPIPE_INIT(tsrb_buf) { .mutex = MUTEX_INIT, .tsrb = TSRB_INIT(tsrb_buf) } /** * @brief Initialisation function for isrpipe * * @param[in] isrpipe isrpipe object to initialize * @param[in] buf buffer to use as ringbuffer (must be power of two sized!) * @param[in] bufsize size of @p buf */ void isrpipe_init(isrpipe_t *isrpipe, char *buf, size_t bufsize); /** * @brief Put one character into the isrpipe's buffer * * @param[in] isrpipe isrpipe object to initialize * @param[in] c character to add to isrpipe buffer * * @returns 0 if character could be added * @returns -1 if buffer was full */ int isrpipe_write_one(isrpipe_t *isrpipe, char c); /** * @brief Read data from isrpipe (blocking) * * @param[in] isrpipe isrpipe object to operate on * @param[in] buf buffer to write to * @param[in] count number of bytes to read * * @returns number of bytes read */ int isrpipe_read(isrpipe_t *isrpipe, char *buf, size_t count); #ifdef __cplusplus } #endif /** @} */ #endif /* ISRPIPE_H */