diff options
author | Mario Sergio Fujikawa Ferreira <lioux@FreeBSD.org> | 2003-03-05 22:27:25 +0000 |
---|---|---|
committer | Mario Sergio Fujikawa Ferreira <lioux@FreeBSD.org> | 2003-03-05 22:27:25 +0000 |
commit | 331e4213c9682358944f11a33fb2ebd6b89f64bf (patch) | |
tree | 58a603a46f27c56b275c8f8375b6754ca5f2dbf8 /multimedia/nuppelvideo | |
parent | 4ed55b9e7fc4a63ffb7d3145dc957cf78da0a3fc (diff) |
New port NuppelVideo version 0.52a: A very low CPU usage VCR/DVR
application
Submitted by: Steve O'Hara-Smith <steve@sohara.org>
Notes
Notes:
svn path=/head/; revision=76985
Diffstat (limited to 'multimedia/nuppelvideo')
-rw-r--r-- | multimedia/nuppelvideo/Makefile | 67 | ||||
-rw-r--r-- | multimedia/nuppelvideo/distinfo | 1 | ||||
-rw-r--r-- | multimedia/nuppelvideo/files/patch-Makefile | 45 | ||||
-rw-r--r-- | multimedia/nuppelvideo/files/patch-nuvplay.c | 12 | ||||
-rw-r--r-- | multimedia/nuppelvideo/files/patch-nuvrec.c | 396 | ||||
-rw-r--r-- | multimedia/nuppelvideo/files/patch-rtjpeg_plugin.c | 21 | ||||
-rw-r--r-- | multimedia/nuppelvideo/pkg-descr | 6 | ||||
-rw-r--r-- | multimedia/nuppelvideo/pkg-plist | 5 |
8 files changed, 553 insertions, 0 deletions
diff --git a/multimedia/nuppelvideo/Makefile b/multimedia/nuppelvideo/Makefile new file mode 100644 index 000000000000..6033bc72f42b --- /dev/null +++ b/multimedia/nuppelvideo/Makefile @@ -0,0 +1,67 @@ +# New ports collection makefile for: NuppelViodeo +# Date created: Mon 10 Feb 2003 22:21:51 CET +# Whom: Steve O'Hara-Smith <steve@sohara.org> +# +# $FreeBSD$ +# + +PORTNAME= NuppelVideo +PORTVERSION= 0.52.a +CATEGORIES= multimedia audio +MASTER_SITES= http://frost.htu.tuwien.ac.at/~roman/nuppelvideo/ +DISTNAME= ${PORTNAME}-${PORTVERSION:C/.(.)$/\1/} + +MAINTAINER= steve@sohara.org +COMMENT= A very low CPU usage VCR/DVR application + +USE_GMAKE= yes +USE_REINPLACE= yes + +# find dependencies +CFLAGS+= -I${LOCALBASE}/include -I${X11BASE}/include \ + -L${LOCALBASE}/lib -L${X11BASE}/lib + +.include <bsd.port.pre.mk> + +### +## Auto detected features +### +.if ${ARCH} == "i386" +. if (defined(MACHINE_CPU) && ${MACHINE_CPU:Mmmx:L} == "mmx") +WITH_MMX=yes +. endif +.endif + +### +## Port options +### +.ifdef(WITH_OPTIMIZED_CFLAGS) +CFLAGS+= -O3 -ffast-math -fomit-frame-pointer -finline-functions \ + -funroll-loops -fexpensive-optimizations +.endif +# +.ifdef(WITH_MMX) +CFLAGS+= -DMMX +.endif + +pre-everything:: +.ifndef(WITH_OPTIMIZED_CFLAGS) + @${ECHO_MSG} + @${ECHO_MSG} 'You can enable additional compilation optimizations' + @${ECHO_MSG} 'by defining WITH_OPTIMIZED_CFLAGS' +.endif +.if (${ARCH} == "i386" && !defined(WITH_MMX)) + @${ECHO_MSG} + @${ECHO_MSG} 'You can enable MMX compilation optimizations' + @${ECHO_MSG} 'by defining WITH_MMX' +.endif + +post-patch: +# C{C,FLAGS} safeness + @${REINPLACE_CMD} -E -e \ + 's|^CFLAGS.*$$|#|' \ + -e 's|^CC.*$$|#|' \ + -e 's|^(COPTSRT).*$$|\1=\$$(CFLAGS)|' \ + ${WRKSRC}/Makefile + +.include <bsd.port.post.mk> diff --git a/multimedia/nuppelvideo/distinfo b/multimedia/nuppelvideo/distinfo new file mode 100644 index 000000000000..0f6e598115a3 --- /dev/null +++ b/multimedia/nuppelvideo/distinfo @@ -0,0 +1 @@ +MD5 (NuppelVideo-0.52a.tar.gz) = 320fa43a19c71778ea0d403528125c1e diff --git a/multimedia/nuppelvideo/files/patch-Makefile b/multimedia/nuppelvideo/files/patch-Makefile new file mode 100644 index 000000000000..e3faa983695b --- /dev/null +++ b/multimedia/nuppelvideo/files/patch-Makefile @@ -0,0 +1,45 @@ +--- Makefile.orig Sat Jul 7 09:08:52 2001 ++++ Makefile Wed Mar 5 19:10:28 2003 +@@ -19,25 +19,25 @@ + + + soxfuncs.o: soxfuncs.c +- $(CC) $(COPTS) -O3 -funroll-loops -finline-functions -c soxfuncs.c ++ $(CC) $(COPTS) -c soxfuncs.c + + + resample.o: resample.c +- $(CC) $(COPTS) -O3 -funroll-loops -finline-functions -c resample.c ++ $(CC) $(COPTS) -c resample.c + + + minilzo.o: minilzo.c minilzo.h +- $(CC) $(COPTS) -O3 -fexpensive-optimizations -funroll-loops -finline-functions -c minilzo.c ++ $(CC) $(COPTS) -c minilzo.c + + + yuv2rgb_mmx.o: yuv2rgb_mmx.c yuv2rgb.h +- $(CC) $(COPTS) -O3 -funroll-loops -finline-functions -c yuv2rgb_mmx.c ++ $(CC) $(COPTS) -c yuv2rgb_mmx.c + + areaDeinterlace.o: areaDeinterlace.h areaDeinterlace.c +- $(CC) $(COPTS) -O3 -fexpensive-optimizations -funroll-loops -finline-functions -c areaDeinterlace.c ++ $(CC) $(COPTS) -c areaDeinterlace.c + + rtjpeg_plugin.o: rtjpeg_plugin.c rtjpeg_plugin.h +- $(CC) $(COPTS) -O3 -fexpensive-optimizations -funroll-loops -finline-functions -c rtjpeg_plugin.c ++ $(CC) $(COPTS) -c rtjpeg_plugin.c + + nuvrec: nuvrec.c RTjpegN.h RTjpegN.o minilzo.o + $(CC) $(COPTS) -o nuvrec minilzo.o RTjpegN.o nuvrec.c +@@ -52,8 +52,8 @@ + $(CC) $(COPTS) -static -o nuvrec minilzo.o RTjpegN.o nuvrec.c + + install: nuvrec nuvplay +- strip nuvrec nuvplay +- install -m 755 nuvrec nuvplay nuvedit nuv2mpg nuv2vbr /usr/local/bin ++ @${BSD_INSTALL_PROGRAM} nuvrec nuvplay ${PREFIX}/bin ++ @${BSD_INSTALL_SCRIPT} nuvedit nuv2mpg nuv2vbr ${PREFIX}/bin + + clean: + rm -f *.o nuvplay nuvrec diff --git a/multimedia/nuppelvideo/files/patch-nuvplay.c b/multimedia/nuppelvideo/files/patch-nuvplay.c new file mode 100644 index 000000000000..0adf99aaaf92 --- /dev/null +++ b/multimedia/nuppelvideo/files/patch-nuvplay.c @@ -0,0 +1,12 @@ +diff -ur ../NuppelVideo-0.52a/nuvplay.c ./nuvplay.c +--- ../NuppelVideo-0.52a/nuvplay.c Wed Jul 4 17:28:41 2001 ++++ ./nuvplay.c Mon Feb 10 18:38:06 2003 +@@ -272,7 +272,7 @@ + if (rtjpeg_fileheader.audioblocks!=0 && playaudio!=0) { + if (writeaudiotofile) { + // write to file, file MUST NOT exist +- audf = (writeaudiotofile==1) ? open(audiofilename, O_EXCL|O_CREAT|O_WRONLY|O_SYNC, 0600) : 1; ++ audf = (writeaudiotofile==1) ? open(audiofilename, O_EXCL|O_CREAT|O_WRONLY|O_FSYNC, 0600) : 1; + if (audf==-1) { + if (errno!=EEXIST) + fprintf(stderr, "cannot write to file '%s', no audio is played\n", audiofilename); diff --git a/multimedia/nuppelvideo/files/patch-nuvrec.c b/multimedia/nuppelvideo/files/patch-nuvrec.c new file mode 100644 index 000000000000..43890279cfe7 --- /dev/null +++ b/multimedia/nuppelvideo/files/patch-nuvrec.c @@ -0,0 +1,396 @@ +diff -ur ../NuppelVideo-0.52a/nuvrec.c ./nuvrec.c +--- ../NuppelVideo-0.52a/nuvrec.c Wed Jul 4 23:59:58 2001 ++++ ./nuvrec.c Mon Feb 10 21:43:02 2003 +@@ -27,14 +27,22 @@ + #include <sys/stat.h> + #include <sys/time.h> + #include <sys/resource.h> ++#include <machine/ioctl_meteor.h> ++#include <machine/ioctl_bt848.h> + #include <sys/soundcard.h> +-#include <linux/videodev.h> +-#include <linux/wait.h> ++#include <sys/wait.h> + #include <errno.h> + #include "minilzo.h" + #include "RTjpegN.h" + #include "nuppelvideo.h" + ++typedef unsigned char UINT8; ++typedef unsigned int UINT32; ++typedef unsigned long long UINT64; ++typedef signed char INT8; ++typedef signed int INT32; ++typedef signed long long INT64; ++ + // #define TESTINPUT 1 + // #define TESTSPLIT 1 + #define KEYFRAMEDIST 30 +@@ -47,11 +55,28 @@ + #define MAXBYTESFORCE 2100000000 + #endif + +-// we need the BTTV_FIELDNR, so we really know how many frames we lose +-#define BTTV_FIELDNR _IOR('v' , BASE_VIDIOCPRIVATE+2, unsigned int) ++#define PAL 1 ++#define NTSC 2 ++#define SECAM 3 ++#define PALN 4 ++#define PALM 5 ++#define PALBDGHI PAL ++#define NTSCJ 6 ++#define NTSCM NTSC ++ ++/* PAL is 768 x 576. NTSC is 640 x 480 */ ++#define PAL_HEIGHT 576 ++#define SECAM_HEIGHT 576 ++#define NTSC_HEIGHT 480 ++ ++#include <sys/mman.h> ++#include <sys/time.h> ++#include <signal.h> + + /* Globals */ + ++int bktr_dev[] = { METEOR_DEV0, METEOR_DEV1, METEOR_DEV2, ++ METEOR_DEV3, METEOR_DEV_SVIDEO }; + int fd; // output file haendle + int ostr=0; + __s8 *strm; +@@ -71,10 +96,10 @@ + unsigned long long audiobytes; + int effectivedsp; + int ntsc=0; // default to PAL, this info is only for the video header ++int secam=0; + int quiet; + int rawmode=0; +-int usebttv=1; +-struct video_audio origaudio; ++int usebttv=0; + + //#define DP(DSTRING) fprintf(stderr, "%s\n", DSTRING); + #define DP(DSTRING) +@@ -173,9 +198,6 @@ + kill(pid, 9); + if (recordaudio) kill(pid2, 9); + +- // reset audio settings +- if (ioctl(fd, VIDIOCSAUDIO, &origaudio)<0) perror("VIDIOCSAUDIO"); +- + if (!quiet) fprintf(stderr, "\n"); // preserve status line + exit(i); + } +@@ -201,24 +223,25 @@ + unsigned char *startaudio; + + if (init_shm) { +- shmid = shmget(IPC_PRIVATE, video_buffer_size*video_buffer_count + ++ shmid = shmget(0xdeadbeef, video_buffer_size*video_buffer_count + + audio_buffer_size*audio_buffer_count + + video_buffer_count*sizeof(vidbuffertyp) + + audio_buffer_count*sizeof(audbuffertyp), +- IPC_EXCL | IPC_CREAT | 0600); ++ IPC_CREAT | SHM_R | SHM_W); + if (shmid == -1) + ERROR("shmget"); + } +- sharedbuffer = shmat(shmid, IPC_RMID, SHM_RND); ++ sharedbuffer = shmat(shmid, (char *) 0, 0); + if (sharedbuffer == (char*)-1) + { ++ fprintf (stderr, "shmid %d\n", shmid); + perror("shmat"); + if(shmctl(shmid, IPC_RMID, NULL)) + perror("shmctl"); + exit(-1); + } +- if(shmctl(shmid, IPC_RMID, NULL)) +- ERROR("shmctl"); ++// if(shmctl(shmid, IPC_RMID, NULL)) ++// ERROR("shmctl"); + + videobuffer = (struct vidbuffertype *)sharedbuffer; + startaudiodesc = (char *)(sharedbuffer + video_buffer_count*sizeof(vidbuffertyp)); +@@ -899,24 +922,6 @@ + #ifdef TESTINPUT + tf+=2; // when reading from files we won't lose frames ;) + #else +- if (usebttv) { +- // i hate it when interfaces changes and a non existent ioctl doesn't make an error +- // and doesn't return -1, returning 0 instead and making no error is really weird +- if (ioctl(fd, BTTV_FIELDNR, &tf)) { +- perror("BTTV_FIELDNR"); +- usebttv = 0; +- fprintf(stderr, "\nbttv_fieldnr not supported by bttv-driver" +- "\nuse insmod/modprobe bttv card=YOURCARD field_nr=1 to activate f.n." +- "\nfalling back to timecode routine to determine lost frames\n"); +- } +- if (tf==0) { +- usebttv = 0; +- fprintf(stderr, "\nbttv_fieldnr not supported by bttv-driver" +- "\nuse insmod/modprobe bttv card=YOURCARD field_nr=1 to activate f.n." +- "\nfalling back to timecode routine to determine lost frames\n"); +- } +- } +- + // here is the non preferable timecode - drop algorithm - fallback + if (!usebttv) { + +@@ -1073,21 +1078,125 @@ + exit(-1); + } + ++INT64 av_gettime(void) ++{ ++ struct timeval tv; ++ gettimeofday(&tv,NULL); ++ return (INT64)tv.tv_sec * 1000000 + tv.tv_usec; ++} ++ ++static int nsignals = 0; ++static void catchsignal(int signal) ++{ ++ nsignals++; ++ return; ++} ++ ++static int bktr_init(int video_fd, int width, int height, UINT8 **video_buf, int channel) ++{ ++ int format = PAL; ++ struct meteor_geomet geo; ++ int c; ++ int h_max; ++ struct sigaction act,old; ++ ++ if (channel < 0 || channel > 4) ++ channel = 1; ++ if (ntsc) { ++ format = NTSC; ++ } else if (secam) { ++ format = SECAM; ++ } ++ ++ memset(&act,0,sizeof(act)); ++ sigemptyset(&act.sa_mask); ++ act.sa_handler = catchsignal; ++ sigaction(SIGUSR1,&act,&old); ++ ++ geo.rows = height; ++ geo.columns = width; ++ geo.frames = 1; ++ geo.oformat = METEOR_GEO_YUV_422 | METEOR_GEO_YUV_12; ++ ++ switch (format) { ++ case PAL: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALBDGHI; break; ++ case PALN: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALN; break; ++ case PALM: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALM; break; ++ case SECAM: h_max = SECAM_HEIGHT; c = BT848_IFORM_F_SECAM; break; ++ case NTSC: h_max = NTSC_HEIGHT; c = BT848_IFORM_F_NTSCM; break; ++ case NTSCJ: h_max = NTSC_HEIGHT; c = BT848_IFORM_F_NTSCJ; break; ++ default: h_max = PAL_HEIGHT; c = BT848_IFORM_F_PALBDGHI; break; ++ } ++ if (height <= h_max/2) { ++ geo.oformat |= METEOR_GEO_EVEN_ONLY; ++ } ++ ++ if (ioctl(video_fd, METEORSETGEO, &geo) < 0) { ++ perror ("METEORSETGEO"); ++ return -EIO; ++ } ++ ++ if (ioctl(video_fd, BT848SFMT, &c) < 0) { ++ perror ("BT848SFMT"); ++ return -EIO; ++ } ++ ++ c = bktr_dev[channel]; ++ if (ioctl(video_fd, METEORSINPUT, &c) < 0) { ++ perror ("METEORSINPUT"); ++ return -EIO; ++ } ++ *video_buf = (UINT8 *) mmap((caddr_t)0, width*height*3, ++ PROT_READ, MAP_SHARED, video_fd, (off_t) 0); ++ if (*video_buf == MAP_FAILED) { ++ perror ("mmap"); ++ return -EIO; ++ } ++ c = METEOR_CAP_CONTINOUS; ++ ioctl(video_fd, METEORCAPTUR, &c); ++ c = SIGUSR1; ++ ioctl (video_fd, METEORSSIGNAL, &c); ++ return 0; ++} ++ ++/* note: we support only one picture read at a time */ ++static void bktr_getframe(int width, int height, UINT64 per_frame) ++{ ++ int size, halfsize; ++ UINT64 curtime; ++ static UINT64 last_frame_time = 0; ++ ++ size = width * height; ++ halfsize = size << 1; ++ ++ curtime = av_gettime(); ++ if (!last_frame_time ++ || ((last_frame_time + per_frame) > curtime)) { ++ if (!usleep (last_frame_time + per_frame + per_frame/8 - curtime)) { ++ if (!nsignals) ++ printf ("\nSLEPT NO signals - %d microseconds late\n", ++ av_gettime() - last_frame_time - per_frame); ++ } ++ } ++ nsignals = 0; ++ ++ last_frame_time = curtime; ++} ++ ++ + // ---------------------------------------------------------- + // -- MAIN -------------------------------------------------- + + int main(int argc, char** argv) + { +- struct video_mmap mm; +- struct video_mbuf vm; +- struct video_channel vchan; +- struct video_audio va; +- struct video_tuner vt; ++ int tuner_fd; ++ int video_frame_rate = 25; ++ UINT64 per_frame = (UINT64) (((UINT64)1000000 * (UINT64)10000) / (UINT64)video_frame_rate); ++ UINT8 *video_buf = NULL; + +- char *videodevice = "/dev/video0"; ++ char *videodevice = "/dev/bktr0"; + char c; +- int secam; +- int channel=0; ++ int channel=1; + double frequency=0.0; + long v4lfrequency=0; + int volume = -1; +@@ -1277,109 +1386,28 @@ + testinput(); + #else + +- fd = open(videodevice, O_RDWR|O_CREAT); ++ fd = open(videodevice, O_RDONLY); + if(fd<=0){ + perror("open"); + fatherhandler(-1); + } +- +- if(ioctl(fd, VIDIOCGMBUF, &vm)<0) +- { +- perror("VIDIOCMCAPTUREi0"); +- fatherhandler(-1); ++ tuner_fd = open ("/dev/tuner0", O_RDWR); ++ if (tuner_fd < 0) { ++ perror("Warning: Tuner not opened continuing"); + } +- if(vm.frames<2) +- { +- fprintf(stderr, "stoopid prog want min 2 cap buffs!\n"); +- fatherhandler(-1); +- } +- +- // fprintf(stderr, "We have vm.frames=%d\n", vm.frames); +- +- buf = (unsigned char*)mmap(0, vm.size, PROT_READ|PROT_WRITE, MAP_SHARED, fd, 0); +- if (buf<=0) +- { +- perror("mmap"); +- fatherhandler(-1); +- } +- +- +- vchan.channel = channel; +- if(ioctl(fd, VIDIOCGCHAN, &vchan)<0) perror("VIDIOCGCHAN"); +- +- // choose the right input +- if(ioctl(fd, VIDIOCSCHAN, &vchan)<0) perror("VIDIOCSCHAN"); +- +- // if channel has a audio then activate it +- if ((vchan.flags & VIDEO_VC_AUDIO)==VIDEO_VC_AUDIO) { +- // we assume only a channel with audio can have a tuner therefore +- // we only tune here if we are supposed to +- if (frequency != 0.0) { +- v4lfrequency = ((unsigned long)frequency)*16; +- v4lfrequency |= ((unsigned long)( (frequency-(v4lfrequency/16))*100 )*16)/100; // ?????? +- if (ioctl(fd, VIDIOCSFREQ, &v4lfrequency)<0) perror("VIDIOCSFREQ"); +- if (!quiet) fprintf(stderr, "tuner frequency set to '%5.4f' MHz.\n", frequency); +- } +- if (!quiet) fprintf(stderr, "%s\n", "unmuting tv-audio"); +- // audio hack, to enable audio from tvcard, in case we use a tuner +- va.audio = 0; // use audio channel 0 +- if (ioctl(fd, VIDIOCGAUDIO, &va)<0) perror("VIDIOCGAUDIO"); +- origaudio = va; +- if (!quiet) fprintf(stderr, "audio volume was '%d'\n", va.volume); +- va.audio = 0; +- va.flags &= ~VIDEO_AUDIO_MUTE; // now this really has to work +- +- if ((volume==-1 && va.volume<32768) || volume!=-1) { +- if (volume==-1) { +- va.volume = 32768; // no more silence 8-) +- } else { +- va.volume = volume; +- } +- if (!quiet) fprintf(stderr, "audio volume set to '%d'\n", va.volume); +- } +- if (ioctl(fd, VIDIOCSAUDIO, &va)<0) perror("VIDIOCSAUDIO"); +- } else { +- if (!quiet) fprintf(stderr, "channel '%d' has no tuner (composite)\n", channel); ++ ++ bktr_init (fd, w, h, &video_buf, channel); ++ if (frequency != 0.0) { ++ v4lfrequency = (unsigned long)(frequency*16); ++ if (ioctl(tuner_fd, TVTUNER_SETFREQ, &v4lfrequency)<0) ++ perror("TVTUNER_SETFREQ"); ++ if (!quiet) ++ fprintf(stderr, "tuner frequency set to '%5.4f' MHz.\n", frequency); + } + +- // setting video mode +- vt.tuner = 0; +- if(ioctl(fd, VIDIOCGTUNER, &vt)<0) perror("VIDIOCGTUNER"); +- if (ntsc) { vt.flags |= VIDEO_TUNER_NTSC; vt.mode |= VIDEO_MODE_NTSC; } +- else if (secam) { vt.flags |= VIDEO_TUNER_SECAM; vt.mode |= VIDEO_MODE_SECAM; } +- else { vt.flags |= VIDEO_TUNER_PAL; vt.mode |= VIDEO_MODE_PAL; } +- vt.tuner = 0; +- if(ioctl(fd, VIDIOCSTUNER, &vt)<0) perror("VIDIOCSTUNER"); +- +- // make sure we use the right input +- if(ioctl(fd, VIDIOCSCHAN, &vchan)<0) perror("VIDIOCSCHAN"); +- +- mm.height = h; +- mm.width = w; +- mm.format = VIDEO_PALETTE_YUV420P ; /* YCrCb422 */ +- +- mm.frame = 0; +- if(ioctl(fd, VIDIOCMCAPTURE, &mm)<0) perror("VIDIOCMCAPTUREi0"); +- mm.frame = 1; +- if(ioctl(fd, VIDIOCMCAPTURE, &mm)<0) perror("VIDIOCMCAPTUREi1"); +- + while(1) { +- frame=0; +- mm.frame = 0; +- if(ioctl(fd, VIDIOCSYNC, &frame)<0) perror("VIDIOCSYNC0"); +- else { +- if(ioctl(fd, VIDIOCMCAPTURE, &mm)<0) perror("VIDIOCMCAPTURE0"); +- DP("Captured 0er"); +- bufferit(buf+vm.offsets[0]); +- } +- frame=1; +- mm.frame = 1; +- if(ioctl(fd, VIDIOCSYNC, &frame)<0) perror("VIDIOCSYNC1"); +- else { +- if(ioctl(fd, VIDIOCMCAPTURE, &mm)<0) perror("VIDIOCMCAPTURE1"); +- DP("Captured 1er"); +- bufferit(buf+vm.offsets[1]); +- } ++ bktr_getframe (w, h, per_frame); ++ bufferit(video_buf); + } + #endif + diff --git a/multimedia/nuppelvideo/files/patch-rtjpeg_plugin.c b/multimedia/nuppelvideo/files/patch-rtjpeg_plugin.c new file mode 100644 index 000000000000..54575d9cca62 --- /dev/null +++ b/multimedia/nuppelvideo/files/patch-rtjpeg_plugin.c @@ -0,0 +1,21 @@ +diff -ur ../NuppelVideo-0.52a/rtjpeg_plugin.c ./rtjpeg_plugin.c +--- ../NuppelVideo-0.52a/rtjpeg_plugin.c Tue Jul 3 15:34:02 2001 ++++ ./rtjpeg_plugin.c Mon Feb 10 18:42:01 2003 +@@ -155,7 +155,7 @@ + while (pos > startpos && !foundit) { + lseek(rtjpeg_file, pos, SEEK_SET); + read(rtjpeg_file, buffer, 32768); +- needlepos = (char *)memmem(buffer, 32768, "RTjjjjjjjjjjjjjjjjjjjjjjjj", FRAMEHEADERSIZE); ++// needlepos = (char *)memmem(buffer, 32768, "RTjjjjjjjjjjjjjjjjjjjjjjjj", FRAMEHEADERSIZE); + if (needlepos != NULL) { + lseek(rtjpeg_file, pos+(needlepos - buffer) + FRAMEHEADERSIZE, SEEK_SET); + read(rtjpeg_file, &frameheader, FRAMEHEADERSIZE); +@@ -273,7 +273,7 @@ + lseek(rtjpeg_file, pos, SEEK_SET); + read(rtjpeg_file, buffer, 32768); + //fprintf(stderr, "check for needle\n"); +- needlepos = (char *)memmem(buffer, 32768, "RTjjjjjjjjjjjjjjjjjjjjjjjj", FRAMEHEADERSIZE); ++// needlepos = (char *)memmem(buffer, 32768, "RTjjjjjjjjjjjjjjjjjjjjjjjj", FRAMEHEADERSIZE); + if (needlepos != NULL) { + lseek(rtjpeg_file, pos+(needlepos - buffer) + FRAMEHEADERSIZE, SEEK_SET); + read(rtjpeg_file, &frameheader, FRAMEHEADERSIZE); diff --git a/multimedia/nuppelvideo/pkg-descr b/multimedia/nuppelvideo/pkg-descr new file mode 100644 index 000000000000..cd62bd4d4df4 --- /dev/null +++ b/multimedia/nuppelvideo/pkg-descr @@ -0,0 +1,6 @@ +NuppelVideo is a simple low consuming and fast capture program for +bktr. It is based on the RTjpeg2.0 test3* programs from Justin +Schoemann who wrote the both very fast and fine RTjpeg2.0 codec +(improved by Joerg Walter and Wim Taymans). + +WWW: http://frost.htu.tuwien.ac.at/~roman/nuppelvideo/ diff --git a/multimedia/nuppelvideo/pkg-plist b/multimedia/nuppelvideo/pkg-plist new file mode 100644 index 000000000000..7d4661cead28 --- /dev/null +++ b/multimedia/nuppelvideo/pkg-plist @@ -0,0 +1,5 @@ +bin/nuv2mpg +bin/nuv2vbr +bin/nuvedit +bin/nuvplay +bin/nuvrec |