X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/6d2d327ca57fefaddceba10eb323451f8150e95d..5dcfc065d123f6643b12ed1766c7976e58b6941a:/lib/speaker-protocol.h diff --git a/lib/speaker-protocol.h b/lib/speaker-protocol.h index 8809f0f..4a8d3aa 100644 --- a/lib/speaker-protocol.h +++ b/lib/speaker-protocol.h @@ -1,21 +1,19 @@ /* * This file is part of DisOrder - * Copyright (C) 2005, 2007 Richard Kettlewell + * Copyright (C) 2005, 2007, 2008, 2013 Richard Kettlewell * - * This program is free software; you can redistribute it and/or modify + * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or + * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, but - * WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * General Public License for more details. - * + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 - * USA + * along with this program. If not, see . */ /** @file lib/speaker-protocol.h * @brief Speaker/server protocol support @@ -27,39 +25,46 @@ #ifndef SPEAKER_PROTOCOL_H #define SPEAKER_PROTOCOL_H +#include "byte-order.h" +#if HAVE_NETINET_IN_H +# include +#endif + /** @brief A message from the main server to the speaker, or vica versa */ struct speaker_message { /** @brief Message type * - * Messges from the main server: - * - @ref SM_PREPARE + * Messages from the main server: * - @ref SM_PLAY * - @ref SM_PAUSE * - @ref SM_RESUME * - @ref SM_CANCEL * - @ref SM_RELOAD + * - @ref SM_RTP_REQUEST + * - @ref SM_RTP_CANCEL * * Messages from the speaker: * - @ref SM_PAUSED * - @ref SM_FINISHED * - @ref SM_PLAYING + * - @ref SM_UNKNOWN + * - @ref SM_ARRIVED */ int type; /** @brief Message-specific data */ long data; - /** @brief Track ID (including 0 terminator) */ - char id[24]; /* ID including terminator */ + union { + /** @brief Track ID (including 0 terminator) */ + char id[24]; /* ID including terminator */ + + /** @brief An IP address (for @ref SM_RTP_REQUEST and @ref SM_RTP_CANCEL) */ + struct sockaddr_storage address; + } u; }; /* messages from the main DisOrder server */ -/** @brief Prepare track @c id - * - * This message will include a file descriptor. The speaker starts buffering - * audio data read from this file against the time that it must be played. - */ -#define SM_PREPARE 0 /** @brief Play track @c id * @@ -79,6 +84,12 @@ struct speaker_message { /** @brief Reload configuration */ #define SM_RELOAD 5 +/** @brief Reload configuration */ +#define SM_RTP_REQUEST 6 + +/** @brief Reload configuration */ +#define SM_RTP_CANCEL 7 + /* messages from the speaker */ /** @brief Paused track @c id, @c data seconds in * @@ -90,22 +101,39 @@ struct speaker_message { /** @brief Finished playing track @c id */ #define SM_FINISHED 129 +/** @brief Never heard of track @c id */ +#define SM_UNKNOWN 130 + /** @brief Currently track @c id, @c data seconds in * * This is sent from time to time while a track is playing. */ #define SM_PLAYING 131 -void speaker_send(int fd, const struct speaker_message *sm, int datafd); -/* Send a message. DATAFD is passed too if not -1. Does not close DATAFD. */ +/** @brief Speaker process is ready + * + * This is sent once at startup when the speaker has finished its + * initialization. */ +#define SM_READY 132 + +/** @brief Cancelled track @c id which wasn't playing */ +#define SM_STILLBORN 133 -int speaker_recv(int fd, struct speaker_message *sm, int *datafd); -/* Receive a message. If DATAFD is not null then can receive an FD. Return 0 - * on EOF, +ve if a message is read, -1 on EAGAIN, terminates on any other - * error. */ +/** @brief A connection for track @c id arrived */ +#define SM_ARRIVED 134 + +void speaker_send(int fd, const struct speaker_message *sm); +/* Send a message. */ + +int speaker_recv(int fd, struct speaker_message *sm); +/* Receive a message. Return 0 on EOF, +ve if a message is read, -1 on EAGAIN, + * terminates on any other error. */ /** @brief One chunk in a stream */ struct stream_header { + /** @brief Number of bytes */ + uint32_t nbytes; + /** @brief Frames per second */ uint32_t rate; @@ -117,16 +145,6 @@ struct stream_header { /** @brief Endianness */ uint8_t endian; -#define ENDIAN_BIG 1 -#define ENDIAN_LITTLE 2 -#ifdef WORDS_BIGENDIAN -# define ENDIAN_NATIVE ENDIAN_BIG -#else -# define ENDIAN_NATIVE ENDIAN_LITTLE -#endif - - /** @brief Number of bytes */ - uint32_t nbytes; } attribute((packed)); static inline int formats_equal(const struct stream_header *a,