aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/omap3isp/ispccdc.c
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/ispccdc.c
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/ispccdc.c')
-rw-r--r--drivers/media/video/omap3isp/ispccdc.c38
1 files changed, 17 insertions, 21 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