#include "pbd/ringbufferNPT.h"
#include "ardour/chan_count.h"
+#include <list>
+#include <glibmm/thread.h>
namespace ARDOUR {
static void ensure_buffers (ChanCount howmany = ChanCount::ZERO);
private:
+ static Glib::StaticMutex rb_mutex;
+
typedef RingBufferNPT<ThreadBuffers*> ThreadBufferFIFO;
+ typedef std::list<ThreadBuffers*> ThreadBufferList;
static ThreadBufferFIFO* thread_buffers;
+ static ThreadBufferList* thread_buffers_list;
};
}
using namespace PBD;
RingBufferNPT<ThreadBuffers*>* BufferManager::thread_buffers = 0;
+std::list<ThreadBuffers*>* BufferManager::thread_buffers_list = 0;
+Glib::StaticMutex BufferManager::rb_mutex = GLIBMM_STATIC_MUTEX_INIT;
void
BufferManager::init (uint32_t size)
{
thread_buffers = new ThreadBufferFIFO (size+1); // must be one larger than requested
+ thread_buffers_list = new ThreadBufferList;
/* and populate with actual ThreadBuffers
*/
for (uint32_t n = 0; n < size; ++n) {
ThreadBuffers* ts = new ThreadBuffers;
thread_buffers->write (&ts, 1);
+ thread_buffers_list->push_back (ts);
}
}
ThreadBuffers*
BufferManager::get_thread_buffers ()
{
+ Glib::Mutex::Lock em (rb_mutex);
ThreadBuffers* tbp;
if (thread_buffers->read (&tbp, 1) == 1) {
void
BufferManager::put_thread_buffers (ThreadBuffers* tbp)
{
+ Glib::Mutex::Lock em (rb_mutex);
thread_buffers->write (&tbp, 1);
}
{
/* this is protected by the audioengine's process lock: we do not */
- for (uint32_t n = 0; n < thread_buffers->bufsize() - 1; ++n) {
- thread_buffers->buffer()[n]->ensure_buffers (howmany);
- }
+ for (ThreadBufferList::iterator i = thread_buffers_list->begin(); i != thread_buffers_list_end(); ++i) {
+ (*i)->ensure_buffers (howmany);
+ }
}
/* make sure we have sufficient scratch buffers to cope with the new processor
configuration */
- _session.ensure_buffers (n_process_buffers ());
+ {
+ Glib::Mutex::Lock em (_session.engine().process_lock ());
+ _session.ensure_buffers (n_process_buffers ());
+ }
_in_configure_processors = false;
return 0;