Lines Matching refs:pcie_phy
80 static void mtk_pcie_efuse_set_lane(struct mtk_pcie_phy *pcie_phy, in mtk_pcie_efuse_set_lane() argument
83 struct mtk_pcie_lane_efuse *data = &pcie_phy->efuse[lane]; in mtk_pcie_efuse_set_lane()
89 addr = pcie_phy->sif_base + PEXTP_ANA_LN0_TRX_REG + in mtk_pcie_efuse_set_lane()
112 struct mtk_pcie_phy *pcie_phy = phy_get_drvdata(phy); in mtk_pcie_phy_init() local
115 if (!pcie_phy->sw_efuse_en) in mtk_pcie_phy_init()
119 mtk_phy_update_field(pcie_phy->sif_base + PEXTP_ANA_GLB_00_REG, in mtk_pcie_phy_init()
120 EFUSE_GLB_INTR_SEL, pcie_phy->efuse_glb_intr); in mtk_pcie_phy_init()
122 for (i = 0; i < pcie_phy->data->num_lanes; i++) in mtk_pcie_phy_init()
123 mtk_pcie_efuse_set_lane(pcie_phy, i); in mtk_pcie_phy_init()
133 static int mtk_pcie_efuse_read_for_lane(struct mtk_pcie_phy *pcie_phy, in mtk_pcie_efuse_read_for_lane() argument
136 struct mtk_pcie_lane_efuse *efuse = &pcie_phy->efuse[lane]; in mtk_pcie_efuse_read_for_lane()
137 struct device *dev = pcie_phy->dev; in mtk_pcie_efuse_read_for_lane()
166 static int mtk_pcie_read_efuse(struct mtk_pcie_phy *pcie_phy) in mtk_pcie_read_efuse() argument
168 struct device *dev = pcie_phy->dev; in mtk_pcie_read_efuse()
178 &pcie_phy->efuse_glb_intr); in mtk_pcie_read_efuse()
182 pcie_phy->sw_efuse_en = true; in mtk_pcie_read_efuse()
184 pcie_phy->efuse = devm_kzalloc(dev, pcie_phy->data->num_lanes * in mtk_pcie_read_efuse()
185 sizeof(*pcie_phy->efuse), GFP_KERNEL); in mtk_pcie_read_efuse()
186 if (!pcie_phy->efuse) in mtk_pcie_read_efuse()
189 for (i = 0; i < pcie_phy->data->num_lanes; i++) { in mtk_pcie_read_efuse()
190 ret = mtk_pcie_efuse_read_for_lane(pcie_phy, i); in mtk_pcie_read_efuse()
202 struct mtk_pcie_phy *pcie_phy; in mtk_pcie_phy_probe() local
205 pcie_phy = devm_kzalloc(dev, sizeof(*pcie_phy), GFP_KERNEL); in mtk_pcie_phy_probe()
206 if (!pcie_phy) in mtk_pcie_phy_probe()
209 pcie_phy->sif_base = devm_platform_ioremap_resource_byname(pdev, "sif"); in mtk_pcie_phy_probe()
210 if (IS_ERR(pcie_phy->sif_base)) in mtk_pcie_phy_probe()
211 return dev_err_probe(dev, PTR_ERR(pcie_phy->sif_base), in mtk_pcie_phy_probe()
214 pcie_phy->phy = devm_phy_create(dev, dev->of_node, &mtk_pcie_phy_ops); in mtk_pcie_phy_probe()
215 if (IS_ERR(pcie_phy->phy)) in mtk_pcie_phy_probe()
216 return dev_err_probe(dev, PTR_ERR(pcie_phy->phy), in mtk_pcie_phy_probe()
219 pcie_phy->dev = dev; in mtk_pcie_phy_probe()
220 pcie_phy->data = of_device_get_match_data(dev); in mtk_pcie_phy_probe()
221 if (!pcie_phy->data) in mtk_pcie_phy_probe()
224 if (pcie_phy->data->sw_efuse_supported) { in mtk_pcie_phy_probe()
229 ret = mtk_pcie_read_efuse(pcie_phy); in mtk_pcie_phy_probe()
234 phy_set_drvdata(pcie_phy->phy, pcie_phy); in mtk_pcie_phy_probe()