Lines Matching +full:pci +full:- +full:phy
1 // SPDX-License-Identifier: GPL-2.0
5 * Copyright (C) 2016-2017 HiSilicon Co., Ltd. http://www.hisilicon.com
18 #include <linux/pci.h>
19 #include <linux/phy/phy.h>
24 #include "pcie-designware.h"
26 #define to_histb_pcie(x) dev_get_drvdata((x)->dev)
53 struct dw_pcie *pci; member
58 struct phy *phy; member
69 return readl(histb_pcie->ctrl + reg); in histb_pcie_readl()
74 writel(val, histb_pcie->ctrl + reg); in histb_pcie_writel()
79 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); in histb_pcie_dbi_w_mode() local
80 struct histb_pcie *hipcie = to_histb_pcie(pci); in histb_pcie_dbi_w_mode()
93 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); in histb_pcie_dbi_r_mode() local
94 struct histb_pcie *hipcie = to_histb_pcie(pci); in histb_pcie_dbi_r_mode()
105 static u32 histb_pcie_read_dbi(struct dw_pcie *pci, void __iomem *base, in histb_pcie_read_dbi() argument
110 histb_pcie_dbi_r_mode(&pci->pp, true); in histb_pcie_read_dbi()
112 histb_pcie_dbi_r_mode(&pci->pp, false); in histb_pcie_read_dbi()
117 static void histb_pcie_write_dbi(struct dw_pcie *pci, void __iomem *base, in histb_pcie_write_dbi() argument
120 histb_pcie_dbi_w_mode(&pci->pp, true); in histb_pcie_write_dbi()
122 histb_pcie_dbi_w_mode(&pci->pp, false); in histb_pcie_write_dbi()
128 struct dw_pcie *pci = to_dw_pcie_from_pp(bus->sysdata); in histb_pcie_rd_own_conf() local
135 *val = dw_pcie_read_dbi(pci, where, size); in histb_pcie_rd_own_conf()
142 struct dw_pcie *pci = to_dw_pcie_from_pp(bus->sysdata); in histb_pcie_wr_own_conf() local
147 dw_pcie_write_dbi(pci, where, size, val); in histb_pcie_wr_own_conf()
156 static int histb_pcie_link_up(struct dw_pcie *pci) in histb_pcie_link_up() argument
158 struct histb_pcie *hipcie = to_histb_pcie(pci); in histb_pcie_link_up()
174 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); in histb_pcie_establish_link() local
175 struct histb_pcie *hipcie = to_histb_pcie(pci); in histb_pcie_establish_link()
178 if (dw_pcie_link_up(pci)) { in histb_pcie_establish_link()
179 dev_info(pci->dev, "Link already up\n"); in histb_pcie_establish_link()
197 return dw_pcie_wait_for_link(pci); in histb_pcie_establish_link()
202 pp->bridge->ops = &histb_pci_ops; in histb_pcie_host_init()
216 reset_control_assert(hipcie->soft_reset); in histb_pcie_host_disable()
217 reset_control_assert(hipcie->sys_reset); in histb_pcie_host_disable()
218 reset_control_assert(hipcie->bus_reset); in histb_pcie_host_disable()
220 clk_disable_unprepare(hipcie->aux_clk); in histb_pcie_host_disable()
221 clk_disable_unprepare(hipcie->pipe_clk); in histb_pcie_host_disable()
222 clk_disable_unprepare(hipcie->sys_clk); in histb_pcie_host_disable()
223 clk_disable_unprepare(hipcie->bus_clk); in histb_pcie_host_disable()
225 if (gpio_is_valid(hipcie->reset_gpio)) in histb_pcie_host_disable()
226 gpio_set_value_cansleep(hipcie->reset_gpio, 0); in histb_pcie_host_disable()
228 if (hipcie->vpcie) in histb_pcie_host_disable()
229 regulator_disable(hipcie->vpcie); in histb_pcie_host_disable()
234 struct dw_pcie *pci = to_dw_pcie_from_pp(pp); in histb_pcie_host_enable() local
235 struct histb_pcie *hipcie = to_histb_pcie(pci); in histb_pcie_host_enable()
236 struct device *dev = pci->dev; in histb_pcie_host_enable()
240 if (hipcie->vpcie) { in histb_pcie_host_enable()
241 ret = regulator_enable(hipcie->vpcie); in histb_pcie_host_enable()
248 if (gpio_is_valid(hipcie->reset_gpio)) in histb_pcie_host_enable()
249 gpio_set_value_cansleep(hipcie->reset_gpio, 1); in histb_pcie_host_enable()
251 ret = clk_prepare_enable(hipcie->bus_clk); in histb_pcie_host_enable()
257 ret = clk_prepare_enable(hipcie->sys_clk); in histb_pcie_host_enable()
263 ret = clk_prepare_enable(hipcie->pipe_clk); in histb_pcie_host_enable()
269 ret = clk_prepare_enable(hipcie->aux_clk); in histb_pcie_host_enable()
275 reset_control_assert(hipcie->soft_reset); in histb_pcie_host_enable()
276 reset_control_deassert(hipcie->soft_reset); in histb_pcie_host_enable()
278 reset_control_assert(hipcie->sys_reset); in histb_pcie_host_enable()
279 reset_control_deassert(hipcie->sys_reset); in histb_pcie_host_enable()
281 reset_control_assert(hipcie->bus_reset); in histb_pcie_host_enable()
282 reset_control_deassert(hipcie->bus_reset); in histb_pcie_host_enable()
287 clk_disable_unprepare(hipcie->pipe_clk); in histb_pcie_host_enable()
289 clk_disable_unprepare(hipcie->sys_clk); in histb_pcie_host_enable()
291 clk_disable_unprepare(hipcie->bus_clk); in histb_pcie_host_enable()
293 if (hipcie->vpcie) in histb_pcie_host_enable()
294 regulator_disable(hipcie->vpcie); in histb_pcie_host_enable()
308 struct dw_pcie *pci; in histb_pcie_probe() local
310 struct device_node *np = pdev->dev.of_node; in histb_pcie_probe()
311 struct device *dev = &pdev->dev; in histb_pcie_probe()
318 return -ENOMEM; in histb_pcie_probe()
320 pci = devm_kzalloc(dev, sizeof(*pci), GFP_KERNEL); in histb_pcie_probe()
321 if (!pci) in histb_pcie_probe()
322 return -ENOMEM; in histb_pcie_probe()
324 hipcie->pci = pci; in histb_pcie_probe()
325 pp = &pci->pp; in histb_pcie_probe()
326 pci->dev = dev; in histb_pcie_probe()
327 pci->ops = &dw_pcie_ops; in histb_pcie_probe()
329 hipcie->ctrl = devm_platform_ioremap_resource_byname(pdev, "control"); in histb_pcie_probe()
330 if (IS_ERR(hipcie->ctrl)) { in histb_pcie_probe()
332 return PTR_ERR(hipcie->ctrl); in histb_pcie_probe()
335 pci->dbi_base = devm_platform_ioremap_resource_byname(pdev, "rc-dbi"); in histb_pcie_probe()
336 if (IS_ERR(pci->dbi_base)) { in histb_pcie_probe()
337 dev_err(dev, "cannot get rc-dbi base\n"); in histb_pcie_probe()
338 return PTR_ERR(pci->dbi_base); in histb_pcie_probe()
341 hipcie->vpcie = devm_regulator_get_optional(dev, "vpcie"); in histb_pcie_probe()
342 if (IS_ERR(hipcie->vpcie)) { in histb_pcie_probe()
343 if (PTR_ERR(hipcie->vpcie) != -ENODEV) in histb_pcie_probe()
344 return PTR_ERR(hipcie->vpcie); in histb_pcie_probe()
345 hipcie->vpcie = NULL; in histb_pcie_probe()
348 hipcie->reset_gpio = of_get_named_gpio_flags(np, in histb_pcie_probe()
349 "reset-gpios", 0, &of_flags); in histb_pcie_probe()
352 if (gpio_is_valid(hipcie->reset_gpio)) { in histb_pcie_probe()
353 ret = devm_gpio_request_one(dev, hipcie->reset_gpio, in histb_pcie_probe()
361 hipcie->aux_clk = devm_clk_get(dev, "aux"); in histb_pcie_probe()
362 if (IS_ERR(hipcie->aux_clk)) { in histb_pcie_probe()
364 return PTR_ERR(hipcie->aux_clk); in histb_pcie_probe()
367 hipcie->pipe_clk = devm_clk_get(dev, "pipe"); in histb_pcie_probe()
368 if (IS_ERR(hipcie->pipe_clk)) { in histb_pcie_probe()
370 return PTR_ERR(hipcie->pipe_clk); in histb_pcie_probe()
373 hipcie->sys_clk = devm_clk_get(dev, "sys"); in histb_pcie_probe()
374 if (IS_ERR(hipcie->sys_clk)) { in histb_pcie_probe()
376 return PTR_ERR(hipcie->sys_clk); in histb_pcie_probe()
379 hipcie->bus_clk = devm_clk_get(dev, "bus"); in histb_pcie_probe()
380 if (IS_ERR(hipcie->bus_clk)) { in histb_pcie_probe()
382 return PTR_ERR(hipcie->bus_clk); in histb_pcie_probe()
385 hipcie->soft_reset = devm_reset_control_get(dev, "soft"); in histb_pcie_probe()
386 if (IS_ERR(hipcie->soft_reset)) { in histb_pcie_probe()
388 return PTR_ERR(hipcie->soft_reset); in histb_pcie_probe()
391 hipcie->sys_reset = devm_reset_control_get(dev, "sys"); in histb_pcie_probe()
392 if (IS_ERR(hipcie->sys_reset)) { in histb_pcie_probe()
394 return PTR_ERR(hipcie->sys_reset); in histb_pcie_probe()
397 hipcie->bus_reset = devm_reset_control_get(dev, "bus"); in histb_pcie_probe()
398 if (IS_ERR(hipcie->bus_reset)) { in histb_pcie_probe()
400 return PTR_ERR(hipcie->bus_reset); in histb_pcie_probe()
404 pp->msi_irq = platform_get_irq_byname(pdev, "msi"); in histb_pcie_probe()
405 if (pp->msi_irq < 0) in histb_pcie_probe()
406 return pp->msi_irq; in histb_pcie_probe()
409 hipcie->phy = devm_phy_get(dev, "phy"); in histb_pcie_probe()
410 if (IS_ERR(hipcie->phy)) { in histb_pcie_probe()
411 dev_info(dev, "no pcie-phy found\n"); in histb_pcie_probe()
412 hipcie->phy = NULL; in histb_pcie_probe()
414 * if no pcie-phy found, phy init in histb_pcie_probe()
418 phy_init(hipcie->phy); in histb_pcie_probe()
421 pp->ops = &histb_pcie_host_ops; in histb_pcie_probe()
446 if (hipcie->phy) in histb_pcie_remove()
447 phy_exit(hipcie->phy); in histb_pcie_remove()
453 { .compatible = "hisilicon,hi3798cv200-pcie", },
462 .name = "histb-pcie",