diff options
| author | Ujwal Patel <ujwalp@codeaurora.org> | 2015-06-11 19:33:59 -0700 |
|---|---|---|
| committer | David Keitel <dkeitel@codeaurora.org> | 2016-03-23 20:43:08 -0700 |
| commit | a88c5d35b97fab09537702185472d517f7b754da (patch) | |
| tree | 4c6c175e746a4899ec9e9c5858792a4c81acdc53 | |
| parent | 129d5ad7724026149f185bb6f96186694246d6e5 (diff) | |
msm: mdss: add support to change border color through debugfs
During blending operation, bottom color is known as border color and it
is same size as mixer dimensions. Default color is black but it can be
configured to different color. This is very useful for debugging purpose.
Add support to program border-color through debugfs as per following
guidelines.
echo code > <debugfs>/mdp/bordercolor/colorN
where
code: 12bit color value in decimal
colorN: color0, color1, color2
Change-Id: Ia3e8791713f5aa309a95c867445995ced028dd8d
Signed-off-by: Ujwal Patel <ujwalp@codeaurora.org>
| -rw-r--r-- | drivers/video/fbdev/msm/mdss.h | 4 | ||||
| -rw-r--r-- | drivers/video/fbdev/msm/mdss_debug.c | 7 | ||||
| -rw-r--r-- | drivers/video/fbdev/msm/mdss_debug.h | 1 | ||||
| -rw-r--r-- | drivers/video/fbdev/msm/mdss_mdp_ctl.c | 12 | ||||
| -rw-r--r-- | drivers/video/fbdev/msm/mdss_mdp_debug.c | 7 |
5 files changed, 29 insertions, 2 deletions
diff --git a/drivers/video/fbdev/msm/mdss.h b/drivers/video/fbdev/msm/mdss.h index c92ef4c8fced..69ad70883802 100644 --- a/drivers/video/fbdev/msm/mdss.h +++ b/drivers/video/fbdev/msm/mdss.h @@ -411,6 +411,10 @@ struct mdss_data_type { struct mdss_max_bw_settings *max_bw_settings; u32 bw_mode_bitmap; u32 max_bw_settings_cnt; + + u32 bcolor0; + u32 bcolor1; + u32 bcolor2; }; extern struct mdss_data_type *mdss_res; diff --git a/drivers/video/fbdev/msm/mdss_debug.c b/drivers/video/fbdev/msm/mdss_debug.c index 4b955d16ee2f..8228425f91ad 100644 --- a/drivers/video/fbdev/msm/mdss_debug.c +++ b/drivers/video/fbdev/msm/mdss_debug.c @@ -1095,6 +1095,13 @@ int mdss_debugfs_init(struct mdss_data_type *mdata) goto err; } + mdd->bordercolor = debugfs_create_dir("bordercolor", mdd->root); + if (IS_ERR_OR_NULL(mdd->root)) { + pr_err("debugfs_create_dir for mdp failed, error %ld\n", + PTR_ERR(mdd->root)); + goto err; + } + mdss_debugfs_perf_init(mdd, mdata); if (mdss_create_xlog_debug(mdd)) diff --git a/drivers/video/fbdev/msm/mdss_debug.h b/drivers/video/fbdev/msm/mdss_debug.h index a043c4ec9579..3e16ec59c3f9 100644 --- a/drivers/video/fbdev/msm/mdss_debug.h +++ b/drivers/video/fbdev/msm/mdss_debug.h @@ -91,6 +91,7 @@ struct mdss_debug_base { struct mdss_debug_data { struct dentry *root; struct dentry *perf; + struct dentry *bordercolor; struct list_head base_list; }; diff --git a/drivers/video/fbdev/msm/mdss_mdp_ctl.c b/drivers/video/fbdev/msm/mdss_mdp_ctl.c index 17cdcf4a3404..7f26339084c0 100644 --- a/drivers/video/fbdev/msm/mdss_mdp_ctl.c +++ b/drivers/video/fbdev/msm/mdss_mdp_ctl.c @@ -3601,15 +3601,23 @@ update_mixer: mixer_op_mode |= BIT(31); mdp_mixer_write(mixer, MDSS_MDP_REG_LM_OP_MODE, mixer_op_mode); + + mdp_mixer_write(mixer, MDSS_MDP_REG_LM_BORDER_COLOR_0, + (mdata->bcolor0 & 0xFFF) | ((mdata->bcolor1 & 0xFFF) << 16)); + mdp_mixer_write(mixer, MDSS_MDP_REG_LM_BORDER_COLOR_1, + mdata->bcolor2 & 0xFFF); + off = __mdss_mdp_ctl_get_mixer_off(mixer); mdss_mdp_ctl_write(ctl, off, mixercfg); /* Program ctl layer extension bits */ mdss_mdp_ctl_write(ctl, off + MDSS_MDP_REG_CTL_LAYER_EXTN_OFFSET, mixercfg_extn); - pr_debug("mixer=%d cfg=0%08x cfg_extn=0x%08x op_mode=0x%08x w=%d h=%d\n", + pr_debug("mixer=%d cfg=0%08x cfg_extn=0x%08x op_mode=0x%08x w=%d h=%d bc0=0x%x bc1=0x%x\n", mixer->num, mixercfg, mixercfg_extn, - mixer_op_mode, mixer->roi.w, mixer->roi.h); + mixer_op_mode, mixer->roi.w, mixer->roi.h, + (mdata->bcolor0 & 0xFFF) | ((mdata->bcolor1 & 0xFFF) << 16), + mdata->bcolor2 & 0xFFF); MDSS_XLOG(mixer->num, mixercfg, mixercfg_extn, mixer_op_mode, mixer->roi.h, mixer->roi.w); } diff --git a/drivers/video/fbdev/msm/mdss_mdp_debug.c b/drivers/video/fbdev/msm/mdss_mdp_debug.c index 678970b6ce80..18ed1b930c3d 100644 --- a/drivers/video/fbdev/msm/mdss_mdp_debug.c +++ b/drivers/video/fbdev/msm/mdss_mdp_debug.c @@ -389,6 +389,13 @@ int mdss_mdp_debugfs_init(struct mdss_data_type *mdata) debugfs_create_u32("serialize_wait4pp", 0644, mdd->root, (u32 *)&mdata->serialize_wait4pp); + debugfs_create_u32("color0", 0644, mdd->bordercolor, + (u32 *)&mdata->bcolor0); + debugfs_create_u32("color1", 0644, mdd->bordercolor, + (u32 *)&mdata->bcolor1); + debugfs_create_u32("color2", 0644, mdd->bordercolor, + (u32 *)&mdata->bcolor2); + return 0; } #endif |
