summaryrefslogtreecommitdiffstats
path: root/vidix
diff options
context:
space:
mode:
authornick <nick@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-01-05 18:16:19 +0000
committernick <nick@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-01-05 18:16:19 +0000
commitce7dd4588d09faee8bf3a610893ce9ab670e3d09 (patch)
tree45a7436494cb483fc980f533500bf190d34ea16d /vidix
parent67aaf4da607c3bfa6f5e5eb5387e17ac340221d1 (diff)
downloadmpv-ce7dd4588d09faee8bf3a610893ce9ab670e3d09.tar.bz2
mpv-ce7dd4588d09faee8bf3a610893ce9ab670e3d09.tar.xz
minor interface changing
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@3996 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'vidix')
-rw-r--r--vidix/vidix.h14
-rw-r--r--vidix/vidixlib.c38
-rw-r--r--vidix/vidixlib.h8
3 files changed, 25 insertions, 35 deletions
diff --git a/vidix/vidix.h b/vidix/vidix.h
index 0111c0e922..31f8e7ff79 100644
--- a/vidix/vidix.h
+++ b/vidix/vidix.h
@@ -26,7 +26,7 @@ extern "C" {
extern unsigned vixGetVersion( void );
/* Probes video hw. Returns 0 if ok else errno */
-extern int vixProbe( void );
+extern int vixProbe( int verbose );
/* Initializes driver. Returns 0 if ok else errno */
extern int vixInit( void );
/* Destroys driver */
@@ -144,23 +144,17 @@ typedef struct vidix_playback_s
#define KEYS_OR 2
#define KEYS_XOR 3
unsigned key_op; /* app -> driver: keys operations */
-}vidix_playback_t;
-
- /* Returns 0 if ok else errno */
-extern int vixConfigPlayback(const vidix_playback_t *);
-
-typedef struct vidix_dga_s
-{
+ /* memory model */
unsigned frame_size; /* app -> driver */
unsigned num_frames; /* app -> driver; after call: driver -> app */
#define LVO_MAXFRAMES 32
unsigned offsets[LVO_MAXFRAMES]; /* driver -> app */
vidix_yuv_t offset; /* driver -> app: relative offsets within frame for yuv planes */
void* dga_addr; /* driver -> app: linear address */
-}vidix_dga_t;
+}vidix_playback_t;
/* Returns 0 if ok else errno */
-extern int vixMapPlayback(vidix_dga_t *);
+extern int vixConfigPlayback(vidix_playback_t *);
/* Returns 0 if ok else errno */
extern int vixPlaybackOn( void );
diff --git a/vidix/vidixlib.c b/vidix/vidixlib.c
index 1dc4a53e26..80e80ae27f 100644
--- a/vidix/vidixlib.c
+++ b/vidix/vidixlib.c
@@ -32,8 +32,7 @@ typedef struct vdl_stream_s
void * handle;
int (*get_caps)(vidix_capability_t *);
int (*query_fourcc)(vidix_fourcc_t *);
- int (*config_playback)(const vidix_playback_t *);
- int (*map_playback)(vidix_dga_t *);
+ int (*config_playback)(vidix_playback_t *);
int (*playback_on)( void );
int (*playback_off)( void );
/* Functions below can be missed in driver ;) */
@@ -59,7 +58,6 @@ static int vdl_fill_driver(VDL_HANDLE stream)
t_vdl(stream)->get_caps = dlsym(t_vdl(stream)->handle,"vixGetCapability");
t_vdl(stream)->query_fourcc = dlsym(t_vdl(stream)->handle,"vixQueryFourcc");
t_vdl(stream)->config_playback= dlsym(t_vdl(stream)->handle,"vixConfigPlayback");
- t_vdl(stream)->map_playback = dlsym(t_vdl(stream)->handle,"vixMapPlayback");
t_vdl(stream)->playback_on = dlsym(t_vdl(stream)->handle,"vixPlaybackOn");
t_vdl(stream)->playback_off = dlsym(t_vdl(stream)->handle,"vixPlaybackOff");
t_vdl(stream)->frame_sel = dlsym(t_vdl(stream)->handle,"vixPlaybackFrameSelect");
@@ -67,18 +65,19 @@ static int vdl_fill_driver(VDL_HANDLE stream)
t_vdl(stream)->set_eq = dlsym(t_vdl(stream)->handle,"vixPlaybackSetEq");
t_vdl(stream)->copy_frame = dlsym(t_vdl(stream)->handle,"vixPlaybackCopyFrame");
/* check driver viability */
- if(!( t_vdl(stream)->get_caps && t_vdl(stream)->query_fourcc && t_vdl(stream)->config_playback &&
- t_vdl(stream)->map_playback && t_vdl(stream)->playback_on && t_vdl(stream)->playback_off))
+ if(!( t_vdl(stream)->get_caps && t_vdl(stream)->query_fourcc &&
+ t_vdl(stream)->config_playback && t_vdl(stream)->playback_on &&
+ t_vdl(stream)->playback_off))
return 0;
return 1;
}
-static int vdl_probe_driver(VDL_HANDLE stream,const char *path,const char *name,unsigned cap)
+static int vdl_probe_driver(VDL_HANDLE stream,const char *path,const char *name,unsigned cap,int verbose)
{
char drv_name[FILENAME_MAX];
vidix_capability_t vid_cap;
unsigned (*_ver)(void);
- int (*_probe)(void);
+ int (*_probe)(int);
int (*_cap)(vidix_capability_t*);
strcpy(drv_name,path);
strcat(drv_name,name);
@@ -88,7 +87,7 @@ static int vdl_probe_driver(VDL_HANDLE stream,const char *path,const char *name,
_cap = dlsym(t_vdl(stream)->handle,"vixGetCapability");
if(_ver) { if((*_ver)() != VIDIX_VERSION) { err: dlclose(t_vdl(stream)->handle); t_vdl(stream)->handle = 0; return 0; } }
else goto err;
- if(_probe) { if((*_probe)() != 0) goto err; }
+ if(_probe) { if((*_probe)(verbose) != 0) goto err; }
else goto err;
if(_cap) { if((*_cap)(&vid_cap) != 0) goto err; }
else goto err;
@@ -96,7 +95,7 @@ static int vdl_probe_driver(VDL_HANDLE stream,const char *path,const char *name,
return 1;
}
-static int vdl_find_driver(VDL_HANDLE stream,const char *path,unsigned cap)
+static int vdl_find_driver(VDL_HANDLE stream,const char *path,unsigned cap,int verbose)
{
DIR *dstream;
struct dirent *name;
@@ -105,14 +104,14 @@ static int vdl_find_driver(VDL_HANDLE stream,const char *path,unsigned cap)
while(!done)
{
name = readdir(dstream);
- if(name) { if(vdl_probe_driver(stream,path,name->d_name,cap)) break; }
+ if(name) { if(vdl_probe_driver(stream,path,name->d_name,cap,verbose)) break; }
else done = 1;
}
closedir(dstream);
return done?0:1;
}
-VDL_HANDLE vdlOpen(const char *path,const char *name,unsigned cap)
+VDL_HANDLE vdlOpen(const char *path,const char *name,unsigned cap,int verbose)
{
vdl_stream_t *stream;
char drv_name[FILENAME_MAX];
@@ -121,6 +120,7 @@ VDL_HANDLE vdlOpen(const char *path,const char *name,unsigned cap)
if(name)
{
unsigned (*ver)(void);
+ int (*probe)(int);
unsigned version = 0;
strcpy(drv_name,path);
strcat(drv_name,name);
@@ -138,13 +138,16 @@ VDL_HANDLE vdlOpen(const char *path,const char *name,unsigned cap)
if(t_vdl(stream)->handle) dlclose(t_vdl(stream)->handle);
goto err;
}
+ probe = dlsym(t_vdl(stream)->handle,"vixProbe");
+ if(probe) { if((*probe)(verbose)!=0) goto drv_err; }
+ else goto drv_err;
fill:
if(!vdl_fill_driver(stream)) goto drv_err;
}
else
- if(vdl_find_driver(stream,path,cap)) goto fill;
- else goto err;
- if(t_vdl(stream)->init) t_vdl(stream)->init();
+ if(vdl_find_driver(stream,path,cap,verbose)) goto fill;
+ else goto err;
+ if(t_vdl(stream)->init) if(t_vdl(stream)->init()) goto drv_err;
return stream;
}
@@ -166,16 +169,11 @@ int vdlQueryFourcc(VDL_HANDLE handle,vidix_fourcc_t *f)
return t_vdl(handle)->query_fourcc(f);
}
-int vdlConfigPlayback(VDL_HANDLE handle,const vidix_playback_t *p)
+int vdlConfigPlayback(VDL_HANDLE handle,vidix_playback_t *p)
{
return t_vdl(handle)->config_playback(p);
}
-int vdlMapPlayback(VDL_HANDLE handle,vidix_dga_t *m)
-{
- return t_vdl(handle)->map_playback(m);
-}
-
int vdlPlaybackOn(VDL_HANDLE handle)
{
return t_vdl(handle)->playback_on();
diff --git a/vidix/vidixlib.h b/vidix/vidixlib.h
index fd023d5de0..4381fe5198 100644
--- a/vidix/vidixlib.h
+++ b/vidix/vidixlib.h
@@ -35,9 +35,10 @@ extern unsigned vdlGetVersion( void );
path - specifies path where drivers are located.
name - specifies prefered driver name (can be NULL).
cap - specifies driver capability (TYPE_* constants).
+ verbose - specifies verbose level
returns !0 if ok else NULL.
*/
-extern VDL_HANDLE vdlOpen(const char *path,const char *name,unsigned cap);
+extern VDL_HANDLE vdlOpen(const char *path,const char *name,unsigned cap,int verbose);
/* Closes stream and corresponded driver. */
extern void vdlClose(VDL_HANDLE stream);
@@ -48,10 +49,7 @@ extern int vdlGetCapability(VDL_HANDLE, vidix_capability_t *);
extern int vdlQueryFourcc(VDL_HANDLE,vidix_fourcc_t *);
/* Returns 0 if ok else errno */
-extern int vdlConfigPlayback(VDL_HANDLE,const vidix_playback_t *);
-
- /* Returns 0 if ok else errno */
-extern int vdlMapPlayback(VDL_HANDLE,vidix_dga_t *);
+extern int vdlConfigPlayback(VDL_HANDLE, vidix_playback_t *);
/* Returns 0 if ok else errno */
extern int vdlPlaybackOn(VDL_HANDLE);