V4L/DVB (10665): soc-camera: add data signal polarity flags to drivers
All soc-camera camera and host drivers must specify supported data signal polarity, after all drivers are fixed, we'll add a suitable test to soc_camera_bus_param_compatible(). Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@gmx.de> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
parent
8420fa7ee2
commit
2d9329f3a5
|
@ -310,7 +310,8 @@ static struct platform_device camera_device = {
|
||||||
|
|
||||||
static struct sh_mobile_ceu_info sh_mobile_ceu_info = {
|
static struct sh_mobile_ceu_info sh_mobile_ceu_info = {
|
||||||
.flags = SOCAM_PCLK_SAMPLE_RISING | SOCAM_HSYNC_ACTIVE_HIGH |
|
.flags = SOCAM_PCLK_SAMPLE_RISING | SOCAM_HSYNC_ACTIVE_HIGH |
|
||||||
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_MASTER | SOCAM_DATAWIDTH_8,
|
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_DATA_ACTIVE_HIGH | SOCAM_MASTER |
|
||||||
|
SOCAM_DATAWIDTH_8,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct resource ceu_resources[] = {
|
static struct resource ceu_resources[] = {
|
||||||
|
|
|
@ -352,8 +352,9 @@ static int tw9910_power(struct device *dev, int mode)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sh_mobile_ceu_info sh_mobile_ceu_info = {
|
static struct sh_mobile_ceu_info sh_mobile_ceu_info = {
|
||||||
.flags = SOCAM_MASTER | SOCAM_DATAWIDTH_8 | SOCAM_PCLK_SAMPLE_RISING \
|
.flags = SOCAM_MASTER | SOCAM_DATAWIDTH_8 | SOCAM_PCLK_SAMPLE_RISING
|
||||||
| SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_HIGH,
|
| SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_HIGH
|
||||||
|
| SOCAM_DATA_ACTIVE_HIGH,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct resource migor_ceu_resources[] = {
|
static struct resource migor_ceu_resources[] = {
|
||||||
|
|
|
@ -276,7 +276,7 @@ static unsigned long mt9m001_query_bus_param(struct soc_camera_device *icd)
|
||||||
/* MT9M001 has all capture_format parameters fixed */
|
/* MT9M001 has all capture_format parameters fixed */
|
||||||
unsigned long flags = SOCAM_DATAWIDTH_10 | SOCAM_PCLK_SAMPLE_RISING |
|
unsigned long flags = SOCAM_DATAWIDTH_10 | SOCAM_PCLK_SAMPLE_RISING |
|
||||||
SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_HIGH |
|
SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_HIGH |
|
||||||
SOCAM_MASTER;
|
SOCAM_DATA_ACTIVE_HIGH | SOCAM_MASTER;
|
||||||
|
|
||||||
if (bus_switch_possible(mt9m001))
|
if (bus_switch_possible(mt9m001))
|
||||||
flags |= SOCAM_DATAWIDTH_8;
|
flags |= SOCAM_DATAWIDTH_8;
|
||||||
|
|
|
@ -420,7 +420,7 @@ static unsigned long mt9m111_query_bus_param(struct soc_camera_device *icd)
|
||||||
struct soc_camera_link *icl = mt9m111->client->dev.platform_data;
|
struct soc_camera_link *icl = mt9m111->client->dev.platform_data;
|
||||||
unsigned long flags = SOCAM_MASTER | SOCAM_PCLK_SAMPLE_RISING |
|
unsigned long flags = SOCAM_MASTER | SOCAM_PCLK_SAMPLE_RISING |
|
||||||
SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_HIGH |
|
SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_HIGH |
|
||||||
SOCAM_DATAWIDTH_8;
|
SOCAM_DATA_ACTIVE_HIGH | SOCAM_DATAWIDTH_8;
|
||||||
|
|
||||||
return soc_camera_apply_sensor_flags(icl, flags);
|
return soc_camera_apply_sensor_flags(icl, flags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -336,7 +336,7 @@ static unsigned long mt9v022_query_bus_param(struct soc_camera_device *icd)
|
||||||
return SOCAM_PCLK_SAMPLE_RISING | SOCAM_PCLK_SAMPLE_FALLING |
|
return SOCAM_PCLK_SAMPLE_RISING | SOCAM_PCLK_SAMPLE_FALLING |
|
||||||
SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_HSYNC_ACTIVE_LOW |
|
SOCAM_HSYNC_ACTIVE_HIGH | SOCAM_HSYNC_ACTIVE_LOW |
|
||||||
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_LOW |
|
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_VSYNC_ACTIVE_LOW |
|
||||||
SOCAM_MASTER | SOCAM_SLAVE |
|
SOCAM_DATA_ACTIVE_HIGH | SOCAM_MASTER | SOCAM_SLAVE |
|
||||||
width_flag;
|
width_flag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -718,7 +718,7 @@ static unsigned long ov772x_query_bus_param(struct soc_camera_device *icd)
|
||||||
struct soc_camera_link *icl = priv->client->dev.platform_data;
|
struct soc_camera_link *icl = priv->client->dev.platform_data;
|
||||||
unsigned long flags = SOCAM_PCLK_SAMPLE_RISING | SOCAM_MASTER |
|
unsigned long flags = SOCAM_PCLK_SAMPLE_RISING | SOCAM_MASTER |
|
||||||
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_HSYNC_ACTIVE_HIGH |
|
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_HSYNC_ACTIVE_HIGH |
|
||||||
priv->info->buswidth;
|
SOCAM_DATA_ACTIVE_HIGH | priv->info->buswidth;
|
||||||
|
|
||||||
return soc_camera_apply_sensor_flags(icl, flags);
|
return soc_camera_apply_sensor_flags(icl, flags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -878,6 +878,7 @@ static int test_platform_param(struct pxa_camera_dev *pcdev,
|
||||||
SOCAM_HSYNC_ACTIVE_LOW |
|
SOCAM_HSYNC_ACTIVE_LOW |
|
||||||
SOCAM_VSYNC_ACTIVE_HIGH |
|
SOCAM_VSYNC_ACTIVE_HIGH |
|
||||||
SOCAM_VSYNC_ACTIVE_LOW |
|
SOCAM_VSYNC_ACTIVE_LOW |
|
||||||
|
SOCAM_DATA_ACTIVE_HIGH |
|
||||||
SOCAM_PCLK_SAMPLE_RISING |
|
SOCAM_PCLK_SAMPLE_RISING |
|
||||||
SOCAM_PCLK_SAMPLE_FALLING;
|
SOCAM_PCLK_SAMPLE_FALLING;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue