Commit 447fa529 authored by Stephane Viau's avatar Stephane Viau Committed by Rob Clark

drm/msm/hdmi: use dynamic allocation for hdmi resources

Instead of reporting BUG_ON when resources arrays are not
dimensioned correctly, this patch does a dynamic allocation of
these arrays. This is needed for the following patches that add a
regulator for a new target.
Signed-off-by: default avatarStephane Viau <sviau@codeaurora.org>
Signed-off-by: default avatarRob Clark <robdclark@gmail.com>
parent 5cdde29b
...@@ -106,7 +106,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev) ...@@ -106,7 +106,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev)
goto fail; goto fail;
} }
BUG_ON(config->hpd_reg_cnt > ARRAY_SIZE(hdmi->hpd_regs)); hdmi->hpd_regs = devm_kzalloc(&pdev->dev, sizeof(hdmi->hpd_regs[0]) *
config->hpd_reg_cnt, GFP_KERNEL);
if (!hdmi->hpd_regs) {
ret = -ENOMEM;
goto fail;
}
for (i = 0; i < config->hpd_reg_cnt; i++) { for (i = 0; i < config->hpd_reg_cnt; i++) {
struct regulator *reg; struct regulator *reg;
...@@ -122,7 +127,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev) ...@@ -122,7 +127,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev)
hdmi->hpd_regs[i] = reg; hdmi->hpd_regs[i] = reg;
} }
BUG_ON(config->pwr_reg_cnt > ARRAY_SIZE(hdmi->pwr_regs)); hdmi->pwr_regs = devm_kzalloc(&pdev->dev, sizeof(hdmi->pwr_regs[0]) *
config->pwr_reg_cnt, GFP_KERNEL);
if (!hdmi->pwr_regs) {
ret = -ENOMEM;
goto fail;
}
for (i = 0; i < config->pwr_reg_cnt; i++) { for (i = 0; i < config->pwr_reg_cnt; i++) {
struct regulator *reg; struct regulator *reg;
...@@ -138,7 +148,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev) ...@@ -138,7 +148,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev)
hdmi->pwr_regs[i] = reg; hdmi->pwr_regs[i] = reg;
} }
BUG_ON(config->hpd_clk_cnt > ARRAY_SIZE(hdmi->hpd_clks)); hdmi->hpd_clks = devm_kzalloc(&pdev->dev, sizeof(hdmi->hpd_clks[0]) *
config->hpd_clk_cnt, GFP_KERNEL);
if (!hdmi->hpd_clks) {
ret = -ENOMEM;
goto fail;
}
for (i = 0; i < config->hpd_clk_cnt; i++) { for (i = 0; i < config->hpd_clk_cnt; i++) {
struct clk *clk; struct clk *clk;
...@@ -153,7 +168,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev) ...@@ -153,7 +168,12 @@ static struct hdmi *hdmi_init(struct platform_device *pdev)
hdmi->hpd_clks[i] = clk; hdmi->hpd_clks[i] = clk;
} }
BUG_ON(config->pwr_clk_cnt > ARRAY_SIZE(hdmi->pwr_clks)); hdmi->pwr_clks = devm_kzalloc(&pdev->dev, sizeof(hdmi->pwr_clks[0]) *
config->pwr_clk_cnt, GFP_KERNEL);
if (!hdmi->pwr_clks) {
ret = -ENOMEM;
goto fail;
}
for (i = 0; i < config->pwr_clk_cnt; i++) { for (i = 0; i < config->pwr_clk_cnt; i++) {
struct clk *clk; struct clk *clk;
......
...@@ -52,10 +52,10 @@ struct hdmi { ...@@ -52,10 +52,10 @@ struct hdmi {
void __iomem *mmio; void __iomem *mmio;
struct regulator *hpd_regs[2]; struct regulator **hpd_regs;
struct regulator *pwr_regs[2]; struct regulator **pwr_regs;
struct clk *hpd_clks[3]; struct clk **hpd_clks;
struct clk *pwr_clks[2]; struct clk **pwr_clks;
struct hdmi_phy *phy; struct hdmi_phy *phy;
struct i2c_adapter *i2c; struct i2c_adapter *i2c;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment