[vlc-commits] converter: spdif: add EAC3 support
Thomas Guillem
git at videolan.org
Mon Sep 12 15:16:15 CEST 2016
vlc | branch: master | Thomas Guillem <thomas at gllm.fr> | Thu Sep 1 10:45:40 2016 +0200| [3d271046cea25fe9b20e6c1f63d23a3675401533] | committer: Thomas Guillem
converter: spdif: add EAC3 support
> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=3d271046cea25fe9b20e6c1f63d23a3675401533
---
modules/audio_filter/converter/tospdif.c | 59 +++++++++++++++++++++++++++++++-
1 file changed, 58 insertions(+), 1 deletion(-)
diff --git a/modules/audio_filter/converter/tospdif.c b/modules/audio_filter/converter/tospdif.c
index 92c5ca3..8f3ad4d 100644
--- a/modules/audio_filter/converter/tospdif.c
+++ b/modules/audio_filter/converter/tospdif.c
@@ -37,6 +37,8 @@
#include <vlc_aout.h>
#include <vlc_filter.h>
+#include "../packetizer/a52.h"
+
static int Open( vlc_object_t * );
static void Close( vlc_object_t * );
@@ -52,9 +54,18 @@ struct filter_sys_t
{
block_t *p_chain_first;
block_t **pp_chain_last;
+
+ union
+ {
+ struct
+ {
+ unsigned int i_nb_blocks_substream0;
+ } eac3;
+ } spec;
};
#define IEC61937_AC3 0x01
+#define IEC61937_EAC3 0x15
#define IEC61937_DTS1 0x0B
#define IEC61937_DTS2 0x0C
#define IEC61937_DTS3 0x0D
@@ -83,6 +94,45 @@ static int parse_header_ac3( filter_t *p_filter, block_t *p_in,
return SPDIF_SUCCESS;
}
+static int parse_header_eac3( filter_t *p_filter, block_t *p_in,
+ struct hdr_res *p_res )
+{
+ filter_sys_t *p_sys = p_filter->p_sys;
+
+ vlc_a52_header_t a52 = { };
+ if( vlc_a52_header_Parse( &a52, p_in->p_buffer, p_in->i_buffer )
+ != VLC_SUCCESS )
+ return SPDIF_ERROR;
+
+ p_in->i_buffer = a52.i_size;
+ p_in->i_nb_samples = a52.i_samples;
+
+ if( a52.b_eac3 )
+ {
+ if( ( a52.eac3.strmtyp == EAC3_STRMTYP_INDEPENDENT
+ || a52.eac3.strmtyp == EAC3_STRMTYP_AC3_CONVERT )
+ && a52.i_blocks_per_sync_frame != 6 )
+ {
+ /* cf. Annex E 2.3.1.2 of AC3 spec */
+ if( a52.eac3.i_substreamid == 0 )
+ p_sys->spec.eac3.i_nb_blocks_substream0
+ += a52.i_blocks_per_sync_frame;
+
+ if( p_sys->spec.eac3.i_nb_blocks_substream0 != 6 )
+ return SPDIF_MORE_DATA;
+ else
+ p_sys->spec.eac3.i_nb_blocks_substream0 = 0;
+ }
+ p_res->i_out_size_padded = AOUT_SPDIF_SIZE * 4;
+ p_res->i_data_type = IEC61937_EAC3;
+ p_res->i_length_mul = 1; /* in bytes */
+ return SPDIF_SUCCESS;
+ }
+ else
+ return SPDIF_MORE_DATA;
+
+}
+
static int parse_header_dts( filter_t *p_filter, block_t *p_in,
struct hdr_res *p_res )
{
@@ -115,6 +165,8 @@ static int parse_header( filter_t *p_filter, block_t *p_in,
{
case VLC_CODEC_A52:
return parse_header_ac3( p_filter, p_in, p_res );
+ case VLC_CODEC_EAC3:
+ return parse_header_eac3( p_filter, p_in, p_res );
case VLC_CODEC_DTS:
return parse_header_dts( p_filter, p_in, p_res );
default:
@@ -127,6 +179,7 @@ static bool is_big_endian( filter_t *p_filter, block_t *p_in )
switch( p_filter->fmt_in.audio.i_format )
{
case VLC_CODEC_A52:
+ case VLC_CODEC_EAC3:
return true;
case VLC_CODEC_DTS:
return p_in->p_buffer[0] == 0x1F || p_in->p_buffer[0] == 0x7F;
@@ -145,6 +198,7 @@ static void Flush( filter_t *p_filter )
p_sys->p_chain_first = NULL;
p_sys->pp_chain_last = &p_sys->p_chain_first;
}
+ memset( &p_sys->spec, 0, sizeof( p_sys->spec ) );
}
static block_t *fill_output_buffer( filter_t *p_filter, struct hdr_res *p_res )
@@ -264,7 +318,8 @@ static int Open( vlc_object_t *p_this )
filter_sys_t *p_sys;
if( ( p_filter->fmt_in.audio.i_format != VLC_CODEC_DTS &&
- p_filter->fmt_in.audio.i_format != VLC_CODEC_A52 ) ||
+ p_filter->fmt_in.audio.i_format != VLC_CODEC_A52 &&
+ p_filter->fmt_in.audio.i_format != VLC_CODEC_EAC3 ) ||
( p_filter->fmt_out.audio.i_format != VLC_CODEC_SPDIFL &&
p_filter->fmt_out.audio.i_format != VLC_CODEC_SPDIFB ) )
return VLC_EGENERIC;
@@ -275,6 +330,8 @@ static int Open( vlc_object_t *p_this )
p_sys->p_chain_first = NULL;
p_sys->pp_chain_last = &p_sys->p_chain_first;
+ memset( &p_sys->spec, 0, sizeof( p_sys->spec ) );
+
p_filter->pf_audio_filter = DoWork;
p_filter->pf_flush = Flush;
More information about the vlc-commits
mailing list