Mercurial > mplayer.hg
changeset 6341:d79c52610702
RealVideo rv30 decoder, using binary driver from realplayer8
patch by Florian Schneider <flo-mplayer-dev@gmx.net>
some cleanup, and transin1{} fix by me
author | arpi |
---|---|
date | Sat, 08 Jun 2002 20:47:54 +0000 |
parents | 7f612cf06ba5 |
children | 40027495a6ed |
files | libmpcodecs/Makefile libmpcodecs/vd_real.c |
diffstat | 2 files changed, 214 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/libmpcodecs/Makefile Sat Jun 08 20:46:14 2002 +0000 +++ b/libmpcodecs/Makefile Sat Jun 08 20:47:54 2002 +0000 @@ -5,7 +5,7 @@ LIBNAME2 = libmpencoders.a AUDIO_SRCS=dec_audio.c ad.c ad_a52.c ad_acm.c ad_alaw.c ad_dk3adpcm.c ad_dk4adpcm.c ad_dshow.c ad_dvdpcm.c ad_ffmpeg.c ad_hwac3.c ad_imaadpcm.c ad_mp3.c ad_msadpcm.c ad_pcm.c ad_roqaudio.c ad_msgsm.c ad_faad.c ad_vorbis.c ad_libmad.c -VIDEO_SRCS=dec_video.c vd.c vd_null.c vd_cinepak.c vd_qtrpza.c vd_ffmpeg.c vd_dshow.c vd_vfw.c vd_odivx.c vd_divx4.c vd_raw.c vd_xanim.c vd_msvidc.c vd_fli.c vd_qtrle.c vd_qtsmc.c vd_roqvideo.c vd_cyuv.c vd_nuv.c vd_libmpeg2.c vd_msrle.c vd_huffyuv.c vd_zlib.c vd_mpegpes.c +VIDEO_SRCS=dec_video.c vd.c vd_null.c vd_real.c vd_cinepak.c vd_qtrpza.c vd_ffmpeg.c vd_dshow.c vd_vfw.c vd_odivx.c vd_divx4.c vd_raw.c vd_xanim.c vd_msvidc.c vd_fli.c vd_qtrle.c vd_qtsmc.c vd_roqvideo.c vd_cyuv.c vd_nuv.c vd_libmpeg2.c vd_msrle.c vd_huffyuv.c vd_zlib.c vd_mpegpes.c VFILTER_SRCS=vf.c vf_vo.c vf_crop.c vf_expand.c vf_pp.c vf_scale.c vf_format.c vf_yuy2.c vf_flip.c vf_rgb2bgr.c vf_rotate.c vf_mirror.c vf_palette.c vf_lavc.c vf_dvbscale.c vf_cropdetect.c vf_test.c ENCODER_SRCS=ve.c ve_divx4.c ve_lavc.c ve_vfw.c ve_rawrgb.c ve_libdv.c NATIVE_SRCS=native/RTjpegN.c native/cinepak.c native/cyuv.c native/fli.c native/minilzo.c native/msvidc.c native/nuppelvideo.c native/qtrle.c native/qtrpza.c native/qtsmc.c native/roqav.c native/xa_gsm.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libmpcodecs/vd_real.c Sat Jun 08 20:47:54 2002 +0000 @@ -0,0 +1,213 @@ +#include <stdio.h> +#include <stdlib.h> + +#include "config.h" +#ifdef USE_REALCODECS + +#include <dlfcn.h> + +#include "mp_msg.h" +#include "help_mp.h" + +#include "vd_internal.h" + +static vd_info_t info = { + "RealPlayer 8 video codecs", + "real", + VFM_REAL, + "Florian Schneider", + "using original closed source codecs for Linux", + "binary real video codecs" +}; + +LIBVD_EXTERN(real) + + +typedef unsigned long ulong; + +ulong (*rvyuv_custom_message)(ulong,ulong); +ulong (*rvyuv_free)(ulong); +ulong (*rvyuv_hive_message)(ulong,ulong); +ulong (*rvyuv_init)(ulong,ulong); +ulong (*rvyuv_transform)(ulong,ulong,ulong,ulong,ulong); +ulong (*rvyuv_rnfru_free)(ulong); +ulong (*rvyuv_rnfru_get_frame)(ulong,ulong,ulong); +ulong (*rvyuv_rnfru_init)(ulong,ulong,ulong); +ulong (*rvyuv_rnfru_setup)(ulong,ulong,ulong,ulong,ulong,ulong,ulong,ulong); + +void *rv_handle=NULL; + +void *__builtin_vec_new(unsigned long size) { + return malloc(size); +} + +void __builtin_vec_delete(void *mem) { + free(mem); +} + +void __pure_virtual(void) { + fprintf(stderr, "I'm outa here!\n"); + exit(1); +} + + +// to set/get/query special features/parameters +static int control(sh_video_t *sh,int cmd,void* arg,...){ +// switch(cmd){ +// case VDCTRL_QUERY_MAX_PP_LEVEL: +// return 9; +// case VDCTRL_SET_PP_LEVEL: +// vfw_set_postproc(sh,10*(*((int*)arg))); +// return CONTROL_OK; +// } + return CONTROL_UNKNOWN; +} + +/* exits program when failure */ +int load_syms(char *path) { + fputs("loadSyms()\n", stderr); + if (1) { + void *handle; + char *error; + + fprintf(stderr, "opening dll %s\n", path); + rv_handle = dlopen (path, RTLD_LAZY); + handle=rv_handle; + if (!handle) { + fputs (dlerror(), stderr); + return 0; + } + + rvyuv_custom_message = dlsym(handle, "RV20toYUV420CustomMessage"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvCustomMessage): %s\n", error); + return 0; + } + rvyuv_free = dlsym(handle, "RV20toYUV420Free"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvFree): %s\n", error); + return 0; + } + rvyuv_hive_message = dlsym(handle, "RV20toYUV420HiveMessage"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvHiveMessage): %s\n", error); + return 0; + } + rvyuv_init = dlsym(handle, "RV20toYUV420Init"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvInit): %s\n", error); + return 0; + } + rvyuv_transform = dlsym(handle, "RV20toYUV420Transform"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvTransform): %s\n", error); + return 0; + } + rvyuv_rnfru_free = dlsym(handle, "RV20toYUV420_RN_FRU_Free"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvRNFRUFree): %s\n", error); + return 0; + } + rvyuv_rnfru_get_frame = dlsym(handle, "RV20toYUV420_RN_FRU_GetFrame"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvRNFRUGetFrame): %s\n", error); + return 0; + } + rvyuv_rnfru_init = dlsym(handle, "RV20toYUV420_RN_FRU_Init"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvRNFRUInit): %s\n", error); + return 0; + } + rvyuv_rnfru_setup = dlsym(handle, "RV20toYUV420_RN_FRU_Setup"); + if ((error = dlerror()) != NULL) { + fprintf (stderr, "dlsym(rvyuvRNFRUSetup): %s\n", error); + return 0; + } + + } + return 1; +} + +/* we need exact positions */ +struct rv_init_t { + short unk1; + short w; + short h; + short unk3; + int unk2; + int unk4; + int unk5; + int format; +} rv_init_t; + +// init driver +static int init(sh_video_t *sh){ + //unsigned int out_fmt; + char path[4096]; + int result; + ulong cmsg24[4]={sh->disp_w,sh->disp_h,sh->disp_w,sh->disp_h}; + ulong cmsg_data[3]={0x24,2,&cmsg24}; + struct rv_init_t init_data={ +// 11, sh->disp_w, sh->disp_h,0,0,0x01099030, + 11, sh->disp_w, sh->disp_h,0,0,0x00099030, +// 1,0x30202002}; + 1,0x30203002}; + + sprintf(path, LIBDIR "/real/%s", sh->codec->dll); + if(!load_syms(path)){ + mp_msg(MSGT_DECVIDEO,MSGL_ERR,MSGTR_MissingDLLcodec,sh->codec->dll); + mp_msg(MSGT_DECVIDEO,MSGL_HINT,"You need to copy the contents of the codecs directory from RealPlayer8\n"); + mp_msg(MSGT_DECVIDEO,MSGL_HINT,"into " LIBDIR "/real/ !\n"); + return 0; + } + // only I420 supported + if(!mpcodecs_config_vo(sh,sh->disp_w,sh->disp_h,IMGFMT_I420)) return 0; + // init codec: + sh->context=NULL; + result=(*rvyuv_init)(&init_data, &sh->context); + if (result){ + mp_msg(MSGT_DECVIDEO,MSGL_ERR,"Couldn't open RealVideo codec, error code: 0x%X \n",result); + return 0; + } + // setup codec: +// realvid_hmsg(sh,0,2,0); + (*rvyuv_custom_message)(cmsg_data,sh->context); + mp_msg(MSGT_DECVIDEO,MSGL_V,"INFO: RealVideo codec init OK!\n"); + return 1; +} + +// uninit driver +static void uninit(sh_video_t *sh){ +// realvid_exit(); +} + +//mp_image_t* mpcodecs_get_image(sh_video_t *sh, int mp_imgtype, int mp_imgflag, int w, int h); + +// decode a frame +static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ + mp_image_t* mpi; + ulong result; + int *buff=(unsigned int *)((char*)data+len); + ulong transform_out[5]; + ulong transform_in[6]={ + len, // length of the packet (sub-packets appended) + 0, // unknown, seems to be unused + buff[0], // number of sub-packets - 1 + &buff[2], // table of sub-packet offsets + 0, // unknown, seems to be unused + buff[1], // timestamp (the integer value from the stream) + }; + + if(len<=0 || flags&2) return NULL; // skipped frame || hardframedrop + + mpi=mpcodecs_get_image(sh, MP_IMGTYPE_TEMP, 0 /*MP_IMGFLAG_ACCEPT_STRIDE*/, + sh->disp_w, sh->disp_h); + if(!mpi) return NULL; + + result=(*rvyuv_transform)(data, mpi->planes[0], transform_in, + transform_out, sh->context); + + return (result?NULL:mpi); +} + +#endif