From: Lorenzo Pieralisi <lpieralisi@kernel.org> To: Minda Chen <minda.chen@starfivetech.com> Cc: "Conor Dooley" <conor@kernel.org>, "Krzysztof Wilczyński" <kw@linux.com>, "Rob Herring" <robh+dt@kernel.org>, "Bjorn Helgaas" <bhelgaas@google.com>, "Daire McNamara" <daire.mcnamara@microchip.com>, "Emil Renner Berthing" <emil.renner.berthing@canonical.com>, "Krzysztof Kozlowski" <krzysztof.kozlowski+dt@linaro.org>, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, linux-pci@vger.kernel.org, "Paul Walmsley" <paul.walmsley@sifive.com>, "Palmer Dabbelt" <palmer@dabbelt.com>, "Albert Ou" <aou@eecs.berkeley.edu>, "Philipp Zabel" <p.zabel@pengutronix.de>, "Mason Huo" <mason.huo@starfivetech.com>, "Leyfoon Tan" <leyfoon.tan@starfivetech.com>, "Kevin Xie" <kevin.xie@starfivetech.com> Subject: Re: [PATCH v13 12/21] PCI: microchip: Add request_event_irq() callback function Date: Wed, 27 Dec 2023 17:01:38 +0100 [thread overview] Message-ID: <ZYxKYhVycTOfbDTI@lpieralisi> (raw) In-Reply-To: <20231214072839.2367-13-minda.chen@starfivetech.com> On Thu, Dec 14, 2023 at 03:28:30PM +0800, Minda Chen wrote: > PolarFire implements specific PCIe interrupts except PLDA local interrupt. Please explain to me what you want to say here. > For lack of MSI controller, these interrupts have to be added to global > event field. PolarFire PCIe driver also register additional interrupt > symbol name. And here. > PolarFire PCIe contain total 28 interrupts event while PLDA contain 13 > local interrupts event, interrupt to event num mapping is different. It "is different" in different platforms ? Is that correct ? > So add a callback function to support different IRQ register function. > Also Add PLDA default handler function, which will be moved to pcie- > plda-host.c in moving codes patch. As I said before, a patch is a single self-contained change, don't refer to other patches, they may or may not be merged or even exist by the time this one hits mainline. Lorenzo > Signed-off-by: Minda Chen <minda.chen@starfivetech.com> > Acked-by: Conor Dooley <conor.dooley@microchip.com> > --- > .../pci/controller/plda/pcie-microchip-host.c | 31 ++++++++++++++++--- > drivers/pci/controller/plda/pcie-plda.h | 5 +++ > 2 files changed, 32 insertions(+), 4 deletions(-) > > diff --git a/drivers/pci/controller/plda/pcie-microchip-host.c b/drivers/pci/controller/plda/pcie-microchip-host.c > index 7b3f4f74745d..624e4e2e97d3 100644 > --- a/drivers/pci/controller/plda/pcie-microchip-host.c > +++ b/drivers/pci/controller/plda/pcie-microchip-host.c > @@ -643,6 +643,11 @@ static irqreturn_t mc_event_handler(int irq, void *dev_id) > return IRQ_HANDLED; > } > > +static irqreturn_t plda_event_handler(int irq, void *dev_id) > +{ > + return IRQ_HANDLED; > +} > + > static void plda_handle_event(struct irq_desc *desc) > { > struct plda_pcie_rp *port = irq_desc_get_handler_data(desc); > @@ -804,6 +809,17 @@ static int mc_pcie_init_clks(struct device *dev) > return 0; > } > > +static int mc_request_event_irq(struct plda_pcie_rp *plda, int event_irq, > + int event) > +{ > + return devm_request_irq(plda->dev, event_irq, mc_event_handler, > + 0, event_cause[event].sym, plda); > +} > + > +static const struct plda_event mc_event = { > + .request_event_irq = mc_request_event_irq, > +}; > + > static int plda_pcie_init_irq_domains(struct plda_pcie_rp *port) > { > struct device *dev = port->dev; > @@ -905,7 +921,9 @@ static void mc_disable_interrupts(struct mc_pcie *port) > writel_relaxed(GENMASK(31, 0), bridge_base_addr + ISTATUS_HOST); > } > > -static int plda_init_interrupts(struct platform_device *pdev, struct plda_pcie_rp *port) > +static int plda_init_interrupts(struct platform_device *pdev, > + struct plda_pcie_rp *port, > + const struct plda_event *event) > { > struct device *dev = &pdev->dev; > int irq; > @@ -929,8 +947,13 @@ static int plda_init_interrupts(struct platform_device *pdev, struct plda_pcie_r > return -ENXIO; > } > > - ret = devm_request_irq(dev, event_irq, mc_event_handler, > - 0, event_cause[i].sym, port); > + if (event->request_event_irq) > + ret = event->request_event_irq(port, event_irq, i); > + else > + ret = devm_request_irq(dev, event_irq, > + plda_event_handler, > + 0, NULL, port); > + > if (ret) { > dev_err(dev, "failed to request IRQ %d\n", event_irq); > return ret; > @@ -984,7 +1007,7 @@ static int mc_platform_init(struct pci_config_window *cfg) > return ret; > > /* Address translation is up; safe to enable interrupts */ > - ret = plda_init_interrupts(pdev, &port->plda); > + ret = plda_init_interrupts(pdev, &port->plda, &mc_event); > if (ret) > return ret; > > diff --git a/drivers/pci/controller/plda/pcie-plda.h b/drivers/pci/controller/plda/pcie-plda.h > index e3d35cef9894..28ed1374e1de 100644 > --- a/drivers/pci/controller/plda/pcie-plda.h > +++ b/drivers/pci/controller/plda/pcie-plda.h > @@ -121,6 +121,11 @@ struct plda_pcie_rp { > int num_events; > }; > > +struct plda_event { > + int (*request_event_irq)(struct plda_pcie_rp *pcie, > + int event_irq, int event); > +}; > + > void plda_pcie_setup_window(void __iomem *bridge_base_addr, u32 index, > phys_addr_t axi_addr, phys_addr_t pci_addr, > size_t size); > -- > 2.17.1 >
WARNING: multiple messages have this Message-ID (diff)
From: Lorenzo Pieralisi <lpieralisi@kernel.org> To: Minda Chen <minda.chen@starfivetech.com> Cc: "Conor Dooley" <conor@kernel.org>, "Krzysztof Wilczyński" <kw@linux.com>, "Rob Herring" <robh+dt@kernel.org>, "Bjorn Helgaas" <bhelgaas@google.com>, "Daire McNamara" <daire.mcnamara@microchip.com>, "Emil Renner Berthing" <emil.renner.berthing@canonical.com>, "Krzysztof Kozlowski" <krzysztof.kozlowski+dt@linaro.org>, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-riscv@lists.infradead.org, linux-pci@vger.kernel.org, "Paul Walmsley" <paul.walmsley@sifive.com>, "Palmer Dabbelt" <palmer@dabbelt.com>, "Albert Ou" <aou@eecs.berkeley.edu>, "Philipp Zabel" <p.zabel@pengutronix.de>, "Mason Huo" <mason.huo@starfivetech.com>, "Leyfoon Tan" <leyfoon.tan@starfivetech.com>, "Kevin Xie" <kevin.xie@starfivetech.com> Subject: Re: [PATCH v13 12/21] PCI: microchip: Add request_event_irq() callback function Date: Wed, 27 Dec 2023 17:01:38 +0100 [thread overview] Message-ID: <ZYxKYhVycTOfbDTI@lpieralisi> (raw) In-Reply-To: <20231214072839.2367-13-minda.chen@starfivetech.com> On Thu, Dec 14, 2023 at 03:28:30PM +0800, Minda Chen wrote: > PolarFire implements specific PCIe interrupts except PLDA local interrupt. Please explain to me what you want to say here. > For lack of MSI controller, these interrupts have to be added to global > event field. PolarFire PCIe driver also register additional interrupt > symbol name. And here. > PolarFire PCIe contain total 28 interrupts event while PLDA contain 13 > local interrupts event, interrupt to event num mapping is different. It "is different" in different platforms ? Is that correct ? > So add a callback function to support different IRQ register function. > Also Add PLDA default handler function, which will be moved to pcie- > plda-host.c in moving codes patch. As I said before, a patch is a single self-contained change, don't refer to other patches, they may or may not be merged or even exist by the time this one hits mainline. Lorenzo > Signed-off-by: Minda Chen <minda.chen@starfivetech.com> > Acked-by: Conor Dooley <conor.dooley@microchip.com> > --- > .../pci/controller/plda/pcie-microchip-host.c | 31 ++++++++++++++++--- > drivers/pci/controller/plda/pcie-plda.h | 5 +++ > 2 files changed, 32 insertions(+), 4 deletions(-) > > diff --git a/drivers/pci/controller/plda/pcie-microchip-host.c b/drivers/pci/controller/plda/pcie-microchip-host.c > index 7b3f4f74745d..624e4e2e97d3 100644 > --- a/drivers/pci/controller/plda/pcie-microchip-host.c > +++ b/drivers/pci/controller/plda/pcie-microchip-host.c > @@ -643,6 +643,11 @@ static irqreturn_t mc_event_handler(int irq, void *dev_id) > return IRQ_HANDLED; > } > > +static irqreturn_t plda_event_handler(int irq, void *dev_id) > +{ > + return IRQ_HANDLED; > +} > + > static void plda_handle_event(struct irq_desc *desc) > { > struct plda_pcie_rp *port = irq_desc_get_handler_data(desc); > @@ -804,6 +809,17 @@ static int mc_pcie_init_clks(struct device *dev) > return 0; > } > > +static int mc_request_event_irq(struct plda_pcie_rp *plda, int event_irq, > + int event) > +{ > + return devm_request_irq(plda->dev, event_irq, mc_event_handler, > + 0, event_cause[event].sym, plda); > +} > + > +static const struct plda_event mc_event = { > + .request_event_irq = mc_request_event_irq, > +}; > + > static int plda_pcie_init_irq_domains(struct plda_pcie_rp *port) > { > struct device *dev = port->dev; > @@ -905,7 +921,9 @@ static void mc_disable_interrupts(struct mc_pcie *port) > writel_relaxed(GENMASK(31, 0), bridge_base_addr + ISTATUS_HOST); > } > > -static int plda_init_interrupts(struct platform_device *pdev, struct plda_pcie_rp *port) > +static int plda_init_interrupts(struct platform_device *pdev, > + struct plda_pcie_rp *port, > + const struct plda_event *event) > { > struct device *dev = &pdev->dev; > int irq; > @@ -929,8 +947,13 @@ static int plda_init_interrupts(struct platform_device *pdev, struct plda_pcie_r > return -ENXIO; > } > > - ret = devm_request_irq(dev, event_irq, mc_event_handler, > - 0, event_cause[i].sym, port); > + if (event->request_event_irq) > + ret = event->request_event_irq(port, event_irq, i); > + else > + ret = devm_request_irq(dev, event_irq, > + plda_event_handler, > + 0, NULL, port); > + > if (ret) { > dev_err(dev, "failed to request IRQ %d\n", event_irq); > return ret; > @@ -984,7 +1007,7 @@ static int mc_platform_init(struct pci_config_window *cfg) > return ret; > > /* Address translation is up; safe to enable interrupts */ > - ret = plda_init_interrupts(pdev, &port->plda); > + ret = plda_init_interrupts(pdev, &port->plda, &mc_event); > if (ret) > return ret; > > diff --git a/drivers/pci/controller/plda/pcie-plda.h b/drivers/pci/controller/plda/pcie-plda.h > index e3d35cef9894..28ed1374e1de 100644 > --- a/drivers/pci/controller/plda/pcie-plda.h > +++ b/drivers/pci/controller/plda/pcie-plda.h > @@ -121,6 +121,11 @@ struct plda_pcie_rp { > int num_events; > }; > > +struct plda_event { > + int (*request_event_irq)(struct plda_pcie_rp *pcie, > + int event_irq, int event); > +}; > + > void plda_pcie_setup_window(void __iomem *bridge_base_addr, u32 index, > phys_addr_t axi_addr, phys_addr_t pci_addr, > size_t size); > -- > 2.17.1 > _______________________________________________ linux-riscv mailing list linux-riscv@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-riscv
next prev parent reply other threads:[~2023-12-27 16:01 UTC|newest] Thread overview: 88+ messages / expand[flat|nested] mbox.gz Atom feed top 2023-12-14 7:28 [PATCH v13 0/21] Refactoring Microchip PCIe driver and add StarFive PCIe Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 01/21] dt-bindings: PCI: Add PLDA XpressRICH PCIe host common properties Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 02/21] PCI: microchip: Move pcie-microchip-host.c to plda directory Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 03/21] PCI: microchip: Move PLDA IP register macros to pcie-plda.h Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 04/21] PCI: microchip: Add bridge_addr field to struct mc_pcie Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 05/21] PCI: microchip: Rename two PCIe data structures Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 06/21] PCI: microchip: Move PCIe host data structures to plda-pcie.h Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 07/21] PCI: microchip: Rename two setup functions Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 08/21] PCI: microchip: Change the argument of plda_pcie_setup_iomems() Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 09/21] PCI: microchip: Move setup functions to pcie-plda-host.c Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-27 15:49 ` Lorenzo Pieralisi 2023-12-27 15:49 ` Lorenzo Pieralisi 2023-12-28 9:46 ` Minda Chen 2023-12-28 9:46 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 10/21] PCI: microchip: Rename interrupt related functions Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-27 15:52 ` Lorenzo Pieralisi 2023-12-27 15:52 ` Lorenzo Pieralisi 2023-12-29 3:44 ` Minda Chen 2023-12-29 3:44 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 11/21] PCI: microchip: Add num_events field to struct plda_pcie_rp Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-27 15:55 ` Lorenzo Pieralisi 2023-12-27 15:55 ` Lorenzo Pieralisi 2023-12-29 3:46 ` Minda Chen 2023-12-29 3:46 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 12/21] PCI: microchip: Add request_event_irq() callback function Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-27 16:01 ` Lorenzo Pieralisi [this message] 2023-12-27 16:01 ` Lorenzo Pieralisi 2023-12-28 11:58 ` Minda Chen 2023-12-28 11:58 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 13/21] PCI: microchip: Add INTx and MSI event num to struct plda_event Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 14/21] PCI: microchip: Add get_events() callback and add PLDA get_event() Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-27 16:31 ` Lorenzo Pieralisi 2023-12-27 16:31 ` Lorenzo Pieralisi 2023-12-28 10:04 ` Minda Chen 2023-12-28 10:04 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 15/21] PCI: microchip: Add event irqchip field to host port and add PLDA irqchip Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-21 10:56 ` Minda Chen 2023-12-21 10:56 ` Minda Chen 2023-12-21 15:32 ` Lorenzo Pieralisi 2023-12-21 15:32 ` Lorenzo Pieralisi 2023-12-22 11:18 ` Minda Chen 2023-12-22 11:18 ` Minda Chen 2023-12-27 12:43 ` Lorenzo Pieralisi 2023-12-27 12:43 ` Lorenzo Pieralisi 2023-12-28 11:25 ` Minda Chen 2023-12-28 11:25 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 16/21] PCI: microchip: Move IRQ functions to pcie-plda-host.c Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 17/21] PCI: plda: Add host init/deinit and map bus functions Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 18/21] dt-bindings: PCI: Add StarFive JH7110 PCIe controller Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 19/21] PCI: Add PCIE_RESET_CONFIG_DEVICE_WAIT_MS waiting time value Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-27 16:03 ` Lorenzo Pieralisi 2023-12-27 16:03 ` Lorenzo Pieralisi 2023-12-27 19:08 ` Bjorn Helgaas 2023-12-27 19:08 ` Bjorn Helgaas 2023-12-14 7:28 ` [PATCH v13 20/21] PCI: starfive: Add JH7110 PCIe controller Minda Chen 2023-12-14 7:28 ` Minda Chen 2023-12-14 7:28 ` [PATCH v13 21/21] riscv: dts: starfive: add PCIe dts configuration for JH7110 Minda Chen 2023-12-14 7:28 ` Minda Chen 2024-01-03 22:40 ` [PATCH v13 0/21] Refactoring Microchip PCIe driver and add StarFive PCIe Kevin Hilman 2024-01-03 22:40 ` Kevin Hilman 2024-01-05 2:35 ` 回复: " Kevin Xie 2024-01-05 2:35 ` Kevin Xie 2024-01-05 17:28 ` Kevin Hilman 2024-01-05 17:28 ` Kevin Hilman 2024-01-08 10:48 ` 回复: " Kevin Xie 2024-01-08 10:48 ` Kevin Xie 2024-01-10 16:29 ` Emil Renner Berthing 2024-01-10 16:29 ` Emil Renner Berthing
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=ZYxKYhVycTOfbDTI@lpieralisi \ --to=lpieralisi@kernel.org \ --cc=aou@eecs.berkeley.edu \ --cc=bhelgaas@google.com \ --cc=conor@kernel.org \ --cc=daire.mcnamara@microchip.com \ --cc=devicetree@vger.kernel.org \ --cc=emil.renner.berthing@canonical.com \ --cc=kevin.xie@starfivetech.com \ --cc=krzysztof.kozlowski+dt@linaro.org \ --cc=kw@linux.com \ --cc=leyfoon.tan@starfivetech.com \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-pci@vger.kernel.org \ --cc=linux-riscv@lists.infradead.org \ --cc=mason.huo@starfivetech.com \ --cc=minda.chen@starfivetech.com \ --cc=p.zabel@pengutronix.de \ --cc=palmer@dabbelt.com \ --cc=paul.walmsley@sifive.com \ --cc=robh+dt@kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.