From: Minda Chen <minda.chen@starfivetech.com>
To: Lorenzo Pieralisi <lpieralisi@kernel.org>
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 v12 15/21] PCI: microchip: Add event IRQ domain ops to struct plda_event
Date: Wed, 13 Dec 2023 16:15:39 +0800 [thread overview]
Message-ID: <9523aa6b-55a8-4e6a-a3ba-45d9b1dacc77@starfivetech.com> (raw)
In-Reply-To: <ZXhB1kKpElgKx8vm@lpieralisi>
On 2023/12/12 19:19, Lorenzo Pieralisi wrote:
> On Wed, Dec 06, 2023 at 06:58:33PM +0800, Minda Chen wrote:
>> For lack of an MSI controller, The new added PCIe interrupts have to be
>> added to global interrupt event field. PolarFire event domain ops can not
>> be re-used.
>
> I don't understand what this means, please explain and I will
> add it to the commit log.
>
Sorry.
Microchip Polarfire PCIe adds 11 PCIe interrupts to PCIe global event domain.(Total 28 PCIe interrupts)
The microchip event domain and event irqchip will handle these interrupts.
But PLDA host contain 13 fixed PCIe interrupts. PLDA codes just process these
13 interrupts. Microchip the event irq codes are quite different and can't be used by PLDA codes.
So add an event domain field support microchip and other vendor who just using the PLDA interrupts.
>> PLDA event domain ops instances will be implemented in later patch.
>
> Future patches don't exist, each commit log is a logical change
> that must make sense on its own, I will remove this sentence.
>
> Lorenzo
OK, Thanks.
>> Signed-off-by: Minda Chen <minda.chen@starfivetech.com>
>> Acked-by: Conor Dooley <conor.dooley@microchip.com>
>> ---
>> drivers/pci/controller/plda/pcie-microchip-host.c | 6 ++++--
>> drivers/pci/controller/plda/pcie-plda.h | 1 +
>> 2 files changed, 5 insertions(+), 2 deletions(-)
>>
>> diff --git a/drivers/pci/controller/plda/pcie-microchip-host.c b/drivers/pci/controller/plda/pcie-microchip-host.c
>> index f5e7da242aec..e6dcc572b65b 100644
>> --- a/drivers/pci/controller/plda/pcie-microchip-host.c
>> +++ b/drivers/pci/controller/plda/pcie-microchip-host.c
>> @@ -821,13 +821,15 @@ static const struct plda_event_ops mc_event_ops = {
>> };
>>
>> static const struct plda_event mc_event = {
>> + .domain_ops = &mc_event_domain_ops,
>> .event_ops = &mc_event_ops,
>> .request_event_irq = mc_request_event_irq,
>> .intx_event = EVENT_LOCAL_PM_MSI_INT_INTX,
>> .msi_event = EVENT_LOCAL_PM_MSI_INT_MSI,
>> };
>>
>> -static int plda_pcie_init_irq_domains(struct plda_pcie_rp *port)
>> +static int plda_pcie_init_irq_domains(struct plda_pcie_rp *port,
>> + const struct irq_domain_ops *ops)
>> {
>> struct device *dev = port->dev;
>> struct device_node *node = dev->of_node;
>> @@ -941,7 +943,7 @@ static int plda_init_interrupts(struct platform_device *pdev,
>> return -EINVAL;
>> }
>>
>> - ret = plda_pcie_init_irq_domains(port);
>> + ret = plda_pcie_init_irq_domains(port, event->domain_ops);
>> if (ret) {
>> dev_err(dev, "failed creating IRQ domains\n");
>> return ret;
>> diff --git a/drivers/pci/controller/plda/pcie-plda.h b/drivers/pci/controller/plda/pcie-plda.h
>> index df1729095952..820ea16855b5 100644
>> --- a/drivers/pci/controller/plda/pcie-plda.h
>> +++ b/drivers/pci/controller/plda/pcie-plda.h
>> @@ -129,6 +129,7 @@ struct plda_pcie_rp {
>> };
>>
>> struct plda_event {
>> + const struct irq_domain_ops *domain_ops;
>> const struct plda_event_ops *event_ops;
>> int (*request_event_irq)(struct plda_pcie_rp *pcie,
>> int event_irq, int event);
>> --
>> 2.17.1
>>
next prev parent reply other threads:[~2023-12-13 8:15 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-12-06 10:58 [PATCH v12 0/21] Refactoring Microchip PCIe driver and add StarFive PCIe Minda Chen
2023-12-06 10:58 ` [PATCH v12 01/21] dt-bindings: PCI: Add PLDA XpressRICH PCIe host common properties Minda Chen
2023-12-06 10:58 ` [PATCH v12 02/21] PCI: microchip: Move pcie-microchip-host.c to plda directory Minda Chen
2023-12-06 10:58 ` [PATCH v12 03/21] PCI: microchip: Move PLDA IP register macros to pcie-plda.h Minda Chen
2023-12-06 10:58 ` [PATCH v12 04/21] PCI: microchip: Add bridge_addr field to struct mc_pcie Minda Chen
2023-12-06 10:58 ` [PATCH v12 05/21] PCI: microchip: Rename two PCIe data structures Minda Chen
2023-12-06 10:58 ` [PATCH v12 06/21] PCI: microchip: Move PCIe host data structures to plda-pcie.h Minda Chen
2023-12-06 10:58 ` [PATCH v12 07/21] PCI: microchip: Rename two setup functions Minda Chen
2023-12-06 10:58 ` [PATCH v12 08/21] PCI: microchip: Change the argument of plda_pcie_setup_iomems() Minda Chen
2023-12-06 10:58 ` [PATCH v12 09/21] PCI: microchip: Move setup functions to pcie-plda-host.c Minda Chen
2023-12-06 10:58 ` [PATCH v12 10/21] PCI: microchip: Rename interrupt related functions Minda Chen
2023-12-06 10:58 ` [PATCH v12 11/21] PCI: microchip: Add num_events field to struct plda_pcie_rp Minda Chen
2023-12-06 10:58 ` [PATCH v12 12/21] PCI: microchip: Add request_event_irq() callback function Minda Chen
2023-12-06 10:58 ` [PATCH v12 13/21] PCI: microchip: Add INTx and MSI event num to struct plda_event Minda Chen
2023-12-06 10:58 ` [PATCH v12 14/21] PCI: microchip: Add get_events() callback function Minda Chen
2023-12-06 10:58 ` [PATCH v12 15/21] PCI: microchip: Add event IRQ domain ops to struct plda_event Minda Chen
2023-12-12 11:19 ` Lorenzo Pieralisi
2023-12-13 8:15 ` Minda Chen [this message]
2023-12-13 9:50 ` Lorenzo Pieralisi
2023-12-13 10:21 ` Minda Chen
2023-12-06 10:58 ` [PATCH v12 16/21] PCI: microchip: Move IRQ functions to pcie-plda-host.c Minda Chen
2023-12-06 10:58 ` [PATCH v12 17/21] PCI: plda: Add event interrupt codes and host init/deinit functions Minda Chen
2023-12-06 10:58 ` [PATCH v12 18/21] dt-bindings: PCI: Add StarFive JH7110 PCIe controller Minda Chen
2023-12-06 10:58 ` [PATCH v12 19/21] PCI: Add PCIE_RESET_CONFIG_DEVICE_WAIT_MS waiting time value Minda Chen
2023-12-06 10:58 ` [PATCH v12 20/21] PCI: starfive: Add JH7110 PCIe controller Minda Chen
2023-12-06 10:58 ` [PATCH v12 21/21] riscv: dts: starfive: add PCIe dts configuration for JH7110 Minda Chen
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=9523aa6b-55a8-4e6a-a3ba-45d9b1dacc77@starfivetech.com \
--to=minda.chen@starfivetech.com \
--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=lpieralisi@kernel.org \
--cc=mason.huo@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: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).