All of lore.kernel.org
 help / color / mirror / Atom feed
From: Thierry Reding <thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
To: linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Cc: Jason Gunthorpe
	<jgunthorpe-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>,
	Russell King <linux-lFZ/pmaqli7XmaaqVzeoHQ@public.gmane.org>,
	linux-pci-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org,
	Liviu Dudau <Liviu.Dudau-5wv7dgnIgG8@public.gmane.org>,
	linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	Rob Herring <rob.herring-bsGFqQB8/DxBDgjK7y7TUQ@public.gmane.org>,
	Bjorn Helgaas <bhelgaas-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
	Andrew Murray <Andrew.Murray-5wv7dgnIgG8@public.gmane.org>,
	linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org
Subject: [PATCH 01/14] of/pci: Provide support for parsing PCI DT ranges property
Date: Wed,  9 Jan 2013 21:43:01 +0100	[thread overview]
Message-ID: <1357764194-12677-2-git-send-email-thierry.reding@avionic-design.de> (raw)
In-Reply-To: <1357764194-12677-1-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>

From: Andrew Murray <andrew.murray-5wv7dgnIgG8@public.gmane.org>

DT bindings for PCI host bridges often use the ranges property to describe
memory and IO ranges - this binding tends to be the same across architectures
yet several parsing implementations exist, e.g. arch/mips/pci/pci.c,
arch/powerpc/kernel/pci-common.c, arch/sparc/kernel/pci.c and
arch/microblaze/pci/pci-common.c (clone of PPC). Some of these duplicate
functionality provided by drivers/of/address.c.

This patch provides a common iterator-based parser for the ranges property, it
is hoped this will reduce DT representation differences between architectures
and that architectures will migrate in part to this new parser.

It is also hoped (and the motativation for the patch) that this patch will
reduce duplication of code when writing host bridge drivers that are supported
by multiple architectures.

This patch provides struct resources from a device tree node, e.g.:

	u32 *last = NULL;
	struct resource res;
	while ((last = of_pci_process_ranges(np, res, last))) {
		//do something with res
	}

Platforms with quirks can then do what they like with the resource or migrate
common quirk handling to the parser. In an ideal world drivers can just request
the obtained resources and pass them on (e.g. pci_add_resource_offset).

Signed-off-by: Andrew Murray <Andrew.Murray-5wv7dgnIgG8@public.gmane.org>
Signed-off-by: Liviu Dudau <Liviu.Dudau-5wv7dgnIgG8@public.gmane.org>
Signed-off-by: Thierry Reding <thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
---
 drivers/of/address.c       | 63 ++++++++++++++++++++++++++++++++++++++++++++++
 include/linux/of_address.h |  9 +++++++
 2 files changed, 72 insertions(+)

diff --git a/drivers/of/address.c b/drivers/of/address.c
index 0125524..d659527 100644
--- a/drivers/of/address.c
+++ b/drivers/of/address.c
@@ -13,6 +13,7 @@
 #define OF_CHECK_COUNTS(na, ns)	(OF_CHECK_ADDR_COUNT(na) && (ns) > 0)
 
 static struct of_bus *of_match_bus(struct device_node *np);
+static struct of_bus *of_find_bus(const char *name);
 static int __of_address_to_resource(struct device_node *dev,
 		const __be32 *addrp, u64 size, unsigned int flags,
 		const char *name, struct resource *r);
@@ -227,6 +228,57 @@ int of_pci_address_to_resource(struct device_node *dev, int bar,
 	return __of_address_to_resource(dev, addrp, size, flags, NULL, r);
 }
 EXPORT_SYMBOL_GPL(of_pci_address_to_resource);
