20 #include <fdk-aac/aacenc_lib.h>
32 #ifdef AACENCODER_LIB_VL0
33 #define FDKENC_VER_AT_LEAST(vl0, vl1) \
34 ((AACENCODER_LIB_VL0 > vl0) || \
35 (AACENCODER_LIB_VL0 == vl0 && AACENCODER_LIB_VL1 >= vl1))
37 #define FDKENC_VER_AT_LEAST(vl0, vl1) 0
65 {
"eld_sbr",
"Enable SBR for ELD (for SBR in other configurations, use the -profile parameter)", offsetof(
AACContext, eld_sbr),
AV_OPT_TYPE_INT, { .i64 = 0 }, 0, 1,
AV_OPT_FLAG_AUDIO_PARAM |
AV_OPT_FLAG_ENCODING_PARAM },
66 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
69 {
"signaling",
"SBR/PS signaling style", offsetof(
AACContext, signaling),
AV_OPT_TYPE_INT, { .i64 = -1 }, -1, 2,
AV_OPT_FLAG_AUDIO_PARAM |
AV_OPT_FLAG_ENCODING_PARAM,
"signaling" },
70 {
"default",
"Choose signaling implicitly (explicit hierarchical by default, implicit if global header is disabled)", 0,
AV_OPT_TYPE_CONST, { .i64 = -1 }, 0, 0,
AV_OPT_FLAG_AUDIO_PARAM |
AV_OPT_FLAG_ENCODING_PARAM,
"signaling" },
72 {
"explicit_sbr",
"Explicit SBR, implicit PS signaling", 0,
AV_OPT_TYPE_CONST, { .i64 = 1 }, 0, 0,
AV_OPT_FLAG_AUDIO_PARAM |
AV_OPT_FLAG_ENCODING_PARAM,
"signaling" },
99 case AACENC_INVALID_HANDLE:
100 return "Invalid handle";
101 case AACENC_MEMORY_ERROR:
102 return "Memory allocation error";
103 case AACENC_UNSUPPORTED_PARAMETER:
104 return "Unsupported parameter";
105 case AACENC_INVALID_CONFIG:
106 return "Invalid config";
107 case AACENC_INIT_ERROR:
108 return "Initialization error";
109 case AACENC_INIT_AAC_ERROR:
110 return "AAC library initialization error";
111 case AACENC_INIT_SBR_ERROR:
112 return "SBR library initialization error";
113 case AACENC_INIT_TP_ERROR:
114 return "Transport library initialization error";
115 case AACENC_INIT_META_ERROR:
116 return "Metadata library initialization error";
117 case AACENC_ENCODE_ERROR:
118 return "Encoding error";
119 case AACENC_ENCODE_EOF:
120 return "End of file";
122 return "Unknown error";
131 aacEncClose(&
s->handle);
140 AACENC_BufDesc in_buf = { 0 }, out_buf = { 0 };
141 AACENC_InArgs in_args = { 0 };
142 AACENC_OutArgs out_args;
144 uint8_t dummy_in[1], dummy_out[1];
145 int in_buffer_identifiers[] = { IN_AUDIO_DATA, IN_METADATA_SETUP };
146 int in_buffer_element_sizes[] = { 2,
sizeof(AACENC_MetaData) };
147 int in_buffer_sizes[] = { 0,
sizeof(
s->metaDataSetup) };
148 int out_buffer_identifier = OUT_BITSTREAM_DATA;
149 int out_buffer_size =
sizeof(dummy_out), out_buffer_element_size = 1;
150 void* inBuffer[] = { dummy_in, &
s->metaDataSetup };
151 void *out_ptr = dummy_out;
156 in_buf.bufs = (
void **)inBuffer;
157 in_buf.numBufs =
s->metadata_mode == 0 ? 1 : 2;
158 in_buf.bufferIdentifiers = in_buffer_identifiers;
159 in_buf.bufSizes = in_buffer_sizes;
160 in_buf.bufElSizes = in_buffer_element_sizes;
163 out_buf.bufs = &out_ptr;
164 out_buf.bufferIdentifiers = &out_buffer_identifier;
165 out_buf.bufSizes = &out_buffer_size;
166 out_buf.bufElSizes = &out_buffer_element_size;
168 err = aacEncEncode(
s->handle, &in_buf, &out_buf, &in_args, &out_args);
169 if (err != AACENC_OK) {
179 AACENC_InfoStruct
info = { 0 };
183 int sce = 0, cpe = 0;
194 if ((err = aacEncoder_SetParam(
s->handle, AACENC_AOT, aot)) != AACENC_OK) {
201 if ((err = aacEncoder_SetParam(
s->handle, AACENC_SBR_MODE,
209 if (
s->frame_length >= 0) {
210 if ((err = aacEncoder_SetParam(
s->handle, AACENC_GRANULE_LENGTH,
211 s->frame_length)) != AACENC_OK) {
218 if ((err = aacEncoder_SetParam(
s->handle, AACENC_SAMPLERATE,
226 case 1:
mode = MODE_1; sce = 1; cpe = 0;
break;
228 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
231 if ((err = aacEncoder_SetParam(
s->handle, AACENC_CHANNELMODE,
232 128)) != AACENC_OK) {
249 case 3:
mode = MODE_1_2; sce = 1; cpe = 1;
break;
250 case 4:
mode = MODE_1_2_1; sce = 2; cpe = 1;
break;
251 case 5:
mode = MODE_1_2_2; sce = 1; cpe = 2;
break;
252 case 6:
mode = MODE_1_2_2_1; sce = 2; cpe = 2;
break;
253 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
254 case 7:
mode = MODE_6_1; sce = 3; cpe = 2;
break;
258 #if FDKENC_VER_AT_LEAST(3, 4) // 3.4.12
263 mode = MODE_7_1_REAR_SURROUND;
264 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
266 mode = MODE_7_1_TOP_FRONT;
270 mode = MODE_7_1_FRONT_CENTER;
280 if ((err = aacEncoder_SetParam(
s->handle, AACENC_CHANNELMODE,
281 mode)) != AACENC_OK) {
287 if ((err = aacEncoder_SetParam(
s->handle, AACENC_CHANNELORDER,
290 "Unable to set wav channel order %d: %s\n",
299 "VBR quality %d out of range, should be 1-5\n",
mode);
303 "Note, the VBR setting is unsupported and only works with "
304 "some parameter combinations\n");
305 if ((err = aacEncoder_SetParam(
s->handle, AACENC_BITRATEMODE,
306 mode)) != AACENC_OK) {
324 if ((err = aacEncoder_SetParam(
s->handle, AACENC_BITRATE,
334 if ((err = aacEncoder_SetParam(
s->handle, AACENC_TRANSMUX,
336 s->latm ? TT_MP4_LOAS : TT_MP4_ADTS)) != AACENC_OK) {
342 if (
s->latm &&
s->header_period) {
343 if ((err = aacEncoder_SetParam(
s->handle, AACENC_HEADER_PERIOD,
344 s->header_period)) != AACENC_OK) {
354 if (
s->signaling < 0)
357 if ((err = aacEncoder_SetParam(
s->handle, AACENC_SIGNALING_MODE,
358 s->signaling)) != AACENC_OK) {
364 if ((err = aacEncoder_SetParam(
s->handle, AACENC_AFTERBURNER,
365 s->afterburner)) != AACENC_OK) {
377 if ((err = aacEncoder_SetParam(
s->handle, AACENC_BANDWIDTH,
378 avctx->
cutoff)) != AACENC_OK) {
385 s->metadata_mode = 0;
387 s->metadata_mode = 1;
388 s->metaDataSetup.prog_ref_level_present = 1;
389 s->metaDataSetup.prog_ref_level =
s->prog_ref << 16;
391 if (
s->drc_profile) {
392 s->metadata_mode = 1;
393 s->metaDataSetup.drc_profile =
s->drc_profile;
394 s->metaDataSetup.drc_TargetRefLevel =
s->drc_target_ref << 16;
395 if (
s->comp_profile) {
397 s->metadata_mode = 2;
398 s->metaDataSetup.comp_profile =
s->comp_profile;
399 s->metaDataSetup.comp_TargetRefLevel =
s->comp_target_ref << 16;
403 if ((err = aacEncoder_SetParam(
s->handle, AACENC_METADATA_MODE,
s->metadata_mode)) != AACENC_OK) {
415 if ((err = aacEncInfo(
s->handle, &
info)) != AACENC_OK) {
422 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
450 AACENC_BufDesc in_buf = { 0 }, out_buf = { 0 };
451 AACENC_InArgs in_args = { 0 };
452 AACENC_OutArgs out_args = { 0 };
453 void* inBuffer[] = { 0, &
s->metaDataSetup };
454 int in_buffer_identifiers[] = { IN_AUDIO_DATA, IN_METADATA_SETUP };
455 int in_buffer_element_sizes[] = { 2,
sizeof(AACENC_MetaData) };
456 int in_buffer_sizes[] = { 0,
sizeof(
s->metaDataSetup) };
457 int out_buffer_identifier = OUT_BITSTREAM_DATA;
458 int out_buffer_size, out_buffer_element_size;
460 int ret, discard_padding;
461 uint8_t dummy_buf[1];
468 inBuffer[0] = dummy_buf;
470 in_args.numInSamples = -1;
482 if (
s->metadata_mode == 0) {
488 in_buf.bufs = (
void**)inBuffer;
489 in_buf.bufferIdentifiers = in_buffer_identifiers;
490 in_buf.bufSizes = in_buffer_sizes;
491 in_buf.bufElSizes = in_buffer_element_sizes;
498 out_ptr = avpkt->
data;
499 out_buffer_size = avpkt->
size;
500 out_buffer_element_size = 1;
502 out_buf.bufs = &out_ptr;
503 out_buf.bufferIdentifiers = &out_buffer_identifier;
504 out_buf.bufSizes = &out_buffer_size;
505 out_buf.bufElSizes = &out_buffer_element_size;
507 if ((err = aacEncEncode(
s->handle, &in_buf, &out_buf, &in_args,
508 &out_args)) != AACENC_OK) {
509 if (!
frame && err == AACENC_ENCODE_EOF)
516 if (!out_args.numOutBytes)
529 if ((!
s->delay_sent && avctx->
initial_padding > 0) || discard_padding > 0) {
534 if (!
s->delay_sent) {
538 AV_WL32(side_data + 4, discard_padding);
541 avpkt->
size = out_args.numOutBytes;
560 #if FF_API_OLD_CHANNEL_LAYOUT
561 static const uint64_t aac_channel_layout[] = {
568 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
571 #if FDKENC_VER_AT_LEAST(3, 4) // 3.4.12
575 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
589 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
592 #if FDKENC_VER_AT_LEAST(3, 4) // 3.4.12
596 #if FDKENC_VER_AT_LEAST(4, 0) // 4.0.0
603 96000, 88200, 64000, 48000, 44100, 32000,
604 24000, 22050, 16000, 12000, 11025, 8000, 0
608 .
p.
name =
"libfdk_aac",
627 .p.wrapper_name =
"libfdk",