Commit 5482b9b0 authored by Philippe Coent's avatar Philippe Coent Committed by Felix Paul Kühne

AudioQueue: fixed compilation

Signed-off-by: default avatarFelix Paul Kühne <fkuehne@videolan.org>
parent a44507ac
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
#include <AudioToolBox/AudioToolBox.h> #include <AudioToolBox/AudioToolBox.h>
#define NUMBER_OF_BUFFERS 3 #define NUMBER_OF_BUFFERS 3
#define FRAME_SIZE 2048
/***************************************************************************** /*****************************************************************************
* aout_sys_t: AudioQueue audio output method descriptor * aout_sys_t: AudioQueue audio output method descriptor
...@@ -132,6 +133,22 @@ static int Open ( vlc_object_t *p_this ) ...@@ -132,6 +133,22 @@ static int Open ( vlc_object_t *p_this )
return VLC_SUCCESS; return VLC_SUCCESS;
} }
/*****************************************************************************
* aout_FifoPop : get the next buffer out of the FIFO
*****************************************************************************/
static aout_buffer_t *aout_FifoPop2( aout_fifo_t * p_fifo )
{
aout_buffer_t *p_buffer = p_fifo->p_first;
if( p_buffer != NULL )
{
p_fifo->p_first = p_buffer->p_next;
if( p_fifo->p_first == NULL )
p_fifo->pp_last = &p_fifo->p_first;
}
return p_buffer;
}
/***************************************************************************** /*****************************************************************************
* Close: close the audio device * Close: close the audio device
*****************************************************************************/ *****************************************************************************/
...@@ -153,9 +170,15 @@ void AudioQueueCallback(void * inUserData, AudioQueueRef inAQ, AudioQueueBufferR ...@@ -153,9 +170,15 @@ void AudioQueueCallback(void * inUserData, AudioQueueRef inAQ, AudioQueueBufferR
aout_buffer_t * p_buffer = NULL; aout_buffer_t * p_buffer = NULL;
if (p_aout) { if (p_aout) {
vlc_mutex_lock( &p_aout->lock ); struct aout_sys_t * p_sys = p_aout->sys;
p_buffer = aout_FifoPop( &p_aout->fifo ); aout_packet_t * packet = &p_sys->packet;
vlc_mutex_unlock( &p_aout->lock );
if (packet)
{
vlc_mutex_lock( &packet->lock );
p_buffer = aout_FifoPop2( &packet->fifo );
vlc_mutex_unlock( &packet->lock );
}
} }
if ( p_buffer != NULL ) { if ( p_buffer != NULL ) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment