summaryrefslogtreecommitdiff
path: root/drivers/gpu
diff options
context:
space:
mode:
authorAjay Singh Parmar <aparmar@codeaurora.org>2016-07-19 10:43:24 -0700
committerDhaval Patel <pdhaval@codeaurora.org>2016-08-01 11:58:16 -0700
commit3d9a80f80559b379ad761cc2a94d4658d973fd3e (patch)
treeb0117f912ac72903aceba2b87d0307789d058d19 /drivers/gpu
parentcf438e4940a8401d10ab8fcf74a8f94c2dc4de00 (diff)
drm/dsi-staging: add support to get regulator data from device tree
Get regulator data from device tree so that clients like DSI driver can make use of it. Change-Id: Ifbbac08f8f93b8ad85d212593e5e3f3ddab3fdfd Signed-off-by: Ajay Singh Parmar <aparmar@codeaurora.org>
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/msm/dsi-staging/dsi_clk_pwr.c55
-rw-r--r--drivers/gpu/drm/msm/dsi-staging/dsi_ctrl.c2
2 files changed, 56 insertions, 1 deletions
diff --git a/drivers/gpu/drm/msm/dsi-staging/dsi_clk_pwr.c b/drivers/gpu/drm/msm/dsi-staging/dsi_clk_pwr.c
index 2443e2cdf6f1..0ba7b526d094 100644
--- a/drivers/gpu/drm/msm/dsi-staging/dsi_clk_pwr.c
+++ b/drivers/gpu/drm/msm/dsi-staging/dsi_clk_pwr.c
@@ -446,6 +446,61 @@ error:
}
/**
+* dsi_clk_pwr_of_get_vreg_data - Parse regulator supply information
+* @of_node: Device of node to parse for supply information.
+* @regs: Pointer where regulator information will be copied to.
+* @supply_name: Name of the supply node.
+*
+* return: error code in case of failure or 0 for success.
+*/
+int dsi_clk_pwr_of_get_vreg_data(struct device_node *of_node,
+ struct dsi_regulator_info *regs,
+ char *supply_name)
+{
+ int rc = 0;
+ struct device_node *supply_root_node = NULL;
+
+ if (!of_node || !regs) {
+ pr_err("Bad params\n");
+ return -EINVAL;
+ }
+
+ regs->count = 0;
+ supply_root_node = of_get_child_by_name(of_node, supply_name);
+ if (!supply_root_node) {
+ supply_root_node = of_parse_phandle(of_node, supply_name, 0);
+ if (!supply_root_node) {
+ pr_err("No supply entry present for %s\n", supply_name);
+ return -EINVAL;
+ }
+ }
+
+ regs->count = of_get_available_child_count(supply_root_node);
+ if (regs->count == 0) {
+ pr_err("No vregs defined for %s\n", supply_name);
+ return -EINVAL;
+ }
+
+ regs->vregs = kcalloc(regs->count, sizeof(*regs->vregs), GFP_KERNEL);
+ if (!regs->vregs) {
+ regs->count = 0;
+ return -ENOMEM;
+ }
+
+ rc = dsi_pwr_parse_supply_node(supply_root_node, regs);
+ if (rc) {
+ pr_err("failed to parse supply node for %s, rc = %d\n",
+ supply_name, rc);
+
+ kfree(regs->vregs);
+ regs->vregs = NULL;
+ regs->count = 0;
+ }
+
+ return rc;
+}
+
+/**
* dsi_clk_pwr_get_dt_vreg_data - parse regulator supply information
* @dev: Device whose of_node needs to be parsed.
* @regs: Pointer where regulator information will be copied to.
diff --git a/drivers/gpu/drm/msm/dsi-staging/dsi_ctrl.c b/drivers/gpu/drm/msm/dsi-staging/dsi_ctrl.c
index f943711b779c..203e17fcab41 100644
--- a/drivers/gpu/drm/msm/dsi-staging/dsi_ctrl.c
+++ b/drivers/gpu/drm/msm/dsi-staging/dsi_ctrl.c
@@ -1371,7 +1371,7 @@ static struct platform_driver dsi_ctrl_driver = {
.probe = dsi_ctrl_dev_probe,
.remove = dsi_ctrl_dev_remove,
.driver = {
- .name = "mdss_dsi_ctrl",
+ .name = "drm_dsi_ctrl",
.of_match_table = msm_dsi_of_match,
},
};