mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-15 20:31:36 +00:00
Merge pull request #60 from TomHarte/SilentAudio
Introduces a reuse list for Mac audio buffers
This commit is contained in:
commit
cf5685abf3
@ -10,10 +10,13 @@
|
|||||||
@import AudioToolbox;
|
@import AudioToolbox;
|
||||||
|
|
||||||
#define AudioQueueBufferMaxLength 8192
|
#define AudioQueueBufferMaxLength 8192
|
||||||
|
#define NumberOfStoredAudioQueueBuffer 16
|
||||||
|
|
||||||
@implementation CSAudioQueue
|
@implementation CSAudioQueue
|
||||||
{
|
{
|
||||||
AudioQueueRef _audioQueue;
|
AudioQueueRef _audioQueue;
|
||||||
|
|
||||||
|
AudioQueueBufferRef _storedBuffers[NumberOfStoredAudioQueueBuffer];
|
||||||
}
|
}
|
||||||
|
|
||||||
#pragma mark - AudioQueue callbacks
|
#pragma mark - AudioQueue callbacks
|
||||||
@ -21,6 +24,19 @@
|
|||||||
- (void)audioQueue:(AudioQueueRef)theAudioQueue didCallbackWithBuffer:(AudioQueueBufferRef)buffer
|
- (void)audioQueue:(AudioQueueRef)theAudioQueue didCallbackWithBuffer:(AudioQueueBufferRef)buffer
|
||||||
{
|
{
|
||||||
[self.delegate audioQueueIsRunningDry:self];
|
[self.delegate audioQueueIsRunningDry:self];
|
||||||
|
|
||||||
|
@synchronized(self)
|
||||||
|
{
|
||||||
|
for(int c = 0; c < NumberOfStoredAudioQueueBuffer; c++)
|
||||||
|
{
|
||||||
|
if(!_storedBuffers[c] || buffer->mAudioDataBytesCapacity > _storedBuffers[c]->mAudioDataBytesCapacity)
|
||||||
|
{
|
||||||
|
if(_storedBuffers[c]) AudioQueueFreeBuffer(_audioQueue, _storedBuffers[c]);
|
||||||
|
_storedBuffers[c] = buffer;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
AudioQueueFreeBuffer(_audioQueue, buffer);
|
AudioQueueFreeBuffer(_audioQueue, buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -95,15 +111,31 @@ static void audioOutputCallback(
|
|||||||
|
|
||||||
- (void)enqueueAudioBuffer:(const int16_t *)buffer numberOfSamples:(size_t)lengthInSamples
|
- (void)enqueueAudioBuffer:(const int16_t *)buffer numberOfSamples:(size_t)lengthInSamples
|
||||||
{
|
{
|
||||||
AudioQueueBufferRef newBuffer;
|
|
||||||
size_t bufferBytes = lengthInSamples * sizeof(int16_t);
|
size_t bufferBytes = lengthInSamples * sizeof(int16_t);
|
||||||
|
|
||||||
AudioQueueAllocateBuffer(_audioQueue, (UInt32)bufferBytes, &newBuffer);
|
@synchronized(self)
|
||||||
|
{
|
||||||
|
for(int c = 0; c < NumberOfStoredAudioQueueBuffer; c++)
|
||||||
|
{
|
||||||
|
if(_storedBuffers[c] && _storedBuffers[c]->mAudioDataBytesCapacity >= bufferBytes)
|
||||||
|
{
|
||||||
|
memcpy(_storedBuffers[c]->mAudioData, buffer, bufferBytes);
|
||||||
|
_storedBuffers[c]->mAudioDataByteSize = (UInt32)bufferBytes;
|
||||||
|
|
||||||
|
AudioQueueEnqueueBuffer(_audioQueue, _storedBuffers[c], 0, NULL);
|
||||||
|
_storedBuffers[c] = NULL;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AudioQueueBufferRef newBuffer;
|
||||||
|
AudioQueueAllocateBuffer(_audioQueue, (UInt32)bufferBytes * 2, &newBuffer);
|
||||||
memcpy(newBuffer->mAudioData, buffer, bufferBytes);
|
memcpy(newBuffer->mAudioData, buffer, bufferBytes);
|
||||||
newBuffer->mAudioDataByteSize = (UInt32)bufferBytes;
|
newBuffer->mAudioDataByteSize = (UInt32)bufferBytes;
|
||||||
|
|
||||||
AudioQueueEnqueueBuffer(_audioQueue, newBuffer, 0, NULL);
|
AudioQueueEnqueueBuffer(_audioQueue, newBuffer, 0, NULL);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#pragma mark - Sampling Rate getters
|
#pragma mark - Sampling Rate getters
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user