On Fri, Feb 23, 2018 at 08:17:53AM -0500, Rob Clark wrote: > Note there seems to be a slight disagreement between public 8x16 HRD > (which claims WB2 has offset of 0x65000, relative to start of MDP), and > reality (which claims WB2 has offset of 0x64800). I sided with reality. > > There should also be a WB0 attached to LM0 (which routes to DSI > interface). It isn't clear if this can be used at the same time as > output to DSI, which would be hugely useful. I was unable to get this > to work (with HDMI bridge chip on db410c, so DSI in video mode). > > This will be needed to implement writeback support, but also useful > to remove a manual hack to the generated headers (since rnndb register > docs for WB had been merged long ago). > > Also fixes LM3 offset. > > Signed-off-by: Rob Clark <robdclark@xxxxxxxxx> I'm not familiar with the hw, but I don't see any programming errors, so: Reviewed-by: Sean Paul <seanpaul@xxxxxxxxxxxx> > --- > drivers/gpu/drm/msm/disp/mdp5/mdp5.xml.h | 2 -- > drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.c | 17 +++++++++++------ > drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.h | 11 +++++++++++ > drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c | 1 + > 4 files changed, 23 insertions(+), 8 deletions(-) > > diff --git a/drivers/gpu/drm/msm/disp/mdp5/mdp5.xml.h b/drivers/gpu/drm/msm/disp/mdp5/mdp5.xml.h > index d9c10e02ee41..bebcbabb1fe4 100644 > --- a/drivers/gpu/drm/msm/disp/mdp5/mdp5.xml.h > +++ b/drivers/gpu/drm/msm/disp/mdp5/mdp5.xml.h > @@ -1391,13 +1391,11 @@ static inline uint32_t REG_MDP5_PP_FBC_LOSSY_MODE(uint32_t i0) { return 0x000000 > static inline uint32_t __offset_WB(uint32_t idx) > { > switch (idx) { > -#if 0 /* TEMPORARY until patch that adds wb.base[] is merged */ > case 0: return (mdp5_cfg->wb.base[0]); > case 1: return (mdp5_cfg->wb.base[1]); > case 2: return (mdp5_cfg->wb.base[2]); > case 3: return (mdp5_cfg->wb.base[3]); > case 4: return (mdp5_cfg->wb.base[4]); > -#endif > default: return INVALID_IDX(idx); > } > } > diff --git a/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.c b/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.c > index 824067d2d427..f92e68cdeeef 100644 > --- a/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.c > +++ b/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.c > @@ -300,8 +300,8 @@ const struct mdp5_cfg_hw msm8x16_config = { > }, > }, > .ctl = { > - .count = 5, > - .base = { 0x01000, 0x01200, 0x01400, 0x01600, 0x01800 }, > + .count = 3, > + .base = { 0x01000, 0x01200, 0x01400 }, > .flush_hw_mask = 0x4003ffff, > }, > .pipe_vig = { > @@ -324,7 +324,7 @@ const struct mdp5_cfg_hw msm8x16_config = { > }, > .lm = { > .count = 2, /* LM0 and LM3 */ > - .base = { 0x44000, 0x47000 }, > + .base = { [0] = 0x44000, [3] = 0x47000 }, > .instances = { > { .id = 0, .pp = 0, .dspp = 0, > .caps = MDP_LM_CAP_DISPLAY, }, > @@ -338,12 +338,17 @@ const struct mdp5_cfg_hw msm8x16_config = { > .dspp = { > .count = 1, > .base = { 0x54000 }, > - > + }, > + .wb = { > + .count = 1, > + .base = { [0] = 0x64000, [2] = 0x64800 }, > + .instances = { > + { .id = 2, .lm = 3 }, > + }, > }, > .intf = { > - .base = { 0x00000, 0x6a800 }, > + .base = { 0x6a000, 0x6a800, 0x6b000, 0x6b800 }, > .connect = { > - [0] = INTF_DISABLED, > [1] = INTF_DSI, > }, > }, > diff --git a/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.h b/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.h > index 75910d0f2f4c..2e529fb2f9ee 100644 > --- a/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.h > +++ b/drivers/gpu/drm/msm/disp/mdp5/mdp5_cfg.h > @@ -77,6 +77,16 @@ struct mdp5_mdp_block { > uint32_t caps; /* MDP capabilities: MDP_CAP_xxx bits */ > }; > > +struct mdp5_wb_instance { > + int id; > + int lm; > +}; > + > +struct mdp5_wb_block { > + MDP5_SUB_BLOCK_DEFINITION; > + struct mdp5_wb_instance instances[MAX_BASES]; > +}; > + > #define MDP5_INTF_NUM_MAX 5 > > struct mdp5_intf_block { > @@ -100,6 +110,7 @@ struct mdp5_cfg_hw { > struct mdp5_sub_block pp; > struct mdp5_sub_block dsc; > struct mdp5_sub_block cdm; > + struct mdp5_wb_block wb; > struct mdp5_intf_block intf; > > uint32_t max_clk; > diff --git a/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c b/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c > index 6d8e3a9a6fc0..1f44d8f15ce1 100644 > --- a/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c > +++ b/drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c > @@ -652,6 +652,7 @@ struct msm_kms *mdp5_kms_init(struct drm_device *dev) > pm_runtime_get_sync(&pdev->dev); > for (i = 0; i < MDP5_INTF_NUM_MAX; i++) { > if (mdp5_cfg_intf_is_virtual(config->hw->intf.connect[i]) || > + (config->hw->intf.connect[i] == INTF_DISABLED) || > !config->hw->intf.base[i]) > continue; > mdp5_write(mdp5_kms, REG_MDP5_INTF_TIMING_ENGINE_EN(i), 0); > -- > 2.14.3 > -- Sean Paul, Software Engineer, Google / Chromium OS -- To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html