diff options
Diffstat (limited to 'drivers/media')
-rw-r--r-- | drivers/media/video/cafe_ccic.c | 42 | ||||
-rw-r--r-- | drivers/media/video/ov7670.c | 15 |
2 files changed, 3 insertions, 54 deletions
diff --git a/drivers/media/video/cafe_ccic.c b/drivers/media/video/cafe_ccic.c index 30864dac26a3..9d9844e22951 100644 --- a/drivers/media/video/cafe_ccic.c +++ b/drivers/media/video/cafe_ccic.c | |||
@@ -612,16 +612,6 @@ static void cafe_ctlr_image(struct cafe_camera *cam) | |||
612 | C0_DF_MASK); | 612 | C0_DF_MASK); |
613 | break; | 613 | break; |
614 | 614 | ||
615 | /* | ||
616 | * For "fake rgb32" get the image pitch right. | ||
617 | */ | ||
618 | case V4L2_PIX_FMT_RGB32: | ||
619 | cafe_reg_write_mask(cam, REG_IMGPITCH, fmt->bytesperline/2, | ||
620 | IMGP_YP_MASK); | ||
621 | imgsz = ((fmt->height << IMGSZ_V_SHIFT) & IMGSZ_V_MASK) | | ||
622 | ((fmt->bytesperline/2) & IMGSZ_H_MASK); | ||
623 | cafe_reg_write(cam, REG_IMGSIZE, imgsz); | ||
624 | /* fall into ... */ | ||
625 | case V4L2_PIX_FMT_RGB444: | 615 | case V4L2_PIX_FMT_RGB444: |
626 | cafe_reg_write_mask(cam, REG_CTRL0, | 616 | cafe_reg_write_mask(cam, REG_CTRL0, |
627 | C0_DF_RGB|C0_RGBF_444|C0_RGB4_XRGB, | 617 | C0_DF_RGB|C0_RGBF_444|C0_RGB4_XRGB, |
@@ -902,11 +892,8 @@ static int cafe_alloc_dma_bufs(struct cafe_camera *cam, int loadtime) | |||
902 | cafe_set_config_needed(cam, 1); | 892 | cafe_set_config_needed(cam, 1); |
903 | if (loadtime) | 893 | if (loadtime) |
904 | cam->dma_buf_size = dma_buf_size; | 894 | cam->dma_buf_size = dma_buf_size; |
905 | else { | 895 | else |
906 | cam->dma_buf_size = cam->pix_format.sizeimage; | 896 | cam->dma_buf_size = cam->pix_format.sizeimage; |
907 | if (cam->pix_format.pixelformat == V4L2_PIX_FMT_RGB32) | ||
908 | cam->dma_buf_size /= 2; | ||
909 | } | ||
910 | if (n_dma_bufs > 3) | 897 | if (n_dma_bufs > 3) |
911 | n_dma_bufs = 3; | 898 | n_dma_bufs = 3; |
912 | 899 | ||
@@ -1751,26 +1738,6 @@ static struct video_device cafe_v4l_template = { | |||
1751 | * Interrupt handler stuff | 1738 | * Interrupt handler stuff |
1752 | */ | 1739 | */ |
1753 | 1740 | ||
1754 | /* | ||
1755 | * Create RGB32 from RGB444 so it can be displayed before the applications | ||
1756 | * know about the latter format. | ||
1757 | */ | ||
1758 | static void cafe_fake_rgb32(struct cafe_camera *cam, char *dest, char *src) | ||
1759 | { | ||
1760 | int i; | ||
1761 | u16 *ssrc = (u16 *) src; | ||
1762 | |||
1763 | /* RGB444 version */ | ||
1764 | for (i = 0; i < cam->pix_format.sizeimage; i += 4) { | ||
1765 | // dest[0] = (*ssrc & 0xf000) >> 8; | ||
1766 | dest[0] = (*ssrc & 0x000f) << 4; | ||
1767 | dest[1] = (*ssrc & 0x00f0); | ||
1768 | dest[2] = (*ssrc & 0x0f00) >> 4; | ||
1769 | dest[3] = (*ssrc & 0xf000); /* Alpha */ | ||
1770 | dest += 4; | ||
1771 | ssrc++; | ||
1772 | } | ||
1773 | } | ||
1774 | 1741 | ||
1775 | 1742 | ||
1776 | static void cafe_frame_tasklet(unsigned long data) | 1743 | static void cafe_frame_tasklet(unsigned long data) |
@@ -1800,11 +1767,8 @@ static void cafe_frame_tasklet(unsigned long data) | |||
1800 | */ | 1767 | */ |
1801 | sbuf = list_entry(cam->sb_avail.next, | 1768 | sbuf = list_entry(cam->sb_avail.next, |
1802 | struct cafe_sio_buffer, list); | 1769 | struct cafe_sio_buffer, list); |
1803 | if (cam->pix_format.pixelformat == V4L2_PIX_FMT_RGB32) | 1770 | memcpy(sbuf->buffer, cam->dma_bufs[bufno], |
1804 | cafe_fake_rgb32(cam, sbuf->buffer, cam->dma_bufs[bufno]); | 1771 | cam->pix_format.sizeimage); |
1805 | else | ||
1806 | memcpy(sbuf->buffer, cam->dma_bufs[bufno], | ||
1807 | cam->pix_format.sizeimage); | ||
1808 | sbuf->v4lbuf.bytesused = cam->pix_format.sizeimage; | 1772 | sbuf->v4lbuf.bytesused = cam->pix_format.sizeimage; |
1809 | sbuf->v4lbuf.sequence = cam->buf_seq[bufno]; | 1773 | sbuf->v4lbuf.sequence = cam->buf_seq[bufno]; |
1810 | sbuf->v4lbuf.flags &= ~V4L2_BUF_FLAG_QUEUED; | 1774 | sbuf->v4lbuf.flags &= ~V4L2_BUF_FLAG_QUEUED; |
diff --git a/drivers/media/video/ov7670.c b/drivers/media/video/ov7670.c index b7d824ee03ea..7d380d76338a 100644 --- a/drivers/media/video/ov7670.c +++ b/drivers/media/video/ov7670.c | |||
@@ -497,19 +497,6 @@ static struct ov7670_format_struct { | |||
497 | .regs = ov7670_fmt_rgb565, | 497 | .regs = ov7670_fmt_rgb565, |
498 | .cmatrix = { 179, -179, 0, -61, -176, 228 }, | 498 | .cmatrix = { 179, -179, 0, -61, -176, 228 }, |
499 | }, | 499 | }, |
500 | /* | ||
501 | * Pretend we do RGB32. This is here on the assumption that the | ||
502 | * upper layer will reformat RGB444 appropriately. | ||
503 | * | ||
504 | * The entire purpose for this thing's existence is to enable easy | ||
505 | * display of RGB444 for debugging purposes. It will come out soon. | ||
506 | */ | ||
507 | { | ||
508 | .desc = "RGB32 (faked)", | ||
509 | .pixelformat = V4L2_PIX_FMT_RGB32, | ||
510 | .regs = ov7670_fmt_rgb444, | ||
511 | .cmatrix = { 179, -179, 0, -61, -176, 228 }, | ||
512 | }, | ||
513 | }; | 500 | }; |
514 | #define N_OV7670_FMTS (sizeof(ov7670_formats)/sizeof(ov7670_formats[0])) | 501 | #define N_OV7670_FMTS (sizeof(ov7670_formats)/sizeof(ov7670_formats[0])) |
515 | 502 | ||
@@ -694,8 +681,6 @@ static int ov7670_try_fmt(struct i2c_client *c, struct v4l2_format *fmt, | |||
694 | pix->width = wsize->width; | 681 | pix->width = wsize->width; |
695 | pix->height = wsize->height; | 682 | pix->height = wsize->height; |
696 | pix->bytesperline = pix->width*BYTES_PER_PIXEL; | 683 | pix->bytesperline = pix->width*BYTES_PER_PIXEL; |
697 | if (pix->pixelformat == V4L2_PIX_FMT_RGB32) | ||
698 | pix->bytesperline *= 2; | ||
699 | pix->sizeimage = pix->height*pix->bytesperline; | 684 | pix->sizeimage = pix->height*pix->bytesperline; |
700 | return 0; | 685 | return 0; |
701 | } | 686 | } |