mirror of
https://github.com/mpv-player/mpv
synced 2025-01-30 11:42:04 +00:00
Switch ad_ffmpeg to avcodec_decode_audio3
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@29955 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
parent
65c2bae2b5
commit
dcd0daccca
@ -163,15 +163,19 @@ static int decode_audio(sh_audio_t *sh_audio,unsigned char *buf,int minlen,int m
|
||||
unsigned char *start=NULL;
|
||||
int y,len=-1;
|
||||
while(len<minlen){
|
||||
AVPacket pkt;
|
||||
int len2=maxlen;
|
||||
double pts;
|
||||
int x=ds_get_packet_pts(sh_audio->ds,&start, &pts);
|
||||
if(x<=0) break; // error
|
||||
av_init_packet(&pkt);
|
||||
pkt.data = start;
|
||||
pkt.size = x;
|
||||
if (pts != MP_NOPTS_VALUE) {
|
||||
sh_audio->pts = pts;
|
||||
sh_audio->pts_bytes = 0;
|
||||
}
|
||||
y=avcodec_decode_audio2(sh_audio->context,(int16_t*)buf,&len2,start,x);
|
||||
y=avcodec_decode_audio3(sh_audio->context,(int16_t*)buf,&len2,&pkt);
|
||||
//printf("return:%d samples_out:%d bitstream_in:%d sample_sum:%d\n", y, len2, x, len); fflush(stdout);
|
||||
if(y<0){ mp_msg(MSGT_DECAUDIO,MSGL_V,"lavc_audio: error\n");break; }
|
||||
if(y<x) sh_audio->ds->buffer_pos+=y-x; // put back data (HACK!)
|
||||
|
Loading…
Reference in New Issue
Block a user