提交 af15d025 编写于 作者: L Laurent Pinchart 提交者: Mauro Carvalho Chehab

[media] v4l: omap4iss: Enable/disabling the ISP interrupts globally

ISP interrupts are enabled/disabled when starting/stopping the IPIPEIF
or resizer. This doesn't permit using the two modules in separate
pipelines. Fix it by enabling/disabling the ISP interrupts at the same
time as the ISS interrupts, in the ISS device get/put operations.
Signed-off-by: NLaurent Pinchart <laurent.pinchart@ideasonboard.com>
Signed-off-by: NMauro Carvalho Chehab <m.chehab@samsung.com>
上级 6016498f
...@@ -67,53 +67,59 @@ void omap4iss_flush(struct iss_device *iss) ...@@ -67,53 +67,59 @@ void omap4iss_flush(struct iss_device *iss)
} }
/* /*
* iss_enable_interrupts - Enable ISS interrupts. * iss_isp_enable_interrupts - Enable ISS ISP interrupts.
* @iss: OMAP4 ISS device * @iss: OMAP4 ISS device
*/ */
static void iss_enable_interrupts(struct iss_device *iss) static void omap4iss_isp_enable_interrupts(struct iss_device *iss)
{ {
static const u32 hl_irq = ISS_HL_IRQ_CSIA | ISS_HL_IRQ_CSIB | ISS_HL_IRQ_ISP(0); static const u32 isp_irq = ISP5_IRQ_OCP_ERR |
ISP5_IRQ_RSZ_FIFO_IN_BLK_ERR |
/* Enable HL interrupts */ ISP5_IRQ_RSZ_FIFO_OVF |
iss_reg_write(iss, OMAP4_ISS_MEM_TOP, ISS_HL_IRQSTATUS(5), hl_irq); ISP5_IRQ_RSZ_INT_DMA |
iss_reg_write(iss, OMAP4_ISS_MEM_TOP, ISS_HL_IRQENABLE_SET(5), hl_irq); ISP5_IRQ_ISIF_INT(0);
/* Enable ISP interrupts */
iss_reg_write(iss, OMAP4_ISS_MEM_ISP_SYS1, ISP5_IRQSTATUS(0), isp_irq);
iss_reg_write(iss, OMAP4_ISS_MEM_ISP_SYS1, ISP5_IRQENABLE_SET(0),
isp_irq);
} }
/* /*
* iss_disable_interrupts - Disable ISS interrupts. * iss_isp_disable_interrupts - Disable ISS interrupts.
* @iss: OMAP4 ISS device * @iss: OMAP4 ISS device
*/ */
static void iss_disable_interrupts(struct iss_device *iss) static void omap4iss_isp_disable_interrupts(struct iss_device *iss)
{ {
iss_reg_write(iss, OMAP4_ISS_MEM_TOP, ISS_HL_IRQENABLE_CLR(5), -1); iss_reg_write(iss, OMAP4_ISS_MEM_ISP_SYS1, ISP5_IRQENABLE_CLR(0), ~0);
} }
/* /*
* iss_isp_enable_interrupts - Enable ISS ISP interrupts. * iss_enable_interrupts - Enable ISS interrupts.
* @iss: OMAP4 ISS device * @iss: OMAP4 ISS device
*/ */
void omap4iss_isp_enable_interrupts(struct iss_device *iss) static void iss_enable_interrupts(struct iss_device *iss)
{ {
static const u32 isp_irq = ISP5_IRQ_OCP_ERR | static const u32 hl_irq = ISS_HL_IRQ_CSIA | ISS_HL_IRQ_CSIB
ISP5_IRQ_RSZ_FIFO_IN_BLK_ERR | | ISS_HL_IRQ_ISP(0);
ISP5_IRQ_RSZ_FIFO_OVF |
ISP5_IRQ_RSZ_INT_DMA |
ISP5_IRQ_ISIF_INT(0);
/* Enable ISP interrupts */ /* Enable HL interrupts */
iss_reg_write(iss, OMAP4_ISS_MEM_ISP_SYS1, ISP5_IRQSTATUS(0), isp_irq); iss_reg_write(iss, OMAP4_ISS_MEM_TOP, ISS_HL_IRQSTATUS(5), hl_irq);
iss_reg_write(iss, OMAP4_ISS_MEM_ISP_SYS1, ISP5_IRQENABLE_SET(0), iss_reg_write(iss, OMAP4_ISS_MEM_TOP, ISS_HL_IRQENABLE_SET(5), hl_irq);
isp_irq);
if (iss->regs[OMAP4_ISS_MEM_ISP_SYS1])
omap4iss_isp_enable_interrupts(iss);
} }
/* /*
* iss_isp_disable_interrupts - Disable ISS interrupts. * iss_disable_interrupts - Disable ISS interrupts.
* @iss: OMAP4 ISS device * @iss: OMAP4 ISS device
*/ */
void omap4iss_isp_disable_interrupts(struct iss_device *iss) static void iss_disable_interrupts(struct iss_device *iss)
{ {
iss_reg_write(iss, OMAP4_ISS_MEM_ISP_SYS1, ISP5_IRQENABLE_CLR(0), -1); if (iss->regs[OMAP4_ISS_MEM_ISP_SYS1])
omap4iss_isp_disable_interrupts(iss);
iss_reg_write(iss, OMAP4_ISS_MEM_TOP, ISS_HL_IRQENABLE_CLR(5), ~0);
} }
int omap4iss_get_external_info(struct iss_pipeline *pipe, int omap4iss_get_external_info(struct iss_pipeline *pipe,
......
...@@ -141,9 +141,6 @@ void omap4iss_isp_subclk_enable(struct iss_device *iss, ...@@ -141,9 +141,6 @@ void omap4iss_isp_subclk_enable(struct iss_device *iss,
void omap4iss_isp_subclk_disable(struct iss_device *iss, void omap4iss_isp_subclk_disable(struct iss_device *iss,
enum iss_isp_subclk_resource res); enum iss_isp_subclk_resource res);
void omap4iss_isp_enable_interrupts(struct iss_device *iss);
void omap4iss_isp_disable_interrupts(struct iss_device *iss);
int omap4iss_pipeline_pm_use(struct media_entity *entity, int use); int omap4iss_pipeline_pm_use(struct media_entity *entity, int use);
int omap4iss_register_entities(struct platform_device *pdev, int omap4iss_register_entities(struct platform_device *pdev,
......
...@@ -116,8 +116,6 @@ static void ipipe_configure(struct iss_ipipe_device *ipipe) ...@@ -116,8 +116,6 @@ static void ipipe_configure(struct iss_ipipe_device *ipipe)
/* IPIPE_PAD_SOURCE_VP */ /* IPIPE_PAD_SOURCE_VP */
format = &ipipe->formats[IPIPE_PAD_SOURCE_VP]; format = &ipipe->formats[IPIPE_PAD_SOURCE_VP];
/* Do nothing? */ /* Do nothing? */
omap4iss_isp_enable_interrupts(iss);
} }
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
...@@ -169,7 +167,6 @@ static int ipipe_set_stream(struct v4l2_subdev *sd, int enable) ...@@ -169,7 +167,6 @@ static int ipipe_set_stream(struct v4l2_subdev *sd, int enable)
ret = -ETIMEDOUT; ret = -ETIMEDOUT;
ipipe_enable(ipipe, 0); ipipe_enable(ipipe, 0);
omap4iss_isp_disable_interrupts(iss);
omap4iss_isp_subclk_disable(iss, OMAP4_ISS_ISP_SUBCLK_IPIPE); omap4iss_isp_subclk_disable(iss, OMAP4_ISS_ISP_SUBCLK_IPIPE);
break; break;
} }
......
...@@ -213,8 +213,6 @@ static void ipipeif_configure(struct iss_ipipeif_device *ipipeif) ...@@ -213,8 +213,6 @@ static void ipipeif_configure(struct iss_ipipeif_device *ipipeif)
/* IPIPEIF_PAD_SOURCE_VP */ /* IPIPEIF_PAD_SOURCE_VP */
/* Do nothing? */ /* Do nothing? */
omap4iss_isp_enable_interrupts(iss);
} }
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
...@@ -368,7 +366,6 @@ static int ipipeif_set_stream(struct v4l2_subdev *sd, int enable) ...@@ -368,7 +366,6 @@ static int ipipeif_set_stream(struct v4l2_subdev *sd, int enable)
if (ipipeif->output & IPIPEIF_OUTPUT_MEMORY) if (ipipeif->output & IPIPEIF_OUTPUT_MEMORY)
ipipeif_write_enable(ipipeif, 0); ipipeif_write_enable(ipipeif, 0);
ipipeif_enable(ipipeif, 0); ipipeif_enable(ipipeif, 0);
omap4iss_isp_disable_interrupts(iss);
omap4iss_isp_subclk_disable(iss, IPIPEIF_DRV_SUBCLK_MASK); omap4iss_isp_subclk_disable(iss, IPIPEIF_DRV_SUBCLK_MASK);
iss_video_dmaqueue_flags_clr(video_out); iss_video_dmaqueue_flags_clr(video_out);
break; break;
......
...@@ -256,8 +256,6 @@ static void resizer_configure(struct iss_resizer_device *resizer) ...@@ -256,8 +256,6 @@ static void resizer_configure(struct iss_resizer_device *resizer)
} else { } else {
iss_reg_write(iss, OMAP4_ISS_MEM_ISP_RESIZER, RZA_420, 0); iss_reg_write(iss, OMAP4_ISS_MEM_ISP_RESIZER, RZA_420, 0);
} }
omap4iss_isp_enable_interrupts(iss);
} }
/* ----------------------------------------------------------------------------- /* -----------------------------------------------------------------------------
...@@ -419,7 +417,6 @@ static int resizer_set_stream(struct v4l2_subdev *sd, int enable) ...@@ -419,7 +417,6 @@ static int resizer_set_stream(struct v4l2_subdev *sd, int enable)
ret = -ETIMEDOUT; ret = -ETIMEDOUT;
resizer_enable(resizer, 0); resizer_enable(resizer, 0);
omap4iss_isp_disable_interrupts(iss);
iss_reg_clr(iss, OMAP4_ISS_MEM_ISP_RESIZER, RSZ_SYSCONFIG, iss_reg_clr(iss, OMAP4_ISS_MEM_ISP_RESIZER, RSZ_SYSCONFIG,
RSZ_SYSCONFIG_RSZA_CLK_EN); RSZ_SYSCONFIG_RSZA_CLK_EN);
iss_reg_clr(iss, OMAP4_ISS_MEM_ISP_RESIZER, RSZ_GCK_SDR, iss_reg_clr(iss, OMAP4_ISS_MEM_ISP_RESIZER, RSZ_GCK_SDR,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册