[media] marvell-ccic: fix Y'CbCr ordering
Various formats had their byte ordering implemented incorrectly, and
the V4L2_PIX_FMT_UYVY is actually impossible to create, instead you
get V4L2_PIX_FMT_YVYU.
This was working before commit ad6ac45222
("add new formats support for marvell-ccic driver"). That commit broke
the original format support and the OLPC XO-1 laptop showed wrong
colors ever since (if you are crazy enough to attempt to run the latest
kernel on it, like I did).
The email addresses of the authors of that patch are no longer valid,
so without a way to reach them and ask them about their test setup
I am going with what I can test on the OLPC laptop.
If this breaks something for someone on their non-OLPC setup, then
contact the linux-media mailinglist. My suspicion however is that
that commit went in untested.
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Acked-by: Jonathan Corbet <corbet@lwn.net>
Cc: <stable@vger.kernel.org> # for v3.19 and up
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
This commit is contained in:
parent
64131a87f2
commit
2a700d8edf
|
@ -116,8 +116,8 @@ static struct mcam_format_struct {
|
||||||
.planar = false,
|
.planar = false,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.desc = "UYVY 4:2:2",
|
.desc = "YVYU 4:2:2",
|
||||||
.pixelformat = V4L2_PIX_FMT_UYVY,
|
.pixelformat = V4L2_PIX_FMT_YVYU,
|
||||||
.mbus_code = MEDIA_BUS_FMT_YUYV8_2X8,
|
.mbus_code = MEDIA_BUS_FMT_YUYV8_2X8,
|
||||||
.bpp = 2,
|
.bpp = 2,
|
||||||
.planar = false,
|
.planar = false,
|
||||||
|
@ -748,7 +748,7 @@ static void mcam_ctlr_image(struct mcam_camera *cam)
|
||||||
|
|
||||||
switch (fmt->pixelformat) {
|
switch (fmt->pixelformat) {
|
||||||
case V4L2_PIX_FMT_YUYV:
|
case V4L2_PIX_FMT_YUYV:
|
||||||
case V4L2_PIX_FMT_UYVY:
|
case V4L2_PIX_FMT_YVYU:
|
||||||
widthy = fmt->width * 2;
|
widthy = fmt->width * 2;
|
||||||
widthuv = 0;
|
widthuv = 0;
|
||||||
break;
|
break;
|
||||||
|
@ -784,15 +784,15 @@ static void mcam_ctlr_image(struct mcam_camera *cam)
|
||||||
case V4L2_PIX_FMT_YUV420:
|
case V4L2_PIX_FMT_YUV420:
|
||||||
case V4L2_PIX_FMT_YVU420:
|
case V4L2_PIX_FMT_YVU420:
|
||||||
mcam_reg_write_mask(cam, REG_CTRL0,
|
mcam_reg_write_mask(cam, REG_CTRL0,
|
||||||
C0_DF_YUV | C0_YUV_420PL | C0_YUVE_YVYU, C0_DF_MASK);
|
C0_DF_YUV | C0_YUV_420PL | C0_YUVE_VYUY, C0_DF_MASK);
|
||||||
break;
|
break;
|
||||||
case V4L2_PIX_FMT_YUYV:
|
case V4L2_PIX_FMT_YUYV:
|
||||||
mcam_reg_write_mask(cam, REG_CTRL0,
|
mcam_reg_write_mask(cam, REG_CTRL0,
|
||||||
C0_DF_YUV | C0_YUV_PACKED | C0_YUVE_UYVY, C0_DF_MASK);
|
C0_DF_YUV | C0_YUV_PACKED | C0_YUVE_NOSWAP, C0_DF_MASK);
|
||||||
break;
|
break;
|
||||||
case V4L2_PIX_FMT_UYVY:
|
case V4L2_PIX_FMT_YVYU:
|
||||||
mcam_reg_write_mask(cam, REG_CTRL0,
|
mcam_reg_write_mask(cam, REG_CTRL0,
|
||||||
C0_DF_YUV | C0_YUV_PACKED | C0_YUVE_YUYV, C0_DF_MASK);
|
C0_DF_YUV | C0_YUV_PACKED | C0_YUVE_SWAP24, C0_DF_MASK);
|
||||||
break;
|
break;
|
||||||
case V4L2_PIX_FMT_JPEG:
|
case V4L2_PIX_FMT_JPEG:
|
||||||
mcam_reg_write_mask(cam, REG_CTRL0,
|
mcam_reg_write_mask(cam, REG_CTRL0,
|
||||||
|
|
|
@ -330,10 +330,10 @@ int mccic_resume(struct mcam_camera *cam);
|
||||||
#define C0_YUVE_YVYU 0x00010000 /* Y1CrY0Cb */
|
#define C0_YUVE_YVYU 0x00010000 /* Y1CrY0Cb */
|
||||||
#define C0_YUVE_VYUY 0x00020000 /* CrY1CbY0 */
|
#define C0_YUVE_VYUY 0x00020000 /* CrY1CbY0 */
|
||||||
#define C0_YUVE_UYVY 0x00030000 /* CbY1CrY0 */
|
#define C0_YUVE_UYVY 0x00030000 /* CbY1CrY0 */
|
||||||
#define C0_YUVE_XYUV 0x00000000 /* 420: .YUV */
|
#define C0_YUVE_NOSWAP 0x00000000 /* no bytes swapping */
|
||||||
#define C0_YUVE_XYVU 0x00010000 /* 420: .YVU */
|
#define C0_YUVE_SWAP13 0x00010000 /* swap byte 1 and 3 */
|
||||||
#define C0_YUVE_XUVY 0x00020000 /* 420: .UVY */
|
#define C0_YUVE_SWAP24 0x00020000 /* swap byte 2 and 4 */
|
||||||
#define C0_YUVE_XVUY 0x00030000 /* 420: .VUY */
|
#define C0_YUVE_SWAP1324 0x00030000 /* swap bytes 1&3 and 2&4 */
|
||||||
/* Bayer bits 18,19 if needed */
|
/* Bayer bits 18,19 if needed */
|
||||||
#define C0_EOF_VSYNC 0x00400000 /* Generate EOF by VSYNC */
|
#define C0_EOF_VSYNC 0x00400000 /* Generate EOF by VSYNC */
|
||||||
#define C0_VEDGE_CTRL 0x00800000 /* Detect falling edge of VSYNC */
|
#define C0_VEDGE_CTRL 0x00800000 /* Detect falling edge of VSYNC */
|
||||||
|
|
Loading…
Reference in New Issue