Mercurial > mplayer.hg
view libmpdemux/tvi_def.h @ 7962:1d2d47aa8717
some card/mobo combos can't handle buffers larger than 128kB, we change the default buffer to 128kB, add warnings if the buffer becomes full, add a commandline option to enlarge the buffer and give suggestions to users to lessen the buffer size requirements (lower quality/resolution). 128kB should, however, be enough for everybody :-). Bug reported by Brain Edmonds, cause explained (to allow me to fix the driver) by Ronald Bultje (mjpegtools developer)
author | rik |
---|---|
date | Tue, 29 Oct 2002 19:06:26 +0000 |
parents | 8cd761968f35 |
children | 9fc45fe0d444 |
line wrap: on
line source
#include <stdlib.h> /* malloc */ static int init(priv_t *priv); static int uninit(priv_t *priv); static int control(priv_t *priv, int cmd, void *arg); static int start(priv_t *priv); static double grab_video_frame(priv_t *priv, char *buffer, int len); #ifdef HAVE_TV_BSDBT848 static double grabimmediate_video_frame(priv_t *priv, char *buffer, int len); #endif static int get_video_framesize(priv_t *priv); static double grab_audio_frame(priv_t *priv, char *buffer, int len); static int get_audio_framesize(priv_t *priv); static tvi_functions_t functions = { init, uninit, control, start, grab_video_frame, #ifdef HAVE_TV_BSDBT848 grabimmediate_video_frame, #endif get_video_framesize, grab_audio_frame, get_audio_framesize }; static tvi_handle_t *new_handle() { tvi_handle_t *h = (tvi_handle_t *)malloc(sizeof(tvi_handle_t)); if (!h) return(NULL); h->priv = (priv_t *)malloc(sizeof(priv_t)); if (!h->priv) { free(h); return(NULL); } memset(h->priv, 0, sizeof(priv_t)); h->info = &info; h->functions = &functions; h->seq = 0; h->chanlist = -1; h->chanlist_s = NULL; h->norm = -1; h->channel = -1; return(h); } static void free_handle(tvi_handle_t *h) { if (h) { if (h->priv) free(h->priv); free(h); } }