Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
21ecdaab
Commit
21ecdaab
authored
Sep 06, 2011
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Segregate access-specific V4L2 code
parent
5a070f69
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
188 additions
and
170 deletions
+188
-170
modules/access/Modules.am
modules/access/Modules.am
+5
-1
modules/access/v4l2/access.c
modules/access/v4l2/access.c
+172
-0
modules/access/v4l2/v4l2.h
modules/access/v4l2/v4l2.h
+7
-0
modules/access/v4l2/video.c
modules/access/v4l2/video.c
+4
-169
No files found.
modules/access/Modules.am
View file @
21ecdaab
...
@@ -130,7 +130,11 @@ libaccess_shm_plugin_la_LIBADD = $(AM_LIBADD)
...
@@ -130,7 +130,11 @@ libaccess_shm_plugin_la_LIBADD = $(AM_LIBADD)
libaccess_shm_plugin_la_DEPENDENCIES =
libaccess_shm_plugin_la_DEPENDENCIES =
libvlc_LTLIBRARIES += $(LTLIBaccess_shm)
libvlc_LTLIBRARIES += $(LTLIBaccess_shm)
libv4l2_plugin_la_SOURCES = v4l2/v4l2.h v4l2/video.c v4l2/controls.c
libv4l2_plugin_la_SOURCES = \
v4l2/video.c \
v4l2/access.c \
v4l2/controls.c \
v4l2/v4l2.h
libv4l2_plugin_la_CFLAGS = $(AM_CFLAGS) $(LIBV4L2_CFLAGS)
libv4l2_plugin_la_CFLAGS = $(AM_CFLAGS) $(LIBV4L2_CFLAGS)
libv4l2_plugin_la_LIBADD = $(AM_LIBADD) $(LIBV4L2_LIBS) $(LIBM)
libv4l2_plugin_la_LIBADD = $(AM_LIBADD) $(LIBV4L2_LIBS) $(LIBM)
libv4l2_plugin_la_DEPENDENCIES =
libv4l2_plugin_la_DEPENDENCIES =
...
...
modules/access/v4l2/access.c
0 → 100644
View file @
21ecdaab
/*****************************************************************************
* access.c : V4L2 compressed byte stream input module for vlc
*****************************************************************************
* Copyright (C) 2002-2011 the VideoLAN team
*
* Authors: Benjamin Pracht <bigben at videolan dot org>
* Richard Hosking <richard at hovis dot net>
* Antoine Cellerier <dionoea at videolan d.t org>
* Dennis Lou <dlou99 at yahoo dot com>
*
* 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.h"
#include <vlc_access.h>
#include <errno.h>
#include <poll.h>
static
block_t
*
AccessRead
(
access_t
*
);
static
ssize_t
AccessReadStream
(
access_t
*
,
uint8_t
*
,
size_t
);
static
int
AccessControl
(
access_t
*
,
int
,
va_list
);
int
AccessOpen
(
vlc_object_t
*
obj
)
{
access_t
*
access
=
(
access_t
*
)
obj
;
/* Only when selected */
if
(
*
access
->
psz_access
==
'\0'
)
return
VLC_EGENERIC
;
access_InitFields
(
access
);
demux_sys_t
*
sys
=
calloc
(
1
,
sizeof
(
demux_sys_t
));
if
(
unlikely
(
sys
==
NULL
)
)
return
VLC_ENOMEM
;
access
->
p_sys
=
(
access_sys_t
*
)
sys
;
ParseMRL
(
obj
,
access
->
psz_location
);
sys
->
i_fd
=
OpenVideo
(
obj
,
sys
,
false
);
if
(
sys
->
i_fd
==
-
1
)
{
free
(
sys
);
return
VLC_EGENERIC
;
}
if
(
sys
->
io
==
IO_METHOD_READ
)
access
->
pf_read
=
AccessReadStream
;
else
access
->
pf_block
=
AccessRead
;
access
->
pf_seek
=
NULL
;
access
->
pf_control
=
AccessControl
;
return
VLC_SUCCESS
;
}
void
AccessClose
(
vlc_object_t
*
obj
)
{
access_t
*
access
=
(
access_t
*
)
obj
;
demux_sys_t
*
sys
=
(
demux_sys_t
*
)
access
->
p_sys
;
v4l2_close
(
sys
->
i_fd
);
free
(
sys
);
}
static
block_t
*
AccessRead
(
access_t
*
access
)
{
demux_sys_t
*
sys
=
(
demux_sys_t
*
)
access
->
p_sys
;
struct
pollfd
fd
;
fd
.
fd
=
sys
->
i_fd
;
fd
.
events
=
POLLIN
|
POLLPRI
;
fd
.
revents
=
0
;
/* Wait for data */
/* FIXME: kill timeout */
if
(
poll
(
&
fd
,
1
,
500
)
>
0
)
return
GrabVideo
(
VLC_OBJECT
(
access
),
sys
);
return
NULL
;
}
static
ssize_t
AccessReadStream
(
access_t
*
access
,
uint8_t
*
buf
,
size_t
len
)
{
demux_sys_t
*
sys
=
(
demux_sys_t
*
)
access
->
p_sys
;
struct
pollfd
ufd
;
int
i_ret
;
ufd
.
fd
=
sys
->
i_fd
;
ufd
.
events
=
POLLIN
;
if
(
access
->
info
.
b_eof
)
return
0
;
/* FIXME: kill timeout and vlc_object_alive() */
do
{
if
(
!
vlc_object_alive
(
access
)
)
return
0
;
ufd
.
revents
=
0
;
}
while
(
(
i_ret
=
poll
(
&
ufd
,
1
,
500
)
)
==
0
);
if
(
i_ret
<
0
)
{
if
(
errno
!=
EINTR
)
msg_Err
(
access
,
"poll error: %m"
);
return
-
1
;
}
i_ret
=
v4l2_read
(
sys
->
i_fd
,
buf
,
len
);
if
(
i_ret
==
0
)
access
->
info
.
b_eof
=
true
;
else
if
(
i_ret
>
0
)
access
->
info
.
i_pos
+=
i_ret
;
return
i_ret
;
}
static
int
AccessControl
(
access_t
*
access
,
int
query
,
va_list
args
)
{
switch
(
query
)
{
/* */
case
ACCESS_CAN_SEEK
:
case
ACCESS_CAN_FASTSEEK
:
case
ACCESS_CAN_PAUSE
:
case
ACCESS_CAN_CONTROL_PACE
:
*
va_arg
(
args
,
bool
*
)
=
false
;
break
;
/* */
case
ACCESS_GET_PTS_DELAY
:
*
va_arg
(
args
,
int64_t
*
)
=
INT64_C
(
1000
)
*
var_InheritInteger
(
access
,
"live-caching"
);
break
;
/* */
case
ACCESS_SET_PAUSE_STATE
:
/* Nothing to do */
break
;
case
ACCESS_GET_TITLE_INFO
:
case
ACCESS_SET_TITLE
:
case
ACCESS_SET_SEEKPOINT
:
case
ACCESS_SET_PRIVATE_ID_STATE
:
case
ACCESS_GET_CONTENT_TYPE
:
case
ACCESS_GET_META
:
return
VLC_EGENERIC
;
default:
msg_Warn
(
access
,
"Unimplemented query %d in control"
,
query
);
return
VLC_EGENERIC
;
}
return
VLC_SUCCESS
;
}
modules/access/v4l2/v4l2.h
View file @
21ecdaab
...
@@ -71,4 +71,11 @@ struct demux_sys_t
...
@@ -71,4 +71,11 @@ struct demux_sys_t
#endif
#endif
};
};
/* 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
*
);
/* access.c */
int
AccessOpen
(
vlc_object_t
*
);
void
AccessClose
(
vlc_object_t
*
);
modules/access/v4l2/video.c
View file @
21ecdaab
...
@@ -39,7 +39,6 @@
...
@@ -39,7 +39,6 @@
#include "v4l2.h"
#include "v4l2.h"
#include <vlc_plugin.h>
#include <vlc_plugin.h>
#include <vlc_access.h>
#include <vlc_fs.h>
#include <vlc_fs.h>
#include <vlc_demux.h>
#include <vlc_demux.h>
...
@@ -57,8 +56,6 @@
...
@@ -57,8 +56,6 @@
static
int
DemuxOpen
(
vlc_object_t
*
);
static
int
DemuxOpen
(
vlc_object_t
*
);
static
void
DemuxClose
(
vlc_object_t
*
);
static
void
DemuxClose
(
vlc_object_t
*
);
static
int
AccessOpen
(
vlc_object_t
*
);
static
void
AccessClose
(
vlc_object_t
*
);
#define DEVICE_TEXT N_( "Device" )
#define DEVICE_TEXT N_( "Device" )
#define DEVICE_LONGTEXT N_( \
#define DEVICE_LONGTEXT N_( \
...
@@ -406,21 +403,11 @@ vlc_module_end ()
...
@@ -406,21 +403,11 @@ vlc_module_end ()
* Access: local prototypes
* Access: local prototypes
*****************************************************************************/
*****************************************************************************/
static
void
CommonClose
(
vlc_object_t
*
,
demux_sys_t
*
);
static
void
ParseMRL
(
vlc_object_t
*
,
const
char
*
);
static
int
DemuxControl
(
demux_t
*
,
int
,
va_list
);
static
int
DemuxControl
(
demux_t
*
,
int
,
va_list
);
static
int
AccessControl
(
access_t
*
,
int
,
va_list
);
static
int
Demux
(
demux_t
*
);
static
int
Demux
(
demux_t
*
);
static
block_t
*
AccessRead
(
access_t
*
);
static
ssize_t
AccessReadStream
(
access_t
*
p_access
,
uint8_t
*
p_buffer
,
size_t
i_len
);
static
block_t
*
GrabVideo
(
vlc_object_t
*
p_demux
,
demux_sys_t
*
p_sys
);
static
block_t
*
ProcessVideoFrame
(
vlc_object_t
*
p_demux
,
uint8_t
*
p_frame
,
size_t
);
static
block_t
*
ProcessVideoFrame
(
vlc_object_t
*
p_demux
,
uint8_t
*
p_frame
,
size_t
);
static
int
OpenVideo
(
vlc_object_t
*
,
demux_sys_t
*
,
bool
);
static
const
struct
static
const
struct
{
{
unsigned
int
i_v4l2
;
unsigned
int
i_v4l2
;
...
@@ -519,7 +506,7 @@ static int DemuxOpen( vlc_object_t *p_this )
...
@@ -519,7 +506,7 @@ static int DemuxOpen( vlc_object_t *p_this )
/**
/**
* Parses a V4L2 MRL into VLC object variables.
* Parses a V4L2 MRL into VLC object variables.
*/
*/
static
void
ParseMRL
(
vlc_object_t
*
obj
,
const
char
*
mrl
)
void
ParseMRL
(
vlc_object_t
*
obj
,
const
char
*
mrl
)
{
{
const
char
*
p
=
strchr
(
mrl
,
':'
);
const
char
*
p
=
strchr
(
mrl
,
':'
);
char
*
dev
=
NULL
;
char
*
dev
=
NULL
;
...
@@ -547,14 +534,6 @@ static void ParseMRL( vlc_object_t *obj, const char *mrl )
...
@@ -547,14 +534,6 @@ static void ParseMRL( vlc_object_t *obj, const char *mrl )
/*****************************************************************************
/*****************************************************************************
* Close: close device, free resources
* Close: close device, free resources
*****************************************************************************/
*****************************************************************************/
static
void
AccessClose
(
vlc_object_t
*
p_this
)
{
access_t
*
p_access
=
(
access_t
*
)
p_this
;
demux_sys_t
*
p_sys
=
(
demux_sys_t
*
)
p_access
->
p_sys
;
CommonClose
(
p_this
,
p_sys
);
}
static
void
DemuxClose
(
vlc_object_t
*
p_this
)
static
void
DemuxClose
(
vlc_object_t
*
p_this
)
{
{
struct
v4l2_buffer
buf
;
struct
v4l2_buffer
buf
;
...
@@ -622,50 +601,8 @@ static void DemuxClose( vlc_object_t *p_this )
...
@@ -622,50 +601,8 @@ static void DemuxClose( vlc_object_t *p_this )
free
(
p_sys
->
p_buffers
);
free
(
p_sys
->
p_buffers
);
}
}
CommonClose
(
p_this
,
p_sys
);
v4l2_close
(
p_sys
->
i_fd
);
}
static
void
CommonClose
(
vlc_object_t
*
p_this
,
demux_sys_t
*
p_sys
)
{
(
void
)
p_this
;
/* Close */
if
(
p_sys
->
i_fd
>=
0
)
v4l2_close
(
p_sys
->
i_fd
);
free
(
p_sys
);
}
/*****************************************************************************
* AccessOpen: opens v4l2 device, access callback
*****************************************************************************
*
* url: <video device>::::
*
*****************************************************************************/
static
int
AccessOpen
(
vlc_object_t
*
p_this
)
{
access_t
*
p_access
=
(
access_t
*
)
p_this
;
demux_sys_t
*
p_sys
;
/* Only when selected */
if
(
*
p_access
->
psz_access
==
'\0'
)
return
VLC_EGENERIC
;
access_InitFields
(
p_access
);
p_sys
=
calloc
(
1
,
sizeof
(
demux_sys_t
));
if
(
!
p_sys
)
return
VLC_ENOMEM
;
p_access
->
p_sys
=
(
access_sys_t
*
)
p_sys
;
ParseMRL
(
p_this
,
p_access
->
psz_location
);
p_sys
->
i_fd
=
OpenVideo
(
p_this
,
p_sys
,
false
);
if
(
p_sys
->
i_fd
==
-
1
)
{
free
(
p_sys
);
free
(
p_sys
);
return
VLC_EGENERIC
;
}
if
(
p_sys
->
io
==
IO_METHOD_READ
)
ACCESS_SET_CALLBACKS
(
AccessReadStream
,
NULL
,
AccessControl
,
NULL
);
else
ACCESS_SET_CALLBACKS
(
NULL
,
AccessRead
,
AccessControl
,
NULL
);
return
VLC_SUCCESS
;
}
}
/*****************************************************************************
/*****************************************************************************
...
@@ -699,108 +636,6 @@ static int DemuxControl( demux_t *p_demux, int i_query, va_list args )
...
@@ -699,108 +636,6 @@ static int DemuxControl( demux_t *p_demux, int i_query, va_list args )
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
/*****************************************************************************
* AccessControl: access callback
*****************************************************************************/
static
int
AccessControl
(
access_t
*
p_access
,
int
i_query
,
va_list
args
)
{
switch
(
i_query
)
{
/* */
case
ACCESS_CAN_SEEK
:
case
ACCESS_CAN_FASTSEEK
:
case
ACCESS_CAN_PAUSE
:
case
ACCESS_CAN_CONTROL_PACE
:
*
va_arg
(
args
,
bool
*
)
=
false
;
break
;
/* */
case
ACCESS_GET_PTS_DELAY
:
*
va_arg
(
args
,
int64_t
*
)
=
INT64_C
(
1000
)
*
var_InheritInteger
(
p_access
,
"live-caching"
);
break
;
/* */
case
ACCESS_SET_PAUSE_STATE
:
/* Nothing to do */
break
;
case
ACCESS_GET_TITLE_INFO
:
case
ACCESS_SET_TITLE
:
case
ACCESS_SET_SEEKPOINT
:
case
ACCESS_SET_PRIVATE_ID_STATE
:
case
ACCESS_GET_CONTENT_TYPE
:
case
ACCESS_GET_META
:
return
VLC_EGENERIC
;
default:
msg_Warn
(
p_access
,
"Unimplemented query in control(%d)."
,
i_query
);
return
VLC_EGENERIC
;
}
return
VLC_SUCCESS
;
}
/*****************************************************************************
* AccessRead: access callback
******************************************************************************/
static
block_t
*
AccessRead
(
access_t
*
p_access
)
{
demux_sys_t
*
p_sys
=
(
demux_sys_t
*
)
p_access
->
p_sys
;
struct
pollfd
fd
;
fd
.
fd
=
p_sys
->
i_fd
;
fd
.
events
=
POLLIN
|
POLLPRI
;
fd
.
revents
=
0
;
/* Wait for data */
if
(
poll
(
&
fd
,
1
,
500
)
>
0
)
/* Timeout after 0.5 seconds since I don't know if pf_demux can be blocking. */
return
GrabVideo
(
VLC_OBJECT
(
p_access
),
p_sys
);
return
NULL
;
}
static
ssize_t
AccessReadStream
(
access_t
*
p_access
,
uint8_t
*
p_buffer
,
size_t
i_len
)
{
demux_sys_t
*
p_sys
=
(
demux_sys_t
*
)
p_access
->
p_sys
;
struct
pollfd
ufd
;
int
i_ret
;
ufd
.
fd
=
p_sys
->
i_fd
;
ufd
.
events
=
POLLIN
;
if
(
p_access
->
info
.
b_eof
)
return
0
;
do
{
if
(
!
vlc_object_alive
(
p_access
)
)
return
0
;
ufd
.
revents
=
0
;
}
while
(
(
i_ret
=
poll
(
&
ufd
,
1
,
500
)
)
==
0
);
if
(
i_ret
<
0
)
{
if
(
errno
!=
EINTR
)
msg_Err
(
p_access
,
"poll error"
);
return
-
1
;
}
i_ret
=
v4l2_read
(
p_sys
->
i_fd
,
p_buffer
,
i_len
);
if
(
i_ret
==
0
)
{
p_access
->
info
.
b_eof
=
true
;
}
else
if
(
i_ret
>
0
)
{
p_access
->
info
.
i_pos
+=
i_ret
;
}
return
i_ret
;
}
/*****************************************************************************
/*****************************************************************************
* Demux: Processes the audio or video frame
* Demux: Processes the audio or video frame
*****************************************************************************/
*****************************************************************************/
...
@@ -838,7 +673,7 @@ static int Demux( demux_t *p_demux )
...
@@ -838,7 +673,7 @@ static int Demux( demux_t *p_demux )
/*****************************************************************************
/*****************************************************************************
* GrabVideo: Grab a video frame
* GrabVideo: Grab a video frame
*****************************************************************************/
*****************************************************************************/
static
block_t
*
GrabVideo
(
vlc_object_t
*
p_demux
,
demux_sys_t
*
p_sys
)
block_t
*
GrabVideo
(
vlc_object_t
*
p_demux
,
demux_sys_t
*
p_sys
)
{
{
block_t
*
p_block
;
block_t
*
p_block
;
struct
v4l2_buffer
buf
;
struct
v4l2_buffer
buf
;
...
@@ -1284,7 +1119,7 @@ static int InitVideo( vlc_object_t *p_obj, int i_fd, demux_sys_t *p_sys,
...
@@ -1284,7 +1119,7 @@ static int InitVideo( vlc_object_t *p_obj, int i_fd, demux_sys_t *p_sys,
* Opens and sets up a video device
* Opens and sets up a video device
* \return file descriptor or -1 on error
* \return file descriptor or -1 on error
*/
*/
static
int
OpenVideo
(
vlc_object_t
*
obj
,
demux_sys_t
*
sys
,
bool
b_demux
)
int
OpenVideo
(
vlc_object_t
*
obj
,
demux_sys_t
*
sys
,
bool
b_demux
)
{
{
char
*
path
=
var_InheritString
(
obj
,
CFG_PREFIX
"dev"
);
char
*
path
=
var_InheritString
(
obj
,
CFG_PREFIX
"dev"
);
if
(
unlikely
(
path
==
NULL
)
)
if
(
unlikely
(
path
==
NULL
)
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment