123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- /*
- * Asterisk -- An open source telephony toolkit.
- *
- * Copyright (C) 2017, Sean Bright
- *
- * Sean Bright <sean.bright@gmail.com>
- *
- * See http://www.asterisk.org for more information about
- * the Asterisk project. Please do not directly contact
- * any of the maintainers of this project for assistance;
- * the project provides a web site, mailing lists and IRC
- * channels for your use.
- *
- * This program is free software, distributed under the terms of
- * the GNU General Public License Version 2. See the LICENSE file
- * at the top of the source tree.
- */
- #ifndef ASTERISK_ALERTPIPE_H
- #define ASTERISK_ALERTPIPE_H
- #include "asterisk/utils.h"
- typedef enum {
- AST_ALERT_READ_SUCCESS = 0,
- AST_ALERT_NOT_READABLE,
- AST_ALERT_READ_FAIL,
- AST_ALERT_READ_FATAL,
- } ast_alert_status_t;
- /*!
- * \brief Initialize an alert pipe
- * \since 13.16.0
- *
- * \param p a two-element array to hold the alert pipe's file descriptors
- *
- * \return non-zero if a failure occurred, zero otherwise.
- */
- int ast_alertpipe_init(int alert_pipe[2]);
- /*!
- * \brief Close an alert pipe
- * \since 13.16.0
- *
- * \param p a two-element containing the alert pipe's file descriptors
- */
- void ast_alertpipe_close(int alert_pipe[2]);
- /*!
- * \brief Read an event from an alert pipe
- * \since 13.16.0
- *
- * \param p a two-element array containing the alert pipe's file descriptors
- *
- * \retval AST_ALERT_READ_SUCCESS on success
- * \retval AST_ALERT_NOT_READABLE if the alert pipe is not readable
- * \retval AST_ALERT_READ_FATAL if the alert pipe's file descriptors are in
- * blocking mode, or a read error occurs.
- */
- ast_alert_status_t ast_alertpipe_read(int alert_pipe[2]);
- /*!
- * \brief Write an event to an alert pipe
- * \since 13.16.0
- *
- * \param p a two-element array containing the alert pipe's file descriptors
- *
- * \retval 0 Success
- * \retval 1 Failure
- */
- ssize_t ast_alertpipe_write(int alert_pipe[2]);
- /*!
- * \brief Consume all alerts written to the alert pipe
- * \since 13.16.0
- *
- * \param p a two-element array containing the alert pipe's file descriptors
- *
- * \retval AST_ALERT_READ_SUCCESS on success
- * \retval AST_ALERT_NOT_READABLE if the alert pipe is not readable
- * \retval AST_ALERT_READ_FATAL if the alert pipe's file descriptors are in
- * blocking mode, or a read error occurs.
- */
- ast_alert_status_t ast_alertpipe_flush(int alert_pipe[2]);
- /*!
- * \brief Sets the alert pipe file descriptors to default values
- * \since 13.16.0
- *
- * \param p a two-element array containing the alert pipe's file descriptors
- */
- AST_INLINE_API(
- void ast_alertpipe_clear(int alert_pipe[2]),
- {
- alert_pipe[0] = alert_pipe[1] = -1;
- }
- )
- /*!
- * \brief Determine if the alert pipe is readable
- * \since 13.16.0
- *
- * \param p a two-element array containing the alert pipe's file descriptors
- *
- * \return non-zero if the alert pipe is readable, zero otherwise.
- */
- AST_INLINE_API(
- int attribute_pure ast_alertpipe_readable(int alert_pipe[2]),
- {
- return alert_pipe[0] > -1;
- }
- )
- /*!
- * \brief Determine if the alert pipe is writable
- * \since 13.16.0
- *
- * \param p a two-element array containing the alert pipe's file descriptors
- *
- * \return non-zero if the alert pipe is writable, zero otherwise.
- */
- AST_INLINE_API(
- int attribute_pure ast_alertpipe_writable(int alert_pipe[2]),
- {
- return alert_pipe[1] > -1;
- }
- )
- /*!
- * \brief Get the alert pipe's read file descriptor
- * \since 13.16.0
- *
- * \param p a two-element array containing the alert pipe's file descriptors
- *
- * \return -1 if the file descriptor is not initialized, a non-negative value
- * otherwise.
- */
- AST_INLINE_API(
- int attribute_pure ast_alertpipe_readfd(int alert_pipe[2]),
- {
- return alert_pipe[0];
- }
- )
- /*!
- * \brief Swap the file descriptors from two alert pipes
- * \since 13.16.0
- *
- * \param p1 a two-element array containing an alert pipe's file descriptors
- * \param p2 a two-element array containing an alert pipe's file descriptors
- */
- AST_INLINE_API(
- void ast_alertpipe_swap(int alert_pipe_1[2], int alert_pipe_2[2]),
- {
- SWAP(alert_pipe_1[0], alert_pipe_2[0]);
- SWAP(alert_pipe_1[1], alert_pipe_2[1]);
- }
- )
- #endif /* ASTERISK_ALERTPIPE_H */
|