+
+const __be32 *of_pci_process_ranges(struct device_node *node,
+				    struct resource *res, const __be32 *from)
+{
+	const __be32 *start, *end;
+	int na, ns, np, pna;
+	int rlen;
+	struct of_bus *bus;
+
+	WARN_ON(!res);
+
+	bus = of_find_bus("pci");
+	bus->count_cells(node, &na, &ns);
+	if (!OF_CHECK_COUNTS(na, ns)) {
+		pr_err("Bad cell count for %s\n", node->full_name);
+		return NULL;
+	}
+
+	pna = of_n_addr_cells(node);
+	np = pna + na + ns;
+
+	start = of_get_property(node, "ranges", &rlen);
+	if (start == NULL)
+		return NULL;
+
+	end = start + rlen / sizeof(__be32);
+
+	if (!from)
+		from = start;
+
+	while (from + np <= end) {
+		u64 cpu_addr, size;
+
+		cpu_addr = of_translate_address(node, from + na);
+		size = of_read_number(from + na + pna, ns);
+		res->flags = bus->get_flags(from);
+		from += np;
+
+		if (cpu_addr == OF_BAD_ADDR || size == 0)
+			continue;
+
+		res->name = node->full_name;
+		res->start = cpu_addr;
+		res->end = res->start + size - 1;
+		res->parent = res->child = res->sibling = NULL;
+		return from;
+	}
+
+	return NULL;
+}
+EXPORT_SYMBOL_GPL(of_pci_process_ranges);
 #endif /* CONFIG_PCI */
 
 /*
@@ -337,6 +389,17 @@ static struct of_bus *of_match_bus(struct device_node *np)
 	return NULL;
 }
 
+static struct of_bus *of_find_bus(const char *name)
+{
+	unsigned int i;
+
+	for (i = 0; i < ARRAY_SIZE(of_busses); i++)
+		if (strcmp(name, of_busses[i].name) == 0)
+			return &of_busses[i];
+
+	return NULL;
+}
+
 static int of_translate_one(struct device_node *parent, struct of_bus *bus,
 			    struct of_bus *pbus, __be32 *addr,
 			    int na, int ns, int pna, const char *rprop)
diff --git a/include/linux/of_address.h b/include/linux/of_address.h
index 0506eb5..751e889 100644
--- a/include/linux/of_address.h
+++ b/include/linux/of_address.h
@@ -27,6 +27,8 @@ static inline unsigned long pci_address_to_pio(phys_addr_t addr) { return -1; }
 #define pci_address_to_pio pci_address_to_pio
 #endif
 
+const __be32 *of_pci_process_ranges(struct device_node *node,
+				    struct resource *res, const __be32 *from);
 #else /* CONFIG_OF_ADDRESS */
 #ifndef of_address_to_resource
 static inline int of_address_to_resource(struct device_node *dev, int index,
@@ -53,6 +55,13 @@ static inline const __be32 *of_get_address(struct device_node *dev, int index,
 {
 	return NULL;
 }
+
+static inline const __be32 *of_pci_process_ranges(struct device_node *node,
+						  struct resource *res,
+						  const __be32 *from)
+{
+	return NULL;
+}
 #endif /* CONFIG_OF_ADDRESS */
 
 
-- 
1.8.1

WARNING: multiple messages have this Message-ID (diff)
From: Thierry Reding <thierry.reding@avionic-design.de>
To: linux-tegra@vger.kernel.org
Cc: Andrew Murray <andrew.murray@arm.com>,
	Andrew Murray <Andrew.Murray@arm.com>,
	Liviu Dudau <Liviu.Dudau@arm.com>,
	Grant Likely <grant.likely@secretlab.ca>,
	Rob Herring <rob.herring@calxeda.com>,
	Russell King <linux@arm.linux.org.uk>,
	Stephen Warren <swarren@wwwdotorg.org>,
	Bjorn Helgaas <bhelgaas@google.com>,
	Jason Gunthorpe <jgunthorpe@obsidianresearch.com>,
	Arnd Bergmann <arnd@arndb.de>,
	Thomas Petazzoni <thomas.petazzoni@free-electrons.com>,
	devicetree-discuss@lists.ozlabs.org,
	linux-kernel@vger.kernel.org,
	linux-arm-kernel@lists.infradead.org, linux-pci@vger.kernel.org
Subject: [PATCH 01/14] of/pci: Provide support for parsing PCI DT ranges property
Date: Wed,  9 Jan 2013 21:43:01 +0100	[thread overview]
Message-ID: <1357764194-12677-2-git-send-email-thierry.reding@avionic-design.de> (raw)
In-Reply-To: <1357764194-12677-1-git-send-email-thierry.reding@avionic-design.de>

From: Andrew Murray <andrew.murray@arm.com>

DT bindings for PCI host bridges often use the ranges property to describe
memory and IO ranges - this binding tends to be the same across architectures
yet several parsing implementations exist, e.g. arch/mips/pci/pci.c,
arch/powerpc/kernel/pci-common.c, arch/sparc/kernel/pci.c and
arch/microblaze/pci/pci-common.c (clone of PPC). Some of these duplicate
functionality provided by drivers/of/address.c.

This patch provides a common iterator-based parser for the ranges property, it
is hoped this will reduce DT representation differences between architectures
and that architectures will migrate in part to this new parser.

It is also hoped (and the motativation for the patch) that this patch will
reduce duplication of code when writing host bridge drivers that are supported
by multiple architectures.

This patch provides struct resources from a device tree node, e.g.:

	u32 *last = NULL;
	struct resource res;
	while ((last = of_pci_process_ranges(np, res, last))) {
		//do something with res
	}

Platforms with quirks can then do what they like with the resource or migrate
common quirk handling to the parser. In an ideal world drivers can just request
the obtained resources and pass them on (e.g. pci_add_resource_offset).

Signed-off-by: Andrew Murray <Andrew.Murray@arm.com>
Signed-off-by: Liviu Dudau <Liviu.Dudau@arm.com>
Signed-off-by: Thierry Reding <thierry.reding@avionic-design.de>
---
 drivers/of/address.c       | 63 ++++++++++++++++++++++++++++++++++++++++++++++
 include/linux/of_address.h |  9 +++++++
 2 files changed, 72 insertions(+)

diff --git a/drivers/of/address.c b/drivers/of/address.c
index 0125524..d659527 100644
--- a/drivers/of/address.c
+++ b/drivers/of/address.c
@@ -13,6 +13,7 @@
 #define OF_CHECK_COUNTS(na, ns)	(OF_CHECK_ADDR_COUNT(na) && (ns) > 0)
 
 static struct of_bus *of_match_bus(struct device_node *np);
+static struct of_bus *of_find_bus(const char *name);
 static int __of_address_to_resource(struct device_node *dev,
 		const __be32 *addrp, u64 size, unsigned int flags,
 		const char *name, struct resource *r);
@@ -227,6 +228,57 @@ int of_pci_address_to_resource(struct device_node *dev, int bar,
 	return __of_address_to_resource(dev, addrp, size, flags, NULL, r);
 }
 EXPORT_SYMBOL_GPL(of_pci_address_to_resource);
+
+const __be32 *of_pci_process_ranges(struct device_node *node,
+				    struct resource *res, const __be32 *from)
+{
+	const __be32 *start, *end;
+	int na, ns, np, pna;
+	int rlen;
+	struct of_bus *bus;
+
+	WARN_ON(!res);
+
+	bus = of_find_bus("pci");
+	bus->count_cells(node, &na, &ns);
+	if (!OF_CHECK_COUNTS(na, ns)) {
+		pr_err("Bad cell count for %s\n", node->full_name);
+		return NULL;
+	}
+
+	pna = of_n_addr_cells(node);
+	np = pna + na + ns;
+
+	start = of_get_property(node, "ranges", &rlen);
+	if (start == NULL)
+		return NULL;
+
+	end = start + rlen / sizeof(__be32);
+
+	if (!from)
+		from = start;
+
+	while (from + np <= end) {
+		u64 cpu_addr, size;
+
+		cpu_addr = of_translate_address(node, from + na);
+		size = of_read_number(from + na + pna, ns);
+		res->flags = bus->get_flags(from);
+		from += np;
+
+		if (cpu_addr == OF_BAD_ADDR || size == 0)
+			continue;
+
+		res->name = node->full_name;
+		res->start = cpu_addr;
+		res->end = res->start + size - 1;
+		res->parent = res->child = res->sibling = NULL;
+		return from;
+	}
+
+	return NULL;
+}
+EXPORT_SYMBOL_GPL(of_pci_process_ranges);
 #endif /* CONFIG_PCI */
 
 /*
@@ -337,6 +389,17 @@ static struct of_bus *of_match_bus(struct device_node *np)
 	return NULL;
 }
 
+static struct of_bus *of_find_bus(const char *name)
+{
+	unsigned int i;
+
+	for (i = 0; i < ARRAY_SIZE(of_busses); i++)
+		if (strcmp(name, of_busses[i].name) == 0)
+			return &of_busses[i];
+
+	return NULL;
+}
+
 static int of_translate_one(struct device_node *parent, struct of_bus *bus,
 			    struct of_bus *pbus, __be32 *addr,
 			    int na, int ns, int pna, const char *rprop)
diff --git a/include/linux/of_address.h b/include/linux/of_address.h
index 0506eb5..751e889 100644
--- a/include/linux/of_address.h
+++ b/include/linux/of_address.h
@@ -27,6 +27,8 @@ static inline unsigned long pci_address_to_pio(phys_addr_t addr) { return -1; }
 #define pci_address_to_pio pci_address_to_pio
 #endif
 
+const __be32 *of_pci_process_ranges(struct device_node *node,
+				    struct resource *res, const __be32 *from);
 #else /* CONFIG_OF_ADDRESS */
 #ifndef of_address_to_resource
 static inline int of_address_to_resource(struct device_node *dev, int index,
@@ -53,6 +55,13 @@ static inline const __be32 *of_get_address(struct device_node *dev, int index,
 {
 	return NULL;
 }
+
+static inline const __be32 *of_pci_process_ranges(struct device_node *node,
+						  struct resource *res,
+						  const __be32 *from)
+{
+	return NULL;
+}
 #endif /* CONFIG_OF_ADDRESS */
 
 
-- 
1.8.1


WARNING: multiple messages have this Message-ID (diff)
From: thierry.reding@avionic-design.de (Thierry Reding)
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH 01/14] of/pci: Provide support for parsing PCI DT ranges property
Date: Wed,  9 Jan 2013 21:43:01 +0100	[thread overview]
Message-ID: <1357764194-12677-2-git-send-email-thierry.reding@avionic-design.de> (raw)
In-Reply-To: <1357764194-12677-1-git-send-email-thierry.reding@avionic-design.de>

From: Andrew Murray <andrew.murray@arm.com>

DT bindings for PCI host bridges often use the ranges property to describe
memory and IO ranges - this binding tends to be the same across architectures
yet several parsing implementations exist, e.g. arch/mips/pci/pci.c,
arch/powerpc/kernel/pci-common.c, arch/sparc/kernel/pci.c and
arch/microblaze/pci/pci-common.c (clone of PPC). Some of these duplicate
functionality provided by drivers/of/address.c.

This patch provides a common iterator-based parser for the ranges property, it
is hoped this will reduce DT representation differences between architectures
and that architectures will migrate in part to this new parser.

It is also hoped (and the motativation for the patch) that this patch will
reduce duplication of code when writing host bridge drivers that are supported
by multiple architectures.

This patch provides struct resources from a device tree node, e.g.:

	u32 *last = NULL;
	struct resource res;
	while ((last = of_pci_process_ranges(np, res, last))) {
		//do something with res
	}

Platforms with quirks can then do what they like with the resource or migrate
common quirk handling to the parser. In an ideal world drivers can just request
the obtained resources and pass them on (e.g. pci_add_resource_offset).

Signed-off-by: Andrew Murray <Andrew.Murray@arm.com>
Signed-off-by: Liviu Dudau <Liviu.Dudau@arm.com>
Signed-off-by: Thierry Reding <thierry.reding@avionic-design.de>
---
 drivers/of/address.c       | 63 ++++++++++++++++++++++++++++++++++++++++++++++
 include/linux/of_address.h |  9 +++++++
 2 files changed, 72 insertions(+)

diff --git a/drivers/of/address.c b/drivers/of/address.c
index 0125524..d659527 100644
--- a/drivers/of/address.c
+++ b/drivers/of/address.c
@@ -13,6 +13,7 @@
 #define OF_CHECK_COUNTS(na, ns)	(OF_CHECK_ADDR_COUNT(na) && (ns) > 0)
 
 static struct of_bus *of_match_bus(struct device_node *np);
+static struct of_bus *of_find_bus(const char *name);
 static int __of_address_to_resource(struct device_node *dev,
 		const __be32 *addrp, u64 size, unsigned int flags,
 		const char *name, struct resource *r);
@@ -227,6 +228,57 @@ int of_pci_address_to_resource(struct device_node *dev, int bar,
 	return __of_address_to_resource(dev, addrp, size, flags, NULL, r);
 }
 EXPORT_SYMBOL_GPL(of_pci_address_to_resource);
+
+const __be32 *of_pci_process_ranges(struct device_node *node,
+				    struct resource *res, const __be32 *from)
+{
+	const __be32 *start, *end;
+	int na, ns, np, pna;
+	int rlen;
+	struct of_bus *bus;
+
+	WARN_ON(!res);
+
+	bus = of_find_bus("pci");
+	bus->count_cells(node, &na, &ns);
+	if (!OF_CHECK_COUNTS(na, ns)) {
+		pr_err("Bad cell count for %s\n", node->full_name);
+		return NULL;
+	}
+
+	pna = of_n_addr_cells(node);
+	np = pna + na + ns;
+
+	start = of_get_property(node, "ranges", &rlen);
+	if (start == NULL)
+		return NULL;
+
+	end = start + rlen / sizeof(__be32);
+
+	if (!from)
+		from = start;
+
+	while (from + np <= end) {
+		u64 cpu_addr, size;
+
+		cpu_addr = of_translate_address(node, from + na);
+		size = of_read_number(from + na + pna, ns);
+		res->flags = bus->get_flags(from);
+		from += np;
+
+		if (cpu_addr == OF_BAD_ADDR || size == 0)
+			continue;
+
+		res->name = node->full_name;
+		res->start = cpu_addr;
+		res->end = res->start + size - 1;
+		res->parent = res->child = res->sibling = NULL;
+		return from;
+	}
+
+	return NULL;
+}
+EXPORT_SYMBOL_GPL(of_pci_process_ranges);
 #endif /* CONFIG_PCI */
 
 /*
@@ -337,6 +389,17 @@ static struct of_bus *of_match_bus(struct device_node *np)
 	return NULL;
 }
 
+static struct of_bus *of_find_bus(const char *name)
+{
+	unsigned int i;
+
+	for (i = 0; i < ARRAY_SIZE(of_busses); i++)
+		if (strcmp(name, of_busses[i].name) == 0)
+			return &of_busses[i];
+
+	return NULL;
+}
+
 static int of_translate_one(struct device_node *parent, struct of_bus *bus,
 			    struct of_bus *pbus, __be32 *addr,
 			    int na, int ns, int pna, const char *rprop)
diff --git a/include/linux/of_address.h b/include/linux/of_address.h
index 0506eb5..751e889 100644
--- a/include/linux/of_address.h
+++ b/include/linux/of_address.h
@@ -27,6 +27,8 @@ static inline unsigned long pci_address_to_pio(phys_addr_t addr) { return -1; }
 #define pci_address_to_pio pci_address_to_pio
 #endif
 
+const __be32 *of_pci_process_ranges(struct device_node *node,
+				    struct resource *res, const __be32 *from);
 #else /* CONFIG_OF_ADDRESS */
 #ifndef of_address_to_resource
 static inline int of_address_to_resource(struct device_node *dev, int index,
@@ -53,6 +55,13 @@ static inline const __be32 *of_get_address(struct device_node *dev, int index,
 {
 	return NULL;
 }
+
+static inline const __be32 *of_pci_process_ranges(struct device_node *node,
+						  struct resource *res,
+						  const __be32 *from)
+{
+	return NULL;
+}
 #endif /* CONFIG_OF_ADDRESS */
 
 
-- 
1.8.1

  parent reply	other threads:[~2013-01-09 20:43 UTC|newest]

Thread overview: 267+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-01-09 20:43 [PATCH 00/14] Rewrite Tegra PCIe driver Thierry Reding
2013-01-09 20:43 ` Thierry Reding
2013-01-09 20:43 ` [PATCH 02/14] of/pci: Add of_pci_get_devfn() function Thierry Reding
2013-01-09 20:43   ` Thierry Reding
     [not found]   ` <1357764194-12677-3-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-11  0:09     ` Stephen Warren
2013-01-11  0:09       ` Stephen Warren
2013-01-11  0:09       ` Stephen Warren
2013-01-11  4:06       ` Thierry Reding
2013-01-11  4:06         ` Thierry Reding
2013-01-09 20:43 ` [PATCH 05/14] lib: Add I/O map cache implementation Thierry Reding
2013-01-09 20:43   ` Thierry Reding
2013-01-09 20:43   ` Thierry Reding
     [not found]   ` <1357764194-12677-6-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-09 21:19     ` Arnd Bergmann
2013-01-09 21:19       ` Arnd Bergmann
2013-01-09 21:19       ` Arnd Bergmann
2013-01-09 21:54       ` Thierry Reding
2013-01-09 21:54         ` Thierry Reding
     [not found]         ` <20130109215428.GA13648-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-09 22:10           ` Arnd Bergmann
2013-01-09 22:10             ` Arnd Bergmann
2013-01-09 22:10             ` Arnd Bergmann
     [not found]             ` <201301092210.49452.arnd-r2nGTMty4D4@public.gmane.org>
2013-01-09 23:12               ` Stephen Warren
2013-01-09 23:12                 ` Stephen Warren
2013-01-09 23:12                 ` Stephen Warren
2013-01-09 23:17                 ` Jason Gunthorpe
2013-01-09 23:17                   ` Jason Gunthorpe
     [not found]                   ` <20130109231758.GA27065-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2013-01-10  7:19                     ` Thierry Reding
2013-01-10  7:19                       ` Thierry Reding
2013-01-10  7:19                       ` Thierry Reding
     [not found]                       ` <20130110071937.GG15212-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-10  9:17                         ` Arnd Bergmann
2013-01-10  9:17                           ` Arnd Bergmann
2013-01-10  9:17                           ` Arnd Bergmann
     [not found]                           ` <201301100917.19577.arnd-r2nGTMty4D4@public.gmane.org>
2013-01-10 10:25                             ` Thierry Reding
2013-01-10 10:25                               ` Thierry Reding
2013-01-10 10:25                               ` Thierry Reding
     [not found]                               ` <20130110102544.GA5546-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-10 18:20                                 ` Jason Gunthorpe
2013-01-10 18:20                                   ` Jason Gunthorpe
2013-01-10 18:20                                   ` Jason Gunthorpe
     [not found]                                   ` <20130110182007.GA28004-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2013-01-10 18:55                                     ` Thierry Reding
2013-01-10 18:55                                       ` Thierry Reding
2013-01-10 18:55                                       ` Thierry Reding
2013-01-10 19:03                                       ` Thierry Reding
2013-01-10 19:03                                         ` Thierry Reding
2013-01-10 19:24                                         ` Jason Gunthorpe
2013-01-10 19:24                                           ` Jason Gunthorpe
     [not found]                                           ` <20130110192417.GA18478-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org>
2013-01-10 20:20                                             ` Thierry Reding
2013-01-10 20:20                                               ` Thierry Reding
2013-01-10 20:20                                               ` Thierry Reding
     [not found]                                               ` <20130110202007.GA26139-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-10 21:06                                                 ` Jason Gunthorpe
2013-01-10 21:06                                                   ` Jason Gunthorpe
2013-01-10 21:06                                                   ` Jason Gunthorpe
2013-01-16 10:18                                             ` Thierry Reding
2013-01-16 10:18                                               ` Thierry Reding
2013-01-16 10:18                                               ` Thierry Reding
     [not found]                                               ` <20130116101822.GA17706-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-16 11:25                                                 ` Russell King - ARM Linux
2013-01-16 11:25                                                   ` Russell King - ARM Linux
2013-01-16 11:25                                                   ` Russell King - ARM Linux
     [not found]                                                   ` <20130116112556.GR23505-l+eeeJia6m9vn6HldHNs0ANdhmdF6hFW@public.gmane.org>
2013-01-16 11:52                                                     ` Thierry Reding
2013-01-16 11:52                                                       ` Thierry Reding
2013-01-16 11:52                                                       ` Thierry Reding
2013-01-10 18:26                                 ` Arnd Bergmann
2013-01-10 18:26                                   ` Arnd Bergmann
2013-01-10 18:26                                   ` Arnd Bergmann
     [not found]                                   ` <201301101826.56248.arnd-r2nGTMty4D4@public.gmane.org>
2013-01-10 18:57                                     ` Thierry Reding
2013-01-10 18:57                                       ` Thierry Reding
2013-01-10 18:57                                       ` Thierry Reding
2013-01-10  7:10               ` Thierry Reding
2013-01-10  7:10                 ` Thierry Reding
2013-01-10  7:10                 ` Thierry Reding
2013-01-09 21:28     ` Russell King - ARM Linux
2013-01-09 21:28       ` Russell King - ARM Linux
2013-01-09 21:28       ` Russell King - ARM Linux
     [not found]       ` <20130109212847.GT3931-l+eeeJia6m9vn6HldHNs0ANdhmdF6hFW@public.gmane.org>
2013-01-09 21:57         ` Thierry Reding
2013-01-09 21:57           ` Thierry Reding
2013-01-09 21:57           ` Thierry Reding
     [not found] ` <1357764194-12677-1-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-09 20:43   ` Thierry Reding [this message]
2013-01-09 20:43     ` [PATCH 01/14] of/pci: Provide support for parsing PCI DT ranges property Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-11  0:06     ` Stephen Warren
2013-01-11  0:06       ` Stephen Warren
     [not found]       ` <50EF5798.6040405-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
2013-01-11  4:02         ` Thierry Reding
2013-01-11  4:02           ` Thierry Reding
2013-01-11  4:02           ` Thierry Reding
2013-01-09 20:43   ` [PATCH 03/14] of/pci: Add of_pci_get_bus() function Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43   ` [PATCH 04/14] of/pci: Add of_pci_parse_bus_range() function Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43   ` [PATCH 06/14] ARM: pci: Keep pci_common_init() around after init Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43     ` Thierry Reding
     [not found]     ` <1357764194-12677-7-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-02-05 20:41       ` Thierry Reding
2013-02-05 20:41         ` Thierry Reding
2013-02-05 20:41         ` Thierry Reding
     [not found]         ` <20130205204147.GA29726-RM9K5IK7kjIQXX3q8xo1gnVAuStQJXxyR5q1nwbD4aMs9pC9oP6+/A@public.gmane.org>
2013-02-06 16:30           ` Russell King - ARM Linux
2013-02-06 16:30             ` Russell King - ARM Linux
2013-02-06 16:30             ` Russell King - ARM Linux
     [not found]             ` <20130206163041.GG17833-l+eeeJia6m9vn6HldHNs0ANdhmdF6hFW@public.gmane.org>
2013-02-06 19:35               ` Thierry Reding
2013-02-06 19:35                 ` Thierry Reding
2013-02-06 19:35                 ` Thierry Reding
2013-02-06  8:36       ` Thomas Petazzoni
2013-02-06  8:36         ` Thomas Petazzoni
2013-02-06  8:36         ` Thomas Petazzoni
2013-02-06 16:38       ` Linus Walleij
2013-02-06 16:38         ` Linus Walleij
2013-02-06 16:38         ` Linus Walleij
2013-02-07  0:54         ` Arnd Bergmann
2013-02-07  0:54           ` Arnd Bergmann
2013-02-06 17:07           ` Linus Walleij
2013-02-06 17:07             ` Linus Walleij
2013-02-06 17:07             ` Linus Walleij
2013-02-07  1:20             ` Arnd Bergmann
2013-02-07  1:20               ` Arnd Bergmann
2013-02-07  1:20               ` Arnd Bergmann
2013-01-09 20:43   ` [PATCH 07/14] ARM: pci: Allow passing per-controller private data Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43   ` [PATCH 08/14] ARM: tegra: Move tegra_pcie_xclk_clamp() to PMC Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43   ` [PATCH 11/14] ARM: tegra: tamonten: Add PCIe support Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43     ` Thierry Reding
     [not found]     ` <1357764194-12677-12-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-09 21:23       ` Arnd Bergmann
2013-01-09 21:23         ` Arnd Bergmann
2013-01-09 21:23         ` Arnd Bergmann
     [not found]         ` <201301092123.37491.arnd-r2nGTMty4D4@public.gmane.org>
2013-01-10 20:21           ` Thierry Reding
2013-01-10 20:21             ` Thierry Reding
2013-01-10 20:21             ` Thierry Reding
2013-01-09 20:43   ` [PATCH 14/14] ARM: tegra: trimslice: Initialize PCIe from DT Thierry Reding
2013-01-09 20:43     ` Thierry Reding
2013-01-09 20:43     ` Thierry Reding
     [not found]     ` <1357764194-12677-15-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-10 23:56       ` Stephen Warren
2013-01-10 23:56         ` Stephen Warren
2013-01-10 23:56         ` Stephen Warren
     [not found]         ` <50EF5537.6080602-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
2013-01-11 18:48           ` Thierry Reding
2013-01-11 18:48             ` Thierry Reding
2013-01-11 18:48             ` Thierry Reding
2013-01-09 21:25   ` [PATCH 00/14] Rewrite Tegra PCIe driver Thomas Petazzoni
2013-01-09 21:25     ` Thomas Petazzoni
2013-01-09 21:25     ` Thomas Petazzoni
2013-01-10  6:55     ` Thierry Reding
2013-01-10  6:55       ` Thierry Reding
2013-01-10  6:55       ` Thierry Reding
2013-01-10  8:34       ` Thomas Petazzoni
2013-01-10  8:34         ` Thomas Petazzoni
2013-03-06 18:16   ` Murali Karicheri
2013-01-09 20:43 ` [PATCH 09/14] ARM: tegra: Move pmc.h to include/mach Thierry Reding
2013-01-09 20:43   ` Thierry Reding
     [not found]   ` <1357764194-12677-10-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-11  0:15     ` Stephen Warren
2013-01-11  0:15       ` Stephen Warren
2013-01-11  0:15       ` Stephen Warren
     [not found]       ` <50EF598B.2030307-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
2013-01-11  4:08         ` Thierry Reding
2013-01-11  4:08           ` Thierry Reding
2013-01-11  4:08           ` Thierry Reding
2013-01-09 20:43 ` [PATCH 10/14] PCI: tegra: Move PCIe driver to drivers/pci/host Thierry Reding
2013-01-09 20:43   ` Thierry Reding
     [not found]   ` <1357764194-12677-11-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-09 21:22     ` Arnd Bergmann
2013-01-09 21:22       ` Arnd Bergmann
2013-01-09 21:22       ` Arnd Bergmann
     [not found]       ` <201301092122.08011.arnd-r2nGTMty4D4@public.gmane.org>
2013-01-09 21:58         ` Thierry Reding
2013-01-09 21:58           ` Thierry Reding
2013-01-09 21:58           ` Thierry Reding
2013-01-09 22:03           ` Arnd Bergmann
2013-01-09 22:03             ` Arnd Bergmann
2013-01-11  0:48     ` Stephen Warren
2013-01-11  0:48       ` Stephen Warren
2013-01-11  0:48       ` Stephen Warren
     [not found]       ` <50EF616E.7040609-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org>
2013-01-11  3:52         ` Thierry Reding
2013-01-11  3:52           ` Thierry Reding
2013-01-11  3:52           ` Thierry Reding
2013-01-11 20:34           ` Stephen Warren
2013-01-11 20:34             ` Stephen Warren
2013-02-13 23:11     ` Thomas Petazzoni
2013-02-13 23:11       ` Thomas Petazzoni
2013-02-13 23:11       ` Thomas Petazzoni
2013-01-10 23:54   ` Stephen Warren
2013-01-10 23:54     ` Stephen Warren
2013-01-11  3:40     ` Thierry Reding
2013-01-11  3:40       ` Thierry Reding
     [not found]       ` <20130111034015.GA28094-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-11 15:36         ` Arnd Bergmann
2013-01-11 15:36           ` Arnd Bergmann
2013-01-11 15:36           ` Arnd Bergmann
     [not found]           ` <201301111536.14799.arnd-r2nGTMty4D4@public.gmane.org>
2013-01-11 15:45             ` Thierry Reding
2013-01-11 15:45               ` Thierry Reding
2013-01-11 15:45               ` Thierry Reding
     [not found]               ` <20130111154516.GA25335-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-12 12:36                 ` Thierry Reding
2013-01-12 12:36                   ` Thierry Reding
2013-01-12 12:36                   ` Thierry Reding
2013-01-12 21:12                   ` Arnd Bergmann
2013-01-12 21:12                     ` Arnd Bergmann
2013-01-13  9:58                     ` Thierry Reding
2013-01-13  9:58                       ` Thierry Reding
     [not found]                       ` <20130113095806.GA31966-RM9K5IK7kjIyiCvfTdI0JKcOhU4Rzj621B7CTYaBSLdn68oJJulU0Q@public.gmane.org>
2013-01-14  9:57                         ` Andrew Murray
2013-01-14  9:57                           ` Andrew Murray
2013-01-14  9:57                           ` Andrew Murray
2013-01-14  9:57                           ` Andrew Murray
     [not found]                           ` <20130114095706.GA23467-5wv7dgnIgG8@public.gmane.org>
2013-01-15 12:08                             ` Thierry Reding
2013-01-15 12:08                               ` Thierry Reding
2013-01-15 12:08                               ` Thierry Reding
2013-01-15 12:08                               ` Thierry Reding
2013-01-15 12:44                               ` Arnd Bergmann
2013-01-15 12:44                                 ` Arnd Bergmann
2013-01-15 12:44                                 ` Arnd Bergmann
     [not found]                                 ` <201301151244.12767.arnd-r2nGTMty4D4@public.gmane.org>
2013-01-15 15:40                                   ` Andrew Murray
2013-01-15 15:40                                     ` Andrew Murray
2013-01-15 15:40                                     ` Andrew Murray
2013-01-15 15:40                                     ` Andrew Murray
     [not found]                                     ` <20130115154038.GA11241-5wv7dgnIgG8@public.gmane.org>
2013-01-15 21:14                                       ` Thierry Reding
2013-01-15 21:14                                         ` Thierry Reding
2013-01-15 21:14                                         ` Thierry Reding
2013-01-15 21:14                                         ` Thierry Reding
2013-01-16 14:00                                         ` Arnd Bergmann
2013-01-16 14:00                                           ` Arnd Bergmann
2013-01-16 14:00                                           ` Arnd Bergmann
2013-01-16 16:17                                           ` Andrew Murray
2013-01-16 16:17                                             ` Andrew Murray
2013-01-16 16:17                                             ` Andrew Murray
2013-01-16 18:31                                             ` Thierry Reding
2013-01-16 18:31                                               ` Thierry Reding
2013-01-16 18:31                                               ` Thierry Reding
2013-01-17 15:42                                               ` Andrew Murray
2013-01-17 15:42                                                 ` Andrew Murray
2013-01-17 15:42                                                 ` Andrew Murray
     [not found]                                                 ` <20130117154236.GA25943-5wv7dgnIgG8@public.gmane.org>
2013-01-17 16:05                                                   ` Thierry Reding
2013-01-17 16:05                                                     ` Thierry Reding
2013-01-17 16:05                                                     ` Thierry Reding
2013-01-17 16:05                                                     ` Thierry Reding
2013-01-17 16:22                                                     ` Andrew Murray
2013-01-17 16:22                                                       ` Andrew Murray
2013-01-17 16:22                                                       ` Andrew Murray
     [not found]                                                       ` <20130117162218.GA29016-5wv7dgnIgG8@public.gmane.org>
2013-01-17 20:30                                                         ` Thierry Reding
2013-01-17 20:30                                                           ` Thierry Reding
2013-01-17 20:30                                                           ` Thierry Reding
2013-01-17 20:30                                                           ` Thierry Reding
2013-01-18  9:18                                                           ` Andrew Murray
2013-01-18  9:18                                                             ` Andrew Murray
2013-01-18  9:18                                                             ` Andrew Murray
2013-01-22 19:29                                                         ` Jason Gunthorpe
2013-01-22 19:29                                                           ` Jason Gunthorpe
2013-01-22 19:29                                                           ` Jason Gunthorpe
2013-01-22 19:29                                                           ` Jason Gunthorpe
2013-01-29 13:31                                                           ` Andrew Murray
2013-01-29 13:31                                                             ` Andrew Murray
2013-01-29 13:31                                                             ` Andrew Murray
2013-01-18  9:56   ` Andrew Murray
2013-01-18  9:56     ` Andrew Murray
2013-01-18  9:56     ` Andrew Murray
     [not found]     ` <20130118095620.GA7552-5wv7dgnIgG8@public.gmane.org>
2013-01-18 10:09       ` Thierry Reding
2013-01-18 10:09         ` Thierry Reding
2013-01-18 10:09         ` Thierry Reding
2013-01-18 10:09         ` Thierry Reding
2013-01-09 20:43 ` [PATCH 12/14] ARM: tegra: tec: Add PCIe support Thierry Reding
2013-01-09 20:43   ` Thierry Reding
     [not found]   ` <1357764194-12677-13-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-11  0:22     ` Stephen Warren
2013-01-11  0:22       ` Stephen Warren
2013-01-11  0:22       ` Stephen Warren
2013-01-11  4:34       ` Thierry Reding
2013-01-11  4:34         ` Thierry Reding
2013-01-09 20:43 ` [PATCH 13/14] ARM: tegra: harmony: Initialize PCIe from DT Thierry Reding
2013-01-09 20:43   ` Thierry Reding
2013-01-09 20:43   ` Thierry Reding
     [not found]   ` <1357764194-12677-14-git-send-email-thierry.reding-RM9K5IK7kjKj5M59NBduVrNAH6kLmebB@public.gmane.org>
2013-01-10 23:58     ` Stephen Warren
2013-01-10 23:58       ` Stephen Warren
2013-01-10 23:58       ` Stephen Warren
2013-01-28 18:15 ` [PATCH 00/14] Rewrite Tegra PCIe driver Bjorn Helgaas
2013-01-28 18:15   ` Bjorn Helgaas

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=1357764194-12677-2-git-send-email-thierry.reding@avionic-design.de \
    --to=thierry.reding-rm9k5ik7kjkj5m59nbduvrnah6klmebb@public.gmane.org \
    --cc=Andrew.Murray-5wv7dgnIgG8@public.gmane.org \
    --cc=Liviu.Dudau-5wv7dgnIgG8@public.gmane.org \
    --cc=bhelgaas-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org \
    --cc=devicetree-discuss-uLR06cmDAlY/bJ5BZ2RsiQ@public.gmane.org \
    --cc=jgunthorpe-ePGOBjL8dl3ta4EC/59zMFaTQe2KTcn/@public.gmane.org \
    --cc=linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org \
    --cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-lFZ/pmaqli7XmaaqVzeoHQ@public.gmane.org \
    --cc=linux-pci-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=rob.herring-bsGFqQB8/DxBDgjK7y7TUQ@public.gmane.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 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.