Commit 40ade071 authored by Michael Niedermayer's avatar Michael Niedermayer

Merge commit '16ea20c8'

* commit '16ea20c8':
  lavc doxy: extend/clarify avcodec_decode_audio4() doxy
Merged-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parents 29d64b1d 16ea20c8
...@@ -3782,11 +3782,20 @@ attribute_deprecated int avcodec_decode_audio3(AVCodecContext *avctx, int16_t *s ...@@ -3782,11 +3782,20 @@ attribute_deprecated int avcodec_decode_audio3(AVCodecContext *avctx, int16_t *s
* Decode the audio frame of size avpkt->size from avpkt->data into frame. * Decode the audio frame of size avpkt->size from avpkt->data into frame.
* *
* Some decoders may support multiple frames in a single AVPacket. Such * Some decoders may support multiple frames in a single AVPacket. Such
* decoders would then just decode the first frame. In this case, * decoders would then just decode the first frame and the return value would be
* avcodec_decode_audio4 has to be called again with an AVPacket containing * less than the packet size. In this case, avcodec_decode_audio4 has to be
* the remaining data in order to decode the second frame, etc... * called again with an AVPacket containing the remaining data in order to
* Even if no frames are returned, the packet needs to be fed to the decoder * decode the second frame, etc... Even if no frames are returned, the packet
* with remaining data until it is completely consumed or an error occurs. * needs to be fed to the decoder with remaining data until it is completely
* consumed or an error occurs.
*
* Some decoders (those marked with CODEC_CAP_DELAY) have a delay between input
* and output. This means that for some packets they will not immediately
* produce decoded output and need to be flushed at the end of decoding to get
* all the decoded data. Flushing is done by calling this function with packets
* with avpkt->data set to NULL and avpkt->size set to 0 until it stops
* returning samples. It is safe to flush even those decoders that are not
* marked with CODEC_CAP_DELAY, then no samples will be returned.
* *
* @warning The input buffer, avpkt->data must be FF_INPUT_BUFFER_PADDING_SIZE * @warning The input buffer, avpkt->data must be FF_INPUT_BUFFER_PADDING_SIZE
* larger than the actual read bytes because some optimized bitstream * larger than the actual read bytes because some optimized bitstream
...@@ -3806,7 +3815,10 @@ attribute_deprecated int avcodec_decode_audio3(AVCodecContext *avctx, int16_t *s ...@@ -3806,7 +3815,10 @@ attribute_deprecated int avcodec_decode_audio3(AVCodecContext *avctx, int16_t *s
* next call to this function or until closing or flushing the * next call to this function or until closing or flushing the
* decoder. The caller may not write to it. * decoder. The caller may not write to it.
* @param[out] got_frame_ptr Zero if no frame could be decoded, otherwise it is * @param[out] got_frame_ptr Zero if no frame could be decoded, otherwise it is
* non-zero. * non-zero. Note that this field being set to zero
* does not mean that an error has occurred. For
* decoders with CODEC_CAP_DELAY set, no given decode
* call is guaranteed to produce a frame.
* @param[in] avpkt The input AVPacket containing the input buffer. * @param[in] avpkt The input AVPacket containing the input buffer.
* At least avpkt->data and avpkt->size should be set. Some * At least avpkt->data and avpkt->size should be set. Some
* decoders might also require additional fields to be set. * decoders might also require additional fields to be set.
......
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