jack2 codebase
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

239 lines
6.5KB

  1. /*
  2. Copyright (C) 2008-2011 Romain Moret at Grame
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of the GNU General Public License as published by
  5. the Free Software Foundation; either version 2 of the License, or
  6. (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program; if not, write to the Free Software
  13. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  14. */
  15. #ifndef __JackNetInterface__
  16. #define __JackNetInterface__
  17. #include "JackNetTool.h"
  18. #include <limits.h>
  19. namespace Jack
  20. {
  21. #define DEFAULT_MULTICAST_IP "225.3.19.154"
  22. #define DEFAULT_MULTICAST_IF "any"
  23. #define DEFAULT_PORT 19000
  24. #define DEFAULT_MTU 1500
  25. #define SLAVE_SETUP_RETRY 5
  26. #define MANAGER_INIT_TIMEOUT 2000000 // in usec
  27. #define MASTER_INIT_TIMEOUT 1000000 * 10 // in usec
  28. #define SLAVE_INIT_TIMEOUT 1000000 * 10 // in usec
  29. #define PACKET_TIMEOUT 500000 // in usec
  30. #define NETWORK_MAX_LATENCY 20
  31. /**
  32. \Brief This class describes the basic Net Interface, used by both master and slave.
  33. */
  34. class SERVER_EXPORT JackNetInterface
  35. {
  36. protected:
  37. bool fSetTimeOut;
  38. void Initialize();
  39. session_params_t fParams;
  40. JackNetSocket fSocket;
  41. char fMulticastIP[32];
  42. char fMulticastIF[32];
  43. // headers
  44. packet_header_t fTxHeader;
  45. packet_header_t fRxHeader;
  46. // transport
  47. net_transport_data_t fSendTransportData;
  48. net_transport_data_t fReturnTransportData;
  49. // network buffers
  50. char* fTxBuffer;
  51. char* fRxBuffer;
  52. char* fTxData;
  53. char* fRxData;
  54. // JACK buffers
  55. NetMidiBuffer* fNetMidiCaptureBuffer;
  56. NetMidiBuffer* fNetMidiPlaybackBuffer;
  57. NetAudioBuffer* fNetAudioCaptureBuffer;
  58. NetAudioBuffer* fNetAudioPlaybackBuffer;
  59. // utility methods
  60. int SetNetBufferSize();
  61. void FreeNetworkBuffers();
  62. // virtual methods : depends on the sub class master/slave
  63. virtual bool SetParams();
  64. virtual bool Init() = 0;
  65. // transport
  66. virtual void EncodeTransportData() = 0;
  67. virtual void DecodeTransportData() = 0;
  68. // sync packet
  69. virtual void EncodeSyncPacket() = 0;
  70. virtual void DecodeSyncPacket() = 0;
  71. virtual int SyncRecv() = 0;
  72. virtual int SyncSend() = 0;
  73. virtual int DataRecv() = 0;
  74. virtual int DataSend() = 0;
  75. virtual int Send(size_t size, int flags) = 0;
  76. virtual int Recv(size_t size, int flags) = 0;
  77. virtual void FatalRecvError() = 0;
  78. virtual void FatalSendError() = 0;
  79. int MidiSend(NetMidiBuffer* buffer, int midi_channnels, int audio_channels);
  80. int AudioSend(NetAudioBuffer* buffer, int audio_channels);
  81. int MidiRecv(packet_header_t* rx_head, NetMidiBuffer* buffer, uint& recvd_midi_pckt);
  82. int AudioRecv(packet_header_t* rx_head, NetAudioBuffer* buffer);
  83. int FinishRecv(NetAudioBuffer* buffer);
  84. void SetRcvTimeOut();
  85. NetAudioBuffer* AudioBufferFactory(int nports, char* buffer);
  86. public:
  87. JackNetInterface();
  88. JackNetInterface(const char* multicast_ip, int port);
  89. JackNetInterface(session_params_t& params, JackNetSocket& socket, const char* multicast_ip);
  90. virtual ~JackNetInterface();
  91. };
  92. /**
  93. \Brief This class describes the Net Interface for masters (NetMaster)
  94. */
  95. class SERVER_EXPORT JackNetMasterInterface : public JackNetInterface
  96. {
  97. protected:
  98. bool fRunning;
  99. int fCurrentCycleOffset;
  100. int fMaxCycleOffset;
  101. bool Init();
  102. bool SetParams();
  103. void Exit();
  104. int SyncRecv();
  105. int SyncSend();
  106. int DataRecv();
  107. int DataSend();
  108. // sync packet
  109. void EncodeSyncPacket();
  110. void DecodeSyncPacket();
  111. int Send(size_t size, int flags);
  112. int Recv(size_t size, int flags);
  113. bool IsSynched();
  114. void FatalRecvError();
  115. void FatalSendError();
  116. public:
  117. JackNetMasterInterface() : JackNetInterface(), fRunning(false), fCurrentCycleOffset(0), fMaxCycleOffset(0)
  118. {}
  119. JackNetMasterInterface(session_params_t& params, JackNetSocket& socket, const char* multicast_ip)
  120. : JackNetInterface(params, socket, multicast_ip), fRunning(false), fCurrentCycleOffset(0), fMaxCycleOffset(0)
  121. {}
  122. virtual~JackNetMasterInterface()
  123. {}
  124. };
  125. /**
  126. \Brief This class describes the Net Interface for slaves (NetDriver and NetAdapter)
  127. */
  128. class SERVER_EXPORT JackNetSlaveInterface : public JackNetInterface
  129. {
  130. protected:
  131. static uint fSlaveCounter;
  132. bool Init();
  133. bool InitConnection(int time_out_sec);
  134. bool InitRendering();
  135. net_status_t SendAvailableToMaster(long count = LONG_MAX); // long here (and not int...)
  136. net_status_t SendStartToMaster();
  137. bool SetParams();
  138. int SyncRecv();
  139. int SyncSend();
  140. int DataRecv();
  141. int DataSend();
  142. // sync packet
  143. void EncodeSyncPacket();
  144. void DecodeSyncPacket();
  145. int Recv(size_t size, int flags);
  146. int Send(size_t size, int flags);
  147. void FatalRecvError();
  148. void FatalSendError();
  149. void InitAPI();
  150. public:
  151. JackNetSlaveInterface() : JackNetInterface()
  152. {
  153. InitAPI();
  154. }
  155. JackNetSlaveInterface(const char* ip, int port) : JackNetInterface(ip, port)
  156. {
  157. InitAPI();
  158. }
  159. virtual ~JackNetSlaveInterface()
  160. {
  161. // close Socket API with the last slave
  162. if (--fSlaveCounter == 0) {
  163. SocketAPIEnd();
  164. }
  165. }
  166. };
  167. }
  168. #endif