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.

146 lines
5.3KB

  1. /*
  2. Copyright (C) 2008 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. #include "JackLibSampleRateResampler.h"
  16. namespace Jack
  17. {
  18. JackLibSampleRateResampler::JackLibSampleRateResampler()
  19. :JackResampler(),fRatio(1)
  20. {
  21. int error;
  22. fResampler = src_new(SRC_LINEAR, 1, &error);
  23. if (error != 0)
  24. jack_error("JackLibSampleRateResampler::JackLibSampleRateResampler err = %s", src_strerror(error));
  25. }
  26. JackLibSampleRateResampler::~JackLibSampleRateResampler()
  27. {
  28. src_delete(fResampler);
  29. }
  30. void JackLibSampleRateResampler::Reset()
  31. {
  32. JackResampler::Reset();
  33. src_reset(fResampler);
  34. }
  35. unsigned int JackLibSampleRateResampler::ReadResample(float* buffer, unsigned int frames)
  36. {
  37. jack_ringbuffer_data_t ring_buffer_data[2];
  38. SRC_DATA src_data;
  39. unsigned int frames_to_write = frames;
  40. unsigned int written_frames = 0;
  41. int res;
  42. jack_ringbuffer_get_read_vector(fRingBuffer, ring_buffer_data);
  43. unsigned int available_frames = (ring_buffer_data[0].len + ring_buffer_data[1].len) / sizeof(float);
  44. jack_log("Output available = %ld", available_frames);
  45. for (int j = 0; j < 2; j++) {
  46. if (ring_buffer_data[j].len > 0) {
  47. src_data.data_in = (float*)ring_buffer_data[j].buf;
  48. src_data.data_out = &buffer[written_frames];
  49. src_data.input_frames = ring_buffer_data[j].len / sizeof(float);
  50. src_data.output_frames = frames_to_write;
  51. src_data.end_of_input = 0;
  52. src_data.src_ratio = fRatio;
  53. res = src_process(fResampler, &src_data);
  54. if (res != 0) {
  55. jack_error("JackLibSampleRateResampler::ReadResample err = %s", src_strerror(res));
  56. return 0;
  57. }
  58. frames_to_write -= src_data.output_frames_gen;
  59. written_frames += src_data.output_frames_gen;
  60. if ((src_data.input_frames_used == 0 || src_data.output_frames_gen == 0) && j == 0) {
  61. jack_error("Output : j = %d input_frames_used = %ld output_frames_gen = %ld", j, src_data.input_frames_used, src_data.output_frames_gen);
  62. return 0;
  63. }
  64. jack_log("Output : j = %d input_frames_used = %ld output_frames_gen = %ld", j, src_data.input_frames_used, src_data.output_frames_gen);
  65. jack_ringbuffer_read_advance(fRingBuffer, src_data.input_frames_used * sizeof(float));
  66. }
  67. }
  68. if (written_frames < frames) {
  69. jack_error("Output available = %ld", available_frames);
  70. jack_error("JackLibSampleRateResampler::ReadResample error written_frames = %ld", written_frames);
  71. }
  72. return written_frames;
  73. }
  74. unsigned int JackLibSampleRateResampler::WriteResample(float* buffer, unsigned int frames)
  75. {
  76. jack_ringbuffer_data_t ring_buffer_data[2];
  77. SRC_DATA src_data;
  78. unsigned int frames_to_read = frames;
  79. unsigned int read_frames = 0;
  80. int res;
  81. jack_ringbuffer_get_write_vector(fRingBuffer, ring_buffer_data);
  82. unsigned int available_frames = (ring_buffer_data[0].len + ring_buffer_data[1].len) / sizeof(float);
  83. jack_log("Input available = %ld", available_frames);
  84. for (int j = 0; j < 2; j++) {
  85. if (ring_buffer_data[j].len > 0) {
  86. src_data.data_in = &buffer[read_frames];
  87. src_data.data_out = (float*)ring_buffer_data[j].buf;
  88. src_data.input_frames = frames_to_read;
  89. src_data.output_frames = (ring_buffer_data[j].len / sizeof(float));
  90. src_data.end_of_input = 0;
  91. src_data.src_ratio = fRatio;
  92. res = src_process(fResampler, &src_data);
  93. if (res != 0) {
  94. jack_error("JackLibSampleRateResampler::ReadResample err = %s", src_strerror(res));
  95. return 0;
  96. }
  97. frames_to_read -= src_data.input_frames_used;
  98. read_frames += src_data.input_frames_used;
  99. if ((src_data.input_frames_used == 0 || src_data.output_frames_gen == 0) && j == 0) {
  100. jack_error("Input : j = %d input_frames_used = %ld output_frames_gen = %ld", j, src_data.input_frames_used, src_data.output_frames_gen);
  101. return 0;
  102. }
  103. jack_log("Input : j = %d input_frames_used = %ld output_frames_gen = %ld", j, src_data.input_frames_used, src_data.output_frames_gen);
  104. jack_ringbuffer_write_advance(fRingBuffer, src_data.output_frames_gen * sizeof(float));
  105. }
  106. }
  107. if (read_frames < frames) {
  108. jack_error("Input available = %ld", available_frames);
  109. jack_error("JackLibSampleRateResampler::ReadResample error read_frames = %ld", read_frames);
  110. }
  111. return read_frames;
  112. }
  113. }