allow to set custom thread-buffer size
authorRobin Gareus <robin@gareus.org>
Mon, 26 May 2014 04:21:05 +0000 (06:21 +0200)
committerRobin Gareus <robin@gareus.org>
Mon, 26 May 2014 04:56:04 +0000 (06:56 +0200)
This is needed for gain and pan automation buffers
as well as silent and scratch buffers when bouncing or
exporting with larger chunk size than the current engine
period.

libs/ardour/ardour/buffer_manager.h
libs/ardour/ardour/thread_buffers.h
libs/ardour/buffer_manager.cc
libs/ardour/thread_buffers.cc

index f5a3935ead6dffe18392f35b54dd3f5a1af618c0..c73b59b763949911d638dbc783487f3b2303da38 100644 (file)
@@ -40,7 +40,7 @@ public:
        static ThreadBuffers* get_thread_buffers ();
        static void           put_thread_buffers (ThreadBuffers*);
 
-       static void ensure_buffers (ChanCount howmany = ChanCount::ZERO);
+       static void ensure_buffers (ChanCount howmany = ChanCount::ZERO, size_t custom = 0);
 
 private:
         static Glib::Threads::Mutex rb_mutex;
index f30476a4747ea662959269014a45b6545d7a8360..bf686fd57ee1e0053f21eb29314138335a5c90a8 100644 (file)
@@ -35,7 +35,7 @@ public:
        ThreadBuffers ();
        ~ThreadBuffers ();
 
-       void ensure_buffers (ChanCount howmany = ChanCount::ZERO);
+       void ensure_buffers (ChanCount howmany = ChanCount::ZERO, size_t custom = 0);
 
        BufferSet* silent_buffers;
        BufferSet* scratch_buffers;
index c8819e41cbe10e7e111a9fdfda7acd0bd814eeb6..c221837af88ddef013ca597ecf1ec8a272f348e0 100644 (file)
@@ -75,11 +75,11 @@ BufferManager::put_thread_buffers (ThreadBuffers* tbp)
 }
 
 void
-BufferManager::ensure_buffers (ChanCount howmany)
+BufferManager::ensure_buffers (ChanCount howmany, size_t custom)
 {
         /* this is protected by the audioengine's process lock: we do not  */
 
        for (ThreadBufferList::iterator i = thread_buffers_list->begin(); i != thread_buffers_list->end(); ++i) {
-               (*i)->ensure_buffers (howmany);
+               (*i)->ensure_buffers (howmany, custom);
        }
 }
index 94490ca912487420c4fdf956ee60b555fb93e7cc..b51576bfc920e1e46a5b908f38b5fe58dd106182 100644 (file)
@@ -40,7 +40,7 @@ ThreadBuffers::ThreadBuffers ()
 }
 
 void
-ThreadBuffers::ensure_buffers (ChanCount howmany)
+ThreadBuffers::ensure_buffers (ChanCount howmany, size_t custom)
 {
        // std::cerr << "ThreadBuffers " << this << " resize buffers with count = " << howmany << std::endl;
 
@@ -60,9 +60,14 @@ ThreadBuffers::ensure_buffers (ChanCount howmany)
 
        for (DataType::iterator t = DataType::begin(); t != DataType::end(); ++t) {
                size_t count = std::max (scratch_buffers->available().get(*t), howmany.get(*t));
-               size_t size = (*t == DataType::MIDI)
-                       ? _engine->raw_buffer_size (*t)
-                       : _engine->raw_buffer_size (*t) / sizeof (Sample);
+               size_t size;
+               if (custom > 0) {
+                       size = custom;
+               } else {
+                       size = (*t == DataType::MIDI)
+                               ? _engine->raw_buffer_size (*t)
+                               : _engine->raw_buffer_size (*t) / sizeof (Sample);
+               }
 
                scratch_buffers->ensure_buffers (*t, count, size);
                mix_buffers->ensure_buffers (*t, count, size);
@@ -70,7 +75,7 @@ ThreadBuffers::ensure_buffers (ChanCount howmany)
                route_buffers->ensure_buffers (*t, count, size);
        }
 
-       size_t audio_buffer_size = _engine->raw_buffer_size (DataType::AUDIO) / sizeof (Sample);
+       size_t audio_buffer_size = custom > 0 ? custom : _engine->raw_buffer_size (DataType::AUDIO) / sizeof (Sample);
 
        delete [] gain_automation_buffer;
        gain_automation_buffer = new gain_t[audio_buffer_size];