summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorUjwal Patel <ujwalp@codeaurora.org>2015-06-11 19:33:59 -0700
committerDavid Keitel <dkeitel@codeaurora.org>2016-03-23 20:43:08 -0700
commita88c5d35b97fab09537702185472d517f7b754da (patch)
tree4c6c175e746a4899ec9e9c5858792a4c81acdc53
parent129d5ad7724026149f185bb6f96186694246d6e5 (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.h4
-rw-r--r--drivers/video/fbdev/msm/mdss_debug.c7
-rw-r--r--drivers/video/fbdev/msm/mdss_debug.h1
-rw-r--r--drivers/video/fbdev/msm/mdss_mdp_ctl.c12
-rw-r--r--drivers/video/fbdev/msm/mdss_mdp_debug.c7
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