2 * This file is part of MPlayer.
4 * MPlayer is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * MPlayer is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License along
15 * with MPlayer; if not, write to the Free Software Foundation, Inc.,
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
27 #include "ad_internal.h"
28 #include "vd_ffmpeg.h"
29 #include "libaf/reorder_ch.h"
33 static const ad_info_t info
=
35 "FFmpeg/libavcodec audio decoders",
46 #include "libavcodec/avcodec.h"
49 static int preinit(sh_audio_t
*sh
)
51 sh
->audio_out_minsize
=AVCODEC_MAX_AUDIO_FRAME_SIZE
;
55 /* Prefer playing audio with the samplerate given in container data
56 * if available, but take number the number of channels and sample format
57 * from the codec, since if the codec isn't using the correct values for
58 * those everything breaks anyway.
60 static int setup_format(sh_audio_t
*sh_audio
, const AVCodecContext
*lavc_context
)
62 int sample_format
= sh_audio
->sample_format
;
63 switch (lavc_context
->sample_fmt
) {
64 case SAMPLE_FMT_U8
: sample_format
= AF_FORMAT_U8
; break;
65 case SAMPLE_FMT_S16
: sample_format
= AF_FORMAT_S16_NE
; break;
66 case SAMPLE_FMT_S32
: sample_format
= AF_FORMAT_S32_NE
; break;
67 case SAMPLE_FMT_FLT
: sample_format
= AF_FORMAT_FLOAT_NE
; break;
69 mp_msg(MSGT_DECAUDIO
, MSGL_FATAL
, "Unsupported sample format\n");
72 bool broken_srate
= false;
73 int samplerate
= lavc_context
->sample_rate
;
74 int container_samplerate
= sh_audio
->container_out_samplerate
;
75 if (!container_samplerate
&& sh_audio
->wf
)
76 container_samplerate
= sh_audio
->wf
->nSamplesPerSec
;
77 if (lavc_context
->codec_id
== CODEC_ID_AAC
78 && samplerate
== 2 * container_samplerate
)
80 else if (container_samplerate
)
81 samplerate
= container_samplerate
;
83 if (lavc_context
->channels
!= sh_audio
->channels
||
84 samplerate
!= sh_audio
->samplerate
||
85 sample_format
!= sh_audio
->sample_format
) {
86 sh_audio
->channels
=lavc_context
->channels
;
87 sh_audio
->samplerate
=samplerate
;
88 sh_audio
->sample_format
= sample_format
;
89 sh_audio
->samplesize
=af_fmt2bits(sh_audio
->sample_format
)/ 8;
91 mp_msg(MSGT_DECAUDIO
, MSGL_WARN
,
92 "Ignoring broken container sample rate for AAC with SBR\n");
98 static int init(sh_audio_t
*sh_audio
)
100 struct MPOpts
*opts
= sh_audio
->opts
;
103 AVCodecContext
*lavc_context
;
106 mp_msg(MSGT_DECAUDIO
,MSGL_V
,"FFmpeg's libavcodec audio codec\n");
109 lavc_codec
= avcodec_find_decoder_by_name(sh_audio
->codec
->dll
);
111 mp_tmsg(MSGT_DECAUDIO
,MSGL_ERR
,"Cannot find codec '%s' in libavcodec...\n",sh_audio
->codec
->dll
);
115 lavc_context
= avcodec_alloc_context();
116 sh_audio
->context
=lavc_context
;
118 lavc_context
->drc_scale
= opts
->drc_level
;
119 lavc_context
->sample_rate
= sh_audio
->samplerate
;
120 lavc_context
->bit_rate
= sh_audio
->i_bps
* 8;
122 lavc_context
->channels
= sh_audio
->wf
->nChannels
;
123 lavc_context
->sample_rate
= sh_audio
->wf
->nSamplesPerSec
;
124 lavc_context
->bit_rate
= sh_audio
->wf
->nAvgBytesPerSec
* 8;
125 lavc_context
->block_align
= sh_audio
->wf
->nBlockAlign
;
126 lavc_context
->bits_per_coded_sample
= sh_audio
->wf
->wBitsPerSample
;
128 lavc_context
->request_channels
= opts
->audio_output_channels
;
129 lavc_context
->codec_tag
= sh_audio
->format
; //FOURCC
130 lavc_context
->codec_type
= CODEC_TYPE_AUDIO
;
131 lavc_context
->codec_id
= lavc_codec
->id
; // not sure if required, imho not --A'rpi
133 /* alloc extra data */
134 if (sh_audio
->wf
&& sh_audio
->wf
->cbSize
> 0) {
135 lavc_context
->extradata
= av_mallocz(sh_audio
->wf
->cbSize
+ FF_INPUT_BUFFER_PADDING_SIZE
);
136 lavc_context
->extradata_size
= sh_audio
->wf
->cbSize
;
137 memcpy(lavc_context
->extradata
, sh_audio
->wf
+ 1,
138 lavc_context
->extradata_size
);
142 if (sh_audio
->codecdata_len
&& sh_audio
->codecdata
&& !lavc_context
->extradata
)
144 lavc_context
->extradata
= av_malloc(sh_audio
->codecdata_len
+
145 FF_INPUT_BUFFER_PADDING_SIZE
);
146 lavc_context
->extradata_size
= sh_audio
->codecdata_len
;
147 memcpy(lavc_context
->extradata
, (char *)sh_audio
->codecdata
,
148 lavc_context
->extradata_size
);
152 if (avcodec_open(lavc_context
, lavc_codec
) < 0) {
153 mp_tmsg(MSGT_DECAUDIO
,MSGL_ERR
, "Could not open codec.\n");
156 mp_msg(MSGT_DECAUDIO
,MSGL_V
,"INFO: libavcodec \"%s\" init OK!\n", lavc_codec
->name
);
158 // printf("\nFOURCC: 0x%X\n",sh_audio->format);
159 if(sh_audio
->format
==0x3343414D){
161 sh_audio
->ds
->ss_div
= 2*3; // 1 samples/packet
162 sh_audio
->ds
->ss_mul
= 2*sh_audio
->wf
->nChannels
; // 1 byte*ch/packet
164 if(sh_audio
->format
==0x3643414D){
166 sh_audio
->ds
->ss_div
= 2*6; // 1 samples/packet
167 sh_audio
->ds
->ss_mul
= 2*sh_audio
->wf
->nChannels
; // 1 byte*ch/packet
170 // Decode at least 1 byte: (to get header filled)
172 x
=decode_audio(sh_audio
,sh_audio
->a_buffer
,1,sh_audio
->a_buffer_size
);
173 } while (x
<= 0 && tries
++ < 5);
174 if(x
>0) sh_audio
->a_buffer_len
=x
;
176 sh_audio
->i_bps
=lavc_context
->bit_rate
/8;
177 if (sh_audio
->wf
&& sh_audio
->wf
->nAvgBytesPerSec
)
178 sh_audio
->i_bps
=sh_audio
->wf
->nAvgBytesPerSec
;
180 switch (lavc_context
->sample_fmt
) {
192 static void uninit(sh_audio_t
*sh
)
194 AVCodecContext
*lavc_context
= sh
->context
;
196 if (avcodec_close(lavc_context
) < 0)
197 mp_tmsg(MSGT_DECVIDEO
, MSGL_ERR
, "Could not close codec.\n");
198 av_freep(&lavc_context
->extradata
);
199 av_freep(&lavc_context
);
202 static int control(sh_audio_t
*sh
,int cmd
,void* arg
, ...)
204 AVCodecContext
*lavc_context
= sh
->context
;
206 case ADCTRL_RESYNC_STREAM
:
207 avcodec_flush_buffers(lavc_context
);
208 ds_clear_parser(sh
->ds
);
211 return CONTROL_UNKNOWN
;
214 static int decode_audio(sh_audio_t
*sh_audio
,unsigned char *buf
,int minlen
,int maxlen
)
216 unsigned char *start
=NULL
;
222 int x
=ds_get_packet_pts(sh_audio
->ds
,&start
, &pts
);
226 ds_parse(sh_audio
->ds
, &start
, &x
, MP_NOPTS_VALUE
, 0);
231 int consumed
= ds_parse(sh_audio
->ds
, &start
, &x
, pts
, 0);
232 sh_audio
->ds
->buffer_pos
-= in_size
- consumed
;
234 av_init_packet(&pkt
);
237 if (pts
!= MP_NOPTS_VALUE
) {
239 sh_audio
->pts_bytes
= 0;
241 y
=avcodec_decode_audio3(sh_audio
->context
,(int16_t*)buf
,&len2
,&pkt
);
242 //printf("return:%d samples_out:%d bitstream_in:%d sample_sum:%d\n", y, len2, x, len); fflush(stdout);
243 // LATM may need many packets to find mux info
244 if (y
== AVERROR(EAGAIN
))
246 if(y
<0){ mp_msg(MSGT_DECAUDIO
,MSGL_V
,"lavc_audio: error\n");break; }
247 if(!sh_audio
->parser
&& y
<x
)
248 sh_audio
->ds
->buffer_pos
+=y
-x
; // put back data (HACK!)
250 if (((AVCodecContext
*)sh_audio
->context
)->channels
>= 5) {
251 int samplesize
= av_get_bits_per_sample_format(((AVCodecContext
*)
252 sh_audio
->context
)->sample_fmt
) / 8;
253 reorder_channel_nch(buf
, AF_CHANNEL_LAYOUT_LAVC_DEFAULT
,
254 AF_CHANNEL_LAYOUT_MPLAYER_DEFAULT
,
255 ((AVCodecContext
*)sh_audio
->context
)->channels
,
256 len2
/ samplesize
, samplesize
);
259 if(len
<0) len
=len2
; else len
+=len2
;
262 sh_audio
->pts_bytes
+= len2
;
264 mp_dbg(MSGT_DECAUDIO
,MSGL_DBG2
,"Decoded %d -> %d \n",y
,len2
);
266 if (setup_format(sh_audio
, sh_audio
->context
))