phy: exynos5-usbdrd: Make it possible to pass custom phy ops
Provide a way to use different PHY ops for different chips. Right now all chips are using exynos5_usbdrd_phy_ops, but it won't always be the case. For example, Exynos850 has very different USB PHY block, so there will be another PHY ops implementation for that chip. No functional change. Signed-off-by: Sam Protsenko <semen.protsenko@linaro.org> Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Link: https://lore.kernel.org/r/20230819031731.22618-5-semen.protsenko@linaro.org Signed-off-by: Vinod Koul <vkoul@kernel.org>
This commit is contained in:
parent
0b76bdce32
commit
6b34ec66e7
@ -165,6 +165,7 @@ struct exynos5_usbdrd_phy_config {
|
|||||||
|
|
||||||
struct exynos5_usbdrd_phy_drvdata {
|
struct exynos5_usbdrd_phy_drvdata {
|
||||||
const struct exynos5_usbdrd_phy_config *phy_cfg;
|
const struct exynos5_usbdrd_phy_config *phy_cfg;
|
||||||
|
const struct phy_ops *phy_ops;
|
||||||
u32 pmu_offset_usbdrd0_phy;
|
u32 pmu_offset_usbdrd0_phy;
|
||||||
u32 pmu_offset_usbdrd1_phy;
|
u32 pmu_offset_usbdrd1_phy;
|
||||||
bool has_common_clk_gate;
|
bool has_common_clk_gate;
|
||||||
@ -779,6 +780,7 @@ static const struct exynos5_usbdrd_phy_config phy_cfg_exynos5[] = {
|
|||||||
|
|
||||||
static const struct exynos5_usbdrd_phy_drvdata exynos5420_usbdrd_phy = {
|
static const struct exynos5_usbdrd_phy_drvdata exynos5420_usbdrd_phy = {
|
||||||
.phy_cfg = phy_cfg_exynos5,
|
.phy_cfg = phy_cfg_exynos5,
|
||||||
|
.phy_ops = &exynos5_usbdrd_phy_ops,
|
||||||
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
||||||
.pmu_offset_usbdrd1_phy = EXYNOS5420_USBDRD1_PHY_CONTROL,
|
.pmu_offset_usbdrd1_phy = EXYNOS5420_USBDRD1_PHY_CONTROL,
|
||||||
.has_common_clk_gate = true,
|
.has_common_clk_gate = true,
|
||||||
@ -786,12 +788,14 @@ static const struct exynos5_usbdrd_phy_drvdata exynos5420_usbdrd_phy = {
|
|||||||
|
|
||||||
static const struct exynos5_usbdrd_phy_drvdata exynos5250_usbdrd_phy = {
|
static const struct exynos5_usbdrd_phy_drvdata exynos5250_usbdrd_phy = {
|
||||||
.phy_cfg = phy_cfg_exynos5,
|
.phy_cfg = phy_cfg_exynos5,
|
||||||
|
.phy_ops = &exynos5_usbdrd_phy_ops,
|
||||||
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
||||||
.has_common_clk_gate = true,
|
.has_common_clk_gate = true,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct exynos5_usbdrd_phy_drvdata exynos5433_usbdrd_phy = {
|
static const struct exynos5_usbdrd_phy_drvdata exynos5433_usbdrd_phy = {
|
||||||
.phy_cfg = phy_cfg_exynos5,
|
.phy_cfg = phy_cfg_exynos5,
|
||||||
|
.phy_ops = &exynos5_usbdrd_phy_ops,
|
||||||
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
||||||
.pmu_offset_usbdrd1_phy = EXYNOS5433_USBHOST30_PHY_CONTROL,
|
.pmu_offset_usbdrd1_phy = EXYNOS5433_USBHOST30_PHY_CONTROL,
|
||||||
.has_common_clk_gate = false,
|
.has_common_clk_gate = false,
|
||||||
@ -799,6 +803,7 @@ static const struct exynos5_usbdrd_phy_drvdata exynos5433_usbdrd_phy = {
|
|||||||
|
|
||||||
static const struct exynos5_usbdrd_phy_drvdata exynos7_usbdrd_phy = {
|
static const struct exynos5_usbdrd_phy_drvdata exynos7_usbdrd_phy = {
|
||||||
.phy_cfg = phy_cfg_exynos5,
|
.phy_cfg = phy_cfg_exynos5,
|
||||||
|
.phy_ops = &exynos5_usbdrd_phy_ops,
|
||||||
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
.pmu_offset_usbdrd0_phy = EXYNOS5_USBDRD_PHY_CONTROL,
|
||||||
.has_common_clk_gate = false,
|
.has_common_clk_gate = false,
|
||||||
};
|
};
|
||||||
@ -906,8 +911,8 @@ static int exynos5_usbdrd_phy_probe(struct platform_device *pdev)
|
|||||||
dev_vdbg(dev, "Creating usbdrd_phy phy\n");
|
dev_vdbg(dev, "Creating usbdrd_phy phy\n");
|
||||||
|
|
||||||
for (i = 0; i < EXYNOS5_DRDPHYS_NUM; i++) {
|
for (i = 0; i < EXYNOS5_DRDPHYS_NUM; i++) {
|
||||||
struct phy *phy = devm_phy_create(dev, NULL,
|
struct phy *phy = devm_phy_create(dev, NULL, drv_data->phy_ops);
|
||||||
&exynos5_usbdrd_phy_ops);
|
|
||||||
if (IS_ERR(phy)) {
|
if (IS_ERR(phy)) {
|
||||||
dev_err(dev, "Failed to create usbdrd_phy phy\n");
|
dev_err(dev, "Failed to create usbdrd_phy phy\n");
|
||||||
return PTR_ERR(phy);
|
return PTR_ERR(phy);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user