media: sun4i-csi: Fix data sampling polarity handling
authorChen-Yu Tsai <wens@csie.org>
Sun, 15 Dec 2019 16:59:13 +0000 (17:59 +0100)
committerMauro Carvalho Chehab <mchehab+huawei@kernel.org>
Sat, 4 Jan 2020 07:17:14 +0000 (08:17 +0100)
The CLK_POL field specifies whether data is sampled on the falling or
rising edge of PCLK, not whether the data lines are active high or low.
Evidence of this can be found in the timing diagram labeled "horizontal
size setting and pixel clock timing".

Fix the setting by checking the correct flag, V4L2_MBUS_PCLK_SAMPLE_RISING.
While at it, reorder the three polarity flag checks so HSYNC and VSYNC
are grouped together.

Fixes: 577bbf23b758 ("media: sunxi: Add A10 CSI driver")
Signed-off-by: Chen-Yu Tsai <wens@csie.org>
Acked-by: Maxime Ripard <mripard@kernel.org>
Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
drivers/media/platform/sunxi/sun4i-csi/sun4i_dma.c

index d6979e1..8b567d0 100644 (file)
@@ -279,8 +279,8 @@ static int sun4i_csi_start_streaming(struct vb2_queue *vq, unsigned int count)
               csi->regs + CSI_WIN_CTRL_H_REG);
 
        hsync_pol = !!(bus->flags & V4L2_MBUS_HSYNC_ACTIVE_HIGH);
-       pclk_pol = !!(bus->flags & V4L2_MBUS_DATA_ACTIVE_HIGH);
        vsync_pol = !!(bus->flags & V4L2_MBUS_VSYNC_ACTIVE_HIGH);
+       pclk_pol = !!(bus->flags & V4L2_MBUS_PCLK_SAMPLE_RISING);
        writel(CSI_CFG_INPUT_FMT(csi_fmt->input) |
               CSI_CFG_OUTPUT_FMT(csi_fmt->output) |
               CSI_CFG_VSYNC_POL(vsync_pol) |