drm/msm/dpu: setup merge modes in merge_3d block
authorDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Thu, 22 Oct 2020 13:16:57 +0000 (16:16 +0300)
committerRob Clark <robdclark@chromium.org>
Wed, 4 Nov 2020 16:26:26 +0000 (08:26 -0800)
Handle setting up merge mode in merge_3d hardware block.

Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Signed-off-by: Rob Clark <robdclark@chromium.org>
drivers/gpu/drm/msm/disp/dpu1/dpu_hw_merge3d.c
drivers/gpu/drm/msm/disp/dpu1/dpu_hw_merge3d.h

index 5c7ad19feea3e0018c46ef294b079c62db368f0e..720813e5a8ae811662a64edc64b7f62ecf025fff 100644 (file)
@@ -11,6 +11,9 @@
 #include "dpu_kms.h"
 #include "dpu_trace.h"
 
+#define MERGE_3D_MUX  0x000
+#define MERGE_3D_MODE 0x004
+
 static const struct dpu_merge_3d_cfg *_merge_3d_offset(enum dpu_merge_3d idx,
                const struct dpu_mdss_cfg *m,
                void __iomem *addr,
@@ -32,9 +35,27 @@ static const struct dpu_merge_3d_cfg *_merge_3d_offset(enum dpu_merge_3d idx,
        return ERR_PTR(-EINVAL);
 }
 
+static void dpu_hw_merge_3d_setup_3d_mode(struct dpu_hw_merge_3d *merge_3d,
+                       enum dpu_3d_blend_mode mode_3d)
+{
+       struct dpu_hw_blk_reg_map *c;
+       u32 data;
+
+
+       c = &merge_3d->hw;
+       if (mode_3d == BLEND_3D_NONE) {
+               DPU_REG_WRITE(c, MERGE_3D_MODE, 0);
+               DPU_REG_WRITE(c, MERGE_3D_MUX, 0);
+       } else {
+               data = BIT(0) | ((mode_3d - 1) << 1);
+               DPU_REG_WRITE(c, MERGE_3D_MODE, data);
+       }
+}
+
 static void _setup_merge_3d_ops(struct dpu_hw_merge_3d *c,
                                unsigned long features)
 {
+       c->ops.setup_3d_mode = dpu_hw_merge_3d_setup_3d_mode;
 };
 
 static struct dpu_hw_blk_ops dpu_hw_ops;
index aaad7c90cfb0a273198014f6040ad296cec0eee2..870bdb14613e4537f7fce9693ec210ad8e3c2db5 100644 (file)
@@ -16,8 +16,12 @@ struct dpu_hw_merge_3d;
  *
  * struct dpu_hw_merge_3d_ops : Interface to the merge_3d Hw driver functions
  *  Assumption is these functions will be called after clocks are enabled
+ *  @setup_3d_mode : enable 3D merge
  */
 struct dpu_hw_merge_3d_ops {
+       void (*setup_3d_mode)(struct dpu_hw_merge_3d *merge_3d,
+                       enum dpu_3d_blend_mode mode_3d);
+
 };
 
 struct dpu_hw_merge_3d {