]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
media: sun8i-di: Fix coefficient writes
authorJernej Skrabec <jernej.skrabec@gmail.com>
Sat, 16 Dec 2023 13:34:20 +0000 (14:34 +0100)
committerSasha Levin <sashal@kernel.org>
Tue, 26 Mar 2024 22:21:57 +0000 (18:21 -0400)
[ Upstream commit 794b581f8c6eb7b60fe468ccb96dd3cd38ff779f ]

Currently coefficients are applied only once, since they don't change.
However, this is done before enable bit is set and thus it doesn't get
applied properly.

Fix that by applying coefficients after enable bit is set. While this
means that it will be done evey time, it doesn't bring much time
penalty.

Fixes: a4260ea49547 ("media: sun4i: Add H3 deinterlace driver")
Signed-off-by: Jernej Skrabec <jernej.skrabec@gmail.com>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/media/platform/sunxi/sun8i-di/sun8i-di.c

index 2c159483c56bacb9f8e4f08f6b375cfc81c64b65..a9d3272940be0641ac55e29490ea694da8604c9d 100644 (file)
@@ -66,6 +66,7 @@ static void deinterlace_device_run(void *priv)
        struct vb2_v4l2_buffer *src, *dst;
        unsigned int hstep, vstep;
        dma_addr_t addr;
+       int i;
 
        src = v4l2_m2m_next_src_buf(ctx->fh.m2m_ctx);
        dst = v4l2_m2m_next_dst_buf(ctx->fh.m2m_ctx);
@@ -160,6 +161,26 @@ static void deinterlace_device_run(void *priv)
        deinterlace_write(dev, DEINTERLACE_CH1_HORZ_FACT, hstep);
        deinterlace_write(dev, DEINTERLACE_CH1_VERT_FACT, vstep);
 
+       /* neutral filter coefficients */
+       deinterlace_set_bits(dev, DEINTERLACE_FRM_CTRL,
+                            DEINTERLACE_FRM_CTRL_COEF_ACCESS);
+       readl_poll_timeout(dev->base + DEINTERLACE_STATUS, val,
+                          val & DEINTERLACE_STATUS_COEF_STATUS, 2, 40);
+
+       for (i = 0; i < 32; i++) {
+               deinterlace_write(dev, DEINTERLACE_CH0_HORZ_COEF0 + i * 4,
+                                 DEINTERLACE_IDENTITY_COEF);
+               deinterlace_write(dev, DEINTERLACE_CH0_VERT_COEF + i * 4,
+                                 DEINTERLACE_IDENTITY_COEF);
+               deinterlace_write(dev, DEINTERLACE_CH1_HORZ_COEF0 + i * 4,
+                                 DEINTERLACE_IDENTITY_COEF);
+               deinterlace_write(dev, DEINTERLACE_CH1_VERT_COEF + i * 4,
+                                 DEINTERLACE_IDENTITY_COEF);
+       }
+
+       deinterlace_clr_set_bits(dev, DEINTERLACE_FRM_CTRL,
+                                DEINTERLACE_FRM_CTRL_COEF_ACCESS, 0);
+
        deinterlace_clr_set_bits(dev, DEINTERLACE_FIELD_CTRL,
                                 DEINTERLACE_FIELD_CTRL_FIELD_CNT_MSK,
                                 DEINTERLACE_FIELD_CTRL_FIELD_CNT(ctx->field));
@@ -248,7 +269,6 @@ static irqreturn_t deinterlace_irq(int irq, void *data)
 static void deinterlace_init(struct deinterlace_dev *dev)
 {
        u32 val;
-       int i;
 
        deinterlace_write(dev, DEINTERLACE_BYPASS,
                          DEINTERLACE_BYPASS_CSC);
@@ -285,26 +305,6 @@ static void deinterlace_init(struct deinterlace_dev *dev)
        deinterlace_clr_set_bits(dev, DEINTERLACE_CHROMA_DIFF,
                                 DEINTERLACE_CHROMA_DIFF_TH_MSK,
                                 DEINTERLACE_CHROMA_DIFF_TH(5));
-
-       /* neutral filter coefficients */
-       deinterlace_set_bits(dev, DEINTERLACE_FRM_CTRL,
-                            DEINTERLACE_FRM_CTRL_COEF_ACCESS);
-       readl_poll_timeout(dev->base + DEINTERLACE_STATUS, val,
-                          val & DEINTERLACE_STATUS_COEF_STATUS, 2, 40);
-
-       for (i = 0; i < 32; i++) {
-               deinterlace_write(dev, DEINTERLACE_CH0_HORZ_COEF0 + i * 4,
-                                 DEINTERLACE_IDENTITY_COEF);
-               deinterlace_write(dev, DEINTERLACE_CH0_VERT_COEF + i * 4,
-                                 DEINTERLACE_IDENTITY_COEF);
-               deinterlace_write(dev, DEINTERLACE_CH1_HORZ_COEF0 + i * 4,
-                                 DEINTERLACE_IDENTITY_COEF);
-               deinterlace_write(dev, DEINTERLACE_CH1_VERT_COEF + i * 4,
-                                 DEINTERLACE_IDENTITY_COEF);
-       }
-
-       deinterlace_clr_set_bits(dev, DEINTERLACE_FRM_CTRL,
-                                DEINTERLACE_FRM_CTRL_COEF_ACCESS, 0);
 }
 
 static inline struct deinterlace_ctx *deinterlace_file2ctx(struct file *file)