| @@ -95,14 +95,12 @@ Playback_DS::disk_thread ( void ) | |||||
| /* buffer to hold the interleaved data returned by the track reader */ | /* buffer to hold the interleaved data returned by the track reader */ | ||||
| sample_t *buf = new sample_t[ _nframes * channels() * _disk_io_blocks ]; | sample_t *buf = new sample_t[ _nframes * channels() * _disk_io_blocks ]; | ||||
| // const size_t block_size = _nframes * sizeof( sample_t ); | |||||
| int blocks_ready = 1; | int blocks_ready = 1; | ||||
| const nframes_t nframes = _nframes * _disk_io_blocks; | |||||
| while ( wait_for_block() ) | while ( wait_for_block() ) | ||||
| { | { | ||||
| // printf( "IO: RT thread is ready for more data...\n" ); | |||||
| // printf( "IO: disk buffer is %3d%% full\r", output_buffer_percent() ); | |||||
| // lock(); // for seeking | // lock(); // for seeking | ||||
| @@ -129,9 +127,6 @@ Playback_DS::disk_thread ( void ) | |||||
| /* reset */ | /* reset */ | ||||
| blocks_ready = 1; | blocks_ready = 1; | ||||
| const nframes_t nframes = _nframes * _disk_io_blocks; | |||||
| /* FIXME: should we not read from disk in larger-than-JACK-buffer blocks? */ | |||||
| read_block( buf, nframes ); | read_block( buf, nframes ); | ||||
| // unlock(); // for seeking | // unlock(); // for seeking | ||||
| @@ -140,14 +135,6 @@ Playback_DS::disk_thread ( void ) | |||||
| for ( int i = channels(); i--; ) | for ( int i = channels(); i--; ) | ||||
| { | { | ||||
| /* while ( jack_ringbuffer_write_space( _rb[ i ] ) < block_size ) */ | |||||
| /* { */ | |||||
| /* printf( "IO: disk buffer overrun!\n" ); */ | |||||
| /* /\* FIXME: is this *really* the right thing to do? *\/ */ | |||||
| /* usleep( 2000 ); */ | |||||
| /* } */ | |||||
| /* deinterleave direcectly into the ringbuffer to avoid | /* deinterleave direcectly into the ringbuffer to avoid | ||||
| * unnecessary copying */ | * unnecessary copying */ | ||||
| @@ -155,37 +142,32 @@ Playback_DS::disk_thread ( void ) | |||||
| jack_ringbuffer_get_write_vector( _rb[ i ], rbd ); | jack_ringbuffer_get_write_vector( _rb[ i ], rbd ); | ||||
| if ( rbd[ 0 ].len >= nframes ) | |||||
| const size_t block_size = nframes * sizeof( sample_t ); | |||||
| if ( rbd[ 0 ].len >= block_size ) | |||||
| /* it'll all fit in one go */ | /* it'll all fit in one go */ | ||||
| buffer_deinterleave_one_channel( (sample_t*)rbd[ 0 ].buf, buf, i, channels(), nframes ); | buffer_deinterleave_one_channel( (sample_t*)rbd[ 0 ].buf, buf, i, channels(), nframes ); | ||||
| else if ( rbd[ 1 ].len ) | |||||
| else if ( rbd[ 0 ].len + rbd[ 1 ].len >= block_size ) | |||||
| { | { | ||||
| /* there's enough space in the ringbuffer, but it's not contiguous */ | /* there's enough space in the ringbuffer, but it's not contiguous */ | ||||
| /* do the first half */ | |||||
| const nframes_t f = rbd[ 0 ].len / sizeof( sample_t ); | const nframes_t f = rbd[ 0 ].len / sizeof( sample_t ); | ||||
| /* do the first half */ | |||||
| buffer_deinterleave_one_channel( (sample_t*)rbd[ 0 ].buf, buf, i, channels(), f ); | buffer_deinterleave_one_channel( (sample_t*)rbd[ 0 ].buf, buf, i, channels(), f ); | ||||
| assert( rbd[ 1 ].len >= (nframes - f) * sizeof( sample_t ) ); | |||||
| /* do the second half */ | /* do the second half */ | ||||
| buffer_deinterleave_one_channel( (sample_t*)rbd[ 1 ].buf, buf + f, i, channels(), nframes - f ); | buffer_deinterleave_one_channel( (sample_t*)rbd[ 1 ].buf, buf + f, i, channels(), nframes - f ); | ||||
| } | } | ||||
| else | else | ||||
| { | { | ||||
| ++_xruns; | ++_xruns; | ||||
| printf( "programming error: expected more space in ringbuffer\n" ); | |||||
| } | } | ||||
| /* buffer_deinterleave_one_channel( (sample_t*)rbd.buf, buf, i, channels(), _nframes ); */ | /* buffer_deinterleave_one_channel( (sample_t*)rbd.buf, buf, i, channels(), _nframes ); */ | ||||
| /* jack_ringbuffer_write( _rb[ i ], (char*)cbuf, block_size ); */ | /* jack_ringbuffer_write( _rb[ i ], (char*)cbuf, block_size ); */ | ||||
| jack_ringbuffer_write_advance( _rb[ i ], nframes * sizeof( sample_t ) ); | |||||
| jack_ringbuffer_write_advance( _rb[ i ], block_size ); | |||||
| } | } | ||||
| } | } | ||||