mirror of https://github.com/mpv-player/mpv
libmpcodecs: add ad_spdif.c, S/PDIF passthrough decoder
patch by Naoya OYAMA, naoya.oyama gmail com git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@34191 b3059339-0415-0410-9bf9-f77b7e298cf2 fix ad_spdif Call av_register_all() before initialising the SPDIF muxer. Fixes playback with -demuxer mpegts -ac spdifac3. Patch by Naoya OYAMA, naoya D oyama gmail git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@34291 b3059339-0415-0410-9bf9-f77b7e298cf2 Use new API avformat_new_stream() instead of the deprecated av_new_stream(). Patch by Naoya OYAMA, naoya D oyama gmail git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@34292 b3059339-0415-0410-9bf9-f77b7e298cf2 Cosmetics: Remove empty statement. Patch by Naoya OYAMA, naoya D oyama gmail git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@34293 b3059339-0415-0410-9bf9-f77b7e298cf2 Use init_avformat() instead of av_register_all(). git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@34294 b3059339-0415-0410-9bf9-f77b7e298cf2 Author: diego
This commit is contained in:
parent
8a9348b079
commit
78f51230d7
1
Makefile
1
Makefile
|
@ -234,6 +234,7 @@ SRCS_COMMON = asxparser.c \
|
|||
libmpcodecs/ad_alaw.c \
|
||||
libmpcodecs/ad_dvdpcm.c \
|
||||
libmpcodecs/ad_ffmpeg.c \
|
||||
libmpcodecs/ad_spdif.c \
|
||||
libmpcodecs/ad_hwac3.c \
|
||||
libmpcodecs/ad_hwmpa.c \
|
||||
libmpcodecs/ad_imaadpcm.c \
|
||||
|
|
|
@ -4719,3 +4719,62 @@ audiocodec uleaddva
|
|||
format 0x216
|
||||
driver acm
|
||||
dll "dvacm.acm"
|
||||
|
||||
audiocodec spdifaac
|
||||
info "libavformat/spdifenc AAC pass-through decoder"
|
||||
status working
|
||||
comment "for AAC hardware decoders"
|
||||
fourcc MP4A
|
||||
dll aac
|
||||
driver spdif
|
||||
|
||||
audiocodec spdifac3
|
||||
info "libavformat/spdifenc AC-3 pass-through decoder"
|
||||
status working
|
||||
comment "for AC-3 hardware decoders"
|
||||
format 0x2000 ; AC-3
|
||||
format 0x332D6361 ; AC-3 in MP4
|
||||
fourcc dnet ; AC-3
|
||||
dll ac3
|
||||
driver spdif
|
||||
|
||||
audiocodec spdifeac3
|
||||
info "libavformat/spdifenc E-AC-3 pass-through decoder"
|
||||
status working
|
||||
comment "for E-AC-3 hardware decoders"
|
||||
fourcc EAC3 ; E-AC-3
|
||||
dll eac3
|
||||
driver spdif
|
||||
|
||||
audiocodec spdifdts
|
||||
info "libavformat/spdifenc DTS pass-through decoder"
|
||||
status working
|
||||
comment "for DTS hardware decoders"
|
||||
format 0x2001
|
||||
format 0x86
|
||||
dll dca
|
||||
driver spdif
|
||||
|
||||
audiocodec spdifmpa
|
||||
info "libavformat/spdifenc MPEG AUDIO BC pass-through decoder"
|
||||
status untested
|
||||
comment "for MPEG AUDIO BC hardware decoders"
|
||||
format 0x50 ; layer-1 && layer-2
|
||||
format 0x55 ; layer-3
|
||||
format 0x5500736d ; "ms\0\x55" older MP3 fcc (MOV files)
|
||||
format 0x5000736d ; "ms\0\x50" older MP2 fcc (MOV files)
|
||||
fourcc ".mp3" ; CBR/VBR MP3 (MOV files)
|
||||
fourcc ".mp2" ; MP2 (MOV files)
|
||||
fourcc ".mp1" ; MP1 (MOV files)
|
||||
fourcc "MP3 " ; used in .nsv files
|
||||
fourcc "LAME" ; used in mythtv .nuv files
|
||||
dll mpa
|
||||
driver spdif
|
||||
|
||||
audiocodec spdifthd
|
||||
info "libavformat/spdifenc Dolby TrueHD pass-through decoder"
|
||||
status working
|
||||
comment "for Dolby TrueHD hardware decoders"
|
||||
fourcc "TRHD"
|
||||
dll thd
|
||||
driver spdif
|
||||
|
|
|
@ -62,6 +62,7 @@
|
|||
#define AF_FORMAT_MPEG2 (3<<6) // MPEG(2) audio
|
||||
#define AF_FORMAT_AC3 (4<<6) // Dolby Digital AC3
|
||||
#define AF_FORMAT_IMA_ADPCM (5<<6)
|
||||
#define AF_FORMAT_IEC61937 (6<<6)
|
||||
#define AF_FORMAT_SPECIAL_MASK (7<<6)
|
||||
|
||||
// PREDEFINED formats
|
||||
|
@ -87,6 +88,9 @@
|
|||
#define AF_FORMAT_AC3_LE (AF_FORMAT_AC3|AF_FORMAT_16BIT|AF_FORMAT_LE)
|
||||
#define AF_FORMAT_AC3_BE (AF_FORMAT_AC3|AF_FORMAT_16BIT|AF_FORMAT_BE)
|
||||
|
||||
#define AF_FORMAT_IEC61937_LE (AF_FORMAT_IEC61937|AF_FORMAT_16BIT|AF_FORMAT_LE)
|
||||
#define AF_FORMAT_IEC61937_BE (AF_FORMAT_IEC61937|AF_FORMAT_16BIT|AF_FORMAT_BE)
|
||||
|
||||
#if BYTE_ORDER == BIG_ENDIAN
|
||||
#define AF_FORMAT_U16_NE AF_FORMAT_U16_BE
|
||||
#define AF_FORMAT_S16_NE AF_FORMAT_S16_BE
|
||||
|
@ -96,6 +100,7 @@
|
|||
#define AF_FORMAT_S32_NE AF_FORMAT_S32_BE
|
||||
#define AF_FORMAT_FLOAT_NE AF_FORMAT_FLOAT_BE
|
||||
#define AF_FORMAT_AC3_NE AF_FORMAT_AC3_BE
|
||||
#define AF_FORMAT_IEC61937_NE AF_FORMAT_IEC61937_BE
|
||||
#else
|
||||
#define AF_FORMAT_U16_NE AF_FORMAT_U16_LE
|
||||
#define AF_FORMAT_S16_NE AF_FORMAT_S16_LE
|
||||
|
@ -105,11 +110,13 @@
|
|||
#define AF_FORMAT_S32_NE AF_FORMAT_S32_LE
|
||||
#define AF_FORMAT_FLOAT_NE AF_FORMAT_FLOAT_LE
|
||||
#define AF_FORMAT_AC3_NE AF_FORMAT_AC3_LE
|
||||
#define AF_FORMAT_IEC61937_NE AF_FORMAT_IEC61937_LE
|
||||
#endif
|
||||
|
||||
#define AF_FORMAT_UNKNOWN (-1)
|
||||
|
||||
#define AF_FORMAT_IS_AC3(fmt) (((fmt) & AF_FORMAT_SPECIAL_MASK) == AF_FORMAT_AC3)
|
||||
#define AF_FORMAT_IS_IEC61937(fmt) (((fmt) & AF_FORMAT_SPECIAL_MASK) == AF_FORMAT_IEC61937)
|
||||
|
||||
int af_str2fmt_short(const char *str);
|
||||
int af_fmt2bits(int format);
|
||||
|
|
|
@ -75,6 +75,8 @@ char* af_fmt2str(int format, char* str, int size)
|
|||
i+=snprintf(&str[i],size-i,"MPEG-2 "); break;
|
||||
case(AF_FORMAT_AC3):
|
||||
i+=snprintf(&str[i],size-i,"AC3 "); break;
|
||||
case(AF_FORMAT_IEC61937):
|
||||
i+=snprintf(&str[i],size-i,"IEC61937 "); break;
|
||||
case(AF_FORMAT_IMA_ADPCM):
|
||||
i+=snprintf(&str[i],size-i,"IMA-ADPCM "); break;
|
||||
default:
|
||||
|
@ -115,6 +117,9 @@ static struct {
|
|||
{ "ac3le", AF_FORMAT_AC3_LE },
|
||||
{ "ac3be", AF_FORMAT_AC3_BE },
|
||||
{ "ac3ne", AF_FORMAT_AC3_NE },
|
||||
{ "iec61937le", AF_FORMAT_IEC61937_LE },
|
||||
{ "iec61937be", AF_FORMAT_IEC61937_BE },
|
||||
{ "iec61937ne", AF_FORMAT_IEC61937_NE },
|
||||
{ "imaadpcm", AF_FORMAT_IMA_ADPCM },
|
||||
|
||||
{ "u8", AF_FORMAT_U8 },
|
||||
|
|
|
@ -115,7 +115,7 @@ static int control(int cmd, void *arg)
|
|||
long get_vol, set_vol;
|
||||
float f_multi;
|
||||
|
||||
if(AF_FORMAT_IS_AC3(ao_data.format))
|
||||
if(AF_FORMAT_IS_AC3(ao_data.format) || AF_FORMAT_IS_IEC61937(ao_data.format))
|
||||
return CONTROL_TRUE;
|
||||
|
||||
if(mixer_channel) {
|
||||
|
@ -380,10 +380,12 @@ static int init(int rate_hz, int channels, int format, int flags)
|
|||
break;
|
||||
case AF_FORMAT_AC3_LE:
|
||||
case AF_FORMAT_S16_LE:
|
||||
case AF_FORMAT_IEC61937_LE:
|
||||
alsa_format = SND_PCM_FORMAT_S16_LE;
|
||||
break;
|
||||
case AF_FORMAT_AC3_BE:
|
||||
case AF_FORMAT_S16_BE:
|
||||
case AF_FORMAT_IEC61937_BE:
|
||||
alsa_format = SND_PCM_FORMAT_S16_BE;
|
||||
break;
|
||||
case AF_FORMAT_U32_LE:
|
||||
|
@ -437,9 +439,9 @@ static int init(int rate_hz, int channels, int format, int flags)
|
|||
* while opening the abstract alias for the spdif subdevice
|
||||
* 'iec958'
|
||||
*/
|
||||
if (AF_FORMAT_IS_AC3(format)) {
|
||||
if (AF_FORMAT_IS_AC3(format) || AF_FORMAT_IS_IEC61937(format)) {
|
||||
device.str = "iec958";
|
||||
mp_msg(MSGT_AO,MSGL_V,"alsa-spdif-init: playing AC3, %i channels\n", channels);
|
||||
mp_msg(MSGT_AO,MSGL_V,"alsa-spdif-init: playing AC3/iec61937/iec958, %i channels\n", channels);
|
||||
}
|
||||
else
|
||||
/* in any case for multichannel playback we should select
|
||||
|
@ -488,7 +490,7 @@ static int init(int rate_hz, int channels, int format, int flags)
|
|||
|
||||
if (!alsa_handler) {
|
||||
int open_mode = block ? 0 : SND_PCM_NONBLOCK;
|
||||
int isac3 = AF_FORMAT_IS_AC3(format);
|
||||
int isac3 = AF_FORMAT_IS_AC3(format) || AF_FORMAT_IS_IEC61937(format);
|
||||
//modes = 0, SND_PCM_NONBLOCK, SND_PCM_ASYNC
|
||||
if ((err = try_open_device(alsa_device, open_mode, isac3)) < 0)
|
||||
{
|
||||
|
@ -539,6 +541,8 @@ static int init(int rate_hz, int channels, int format, int flags)
|
|||
alsa_format = SND_PCM_FORMAT_S16_LE;
|
||||
if (AF_FORMAT_IS_AC3(ao_data.format))
|
||||
ao_data.format = AF_FORMAT_AC3_LE;
|
||||
else if (AF_FORMAT_IS_IEC61937(ao_data.format))
|
||||
ao_data.format = AF_FORMAT_IEC61937_LE;
|
||||
else
|
||||
ao_data.format = AF_FORMAT_S16_LE;
|
||||
}
|
||||
|
|
|
@ -49,6 +49,7 @@ extern const ad_functions_t mpcodecs_ad_libmad;
|
|||
extern const ad_functions_t mpcodecs_ad_realaud;
|
||||
extern const ad_functions_t mpcodecs_ad_libdv;
|
||||
extern const ad_functions_t mpcodecs_ad_qtaudio;
|
||||
extern const ad_functions_t mpcodecs_ad_spdif;
|
||||
extern const ad_functions_t mpcodecs_ad_libdca;
|
||||
|
||||
const ad_functions_t * const mpcodecs_ad_drivers[] =
|
||||
|
@ -62,6 +63,7 @@ const ad_functions_t * const mpcodecs_ad_drivers[] =
|
|||
&mpcodecs_ad_hwac3,
|
||||
&mpcodecs_ad_hwmpa,
|
||||
&mpcodecs_ad_ffmpeg,
|
||||
&mpcodecs_ad_spdif,
|
||||
&mpcodecs_ad_pcm,
|
||||
&mpcodecs_ad_dvdpcm,
|
||||
&mpcodecs_ad_alaw,
|
||||
|
|
|
@ -0,0 +1,310 @@
|
|||
/*
|
||||
* This file is part of MPlayer.
|
||||
*
|
||||
* MPlayer is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* MPlayer is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with MPlayer; if not, write to the Free Software Foundation, Inc.,
|
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*/
|
||||
|
||||
#include <string.h>
|
||||
|
||||
#include <libavformat/avformat.h>
|
||||
#include <libavcodec/avcodec.h>
|
||||
#include <libavutil/opt.h>
|
||||
|
||||
#include "config.h"
|
||||
#include "mp_msg.h"
|
||||
#include "ad_internal.h"
|
||||
|
||||
static const ad_info_t info = {
|
||||
"libavformat/spdifenc audio pass-through decoder.",
|
||||
"spdif",
|
||||
"Naoya OYAMA",
|
||||
"Naoya OYAMA",
|
||||
"For ALL hardware decoders"
|
||||
};
|
||||
|
||||
LIBAD_EXTERN(spdif)
|
||||
|
||||
#define FILENAME_SPDIFENC "spdif"
|
||||
#define OUTBUF_SIZE 65536
|
||||
struct spdifContext {
|
||||
AVFormatContext *lavf_ctx;
|
||||
int iec61937_packet_size;
|
||||
int out_buffer_len;
|
||||
int out_buffer_size;
|
||||
uint8_t *out_buffer;
|
||||
uint8_t pb_buffer[OUTBUF_SIZE];
|
||||
};
|
||||
|
||||
static int read_packet(void *p, uint8_t *buf, int buf_size)
|
||||
{
|
||||
// spdifenc does not use read callback.
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int write_packet(void *p, uint8_t *buf, int buf_size)
|
||||
{
|
||||
int len;
|
||||
struct spdifContext *ctx = p;
|
||||
|
||||
len = FFMIN(buf_size, ctx->out_buffer_size -ctx->out_buffer_len);
|
||||
memcpy(&ctx->out_buffer[ctx->out_buffer_len], buf, len);
|
||||
ctx->out_buffer_len += len;
|
||||
return len;
|
||||
}
|
||||
|
||||
static int64_t seek(void *p, int64_t offset, int whence)
|
||||
{
|
||||
// spdifenc does not use seek callback.
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int preinit(sh_audio_t *sh)
|
||||
{
|
||||
sh->samplesize = 2;
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int init(sh_audio_t *sh)
|
||||
{
|
||||
int i, x, in_size, srate, bps, *dtshd_rate;
|
||||
unsigned char *start;
|
||||
double pts;
|
||||
static const struct {
|
||||
const char *name; enum CodecID id;
|
||||
} fmt_id_type[] = {
|
||||
{ "aac" , CODEC_ID_AAC },
|
||||
{ "ac3" , CODEC_ID_AC3 },
|
||||
{ "dca" , CODEC_ID_DTS },
|
||||
{ "eac3", CODEC_ID_EAC3 },
|
||||
{ "mpa" , CODEC_ID_MP3 },
|
||||
{ "thd" , CODEC_ID_TRUEHD },
|
||||
{ NULL , 0 }
|
||||
};
|
||||
AVFormatContext *lavf_ctx = NULL;
|
||||
AVStream *stream = NULL;
|
||||
const AVOption *opt = NULL;
|
||||
struct spdifContext *spdif_ctx = NULL;
|
||||
|
||||
spdif_ctx = av_mallocz(sizeof(*spdif_ctx));
|
||||
if (!spdif_ctx)
|
||||
goto fail;
|
||||
spdif_ctx->lavf_ctx = avformat_alloc_context();
|
||||
if (!spdif_ctx->lavf_ctx)
|
||||
goto fail;
|
||||
|
||||
sh->context = spdif_ctx;
|
||||
lavf_ctx = spdif_ctx->lavf_ctx;
|
||||
|
||||
lavf_ctx->oformat = av_guess_format(FILENAME_SPDIFENC, NULL, NULL);
|
||||
if (!lavf_ctx->oformat)
|
||||
goto fail;
|
||||
lavf_ctx->priv_data = av_mallocz(lavf_ctx->oformat->priv_data_size);
|
||||
if (!lavf_ctx->priv_data)
|
||||
goto fail;
|
||||
lavf_ctx->pb = avio_alloc_context(spdif_ctx->pb_buffer, OUTBUF_SIZE, 1, spdif_ctx,
|
||||
read_packet, write_packet, seek);
|
||||
if (!lavf_ctx->pb)
|
||||
goto fail;
|
||||
stream = avformat_new_stream(lavf_ctx, 0);
|
||||
if (!stream)
|
||||
goto fail;
|
||||
lavf_ctx->duration = AV_NOPTS_VALUE;
|
||||
lavf_ctx->start_time = AV_NOPTS_VALUE;
|
||||
for (i = 0; fmt_id_type[i].name; i++) {
|
||||
if (!strcmp(sh->codec->dll, fmt_id_type[i].name)) {
|
||||
lavf_ctx->streams[0]->codec->codec_id = fmt_id_type[i].id;
|
||||
break;
|
||||
}
|
||||
}
|
||||
lavf_ctx->raw_packet_buffer_remaining_size = RAW_PACKET_BUFFER_SIZE;
|
||||
if (AVERROR_PATCHWELCOME == lavf_ctx->oformat->write_header(lavf_ctx)) {
|
||||
mp_msg(MSGT_DECAUDIO,MSGL_INFO,
|
||||
"This codec is not supported by spdifenc.\n");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
// get sample_rate & bitrate from parser
|
||||
bps = srate = 0;
|
||||
x = ds_get_packet_pts(sh->ds, &start, &pts);
|
||||
in_size = x;
|
||||
if (x <= 0) {
|
||||
pts = MP_NOPTS_VALUE;
|
||||
x = 0;
|
||||
}
|
||||
ds_parse(sh->ds, &start, &x, pts, 0);
|
||||
if (x == 0) { // not enough buffer
|
||||
srate = 48000; //fake value
|
||||
bps = 768000/8; //fake value
|
||||
} else if (sh->avctx) {
|
||||
if (sh->avctx->sample_rate < 44100) {
|
||||
mp_msg(MSGT_DECAUDIO,MSGL_INFO,
|
||||
"This stream sample_rate[%d Hz] may be broken. "
|
||||
"Force reset 48000Hz.\n",
|
||||
sh->avctx->sample_rate);
|
||||
srate = 48000; //fake value
|
||||
} else
|
||||
srate = sh->avctx->sample_rate;
|
||||
bps = sh->avctx->bit_rate/8;
|
||||
}
|
||||
sh->ds->buffer_pos -= in_size;
|
||||
|
||||
switch (lavf_ctx->streams[0]->codec->codec_id) {
|
||||
case CODEC_ID_AAC:
|
||||
spdif_ctx->iec61937_packet_size = 16384;
|
||||
sh->sample_format = AF_FORMAT_IEC61937_LE;
|
||||
sh->samplerate = srate;
|
||||
sh->channels = 2;
|
||||
sh->i_bps = bps;
|
||||
break;
|
||||
case CODEC_ID_AC3:
|
||||
spdif_ctx->iec61937_packet_size = 6144;
|
||||
sh->sample_format = AF_FORMAT_IEC61937_LE;
|
||||
sh->samplerate = srate;
|
||||
sh->channels = 2;
|
||||
sh->i_bps = bps;
|
||||
break;
|
||||
case CODEC_ID_DTS: // FORCE USE DTS-HD
|
||||
opt = av_opt_find(&lavf_ctx->oformat->priv_class,
|
||||
"dtshd_rate", NULL, 0, 0);
|
||||
if (!opt)
|
||||
goto fail;
|
||||
dtshd_rate = (int*)(((uint8_t*)lavf_ctx->priv_data) +
|
||||
opt->offset);
|
||||
*dtshd_rate = 192000*4;
|
||||
spdif_ctx->iec61937_packet_size = 32768;
|
||||
sh->sample_format = AF_FORMAT_IEC61937_LE;
|
||||
sh->samplerate = 192000; // DTS core require 48000
|
||||
sh->channels = 2*4;
|
||||
sh->i_bps = bps;
|
||||
break;
|
||||
case CODEC_ID_EAC3:
|
||||
spdif_ctx->iec61937_packet_size = 24576;
|
||||
sh->sample_format = AF_FORMAT_IEC61937_LE;
|
||||
sh->samplerate = 192000;
|
||||
sh->channels = 2;
|
||||
sh->i_bps = bps;
|
||||
break;
|
||||
case CODEC_ID_MP3:
|
||||
spdif_ctx->iec61937_packet_size = 4608;
|
||||
sh->sample_format = AF_FORMAT_MPEG2;
|
||||
sh->samplerate = srate;
|
||||
sh->channels = 2;
|
||||
sh->i_bps = bps;
|
||||
break;
|
||||
case CODEC_ID_TRUEHD:
|
||||
spdif_ctx->iec61937_packet_size = 61440;
|
||||
sh->sample_format = AF_FORMAT_IEC61937_LE;
|
||||
sh->samplerate = 192000;
|
||||
sh->channels = 8;
|
||||
sh->i_bps = bps;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return 1;
|
||||
|
||||
fail:
|
||||
uninit(sh);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int decode_audio(sh_audio_t *sh, unsigned char *buf,
|
||||
int minlen, int maxlen)
|
||||
{
|
||||
struct spdifContext *spdif_ctx = sh->context;
|
||||
AVFormatContext *lavf_ctx = spdif_ctx->lavf_ctx;
|
||||
AVPacket pkt;
|
||||
double pts;
|
||||
int ret, in_size, consumed, x;
|
||||
unsigned char *start = NULL;
|
||||
|
||||
consumed = spdif_ctx->out_buffer_len = 0;
|
||||
spdif_ctx->out_buffer_size = maxlen;
|
||||
spdif_ctx->out_buffer = buf;
|
||||
while (spdif_ctx->out_buffer_len + spdif_ctx->iec61937_packet_size < maxlen
|
||||
&& spdif_ctx->out_buffer_len < minlen) {
|
||||
if (sh->ds->eof)
|
||||
break;
|
||||
x = ds_get_packet_pts(sh->ds, &start, &pts);
|
||||
if (x <= 0) {
|
||||
x = 0;
|
||||
ds_parse(sh->ds, &start, &x, MP_NOPTS_VALUE, 0);
|
||||
if (x == 0)
|
||||
continue; // END_NOT_FOUND
|
||||
in_size = x;
|
||||
} else {
|
||||
in_size = x;
|
||||
consumed = ds_parse(sh->ds, &start, &x, pts, 0);
|
||||
if (x == 0) {
|
||||
mp_msg(MSGT_DECAUDIO,MSGL_V,
|
||||
"start[%p] pkt.size[%d] in_size[%d] consumed[%d] x[%d].\n",
|
||||
start, pkt.size, in_size, consumed, x);
|
||||
continue; // END_NOT_FOUND
|
||||
}
|
||||
sh->ds->buffer_pos -= in_size - consumed;
|
||||
}
|
||||
av_init_packet(&pkt);
|
||||
pkt.data = start;
|
||||
pkt.size = x;
|
||||
mp_msg(MSGT_DECAUDIO,MSGL_V,
|
||||
"start[%p] pkt.size[%d] in_size[%d] consumed[%d] x[%d].\n",
|
||||
start, pkt.size, in_size, consumed, x);
|
||||
if (pts != MP_NOPTS_VALUE) {
|
||||
sh->pts = pts;
|
||||
sh->pts_bytes = 0;
|
||||
}
|
||||
ret = lavf_ctx->oformat->write_packet(lavf_ctx, &pkt);
|
||||
if (ret < 0)
|
||||
break;
|
||||
}
|
||||
sh->pts_bytes += spdif_ctx->out_buffer_len;
|
||||
return spdif_ctx->out_buffer_len;
|
||||
}
|
||||
|
||||
static int control(sh_audio_t *sh, int cmd, void* arg, ...)
|
||||
{
|
||||
unsigned char *start;
|
||||
double pts;
|
||||
|
||||
switch (cmd) {
|
||||
case ADCTRL_RESYNC_STREAM:
|
||||
case ADCTRL_SKIP_FRAME:
|
||||
ds_get_packet_pts(sh->ds, &start, &pts);
|
||||
return CONTROL_TRUE;
|
||||
}
|
||||
return CONTROL_UNKNOWN;
|
||||
}
|
||||
|
||||
static void uninit(sh_audio_t *sh)
|
||||
{
|
||||
struct spdifContext *spdif_ctx = sh->context;
|
||||
AVFormatContext *lavf_ctx = spdif_ctx->lavf_ctx;
|
||||
|
||||
if (lavf_ctx) {
|
||||
if (lavf_ctx->oformat)
|
||||
lavf_ctx->oformat->write_trailer(lavf_ctx);
|
||||
av_freep(&lavf_ctx->pb);
|
||||
if (lavf_ctx->streams) {
|
||||
av_freep(&lavf_ctx->streams[0]->codec);
|
||||
av_freep(&lavf_ctx->streams[0]->info);
|
||||
av_freep(&lavf_ctx->streams[0]);
|
||||
}
|
||||
av_freep(&lavf_ctx->streams);
|
||||
av_freep(&lavf_ctx->priv_data);
|
||||
}
|
||||
av_freep(&lavf_ctx);
|
||||
av_freep(&spdif_ctx);
|
||||
}
|
Loading…
Reference in New Issue