aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/omap3isp
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2011-08-31 09:53:41 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2012-08-11 15:02:01 -0400
commit73ea57eb5442aece696a7a03e2cd4509d38e55fd (patch)
tree04d48cc7bf37d6e3ca617820d3ed1a10c74c54e8 /drivers/media/video/omap3isp
parentcf7a3d91ade6c56bfd860b377f84bd58132f7a81 (diff)
[media] omap3isp: ccdc: Remove ispccdc_syncif structure
The structure is only used to store configuration data and pass it to CCDC configuration functions. Access the data directly from the locations that need it. Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Acked-by: Sakari Ailus <sakari.ailus@iki.fi> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/omap3isp')
-rw-r--r--drivers/media/video/omap3isp/ispccdc.c38
-rw-r--r--drivers/media/video/omap3isp/ispccdc.h19
2 files changed, 17 insertions, 40 deletions
diff --git a/drivers/media/video/omap3isp/ispccdc.c b/drivers/media/video/omap3isp/ispccdc.c
index 8dbb55a92fcf..c58b0c68ce36 100644
--- a/drivers/media/video/omap3isp/ispccdc.c
+++ b/drivers/media/video/omap3isp/ispccdc.c
@@ -627,9 +627,12 @@ static void ccdc_configure_lpf(struct isp_ccdc_device *ccdc)
627static void ccdc_configure_alaw(struct isp_ccdc_device *ccdc) 627static void ccdc_configure_alaw(struct isp_ccdc_device *ccdc)
628{ 628{
629 struct isp_device *isp = to_isp_device(ccdc); 629 struct isp_device *isp = to_isp_device(ccdc);
630 const struct isp_format_info *info;
630 u32 alaw = 0; 631 u32 alaw = 0;
631 632
632 switch (ccdc->syncif.datsz) { 633 info = omap3isp_video_format_info(ccdc->formats[CCDC_PAD_SINK].code);
634
635 switch (info->width) {
633 case 8: 636 case 8:
634 return; 637 return;
635 638
@@ -813,6 +816,7 @@ static void ccdc_config_vp(struct isp_ccdc_device *ccdc)
813{ 816{
814 struct isp_pipeline *pipe = to_isp_pipeline(&ccdc->subdev.entity); 817 struct isp_pipeline *pipe = to_isp_pipeline(&ccdc->subdev.entity);
815 struct isp_device *isp = to_isp_device(ccdc); 818 struct isp_device *isp = to_isp_device(ccdc);
819 const struct isp_format_info *info;
816 unsigned long l3_ick = pipe->l3_ick; 820 unsigned long l3_ick = pipe->l3_ick;
817 unsigned int max_div = isp->revision == ISP_REVISION_15_0 ? 64 : 8; 821 unsigned int max_div = isp->revision == ISP_REVISION_15_0 ? 64 : 8;
818 unsigned int div = 0; 822 unsigned int div = 0;
@@ -821,7 +825,9 @@ static void ccdc_config_vp(struct isp_ccdc_device *ccdc)
821 fmtcfg_vp = isp_reg_readl(isp, OMAP3_ISP_IOMEM_CCDC, ISPCCDC_FMTCFG) 825 fmtcfg_vp = isp_reg_readl(isp, OMAP3_ISP_IOMEM_CCDC, ISPCCDC_FMTCFG)
822 & ~(ISPCCDC_FMTCFG_VPIN_MASK | ISPCCDC_FMTCFG_VPIF_FRQ_MASK); 826 & ~(ISPCCDC_FMTCFG_VPIN_MASK | ISPCCDC_FMTCFG_VPIF_FRQ_MASK);
823 827
824 switch (ccdc->syncif.datsz) { 828 info = omap3isp_video_format_info(ccdc->formats[CCDC_PAD_SINK].code);
829
830 switch (info->width) {
825 case 8: 831 case 8:
826 case 10: 832 case 10:
827 fmtcfg_vp |= ISPCCDC_FMTCFG_VPIN_9_0; 833 fmtcfg_vp |= ISPCCDC_FMTCFG_VPIN_9_0;
@@ -959,17 +965,17 @@ void omap3isp_ccdc_max_rate(struct isp_ccdc_device *ccdc,
959/* 965/*
960 * ccdc_config_sync_if - Set CCDC sync interface configuration 966 * ccdc_config_sync_if - Set CCDC sync interface configuration
961 * @ccdc: Pointer to ISP CCDC device. 967 * @ccdc: Pointer to ISP CCDC device.
962 * @syncif: Structure containing the sync parameters like field state, CCDC in 968 * @pdata: Parallel interface platform data (may be NULL)
963 * master/slave mode, raw/yuv data, polarity of data, field, hs, vs 969 * @data_size: Data size
964 * signals.
965 */ 970 */
966static void ccdc_config_sync_if(struct isp_ccdc_device *ccdc, 971static void ccdc_config_sync_if(struct isp_ccdc_device *ccdc,
967 struct ispccdc_syncif *syncif) 972 struct isp_parallel_platform_data *pdata,
973 unsigned int data_size)
968{ 974{
969 struct isp_device *isp = to_isp_device(ccdc); 975 struct isp_device *isp = to_isp_device(ccdc);
970 u32 syn_mode = ISPCCDC_SYN_MODE_VDHDEN; 976 u32 syn_mode = ISPCCDC_SYN_MODE_VDHDEN;
971 977
972 switch (syncif->datsz) { 978 switch (data_size) {
973 case 8: 979 case 8:
974 syn_mode |= ISPCCDC_SYN_MODE_DATSIZ_8; 980 syn_mode |= ISPCCDC_SYN_MODE_DATSIZ_8;
975 break; 981 break;
@@ -984,20 +990,16 @@ static void ccdc_config_sync_if(struct isp_ccdc_device *ccdc,
984 break; 990 break;
985 } 991 }
986 992
987 if (syncif->datapol) 993 if (pdata && pdata->data_pol)
988 syn_mode |= ISPCCDC_SYN_MODE_DATAPOL; 994 syn_mode |= ISPCCDC_SYN_MODE_DATAPOL;
989 995
990 if (syncif->hdpol) 996 if (pdata && pdata->hs_pol)
991 syn_mode |= ISPCCDC_SYN_MODE_HDPOL; 997 syn_mode |= ISPCCDC_SYN_MODE_HDPOL;
992 998
993 if (syncif->vdpol) 999 if (pdata && pdata->vs_pol)
994 syn_mode |= ISPCCDC_SYN_MODE_VDPOL; 1000 syn_mode |= ISPCCDC_SYN_MODE_VDPOL;
995 1001
996 isp_reg_writel(isp, syn_mode, OMAP3_ISP_IOMEM_CCDC, ISPCCDC_SYN_MODE); 1002 isp_reg_writel(isp, syn_mode, OMAP3_ISP_IOMEM_CCDC, ISPCCDC_SYN_MODE);
997
998 if (!syncif->bt_r656_en)
999 isp_reg_clr(isp, OMAP3_ISP_IOMEM_CCDC, ISPCCDC_REC656IF,
1000 ISPCCDC_REC656IF_R656ON);
1001} 1003}
1002 1004
1003/* CCDC formats descriptions */ 1005/* CCDC formats descriptions */
@@ -1111,11 +1113,7 @@ static void ccdc_configure(struct isp_ccdc_device *ccdc)
1111 shift = depth_in - depth_out; 1113 shift = depth_in - depth_out;
1112 omap3isp_configure_bridge(isp, ccdc->input, pdata, shift); 1114 omap3isp_configure_bridge(isp, ccdc->input, pdata, shift);
1113 1115
1114 ccdc->syncif.datsz = depth_out; 1116 ccdc_config_sync_if(ccdc, pdata, depth_out);
1115 ccdc->syncif.datapol = 0;
1116 ccdc->syncif.hdpol = pdata ? pdata->hs_pol : 0;
1117 ccdc->syncif.vdpol = pdata ? pdata->vs_pol : 0;
1118 ccdc_config_sync_if(ccdc, &ccdc->syncif);
1119 1117
1120 /* CCDC_PAD_SINK */ 1118 /* CCDC_PAD_SINK */
1121 format = &ccdc->formats[CCDC_PAD_SINK]; 1119 format = &ccdc->formats[CCDC_PAD_SINK];
@@ -2446,8 +2444,6 @@ int omap3isp_ccdc_init(struct isp_device *isp)
2446 INIT_LIST_HEAD(&ccdc->lsc.free_queue); 2444 INIT_LIST_HEAD(&ccdc->lsc.free_queue);
2447 spin_lock_init(&ccdc->lsc.req_lock); 2445 spin_lock_init(&ccdc->lsc.req_lock);
2448 2446
2449 ccdc->syncif.datsz = 0;
2450
2451 ccdc->clamp.oblen = 0; 2447 ccdc->clamp.oblen = 0;
2452 ccdc->clamp.dcsubval = 0; 2448 ccdc->clamp.dcsubval = 0;
2453 2449
diff --git a/drivers/media/video/omap3isp/ispccdc.h b/drivers/media/video/omap3isp/ispccdc.h
index 57007d7b2d56..a5da9e19edbf 100644
--- a/drivers/media/video/omap3isp/ispccdc.h
+++ b/drivers/media/video/omap3isp/ispccdc.h
@@ -46,22 +46,6 @@ enum ccdc_input_entity {
46 46
47#define OMAP3ISP_CCDC_NEVENTS 16 47#define OMAP3ISP_CCDC_NEVENTS 16
48 48
49/*
50 * struct ispccdc_syncif - Structure for Sync Interface between sensor and CCDC
51 * @datsz: Data size.
52 * @datapol: 0 - Positive, 1 - Negative.
53 * @hdpol: 0 - Positive, 1 - Negative.
54 * @vdpol: 0 - Positive, 1 - Negative.
55 * @bt_r656_en: 1 - Enable ITU-R BT656 mode, 0 - Sync mode.
56 */
57struct ispccdc_syncif {
58 u8 datsz;
59 u8 datapol;
60 u8 hdpol;
61 u8 vdpol;
62 u8 bt_r656_en;
63};
64
65enum ispccdc_lsc_state { 49enum ispccdc_lsc_state {
66 LSC_STATE_STOPPED = 0, 50 LSC_STATE_STOPPED = 0,
67 LSC_STATE_STOPPING = 1, 51 LSC_STATE_STOPPING = 1,
@@ -135,7 +119,6 @@ struct ispccdc_lsc {
135 * @lsc: Lens shading compensation configuration 119 * @lsc: Lens shading compensation configuration
136 * @update: Bitmask of controls to update during the next interrupt 120 * @update: Bitmask of controls to update during the next interrupt
137 * @shadow_update: Controls update in progress by userspace 121 * @shadow_update: Controls update in progress by userspace
138 * @syncif: Interface synchronization configuration
139 * @underrun: A buffer underrun occurred and a new buffer has been queued 122 * @underrun: A buffer underrun occurred and a new buffer has been queued
140 * @state: Streaming state 123 * @state: Streaming state
141 * @lock: Serializes shadow_update with interrupt handler 124 * @lock: Serializes shadow_update with interrupt handler
@@ -164,8 +147,6 @@ struct isp_ccdc_device {
164 unsigned int update; 147 unsigned int update;
165 unsigned int shadow_update; 148 unsigned int shadow_update;
166 149
167 struct ispccdc_syncif syncif;
168
169 unsigned int underrun:1; 150 unsigned int underrun:1;
170 enum isp_pipeline_stream_state state; 151 enum isp_pipeline_stream_state state;
171 spinlock_t lock; 152 spinlock_t lock;