summaryrefslogtreecommitdiffstats
path: root/libvo
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-10-08 23:11:49 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-10-08 23:11:49 +0000
commita2fd2e1ef869ae8e4a1a8f467cae00baa45e278a (patch)
treed9794a059197969290c73e4777b99d290e8872d0 /libvo
parenta38ea8705b098f0656e43c18b34e3cb71bef08a0 (diff)
downloadmpv-a2fd2e1ef869ae8e4a1a8f467cae00baa45e278a.tar.bz2
mpv-a2fd2e1ef869ae8e4a1a8f467cae00baa45e278a.tar.xz
- fixed a 10l bug: setting PTS flag even if no PTS stored
- support for file-writing even if --enable-dvb: -vo mpegpes:filename.mpg git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@7673 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libvo')
-rw-r--r--libvo/vo_mpegpes.c23
1 files changed, 15 insertions, 8 deletions
diff --git a/libvo/vo_mpegpes.c b/libvo/vo_mpegpes.c
index f4d586ed83..f2e8883182 100644
--- a/libvo/vo_mpegpes.c
+++ b/libvo/vo_mpegpes.c
@@ -84,6 +84,7 @@ config(uint32_t s_width, uint32_t s_height, uint32_t width, uint32_t height, uin
static uint32_t preinit(const char *arg){
#ifdef HAVE_DVB
+ if(!arg){
//|O_NONBLOCK
if((vo_mpegpes_fd = open("/dev/ost/video",O_RDWR)) < 0){
perror("DVB VIDEO DEVICE: ");
@@ -120,22 +121,24 @@ static uint32_t preinit(const char *arg){
perror("DVB VIDEO PLAY: ");
return -1;
}
- if ( (ioctl(vo_mpegpes_fd2,AUDIO_SET_AV_SYNC, true) < 0)){
+ if ( (ioctl(vo_mpegpes_fd2,AUDIO_SET_AV_SYNC, false) < 0)){
perror("DVB AUDIO SET AV SYNC: ");
return -1;
}
- if ( (ioctl(vo_mpegpes_fd2,AUDIO_SET_MUTE, false) < 0)){
+// if ( (ioctl(vo_mpegpes_fd2,AUDIO_SET_MUTE, false) < 0)){
+ if ( (ioctl(vo_mpegpes_fd2,AUDIO_SET_MUTE, true) < 0)){
perror("DVB AUDIO SET MUTE: ");
return -1;
}
-
-#else
- vo_mpegpes_fd=open("grab.mpg",O_WRONLY|O_CREAT,0666);
+ return 0;
+ }
+#endif
+ vo_mpegpes_fd=open(arg ? arg : "grab.mpg",O_WRONLY|O_CREAT,0666);
if(vo_mpegpes_fd<0){
perror("vo_mpegpes");
return -1;
}
-#endif
+ vo_mpegpes_fd2=vo_mpegpes_fd;
return 0;
}
@@ -248,8 +251,11 @@ void send_lpcm_packet(unsigned char* data,int len,int id,unsigned int timestamp,
pes_header[5]=(payload_size+3+ptslen+7)&255;
// stuffing:
+ // TTCCxxxx CC=css TT=type: 1=STD 0=mpeg1 2=vob
pes_header[6]=0x81;
- pes_header[7]=0x80;
+
+ // FFxxxxxx FF=pts flags=2 vs 0
+ pes_header[7]=ptslen ? 0x80 : 0;
// hdrlen:
pes_header[8]=ptslen;
@@ -332,8 +338,9 @@ query_format(uint32_t format)
static void
uninit(void)
{
+ if(vo_mpegpes_fd2>=0 && vo_mpegpes_fd2!=vo_mpegpes_fd) close(vo_mpegpes_fd2);
+ vo_mpegpes_fd2=-1;
if(vo_mpegpes_fd>=0){ close(vo_mpegpes_fd);vo_mpegpes_fd=-1;}
- if(vo_mpegpes_fd2>=0){ close(vo_mpegpes_fd2);vo_mpegpes_fd2=-1;}
}