[vlc-devel] [PATCH 1/2] v4l2: split some v4l2 declarations
Francois Cartegnie
fcvlcdev at free.fr
Mon Mar 12 22:24:38 CET 2012
---
modules/access/Modules.am | 3 +
modules/access/v4l2/access.c | 1 +
modules/access/v4l2/controls.c | 1 +
modules/access/v4l2/demux.c | 1 +
modules/access/v4l2/v4l2.h | 24 +--------
modules/access/v4l2/v4l2_common.c | 110 +++++++++++++++++++++++++++++++++++++
modules/access/v4l2/v4l2_common.h | 40 +++++++++++++
modules/access/v4l2/v4l2_input.h | 46 +++++++++++++++
modules/access/v4l2/video.c | 106 +++++++++--------------------------
9 files changed, 230 insertions(+), 102 deletions(-)
create mode 100644 modules/access/v4l2/v4l2_common.c
create mode 100644 modules/access/v4l2/v4l2_common.h
create mode 100644 modules/access/v4l2/v4l2_input.h
diff --git a/modules/access/Modules.am b/modules/access/Modules.am
index eee6276..e807442 100644
--- a/modules/access/Modules.am
+++ b/modules/access/Modules.am
@@ -161,6 +161,9 @@ libv4l2_plugin_la_SOURCES = \
v4l2/video.c \
v4l2/demux.c \
v4l2/access.c \
+ v4l2/v4l2_common.c \
+ v4l2/v4l2_common.h \
+ v4l2/v4l2_input.h \
v4l2/controls.c \
v4l2/lib.c \
v4l2/v4l2.h
diff --git a/modules/access/v4l2/access.c b/modules/access/v4l2/access.c
index 078ccb8..3e91215 100644
--- a/modules/access/v4l2/access.c
+++ b/modules/access/v4l2/access.c
@@ -28,6 +28,7 @@
#endif
#include "v4l2.h"
+#include "v4l2_input.h"
#include <vlc_access.h>
#include <errno.h>
diff --git a/modules/access/v4l2/controls.c b/modules/access/v4l2/controls.c
index 9c02263..6552d62 100644
--- a/modules/access/v4l2/controls.c
+++ b/modules/access/v4l2/controls.c
@@ -28,6 +28,7 @@
#endif
#include "v4l2.h"
+#include "v4l2_input.h"
#include <ctype.h>
#include <assert.h>
#include <sys/ioctl.h>
diff --git a/modules/access/v4l2/demux.c b/modules/access/v4l2/demux.c
index c5bf6c5..84629cd 100644
--- a/modules/access/v4l2/demux.c
+++ b/modules/access/v4l2/demux.c
@@ -28,6 +28,7 @@
#endif
#include "v4l2.h"
+#include "v4l2_input.h"
#include <vlc_demux.h>
#include <errno.h>
#include <sys/ioctl.h>
diff --git a/modules/access/v4l2/v4l2.h b/modules/access/v4l2/v4l2.h
index 705b7f4..f4587ce 100644
--- a/modules/access/v4l2/v4l2.h
+++ b/modules/access/v4l2/v4l2.h
@@ -73,8 +73,6 @@ extern ssize_t (*v4l2_read) (int, void *, size_t);
extern void * (*v4l2_mmap) (void *, size_t, int, int, int, int64_t);
extern int (*v4l2_munmap) (void *, size_t);
-#define CFG_PREFIX "v4l2-"
-
/* TODO: remove this, use callbacks */
typedef enum {
IO_METHOD_READ=1,
@@ -96,7 +94,7 @@ struct demux_sys_t
unsigned int i_nbuffers;
#define blocksize i_nbuffers /* HACK HACK */
- int i_fourcc;
+ vlc_fourcc_t i_fourcc;
uint32_t i_block_flags;
es_out_id_t *p_es;
@@ -109,23 +107,3 @@ struct buffer_t
void * start;
size_t length;
};
-
-/* video.c */
-void ParseMRL(vlc_object_t *, const char *);
-int OpenVideo(vlc_object_t *, demux_sys_t *, bool);
-block_t* GrabVideo(vlc_object_t *, demux_sys_t *);
-
-/* demux.c */
-int DemuxOpen(vlc_object_t *);
-void DemuxClose(vlc_object_t *);
-float GetAbsoluteMaxFrameRate(vlc_object_t *, int fd, uint32_t fmt);
-void GetMaxDimensions(vlc_object_t *, int fd, uint32_t fmt, float fps_min,
- uint32_t *pwidth, uint32_t *pheight);
-
-/* access.c */
-int AccessOpen(vlc_object_t *);
-void AccessClose(vlc_object_t *);
-
-/* controls.c */
-vlc_v4l2_ctrl_t *ControlsInit(vlc_object_t *, int fd);
-void ControlsDeinit(vlc_object_t *, vlc_v4l2_ctrl_t *);
diff --git a/modules/access/v4l2/v4l2_common.c b/modules/access/v4l2/v4l2_common.c
new file mode 100644
index 0000000..68d7ea6
--- /dev/null
+++ b/modules/access/v4l2/v4l2_common.c
@@ -0,0 +1,110 @@
+/*****************************************************************************
+ * v4l2_common.c : V4L2 shared data & functions for vlc
+ *****************************************************************************
+ * Copyright (C) 2002-2011 the VideoLAN team
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
+ *****************************************************************************/
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include "v4l2_common.h"
+#include "v4l2.h"
+
+#include <vlc_fourcc.h>
+
+#include <sys/ioctl.h>
+#include <sys/mman.h>
+
+static const struct
+{
+ unsigned int i_v4l2;
+ vlc_fourcc_t i_fourcc;
+ int i_rmask;
+ int i_gmask;
+ int i_bmask;
+} v4l2chroma_to_fourcc[] =
+{
+ /* Raw data types */
+ { V4L2_PIX_FMT_GREY, VLC_CODEC_GREY, 0, 0, 0 },
+ { V4L2_PIX_FMT_HI240, VLC_FOURCC('I','2','4','0'), 0, 0, 0 },
+ { V4L2_PIX_FMT_RGB555, VLC_CODEC_RGB15, 0x001f,0x03e0,0x7c00 },
+ { V4L2_PIX_FMT_RGB565, VLC_CODEC_RGB16, 0x001f,0x07e0,0xf800 },
+ /* Won't work since we don't know how to handle such gmask values
+ * correctly
+ { V4L2_PIX_FMT_RGB555X, VLC_CODEC_RGB15, 0x007c,0xe003,0x1f00 },
+ { V4L2_PIX_FMT_RGB565X, VLC_CODEC_RGB16, 0x00f8,0xe007,0x1f00 },
+ */
+ { V4L2_PIX_FMT_BGR24, VLC_CODEC_RGB24, 0xff0000,0xff00,0xff },
+ { V4L2_PIX_FMT_RGB24, VLC_CODEC_RGB24, 0xff,0xff00,0xff0000 },
+ { V4L2_PIX_FMT_BGR32, VLC_CODEC_RGB32, 0xff0000,0xff00,0xff },
+ { V4L2_PIX_FMT_RGB32, VLC_CODEC_RGB32, 0xff,0xff00,0xff0000 },
+ { V4L2_PIX_FMT_YUYV, VLC_CODEC_YUYV, 0, 0, 0 },
+ { V4L2_PIX_FMT_UYVY, VLC_CODEC_UYVY, 0, 0, 0 },
+ { V4L2_PIX_FMT_Y41P, VLC_FOURCC('I','4','1','N'), 0, 0, 0 },
+ { V4L2_PIX_FMT_YUV422P, VLC_CODEC_I422, 0, 0, 0 },
+ { V4L2_PIX_FMT_YVU420, VLC_CODEC_YV12, 0, 0, 0 },
+ { V4L2_PIX_FMT_YUV411P, VLC_CODEC_I411, 0, 0, 0 },
+ { V4L2_PIX_FMT_YUV410, VLC_CODEC_I410, 0, 0, 0 },
+
+ /* Raw data types, not in V4L2 spec but still in videodev2.h and supported
+ * by VLC */
+ { V4L2_PIX_FMT_YUV420, VLC_CODEC_I420, 0, 0, 0 },
+ /* FIXME { V4L2_PIX_FMT_RGB444, VLC_CODEC_RGB32 }, */
+
+ /* Compressed data types */
+ { V4L2_PIX_FMT_MJPEG, VLC_CODEC_MJPG, 0, 0, 0 },
+ { V4L2_PIX_FMT_JPEG, VLC_CODEC_JPEG, 0, 0, 0 },
+#if 0
+ { V4L2_PIX_FMT_DV, VLC_FOURCC('?','?','?','?') },
+ { V4L2_PIX_FMT_MPEG, VLC_FOURCC('?','?','?','?') },
+#endif
+ { 0, 0, 0, 0, 0 }
+};
+
+bool get_v4l2pixelformat_by_fourcc( unsigned int *found,
+ vlc_fourcc_t i_requested_fourcc )
+{
+ for( int i = 0; v4l2chroma_to_fourcc[i].i_v4l2 != 0; i++ )
+ {
+ if( v4l2chroma_to_fourcc[i].i_fourcc == i_requested_fourcc )
+ {
+ *found = v4l2chroma_to_fourcc[i].i_v4l2;
+ return true;
+ }
+ }
+ return false;
+}
+
+bool get_fourcc_by_v4l2pixelformat( vlc_fourcc_t *i_fourcc,
+ int *i_rmask, int *i_gmask, int *i_bmask,
+ unsigned int pixelformat )
+{
+ for( int i = 0; v4l2chroma_to_fourcc[i].i_fourcc != 0; i++ )
+ {
+ if( v4l2chroma_to_fourcc[i].i_v4l2 == pixelformat )
+ {
+ *i_fourcc = v4l2chroma_to_fourcc[i].i_fourcc;
+ *i_rmask = v4l2chroma_to_fourcc[i].i_rmask;
+ *i_gmask = v4l2chroma_to_fourcc[i].i_gmask;
+ *i_bmask = v4l2chroma_to_fourcc[i].i_bmask;
+ return true;
+ }
+ }
+ return false;
+}
+
diff --git a/modules/access/v4l2/v4l2_common.h b/modules/access/v4l2/v4l2_common.h
new file mode 100644
index 0000000..870c818
--- /dev/null
+++ b/modules/access/v4l2/v4l2_common.h
@@ -0,0 +1,40 @@
+/*****************************************************************************
+ * v4l2_common.h : V4L2 shared data & functions for vlc
+ *****************************************************************************
+ * Copyright (C) 2002-2011 the VideoLAN team
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
+ *****************************************************************************/
+#ifndef V4L2_COMMON_H
+#define V4L2_COMMON_H
+
+#include <vlc_common.h>
+
+/**
+ * Matchs a V4L2 fourcc with VLC's one.
+ * @return true if successfully matched.
+ **/
+bool get_fourcc_by_v4l2pixelformat( vlc_fourcc_t *i_fourcc,
+ int *i_rmask, int *i_gmask, int *i_bmask,
+ unsigned int pixelformat );
+
+/**
+ * Matchs a VLC fourcc with V4L2's one.
+ * @return true if successfully matched.
+ **/
+bool get_v4l2pixelformat_by_fourcc( unsigned int *found,
+ vlc_fourcc_t i_requested_fourcc );
+
+#endif // V4L2_COMMON_H
diff --git a/modules/access/v4l2/v4l2_input.h b/modules/access/v4l2/v4l2_input.h
new file mode 100644
index 0000000..9cfdd22
--- /dev/null
+++ b/modules/access/v4l2/v4l2_input.h
@@ -0,0 +1,46 @@
+/*****************************************************************************
+ * v4l2_input.h : Video4Linux2 input/access/demux modules for vlc
+ *****************************************************************************
+ * Copyright (C) 2002-2011 the VideoLAN team
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
+ *****************************************************************************/
+
+#ifndef V4L2_INPUT_H
+#define V4L2_INPUT_H
+
+#define CFG_PREFIX "v4l2-"
+
+/* video.c */
+void ParseMRL(vlc_object_t *, const char *);
+int OpenVideo(vlc_object_t *, demux_sys_t *, bool);
+block_t* GrabVideo(vlc_object_t *, demux_sys_t *);
+
+/* demux.c */
+int DemuxOpen(vlc_object_t *);
+void DemuxClose(vlc_object_t *);
+float GetAbsoluteMaxFrameRate(vlc_object_t *, int fd, uint32_t fmt);
+void GetMaxDimensions(vlc_object_t *, int fd, uint32_t fmt, float fps_min,
+ uint32_t *pwidth, uint32_t *pheight);
+
+/* access.c */
+int AccessOpen(vlc_object_t *);
+void AccessClose(vlc_object_t *);
+
+/* controls.c */
+vlc_v4l2_ctrl_t *ControlsInit(vlc_object_t *, int fd);
+void ControlsDeinit(vlc_object_t *, vlc_v4l2_ctrl_t *);
+
+#endif // V4L2_INPUT_H
diff --git a/modules/access/v4l2/video.c b/modules/access/v4l2/video.c
index 7e24c0d..f493664 100644
--- a/modules/access/v4l2/video.c
+++ b/modules/access/v4l2/video.c
@@ -38,6 +38,8 @@
#endif
#include "v4l2.h"
+#include "v4l2_input.h"
+#include "v4l2_common.h"
#include <vlc_plugin.h>
#include <vlc_fs.h>
#include <vlc_demux.h>
@@ -456,52 +458,6 @@ vlc_module_end ()
static block_t* ProcessVideoFrame( vlc_object_t *p_demux, uint8_t *p_frame, size_t );
-static const struct
-{
- unsigned int i_v4l2;
- vlc_fourcc_t i_fourcc;
- int i_rmask;
- int i_gmask;
- int i_bmask;
-} v4l2chroma_to_fourcc[] =
-{
- /* Raw data types */
- { V4L2_PIX_FMT_GREY, VLC_CODEC_GREY, 0, 0, 0 },
- { V4L2_PIX_FMT_HI240, VLC_FOURCC('I','2','4','0'), 0, 0, 0 },
- { V4L2_PIX_FMT_RGB555, VLC_CODEC_RGB15, 0x001f,0x03e0,0x7c00 },
- { V4L2_PIX_FMT_RGB565, VLC_CODEC_RGB16, 0x001f,0x07e0,0xf800 },
- /* Won't work since we don't know how to handle such gmask values
- * correctly
- { V4L2_PIX_FMT_RGB555X, VLC_CODEC_RGB15, 0x007c,0xe003,0x1f00 },
- { V4L2_PIX_FMT_RGB565X, VLC_CODEC_RGB16, 0x00f8,0xe007,0x1f00 },
- */
- { V4L2_PIX_FMT_BGR24, VLC_CODEC_RGB24, 0xff0000,0xff00,0xff },
- { V4L2_PIX_FMT_RGB24, VLC_CODEC_RGB24, 0xff,0xff00,0xff0000 },
- { V4L2_PIX_FMT_BGR32, VLC_CODEC_RGB32, 0xff0000,0xff00,0xff },
- { V4L2_PIX_FMT_RGB32, VLC_CODEC_RGB32, 0xff,0xff00,0xff0000 },
- { V4L2_PIX_FMT_YUYV, VLC_CODEC_YUYV, 0, 0, 0 },
- { V4L2_PIX_FMT_UYVY, VLC_CODEC_UYVY, 0, 0, 0 },
- { V4L2_PIX_FMT_Y41P, VLC_FOURCC('I','4','1','N'), 0, 0, 0 },
- { V4L2_PIX_FMT_YUV422P, VLC_CODEC_I422, 0, 0, 0 },
- { V4L2_PIX_FMT_YVU420, VLC_CODEC_YV12, 0, 0, 0 },
- { V4L2_PIX_FMT_YUV411P, VLC_CODEC_I411, 0, 0, 0 },
- { V4L2_PIX_FMT_YUV410, VLC_CODEC_I410, 0, 0, 0 },
-
- /* Raw data types, not in V4L2 spec but still in videodev2.h and supported
- * by VLC */
- { V4L2_PIX_FMT_YUV420, VLC_CODEC_I420, 0, 0, 0 },
- /* FIXME { V4L2_PIX_FMT_RGB444, VLC_CODEC_RGB32 }, */
-
- /* Compressed data types */
- { V4L2_PIX_FMT_MJPEG, VLC_CODEC_MJPG, 0, 0, 0 },
- { V4L2_PIX_FMT_JPEG, VLC_CODEC_JPEG, 0, 0, 0 },
-#if 0
- { V4L2_PIX_FMT_DV, VLC_FOURCC('?','?','?','?') },
- { V4L2_PIX_FMT_MPEG, VLC_FOURCC('?','?','?','?') },
-#endif
- { 0, 0, 0, 0, 0 }
-};
-
/**
* List of V4L2 chromas were confident enough to use as fallbacks if the
* user hasn't provided a --v4l2-chroma value.
@@ -1060,21 +1016,18 @@ static int InitVideo( vlc_object_t *p_obj, int i_fd, demux_sys_t *p_sys,
vlc_fourcc_to_char( codecs[i].pixelformat, fourcc_v4l2 );
bool b_codec_supported = false;
- for( unsigned j = 0; v4l2chroma_to_fourcc[j].i_v4l2 != 0; j++ )
- {
- if( v4l2chroma_to_fourcc[j].i_v4l2 == codecs[i].pixelformat )
- {
- char fourcc[5];
- memset( fourcc, 0, sizeof( fourcc ) );
- vlc_fourcc_to_char( v4l2chroma_to_fourcc[j].i_fourcc,
- fourcc );
- msg_Dbg( p_obj, "device supports chroma %4.4s [%s, %s]",
- fourcc, codecs[i].description, fourcc_v4l2 );
- b_codec_supported = true;
- }
- }
- if( !b_codec_supported )
+ vlc_fourcc_t i_fourcc;
+ int i_rmask, i_gmask, i_bmask;
+ b_codec_supported = get_fourcc_by_v4l2pixelformat( &i_fourcc,
+ &i_rmask, &i_gmask, &i_bmask, codecs[i].pixelformat );
+ if( b_codec_supported )
{
+ char fourcc[5];
+ memset( fourcc, 0, sizeof( fourcc ) );
+ vlc_fourcc_to_char( i_fourcc, fourcc );
+ msg_Dbg( p_obj, "device supports chroma %4.4s [%s, %s]",
+ fourcc, codecs[i].description, fourcc_v4l2 );
+ } else {
msg_Dbg( p_obj, "device codec %4.4s (%s) not supported",
fourcc_v4l2, codecs[i].description );
}
@@ -1156,14 +1109,8 @@ static int InitVideo( vlc_object_t *p_obj, int i_fd, demux_sys_t *p_sys,
const vlc_fourcc_t i_requested_fourcc =
vlc_fourcc_GetCodecFromString( VIDEO_ES, reqchroma );
- for( int i = 0; v4l2chroma_to_fourcc[i].i_v4l2 != 0; i++ )
- {
- if( v4l2chroma_to_fourcc[i].i_fourcc == i_requested_fourcc )
- {
- fmt.fmt.pix.pixelformat = v4l2chroma_to_fourcc[i].i_v4l2;
- break;
- }
- }
+ get_v4l2pixelformat_by_fourcc( &fmt.fmt.pix.pixelformat, i_requested_fourcc );
+
/* Try and set user chroma */
bool b_error = !IsPixelFormatSupported( codecs, ncodec,
fmt.fmt.pix.pixelformat );
@@ -1298,18 +1245,19 @@ static int InitVideo( vlc_object_t *p_obj, int i_fd, demux_sys_t *p_sys,
}
/* Look up final fourcc */
- p_sys->i_fourcc = 0;
- for( int i = 0; v4l2chroma_to_fourcc[i].i_fourcc != 0; i++ )
+ int i_rmask, i_gmask, i_bmask;
+ if ( get_fourcc_by_v4l2pixelformat( &p_sys->i_fourcc,
+ &i_rmask,
+ &i_gmask,
+ &i_bmask,
+ fmt.fmt.pix.pixelformat ) )
{
- if( v4l2chroma_to_fourcc[i].i_v4l2 == fmt.fmt.pix.pixelformat )
- {
- p_sys->i_fourcc = v4l2chroma_to_fourcc[i].i_fourcc;
- es_format_Init( &es_fmt, VIDEO_ES, p_sys->i_fourcc );
- es_fmt.video.i_rmask = v4l2chroma_to_fourcc[i].i_rmask;
- es_fmt.video.i_gmask = v4l2chroma_to_fourcc[i].i_gmask;
- es_fmt.video.i_bmask = v4l2chroma_to_fourcc[i].i_bmask;
- break;
- }
+ es_format_Init( &es_fmt, VIDEO_ES, p_sys->i_fourcc );
+ es_fmt.video.i_rmask = i_rmask;
+ es_fmt.video.i_gmask = i_gmask;
+ es_fmt.video.i_bmask = i_bmask;
+ } else {
+ p_sys->i_fourcc = 0;
}
/* Buggy driver paranoia */
--
1.7.6
More information about the vlc-devel
mailing list