diff mbox series

[v2,02/25] dm: core: Add API to read PCI bus-range property

Message ID 20200817070802.1517632-3-sr@denx.de
State Accepted
Commit 68f81b857563e8f739323385795f1e99b3d2e598
Delegated to: Stefan Roese
Headers show
Series arm: Introduce Marvell/Cavium OcteonTX/TX2 | expand

Commit Message

Stefan Roese Aug. 17, 2020, 7:07 a.m. UTC
Add dev_read_pci_bus_range() to read bus-range property values

Signed-off-by: Stefan Roese <sr@denx.de>
Cc: Simon Glass <sjg@chromium.org>

---

Changes in v2:
- New patch

 drivers/core/read.c | 17 +++++++++++++++++
 include/dm/read.h   | 12 ++++++++++++
 2 files changed, 29 insertions(+)

Comments

Simon Glass Aug. 22, 2020, 3:09 p.m. UTC | #1
On Mon, 17 Aug 2020 at 01:08, Stefan Roese <sr@denx.de> wrote:
>
> Add dev_read_pci_bus_range() to read bus-range property values
>
> Signed-off-by: Stefan Roese <sr@denx.de>
> Cc: Simon Glass <sjg@chromium.org>
>
> ---
>
> Changes in v2:
> - New patch
>
>  drivers/core/read.c | 17 +++++++++++++++++
>  include/dm/read.h   | 12 ++++++++++++
>  2 files changed, 29 insertions(+)

Reviewed-by: Simon Glass <sjg@chromium.org>
diff mbox series

Patch

diff --git a/drivers/core/read.c b/drivers/core/read.c
index 8bb456bc3f..86f3f88170 100644
--- a/drivers/core/read.c
+++ b/drivers/core/read.c
@@ -10,6 +10,7 @@ 
 #include <mapmem.h>
 #include <asm/types.h>
 #include <asm/io.h>
+#include <linux/ioport.h>
 
 int dev_read_u32(const struct udevice *dev, const char *propname, u32 *outp)
 {
@@ -359,3 +360,19 @@  int dev_get_child_count(const struct udevice *dev)
 {
 	return ofnode_get_child_count(dev_ofnode(dev));
 }
+
+int dev_read_pci_bus_range(const struct udevice *dev,
+			   struct resource *res)
+{
+	const u32 *values;
+	int len;
+
+	values = dev_read_prop(dev, "bus-range", &len);
+	if (!values || len < sizeof(*values) * 2)
+		return -EINVAL;
+
+	res->start = *values++;
+	res->end = *values;
+
+	return 0;
+}
diff --git a/include/dm/read.h b/include/dm/read.h
index 487ec9e9c9..ac7ec5dd79 100644
--- a/include/dm/read.h
+++ b/include/dm/read.h
@@ -680,6 +680,18 @@  int dev_read_alias_highest_id(const char *stem);
  */
 int dev_get_child_count(const struct udevice *dev);
 
+/**
+ * dev_read_pci_bus_range - Read PCI bus-range resource
+ *
+ * Look at the bus range property of a device node and return the pci bus
+ * range for this node.
+ *
+ * @dev: device to examine
+ * @res returns the resource
+ * @return 0 if ok, negative on error
+ */
+int dev_read_pci_bus_range(const struct udevice *dev, struct resource *res);
+
 #else /* CONFIG_DM_DEV_READ_INLINE is enabled */
 
 static inline int dev_read_u32(const struct udevice *dev,