From: tip-bot for Marc Zyngier <tipbot@zytor.com>
To: linux-tip-commits@vger.kernel.org
Cc: tglx@linutronix.de, lorenzo.pieralisi@arm.com,
majun258@huawei.com, hpa@zytor.com, dhdang@apm.com,
marc.zyngier@arm.com, wangyijing@huawei.com, bhelgaas@google.com,
linux-kernel@vger.kernel.org, hanjun.guo@linaro.org,
mingo@kernel.org, jason@lakedaemon.net,
linux-arm-kernel@lists.infradead.org, jiang.liu@linux.intel.com
Subject: [tip:irq/core] irqchip/GICv2m: Add platform MSI support
Date: Wed, 29 Jul 2015 15:30:30 -0700 [thread overview]
Message-ID: <tip-ef50645aa32c6b55fe1445b5d06c73bfdf65019f@git.kernel.org> (raw)
In-Reply-To: <1438091186-10244-18-git-send-email-marc.zyngier@arm.com>
Commit-ID: ef50645aa32c6b55fe1445b5d06c73bfdf65019f
Gitweb: http://git.kernel.org/tip/ef50645aa32c6b55fe1445b5d06c73bfdf65019f
Author: Marc Zyngier <marc.zyngier@arm.com>
AuthorDate: Tue, 28 Jul 2015 14:46:24 +0100
Committer: Thomas Gleixner <tglx@linutronix.de>
CommitDate: Thu, 30 Jul 2015 00:14:39 +0200
irqchip/GICv2m: Add platform MSI support
In order to support non-PCI MSI with GICv2m, add the minimal
required entry points for the MSI domain, which is actually almost
nothing (we just use the defaults provided by the core code).
Signed-off-by: Marc Zyngier <marc.zyngier@arm.com>
Cc: <linux-arm-kernel@lists.infradead.org>
Cc: Yijing Wang <wangyijing@huawei.com>
Cc: Ma Jun <majun258@huawei.com>
Cc: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Cc: Duc Dang <dhdang@apm.com>
Cc: Hanjun Guo <hanjun.guo@linaro.org>
Cc: Bjorn Helgaas <bhelgaas@google.com>
Cc: Jiang Liu <jiang.liu@linux.intel.com>
Cc: Jason Cooper <jason@lakedaemon.net>
Link: http://lkml.kernel.org/r/1438091186-10244-18-git-send-email-marc.zyngier@arm.com
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
---
drivers/irqchip/irq-gic-v2m.c | 33 +++++++++++++++++++++++++--------
1 file changed, 25 insertions(+), 8 deletions(-)
diff --git a/drivers/irqchip/irq-gic-v2m.c b/drivers/irqchip/irq-gic-v2m.c
index ec9c376..db04fc1 100644
--- a/drivers/irqchip/irq-gic-v2m.c
+++ b/drivers/irqchip/irq-gic-v2m.c
@@ -50,7 +50,6 @@ struct v2m_data {
u32 spi_start; /* The SPI number that MSIs start */
u32 nr_spis; /* The number of SPIs for MSIs */
unsigned long *bm; /* MSI vector bitmap */
- struct irq_domain *domain;
};
static void gicv2m_mask_msi_irq(struct irq_data *d)
@@ -212,12 +211,25 @@ static bool is_msi_spi_valid(u32 base, u32 num)
return true;
}
+static struct irq_chip gicv2m_pmsi_irq_chip = {
+ .name = "pMSI",
+};
+
+static struct msi_domain_ops gicv2m_pmsi_ops = {
+};
+
+static struct msi_domain_info gicv2m_pmsi_domain_info = {
+ .flags = (MSI_FLAG_USE_DEF_DOM_OPS | MSI_FLAG_USE_DEF_CHIP_OPS),
+ .ops = &gicv2m_pmsi_ops,
+ .chip = &gicv2m_pmsi_irq_chip,
+};
+
static int __init gicv2m_init_one(struct device_node *node,
struct irq_domain *parent)
{
int ret;
struct v2m_data *v2m;
- struct irq_domain *inner_domain;
+ struct irq_domain *inner_domain, *pci_domain, *plat_domain;
v2m = kzalloc(sizeof(struct v2m_data), GFP_KERNEL);
if (!v2m) {
@@ -270,10 +282,13 @@ static int __init gicv2m_init_one(struct device_node *node,
inner_domain->bus_token = DOMAIN_BUS_NEXUS;
inner_domain->parent = parent;
- v2m->domain = pci_msi_create_irq_domain(node, &gicv2m_msi_domain_info,
- inner_domain);
- if (!v2m->domain) {
- pr_err("Failed to create MSI domain\n");
+ pci_domain = pci_msi_create_irq_domain(node, &gicv2m_msi_domain_info,
+ inner_domain);
+ plat_domain = platform_msi_create_irq_domain(node,
+ &gicv2m_pmsi_domain_info,
+ inner_domain);
+ if (!pci_domain || !plat_domain) {
+ pr_err("Failed to create MSI domains\n");
ret = -ENOMEM;
goto err_free_domains;
}
@@ -287,8 +302,10 @@ static int __init gicv2m_init_one(struct device_node *node,
return 0;
err_free_domains:
- if (v2m->domain)
- irq_domain_remove(v2m->domain);
+ if (plat_domain)
+ irq_domain_remove(plat_domain);
+ if (pci_domain)
+ irq_domain_remove(pci_domain);
if (inner_domain)
irq_domain_remove(inner_domain);
err_free_bm:
next prev parent reply other threads:[~2015-07-29 22:31 UTC|newest]
Thread overview: 60+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-07-28 13:46 [PATCH v6 00/19] Per-device MSI domain & platform MSI Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 01/19] genirq: irqdomain: Allow irq domain aliasing Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:24 ` [tip:irq/core] genirq/irqdomain: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 02/19] PCI: MSI: Register irq domain with specific token Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:25 ` [tip:irq/core] PCI/MSI: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 03/19] device core: Introduce per-device MSI domain pointer Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:25 ` [tip:irq/core] " tip-bot for Marc Zyngier
2015-07-29 22:25 ` tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 04/19] PCI/MSI: Add hooks to populate the msi_domain field Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:25 ` [tip:irq/core] " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 05/19] PCI/MSI: of: Add support for OF-provided msi_domain Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:26 ` [tip:irq/core] PCI/MSI: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 06/19] PCI/MSI: of: Allow msi_domain lookup using the host bridge node Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:26 ` [tip:irq/core] PCI/MSI: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 07/19] PCI/MSI: Let pci_msi_get_domain use struct device's msi_domain Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:26 ` [tip:irq/core] PCI/MSI: Let pci_msi_get_domain use struct device: :msi_domain tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 08/19] platform: of: Assign MSI domain to platform device Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:27 ` [tip:irq/core] of/platform: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 09/19] drivers: base: Add MSI domain support for non-PCI devices Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:27 ` [tip:irq/core] drivers/base: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 10/19] genirq: Add DOMAIN_BUS_NEXUS irqdomain property Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:28 ` [tip:irq/core] " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 11/19] irqchip: gicv3-its: Split PCI/MSI code from the core ITS driver Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:28 ` [tip:irq/core] irqchip/gicv3-its: Split PCI/ MSI " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 12/19] irqchip: gicv3-its: Register irq domain with NEXUS token Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:28 ` [tip:irq/core] irqchip/gicv3-its: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 13/19] irqchip: gicv3-its: Get rid of struct msi_controller Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:29 ` [tip:irq/core] irqchip/gicv3-its: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 14/19] irqchip: gicv3-its: Make the PCI/MSI code standalone Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:29 ` [tip:irq/core] irqchip/gicv3-its: Make the PCI/ MSI " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 15/19] irqchip: gicv3-its: Add platform MSI support Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:29 ` [tip:irq/core] irqchip/gicv3-its: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 16/19] irqchip: GICv2m: Get rid of struct msi_controller Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:30 ` [tip:irq/core] irqchip/GICv2m: " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 17/19] irqchip: GICv2m: Add platform MSI support Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:30 ` tip-bot for Marc Zyngier [this message]
2015-07-28 13:46 ` [PATCH v6 18/19] PCI/MSI: pci-xgene-msi: Get rid of struct msi_controller Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:30 ` [tip:irq/core] " tip-bot for Marc Zyngier
2015-07-28 13:46 ` [PATCH v6 19/19] PCI/MSI: Drop domain field from msi_controller Marc Zyngier
2015-07-28 13:46 ` Marc Zyngier
2015-07-29 22:31 ` [tip:irq/core] " tip-bot for 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=tip-ef50645aa32c6b55fe1445b5d06c73bfdf65019f@git.kernel.org \
--to=tipbot@zytor.com \
--cc=bhelgaas@google.com \
--cc=dhdang@apm.com \
--cc=hanjun.guo@linaro.org \
--cc=hpa@zytor.com \
--cc=jason@lakedaemon.net \
--cc=jiang.liu@linux.intel.com \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-tip-commits@vger.kernel.org \
--cc=lorenzo.pieralisi@arm.com \
--cc=majun258@huawei.com \
--cc=marc.zyngier@arm.com \
--cc=mingo@kernel.org \
--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.