diff options
| author | Ajay Singh Parmar <aparmar@codeaurora.org> | 2016-07-19 10:43:24 -0700 |
|---|---|---|
| committer | Dhaval Patel <pdhaval@codeaurora.org> | 2016-08-01 11:58:16 -0700 |
| commit | 3d9a80f80559b379ad761cc2a94d4658d973fd3e (patch) | |
| tree | b0117f912ac72903aceba2b87d0307789d058d19 /drivers/gpu | |
| parent | cf438e4940a8401d10ab8fcf74a8f94c2dc4de00 (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.c | 55 | ||||
| -rw-r--r-- | drivers/gpu/drm/msm/dsi-staging/dsi_ctrl.c | 2 |
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, }, }; |
