From: Lad, Prabhakar <[email protected]>

channel_first_int[][] variable is used as a flag for the ISR,
This flag was being set after enabling the interrupts, There
where situations when the isr occurred even before the flag was set
due to which it was causing the application hang.
This patch sets channel_first_int[][] flag just before enabling the
interrupt.

Reported-by: David Oleszkiewicz <[email protected]>
Signed-off-by: Lad, Prabhakar <[email protected]>
Signed-off-by: Manjunath Hadli <[email protected]>
Cc: Hans Verkuil <[email protected]>
---
 Changes for v2:
 1: Fixed typo's in description.

 drivers/media/platform/davinci/vpif_capture.c |    2 +-
 drivers/media/platform/davinci/vpif_display.c |    2 +-
 2 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/media/platform/davinci/vpif_capture.c 
b/drivers/media/platform/davinci/vpif_capture.c
index 1b625b0..f64919b 100644
--- a/drivers/media/platform/davinci/vpif_capture.c
+++ b/drivers/media/platform/davinci/vpif_capture.c
@@ -339,6 +339,7 @@ static int vpif_start_streaming(struct vb2_queue *vq, 
unsigned int count)
         * Set interrupt for both the fields in VPIF Register enable channel in
         * VPIF register
         */
+       channel_first_int[VPIF_VIDEO_INDEX][ch->channel_id] = 1;
        if ((VPIF_CHANNEL0_VIDEO == ch->channel_id)) {
                channel0_intr_assert();
                channel0_intr_enable(1);
@@ -350,7 +351,6 @@ static int vpif_start_streaming(struct vb2_queue *vq, 
unsigned int count)
                channel1_intr_enable(1);
                enable_channel1(1);
        }
-       channel_first_int[VPIF_VIDEO_INDEX][ch->channel_id] = 1;
 
        return 0;
 }
diff --git a/drivers/media/platform/davinci/vpif_display.c 
b/drivers/media/platform/davinci/vpif_display.c
index 4a24848..523a840 100644
--- a/drivers/media/platform/davinci/vpif_display.c
+++ b/drivers/media/platform/davinci/vpif_display.c
@@ -302,6 +302,7 @@ static int vpif_start_streaming(struct vb2_queue *vq, 
unsigned int count)
 
        /* Set interrupt for both the fields in VPIF
            Register enable channel in VPIF register */
+       channel_first_int[VPIF_VIDEO_INDEX][ch->channel_id] = 1;
        if (VPIF_CHANNEL2_VIDEO == ch->channel_id) {
                channel2_intr_assert();
                channel2_intr_enable(1);
@@ -318,7 +319,6 @@ static int vpif_start_streaming(struct vb2_queue *vq, 
unsigned int count)
                if (vpif_config_data->ch3_clip_en)
                        channel3_clipping_enable(1);
        }
-       channel_first_int[VPIF_VIDEO_INDEX][ch->channel_id] = 1;
 
        return 0;
 }
-- 
1.7.0.4

_______________________________________________
Davinci-linux-open-source mailing list
[email protected]
http://linux.davincidsp.com/mailman/listinfo/davinci-linux-open-source

Reply via email to