Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
aa98c569
Commit
aa98c569
authored
Sep 13, 2008
by
Antoine Cellerier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fixed the RGB masks in v4l2.
Thanks a lot to plc5_250 on IRC for testing.
parent
f93b233d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
36 additions
and
29 deletions
+36
-29
modules/access/v4l2/v4l2.c
modules/access/v4l2/v4l2.c
+36
-29
No files found.
modules/access/v4l2/v4l2.c
View file @
aa98c569
...
...
@@ -439,46 +439,59 @@ static const struct
{
unsigned
int
i_v4l2
;
int
i_fourcc
;
int
i_rmask
;
int
i_gmask
;
int
i_bmask
;
}
v4l2chroma_to_fourcc
[]
=
{
/* Raw data types */
{
V4L2_PIX_FMT_GREY
,
VLC_FOURCC
(
'G'
,
'R'
,
'E'
,
'Y'
)
},
{
V4L2_PIX_FMT_HI240
,
VLC_FOURCC
(
'I'
,
'2'
,
'4'
,
'0'
)
},
{
V4L2_PIX_FMT_RGB565
,
VLC_FOURCC
(
'R'
,
'V'
,
'1'
,
'6'
)
},
{
V4L2_PIX_FMT_RGB555
,
VLC_FOURCC
(
'R'
,
'V'
,
'1'
,
'5'
)
},
{
V4L2_PIX_FMT_BGR24
,
VLC_FOURCC
(
'R'
,
'V'
,
'2'
,
'4'
)
},
{
V4L2_PIX_FMT_BGR32
,
VLC_FOURCC
(
'R'
,
'V'
,
'3'
,
'2'
)
},
{
V4L2_PIX_FMT_YUYV
,
VLC_FOURCC
(
'Y'
,
'U'
,
'Y'
,
'2'
)
},
{
V4L2_PIX_FMT_YUYV
,
VLC_FOURCC
(
'Y'
,
'U'
,
'Y'
,
'V'
)
},
{
V4L2_PIX_FMT_UYVY
,
VLC_FOURCC
(
'U'
,
'Y'
,
'V'
,
'Y'
)
},
{
V4L2_PIX_FMT_Y41P
,
VLC_FOURCC
(
'I'
,
'4'
,
'1'
,
'N'
)
},
{
V4L2_PIX_FMT_YUV422P
,
VLC_FOURCC
(
'I'
,
'4'
,
'2'
,
'2'
)
},
{
V4L2_PIX_FMT_YVU420
,
VLC_FOURCC
(
'Y'
,
'V'
,
'1'
,
'2'
)
},
{
V4L2_PIX_FMT_YUV411P
,
VLC_FOURCC
(
'I'
,
'4'
,
'1'
,
'1'
)
},
{
V4L2_PIX_FMT_YUV410
,
VLC_FOURCC
(
'I'
,
'4'
,
'1'
,
'0'
)
},
{
V4L2_PIX_FMT_GREY
,
VLC_FOURCC
(
'G'
,
'R'
,
'E'
,
'Y'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_HI240
,
VLC_FOURCC
(
'I'
,
'2'
,
'4'
,
'0'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_RGB555
,
VLC_FOURCC
(
'R'
,
'V'
,
'1'
,
'5'
),
0x001f
,
0x03e0
,
0x7c00
},
{
V4L2_PIX_FMT_RGB565
,
VLC_FOURCC
(
'R'
,
'V'
,
'1'
,
'6'
),
0x001f
,
0x07e0
,
0xf800
},
/* Won't work since we don't know how to handle such gmask values
* correctly
{ V4L2_PIX_FMT_RGB555X, VLC_FOURCC('R','V','1','5'), 0x007c,0xe003,0x1f00 },
{ V4L2_PIX_FMT_RGB565X, VLC_FOURCC('R','V','1','6'), 0x00f8,0xe007,0x1f00 },
*/
{
V4L2_PIX_FMT_BGR24
,
VLC_FOURCC
(
'R'
,
'V'
,
'2'
,
'4'
),
0xff0000
,
0xff00
,
0xff
},
{
V4L2_PIX_FMT_RGB24
,
VLC_FOURCC
(
'R'
,
'V'
,
'2'
,
'4'
),
0xff
,
0xff00
,
0xff0000
},
{
V4L2_PIX_FMT_BGR32
,
VLC_FOURCC
(
'R'
,
'V'
,
'3'
,
'2'
),
0xff0000
,
0xff00
,
0xff
},
{
V4L2_PIX_FMT_RGB32
,
VLC_FOURCC
(
'R'
,
'V'
,
'3'
,
'2'
),
0xff
,
0xff00
,
0xff0000
},
{
V4L2_PIX_FMT_YUYV
,
VLC_FOURCC
(
'Y'
,
'U'
,
'Y'
,
'2'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_YUYV
,
VLC_FOURCC
(
'Y'
,
'U'
,
'Y'
,
'V'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_UYVY
,
VLC_FOURCC
(
'U'
,
'Y'
,
'V'
,
'Y'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_Y41P
,
VLC_FOURCC
(
'I'
,
'4'
,
'1'
,
'N'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_YUV422P
,
VLC_FOURCC
(
'I'
,
'4'
,
'2'
,
'2'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_YVU420
,
VLC_FOURCC
(
'Y'
,
'V'
,
'1'
,
'2'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_YUV411P
,
VLC_FOURCC
(
'I'
,
'4'
,
'1'
,
'1'
),
0
,
0
,
0
},
{
V4L2_PIX_FMT_YUV410
,
VLC_FOURCC
(
'I'
,
'4'
,
'1'
,
'0'
),
0
,
0
,
0
},
/* Raw data types, not in V4L2 spec but still in videodev2.h and supported
* by VLC */
{
V4L2_PIX_FMT_YUV420
,
VLC_FOURCC
(
'I'
,
'4'
,
'2'
,
'0'
)
},
{
V4L2_PIX_FMT_YUV420
,
VLC_FOURCC
(
'I'
,
'4'
,
'2'
,
'0'
)
,
0
,
0
,
0
},
/* FIXME { V4L2_PIX_FMT_RGB444, VLC_FOURCC('R','V','3','2') }, */
/* Compressed data types */
{
V4L2_PIX_FMT_MJPEG
,
VLC_FOURCC
(
'M'
,
'J'
,
'P'
,
'G'
)
},
{
V4L2_PIX_FMT_MJPEG
,
VLC_FOURCC
(
'M'
,
'J'
,
'P'
,
'G'
)
,
0
,
0
,
0
},
#if 0
{ V4L2_PIX_FMT_JPEG, VLC_FOURCC('J','P','E','G') },
{ V4L2_PIX_FMT_DV, VLC_FOURCC('?','?','?','?') },
{ V4L2_PIX_FMT_MPEG, VLC_FOURCC('?','?','?','?') },
#endif
{
0
,
0
}
{
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.
*
* Try YUV chromas first, then RGB little endian and MJPEG as last resort.
*/
static
const
__u32
p_chroma_fallbacks
[]
=
{
V4L2_PIX_FMT_YUV420
,
V4L2_PIX_FMT_YVU420
,
V4L2_PIX_FMT_YUV422P
,
V4L2_PIX_FMT_YUYV
,
V4L2_PIX_FMT_UYVY
,
V4L2_PIX_FMT_MJPEG
};
V4L2_PIX_FMT_YUYV
,
V4L2_PIX_FMT_UYVY
,
V4L2_PIX_FMT_BGR24
,
V4L2_PIX_FTM_BGR32
,
V4L2_PIX_FMT_MJPEG
};
static
const
struct
{
...
...
@@ -1816,6 +1829,7 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
unsigned
int
i_min
;
enum
v4l2_buf_type
buf_type
;
char
*
psz_device
=
p_sys
->
psz_vdev
;
es_format_t
es_fmt
;
if
(
(
i_fd
=
open
(
psz_device
,
O_RDWR
)
)
<
0
)
{
...
...
@@ -2054,6 +2068,10 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
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
;
}
}
...
...
@@ -2131,21 +2149,10 @@ static int OpenVideoDev( vlc_object_t *p_obj, demux_sys_t *p_sys, bool b_demux )
}
/* Add */
es_format_t
es_fmt
;
es_format_Init
(
&
es_fmt
,
VIDEO_ES
,
p_sys
->
i_fourcc
);
es_fmt
.
video
.
i_width
=
p_sys
->
i_width
;
es_fmt
.
video
.
i_height
=
p_sys
->
i_height
;
es_fmt
.
video
.
i_aspect
=
4
*
VOUT_ASPECT_FACTOR
/
3
;
/* Setup rgb mask for RGB formats */
if
(
p_sys
->
i_fourcc
==
VLC_FOURCC
(
'R'
,
'V'
,
'2'
,
'4'
)
)
{
/* This is in BGR format */
es_fmt
.
video
.
i_bmask
=
0x00ff0000
;
es_fmt
.
video
.
i_gmask
=
0x0000ff00
;
es_fmt
.
video
.
i_rmask
=
0x000000ff
;
}
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
);
p_sys
->
p_es_video
=
es_out_Add
(
p_demux
->
out
,
&
es_fmt
);
...
...
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