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.

187 lines
5.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. #ifdef WIN32
  17. #pragma warning (disable : 4786)
  18. #endif
  19. #include "JackLoopbackDriver.h"
  20. #include "JackEngineControl.h"
  21. #include "JackGraphManager.h"
  22. #include <iostream>
  23. #include <assert.h>
  24. namespace Jack
  25. {
  26. int JackLoopbackDriver::Process()
  27. {
  28. assert(fCaptureChannels == fPlaybackChannels);
  29. // Loopback copy
  30. for (int i = 0; i < fCaptureChannels; i++) {
  31. memcpy(GetInputBuffer(i), GetOutputBuffer(i), sizeof(float) * fEngineControl->fBufferSize);
  32. }
  33. fGraphManager->ResumeRefNum(fClientControl, fSynchroTable); // Signal all clients
  34. if (fEngineControl->fSyncMode) {
  35. if (fGraphManager->SuspendRefNum(fClientControl, fSynchroTable, fEngineControl->fTimeOutUsecs) < 0)
  36. jack_error("JackLoopbackDriver::ProcessSync SuspendRefNum error");
  37. }
  38. return 0;
  39. }
  40. void JackLoopbackDriver::PrintState()
  41. {
  42. int i;
  43. jack_port_id_t port_index;
  44. std::cout << "JackLoopbackDriver state" << std::endl;
  45. std::cout << "Input ports" << std::endl;
  46. for (i = 0; i < fPlaybackChannels; i++) {
  47. port_index = fCapturePortList[i];
  48. JackPort* port = fGraphManager->GetPort(port_index);
  49. std::cout << port->GetName() << std::endl;
  50. if (fGraphManager->GetConnectionsNum(port_index)) {}
  51. }
  52. std::cout << "Output ports" << std::endl;
  53. for (i = 0; i < fCaptureChannels; i++) {
  54. port_index = fPlaybackPortList[i];
  55. JackPort* port = fGraphManager->GetPort(port_index);
  56. std::cout << port->GetName() << std::endl;
  57. if (fGraphManager->GetConnectionsNum(port_index)) {}
  58. }
  59. }
  60. } // end of namespace
  61. /*
  62. #ifdef __cplusplus
  63. extern "C" {
  64. #endif
  65. jack_driver_desc_t * driver_get_descriptor ()
  66. {
  67. jack_driver_desc_t * desc;
  68. jack_driver_param_desc_t * params;
  69. unsigned int i;
  70. desc = (jack_driver_desc_t*)calloc (1, sizeof (jack_driver_desc_t));
  71. strcpy (desc->name, "dummy");
  72. desc->nparams = 5;
  73. params = (jack_driver_param_desc_t*)calloc (desc->nparams, sizeof (jack_driver_param_desc_t));
  74. i = 0;
  75. strcpy (params[i].name, "capture");
  76. params[i].character = 'C';
  77. params[i].type = JackDriverParamUInt;
  78. params[i].value.ui = 2U;
  79. strcpy (params[i].short_desc, "Number of capture ports");
  80. strcpy (params[i].long_desc, params[i].short_desc);
  81. i++;
  82. strcpy (params[i].name, "playback");
  83. params[i].character = 'P';
  84. params[i].type = JackDriverParamUInt;
  85. params[1].value.ui = 2U;
  86. strcpy (params[i].short_desc, "Number of playback ports");
  87. strcpy (params[i].long_desc, params[i].short_desc);
  88. i++;
  89. strcpy (params[i].name, "rate");
  90. params[i].character = 'r';
  91. params[i].type = JackDriverParamUInt;
  92. params[i].value.ui = 48000U;
  93. strcpy (params[i].short_desc, "Sample rate");
  94. strcpy (params[i].long_desc, params[i].short_desc);
  95. i++;
  96. strcpy (params[i].name, "period");
  97. params[i].character = 'p';
  98. params[i].type = JackDriverParamUInt;
  99. params[i].value.ui = 1024U;
  100. strcpy (params[i].short_desc, "Frames per period");
  101. strcpy (params[i].long_desc, params[i].short_desc);
  102. i++;
  103. strcpy (params[i].name, "wait");
  104. params[i].character = 'w';
  105. params[i].type = JackDriverParamUInt;
  106. params[i].value.ui = 21333U;
  107. strcpy (params[i].short_desc,
  108. "Number of usecs to wait between engine processes");
  109. strcpy (params[i].long_desc, params[i].short_desc);
  110. desc->params = params;
  111. return desc;
  112. }
  113. Jack::JackDriverClientInterface* driver_initialize(Jack::JackEngine* engine, Jack::JackSynchro** table, const JSList* params)
  114. {
  115. jack_nframes_t sample_rate = 48000;
  116. jack_nframes_t period_size = 1024;
  117. unsigned int capture_ports = 2;
  118. unsigned int playback_ports = 2;
  119. const JSList * node;
  120. const jack_driver_param_t * param;
  121. for (node = params; node; node = jack_slist_next (node)) {
  122. param = (const jack_driver_param_t *) node->data;
  123. switch (param->character) {
  124. case 'C':
  125. capture_ports = param->value.ui;
  126. break;
  127. case 'P':
  128. playback_ports = param->value.ui;
  129. break;
  130. case 'r':
  131. sample_rate = param->value.ui;
  132. break;
  133. case 'p':
  134. period_size = param->value.ui;
  135. break;
  136. }
  137. }
  138. Jack::JackDriverClientInterface* driver = new Jack::JackLoopbackDriver("loopback", engine, table);
  139. if (driver->Open(period_size, sample_rate, 1, 1, capture_ports, playback_ports, "loopback") == 0) {
  140. return driver;
  141. } else {
  142. delete driver;
  143. return NULL;
  144. }
  145. }
  146. #ifdef __cplusplus
  147. }
  148. #endif
  149. */