Assists music production by grouping standalone programs into sessions. Community version of "Non Session Manager".
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.

106 lines
3.3KB

  1. /*******************************************************************************/
  2. /* Copyright (C) 2008 Jonathan Moore Liles */
  3. /* */
  4. /* This program is free software; you can redistribute it and/or modify it */
  5. /* under the terms of the GNU General Public License as published by the */
  6. /* Free Software Foundation; either version 2 of the License, or (at your */
  7. /* option) any later version. */
  8. /* */
  9. /* This program is distributed in the hope that it will be useful, but WITHOUT */
  10. /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or */
  11. /* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for */
  12. /* more details. */
  13. /* */
  14. /* You should have received a copy of the GNU General Public License along */
  15. /* with This program; see the file COPYING. If not,write to the Free Software */
  16. /* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
  17. /*******************************************************************************/
  18. #pragma once
  19. #include "types.h"
  20. #include <jack/ringbuffer.h>
  21. #include <semaphore.h>
  22. #include <errno.h>
  23. #include <pthread.h>
  24. #include "Mutex.H"
  25. #include <vector>
  26. using std::vector;
  27. class Track;
  28. class Audio_Sequence;
  29. class Disk_Stream : public Mutex
  30. {
  31. protected:
  32. pthread_t _thread; /* io thread */
  33. Track *_th; /* Track we belong to */
  34. nframes_t _nframes; /* buffer size */
  35. nframes_t _frame; /* location of disk read */
  36. vector < jack_ringbuffer_t * >_rb; /* one ringbuffer for each channel */
  37. sem_t _blocks; /* semaphore to wake the IO thread with */
  38. int _total_blocks; /* total number of blocks that we can buffer */
  39. int _disk_io_blocks; /* the number of blocks to read/write to/from disk at once */
  40. volatile nframes_t _pending_seek; /* absolute transport position to seek to */
  41. volatile int _terminate;
  42. int channels ( void ) const { return _rb.size(); }
  43. Audio_Sequence * track ( void );
  44. static void *disk_thread ( void *arg );
  45. protected:
  46. void block_processed ( void ) { sem_post( &_blocks ); }
  47. bool wait_for_block ( void )
  48. {
  49. if ( _terminate )
  50. return false;
  51. else
  52. {
  53. while ( sem_wait( &_blocks ) == EINTR );
  54. return true;
  55. }
  56. }
  57. virtual void disk_thread ( void ) = 0;
  58. public:
  59. /* must be set before any Disk_Streams are created */
  60. static float seconds_to_buffer;
  61. static size_t disk_io_kbytes;
  62. Disk_Stream ( Track *th, float frame_rate, nframes_t nframes, int channels );
  63. virtual ~Disk_Stream ( );
  64. void resize ( nframes_t nframes );
  65. /* void seek ( nframes_t frame ); */
  66. /* bool seek_pending ( void ); */
  67. void run ( void );
  68. void shutdown ( void );
  69. virtual nframes_t process ( nframes_t nframes ) = 0;
  70. int buffer_percent ( void );
  71. };