mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-08 13:22:53 +02:00
ac3enc: add support for E-AC-3 encoding.
This adds basic stream format support and allows for arbitrary bit rates rather than just those supported in AC-3.
This commit is contained in:
parent
b1bf8c7887
commit
aa47c35dff
@ -4,6 +4,8 @@ releases are sorted from youngest to oldest.
|
|||||||
|
|
||||||
version <next>:
|
version <next>:
|
||||||
|
|
||||||
|
- E-AC-3 audio encoder
|
||||||
|
|
||||||
|
|
||||||
version 0.7_beta2:
|
version 0.7_beta2:
|
||||||
|
|
||||||
|
1
configure
vendored
1
configure
vendored
@ -1261,6 +1261,7 @@ dca_decoder_select="mdct"
|
|||||||
dnxhd_encoder_select="aandct"
|
dnxhd_encoder_select="aandct"
|
||||||
dxa_decoder_select="zlib"
|
dxa_decoder_select="zlib"
|
||||||
eac3_decoder_select="ac3_decoder"
|
eac3_decoder_select="ac3_decoder"
|
||||||
|
eac3_encoder_select="mdct ac3dsp"
|
||||||
eamad_decoder_select="aandct"
|
eamad_decoder_select="aandct"
|
||||||
eatgq_decoder_select="aandct"
|
eatgq_decoder_select="aandct"
|
||||||
eatqi_decoder_select="aandct"
|
eatqi_decoder_select="aandct"
|
||||||
|
@ -614,7 +614,7 @@ following image formats are supported:
|
|||||||
@tab Used in Origin's Wing Commander IV AVI files.
|
@tab Used in Origin's Wing Commander IV AVI files.
|
||||||
@item DSP Group TrueSpeech @tab @tab X
|
@item DSP Group TrueSpeech @tab @tab X
|
||||||
@item DV audio @tab @tab X
|
@item DV audio @tab @tab X
|
||||||
@item Enhanced AC-3 @tab @tab X
|
@item Enhanced AC-3 @tab X @tab X
|
||||||
@item FLAC (Free Lossless Audio Codec) @tab X @tab IX
|
@item FLAC (Free Lossless Audio Codec) @tab X @tab IX
|
||||||
@item GSM @tab E @tab X
|
@item GSM @tab E @tab X
|
||||||
@tab encoding supported through external library libgsm
|
@tab encoding supported through external library libgsm
|
||||||
|
@ -124,6 +124,7 @@ OBJS-$(CONFIG_DVVIDEO_DECODER) += dv.o dvdata.o
|
|||||||
OBJS-$(CONFIG_DVVIDEO_ENCODER) += dv.o dvdata.o
|
OBJS-$(CONFIG_DVVIDEO_ENCODER) += dv.o dvdata.o
|
||||||
OBJS-$(CONFIG_DXA_DECODER) += dxa.o
|
OBJS-$(CONFIG_DXA_DECODER) += dxa.o
|
||||||
OBJS-$(CONFIG_EAC3_DECODER) += eac3dec.o eac3dec_data.o
|
OBJS-$(CONFIG_EAC3_DECODER) += eac3dec.o eac3dec_data.o
|
||||||
|
OBJS-$(CONFIG_EAC3_ENCODER) += ac3enc_float.o ac3tab.o ac3.o kbdwin.o
|
||||||
OBJS-$(CONFIG_EACMV_DECODER) += eacmv.o
|
OBJS-$(CONFIG_EACMV_DECODER) += eacmv.o
|
||||||
OBJS-$(CONFIG_EAMAD_DECODER) += eamad.o eaidct.o mpeg12.o \
|
OBJS-$(CONFIG_EAMAD_DECODER) += eamad.o eaidct.o mpeg12.o \
|
||||||
mpeg12data.o mpegvideo.o \
|
mpeg12data.o mpegvideo.o \
|
||||||
|
@ -147,6 +147,7 @@ typedef struct AC3EncodeContext {
|
|||||||
|
|
||||||
AC3Block blocks[AC3_MAX_BLOCKS]; ///< per-block info
|
AC3Block blocks[AC3_MAX_BLOCKS]; ///< per-block info
|
||||||
|
|
||||||
|
int eac3; ///< indicates if this is E-AC-3 vs. AC-3
|
||||||
int bitstream_id; ///< bitstream id (bsid)
|
int bitstream_id; ///< bitstream id (bsid)
|
||||||
int bitstream_mode; ///< bitstream mode (bsmod)
|
int bitstream_mode; ///< bitstream mode (bsmod)
|
||||||
|
|
||||||
@ -157,8 +158,8 @@ typedef struct AC3EncodeContext {
|
|||||||
int frame_size; ///< current frame size in bytes
|
int frame_size; ///< current frame size in bytes
|
||||||
int frame_size_code; ///< frame size code (frmsizecod)
|
int frame_size_code; ///< frame size code (frmsizecod)
|
||||||
uint16_t crc_inv[2];
|
uint16_t crc_inv[2];
|
||||||
int bits_written; ///< bit count (used to avg. bitrate)
|
int64_t bits_written; ///< bit count (used to avg. bitrate)
|
||||||
int samples_written; ///< sample count (used to avg. bitrate)
|
int64_t samples_written; ///< sample count (used to avg. bitrate)
|
||||||
|
|
||||||
int fbw_channels; ///< number of full-bandwidth channels (nfchans)
|
int fbw_channels; ///< number of full-bandwidth channels (nfchans)
|
||||||
int channels; ///< total number of channels (nchans)
|
int channels; ///< total number of channels (nchans)
|
||||||
@ -247,15 +248,20 @@ static const float extmixlev_options[EXTMIXLEV_NUM_OPTIONS] = {
|
|||||||
#define OFFSET(param) offsetof(AC3EncodeContext, options.param)
|
#define OFFSET(param) offsetof(AC3EncodeContext, options.param)
|
||||||
#define AC3ENC_PARAM (AV_OPT_FLAG_AUDIO_PARAM | AV_OPT_FLAG_ENCODING_PARAM)
|
#define AC3ENC_PARAM (AV_OPT_FLAG_AUDIO_PARAM | AV_OPT_FLAG_ENCODING_PARAM)
|
||||||
|
|
||||||
|
|
||||||
#define AC3ENC_TYPE_AC3_FIXED 0
|
#define AC3ENC_TYPE_AC3_FIXED 0
|
||||||
#define AC3ENC_TYPE_AC3 1
|
#define AC3ENC_TYPE_AC3 1
|
||||||
|
#define AC3ENC_TYPE_EAC3 2
|
||||||
|
|
||||||
#if CONFIG_AC3ENC_FLOAT
|
#if CONFIG_AC3ENC_FLOAT
|
||||||
#define AC3ENC_TYPE AC3ENC_TYPE_AC3
|
#define AC3ENC_TYPE AC3ENC_TYPE_AC3
|
||||||
#include "ac3enc_opts_template.c"
|
#include "ac3enc_opts_template.c"
|
||||||
static AVClass ac3enc_class = { "AC-3 Encoder", av_default_item_name,
|
static AVClass ac3enc_class = { "AC-3 Encoder", av_default_item_name,
|
||||||
ac3_options, LIBAVUTIL_VERSION_INT };
|
ac3_options, LIBAVUTIL_VERSION_INT };
|
||||||
|
#undef AC3ENC_TYPE
|
||||||
|
#define AC3ENC_TYPE AC3ENC_TYPE_EAC3
|
||||||
|
#include "ac3enc_opts_template.c"
|
||||||
|
static AVClass eac3enc_class = { "E-AC-3 Encoder", av_default_item_name,
|
||||||
|
eac3_options, LIBAVUTIL_VERSION_INT };
|
||||||
#else
|
#else
|
||||||
#define AC3ENC_TYPE AC3ENC_TYPE_AC3_FIXED
|
#define AC3ENC_TYPE AC3ENC_TYPE_AC3_FIXED
|
||||||
#include "ac3enc_opts_template.c"
|
#include "ac3enc_opts_template.c"
|
||||||
@ -387,7 +393,7 @@ static const int8_t ac3_coupling_start_tab[6][3][19] = {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Adjust the frame size to make the average bit rate match the target bit rate.
|
* Adjust the frame size to make the average bit rate match the target bit rate.
|
||||||
* This is only needed for 11025, 22050, and 44100 sample rates.
|
* This is only needed for 11025, 22050, and 44100 sample rates or any E-AC-3.
|
||||||
*/
|
*/
|
||||||
static void adjust_frame_size(AC3EncodeContext *s)
|
static void adjust_frame_size(AC3EncodeContext *s)
|
||||||
{
|
{
|
||||||
@ -734,6 +740,35 @@ static void apply_channel_coupling(AC3EncodeContext *s)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (s->eac3) {
|
||||||
|
/* set first cpl coords */
|
||||||
|
int first_cpl_coords[AC3_MAX_CHANNELS];
|
||||||
|
for (ch = 1; ch <= s->fbw_channels; ch++)
|
||||||
|
first_cpl_coords[ch] = 1;
|
||||||
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++) {
|
||||||
|
AC3Block *block = &s->blocks[blk];
|
||||||
|
for (ch = 1; ch <= s->fbw_channels; ch++) {
|
||||||
|
if (block->channel_in_cpl[ch]) {
|
||||||
|
if (first_cpl_coords[ch]) {
|
||||||
|
block->new_cpl_coords = 2;
|
||||||
|
first_cpl_coords[ch] = 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
first_cpl_coords[ch] = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* set first cpl leak */
|
||||||
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++) {
|
||||||
|
AC3Block *block = &s->blocks[blk];
|
||||||
|
if (block->cpl_in_use) {
|
||||||
|
block->new_cpl_leak = 2;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
#endif /* CONFIG_AC3ENC_FLOAT */
|
#endif /* CONFIG_AC3ENC_FLOAT */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1151,23 +1186,50 @@ static void count_frame_bits_fixed(AC3EncodeContext *s)
|
|||||||
* no delta bit allocation
|
* no delta bit allocation
|
||||||
* no skipped data
|
* no skipped data
|
||||||
* no auxilliary data
|
* no auxilliary data
|
||||||
|
* no E-AC-3 metadata
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* header */
|
/* header */
|
||||||
frame_bits = 65;
|
frame_bits = 16; /* sync info */
|
||||||
frame_bits += frame_bits_inc[s->channel_mode];
|
if (s->eac3) {
|
||||||
|
/* bitstream info header */
|
||||||
|
frame_bits += 35;
|
||||||
|
frame_bits += 1 + 1 + 1;
|
||||||
|
/* audio frame header */
|
||||||
|
frame_bits += 2;
|
||||||
|
frame_bits += 10;
|
||||||
|
/* exponent strategy */
|
||||||
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++)
|
||||||
|
frame_bits += 2 * s->fbw_channels + s->lfe_on;
|
||||||
|
/* converter exponent strategy */
|
||||||
|
frame_bits += s->fbw_channels * 5;
|
||||||
|
/* snr offsets */
|
||||||
|
frame_bits += 10;
|
||||||
|
/* block start info */
|
||||||
|
frame_bits++;
|
||||||
|
} else {
|
||||||
|
frame_bits += 49;
|
||||||
|
frame_bits += frame_bits_inc[s->channel_mode];
|
||||||
|
}
|
||||||
|
|
||||||
/* audio blocks */
|
/* audio blocks */
|
||||||
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++) {
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++) {
|
||||||
|
if (!s->eac3) {
|
||||||
/* block switch flags */
|
/* block switch flags */
|
||||||
frame_bits += s->fbw_channels;
|
frame_bits += s->fbw_channels;
|
||||||
|
|
||||||
/* dither flags */
|
/* dither flags */
|
||||||
frame_bits += s->fbw_channels;
|
frame_bits += s->fbw_channels;
|
||||||
|
}
|
||||||
|
|
||||||
/* dynamic range */
|
/* dynamic range */
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
|
|
||||||
|
/* spectral extension */
|
||||||
|
if (s->eac3)
|
||||||
|
frame_bits++;
|
||||||
|
|
||||||
|
if (!s->eac3) {
|
||||||
/* exponent strategy */
|
/* exponent strategy */
|
||||||
frame_bits += 2 * s->fbw_channels;
|
frame_bits += 2 * s->fbw_channels;
|
||||||
if (s->lfe_on)
|
if (s->lfe_on)
|
||||||
@ -1177,12 +1239,19 @@ static void count_frame_bits_fixed(AC3EncodeContext *s)
|
|||||||
frame_bits++;
|
frame_bits++;
|
||||||
if (!blk)
|
if (!blk)
|
||||||
frame_bits += 2 + 2 + 2 + 2 + 3;
|
frame_bits += 2 + 2 + 2 + 2 + 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* converter snr offset */
|
||||||
|
if (s->eac3)
|
||||||
|
frame_bits++;
|
||||||
|
|
||||||
|
if (!s->eac3) {
|
||||||
/* delta bit allocation */
|
/* delta bit allocation */
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
|
|
||||||
/* skipped data */
|
/* skipped data */
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* auxiliary data */
|
/* auxiliary data */
|
||||||
@ -1207,7 +1276,7 @@ static void bit_alloc_init(AC3EncodeContext *s)
|
|||||||
s->slow_decay_code = 2;
|
s->slow_decay_code = 2;
|
||||||
s->fast_decay_code = 1;
|
s->fast_decay_code = 1;
|
||||||
s->slow_gain_code = 1;
|
s->slow_gain_code = 1;
|
||||||
s->db_per_bit_code = 3;
|
s->db_per_bit_code = s->eac3 ? 2 : 3;
|
||||||
s->floor_code = 7;
|
s->floor_code = 7;
|
||||||
for (ch = 0; ch <= s->channels; ch++)
|
for (ch = 0; ch <= s->channels; ch++)
|
||||||
s->fast_gain_code[ch] = 4;
|
s->fast_gain_code[ch] = 4;
|
||||||
@ -1242,6 +1311,21 @@ static void count_frame_bits(AC3EncodeContext *s)
|
|||||||
int frame_bits = 0;
|
int frame_bits = 0;
|
||||||
|
|
||||||
/* header */
|
/* header */
|
||||||
|
if (s->eac3) {
|
||||||
|
/* coupling */
|
||||||
|
if (s->channel_mode > AC3_CHMODE_MONO) {
|
||||||
|
frame_bits++;
|
||||||
|
for (blk = 1; blk < AC3_MAX_BLOCKS; blk++) {
|
||||||
|
AC3Block *block = &s->blocks[blk];
|
||||||
|
frame_bits++;
|
||||||
|
if (block->new_cpl_strategy)
|
||||||
|
frame_bits++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* coupling exponent strategy */
|
||||||
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++)
|
||||||
|
frame_bits += 2 * s->blocks[blk].cpl_in_use;
|
||||||
|
} else {
|
||||||
if (opt->audio_production_info)
|
if (opt->audio_production_info)
|
||||||
frame_bits += 7;
|
frame_bits += 7;
|
||||||
if (s->bitstream_id == 6) {
|
if (s->bitstream_id == 6) {
|
||||||
@ -1250,20 +1334,29 @@ static void count_frame_bits(AC3EncodeContext *s)
|
|||||||
if (opt->extended_bsi_2)
|
if (opt->extended_bsi_2)
|
||||||
frame_bits += 14;
|
frame_bits += 14;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* audio blocks */
|
/* audio blocks */
|
||||||
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++) {
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++) {
|
||||||
AC3Block *block = &s->blocks[blk];
|
AC3Block *block = &s->blocks[blk];
|
||||||
|
|
||||||
/* coupling strategy */
|
/* coupling strategy */
|
||||||
|
if (!s->eac3)
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
if (block->new_cpl_strategy) {
|
if (block->new_cpl_strategy) {
|
||||||
|
if (!s->eac3)
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
if (block->cpl_in_use) {
|
if (block->cpl_in_use) {
|
||||||
|
if (s->eac3)
|
||||||
|
frame_bits++;
|
||||||
|
if (!s->eac3 || s->channel_mode != AC3_CHMODE_STEREO)
|
||||||
frame_bits += s->fbw_channels;
|
frame_bits += s->fbw_channels;
|
||||||
if (s->channel_mode == AC3_CHMODE_STEREO)
|
if (s->channel_mode == AC3_CHMODE_STEREO)
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
frame_bits += 4 + 4;
|
frame_bits += 4 + 4;
|
||||||
|
if (s->eac3)
|
||||||
|
frame_bits++;
|
||||||
|
else
|
||||||
frame_bits += s->num_cpl_subbands - 1;
|
frame_bits += s->num_cpl_subbands - 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1272,6 +1365,7 @@ static void count_frame_bits(AC3EncodeContext *s)
|
|||||||
if (block->cpl_in_use) {
|
if (block->cpl_in_use) {
|
||||||
for (ch = 1; ch <= s->fbw_channels; ch++) {
|
for (ch = 1; ch <= s->fbw_channels; ch++) {
|
||||||
if (block->channel_in_cpl[ch]) {
|
if (block->channel_in_cpl[ch]) {
|
||||||
|
if (!s->eac3 || block->new_cpl_coords != 2)
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
if (block->new_cpl_coords) {
|
if (block->new_cpl_coords) {
|
||||||
frame_bits += 2;
|
frame_bits += 2;
|
||||||
@ -1283,6 +1377,7 @@ static void count_frame_bits(AC3EncodeContext *s)
|
|||||||
|
|
||||||
/* stereo rematrixing */
|
/* stereo rematrixing */
|
||||||
if (s->channel_mode == AC3_CHMODE_STEREO) {
|
if (s->channel_mode == AC3_CHMODE_STEREO) {
|
||||||
|
if (!s->eac3 || blk > 0)
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
if (s->blocks[blk].new_rematrixing_strategy)
|
if (s->blocks[blk].new_rematrixing_strategy)
|
||||||
frame_bits += block->num_rematrixing_bands;
|
frame_bits += block->num_rematrixing_bands;
|
||||||
@ -1298,16 +1393,19 @@ static void count_frame_bits(AC3EncodeContext *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* coupling exponent strategy */
|
/* coupling exponent strategy */
|
||||||
if (block->cpl_in_use)
|
if (!s->eac3 && block->cpl_in_use)
|
||||||
frame_bits += 2;
|
frame_bits += 2;
|
||||||
|
|
||||||
/* snr offsets and fast gain codes */
|
/* snr offsets and fast gain codes */
|
||||||
|
if (!s->eac3) {
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
if (block->new_snr_offsets)
|
if (block->new_snr_offsets)
|
||||||
frame_bits += 6 + (s->channels + block->cpl_in_use) * (4 + 3);
|
frame_bits += 6 + (s->channels + block->cpl_in_use) * (4 + 3);
|
||||||
|
}
|
||||||
|
|
||||||
/* coupling leak info */
|
/* coupling leak info */
|
||||||
if (block->cpl_in_use) {
|
if (block->cpl_in_use) {
|
||||||
|
if (!s->eac3 || block->new_cpl_leak != 2)
|
||||||
frame_bits++;
|
frame_bits++;
|
||||||
if (block->new_cpl_leak)
|
if (block->new_cpl_leak)
|
||||||
frame_bits += 3 + 3;
|
frame_bits += 3 + 3;
|
||||||
@ -1736,7 +1834,7 @@ static void quantize_mantissas(AC3EncodeContext *s)
|
|||||||
/**
|
/**
|
||||||
* Write the AC-3 frame header to the output bitstream.
|
* Write the AC-3 frame header to the output bitstream.
|
||||||
*/
|
*/
|
||||||
static void output_frame_header(AC3EncodeContext *s)
|
static void ac3_output_frame_header(AC3EncodeContext *s)
|
||||||
{
|
{
|
||||||
AC3EncOptions *opt = &s->options;
|
AC3EncOptions *opt = &s->options;
|
||||||
|
|
||||||
@ -1789,6 +1887,79 @@ static void output_frame_header(AC3EncodeContext *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write the E-AC-3 frame header to the output bitstream.
|
||||||
|
*/
|
||||||
|
static void eac3_output_frame_header(AC3EncodeContext *s)
|
||||||
|
{
|
||||||
|
int blk, ch;
|
||||||
|
AC3EncOptions *opt = &s->options;
|
||||||
|
|
||||||
|
put_bits(&s->pb, 16, 0x0b77); /* sync word */
|
||||||
|
|
||||||
|
/* BSI header */
|
||||||
|
put_bits(&s->pb, 2, 0); /* stream type = independent */
|
||||||
|
put_bits(&s->pb, 3, 0); /* substream id = 0 */
|
||||||
|
put_bits(&s->pb, 11, (s->frame_size / 2) - 1); /* frame size */
|
||||||
|
if (s->bit_alloc.sr_shift) {
|
||||||
|
put_bits(&s->pb, 2, 0x3); /* fscod2 */
|
||||||
|
put_bits(&s->pb, 2, s->bit_alloc.sr_code); /* sample rate code */
|
||||||
|
} else {
|
||||||
|
put_bits(&s->pb, 2, s->bit_alloc.sr_code); /* sample rate code */
|
||||||
|
put_bits(&s->pb, 2, 0x3); /* number of blocks = 6 */
|
||||||
|
}
|
||||||
|
put_bits(&s->pb, 3, s->channel_mode); /* audio coding mode */
|
||||||
|
put_bits(&s->pb, 1, s->lfe_on); /* LFE channel indicator */
|
||||||
|
put_bits(&s->pb, 5, s->bitstream_id); /* bitstream id (EAC3=16) */
|
||||||
|
put_bits(&s->pb, 5, -opt->dialogue_level); /* dialogue normalization level */
|
||||||
|
put_bits(&s->pb, 1, 0); /* no compression gain */
|
||||||
|
put_bits(&s->pb, 1, 0); /* no mixing metadata */
|
||||||
|
/* TODO: mixing metadata */
|
||||||
|
put_bits(&s->pb, 1, 0); /* no info metadata */
|
||||||
|
/* TODO: info metadata */
|
||||||
|
put_bits(&s->pb, 1, 0); /* no additional bit stream info */
|
||||||
|
|
||||||
|
/* frame header */
|
||||||
|
put_bits(&s->pb, 1, 1); /* exponent strategy syntax = each block */
|
||||||
|
put_bits(&s->pb, 1, 0); /* aht enabled = no */
|
||||||
|
put_bits(&s->pb, 2, 0); /* snr offset strategy = 1 */
|
||||||
|
put_bits(&s->pb, 1, 0); /* transient pre-noise processing enabled = no */
|
||||||
|
put_bits(&s->pb, 1, 0); /* block switch syntax enabled = no */
|
||||||
|
put_bits(&s->pb, 1, 0); /* dither flag syntax enabled = no */
|
||||||
|
put_bits(&s->pb, 1, 0); /* bit allocation model syntax enabled = no */
|
||||||
|
put_bits(&s->pb, 1, 0); /* fast gain codes enabled = no */
|
||||||
|
put_bits(&s->pb, 1, 0); /* dba syntax enabled = no */
|
||||||
|
put_bits(&s->pb, 1, 0); /* skip field syntax enabled = no */
|
||||||
|
put_bits(&s->pb, 1, 0); /* spx enabled = no */
|
||||||
|
/* coupling strategy use flags */
|
||||||
|
if (s->channel_mode > AC3_CHMODE_MONO) {
|
||||||
|
put_bits(&s->pb, 1, s->blocks[0].cpl_in_use);
|
||||||
|
for (blk = 1; blk < AC3_MAX_BLOCKS; blk++) {
|
||||||
|
AC3Block *block = &s->blocks[blk];
|
||||||
|
put_bits(&s->pb, 1, block->new_cpl_strategy);
|
||||||
|
if (block->new_cpl_strategy)
|
||||||
|
put_bits(&s->pb, 1, block->cpl_in_use);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
/* exponent strategy */
|
||||||
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++)
|
||||||
|
for (ch = !s->blocks[blk].cpl_in_use; ch <= s->fbw_channels; ch++)
|
||||||
|
put_bits(&s->pb, 2, s->exp_strategy[ch][blk]);
|
||||||
|
if (s->lfe_on) {
|
||||||
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++)
|
||||||
|
put_bits(&s->pb, 1, s->exp_strategy[s->lfe_channel][blk]);
|
||||||
|
}
|
||||||
|
/* E-AC-3 to AC-3 converter exponent strategy (unfortunately not optional...) */
|
||||||
|
for (ch = 1; ch <= s->fbw_channels; ch++)
|
||||||
|
put_bits(&s->pb, 5, 0);
|
||||||
|
/* snr offsets */
|
||||||
|
put_bits(&s->pb, 6, s->coarse_snr_offset);
|
||||||
|
put_bits(&s->pb, 4, s->fine_snr_offset[1]);
|
||||||
|
/* block start info */
|
||||||
|
put_bits(&s->pb, 1, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Write one audio block to the output bitstream.
|
* Write one audio block to the output bitstream.
|
||||||
*/
|
*/
|
||||||
@ -1799,32 +1970,51 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
AC3Block *block = &s->blocks[blk];
|
AC3Block *block = &s->blocks[blk];
|
||||||
|
|
||||||
/* block switching */
|
/* block switching */
|
||||||
|
if (!s->eac3) {
|
||||||
for (ch = 0; ch < s->fbw_channels; ch++)
|
for (ch = 0; ch < s->fbw_channels; ch++)
|
||||||
put_bits(&s->pb, 1, 0);
|
put_bits(&s->pb, 1, 0);
|
||||||
|
}
|
||||||
|
|
||||||
/* dither flags */
|
/* dither flags */
|
||||||
|
if (!s->eac3) {
|
||||||
for (ch = 0; ch < s->fbw_channels; ch++)
|
for (ch = 0; ch < s->fbw_channels; ch++)
|
||||||
put_bits(&s->pb, 1, 1);
|
put_bits(&s->pb, 1, 1);
|
||||||
|
}
|
||||||
|
|
||||||
/* dynamic range codes */
|
/* dynamic range codes */
|
||||||
put_bits(&s->pb, 1, 0);
|
put_bits(&s->pb, 1, 0);
|
||||||
|
|
||||||
|
/* spectral extension */
|
||||||
|
if (s->eac3)
|
||||||
|
put_bits(&s->pb, 1, 0);
|
||||||
|
|
||||||
/* channel coupling */
|
/* channel coupling */
|
||||||
|
if (!s->eac3)
|
||||||
put_bits(&s->pb, 1, block->new_cpl_strategy);
|
put_bits(&s->pb, 1, block->new_cpl_strategy);
|
||||||
if (block->new_cpl_strategy) {
|
if (block->new_cpl_strategy) {
|
||||||
|
if (!s->eac3)
|
||||||
put_bits(&s->pb, 1, block->cpl_in_use);
|
put_bits(&s->pb, 1, block->cpl_in_use);
|
||||||
if (block->cpl_in_use) {
|
if (block->cpl_in_use) {
|
||||||
int start_sub, end_sub;
|
int start_sub, end_sub;
|
||||||
|
if (s->eac3)
|
||||||
|
put_bits(&s->pb, 1, 0); /* enhanced coupling */
|
||||||
|
if (!s->eac3 || s->channel_mode != AC3_CHMODE_STEREO) {
|
||||||
for (ch = 1; ch <= s->fbw_channels; ch++)
|
for (ch = 1; ch <= s->fbw_channels; ch++)
|
||||||
put_bits(&s->pb, 1, block->channel_in_cpl[ch]);
|
put_bits(&s->pb, 1, block->channel_in_cpl[ch]);
|
||||||
|
}
|
||||||
if (s->channel_mode == AC3_CHMODE_STEREO)
|
if (s->channel_mode == AC3_CHMODE_STEREO)
|
||||||
put_bits(&s->pb, 1, 0); /* phase flags in use */
|
put_bits(&s->pb, 1, 0); /* phase flags in use */
|
||||||
start_sub = (s->start_freq[CPL_CH] - 37) / 12;
|
start_sub = (s->start_freq[CPL_CH] - 37) / 12;
|
||||||
end_sub = (s->cpl_end_freq - 37) / 12;
|
end_sub = (s->cpl_end_freq - 37) / 12;
|
||||||
put_bits(&s->pb, 4, start_sub);
|
put_bits(&s->pb, 4, start_sub);
|
||||||
put_bits(&s->pb, 4, end_sub - 3);
|
put_bits(&s->pb, 4, end_sub - 3);
|
||||||
|
/* coupling band structure */
|
||||||
|
if (s->eac3) {
|
||||||
|
put_bits(&s->pb, 1, 0); /* use default */
|
||||||
|
} else {
|
||||||
for (bnd = start_sub+1; bnd < end_sub; bnd++)
|
for (bnd = start_sub+1; bnd < end_sub; bnd++)
|
||||||
put_bits(&s->pb, 1, ff_eac3_default_cpl_band_struct[bnd]);
|
put_bits(&s->pb, 1, ff_eac3_default_cpl_band_struct[bnd]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1832,6 +2022,7 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
if (block->cpl_in_use) {
|
if (block->cpl_in_use) {
|
||||||
for (ch = 1; ch <= s->fbw_channels; ch++) {
|
for (ch = 1; ch <= s->fbw_channels; ch++) {
|
||||||
if (block->channel_in_cpl[ch]) {
|
if (block->channel_in_cpl[ch]) {
|
||||||
|
if (!s->eac3 || block->new_cpl_coords != 2)
|
||||||
put_bits(&s->pb, 1, block->new_cpl_coords);
|
put_bits(&s->pb, 1, block->new_cpl_coords);
|
||||||
if (block->new_cpl_coords) {
|
if (block->new_cpl_coords) {
|
||||||
put_bits(&s->pb, 2, block->cpl_master_exp[ch]);
|
put_bits(&s->pb, 2, block->cpl_master_exp[ch]);
|
||||||
@ -1846,6 +2037,7 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
|
|
||||||
/* stereo rematrixing */
|
/* stereo rematrixing */
|
||||||
if (s->channel_mode == AC3_CHMODE_STEREO) {
|
if (s->channel_mode == AC3_CHMODE_STEREO) {
|
||||||
|
if (!s->eac3 || blk > 0)
|
||||||
put_bits(&s->pb, 1, block->new_rematrixing_strategy);
|
put_bits(&s->pb, 1, block->new_rematrixing_strategy);
|
||||||
if (block->new_rematrixing_strategy) {
|
if (block->new_rematrixing_strategy) {
|
||||||
/* rematrixing flags */
|
/* rematrixing flags */
|
||||||
@ -1855,10 +2047,12 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* exponent strategy */
|
/* exponent strategy */
|
||||||
|
if (!s->eac3) {
|
||||||
for (ch = !block->cpl_in_use; ch <= s->fbw_channels; ch++)
|
for (ch = !block->cpl_in_use; ch <= s->fbw_channels; ch++)
|
||||||
put_bits(&s->pb, 2, s->exp_strategy[ch][blk]);
|
put_bits(&s->pb, 2, s->exp_strategy[ch][blk]);
|
||||||
if (s->lfe_on)
|
if (s->lfe_on)
|
||||||
put_bits(&s->pb, 1, s->exp_strategy[s->lfe_channel][blk]);
|
put_bits(&s->pb, 1, s->exp_strategy[s->lfe_channel][blk]);
|
||||||
|
}
|
||||||
|
|
||||||
/* bandwidth */
|
/* bandwidth */
|
||||||
for (ch = 1; ch <= s->fbw_channels; ch++) {
|
for (ch = 1; ch <= s->fbw_channels; ch++) {
|
||||||
@ -1888,6 +2082,7 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* bit allocation info */
|
/* bit allocation info */
|
||||||
|
if (!s->eac3) {
|
||||||
baie = (blk == 0);
|
baie = (blk == 0);
|
||||||
put_bits(&s->pb, 1, baie);
|
put_bits(&s->pb, 1, baie);
|
||||||
if (baie) {
|
if (baie) {
|
||||||
@ -1897,8 +2092,10 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
put_bits(&s->pb, 2, s->db_per_bit_code);
|
put_bits(&s->pb, 2, s->db_per_bit_code);
|
||||||
put_bits(&s->pb, 3, s->floor_code);
|
put_bits(&s->pb, 3, s->floor_code);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* snr offset */
|
/* snr offset */
|
||||||
|
if (!s->eac3) {
|
||||||
put_bits(&s->pb, 1, block->new_snr_offsets);
|
put_bits(&s->pb, 1, block->new_snr_offsets);
|
||||||
if (block->new_snr_offsets) {
|
if (block->new_snr_offsets) {
|
||||||
put_bits(&s->pb, 6, s->coarse_snr_offset);
|
put_bits(&s->pb, 6, s->coarse_snr_offset);
|
||||||
@ -1907,9 +2104,13 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
put_bits(&s->pb, 3, s->fast_gain_code[ch]);
|
put_bits(&s->pb, 3, s->fast_gain_code[ch]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
put_bits(&s->pb, 1, 0); /* no converter snr offset */
|
||||||
|
}
|
||||||
|
|
||||||
/* coupling leak */
|
/* coupling leak */
|
||||||
if (block->cpl_in_use) {
|
if (block->cpl_in_use) {
|
||||||
|
if (!s->eac3 || block->new_cpl_leak != 2)
|
||||||
put_bits(&s->pb, 1, block->new_cpl_leak);
|
put_bits(&s->pb, 1, block->new_cpl_leak);
|
||||||
if (block->new_cpl_leak) {
|
if (block->new_cpl_leak) {
|
||||||
put_bits(&s->pb, 3, s->bit_alloc.cpl_fast_leak);
|
put_bits(&s->pb, 3, s->bit_alloc.cpl_fast_leak);
|
||||||
@ -1917,8 +2118,10 @@ static void output_audio_block(AC3EncodeContext *s, int blk)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!s->eac3) {
|
||||||
put_bits(&s->pb, 1, 0); /* no delta bit allocation */
|
put_bits(&s->pb, 1, 0); /* no delta bit allocation */
|
||||||
put_bits(&s->pb, 1, 0); /* no data to skip */
|
put_bits(&s->pb, 1, 0); /* no data to skip */
|
||||||
|
}
|
||||||
|
|
||||||
/* mantissas */
|
/* mantissas */
|
||||||
got_cpl = !block->cpl_in_use;
|
got_cpl = !block->cpl_in_use;
|
||||||
@ -2007,6 +2210,10 @@ static void output_frame_end(AC3EncodeContext *s)
|
|||||||
if (pad_bytes > 0)
|
if (pad_bytes > 0)
|
||||||
memset(put_bits_ptr(&s->pb), 0, pad_bytes);
|
memset(put_bits_ptr(&s->pb), 0, pad_bytes);
|
||||||
|
|
||||||
|
if (s->eac3) {
|
||||||
|
/* compute crc2 */
|
||||||
|
crc2_partial = av_crc(crc_ctx, 0, frame + 2, s->frame_size - 5);
|
||||||
|
} else {
|
||||||
/* compute crc1 */
|
/* compute crc1 */
|
||||||
/* this is not so easy because it is at the beginning of the data... */
|
/* this is not so easy because it is at the beginning of the data... */
|
||||||
crc1 = av_bswap16(av_crc(crc_ctx, 0, frame + 4, frame_size_58 - 4));
|
crc1 = av_bswap16(av_crc(crc_ctx, 0, frame + 4, frame_size_58 - 4));
|
||||||
@ -2017,6 +2224,7 @@ static void output_frame_end(AC3EncodeContext *s)
|
|||||||
/* compute crc2 */
|
/* compute crc2 */
|
||||||
crc2_partial = av_crc(crc_ctx, 0, frame + frame_size_58,
|
crc2_partial = av_crc(crc_ctx, 0, frame + frame_size_58,
|
||||||
s->frame_size - frame_size_58 - 3);
|
s->frame_size - frame_size_58 - 3);
|
||||||
|
}
|
||||||
crc2 = av_crc(crc_ctx, crc2_partial, frame + s->frame_size - 3, 1);
|
crc2 = av_crc(crc_ctx, crc2_partial, frame + s->frame_size - 3, 1);
|
||||||
/* ensure crc2 does not match sync word by flipping crcrsv bit if needed */
|
/* ensure crc2 does not match sync word by flipping crcrsv bit if needed */
|
||||||
if (crc2 == 0x770B) {
|
if (crc2 == 0x770B) {
|
||||||
@ -2037,7 +2245,10 @@ static void output_frame(AC3EncodeContext *s, unsigned char *frame)
|
|||||||
|
|
||||||
init_put_bits(&s->pb, frame, AC3_MAX_CODED_FRAME_SIZE);
|
init_put_bits(&s->pb, frame, AC3_MAX_CODED_FRAME_SIZE);
|
||||||
|
|
||||||
output_frame_header(s);
|
if (s->eac3)
|
||||||
|
eac3_output_frame_header(s);
|
||||||
|
else
|
||||||
|
ac3_output_frame_header(s);
|
||||||
|
|
||||||
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++)
|
for (blk = 0; blk < AC3_MAX_BLOCKS; blk++)
|
||||||
output_audio_block(s, blk);
|
output_audio_block(s, blk);
|
||||||
@ -2058,6 +2269,7 @@ static void dprint_options(AVCodecContext *avctx)
|
|||||||
case 8: av_strlcpy(strbuf, "AC-3 (standard)", 32); break;
|
case 8: av_strlcpy(strbuf, "AC-3 (standard)", 32); break;
|
||||||
case 9: av_strlcpy(strbuf, "AC-3 (dnet half-rate)", 32); break;
|
case 9: av_strlcpy(strbuf, "AC-3 (dnet half-rate)", 32); break;
|
||||||
case 10: av_strlcpy(strbuf, "AC-3 (dnet quater-rate", 32); break;
|
case 10: av_strlcpy(strbuf, "AC-3 (dnet quater-rate", 32); break;
|
||||||
|
case 16: av_strlcpy(strbuf, "E-AC-3 (enhanced)", 32); break;
|
||||||
default: snprintf(strbuf, 32, "ERROR");
|
default: snprintf(strbuf, 32, "ERROR");
|
||||||
}
|
}
|
||||||
av_dlog(avctx, "bitstream_id: %s (%d)\n", strbuf, s->bitstream_id);
|
av_dlog(avctx, "bitstream_id: %s (%d)\n", strbuf, s->bitstream_id);
|
||||||
@ -2318,13 +2530,13 @@ static int ac3_encode_frame(AVCodecContext *avctx, unsigned char *frame,
|
|||||||
const SampleType *samples = data;
|
const SampleType *samples = data;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (s->options.allow_per_frame_metadata) {
|
if (!s->eac3 && s->options.allow_per_frame_metadata) {
|
||||||
ret = validate_metadata(avctx);
|
ret = validate_metadata(avctx);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (s->bit_alloc.sr_code == 1)
|
if (s->bit_alloc.sr_code == 1 || s->eac3)
|
||||||
adjust_frame_size(s);
|
adjust_frame_size(s);
|
||||||
|
|
||||||
deinterleave_input_samples(s, samples);
|
deinterleave_input_samples(s, samples);
|
||||||
@ -2450,7 +2662,7 @@ static av_cold int set_channel_info(AC3EncodeContext *s, int channels,
|
|||||||
|
|
||||||
static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s)
|
static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s)
|
||||||
{
|
{
|
||||||
int i, ret;
|
int i, ret, max_sr;
|
||||||
|
|
||||||
/* validate channel layout */
|
/* validate channel layout */
|
||||||
if (!avctx->channel_layout) {
|
if (!avctx->channel_layout) {
|
||||||
@ -2465,20 +2677,59 @@ static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* validate sample rate */
|
/* validate sample rate */
|
||||||
for (i = 0; i < 9; i++) {
|
/* note: max_sr could be changed from 2 to 5 for E-AC-3 once we find a
|
||||||
if ((ff_ac3_sample_rate_tab[i / 3] >> (i % 3)) == avctx->sample_rate)
|
decoder that supports half sample rate so we can validate that
|
||||||
|
the generated files are correct. */
|
||||||
|
max_sr = s->eac3 ? 2 : 8;
|
||||||
|
for (i = 0; i <= max_sr; i++) {
|
||||||
|
if ((ff_ac3_sample_rate_tab[i % 3] >> (i / 3)) == avctx->sample_rate)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (i == 9) {
|
if (i > max_sr) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "invalid sample rate\n");
|
av_log(avctx, AV_LOG_ERROR, "invalid sample rate\n");
|
||||||
return AVERROR(EINVAL);
|
return AVERROR(EINVAL);
|
||||||
}
|
}
|
||||||
s->sample_rate = avctx->sample_rate;
|
s->sample_rate = avctx->sample_rate;
|
||||||
s->bit_alloc.sr_shift = i % 3;
|
s->bit_alloc.sr_shift = i / 3;
|
||||||
s->bit_alloc.sr_code = i / 3;
|
s->bit_alloc.sr_code = i % 3;
|
||||||
s->bitstream_id = 8 + s->bit_alloc.sr_shift;
|
s->bitstream_id = s->eac3 ? 16 : 8 + s->bit_alloc.sr_shift;
|
||||||
|
|
||||||
/* validate bit rate */
|
/* validate bit rate */
|
||||||
|
if (s->eac3) {
|
||||||
|
int max_br, min_br, wpf, min_br_dist, min_br_code;
|
||||||
|
|
||||||
|
/* calculate min/max bitrate */
|
||||||
|
max_br = 2048 * s->sample_rate / AC3_FRAME_SIZE * 16;
|
||||||
|
min_br = ((s->sample_rate + (AC3_FRAME_SIZE-1)) / AC3_FRAME_SIZE) * 16;
|
||||||
|
if (avctx->bit_rate < min_br || avctx->bit_rate > max_br) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "invalid bit rate. must be %d to %d "
|
||||||
|
"for this sample rate\n", min_br, max_br);
|
||||||
|
return AVERROR(EINVAL);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* calculate words-per-frame for the selected bitrate */
|
||||||
|
wpf = (avctx->bit_rate / 16) * AC3_FRAME_SIZE / s->sample_rate;
|
||||||
|
av_assert1(wpf > 0 && wpf <= 2048);
|
||||||
|
|
||||||
|
/* find the closest AC-3 bitrate code to the selected bitrate.
|
||||||
|
this is needed for lookup tables for bandwidth and coupling
|
||||||
|
parameter selection */
|
||||||
|
min_br_code = -1;
|
||||||
|
min_br_dist = INT_MAX;
|
||||||
|
for (i = 0; i < 19; i++) {
|
||||||
|
int br_dist = abs(ff_ac3_bitrate_tab[i] * 1000 - avctx->bit_rate);
|
||||||
|
if (br_dist < min_br_dist) {
|
||||||
|
min_br_dist = br_dist;
|
||||||
|
min_br_code = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* make sure the minimum frame size is below the average frame size */
|
||||||
|
s->frame_size_code = min_br_code << 1;
|
||||||
|
while (wpf > 1 && wpf * s->sample_rate / AC3_FRAME_SIZE * 16 > avctx->bit_rate)
|
||||||
|
wpf--;
|
||||||
|
s->frame_size_min = 2 * wpf;
|
||||||
|
} else {
|
||||||
for (i = 0; i < 19; i++) {
|
for (i = 0; i < 19; i++) {
|
||||||
if ((ff_ac3_bitrate_tab[i] >> s->bit_alloc.sr_shift)*1000 == avctx->bit_rate)
|
if ((ff_ac3_bitrate_tab[i] >> s->bit_alloc.sr_shift)*1000 == avctx->bit_rate)
|
||||||
break;
|
break;
|
||||||
@ -2487,8 +2738,11 @@ static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s)
|
|||||||
av_log(avctx, AV_LOG_ERROR, "invalid bit rate\n");
|
av_log(avctx, AV_LOG_ERROR, "invalid bit rate\n");
|
||||||
return AVERROR(EINVAL);
|
return AVERROR(EINVAL);
|
||||||
}
|
}
|
||||||
s->bit_rate = avctx->bit_rate;
|
|
||||||
s->frame_size_code = i << 1;
|
s->frame_size_code = i << 1;
|
||||||
|
s->frame_size_min = 2 * ff_ac3_frame_size_tab[s->frame_size_code][s->bit_alloc.sr_code];
|
||||||
|
}
|
||||||
|
s->bit_rate = avctx->bit_rate;
|
||||||
|
s->frame_size = s->frame_size_min;
|
||||||
|
|
||||||
/* validate cutoff */
|
/* validate cutoff */
|
||||||
if (avctx->cutoff < 0) {
|
if (avctx->cutoff < 0) {
|
||||||
@ -2511,9 +2765,11 @@ static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s)
|
|||||||
return AVERROR(EINVAL);
|
return AVERROR(EINVAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!s->eac3) {
|
||||||
ret = validate_metadata(avctx);
|
ret = validate_metadata(avctx);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
s->rematrixing_enabled = s->options.stereo_rematrixing &&
|
s->rematrixing_enabled = s->options.stereo_rematrixing &&
|
||||||
(s->channel_mode == AC3_CHMODE_STEREO);
|
(s->channel_mode == AC3_CHMODE_STEREO);
|
||||||
@ -2713,6 +2969,8 @@ static av_cold int ac3_encode_init(AVCodecContext *avctx)
|
|||||||
AC3EncodeContext *s = avctx->priv_data;
|
AC3EncodeContext *s = avctx->priv_data;
|
||||||
int ret, frame_size_58;
|
int ret, frame_size_58;
|
||||||
|
|
||||||
|
s->eac3 = avctx->codec_id == CODEC_ID_EAC3;
|
||||||
|
|
||||||
avctx->frame_size = AC3_FRAME_SIZE;
|
avctx->frame_size = AC3_FRAME_SIZE;
|
||||||
|
|
||||||
ff_ac3_common_init();
|
ff_ac3_common_init();
|
||||||
@ -2725,10 +2983,8 @@ static av_cold int ac3_encode_init(AVCodecContext *avctx)
|
|||||||
if (s->bitstream_mode == AV_AUDIO_SERVICE_TYPE_KARAOKE)
|
if (s->bitstream_mode == AV_AUDIO_SERVICE_TYPE_KARAOKE)
|
||||||
s->bitstream_mode = 0x7;
|
s->bitstream_mode = 0x7;
|
||||||
|
|
||||||
s->frame_size_min = 2 * ff_ac3_frame_size_tab[s->frame_size_code][s->bit_alloc.sr_code];
|
|
||||||
s->bits_written = 0;
|
s->bits_written = 0;
|
||||||
s->samples_written = 0;
|
s->samples_written = 0;
|
||||||
s->frame_size = s->frame_size_min;
|
|
||||||
|
|
||||||
/* calculate crc_inv for both possible frame sizes */
|
/* calculate crc_inv for both possible frame sizes */
|
||||||
frame_size_58 = (( s->frame_size >> 2) + ( s->frame_size >> 4)) << 1;
|
frame_size_58 = (( s->frame_size >> 2) + ( s->frame_size >> 4)) << 1;
|
||||||
|
@ -100,6 +100,7 @@ static void scale_coefficients(AC3EncodeContext *s)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if CONFIG_AC3_ENCODER
|
||||||
AVCodec ff_ac3_encoder = {
|
AVCodec ff_ac3_encoder = {
|
||||||
"ac3",
|
"ac3",
|
||||||
AVMEDIA_TYPE_AUDIO,
|
AVMEDIA_TYPE_AUDIO,
|
||||||
@ -114,3 +115,20 @@ AVCodec ff_ac3_encoder = {
|
|||||||
.priv_class = &ac3enc_class,
|
.priv_class = &ac3enc_class,
|
||||||
.channel_layouts = ac3_channel_layouts,
|
.channel_layouts = ac3_channel_layouts,
|
||||||
};
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EAC3_ENCODER
|
||||||
|
AVCodec ff_eac3_encoder = {
|
||||||
|
.name = "eac3",
|
||||||
|
.type = AVMEDIA_TYPE_AUDIO,
|
||||||
|
.id = CODEC_ID_EAC3,
|
||||||
|
.priv_data_size = sizeof(AC3EncodeContext),
|
||||||
|
.init = ac3_encode_init,
|
||||||
|
.encode = ac3_encode_frame,
|
||||||
|
.close = ac3_encode_close,
|
||||||
|
.sample_fmts = (const enum AVSampleFormat[]){AV_SAMPLE_FMT_FLT,AV_SAMPLE_FMT_NONE},
|
||||||
|
.long_name = NULL_IF_CONFIG_SMALL("ATSC A/52 E-AC-3"),
|
||||||
|
.priv_class = &eac3enc_class,
|
||||||
|
.channel_layouts = ac3_channel_layouts,
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
@ -23,7 +23,10 @@
|
|||||||
static const AVOption ac3fixed_options[] = {
|
static const AVOption ac3fixed_options[] = {
|
||||||
#elif AC3ENC_TYPE == AC3ENC_TYPE_AC3
|
#elif AC3ENC_TYPE == AC3ENC_TYPE_AC3
|
||||||
static const AVOption ac3_options[] = {
|
static const AVOption ac3_options[] = {
|
||||||
|
#else /* AC3ENC_TYPE_EAC3 */
|
||||||
|
static const AVOption eac3_options[] = {
|
||||||
#endif
|
#endif
|
||||||
|
#if AC3ENC_TYPE != AC3ENC_TYPE_EAC3
|
||||||
/* Metadata Options */
|
/* Metadata Options */
|
||||||
{"per_frame_metadata", "Allow Changing Metadata Per-Frame", OFFSET(allow_per_frame_metadata), FF_OPT_TYPE_INT, {.dbl = 0 }, 0, 1, AC3ENC_PARAM},
|
{"per_frame_metadata", "Allow Changing Metadata Per-Frame", OFFSET(allow_per_frame_metadata), FF_OPT_TYPE_INT, {.dbl = 0 }, 0, 1, AC3ENC_PARAM},
|
||||||
/* downmix levels */
|
/* downmix levels */
|
||||||
@ -37,7 +40,9 @@ static const AVOption ac3_options[] = {
|
|||||||
{"small", "Small Room", 0, FF_OPT_TYPE_CONST, {.dbl = 2 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "room_type"},
|
{"small", "Small Room", 0, FF_OPT_TYPE_CONST, {.dbl = 2 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "room_type"},
|
||||||
/* other metadata options */
|
/* other metadata options */
|
||||||
{"copyright", "Copyright Bit", OFFSET(copyright), FF_OPT_TYPE_INT, {.dbl = 0 }, 0, 1, AC3ENC_PARAM},
|
{"copyright", "Copyright Bit", OFFSET(copyright), FF_OPT_TYPE_INT, {.dbl = 0 }, 0, 1, AC3ENC_PARAM},
|
||||||
|
#endif
|
||||||
{"dialnorm", "Dialogue Level (dB)", OFFSET(dialogue_level), FF_OPT_TYPE_INT, {.dbl = -31 }, -31, -1, AC3ENC_PARAM},
|
{"dialnorm", "Dialogue Level (dB)", OFFSET(dialogue_level), FF_OPT_TYPE_INT, {.dbl = -31 }, -31, -1, AC3ENC_PARAM},
|
||||||
|
#if AC3ENC_TYPE != AC3ENC_TYPE_EAC3
|
||||||
{"dsur_mode", "Dolby Surround Mode", OFFSET(dolby_surround_mode), FF_OPT_TYPE_INT, {.dbl = 0 }, 0, 2, AC3ENC_PARAM, "dsur_mode"},
|
{"dsur_mode", "Dolby Surround Mode", OFFSET(dolby_surround_mode), FF_OPT_TYPE_INT, {.dbl = 0 }, 0, 2, AC3ENC_PARAM, "dsur_mode"},
|
||||||
{"notindicated", "Not Indicated (default)", 0, FF_OPT_TYPE_CONST, {.dbl = 0 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "dsur_mode"},
|
{"notindicated", "Not Indicated (default)", 0, FF_OPT_TYPE_CONST, {.dbl = 0 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "dsur_mode"},
|
||||||
{"on", "Dolby Surround Encoded", 0, FF_OPT_TYPE_CONST, {.dbl = 1 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "dsur_mode"},
|
{"on", "Dolby Surround Encoded", 0, FF_OPT_TYPE_CONST, {.dbl = 1 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "dsur_mode"},
|
||||||
@ -63,6 +68,7 @@ static const AVOption ac3_options[] = {
|
|||||||
{"ad_conv_type", "A/D Converter Type", OFFSET(ad_converter_type), FF_OPT_TYPE_INT, {.dbl = -1 }, -1, 1, AC3ENC_PARAM, "ad_conv_type"},
|
{"ad_conv_type", "A/D Converter Type", OFFSET(ad_converter_type), FF_OPT_TYPE_INT, {.dbl = -1 }, -1, 1, AC3ENC_PARAM, "ad_conv_type"},
|
||||||
{"standard", "Standard (default)", 0, FF_OPT_TYPE_CONST, {.dbl = 0 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "ad_conv_type"},
|
{"standard", "Standard (default)", 0, FF_OPT_TYPE_CONST, {.dbl = 0 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "ad_conv_type"},
|
||||||
{"hdcd", "HDCD", 0, FF_OPT_TYPE_CONST, {.dbl = 1 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "ad_conv_type"},
|
{"hdcd", "HDCD", 0, FF_OPT_TYPE_CONST, {.dbl = 1 }, INT_MIN, INT_MAX, AC3ENC_PARAM, "ad_conv_type"},
|
||||||
|
#endif
|
||||||
/* Other Encoding Options */
|
/* Other Encoding Options */
|
||||||
{"stereo_rematrixing", "Stereo Rematrixing", OFFSET(stereo_rematrixing), FF_OPT_TYPE_INT, {.dbl = 1 }, 0, 1, AC3ENC_PARAM},
|
{"stereo_rematrixing", "Stereo Rematrixing", OFFSET(stereo_rematrixing), FF_OPT_TYPE_INT, {.dbl = 1 }, 0, 1, AC3ENC_PARAM},
|
||||||
#if AC3ENC_TYPE != AC3ENC_TYPE_AC3_FIXED
|
#if AC3ENC_TYPE != AC3ENC_TYPE_AC3_FIXED
|
||||||
|
@ -241,7 +241,7 @@ void avcodec_register_all(void)
|
|||||||
REGISTER_DECODER (COOK, cook);
|
REGISTER_DECODER (COOK, cook);
|
||||||
REGISTER_DECODER (DCA, dca);
|
REGISTER_DECODER (DCA, dca);
|
||||||
REGISTER_DECODER (DSICINAUDIO, dsicinaudio);
|
REGISTER_DECODER (DSICINAUDIO, dsicinaudio);
|
||||||
REGISTER_DECODER (EAC3, eac3);
|
REGISTER_ENCDEC (EAC3, eac3);
|
||||||
REGISTER_ENCDEC (FLAC, flac);
|
REGISTER_ENCDEC (FLAC, flac);
|
||||||
REGISTER_DECODER (GSM, gsm);
|
REGISTER_DECODER (GSM, gsm);
|
||||||
REGISTER_DECODER (GSM_MS, gsm_ms);
|
REGISTER_DECODER (GSM_MS, gsm_ms);
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
#define AVCODEC_VERSION_H
|
#define AVCODEC_VERSION_H
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_MAJOR 53
|
#define LIBAVCODEC_VERSION_MAJOR 53
|
||||||
#define LIBAVCODEC_VERSION_MINOR 4
|
#define LIBAVCODEC_VERSION_MINOR 5
|
||||||
#define LIBAVCODEC_VERSION_MICRO 0
|
#define LIBAVCODEC_VERSION_MICRO 0
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
||||||
|
Loading…
Reference in New Issue
Block a user