mirror of https://gitee.com/openkylin/linux.git
clk: qcom: create virtual child device for TSENS
8960 family of devices have TSENS as part of GCC in hardware. Hence DT would represent a GCC node with GCC properties as well as TSENS. Create a virtual platform child device here for TSENS so the driver can probe it and use the parent (GCC) to extract DT properties. Suggested-by: Stephen Boyd <sboyd@codeaurora.org> Signed-off-by: Rajendra Nayak <rnayak@codeaurora.org> [sboyd@codeaurora.org: Massaged to work with devm friendly qcom_cc_probe()] Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
This commit is contained in:
parent
73bb7dc08e
commit
53c929c922
|
@ -3506,6 +3506,8 @@ static int gcc_msm8960_probe(struct platform_device *pdev)
|
|||
struct clk *clk;
|
||||
struct device *dev = &pdev->dev;
|
||||
const struct of_device_id *match;
|
||||
struct platform_device *tsens;
|
||||
int ret;
|
||||
|
||||
match = of_match_device(gcc_msm8960_match_table, &pdev->dev);
|
||||
if (!match)
|
||||
|
@ -3520,11 +3522,26 @@ static int gcc_msm8960_probe(struct platform_device *pdev)
|
|||
if (IS_ERR(clk))
|
||||
return PTR_ERR(clk);
|
||||
|
||||
return qcom_cc_probe(pdev, match->data);
|
||||
ret = qcom_cc_probe(pdev, match->data);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
tsens = platform_device_register_data(&pdev->dev, "qcom-tsens", -1,
|
||||
NULL, 0);
|
||||
if (IS_ERR(tsens))
|
||||
return PTR_ERR(tsens);
|
||||
|
||||
platform_set_drvdata(pdev, tsens);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int gcc_msm8960_remove(struct platform_device *pdev)
|
||||
{
|
||||
struct platform_device *tsens = platform_get_drvdata(pdev);
|
||||
|
||||
platform_device_unregister(tsens);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue