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.

208 lines
6.0KB

  1. /*
  2. Copyright (C) 2001 Paul Davis
  3. Copyright (C) 2004-2006 Grame
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 2 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the Free Software
  14. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  15. */
  16. #include "JackLoopbackDriver.h"
  17. #include "JackEngineControl.h"
  18. #include "JackGraphManager.h"
  19. #include <iostream>
  20. #include <assert.h>
  21. namespace Jack
  22. {
  23. int JackLoopbackDriver::Open(jack_nframes_t nframes,
  24. jack_nframes_t samplerate,
  25. int capturing,
  26. int playing,
  27. int inchannels,
  28. int outchannels,
  29. bool monitor,
  30. const char* capture_driver_name,
  31. const char* playback_driver_name,
  32. jack_nframes_t capture_latency,
  33. jack_nframes_t playback_latency)
  34. {
  35. return JackAudioDriver::Open(nframes,
  36. samplerate,
  37. capturing,
  38. playing,
  39. inchannels,
  40. outchannels,
  41. monitor,
  42. capture_driver_name,
  43. playback_driver_name,
  44. capture_latency,
  45. playback_latency);
  46. }
  47. int JackLoopbackDriver::Process()
  48. {
  49. assert(fCaptureChannels == fPlaybackChannels);
  50. // Loopback copy
  51. for (int i = 0; i < fCaptureChannels; i++) {
  52. memcpy(GetInputBuffer(i), GetOutputBuffer(i), sizeof(float) * fEngineControl->fBufferSize);
  53. }
  54. fGraphManager->ResumeRefNum(fClientControl, fSynchroTable); // Signal all clients
  55. if (fEngineControl->fSyncMode) {
  56. if (fGraphManager->SuspendRefNum(fClientControl, fSynchroTable, fEngineControl->fTimeOutUsecs) < 0)
  57. jack_error("JackLoopbackDriver::ProcessSync SuspendRefNum error");
  58. }
  59. return 0;
  60. }
  61. void JackLoopbackDriver::PrintState()
  62. {
  63. int i;
  64. jack_port_id_t port_index;
  65. std::cout << "JackLoopbackDriver state" << std::endl;
  66. std::cout << "Input ports" << std::endl;
  67. for (i = 0; i < fPlaybackChannels; i++) {
  68. port_index = fCapturePortList[i];
  69. JackPort* port = fGraphManager->GetPort(port_index);
  70. std::cout << port->GetName() << std::endl;
  71. if (fGraphManager->GetConnectionsNum(port_index)) {}
  72. }
  73. std::cout << "Output ports" << std::endl;
  74. for (i = 0; i < fCaptureChannels; i++) {
  75. port_index = fPlaybackPortList[i];
  76. JackPort* port = fGraphManager->GetPort(port_index);
  77. std::cout << port->GetName() << std::endl;
  78. if (fGraphManager->GetConnectionsNum(port_index)) {}
  79. }
  80. }
  81. } // end of namespace
  82. /*
  83. #ifdef __cplusplus
  84. extern "C" {
  85. #endif
  86. jack_driver_desc_t * driver_get_descriptor ()
  87. {
  88. jack_driver_desc_t * desc;
  89. jack_driver_param_desc_t * params;
  90. unsigned int i;
  91. desc = (jack_driver_desc_t*)calloc (1, sizeof (jack_driver_desc_t));
  92. strcpy (desc->name, "dummy");
  93. desc->nparams = 5;
  94. params = (jack_driver_param_desc_t*)calloc (desc->nparams, sizeof (jack_driver_param_desc_t));
  95. i = 0;
  96. strcpy (params[i].name, "capture");
  97. params[i].character = 'C';
  98. params[i].type = JackDriverParamUInt;
  99. params[i].value.ui = 2U;
  100. strcpy (params[i].short_desc, "Number of capture ports");
  101. strcpy (params[i].long_desc, params[i].short_desc);
  102. i++;
  103. strcpy (params[i].name, "playback");
  104. params[i].character = 'P';
  105. params[i].type = JackDriverParamUInt;
  106. params[1].value.ui = 2U;
  107. strcpy (params[i].short_desc, "Number of playback ports");
  108. strcpy (params[i].long_desc, params[i].short_desc);
  109. i++;
  110. strcpy (params[i].name, "rate");
  111. params[i].character = 'r';
  112. params[i].type = JackDriverParamUInt;
  113. params[i].value.ui = 48000U;
  114. strcpy (params[i].short_desc, "Sample rate");
  115. strcpy (params[i].long_desc, params[i].short_desc);
  116. i++;
  117. strcpy (params[i].name, "period");
  118. params[i].character = 'p';
  119. params[i].type = JackDriverParamUInt;
  120. params[i].value.ui = 1024U;
  121. strcpy (params[i].short_desc, "Frames per period");
  122. strcpy (params[i].long_desc, params[i].short_desc);
  123. i++;
  124. strcpy (params[i].name, "wait");
  125. params[i].character = 'w';
  126. params[i].type = JackDriverParamUInt;
  127. params[i].value.ui = 21333U;
  128. strcpy (params[i].short_desc,
  129. "Number of usecs to wait between engine processes");
  130. strcpy (params[i].long_desc, params[i].short_desc);
  131. desc->params = params;
  132. return desc;
  133. }
  134. Jack::JackDriverClientInterface* driver_initialize(Jack::JackEngine* engine, Jack::JackSynchro** table, const JSList* params)
  135. {
  136. jack_nframes_t sample_rate = 48000;
  137. jack_nframes_t period_size = 1024;
  138. unsigned int capture_ports = 2;
  139. unsigned int playback_ports = 2;
  140. const JSList * node;
  141. const jack_driver_param_t * param;
  142. for (node = params; node; node = jack_slist_next (node)) {
  143. param = (const jack_driver_param_t *) node->data;
  144. switch (param->character) {
  145. case 'C':
  146. capture_ports = param->value.ui;
  147. break;
  148. case 'P':
  149. playback_ports = param->value.ui;
  150. break;
  151. case 'r':
  152. sample_rate = param->value.ui;
  153. break;
  154. case 'p':
  155. period_size = param->value.ui;
  156. break;
  157. }
  158. }
  159. Jack::JackDriverClientInterface* driver = new Jack::JackLoopbackDriver("loopback", engine, table);
  160. if (driver->Open(period_size, sample_rate, 1, 1, capture_ports, playback_ports, "loopback") == 0) {
  161. return driver;
  162. } else {
  163. delete driver;
  164. return NULL;
  165. }
  166. }
  167. #ifdef __cplusplus
  168. }
  169. #endif
  170. */