diff options
author | Xiaowei Song <songxiaowei@hisilicon.com> | 2018-07-11 04:09:46 -0400 |
---|---|---|
committer | Lorenzo Pieralisi <lorenzo.pieralisi@arm.com> | 2018-07-11 07:20:41 -0400 |
commit | 141cb3d4ee521eff45d0520327106ddfe0abe90a (patch) | |
tree | 03fb2e045fa62ebd530b331503495172060552cc /drivers/pci/controller/dwc | |
parent | ce397d215ccd07b8ae3f71db689aedb85d56ab40 (diff) |
PCI: kirin: Add MSI support
Add support for MSI to the kirin host controller driver, based
on the generic dwc infrastructure.
Signed-off-by: Xiaowei Song <songxiaowei@hisilicon.com>
Signed-off-by: Yao Chen <chenyao11@huawei.com>
[lorenzo.pieralisi@arm.com: updated commit log]
Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
Diffstat (limited to 'drivers/pci/controller/dwc')
-rw-r--r-- | drivers/pci/controller/dwc/pcie-kirin.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/drivers/pci/controller/dwc/pcie-kirin.c b/drivers/pci/controller/dwc/pcie-kirin.c index d2970a009eb5..5352e0c3be82 100644 --- a/drivers/pci/controller/dwc/pcie-kirin.c +++ b/drivers/pci/controller/dwc/pcie-kirin.c | |||
@@ -430,6 +430,9 @@ static int kirin_pcie_host_init(struct pcie_port *pp) | |||
430 | { | 430 | { |
431 | kirin_pcie_establish_link(pp); | 431 | kirin_pcie_establish_link(pp); |
432 | 432 | ||
433 | if (IS_ENABLED(CONFIG_PCI_MSI)) | ||
434 | dw_pcie_msi_init(pp); | ||
435 | |||
433 | return 0; | 436 | return 0; |
434 | } | 437 | } |
435 | 438 | ||
@@ -445,9 +448,34 @@ static const struct dw_pcie_host_ops kirin_pcie_host_ops = { | |||
445 | .host_init = kirin_pcie_host_init, | 448 | .host_init = kirin_pcie_host_init, |
446 | }; | 449 | }; |
447 | 450 | ||
451 | static int kirin_pcie_add_msi(struct dw_pcie *pci, | ||
452 | struct platform_device *pdev) | ||
453 | { | ||
454 | int irq; | ||
455 | |||
456 | if (IS_ENABLED(CONFIG_PCI_MSI)) { | ||
457 | irq = platform_get_irq(pdev, 0); | ||
458 | if (irq < 0) { | ||
459 | dev_err(&pdev->dev, | ||
460 | "failed to get MSI IRQ (%d)\n", irq); | ||
461 | return irq; | ||
462 | } | ||
463 | |||
464 | pci->pp.msi_irq = irq; | ||
465 | } | ||
466 | |||
467 | return 0; | ||
468 | } | ||
469 | |||
448 | static int __init kirin_add_pcie_port(struct dw_pcie *pci, | 470 | static int __init kirin_add_pcie_port(struct dw_pcie *pci, |
449 | struct platform_device *pdev) | 471 | struct platform_device *pdev) |
450 | { | 472 | { |
473 | int ret; | ||
474 | |||
475 | ret = kirin_pcie_add_msi(pci, pdev); | ||
476 | if (ret) | ||
477 | return ret; | ||
478 | |||
451 | pci->pp.ops = &kirin_pcie_host_ops; | 479 | pci->pp.ops = &kirin_pcie_host_ops; |
452 | 480 | ||
453 | return dw_pcie_host_init(&pci->pp); | 481 | return dw_pcie_host_init(&pci->pp); |