summaryrefslogtreecommitdiffstats
path: root/mplayer.c
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-07-08 12:34:08 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-07-08 12:34:08 +0000
commit0a6439a5619d2de2ef9c0f81a260b4354411e6e9 (patch)
tree1fad22de59bf585c880d399823492803b24869dc /mplayer.c
parenta768ca2013e5315990ebd4e81e8330beac689634 (diff)
downloadmpv-0a6439a5619d2de2ef9c0f81a260b4354411e6e9.tar.bz2
mpv-0a6439a5619d2de2ef9c0f81a260b4354411e6e9.tar.xz
mpeg2 timing & fps fix for ffmpeg12 codec
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@1296 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'mplayer.c')
-rw-r--r--mplayer.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/mplayer.c b/mplayer.c
index 7348852d39..1555279cc3 100644
--- a/mplayer.c
+++ b/mplayer.c
@@ -1517,6 +1517,7 @@ if(1)
videobuf_len=0;
while(videobuf_len<VIDEOBUFFER_SIZE-MAX_VIDEO_PACKET_SIZE){
int i=sync_video_packet(d_video);
+ void* buffer=&videobuffer[videobuf_len+4];
if(in_frame){
if(i<0x101 || i>=0x1B0){ // not slice code -> end of frame
#if 1
@@ -1538,6 +1539,13 @@ if(1)
if(grab_frames==2 && (i==0x1B3 || i==0x1B8)) grab_frames=1;
if(!read_video_packet(d_video)){ eof=1; break;} // EOF
//printf("read packet 0x%X, len=%d\n",i,videobuf_len);
+ if(sh_video->codec->driver!=1){
+ // not libmpeg2:
+ switch(i){
+ case 0x1B3: header_process_sequence_header (picture, buffer);break;
+ case 0x1B5: header_process_extension (picture, buffer);break;
+ }
+ }
}
if(videobuf_len>max_framesize) max_framesize=videobuf_len; // debug