From c67392abf59b500fe405101d7ad896d9da869e47 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Tue, 5 Jan 2010 03:51:50 +0000 Subject: Realtime safe buffer reference handling. Turns out that dropping a shared_ptr is not realtime safe, even if you use a realtime safe deleter. Instead, instrusive_ptr is used for buffer references, so a buffer reference may safely be dropped in the audio thread (in which case it will be recycled by the BufferFactory). Faster, cleaner, better. git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@2341 a436a847-0d15-0410-975c-d299462d15a1 --- src/engine/EventBuffer.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src/engine/EventBuffer.cpp') diff --git a/src/engine/EventBuffer.cpp b/src/engine/EventBuffer.cpp index da6b5745..4f7f6b5f 100644 --- a/src/engine/EventBuffer.cpp +++ b/src/engine/EventBuffer.cpp @@ -33,8 +33,8 @@ using namespace Shared; /** Allocate a new event buffer. * \a capacity is in bytes (not number of events). */ -EventBuffer::EventBuffer(size_t capacity) - : Buffer(PortType(PortType::EVENTS), capacity) +EventBuffer::EventBuffer(BufferFactory& factory, size_t capacity) + : Buffer(factory, PortType(PortType::EVENTS), capacity) , _latest_frames(0) , _latest_subframes(0) { -- cgit v1.2.1