libavcodec/libfdk-aacenc: send encoder delay/padding in packet side data

Signed-off-by: JonHGee <JonHGee@gmail.com>
Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
JonHGee 2023-02-28 23:08:10 +00:00 committed by Martin Storsjö
parent 083dde57e2
commit e026e29460

View File

@ -21,6 +21,7 @@
#include "libavutil/channel_layout.h" #include "libavutil/channel_layout.h"
#include "libavutil/common.h" #include "libavutil/common.h"
#include "libavutil/intreadwrite.h"
#include "libavutil/opt.h" #include "libavutil/opt.h"
#include "avcodec.h" #include "avcodec.h"
#include "audio_frame_queue.h" #include "audio_frame_queue.h"
@ -53,6 +54,7 @@ typedef struct AACContext {
int prog_ref; int prog_ref;
int metadata_mode; int metadata_mode;
AACENC_MetaData metaDataSetup; AACENC_MetaData metaDataSetup;
int delay_sent;
AudioFrameQueue afq; AudioFrameQueue afq;
} AACContext; } AACContext;
@ -406,7 +408,7 @@ static int aac_encode_frame(AVCodecContext *avctx, AVPacket *avpkt,
int out_buffer_identifier = OUT_BITSTREAM_DATA; int out_buffer_identifier = OUT_BITSTREAM_DATA;
int out_buffer_size, out_buffer_element_size; int out_buffer_size, out_buffer_element_size;
void *out_ptr; void *out_ptr;
int ret; int ret, discard_padding;
uint8_t dummy_buf[1]; uint8_t dummy_buf[1];
AACENC_ERROR err; AACENC_ERROR err;
@ -469,6 +471,27 @@ static int aac_encode_frame(AVCodecContext *avctx, AVPacket *avpkt,
ff_af_queue_remove(&s->afq, avctx->frame_size, &avpkt->pts, ff_af_queue_remove(&s->afq, avctx->frame_size, &avpkt->pts,
&avpkt->duration); &avpkt->duration);
discard_padding = avctx->frame_size - avpkt->duration;
// Check if subtraction resulted in an overflow
if ((discard_padding < avctx->frame_size) != (avpkt->duration > 0)) {
av_log(avctx, AV_LOG_ERROR, "discard padding overflow\n");
av_packet_unref(avpkt);
return AVERROR(EINVAL);
}
if ((!s->delay_sent && avctx->initial_padding > 0) || discard_padding > 0) {
uint8_t *side_data =
av_packet_new_side_data(avpkt, AV_PKT_DATA_SKIP_SAMPLES, 10);
if (!side_data) {
av_packet_unref(avpkt);
return AVERROR(ENOMEM);
}
if (!s->delay_sent) {
AV_WL32(side_data, avctx->initial_padding);
s->delay_sent = 1;
}
AV_WL32(side_data + 4, discard_padding);
}
avpkt->size = out_args.numOutBytes; avpkt->size = out_args.numOutBytes;
*got_packet_ptr = 1; *got_packet_ptr = 1;
return 0; return 0;