Page MenuHomeFreeBSD

D1482.diff
No OneTemporary

D1482.diff

Index: multimedia/libv4l/Makefile
===================================================================
--- multimedia/libv4l/Makefile
+++ multimedia/libv4l/Makefile
@@ -1,32 +1,73 @@
# Created by: Andrew Thompson <thompsa@FreeBSD.org>
# $FreeBSD$
+# Check v4l_compat and v4l-utils slave ports
-PORTNAME= libv4l
-PORTVERSION= 0.8.8
-PORTREVISION= 2
+PORTNAME?= libv4l
+PORTVERSION= 1.6.3
+PORTREVISION?= 0
CATEGORIES= multimedia
-MASTER_SITES= http://linuxtv.org/downloads/v4l-utils/
-DISTNAME= v4l-utils-${PORTVERSION}
-
-MAINTAINER= hselasky@FreeBSD.org
-COMMENT= Video4Linux library
-
-BUILD_DEPENDS= v4l_compat>=1.0.20120501:${PORTSDIR}/multimedia/v4l_compat
-LIB_DEPENDS= libjpeg.so:${PORTSDIR}/graphics/jpeg
-
-MAKE_ARGS= CFLAGS="${CFLAGS} -I${LOCALBASE}/include" \
- LDFLAGS="-L${LOCALBASE}/lib" LIBDIR="${PREFIX}/lib"
-USES= gmake tar:bzip2
+MASTER_SITES= http://linuxtv.org/downloads/v4l-utils/:master \
+ LOCAL/kwm:local
+DISTFILES+= v4l-utils-${PORTVERSION}.tar.bz2:master \
+ linux-3.16.7-dvb-headers.tar.xz:local
+
+MAINTAINER?= multimedia@FreeBSD.org
+COMMENT?= Video4Linux library
+
+LICENSE= GPLv2 LGPL21
+LICENSE_COMB= dual
+
+LIBV4L_SLAVE?= no
+
+USES= tar:bzip2
+WRKSRC= ${WRKDIR}/v4l-utils-${PORTVERSION}
+
+.if ${LIBV4L_SLAVE} != compat
+BUILD_DEPENDS+= v4l_compat>=${PORTVERSION}:${PORTSDIR}/multimedia/v4l_compat
+LIB_DEPENDS+= libjpeg.so:${PORTSDIR}/graphics/jpeg \
+ libargp.so:${PORTSDIR}/devel/argp-standalone
+
+GNU_CONFIGURE= yes
+CPPFLAGS+= -I${LOCALBASE}/include
+LDFLAGS+= -L${LOCALBASE}/lib
+USES+= gmake libtool pathfix pkgconfig
USE_LDCONFIG= yes
-
-WRKSRC= ${WRKDIR}/${DISTNAME}/lib
+CONFIGURE_ARGS= --enable-libdvbv5 \
+ --disable-qv4l2 \
+ --without-libudev
+INSTALL_TARGET= install-strip
+
+. if ${LIBV4L_SLAVE} == utils
+BUILD_DEPENDS+= libv4l>=${PORTVERSION}:${PORTSDIR}/multimedia/libv4l
+LIB_DEPENDS+= libv4l2.so:${PORTSDIR}/multimedia/libv4l
+# Disabling building libv4l in the utils slave is too much hackery
+# Lets wait for subpackages
+CONFIGURE_ARGS+=--enable-v4l-utils
+. else
+CONFIGURE_ARGS+=--disable-v4l-utils --enable-libv4l
+. endif
+.endif
+
+HEADER_PATCHES= extra-linux_dvb_ca.h \
+ extra-linux_dvb_osd.h \
+ patch-include_linux_dvb_frontend.h \
+ patch-include_linux_dvb_video.h
post-patch:
- @${REINPLACE_CMD} -e 's|$$(LIBDIR)/pkgconfig|${PREFIX}/libdata/pkgconfig|g' \
- -e 's|-lrt||g' \
- ${WRKSRC}/libv4l1/Makefile \
- ${WRKSRC}/libv4l2/Makefile \
- ${WRKSRC}/libv4lconvert/Makefile
- @${RM} ${WRKSRC}/../include/linux/videodev2.h
+ @${REINPLACE_CMD} -e 's|$$libdir/pkgconfig|${PREFIX}/libdata/pkgconfig|g' \
+ ${WRKSRC}/configure
+# fix weird types, except a few headers which have compat code for these types.
+ @${FIND} ${WRKDIR} -type f \( -iname "*.h" ! -iname "input.h" ! -iname "videodev2.h" \) | \
+ ${XARGS} -n 10 ${REINPLACE_CMD} \
+ -e 's|linux/types.h|sys/types.h|g; s|__user||g; \
+ s|__u8|uint8_t|g; s|__s8|int8_t|g; \
+ s|__u16|uint16_t|g; s|__s16|int16_t|g; \
+ s|__u32|uint32_t|g; s|__s32|int32_t|g; \
+ s|__u64|uint64_t|g; s|__s64|int64_t|g'
+.if ${LIBV4L_SLAVE} == compat
+.for patch in ${HEADER_PATCHES}
+ @cd ${WRKDIR}/linux && ${PATCH} -p2 < ${FILESDIR}/${patch}
+.endfor
+.endif
.include <bsd.port.mk>
Index: multimedia/libv4l/distinfo
===================================================================
--- multimedia/libv4l/distinfo
+++ multimedia/libv4l/distinfo
@@ -1,2 +1,4 @@
-SHA256 (v4l-utils-0.8.8.tar.bz2) = 5fa4c6f4b6f5410de57271a03cc9a15f15195ef3fc05a8e42ecf507d6d70a87f
-SIZE (v4l-utils-0.8.8.tar.bz2) = 420888
+SHA256 (v4l-utils-1.6.3.tar.bz2) = 164abf5c1befcd27e8e6ef824a82d4015bdfb5d99ae82daa00e77d895ff9864c
+SIZE (v4l-utils-1.6.3.tar.bz2) = 1151081
+SHA256 (linux-3.16.7-dvb-headers.tar.xz) = 0ee217b243d52b8104e6b61bbf009bf84155573317720f41930af0a9ef50cdaa
+SIZE (linux-3.16.7-dvb-headers.tar.xz) = 11712
Index: multimedia/libv4l/files/extra-linux_dvb_ca.h
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/extra-linux_dvb_ca.h
@@ -0,0 +1,20 @@
+--- ../linux/dvb/ca.h.orig 2014-12-01 10:58:18.000000000 +0100
++++ ../linux/dvb/ca.h 2015-01-23 22:41:21.761540460 +0100
+@@ -80,9 +80,17 @@
+
+ #define CA_RESET _IO('o', 128)
+ #define CA_GET_CAP _IOR('o', 129, ca_caps_t)
++
++/* At least CA_GET_SLOT_INFO and CA_GET_MSG need to be _IOWR not _IOR.
++ * This is wrong on Linux too but there the driver doesn't care.
++ *
+ #define CA_GET_SLOT_INFO _IOR('o', 130, ca_slot_info_t)
+ #define CA_GET_DESCR_INFO _IOR('o', 131, ca_descr_info_t)
+ #define CA_GET_MSG _IOR('o', 132, ca_msg_t)
++ */
++#define CA_GET_SLOT_INFO _IOWR('o', 130, ca_slot_info_t)
++#define CA_GET_DESCR_INFO _IOR('o', 131, ca_descr_info_t)
++#define CA_GET_MSG _IOWR('o', 132, ca_msg_t)
+ #define CA_SEND_MSG _IOW('o', 133, ca_msg_t)
+ #define CA_SET_DESCR _IOW('o', 134, ca_descr_t)
+ #define CA_SET_PID _IOW('o', 135, ca_pid_t)
Index: multimedia/libv4l/files/extra-linux_dvb_osd.h
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/extra-linux_dvb_osd.h
@@ -0,0 +1,11 @@
+--- ../linux/dvb/osd.h.bak 2014-12-01 10:58:18.000000000 +0100
++++ ../linux/dvb/osd.h 2015-01-24 00:12:54.252160592 +0100
+@@ -24,7 +24,7 @@
+ #ifndef _DVBOSD_H_
+ #define _DVBOSD_H_
+
+-#include <linux/compiler.h>
++#include <sys/types.h>
+
+ typedef enum {
+ // All functions return -2 on "not open"
Index: multimedia/libv4l/files/patch-Make.rules
===================================================================
--- multimedia/libv4l/files/patch-Make.rules
+++ /dev/null
@@ -1,26 +0,0 @@
---- ../Make.rules.orig 2010-08-26 17:19:37.000000000 +0200
-+++ ../Make.rules 2010-11-04 20:26:22.000000000 +0100
-@@ -7,8 +7,8 @@ CFLAGS += -Wall -Wpointer-arith
- CXXFLAGS := $(CFLAGS)
- CFLAGS += -Wstrict-prototypes -Wmissing-prototypes
-
--PREFIX = /usr/local
--LIBDIR = $(PREFIX)/lib
-+PREFIX ?= /usr/local
-+LIBDIR ?= $(PREFIX)/lib
- # subdir below LIBDIR in which to install the libv4lx libc wrappers
- LIBSUBDIR = libv4l
-
-@@ -22,10 +22,10 @@ LIB_RELEASE = 0
- # And last various rules
-
- %.o: %.c
-- $(CC) -Wp,-MMD,"$*.d",-MQ,"$@",-MP -c $(CPPFLAGS) $(CFLAGS) -o $@ $<
-+ $(CC) -MMD -MF "$*.d" -MQ "$@" -MP -c $(CPPFLAGS) $(CFLAGS) -o $@ $<
-
- %.o: %.cpp
-- $(CXX) -Wp,-MMD,"$*.d",-MQ,"$@",-MP -c $(CPPFLAGS) $(CXXFLAGS) -o $@ $<
-+ $(CXX) -MMD -MF "$*.d" -MQ "$@" -MP -c $(CPPFLAGS) $(CXXFLAGS) -o $@ $<
-
- %.so:
- $(CC) -shared $(LDFLAGS) -Wl,-soname,$@.$(LIB_RELEASE) -o $@.$(LIB_RELEASE) $^ $(LIBS_$*)
Index: multimedia/libv4l/files/patch-configure
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/patch-configure
@@ -0,0 +1,11 @@
+--- configure.orig 2015-01-25 19:42:02.248041140 +0100
++++ configure 2015-01-25 19:42:14.503036421 +0100
+@@ -19876,7 +19876,7 @@
+ WITH_LIBV4L_FALSE=
+ fi
+
+- if test x$enable_v4l_utils != xno -a x$linux_os = xyes; then
++ if test x$enable_v4l_utils != xno; then
+ WITH_V4LUTILS_TRUE=
+ WITH_V4LUTILS_FALSE='#'
+ else
Index: multimedia/libv4l/files/patch-include_libv4l1-videodev.h
===================================================================
--- multimedia/libv4l/files/patch-include_libv4l1-videodev.h
+++ /dev/null
@@ -1,18 +0,0 @@
-diff -ru v4l-utils-0.8.4.orig/lib/include/libv4l1-videodev.h v4l-utils-0.8.4/lib/include/libv4l1-videodev.h
---- include/libv4l1-videodev.h 2011-06-27 09:52:38.000000000 +0200
-+++ include/libv4l1-videodev.h 2011-06-27 09:55:51.000000000 +0200
-@@ -2,7 +2,14 @@
- #ifndef __LINUX_VIDEODEV_H
- #define __LINUX_VIDEODEV_H
-
-+#ifdef linux
- #include <linux/ioctl.h>
-+#endif
-+
-+#ifdef __FreeBSD__
-+#include <sys/ioctl.h>
-+#endif
-+
- #include <stdint.h>
-
- #define VID_TYPE_CAPTURE 1 /* Can capture */
Index: multimedia/libv4l/files/patch-include_linux_dvb_frontend.h
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/patch-include_linux_dvb_frontend.h
@@ -0,0 +1,17 @@
+--- include/linux/dvb/frontend.h.orig 2015-01-10 15:04:07.446370686 +0100
++++ include/linux/dvb/frontend.h 2015-01-10 15:05:20.367365809 +0100
+@@ -549,7 +549,13 @@
+ };
+
+ #define FE_SET_PROPERTY _IOW('o', 82, struct dtv_properties)
+-#define FE_GET_PROPERTY _IOR('o', 83, struct dtv_properties)
++/*
++ * This is broken on linux as well but they workaround it in the driver.
++ * Since this is impossible to do on FreeBSD fix the header instead.
++ * Detailed and discussion :
++ * http://lists.freebsd.org/pipermail/freebsd-multimedia/2010-April/010958.html
++ */
++#define FE_GET_PROPERTY _IOW('o', 83, struct dtv_properties)
+
+
+ /**
Index: multimedia/libv4l/files/patch-include_linux_dvb_video.h
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/patch-include_linux_dvb_video.h
@@ -0,0 +1,11 @@
+--- include/linux/dvb/video.h.orig 2015-01-10 15:05:58.438363362 +0100
++++ include/linux/dvb/video.h 2015-01-10 15:06:25.350361374 +0100
+@@ -133,7 +133,7 @@
+ #define VIDEO_EVENT_FRAME_RATE_CHANGED 2
+ #define VIDEO_EVENT_DECODER_STOPPED 3
+ #define VIDEO_EVENT_VSYNC 4
+- __kernel_time_t timestamp;
++ struct timespec timestamp;
+ union {
+ video_size_t size;
+ unsigned int frame_rate; /* in frames per 1000sec */
Index: multimedia/libv4l/files/patch-lib_Makefile.in
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/patch-lib_Makefile.in
@@ -0,0 +1,13 @@
+--- lib/Makefile.in.orig 2015-01-12 10:51:50.193906738 +0100
++++ lib/Makefile.in 2015-01-12 10:52:04.848018891 +0100
+@@ -77,8 +77,8 @@
+ POST_UNINSTALL = :
+ build_triplet = @build@
+ host_triplet = @host@
+-@LINUX_OS_TRUE@am__append_1 = \
+-@LINUX_OS_TRUE@ libdvbv5
++am__append_1 = \
++ libdvbv5
+
+ subdir = lib
+ DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am
Index: multimedia/libv4l/files/patch-lib_libv4lconvert_control_libv4lcontrol.c
===================================================================
--- multimedia/libv4l/files/patch-lib_libv4lconvert_control_libv4lcontrol.c
+++ multimedia/libv4l/files/patch-lib_libv4lconvert_control_libv4lcontrol.c
@@ -1,6 +1,6 @@
---- libv4lconvert/control/libv4lcontrol.c.orig 2012-05-02 21:17:37.000000000 +0200
-+++ libv4lconvert/control/libv4lcontrol.c 2012-05-06 08:52:42.000000000 +0200
-@@ -345,6 +345,16 @@
+--- lib/libv4lconvert/control/libv4lcontrol.c.orig 2014-07-26 21:33:00.000000000 +0200
++++ lib/libv4lconvert/control/libv4lcontrol.c 2015-01-11 09:40:05.521158993 +0100
+@@ -361,6 +361,16 @@
unsigned short *vendor_id, unsigned short *product_id,
int *speed)
{
@@ -17,7 +17,7 @@
FILE *f;
int i, minor;
struct stat st;
-@@ -434,6 +444,7 @@
+@@ -457,6 +467,7 @@
return 0; /* Should never happen */
return 1;
@@ -25,16 +25,3 @@
}
/*
-@@ -456,7 +456,12 @@
- while (isspace(*start)) start++;
- n = strlen(start);
- while (n > 0 && isspace(start[n-1])) --n;
-+#ifndef __FreeBSD__
- trimmed_dmi = strndupa(start, n);
-+#else
-+ trimmed_dmi = (char *)alloca(n + 1);
-+ strlcpy(trimmed_dmi, start, n + 1);
-+#endif
-
- /* find trimmed value */
- for (entry_ptr = table_entries; *entry_ptr; entry_ptr++) {
Index: multimedia/libv4l/files/patch-libv4lconvert_control_libv4lcontrol.c
===================================================================
--- multimedia/libv4l/files/patch-libv4lconvert_control_libv4lcontrol.c
+++ multimedia/libv4l/files/patch-libv4lconvert_control_libv4lcontrol.c
@@ -1,40 +0,0 @@
---- libv4lconvert/control/libv4lcontrol.c.orig 2012-05-02 21:17:37.000000000 +0200
-+++ libv4lconvert/control/libv4lcontrol.c 2012-05-06 08:52:42.000000000 +0200
-@@ -345,6 +345,16 @@
- unsigned short *vendor_id, unsigned short *product_id,
- int *speed)
- {
-+#ifdef __FreeBSD__
-+#define WEBCAMD_IOCTL_GET_USB_VENDOR_ID _IOR('q', 250, unsigned short)
-+#define WEBCAMD_IOCTL_GET_USB_PRODUCT_ID _IOR('q', 251, unsigned short)
-+#define WEBCAMD_IOCTL_GET_USB_SPEED _IOR('q', 252, unsigned int)
-+ if (ioctl(data->fd, WEBCAMD_IOCTL_GET_USB_VENDOR_ID, vendor_id) == 0 &&
-+ ioctl(data->fd, WEBCAMD_IOCTL_GET_USB_PRODUCT_ID, product_id) == 0 &&
-+ ioctl(data->fd, WEBCAMD_IOCTL_GET_USB_SPEED, speed) == 0)
-+ return (1);
-+ return (0);
-+#else
- FILE *f;
- int i, minor;
- struct stat st;
-@@ -434,6 +444,7 @@
- return 0; /* Should never happen */
-
- return 1;
-+#endif
- }
-
- /*
-@@ -456,7 +456,12 @@
- while (isspace(*start)) start++;
- n = strlen(start);
- while (n > 0 && isspace(start[n-1])) --n;
-+#ifndef __FreeBSD__
- trimmed_dmi = strndupa(start, n);
-+#else
-+ trimmed_dmi = (char *)alloca(n + 1);
-+ strlcpy(trimmed_dmi, start, n + 1);
-+#endif
-
- /* find trimmed value */
- for (entry_ptr = table_entries; *entry_ptr; entry_ptr++) {
Index: multimedia/libv4l/files/patch-utils_Makefile.in
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/patch-utils_Makefile.in
@@ -0,0 +1,11 @@
+--- utils/Makefile.in.orig 2015-01-25 19:52:31.619994565 +0100
++++ utils/Makefile.in 2015-01-25 19:53:34.975249497 +0100
+@@ -374,7 +374,7 @@
+ top_srcdir = @top_srcdir@
+ udevrulesdir = @udevrulesdir@
+ SUBDIRS = dvb libv4l2util libmedia_dev decode_tm6000 keytable \
+- media-ctl v4l2-compliance v4l2-ctl v4l2-dbg v4l2-sysfs-path \
++ v4l2-compliance v4l2-dbg v4l2-sysfs-path \
+ rds-ctl $(am__append_1) $(am__append_2) $(am__append_3)
+ all: all-recursive
+
Index: multimedia/libv4l/files/videodev.h
===================================================================
--- /dev/null
+++ multimedia/libv4l/files/videodev.h
@@ -0,0 +1,340 @@
+/*
+ * Video for Linux version 1 - OBSOLETE
+ *
+ * Header file for v4l1 drivers and applications, for
+ * Linux kernels 2.2.x or 2.4.x.
+ *
+ * Provides header for legacy drivers and applications
+ *
+ * See http://linuxtv.org for more info
+ *
+ */
+#ifndef __LINUX_VIDEODEV_H
+#define __LINUX_VIDEODEV_H
+
+#include <sys/types.h>
+#include <sys/ioctl.h>
+#include <linux/videodev2.h>
+
+#if defined(__MIN_V4L1) && defined (__KERNEL__)
+
+/*
+ * Used by those V4L2 core functions that need a minimum V4L1 support,
+ * in order to allow V4L1 Compatibilty code compilation.
+ */
+
+struct video_mbuf
+{
+ int size; /* Total memory to map */
+ int frames; /* Frames */
+ int offsets[VIDEO_MAX_FRAME];
+};
+
+#define VIDIOCGMBUF _IOR('v',20, struct video_mbuf) /* Memory map buffer info */
+
+#else
+#if defined(CONFIG_VIDEO_V4L1_COMPAT) || !defined (__KERNEL__)
+
+#define VID_TYPE_CAPTURE 1 /* Can capture */
+#define VID_TYPE_TUNER 2 /* Can tune */
+#define VID_TYPE_TELETEXT 4 /* Does teletext */
+#define VID_TYPE_OVERLAY 8 /* Overlay onto frame buffer */
+#define VID_TYPE_CHROMAKEY 16 /* Overlay by chromakey */
+#define VID_TYPE_CLIPPING 32 /* Can clip */
+#define VID_TYPE_FRAMERAM 64 /* Uses the frame buffer memory */
+#define VID_TYPE_SCALES 128 /* Scalable */
+#define VID_TYPE_MONOCHROME 256 /* Monochrome only */
+#define VID_TYPE_SUBCAPTURE 512 /* Can capture subareas of the image */
+#define VID_TYPE_MPEG_DECODER 1024 /* Can decode MPEG streams */
+#define VID_TYPE_MPEG_ENCODER 2048 /* Can encode MPEG streams */
+#define VID_TYPE_MJPEG_DECODER 4096 /* Can decode MJPEG streams */
+#define VID_TYPE_MJPEG_ENCODER 8192 /* Can encode MJPEG streams */
+
+struct video_capability
+{
+ char name[32];
+ int type;
+ int channels; /* Num channels */
+ int audios; /* Num audio devices */
+ int maxwidth; /* Supported width */
+ int maxheight; /* And height */
+ int minwidth; /* Supported width */
+ int minheight; /* And height */
+};
+
+
+struct video_channel
+{
+ int channel;
+ char name[32];
+ int tuners;
+ uint32_t flags;
+#define VIDEO_VC_TUNER 1 /* Channel has a tuner */
+#define VIDEO_VC_AUDIO 2 /* Channel has audio */
+ uint16_t type;
+#define VIDEO_TYPE_TV 1
+#define VIDEO_TYPE_CAMERA 2
+ uint16_t norm; /* Norm set by channel */
+};
+
+struct video_tuner
+{
+ int tuner;
+ char name[32];
+ unsigned long rangelow, rangehigh; /* Tuner range */
+ uint32_t flags;
+#define VIDEO_TUNER_PAL 1
+#define VIDEO_TUNER_NTSC 2
+#define VIDEO_TUNER_SECAM 4
+#define VIDEO_TUNER_LOW 8 /* Uses KHz not MHz */
+#define VIDEO_TUNER_NORM 16 /* Tuner can set norm */
+#define VIDEO_TUNER_STEREO_ON 128 /* Tuner is seeing stereo */
+#define VIDEO_TUNER_RDS_ON 256 /* Tuner is seeing an RDS datastream */
+#define VIDEO_TUNER_MBS_ON 512 /* Tuner is seeing an MBS datastream */
+ uint16_t mode; /* PAL/NTSC/SECAM/OTHER */
+#define VIDEO_MODE_PAL 0
+#define VIDEO_MODE_NTSC 1
+#define VIDEO_MODE_SECAM 2
+#define VIDEO_MODE_AUTO 3
+ uint16_t signal; /* Signal strength 16bit scale */
+};
+
+struct video_picture
+{
+ uint16_t brightness;
+ uint16_t hue;
+ uint16_t colour;
+ uint16_t contrast;
+ uint16_t whiteness; /* Black and white only */
+ uint16_t depth; /* Capture depth */
+ uint16_t palette; /* Palette in use */
+#define VIDEO_PALETTE_GREY 1 /* Linear greyscale */
+#define VIDEO_PALETTE_HI240 2 /* High 240 cube (BT848) */
+#define VIDEO_PALETTE_RGB565 3 /* 565 16 bit RGB */
+#define VIDEO_PALETTE_RGB24 4 /* 24bit RGB */
+#define VIDEO_PALETTE_RGB32 5 /* 32bit RGB */
+#define VIDEO_PALETTE_RGB555 6 /* 555 15bit RGB */
+#define VIDEO_PALETTE_YUV422 7 /* YUV422 capture */
+#define VIDEO_PALETTE_YUYV 8
+#define VIDEO_PALETTE_UYVY 9 /* The great thing about standards is ... */
+#define VIDEO_PALETTE_YUV420 10
+#define VIDEO_PALETTE_YUV411 11 /* YUV411 capture */
+#define VIDEO_PALETTE_RAW 12 /* RAW capture (BT848) */
+#define VIDEO_PALETTE_YUV422P 13 /* YUV 4:2:2 Planar */
+#define VIDEO_PALETTE_YUV411P 14 /* YUV 4:1:1 Planar */
+#define VIDEO_PALETTE_YUV420P 15 /* YUV 4:2:0 Planar */
+#define VIDEO_PALETTE_YUV410P 16 /* YUV 4:1:0 Planar */
+#define VIDEO_PALETTE_PLANAR 13 /* start of planar entries */
+#define VIDEO_PALETTE_COMPONENT 7 /* start of component entries */
+};
+
+struct video_audio
+{
+ int audio; /* Audio channel */
+ uint16_t volume; /* If settable */
+ uint16_t bass, treble;
+ uint32_t flags;
+#define VIDEO_AUDIO_MUTE 1
+#define VIDEO_AUDIO_MUTABLE 2
+#define VIDEO_AUDIO_VOLUME 4
+#define VIDEO_AUDIO_BASS 8
+#define VIDEO_AUDIO_TREBLE 16
+#define VIDEO_AUDIO_BALANCE 32
+ char name[16];
+#define VIDEO_SOUND_MONO 1
+#define VIDEO_SOUND_STEREO 2
+#define VIDEO_SOUND_LANG1 4
+#define VIDEO_SOUND_LANG2 8
+ uint16_t mode;
+ uint16_t balance; /* Stereo balance */
+ uint16_t step; /* Step actual volume uses */
+};
+
+struct video_clip
+{
+ int32_t x,y;
+ int32_t width, height;
+ struct video_clip *next; /* For user use/driver use only */
+};
+
+struct video_window
+{
+ uint32_t x,y; /* Position of window */
+ uint32_t width,height; /* Its size */
+ uint32_t chromakey;
+ uint32_t flags;
+ struct video_clip *clips; /* Set only */
+ int clipcount;
+#define VIDEO_WINDOW_INTERLACE 1
+#define VIDEO_WINDOW_CHROMAKEY 16 /* Overlay by chromakey */
+#define VIDEO_CLIP_BITMAP -1
+/* bitmap is 1024x625, a '1' bit represents a clipped pixel */
+#define VIDEO_CLIPMAP_SIZE (128 * 625)
+};
+
+struct video_capture
+{
+ uint32_t x,y; /* Offsets into image */
+ uint32_t width, height; /* Area to capture */
+ uint16_t decimation; /* Decimation divider */
+ uint16_t flags; /* Flags for capture */
+#define VIDEO_CAPTURE_ODD 0 /* Temporal */
+#define VIDEO_CAPTURE_EVEN 1
+};
+
+struct video_buffer
+{
+ void *base;
+ int height,width;
+ int depth;
+ int bytesperline;
+};
+
+struct video_mmap
+{
+ unsigned int frame; /* Frame (0 - n) for double buffer */
+ int height,width;
+ unsigned int format; /* should be VIDEO_PALETTE_* */
+};
+
+struct video_key
+{
+ uint8_t key[8];
+ uint32_t flags;
+};
+
+struct video_mbuf
+{
+ int size; /* Total memory to map */
+ int frames; /* Frames */
+ int offsets[VIDEO_MAX_FRAME];
+};
+
+#define VIDEO_NO_UNIT (-1)
+
+struct video_unit
+{
+ int video; /* Video minor */
+ int vbi; /* VBI minor */
+ int radio; /* Radio minor */
+ int audio; /* Audio minor */
+ int teletext; /* Teletext minor */
+};
+
+struct vbi_format {
+ uint32_t sampling_rate; /* in Hz */
+ uint32_t samples_per_line;
+ uint32_t sample_format; /* VIDEO_PALETTE_RAW only (1 byte) */
+ int32_t start[2]; /* starting line for each frame */
+ uint32_t count[2]; /* count of lines for each frame */
+ uint32_t flags;
+#define VBI_UNSYNC 1 /* can distingues between top/bottom field */
+#define VBI_INTERLACED 2 /* lines are interlaced */
+};
+
+/* video_info is biased towards hardware mpeg encode/decode */
+/* but it could apply generically to any hardware compressor/decompressor */
+struct video_info
+{
+ uint32_t frame_count; /* frames output since decode/encode began */
+ uint32_t h_size; /* current unscaled horizontal size */
+ uint32_t v_size; /* current unscaled veritcal size */
+ uint32_t smpte_timecode; /* current SMPTE timecode (for current GOP) */
+ uint32_t picture_type; /* current picture type */
+ uint32_t temporal_reference; /* current temporal reference */
+ uint8_t user_data[256]; /* user data last found in compressed stream */
+ /* user_data[0] contains user data flags, user_data[1] has count */
+};
+
+/* generic structure for setting playback modes */
+struct video_play_mode
+{
+ int mode;
+ int p1;
+ int p2;
+};
+
+/* for loading microcode / fpga programming */
+struct video_code
+{
+ char loadwhat[16]; /* name or tag of file being passed */
+ int datasize;
+ uint8_t *data;
+};
+
+#define VIDIOCGCAP _IOR('v',1,struct video_capability) /* Get capabilities */
+#define VIDIOCGCHAN _IOWR('v',2,struct video_channel) /* Get channel info (sources) */
+#define VIDIOCSCHAN _IOW('v',3,struct video_channel) /* Set channel */
+#define VIDIOCGTUNER _IOWR('v',4,struct video_tuner) /* Get tuner abilities */
+#define VIDIOCSTUNER _IOW('v',5,struct video_tuner) /* Tune the tuner for the current channel */
+#define VIDIOCGPICT _IOR('v',6,struct video_picture) /* Get picture properties */
+#define VIDIOCSPICT _IOW('v',7,struct video_picture) /* Set picture properties */
+#define VIDIOCCAPTURE _IOW('v',8,int) /* Start, end capture */
+#define VIDIOCGWIN _IOR('v',9, struct video_window) /* Get the video overlay window */
+#define VIDIOCSWIN _IOW('v',10, struct video_window) /* Set the video overlay window - passes clip list for hardware smarts , chromakey etc */
+#define VIDIOCGFBUF _IOR('v',11, struct video_buffer) /* Get frame buffer */
+#define VIDIOCSFBUF _IOW('v',12, struct video_buffer) /* Set frame buffer - root only */
+#define VIDIOCKEY _IOR('v',13, struct video_key) /* Video key event - to dev 255 is to all - cuts capture on all DMA windows with this key (0xFFFFFFFF == all) */
+#define VIDIOCGFREQ _IOR('v',14, unsigned long) /* Set tuner */
+#define VIDIOCSFREQ _IOW('v',15, unsigned long) /* Set tuner */
+#define VIDIOCGAUDIO _IOR('v',16, struct video_audio) /* Get audio info */
+#define VIDIOCSAUDIO _IOW('v',17, struct video_audio) /* Audio source, mute etc */
+#define VIDIOCSYNC _IOW('v',18, int) /* Sync with mmap grabbing */
+#define VIDIOCMCAPTURE _IOW('v',19, struct video_mmap) /* Grab frames */
+#define VIDIOCGMBUF _IOR('v',20, struct video_mbuf) /* Memory map buffer info */
+#define VIDIOCGUNIT _IOR('v',21, struct video_unit) /* Get attached units */
+#define VIDIOCGCAPTURE _IOR('v',22, struct video_capture) /* Get subcapture */
+#define VIDIOCSCAPTURE _IOW('v',23, struct video_capture) /* Set subcapture */
+#define VIDIOCSPLAYMODE _IOW('v',24, struct video_play_mode) /* Set output video mode/feature */
+#define VIDIOCSWRITEMODE _IOW('v',25, int) /* Set write mode */
+#define VIDIOCGPLAYINFO _IOR('v',26, struct video_info) /* Get current playback info from hardware */
+#define VIDIOCSMICROCODE _IOW('v',27, struct video_code) /* Load microcode into hardware */
+#define VIDIOCGVBIFMT _IOR('v',28, struct vbi_format) /* Get VBI information */
+#define VIDIOCSVBIFMT _IOW('v',29, struct vbi_format) /* Set VBI information */
+
+
+#define BASE_VIDIOCPRIVATE 192 /* 192-255 are private */
+
+/* VIDIOCSWRITEMODE */
+#define VID_WRITE_MPEG_AUD 0
+#define VID_WRITE_MPEG_VID 1
+#define VID_WRITE_OSD 2
+#define VID_WRITE_TTX 3
+#define VID_WRITE_CC 4
+#define VID_WRITE_MJPEG 5
+
+/* VIDIOCSPLAYMODE */
+#define VID_PLAY_VID_OUT_MODE 0
+ /* p1: = VIDEO_MODE_PAL, VIDEO_MODE_NTSC, etc ... */
+#define VID_PLAY_GENLOCK 1
+ /* p1: 0 = OFF, 1 = ON */
+ /* p2: GENLOCK FINE DELAY value */
+#define VID_PLAY_NORMAL 2
+#define VID_PLAY_PAUSE 3
+#define VID_PLAY_SINGLE_FRAME 4
+#define VID_PLAY_FAST_FORWARD 5
+#define VID_PLAY_SLOW_MOTION 6
+#define VID_PLAY_IMMEDIATE_NORMAL 7
+#define VID_PLAY_SWITCH_CHANNELS 8
+#define VID_PLAY_FREEZE_FRAME 9
+#define VID_PLAY_STILL_MODE 10
+#define VID_PLAY_MASTER_MODE 11
+ /* p1: see below */
+#define VID_PLAY_MASTER_NONE 1
+#define VID_PLAY_MASTER_VIDEO 2
+#define VID_PLAY_MASTER_AUDIO 3
+#define VID_PLAY_ACTIVE_SCANLINES 12
+ /* p1 = first active; p2 = last active */
+#define VID_PLAY_RESET 13
+#define VID_PLAY_END_MARK 14
+
+#endif /* CONFIG_VIDEO_V4L1_COMPAT */
+#endif /* __MIN_V4L1 */
+
+#endif /* __LINUX_VIDEODEV_H */
+
+/*
+ * Local variables:
+ * c-basic-offset: 8
+ * End:
+ */
Index: multimedia/libv4l/pkg-plist
===================================================================
--- multimedia/libv4l/pkg-plist
+++ multimedia/libv4l/pkg-plist
@@ -1,17 +1,81 @@
+include/libdvbv5/atsc_eit.h
+include/libdvbv5/atsc_header.h
+include/libdvbv5/cat.h
+include/libdvbv5/crc32.h
+include/libdvbv5/desc_atsc_service_location.h
+include/libdvbv5/desc_ca.h
+include/libdvbv5/desc_ca_identifier.h
+include/libdvbv5/desc_cable_delivery.h
+include/libdvbv5/desc_event_extended.h
+include/libdvbv5/desc_event_short.h
+include/libdvbv5/desc_extension.h
+include/libdvbv5/desc_frequency_list.h
+include/libdvbv5/desc_hierarchy.h
+include/libdvbv5/desc_isdbt_delivery.h
+include/libdvbv5/desc_language.h
+include/libdvbv5/desc_logical_channel.h
+include/libdvbv5/desc_network_name.h
+include/libdvbv5/desc_partial_reception.h
+include/libdvbv5/desc_sat.h
+include/libdvbv5/desc_service.h
+include/libdvbv5/desc_t2_delivery.h
+include/libdvbv5/desc_terrestrial_delivery.h
+include/libdvbv5/desc_ts_info.h
+include/libdvbv5/descriptors.h
+include/libdvbv5/dvb-demux.h
+include/libdvbv5/dvb-fe.h
+include/libdvbv5/dvb-file.h
+include/libdvbv5/dvb-frontend.h
+include/libdvbv5/dvb-log.h
+include/libdvbv5/dvb-sat.h
+include/libdvbv5/dvb-scan.h
+include/libdvbv5/dvb-v5-std.h
+include/libdvbv5/eit.h
+include/libdvbv5/header.h
+include/libdvbv5/mgt.h
+include/libdvbv5/mpeg_es.h
+include/libdvbv5/mpeg_pes.h
+include/libdvbv5/mpeg_ts.h
+include/libdvbv5/nit.h
+include/libdvbv5/pat.h
+include/libdvbv5/pmt.h
+include/libdvbv5/sdt.h
+include/libdvbv5/vct.h
+include/libv4l-plugin.h
include/libv4l1-videodev.h
include/libv4l1.h
include/libv4l2.h
+include/libv4l2rds.h
include/libv4lconvert.h
+lib/libdvbv5.a
+lib/libdvbv5.so
+lib/libdvbv5.so.0
+lib/libdvbv5.so.0.0.0
lib/libv4l/ov511-decomp
lib/libv4l/ov518-decomp
+lib/libv4l/plugins/libv4l-mplane.so
lib/libv4l/v4l1compat.so
lib/libv4l/v4l2convert.so
+lib/libv4l1.a
lib/libv4l1.so
lib/libv4l1.so.0
+lib/libv4l1.so.0.0.0
+lib/libv4l2.a
lib/libv4l2.so
lib/libv4l2.so.0
+lib/libv4l2.so.0.0.0
+lib/libv4l2rds.a
+lib/libv4l2rds.so
+lib/libv4l2rds.so.0
+lib/libv4l2rds.so.0.0.0
+lib/libv4lconvert.a
lib/libv4lconvert.so
lib/libv4lconvert.so.0
+lib/libv4lconvert.so.0.0.0
+lib/v4l1compat.so
+lib/v4l2convert.so
+libdata/pkgconfig/libdvbv5.pc
libdata/pkgconfig/libv4l1.pc
libdata/pkgconfig/libv4l2.pc
+libdata/pkgconfig/libv4l2rds.pc
libdata/pkgconfig/libv4lconvert.pc
Index: multimedia/v4l-utils/Makefile
===================================================================
--- multimedia/v4l-utils/Makefile
+++ multimedia/v4l-utils/Makefile
@@ -1,36 +1,20 @@
# Created by: Juergen Lock <nox@FreeBSD.org>
# $FreeBSD$
-PORTNAME= v4l-utils
-PORTVERSION= 0.8.8
-PORTREVISION= 1
-CATEGORIES= multimedia
-MASTER_SITES= http://linuxtv.org/downloads/v4l-utils/
+PORTNAME?= v4l-utils
+PORTREVISION= 0
-MAINTAINER= nox@FreeBSD.org
COMMENT= Video4Linux utilities
-BUILD_DEPENDS= v4l_compat>=1.0.20120501:${PORTSDIR}/multimedia/v4l_compat \
- libv4l>=0.8.8:${PORTSDIR}/multimedia/libv4l
-LIB_DEPENDS= libv4l2.so:${PORTSDIR}/multimedia/libv4l \
- libargp.so:${PORTSDIR}/devel/argp-standalone
-
-MAKE_ARGS= CFLAGS="${CFLAGS} -I${LOCALBASE}/include -DPREFIX=\\\"${PREFIX}\\\"" \
- LIBDIR="${PREFIX}/lib" LDFLAGS="-L${LOCALBASE}/lib -largp"
-USES= gmake tar:bzip2
-USE_LDCONFIG= yes
-
-WRKSRC= ${WRKDIR}/${DISTNAME}/utils
-
-post-patch:
- @${RM} ${WRKSRC}/../include/linux/videodev2.h
- @${REINPLACE_CMD} -e 's|#include <sys/klog.h>||g' \
- -e 's|#include <features.h>||g' \
- -e 's|#include <linux/types.h>||g' \
- ${WRKSRC}/v4l2-compliance/v4l2-compliance.cpp \
- ${WRKSRC}/v4l2-compliance/v4l2-test-debug.cpp \
- ${WRKSRC}/v4l2-ctl/cx18-ctl.c \
- ${WRKSRC}/v4l2-ctl/ivtv-ctl.c \
- ${WRKSRC}/../include/linux/ivtv.h
+MASTERDIR= ${.CURDIR}/../../multimedia/libv4l
+DESCR= ${.CURDIR}/pkg-descr
+PLIST= ${.CURDIR}/pkg-plist
+LIBV4L_SLAVE= utils
+
+INSTALL_WRKSRC= ${WRKSRC}/utils
+
+# no need for udev rules
+post-install:
+ @${RM} -rf ${STAGEDIR}/lib/udev
-.include <bsd.port.mk>
+.include "${MASTERDIR}/Makefile"
Index: multimedia/v4l-utils/distinfo
===================================================================
--- multimedia/v4l-utils/distinfo
+++ /dev/null
@@ -1,2 +0,0 @@
-SHA256 (v4l-utils-0.8.8.tar.bz2) = 5fa4c6f4b6f5410de57271a03cc9a15f15195ef3fc05a8e42ecf507d6d70a87f
-SIZE (v4l-utils-0.8.8.tar.bz2) = 420888
Index: multimedia/v4l-utils/files/patch-Make.rules
===================================================================
--- multimedia/v4l-utils/files/patch-Make.rules
+++ /dev/null
@@ -1,26 +0,0 @@
---- ../Make.rules.orig 2010-08-26 17:19:37.000000000 +0200
-+++ ../Make.rules 2010-11-04 20:26:22.000000000 +0100
-@@ -7,8 +7,8 @@ CFLAGS += -Wall -Wpointer-arith
- CXXFLAGS := $(CFLAGS)
- CFLAGS += -Wstrict-prototypes -Wmissing-prototypes
-
--PREFIX = /usr/local
--LIBDIR = $(PREFIX)/lib
-+PREFIX ?= /usr/local
-+LIBDIR ?= $(PREFIX)/lib
- # subdir below LIBDIR in which to install the libv4lx libc wrappers
- LIBSUBDIR = libv4l
-
-@@ -22,10 +22,10 @@ LIB_RELEASE = 0
- # And last various rules
-
- %.o: %.c
-- $(CC) -Wp,-MMD,"$*.d",-MQ,"$@",-MP -c $(CPPFLAGS) $(CFLAGS) -o $@ $<
-+ $(CC) -MMD -MF "$*.d" -MQ "$@" -MP -c $(CPPFLAGS) $(CFLAGS) -o $@ $<
-
- %.o: %.cpp
-- $(CXX) -Wp,-MMD,"$*.d",-MQ,"$@",-MP -c $(CPPFLAGS) $(CXXFLAGS) -o $@ $<
-+ $(CXX) -MMD -MF "$*.d" -MQ "$@" -MP -c $(CPPFLAGS) $(CXXFLAGS) -o $@ $<
-
- %.so:
- $(CC) -shared $(LDFLAGS) -Wl,-soname,$@.$(LIB_RELEASE) -o $@.$(LIB_RELEASE) $^ $(LIBS_$*)
Index: multimedia/v4l-utils/files/patch-Makefile
===================================================================
--- multimedia/v4l-utils/files/patch-Makefile
+++ /dev/null
@@ -1,25 +0,0 @@
---- ./Makefile.orig 2011-02-09 23:04:27.000000000 +0100
-+++ ./Makefile 2011-06-03 19:08:13.000000000 +0200
-@@ -1,4 +1,5 @@
--SUBDIRS=libv4l2util decode_tm6000 keytable rds v4l2-compliance v4l2-ctl v4l2-dbg xc3028-firmware
-+#SUBDIRS=libv4l2util decode_tm6000 keytable rds v4l2-compliance v4l2-ctl v4l2-dbg xc3028-firmware
-+SUBDIRS=libv4l2util decode_tm6000 keytable v4l2-compliance v4l2-ctl v4l2-dbg
-
- all install:
- @for i in $(SUBDIRS); do \
-@@ -10,6 +11,7 @@
- $(MAKE) -C v4l2-sysfs-path $@; \
- fi
-
-+ifdef WITH_QV4L2
- # Test whether qmake is installed, and whether it is for qt4.
- @if which qmake-qt4 >/dev/null 2>&1; then \
- QMAKE=qmake-qt4; \
-@@ -24,6 +26,7 @@
- $(MAKE) -C qv4l2 -f Makefile.install $@; \
- fi \
- fi
-+endif
-
- sync-with-kernel:
- $(MAKE) -C keytable $@
Index: multimedia/v4l-utils/files/patch-decode_tm6000__decode_tm6000.c
===================================================================
--- multimedia/v4l-utils/files/patch-decode_tm6000__decode_tm6000.c
+++ /dev/null
@@ -1,11 +0,0 @@
---- ./decode_tm6000/decode_tm6000.c.orig 2011-02-09 23:04:27.000000000 +0100
-+++ ./decode_tm6000/decode_tm6000.c 2011-06-03 19:08:13.000000000 +0200
-@@ -41,6 +41,8 @@
- { 0, 0, 0, 0, 0, 0 }
- };
-
-+#define devname dev_name
-+
- static char outbuf[692224];
- static int debug=0, audio=0, use_mmap=1, nbufs=4;
- static float freq_mhz=193.25;
Index: multimedia/v4l-utils/files/patch-keytable__Makefile
===================================================================
--- multimedia/v4l-utils/files/patch-keytable__Makefile
+++ /dev/null
@@ -1,24 +0,0 @@
---- keytable/Makefile.orig 2011-06-01 13:23:03.000000000 +0200
-+++ keytable/Makefile 2011-06-04 09:43:14.000000000 +0200
-@@ -34,12 +34,14 @@
- install: $(TARGETS)
- mkdir -p $(DESTDIR)$(PREFIX)/bin $(DESTDIR)/etc
- install -m 755 $(TARGETS) $(DESTDIR)$(PREFIX)/bin
-- install -m 644 -p rc_maps.cfg $(DESTDIR)/etc
-- install -m 755 -d $(DESTDIR)/etc/rc_keymaps
-- install -m 644 -p rc_keymaps/* $(DESTDIR)/etc/rc_keymaps
-- install -m 755 -d $(DESTDIR)/lib/udev/rules.d
-- install -m 644 -p 70-infrared.rules $(DESTDIR)/lib/udev/rules.d
-- install -m 755 -d $(DESTDIR)$(MANDIR)/man1
-- install -m 644 -p ir-keytable.1 $(DESTDIR)$(MANDIR)/man1
-+ install -m 644 -p rc_maps.cfg $(DESTDIR)$(PREFIX)/etc
-+ install -m 755 -d $(DESTDIR)$(PREFIX)/etc/rc_keymaps
-+ install -m 644 -p rc_keymaps/* $(DESTDIR)$(PREFIX)/etc/rc_keymaps
-+ifdef UDEV
-+ install -m 755 -d $(DESTDIR)$(PREFIX)/etc/udev/rules.d
-+ install -m 644 -p 70-infrared.rules $(DESTDIR)$(PREFIX)/etc/udev/rules.d
-+endif
-+ install -m 755 -d $(DESTDIR)$(PREFIX)/man/man1
-+ install -m 644 -p ir-keytable.1 $(DESTDIR)$(PREFIX)/man/man1
-
- include ../../Make.rules
Index: multimedia/v4l-utils/files/patch-keytable__keytable.c
===================================================================
--- multimedia/v4l-utils/files/patch-keytable__keytable.c
+++ /dev/null
@@ -1,25 +0,0 @@
---- ./keytable/keytable.c.orig 2011-02-09 23:04:27.000000000 +0100
-+++ ./keytable/keytable.c 2011-06-03 19:08:13.000000000 +0200
-@@ -28,7 +28,11 @@
- #include "parse.h"
-
- /* Default place where the keymaps will be stored */
-+#ifndef __FreeBSD__
- #define CFGDIR "/etc/rc_keymaps"
-+#else
-+#define CFGDIR PREFIX "/etc/rc_keymaps"
-+#endif
-
- struct input_keymap_entry_v2 {
- #define KEYMAP_BY_INDEX (1 << 0)
-@@ -137,6 +141,10 @@
- "--sysdev [ir class (f. ex. rc0)]\n"
- "[for using the rc0 sysdev]";
-
-+#ifdef __FreeBSD__
-+#define devname dev_name
-+#endif
-+
- /* Static vars to store the parameters */
- static char *devclass = "rc0";
- static char *devname = NULL;
Index: multimedia/v4l-utils/files/patch-libv4l2util__v4l2_driver.c
===================================================================
--- multimedia/v4l-utils/files/patch-libv4l2util__v4l2_driver.c
+++ /dev/null
@@ -1,14 +0,0 @@
---- ./libv4l2util/v4l2_driver.c.orig 2011-02-09 23:04:27.000000000 +0100
-+++ ./libv4l2util/v4l2_driver.c 2011-06-03 19:08:13.000000000 +0200
-@@ -15,7 +15,11 @@
- #include <assert.h>
- #include <errno.h>
- #include <fcntl.h>
-+#ifndef __FreeBSD__
- #include <malloc.h>
-+#else
-+#include <stdlib.h>
-+#endif
- #include <stdio.h>
- #include <string.h>
- #include <unistd.h>
Index: multimedia/v4l-utils/files/patch-qv4l2__v4l2-api.h
===================================================================
--- multimedia/v4l-utils/files/patch-qv4l2__v4l2-api.h
+++ /dev/null
@@ -1,13 +0,0 @@
---- ./qv4l2/v4l2-api.h.orig 2011-02-09 23:04:27.000000000 +0100
-+++ ./qv4l2/v4l2-api.h 2011-06-03 19:08:13.000000000 +0200
-@@ -24,6 +24,10 @@
- #include <linux/videodev2.h>
- #include <libv4lconvert.h>
-
-+#ifdef __FreeBSD__
-+typedef off_t __off64_t;
-+#endif
-+
- class v4l2
- {
- public:
Index: multimedia/v4l-utils/files/patch-v4l2-ctl__ivtv-ctl.c
===================================================================
--- multimedia/v4l-utils/files/patch-v4l2-ctl__ivtv-ctl.c
+++ /dev/null
@@ -1,17 +0,0 @@
---- ./v4l2-ctl/ivtv-ctl.c.orig 2011-02-09 23:04:27.000000000 +0100
-+++ ./v4l2-ctl/ivtv-ctl.c 2011-06-03 19:20:05.000000000 +0200
-@@ -498,7 +498,13 @@
- if (ioctl(fd, VIDEO_GET_EVENT, &ev) < 0) {
- fprintf(stderr, "ioctl: VIDEO_GET_EVENT failed\n");
- break;
-- } else if (ev.timestamp == 0) {
-+ }
-+#ifndef __FreeBSD__
-+ else if (ev.timestamp == 0)
-+#else
-+ else if (ev.timestamp.tv_sec == 0)
-+#endif
-+ {
- unsigned long long pts = 0, frame = 0;
- struct timeval tv;
- gettimeofday(&tv, NULL);
Index: multimedia/v4l-utils/files/patch-v4l2-ctl__v4l2-ctl.cpp
===================================================================
--- multimedia/v4l-utils/files/patch-v4l2-ctl__v4l2-ctl.cpp
+++ /dev/null
@@ -1,95 +0,0 @@
---- v4l2-ctl/v4l2-ctl.cpp.orig
-+++ v4l2-ctl/v4l2-ctl.cpp
-@@ -21,7 +21,6 @@
- */
-
- #include <unistd.h>
--#include <features.h> /* Uses _GNU_SOURCE to define getsubopt in stdlib.h */
- #include <stdlib.h>
- #include <stdio.h>
- #include <string.h>
-@@ -36,7 +35,6 @@
- #include <sys/time.h>
- #include <dirent.h>
- #include <math.h>
--#include <sys/klog.h>
-
- #include <linux/videodev2.h>
- #include <libv4l2.h>
-@@ -1644,9 +1642,50 @@ static void list_devices()
- }
- }
-
-+#if __FreeBSD_version < 1000000
-+/* from FreeBSD src/lib/libc/string/strchrnul.c: */
-+
-+char *strchrnul(const char *p, int ch);
-+
-+char *
-+strchrnul(const char *p, int ch)
-+{
-+ char c;
-+
-+ c = ch;
-+ for (;; ++p) {
-+ if (*p == c || *p == '\0')
-+ return ((char *)p);
-+ }
-+ /* NOTREACHED */
-+}
-+#endif
-+
-+int
-+my_getsubopt (char **optionp, char *const *tokens, char **valuep)
-+{
-+ char *endp, *vstart;
-+ int cnt;
-+
-+ if (**optionp == '\0')
-+ return -1;
-+
-+ /* Find end of next token. */
-+ endp = strchrnul (*optionp, ',');
-+
-+ /* The current suboption does not match any option. */
-+ *valuep = *optionp;
-+
-+ if (*endp != '\0')
-+ *endp++ = '\0';
-+ *optionp = endp;
-+
-+ return -1;
-+}
-+
- static int parse_subopt(char **subs, const char * const *subopts, char **value)
- {
-- int opt = getsubopt(subs, (char * const *)subopts, value);
-+ int opt = my_getsubopt(subs, (char * const *)subopts, value);
-
- if (opt == -1) {
- fprintf(stderr, "Invalid suboptions specified\n");
-@@ -1667,7 +1704,7 @@ static void parse_next_subopt(char **sub
- static char *const subopts[] = {
- NULL
- };
-- int opt = getsubopt(subs, subopts, value);
-+ int opt = my_getsubopt(subs, subopts, value);
-
- if (value == NULL) {
- fprintf(stderr, "No value given to suboption <%s>\n",
-@@ -3493,6 +3530,7 @@ int main(int argc, char **argv)
- static char buf[40960];
- int len;
-
-+#ifndef __FreeBSD__
- if (doioctl(fd, VIDIOC_LOG_STATUS, NULL) == 0) {
- printf("\nStatus Log:\n\n");
- len = klogctl(3, buf, sizeof(buf) - 1);
-@@ -3514,6 +3552,7 @@ int main(int argc, char **argv)
- }
- }
- }
-+#endif
- }
-
- /* List options */
Index: multimedia/v4l-utils/files/patch-v4l2-dbg__v4l2-dbg.cpp
===================================================================
--- multimedia/v4l-utils/files/patch-v4l2-dbg__v4l2-dbg.cpp
+++ /dev/null
@@ -1,34 +0,0 @@
---- v4l2-dbg/v4l2-dbg.cpp.orig 2011-06-01 13:23:03.000000000 +0200
-+++ v4l2-dbg/v4l2-dbg.cpp 2011-06-04 10:04:30.000000000 +0200
-@@ -17,7 +17,6 @@
- */
-
- #include <unistd.h>
--#include <features.h> /* Uses _GNU_SOURCE to define getsubopt in stdlib.h */
- #include <stdlib.h>
- #include <stdio.h>
- #include <string.h>
-@@ -31,7 +30,6 @@
- #include <sys/ioctl.h>
- #include <sys/time.h>
- #include <math.h>
--#include <sys/klog.h>
-
- #include <linux/videodev2.h>
- #include <media/v4l2-chip-ident.h>
-@@ -767,6 +765,7 @@
- static char buf[40960];
- int len;
-
-+#ifndef __FreeBSD__
- if (doioctl(fd, VIDIOC_LOG_STATUS, NULL, "VIDIOC_LOG_STATUS") == 0) {
- printf("\nStatus Log:\n\n");
- len = klogctl(3, buf, sizeof(buf) - 1);
-@@ -788,6 +787,7 @@
- }
- }
- }
-+#endif
- }
-
- if (options[OptListSymbols]) {
Index: multimedia/v4l-utils/pkg-plist
===================================================================
--- multimedia/v4l-utils/pkg-plist
+++ multimedia/v4l-utils/pkg-plist
@@ -1,117 +1,17 @@
-bin/cx18-ctl
bin/decode_tm6000
+bin/dvb-fe-tool
+bin/dvb-format-convert
+bin/dvbv5-scan
+bin/dvbv5-zap
bin/ir-keytable
-bin/ivtv-ctl
+bin/rds-ctl
bin/v4l2-compliance
-bin/v4l2-ctl
-etc/rc_keymaps/a800
-etc/rc_keymaps/adstech_dvb_t_pci
-etc/rc_keymaps/af9005
-etc/rc_keymaps/alink_dtu_m
-etc/rc_keymaps/anysee
-etc/rc_keymaps/apac_viewcomp
-etc/rc_keymaps/asus_pc39
-etc/rc_keymaps/ati_tv_wonder_hd_600
-etc/rc_keymaps/avermedia
-etc/rc_keymaps/avermedia_a16d
-etc/rc_keymaps/avermedia_cardbus
-etc/rc_keymaps/avermedia_dvbt
-etc/rc_keymaps/avermedia_m135a
-etc/rc_keymaps/avermedia_m733a_rm_k6
-etc/rc_keymaps/avermedia_rm_ks
-etc/rc_keymaps/avertv_303
-etc/rc_keymaps/azurewave_ad_tu700
-etc/rc_keymaps/behold
-etc/rc_keymaps/behold_columbus
-etc/rc_keymaps/budget_ci_old
-etc/rc_keymaps/cinergy
-etc/rc_keymaps/cinergy_1400
-etc/rc_keymaps/cinergyt2
-etc/rc_keymaps/d680_dmb
-etc/rc_keymaps/dib0700_nec
-etc/rc_keymaps/dib0700_rc5
-etc/rc_keymaps/dibusb
-etc/rc_keymaps/digitalnow_tinytwin
-etc/rc_keymaps/digittrade
-etc/rc_keymaps/digitv
-etc/rc_keymaps/dm1105_nec
-etc/rc_keymaps/dntv_live_dvb_t
-etc/rc_keymaps/dntv_live_dvbt_pro
-etc/rc_keymaps/dtt200u
-etc/rc_keymaps/dvico_mce
-etc/rc_keymaps/dvico_portable
-etc/rc_keymaps/dw210x
-etc/rc_keymaps/em_terratec
-etc/rc_keymaps/encore_enltv
-etc/rc_keymaps/encore_enltv2
-etc/rc_keymaps/encore_enltv_fm53
-etc/rc_keymaps/evga_indtube
-etc/rc_keymaps/eztv
-etc/rc_keymaps/flydvb
-etc/rc_keymaps/flyvideo
-etc/rc_keymaps/fusionhdtv_mce
-etc/rc_keymaps/gadmei_rm008z
-etc/rc_keymaps/genius_tvgo_a11mce
-etc/rc_keymaps/gotview7135
-etc/rc_keymaps/haupp
-etc/rc_keymaps/hauppauge
-etc/rc_keymaps/imon_mce
-etc/rc_keymaps/imon_pad
-etc/rc_keymaps/iodata_bctv7e
-etc/rc_keymaps/kaiomy
-etc/rc_keymaps/kworld_315u
-etc/rc_keymaps/kworld_plus_tv_analog
-etc/rc_keymaps/leadtek_y04g0051
-etc/rc_keymaps/lme2510
-etc/rc_keymaps/manli
-etc/rc_keymaps/megasky
-etc/rc_keymaps/msi_digivox_ii
-etc/rc_keymaps/msi_digivox_iii
-etc/rc_keymaps/msi_tvanywhere
-etc/rc_keymaps/msi_tvanywhere_plus
-etc/rc_keymaps/nebula
-etc/rc_keymaps/nec_terratec_cinergy_xs
-etc/rc_keymaps/norwood
-etc/rc_keymaps/npgtech
-etc/rc_keymaps/opera1
-etc/rc_keymaps/pctv_sedna
-etc/rc_keymaps/pinnacle310e
-etc/rc_keymaps/pinnacle_color
-etc/rc_keymaps/pinnacle_grey
-etc/rc_keymaps/pinnacle_pctv_hd
-etc/rc_keymaps/pixelview
-etc/rc_keymaps/pixelview_002t
-etc/rc_keymaps/pixelview_mk12
-etc/rc_keymaps/pixelview_new
-etc/rc_keymaps/powercolor_real_angel
-etc/rc_keymaps/proteus_2309
-etc/rc_keymaps/purpletv
-etc/rc_keymaps/pv951
-etc/rc_keymaps/rc6_mce
-etc/rc_keymaps/real_audio_220_32_keys
-etc/rc_keymaps/streamzap
-etc/rc_keymaps/su3000
-etc/rc_keymaps/tbs
-etc/rc_keymaps/tbs_nec
-etc/rc_keymaps/technisat_usb2
-etc/rc_keymaps/terratec_cinergy_xs
-etc/rc_keymaps/terratec_slim
-etc/rc_keymaps/terratec_slim_2
-etc/rc_keymaps/tevii
-etc/rc_keymaps/tevii_nec
-etc/rc_keymaps/tivo
-etc/rc_keymaps/total_media_in_hand
-etc/rc_keymaps/trekstor
-etc/rc_keymaps/tt_1500
-etc/rc_keymaps/tvwalkertwin
-etc/rc_keymaps/twinhan_vp1027_dvbs
-etc/rc_keymaps/videomate_m1f
-etc/rc_keymaps/videomate_s350
-etc/rc_keymaps/videomate_tv_pvr
-etc/rc_keymaps/vp702x
-etc/rc_keymaps/vp7045
-etc/rc_keymaps/winfast
-etc/rc_keymaps/winfast_usbii_deluxe
+@comment bin/v4l2-sysfs-path
etc/rc_maps.cfg
-sbin/v4l2-dbg
+man/man1/dvb-fe-tool.1.gz
+man/man1/dvb-format-convert.1.gz
+man/man1/dvbv5-scan.1.gz
+man/man1/dvbv5-zap.1.gz
man/man1/ir-keytable.1.gz
+sbin/v4l2-dbg
+@dir etc/rc_keymaps
Index: multimedia/v4l_compat/Makefile
===================================================================
--- multimedia/v4l_compat/Makefile
+++ multimedia/v4l_compat/Makefile
@@ -1,26 +1,42 @@
# $FreeBSD$
PORTNAME= v4l_compat
-PORTVERSION= 1.0.${DUMMYDATE}
-PORTREVISION= 1
-CATEGORIES= multimedia
-MASTER_SITES= LOCAL/kwm
+PORTREVISION= 0
-MAINTAINER= multimedia@FreeBSD.org
COMMENT= Video4Linux IOCTL header files
-LICENSE= GPLv2
-
-DUMMYDATE= 20120501
-
NO_BUILD= yes
NO_ARCH= yes
-BASE_HEADERS= input.h uinput.h videodev.h videodev2.h
-DVB_HEADERS= audio.h ca.h dmx.h frontend.h net.h osd.h version.h video.h
+
+MASTERDIR= ${.CURDIR}/../../multimedia/libv4l
+EXTRADIR= ${WRKSRC}/../linux
+DESCR= ${.CURDIR}/pkg-descr
+PLIST= ${.CURDIR}/pkg-plist
+LIBV4L_SLAVE= compat
+
+BASE_HEADERS= input.h uinput.h ivtv.h v4l2-controls.h \
+ v4l2-common.h videodev2.h
+DVB_HEADERS= audio.h dmx.h frontend.h video.h
+EXTRA_HEADERS= ca.h osd.h version.h
do-install:
- ${MKDIR} ${STAGEDIR}${PREFIX}/include/linux/dvb
- cd ${WRKSRC}; ${INSTALL_DATA} ${BASE_HEADERS} ${STAGEDIR}${PREFIX}/include/linux/
- cd ${WRKSRC}/dvb; ${INSTALL_DATA} ${DVB_HEADERS} ${STAGEDIR}${PREFIX}/include/linux/dvb/
+ @${MKDIR} ${STAGEDIR}${PREFIX}/include/linux/dvb/
+.for i in ${BASE_HEADERS}
+ ${INSTALL_DATA} ${WRKSRC}/contrib/freebsd/include/linux/${i} \
+ ${STAGEDIR}${PREFIX}/include/linux/
+.endfor
+.for i in ${DVB_HEADERS}
+ ${INSTALL_DATA} ${WRKSRC}/include/linux/dvb/${i} \
+ ${STAGEDIR}${PREFIX}/include/linux/dvb
+.endfor
+# V4L1 is dead in linux, however webcamd still supports it.
+ ${INSTALL_DATA} ${FILESDIR}/videodev.h \
+ ${STAGEDIR}${PREFIX}/include/linux/
+# Extra dvb headers supplied taken from the linux kernel distfile.
+# vdr and the gst dvb plugin need them at least
+.for i in ${EXTRA_HEADERS}
+ ${INSTALL_DATA} ${EXTRADIR}/dvb/${i} \
+ ${STAGEDIR}${PREFIX}/include/linux/dvb/
+.endfor
-.include <bsd.port.mk>
+.include "${MASTERDIR}/Makefile"
Index: multimedia/v4l_compat/distinfo
===================================================================
--- multimedia/v4l_compat/distinfo
+++ /dev/null
@@ -1,2 +0,0 @@
-SHA256 (v4l_compat-1.0.20120501.tar.gz) = 0bc375a36f450ad7f665996ca3d9efcffa63d9befcdf3214412f0a1e82d68b30
-SIZE (v4l_compat-1.0.20120501.tar.gz) = 63578
Index: multimedia/v4l_compat/files/patch-dvb-ca.h
===================================================================
--- multimedia/v4l_compat/files/patch-dvb-ca.h
+++ /dev/null
@@ -1,20 +0,0 @@
---- dvb/ca.h.orig
-+++ dvb/ca.h
-@@ -80,9 +80,17 @@ typedef struct ca_pid {
-
- #define CA_RESET _IO('o', 128)
- #define CA_GET_CAP _IOR('o', 129, ca_caps_t)
-+
-+/* At least CA_GET_SLOT_INFO and CA_GET_MSG need to be _IOWR not _IOR.
-+ * This is wrong on Linux too but there the driver doesn't care.
-+ *
- #define CA_GET_SLOT_INFO _IOR('o', 130, ca_slot_info_t)
- #define CA_GET_DESCR_INFO _IOR('o', 131, ca_descr_info_t)
- #define CA_GET_MSG _IOR('o', 132, ca_msg_t)
-+ */
-+#define CA_GET_SLOT_INFO _IOWR('o', 130, ca_slot_info_t)
-+#define CA_GET_DESCR_INFO _IOR('o', 131, ca_descr_info_t)
-+#define CA_GET_MSG _IOWR('o', 132, ca_msg_t)
- #define CA_SEND_MSG _IOW('o', 133, ca_msg_t)
- #define CA_SET_DESCR _IOW('o', 134, ca_descr_t)
- #define CA_SET_PID _IOW('o', 135, ca_pid_t)
Index: multimedia/v4l_compat/pkg-plist
===================================================================
--- multimedia/v4l_compat/pkg-plist
+++ multimedia/v4l_compat/pkg-plist
@@ -1,12 +1,14 @@
-include/linux/input.h
-include/linux/uinput.h
-include/linux/videodev.h
-include/linux/videodev2.h
include/linux/dvb/audio.h
include/linux/dvb/ca.h
include/linux/dvb/dmx.h
include/linux/dvb/frontend.h
-include/linux/dvb/net.h
include/linux/dvb/osd.h
include/linux/dvb/version.h
include/linux/dvb/video.h
+include/linux/input.h
+include/linux/ivtv.h
+include/linux/uinput.h
+include/linux/v4l2-common.h
+include/linux/v4l2-controls.h
+include/linux/videodev.h
+include/linux/videodev2.h

File Metadata

Mime Type
text/plain
Expires
Sat, Oct 25, 7:16 AM (18 h, 31 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
24122486
Default Alt Text
D1482.diff (46 KB)

Event Timeline