diff options
author | David Robillard <d@drobilla.net> | 2010-01-05 03:51:50 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2010-01-05 03:51:50 +0000 |
commit | c67392abf59b500fe405101d7ad896d9da869e47 (patch) | |
tree | 53b5d5b27d4389caa123c5deb2a1e0aadf180ec7 /src/engine/PortImpl.cpp | |
parent | 4c32f20699db0ede850a9485271dfda779761fac (diff) | |
download | ingen-c67392abf59b500fe405101d7ad896d9da869e47.tar.gz ingen-c67392abf59b500fe405101d7ad896d9da869e47.tar.bz2 ingen-c67392abf59b500fe405101d7ad896d9da869e47.zip |
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
Diffstat (limited to 'src/engine/PortImpl.cpp')
-rw-r--r-- | src/engine/PortImpl.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/engine/PortImpl.cpp b/src/engine/PortImpl.cpp index 45ee76da..bbda42ea 100644 --- a/src/engine/PortImpl.cpp +++ b/src/engine/PortImpl.cpp @@ -59,7 +59,7 @@ PortImpl::PortImpl(BufferFactory& bufs, , _set_by_user(false) , _last_broadcasted_value(_value.type() == Atom::FLOAT ? _value.get_float() : 0.0f) // default? , _context(Context::AUDIO) - , _buffers(new Array< SharedPtr<Buffer> >(poly)) + , _buffers(new Array<BufferFactory::Ref>(poly)) , _prepared_buffers(NULL) { assert(node != NULL); @@ -113,7 +113,7 @@ PortImpl::prepare_poly(BufferFactory& bufs, uint32_t poly) /* FIXME: poly never goes down, harsh on memory.. */ if (poly > _poly) { - _prepared_buffers = new Array< SharedPtr<Buffer> >(poly, *_buffers); + _prepared_buffers = new Array<BufferFactory::Ref>(poly, *_buffers); for (uint32_t i = _poly; i < _prepared_buffers->size(); ++i) _prepared_buffers->at(i) = bufs.get(_type, _buffer_size); } |