media: i2c: ov5640: Add support for BT656 mode
Enable support for BT656 mode. Signed-off-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com> Reviewed-by: Biju Das <biju.das.jz@bp.renesas.com> Reviewed-by: Jacopo Mondi <jacopo@jmondi.org> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
parent
311a6408f8
commit
4039b03720
@ -84,6 +84,7 @@
|
|||||||
#define OV5640_REG_VFIFO_HSIZE 0x4602
|
#define OV5640_REG_VFIFO_HSIZE 0x4602
|
||||||
#define OV5640_REG_VFIFO_VSIZE 0x4604
|
#define OV5640_REG_VFIFO_VSIZE 0x4604
|
||||||
#define OV5640_REG_JPG_MODE_SELECT 0x4713
|
#define OV5640_REG_JPG_MODE_SELECT 0x4713
|
||||||
|
#define OV5640_REG_CCIR656_CTRL00 0x4730
|
||||||
#define OV5640_REG_POLARITY_CTRL00 0x4740
|
#define OV5640_REG_POLARITY_CTRL00 0x4740
|
||||||
#define OV5640_REG_MIPI_CTRL00 0x4800
|
#define OV5640_REG_MIPI_CTRL00 0x4800
|
||||||
#define OV5640_REG_DEBUG_MODE 0x4814
|
#define OV5640_REG_DEBUG_MODE 0x4814
|
||||||
@ -1215,6 +1216,20 @@ static int ov5640_set_autogain(struct ov5640_dev *sensor, bool on)
|
|||||||
BIT(1), on ? 0 : BIT(1));
|
BIT(1), on ? 0 : BIT(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int ov5640_set_stream_bt656(struct ov5640_dev *sensor, bool on)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = ov5640_write_reg(sensor, OV5640_REG_CCIR656_CTRL00,
|
||||||
|
on ? 0x1 : 0x00);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
return ov5640_write_reg(sensor, OV5640_REG_SYS_CTRL0, on ?
|
||||||
|
OV5640_REG_SYS_CTRL0_SW_PWUP :
|
||||||
|
OV5640_REG_SYS_CTRL0_SW_PWDN);
|
||||||
|
}
|
||||||
|
|
||||||
static int ov5640_set_stream_dvp(struct ov5640_dev *sensor, bool on)
|
static int ov5640_set_stream_dvp(struct ov5640_dev *sensor, bool on)
|
||||||
{
|
{
|
||||||
return ov5640_write_reg(sensor, OV5640_REG_SYS_CTRL0, on ?
|
return ov5640_write_reg(sensor, OV5640_REG_SYS_CTRL0, on ?
|
||||||
@ -2020,18 +2035,21 @@ static int ov5640_set_power_dvp(struct ov5640_dev *sensor, bool on)
|
|||||||
* datasheet and hardware, 0 is active high
|
* datasheet and hardware, 0 is active high
|
||||||
* and 1 is active low...)
|
* and 1 is active low...)
|
||||||
*/
|
*/
|
||||||
if (flags & V4L2_MBUS_PCLK_SAMPLE_RISING)
|
if (sensor->ep.bus_type == V4L2_MBUS_PARALLEL) {
|
||||||
pclk_pol = 1;
|
if (flags & V4L2_MBUS_PCLK_SAMPLE_RISING)
|
||||||
if (flags & V4L2_MBUS_HSYNC_ACTIVE_HIGH)
|
pclk_pol = 1;
|
||||||
hsync_pol = 1;
|
if (flags & V4L2_MBUS_HSYNC_ACTIVE_HIGH)
|
||||||
if (flags & V4L2_MBUS_VSYNC_ACTIVE_LOW)
|
hsync_pol = 1;
|
||||||
vsync_pol = 1;
|
if (flags & V4L2_MBUS_VSYNC_ACTIVE_LOW)
|
||||||
|
vsync_pol = 1;
|
||||||
|
|
||||||
ret = ov5640_write_reg(sensor, OV5640_REG_POLARITY_CTRL00,
|
ret = ov5640_write_reg(sensor, OV5640_REG_POLARITY_CTRL00,
|
||||||
(pclk_pol << 5) | (hsync_pol << 1) | vsync_pol);
|
(pclk_pol << 5) | (hsync_pol << 1) |
|
||||||
|
vsync_pol);
|
||||||
|
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* powerdown MIPI TX/RX PHY & disable MIPI
|
* powerdown MIPI TX/RX PHY & disable MIPI
|
||||||
@ -2055,7 +2073,9 @@ static int ov5640_set_power_dvp(struct ov5640_dev *sensor, bool on)
|
|||||||
* - 4: PCLK output enable
|
* - 4: PCLK output enable
|
||||||
* - [3:0]: D[9:6] output enable
|
* - [3:0]: D[9:6] output enable
|
||||||
*/
|
*/
|
||||||
ret = ov5640_write_reg(sensor, OV5640_REG_PAD_OUTPUT_ENABLE01, 0x7f);
|
ret = ov5640_write_reg(sensor, OV5640_REG_PAD_OUTPUT_ENABLE01,
|
||||||
|
sensor->ep.bus_type == V4L2_MBUS_PARALLEL ?
|
||||||
|
0x7f : 0x1f);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
@ -2905,6 +2925,8 @@ static int ov5640_s_stream(struct v4l2_subdev *sd, int enable)
|
|||||||
|
|
||||||
if (sensor->ep.bus_type == V4L2_MBUS_CSI2_DPHY)
|
if (sensor->ep.bus_type == V4L2_MBUS_CSI2_DPHY)
|
||||||
ret = ov5640_set_stream_mipi(sensor, enable);
|
ret = ov5640_set_stream_mipi(sensor, enable);
|
||||||
|
else if (sensor->ep.bus_type == V4L2_MBUS_BT656)
|
||||||
|
ret = ov5640_set_stream_bt656(sensor, enable);
|
||||||
else
|
else
|
||||||
ret = ov5640_set_stream_dvp(sensor, enable);
|
ret = ov5640_set_stream_dvp(sensor, enable);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user