]> git.sesse.net Git - vlc/commitdiff
auhal: don't leak audio data and avoid useless memcpy
authorDavid Fuhrmann <david.fuhrmann@googlemail.com>
Mon, 18 Feb 2013 18:09:55 +0000 (19:09 +0100)
committerDavid Fuhrmann <david.fuhrmann@googlemail.com>
Mon, 18 Feb 2013 18:27:26 +0000 (19:27 +0100)
modules/audio_output/auhal.c

index 292c451166ca5f7d83b65d37f200c01da4825527..d1f5eb141a14c024a092fb566b36894d8bf63fac 100644 (file)
@@ -1181,20 +1181,11 @@ static void Play (audio_output_t * p_aout, block_t * p_block)
                                VLC_CODEC_FL32);
         }
 
-        /* Render audio into buffer */
-        AudioBufferList bufferList;
-        bufferList.mNumberBuffers = 1;
-        bufferList.mBuffers[0].mNumberChannels = p_sys->i_numberOfChannels;
-        bufferList.mBuffers[0].mData = malloc(p_block->i_nb_samples * sizeof(Float32) * p_sys->i_numberOfChannels);
-        bufferList.mBuffers[0].mDataByteSize = p_block->i_nb_samples * sizeof(Float32) * p_sys->i_numberOfChannels;
-
-        memcpy(bufferList.mBuffers[0].mData, p_block->p_buffer, p_block->i_buffer);
-
         /* keep track of the played data */
         p_aout->sys->i_played_length += p_block->i_length;
 
         /* move data to buffer */
-        TPCircularBufferProduceBytes(&p_sys->circular_buffer, bufferList.mBuffers[0].mData, bufferList.mBuffers[0].mDataByteSize);
+        TPCircularBufferProduceBytes(&p_sys->circular_buffer, p_block->p_buffer, p_block->i_buffer);
     }
 
     block_Release(p_block);