From: Bjorn Helgaas <bhelgaas@google.com>
To: Marc Zyngier <marc.zyngier@arm.com>
Cc: Thomas Gleixner <tglx@linutronix.de>,
Jiang Liu <jiang.liu@linux.intel.com>,
linux-arm-kernel@lists.infradead.org, linux-pci@vger.kernel.org,
linux-kernel@vger.kernel.org, Will Deacon <Will.Deacon@arm.com>,
Yijing Wang <wangyijing@huawei.com>,
Suravee Suthikulpanit <Suravee.Suthikulpanit@amd.com>
Subject: Re: [PATCH 3/6] PCI/MSI: of: add support for OF-provided msi_domain
Date: Mon, 26 Jan 2015 18:41:20 -0600 [thread overview]
Message-ID: <20150127004120.GD11624@google.com> (raw)
In-Reply-To: <1418069543-21969-4-git-send-email-marc.zyngier@arm.com>
On Mon, Dec 08, 2014 at 08:12:20PM +0000, Marc Zyngier wrote:
> In order to populate the PHB msi_domain, use the "msi-parent"
> attribute to lookup a corresponding irq domain. If found,
> this is our MSI domain.
>
> This gets plugged into the core PCI code.
>
> Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
> ---
> drivers/pci/of.c | 15 +++++++++++++++
> drivers/pci/probe.c | 1 +
> include/linux/pci.h | 2 ++
> 3 files changed, 18 insertions(+)
>
> diff --git a/drivers/pci/of.c b/drivers/pci/of.c
> index f092993..d8d1274 100644
> --- a/drivers/pci/of.c
> +++ b/drivers/pci/of.c
> @@ -9,6 +9,7 @@
> * 2 of the License, or (at your option) any later version.
> */
>
> +#include <linux/irqdomain.h>
> #include <linux/kernel.h>
> #include <linux/pci.h>
> #include <linux/of.h>
> @@ -59,3 +60,17 @@ struct device_node * __weak pcibios_get_phb_of_node(struct pci_bus *bus)
> return of_node_get(bus->bridge->parent->of_node);
> return NULL;
> }
> +
> +void pci_set_phb_of_msi_domain(struct pci_bus *bus)
Same "phb" comment as before (also in the changelog above).
> +{
> +#ifdef CONFIG_GENERIC_MSI_IRQ_DOMAIN
> + struct device_node *np;
> +
> + if (!bus->dev.of_node)
> + return;
> + np = of_parse_phandle(bus->dev.of_node, "msi-parent", 0);
> + if (!np)
> + return;
> + dev_set_msi_domain(&bus->dev, irq_find_host(np));
> +#endif
> +}
> diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
> index d1009a2..65600e5 100644
> --- a/drivers/pci/probe.c
> +++ b/drivers/pci/probe.c
> @@ -672,6 +672,7 @@ static void pci_set_bus_speed(struct pci_bus *bus)
>
> void __weak pcibios_set_phb_msi_domain(struct pci_bus *bus)
> {
> + pci_set_phb_of_msi_domain(bus);
> }
>
> static void pci_set_bus_msi_domain(struct pci_bus *bus)
> diff --git a/include/linux/pci.h b/include/linux/pci.h
> index 3266764..6a9713f 100644
> --- a/include/linux/pci.h
> +++ b/include/linux/pci.h
> @@ -1825,6 +1825,7 @@ void pci_set_of_node(struct pci_dev *dev);
> void pci_release_of_node(struct pci_dev *dev);
> void pci_set_bus_of_node(struct pci_bus *bus);
> void pci_release_bus_of_node(struct pci_bus *bus);
> +void pci_set_phb_of_msi_domain(struct pci_bus *bus);
>
> /* Arch may override this (weak) */
> struct device_node *pcibios_get_phb_of_node(struct pci_bus *bus);
> @@ -1845,6 +1846,7 @@ static inline void pci_set_of_node(struct pci_dev *dev) { }
> static inline void pci_release_of_node(struct pci_dev *dev) { }
> static inline void pci_set_bus_of_node(struct pci_bus *bus) { }
> static inline void pci_release_bus_of_node(struct pci_bus *bus) { }
> +static inline void pci_set_phb_of_msi_domain(struct pci_bus *bus) {}
Add a space between the braces to match the others.
> #endif /* CONFIG_OF */
>
> #ifdef CONFIG_EEH
> --
> 2.1.3
>
WARNING: multiple messages have this Message-ID (diff)
From: bhelgaas@google.com (Bjorn Helgaas)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 3/6] PCI/MSI: of: add support for OF-provided msi_domain
Date: Mon, 26 Jan 2015 18:41:20 -0600 [thread overview]
Message-ID: <20150127004120.GD11624@google.com> (raw)
In-Reply-To: <1418069543-21969-4-git-send-email-marc.zyngier@arm.com>
On Mon, Dec 08, 2014 at 08:12:20PM +0000, Marc Zyngier wrote:
> In order to populate the PHB msi_domain, use the "msi-parent"
> attribute to lookup a corresponding irq domain. If found,
> this is our MSI domain.
>
> This gets plugged into the core PCI code.
>
> Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
> ---
> drivers/pci/of.c | 15 +++++++++++++++
> drivers/pci/probe.c | 1 +
> include/linux/pci.h | 2 ++
> 3 files changed, 18 insertions(+)
>
> diff --git a/drivers/pci/of.c b/drivers/pci/of.c
> index f092993..d8d1274 100644
> --- a/drivers/pci/of.c
> +++ b/drivers/pci/of.c
> @@ -9,6 +9,7 @@
> * 2 of the License, or (at your option) any later version.
> */
>
> +#include <linux/irqdomain.h>
> #include <linux/kernel.h>
> #include <linux/pci.h>
> #include <linux/of.h>
> @@ -59,3 +60,17 @@ struct device_node * __weak pcibios_get_phb_of_node(struct pci_bus *bus)
> return of_node_get(bus->bridge->parent->of_node);
> return NULL;
> }
> +
> +void pci_set_phb_of_msi_domain(struct pci_bus *bus)
Same "phb" comment as before (also in the changelog above).
> +{
> +#ifdef CONFIG_GENERIC_MSI_IRQ_DOMAIN
> + struct device_node *np;
> +
> + if (!bus->dev.of_node)
> + return;
> + np = of_parse_phandle(bus->dev.of_node, "msi-parent", 0);
> + if (!np)
> + return;
> + dev_set_msi_domain(&bus->dev, irq_find_host(np));
> +#endif
> +}
> diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
> index d1009a2..65600e5 100644
> --- a/drivers/pci/probe.c
> +++ b/drivers/pci/probe.c
> @@ -672,6 +672,7 @@ static void pci_set_bus_speed(struct pci_bus *bus)
>
> void __weak pcibios_set_phb_msi_domain(struct pci_bus *bus)
> {
> + pci_set_phb_of_msi_domain(bus);
> }
>
> static void pci_set_bus_msi_domain(struct pci_bus *bus)
> diff --git a/include/linux/pci.h b/include/linux/pci.h
> index 3266764..6a9713f 100644
> --- a/include/linux/pci.h
> +++ b/include/linux/pci.h
> @@ -1825,6 +1825,7 @@ void pci_set_of_node(struct pci_dev *dev);
> void pci_release_of_node(struct pci_dev *dev);
> void pci_set_bus_of_node(struct pci_bus *bus);
> void pci_release_bus_of_node(struct pci_bus *bus);
> +void pci_set_phb_of_msi_domain(struct pci_bus *bus);
>
> /* Arch may override this (weak) */
> struct device_node *pcibios_get_phb_of_node(struct pci_bus *bus);
> @@ -1845,6 +1846,7 @@ static inline void pci_set_of_node(struct pci_dev *dev) { }
> static inline void pci_release_of_node(struct pci_dev *dev) { }
> static inline void pci_set_bus_of_node(struct pci_bus *bus) { }
> static inline void pci_release_bus_of_node(struct pci_bus *bus) { }
> +static inline void pci_set_phb_of_msi_domain(struct pci_bus *bus) {}
Add a space between the braces to match the others.
> #endif /* CONFIG_OF */
>
> #ifdef CONFIG_EEH
> --
> 2.1.3
>
next prev parent reply other threads:[~2015-01-27 0:41 UTC|newest]
Thread overview: 46+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-12-08 20:12 [PATCH 0/6] Introducing per-device MSI domain Marc Zyngier
2014-12-08 20:12 ` Marc Zyngier
2014-12-08 20:12 ` [PATCH 1/6] device core: Introduce per-device MSI domain pointer Marc Zyngier
2014-12-08 20:12 ` Marc Zyngier
2014-12-08 20:12 ` [PATCH 2/6] PCI/MSI: add hooks to populate the msi_domain field Marc Zyngier
2014-12-08 20:12 ` Marc Zyngier
2014-12-09 2:03 ` Yijing Wang
2014-12-09 2:03 ` Yijing Wang
2014-12-09 10:02 ` Marc Zyngier
2014-12-09 10:02 ` Marc Zyngier
2014-12-09 11:57 ` Yijing Wang
2014-12-09 11:57 ` Yijing Wang
2014-12-09 12:12 ` Marc Zyngier
2014-12-09 12:12 ` Marc Zyngier
2014-12-09 12:24 ` Yijing Wang
2014-12-09 12:24 ` Yijing Wang
2014-12-09 12:47 ` Jiang Liu
2014-12-09 12:47 ` Jiang Liu
2014-12-09 14:03 ` Marc Zyngier
2014-12-09 14:03 ` Marc Zyngier
2014-12-09 14:11 ` Jiang Liu
2014-12-09 14:11 ` Jiang Liu
2014-12-09 14:27 ` Marc Zyngier
2014-12-09 14:27 ` Marc Zyngier
2014-12-09 14:35 ` Jiang Liu
2014-12-09 14:35 ` Jiang Liu
2014-12-09 14:59 ` Marc Zyngier
2014-12-09 14:59 ` Marc Zyngier
2014-12-09 15:42 ` Jiang Liu
2014-12-09 15:42 ` Jiang Liu
2014-12-09 12:57 ` Jiang Liu
2014-12-09 12:57 ` Jiang Liu
2015-01-27 0:40 ` Bjorn Helgaas
2015-01-27 0:40 ` Bjorn Helgaas
2015-01-27 0:43 ` Bjorn Helgaas
2015-01-27 0:43 ` Bjorn Helgaas
2014-12-08 20:12 ` [PATCH 3/6] PCI/MSI: of: add support for OF-provided msi_domain Marc Zyngier
2014-12-08 20:12 ` Marc Zyngier
2015-01-27 0:41 ` Bjorn Helgaas [this message]
2015-01-27 0:41 ` Bjorn Helgaas
2014-12-08 20:12 ` [PATCH 4/6] PCI/MSI: Let pci_msi_get_domain use struct device's msi_domain Marc Zyngier
2014-12-08 20:12 ` Marc Zyngier
2014-12-08 20:12 ` [PATCH 5/6] irqchip: GICv2m: Get rid of struct msi_controller Marc Zyngier
2014-12-08 20:12 ` Marc Zyngier
2014-12-08 20:12 ` [PATCH 6/6] irqchip: gicv3-its: " Marc Zyngier
2014-12-08 20:12 ` Marc Zyngier
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=20150127004120.GD11624@google.com \
--to=bhelgaas@google.com \
--cc=Suravee.Suthikulpanit@amd.com \
--cc=Will.Deacon@arm.com \
--cc=jiang.liu@linux.intel.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pci@vger.kernel.org \
--cc=marc.zyngier@arm.com \
--cc=tglx@linutronix.de \
--cc=wangyijing@huawei.com \
/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 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.