1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-11 17:39:38 +00:00

Paul Ortyl's patch - tv4l timestamps (not so precise :()

git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@6554 b3059339-0415-0410-9bf9-f77b7e298cf2
This commit is contained in:
alex 2002-06-24 16:37:18 +00:00
parent a1a61e895a
commit d402d04e4a

View File

@ -19,6 +19,7 @@
#include <signal.h>
#include <sys/ioctl.h>
#include <sys/types.h>
#include <sys/time.h>
#include <linux/videodev.h>
#include <linux/soundcard.h>
#include <unistd.h>
@ -75,6 +76,9 @@ typedef struct {
int audio_samplesize[MAX_AUDIO_CHANNELS];
int audio_samplerate[MAX_AUDIO_CHANNELS];
int audio_blocksize;
/* other */
double starttime;
} priv_t;
#include "tvi_def.h"
@ -524,6 +528,12 @@ static int start(priv_t *priv)
}
#endif
{
struct timeval curtime;
gettimeofday(&curtime, NULL);
priv->starttime=curtime.tv_sec + curtime.tv_usec*.000001;
}
return(1);
}
@ -541,8 +551,6 @@ static int control(priv_t *priv, int cmd, void *arg)
return(TVI_CONTROL_FALSE);
}
case TVI_CONTROL_IS_AUDIO:
return(TVI_CONTROL_FALSE);
/* also disable audio for as it's not working! */
if (priv->channels[priv->act_channel].flags & VIDEO_VC_AUDIO)
{
return(TVI_CONTROL_TRUE);
@ -821,6 +829,8 @@ static int control(priv_t *priv, int cmd, void *arg)
static double grab_video_frame(priv_t *priv, char *buffer, int len)
{
struct timeval curtime;
double timestamp;
int frame = priv->queue % priv->nbuf;
int nextframe = (priv->queue+1) % priv->nbuf;
@ -841,6 +851,9 @@ static double grab_video_frame(priv_t *priv, char *buffer, int len)
priv->queue++;
gettimeofday(&curtime, NULL);
timestamp=curtime.tv_sec + curtime.tv_usec*.000001;
mp_dbg(MSGT_TV, MSGL_DBG3, "mmap: %p + offset: %d => %p\n",
priv->mmap, priv->mbuf.offsets[frame],
priv->mmap+priv->mbuf.offsets[frame]);
@ -851,7 +864,7 @@ static double grab_video_frame(priv_t *priv, char *buffer, int len)
/* copy the actual frame */
memcpy(buffer, priv->mmap+priv->mbuf.offsets[frame], len);
return(0);
return(timestamp-priv->starttime);
}
static int get_video_framesize(priv_t *priv)
@ -862,13 +875,13 @@ static int get_video_framesize(priv_t *priv)
static double grab_audio_frame(priv_t *priv, char *buffer, int len)
{
int in_len = 0;
// int max_tries = 128;
int max_tries = 2;
mp_dbg(MSGT_TV, MSGL_DBG2, "grab_audio_frame(priv=%p, buffer=%p, len=%d)\n",
priv, buffer, len);
// while (--max_tries > 0)
for (;;)
while (--max_tries > 0)
// for (;;)
{
in_len = read(priv->audio_fd, buffer, len);
// printf("in_len: %d\n", in_len);
@ -882,7 +895,6 @@ static double grab_audio_frame(priv_t *priv, char *buffer, int len)
break;
}
}
// printf("tries: %d\n", 128-max_tries);
return 0; //(in_len); // FIXME!
}