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
a26af04b
Commit
a26af04b
authored
Sep 01, 2011
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Do not keep some V4L2 useless settings after initialization
parent
43782114
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
25 additions
and
34 deletions
+25
-34
modules/access/Modules.am
modules/access/Modules.am
+1
-1
modules/access/v4l2.c
modules/access/v4l2.c
+24
-33
No files found.
modules/access/Modules.am
View file @
a26af04b
...
@@ -132,7 +132,7 @@ libvlc_LTLIBRARIES += $(LTLIBaccess_shm)
...
@@ -132,7 +132,7 @@ libvlc_LTLIBRARIES += $(LTLIBaccess_shm)
libv4l2_plugin_la_SOURCES = v4l2.c
libv4l2_plugin_la_SOURCES = v4l2.c
libv4l2_plugin_la_CFLAGS = $(AM_CFLAGS) $(CFLAGS_v4L2)
libv4l2_plugin_la_CFLAGS = $(AM_CFLAGS) $(CFLAGS_v4L2)
libv4l2_plugin_la_LIBADD = $(AM_LIBADD) $(LIBS_v4l2)
libv4l2_plugin_la_LIBADD = $(AM_LIBADD) $(LIBS_v4l2)
$(LIBM)
libv4l2_plugin_la_DEPENDENCIES =
libv4l2_plugin_la_DEPENDENCIES =
if HAVE_V4L2
if HAVE_V4L2
libvlc_LTLIBRARIES += libv4l2_plugin.la
libvlc_LTLIBRARIES += libv4l2_plugin.la
...
...
modules/access/v4l2.c
View file @
a26af04b
...
@@ -46,6 +46,7 @@
...
@@ -46,6 +46,7 @@
#include <vlc_input.h>
#include <vlc_input.h>
#include <ctype.h>
#include <ctype.h>
#include <math.h>
#include <assert.h>
#include <assert.h>
#include <errno.h>
#include <errno.h>
#include <fcntl.h>
#include <fcntl.h>
...
@@ -343,6 +344,7 @@ vlc_module_begin ()
...
@@ -343,6 +344,7 @@ vlc_module_begin ()
change_safe
()
change_safe
()
add_integer
(
CFG_PREFIX
"tuner-frequency"
,
-
1
,
FREQUENCY_TEXT
,
add_integer
(
CFG_PREFIX
"tuner-frequency"
,
-
1
,
FREQUENCY_TEXT
,
FREQUENCY_LONGTEXT
,
true
)
FREQUENCY_LONGTEXT
,
true
)
change_integer_range
(
-
1
,
0xFFFFFFFE
)
change_safe
()
change_safe
()
add_integer
(
CFG_PREFIX
"tuner-audio-mode"
,
-
1
,
TUNER_AUDIO_MODE_TEXT
,
add_integer
(
CFG_PREFIX
"tuner-audio-mode"
,
-
1
,
TUNER_AUDIO_MODE_TEXT
,
TUNER_AUDIO_MODE_LONGTEXT
,
true
)
TUNER_AUDIO_MODE_LONGTEXT
,
true
)
...
@@ -565,13 +567,10 @@ struct demux_sys_t
...
@@ -565,13 +567,10 @@ struct demux_sys_t
char
*
psz_device
;
/* Main device from MRL */
char
*
psz_device
;
/* Main device from MRL */
int
i_fd
;
int
i_fd
;
char
*
psz_requested_chroma
;
/* Video */
/* Video */
io_method
io
;
io_method
io
;
unsigned
i_selected_input
;
unsigned
i_selected_input
;
char
*
psz_standard
;
unsigned
i_codec
;
unsigned
i_codec
;
struct
v4l2_fmtdesc
*
p_codecs
;
struct
v4l2_fmtdesc
*
p_codecs
;
...
@@ -582,7 +581,6 @@ struct demux_sys_t
...
@@ -582,7 +581,6 @@ struct demux_sys_t
int
i_width
;
int
i_width
;
int
i_height
;
int
i_height
;
unsigned
int
i_aspect
;
unsigned
int
i_aspect
;
float
f_fps
;
/* <= 0.0 mean to grab at full rate */
int
i_fourcc
;
int
i_fourcc
;
uint32_t
i_block_flags
;
uint32_t
i_block_flags
;
...
@@ -594,7 +592,6 @@ struct demux_sys_t
...
@@ -594,7 +592,6 @@ struct demux_sys_t
/* Tuner */
/* Tuner */
uint32_t
i_tuner
;
uint32_t
i_tuner
;
enum
v4l2_tuner_type
i_tuner_type
;
enum
v4l2_tuner_type
i_tuner_type
;
int
i_frequency
;
int
i_tuner_audio_mode
;
int
i_tuner_audio_mode
;
#ifdef HAVE_LIBV4L2
#ifdef HAVE_LIBV4L2
...
@@ -681,12 +678,8 @@ static void GetV4L2Params( demux_sys_t *p_sys, vlc_object_t *p_obj )
...
@@ -681,12 +678,8 @@ static void GetV4L2Params( demux_sys_t *p_sys, vlc_object_t *p_obj )
var_Create
(
p_obj
,
"v4l2-controls-reset"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
var_Create
(
p_obj
,
"v4l2-controls-reset"
,
VLC_VAR_BOOL
|
VLC_VAR_DOINHERIT
);
p_sys
->
f_fps
=
var_CreateGetFloat
(
p_obj
,
"v4l2-fps"
);
p_sys
->
psz_requested_chroma
=
var_CreateGetString
(
p_obj
,
"v4l2-chroma"
);
p_sys
->
i_tuner
=
var_CreateGetInteger
(
p_obj
,
"v4l2-tuner"
);
p_sys
->
i_tuner
=
var_CreateGetInteger
(
p_obj
,
"v4l2-tuner"
);
p_sys
->
i_tuner_type
=
V4L2_TUNER_RADIO
;
/* non-trap default value */
p_sys
->
i_tuner_type
=
V4L2_TUNER_RADIO
;
/* non-trap default value */
p_sys
->
i_frequency
=
var_CreateGetInteger
(
p_obj
,
"v4l2-tuner-frequency"
);
p_sys
->
i_tuner_audio_mode
=
var_CreateGetInteger
(
p_obj
,
"v4l2-tuner-audio-mode"
);
p_sys
->
i_tuner_audio_mode
=
var_CreateGetInteger
(
p_obj
,
"v4l2-tuner-audio-mode"
);
char
*
psz_aspect
=
var_CreateGetString
(
p_obj
,
"v4l2-aspect-ratio"
);
char
*
psz_aspect
=
var_CreateGetString
(
p_obj
,
"v4l2-aspect-ratio"
);
...
@@ -816,9 +809,7 @@ static void CommonClose( vlc_object_t *p_this, demux_sys_t *p_sys )
...
@@ -816,9 +809,7 @@ static void CommonClose( vlc_object_t *p_this, demux_sys_t *p_sys )
/* Close */
/* Close */
if
(
p_sys
->
i_fd
>=
0
)
v4l2_close
(
p_sys
->
i_fd
);
if
(
p_sys
->
i_fd
>=
0
)
v4l2_close
(
p_sys
->
i_fd
);
free
(
p_sys
->
psz_device
);
free
(
p_sys
->
psz_device
);
free
(
p_sys
->
psz_standard
);
free
(
p_sys
->
p_codecs
);
free
(
p_sys
->
p_codecs
);
free
(
p_sys
->
psz_requested_chroma
);
free
(
p_sys
);
free
(
p_sys
);
}
}
...
@@ -1549,9 +1540,7 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
...
@@ -1549,9 +1540,7 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
/* Select standard */
/* Select standard */
bool
bottom_first
;
bool
bottom_first
;
const
char
*
stdname
=
p_sys
->
psz_standard
;
const
char
*
stdname
=
var_InheritString
(
p_obj
,
CFG_PREFIX
"standard"
);
if
(
stdname
==
NULL
)
stdname
=
var_InheritString
(
p_obj
,
CFG_PREFIX
"standard"
);
if
(
stdname
!=
NULL
)
if
(
stdname
!=
NULL
)
{
{
v4l2_std_id
std
=
strtoull
(
stdname
,
NULL
,
0
);
v4l2_std_id
std
=
strtoull
(
stdname
,
NULL
,
0
);
...
@@ -1581,12 +1570,13 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
...
@@ -1581,12 +1570,13 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
bottom_first
=
false
;
bottom_first
=
false
;
/* Tune the tuner */
/* Tune the tuner */
if
(
p_sys
->
i_frequency
>=
0
)
uint32_t
freq
=
var_InheritInteger
(
p_obj
,
CFG_PREFIX
"frequency"
);
if
(
freq
!=
(
uint32_t
)
-
1
)
{
{
struct
v4l2_frequency
frequency
=
{
struct
v4l2_frequency
frequency
=
{
.
tuner
=
p_sys
->
i_tuner
,
.
tuner
=
p_sys
->
i_tuner
,
.
type
=
p_sys
->
i_tuner_type
,
.
type
=
p_sys
->
i_tuner_type
,
.
frequency
=
p_sys
->
i_frequency
/
62
.
5
,
.
frequency
=
freq
/
62
.
5
,
};
};
if
(
v4l2_ioctl
(
i_fd
,
VIDIOC_S_FREQUENCY
,
&
frequency
)
<
0
)
if
(
v4l2_ioctl
(
i_fd
,
VIDIOC_S_FREQUENCY
,
&
frequency
)
<
0
)
...
@@ -1694,17 +1684,19 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
...
@@ -1694,17 +1684,19 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
fmt
.
fmt
.
pix
.
field
=
V4L2_FIELD_NONE
;
fmt
.
fmt
.
pix
.
field
=
V4L2_FIELD_NONE
;
float
f_fps
;
if
(
b_demux
)
if
(
b_demux
)
{
{
demux_t
*
p_demux
=
(
demux_t
*
)
p_obj
;
demux_t
*
p_demux
=
(
demux_t
*
)
p_obj
;
char
*
reqchroma
=
var_InheritString
(
p_obj
,
CFG_PREFIX
"chroma"
);
/* Test and set Chroma */
/* Test and set Chroma */
fmt
.
fmt
.
pix
.
pixelformat
=
0
;
fmt
.
fmt
.
pix
.
pixelformat
=
0
;
if
(
p_sys
->
psz_requested_chroma
&&
*
p_sys
->
psz_requested_chroma
)
if
(
reqchroma
!=
NULL
)
{
{
/* User specified chroma */
/* User specified chroma */
const
vlc_fourcc_t
i_requested_fourcc
=
const
vlc_fourcc_t
i_requested_fourcc
=
vlc_fourcc_GetCodecFromString
(
VIDEO_ES
,
p_sys
->
psz_requested_
chroma
);
vlc_fourcc_GetCodecFromString
(
VIDEO_ES
,
req
chroma
);
for
(
int
i
=
0
;
v4l2chroma_to_fourcc
[
i
].
i_v4l2
!=
0
;
i
++
)
for
(
int
i
=
0
;
v4l2chroma_to_fourcc
[
i
].
i_v4l2
!=
0
;
i
++
)
{
{
...
@@ -1730,9 +1722,11 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
...
@@ -1730,9 +1722,11 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
}
}
if
(
b_error
)
if
(
b_error
)
{
{
msg_Warn
(
p_demux
,
"Driver is unable to use specified chroma %s. Trying defaults."
,
p_sys
->
psz_requested_chroma
);
msg_Warn
(
p_obj
,
"requested chroma %s not supported. "
" Trying default."
,
reqchroma
);
fmt
.
fmt
.
pix
.
pixelformat
=
0
;
fmt
.
fmt
.
pix
.
pixelformat
=
0
;
}
}
free
(
reqchroma
);
}
}
/* If no user specified chroma, find best */
/* If no user specified chroma, find best */
...
@@ -1762,20 +1756,21 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
...
@@ -1762,20 +1756,21 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
if
(
p_sys
->
i_width
<
0
||
p_sys
->
i_height
<
0
)
if
(
p_sys
->
i_width
<
0
||
p_sys
->
i_height
<
0
)
{
{
if
(
p_sys
->
f_fps
<=
0
)
f_fps
=
var_InheritFloat
(
p_obj
,
CFG_PREFIX
"fps"
);
if
(
f_fps
<=
0
.
)
{
{
p_sys
->
f_fps
=
GetAbsoluteMaxFrameRate
(
p_demux
,
i_fd
,
f_fps
=
GetAbsoluteMaxFrameRate
(
p_demux
,
i_fd
,
fmt
.
fmt
.
pix
.
pixelformat
);
fmt
.
fmt
.
pix
.
pixelformat
);
msg_Dbg
(
p_demux
,
"Found maximum framerate of %f"
,
p_sys
->
f_fps
);
msg_Dbg
(
p_demux
,
"Found maximum framerate of %f"
,
f_fps
);
}
}
uint32_t
i_width
,
i_height
;
uint32_t
i_width
,
i_height
;
GetMaxDimensions
(
p_demux
,
i_fd
,
GetMaxDimensions
(
p_demux
,
i_fd
,
fmt
.
fmt
.
pix
.
pixelformat
,
p_sys
->
f_fps
,
fmt
.
fmt
.
pix
.
pixelformat
,
f_fps
,
&
i_width
,
&
i_height
);
&
i_width
,
&
i_height
);
if
(
i_width
||
i_height
)
if
(
i_width
||
i_height
)
{
{
msg_Dbg
(
p_demux
,
"Found optimal dimensions for framerate %f "
msg_Dbg
(
p_demux
,
"Found optimal dimensions for framerate %f "
"of %ux%u"
,
p_sys
->
f_fps
,
i_width
,
i_height
);
"of %ux%u"
,
f_fps
,
i_width
,
i_height
);
fmt
.
fmt
.
pix
.
width
=
i_width
;
fmt
.
fmt
.
pix
.
width
=
i_width
;
fmt
.
fmt
.
pix
.
height
=
i_height
;
fmt
.
fmt
.
pix
.
height
=
i_height
;
if
(
v4l2_ioctl
(
i_fd
,
VIDIOC_S_FMT
,
&
fmt
)
<
0
)
if
(
v4l2_ioctl
(
i_fd
,
VIDIOC_S_FMT
,
&
fmt
)
<
0
)
...
@@ -1943,12 +1938,14 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
...
@@ -1943,12 +1938,14 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
es_fmt
.
video
.
i_sar_den
=
VOUT_ASPECT_FACTOR
*
es_fmt
.
video
.
i_width
;
es_fmt
.
video
.
i_sar_den
=
VOUT_ASPECT_FACTOR
*
es_fmt
.
video
.
i_width
;
/* Framerate */
/* Framerate */
es_fmt
.
video
.
i_frame_rate
=
p_sys
->
f_fps
*
INT64_C
(
1000000
);
es_fmt
.
video
.
i_frame_rate
=
lround
(
f_fps
*
1000000
.
);
es_fmt
.
video
.
i_frame_rate_base
=
INT64_C
(
1000000
)
;
es_fmt
.
video
.
i_frame_rate_base
=
1000000
;
demux_t
*
p_demux
=
(
demux_t
*
)
p_obj
;
demux_t
*
p_demux
=
(
demux_t
*
)
p_obj
;
msg_Dbg
(
p_demux
,
"added new video es %4.4s %dx%d"
,
msg_Dbg
(
p_demux
,
"added new video es %4.4s %dx%d"
,
(
char
*
)
&
es_fmt
.
i_codec
,
es_fmt
.
video
.
i_width
,
es_fmt
.
video
.
i_height
);
(
char
*
)
&
es_fmt
.
i_codec
,
es_fmt
.
video
.
i_width
,
es_fmt
.
video
.
i_height
);
msg_Dbg
(
p_obj
,
" frame rate: %f"
,
f_fps
);
p_sys
->
p_es
=
es_out_Add
(
p_demux
->
out
,
&
es_fmt
);
p_sys
->
p_es
=
es_out_Add
(
p_demux
->
out
,
&
es_fmt
);
}
}
...
@@ -2014,12 +2011,6 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
...
@@ -2014,12 +2011,6 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
break
;
break
;
}
}
/* report fps */
if
(
p_sys
->
f_fps
>=
0
.
1
)
{
msg_Dbg
(
p_obj
,
"User set fps=%f"
,
p_sys
->
f_fps
);
}
return
i_fd
;
return
i_fd
;
error:
error:
...
...
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