of/pci: Add of_pci_parse_bus_range() function
authorThierry Reding <thierry.reding@avionic-design.de>
Thu, 16 May 2013 15:55:19 +0000 (17:55 +0200)
committerJason Cooper <jason@lakedaemon.net>
Sun, 19 May 2013 20:30:10 +0000 (20:30 +0000)
This function can be used to parse a bus-range property as specified by
device nodes representing PCI bridges.

Signed-off-by: Thierry Reding <thierry.reding@avionic-design.de>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
drivers/of/of_pci.c
include/linux/of_pci.h

index 4dd7b9b80076c352a57e8c5a591d9e2347e7dbe1..42c687a820ac3bedcb0eae90b64e8c4911509d09 100644 (file)
@@ -64,3 +64,28 @@ int of_pci_get_devfn(struct device_node *np)
        return (be32_to_cpup(reg) >> 8) & 0xff;
 }
 EXPORT_SYMBOL_GPL(of_pci_get_devfn);
+
+/**
+ * of_pci_parse_bus_range() - parse the bus-range property of a PCI device
+ * @node: device node
+ * @res: address to a struct resource to return the bus-range
+ *
+ * Returns 0 on success or a negative error-code on failure.
+ */
+int of_pci_parse_bus_range(struct device_node *node, struct resource *res)
+{
+       const __be32 *values;
+       int len;
+
+       values = of_get_property(node, "bus-range", &len);
+       if (!values || len < sizeof(*values) * 2)
+               return -EINVAL;
+
+       res->name = node->name;
+       res->start = be32_to_cpup(values++);
+       res->end = be32_to_cpup(values);
+       res->flags = IORESOURCE_BUS;
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(of_pci_parse_bus_range);
index 91ec484e0045a05eeaf5a6e32baea8b86c0e9976..7a04826018c063fca8464deeab3f26c39f363fe0 100644 (file)
@@ -11,5 +11,6 @@ struct device_node;
 struct device_node *of_pci_find_child_device(struct device_node *parent,
                                             unsigned int devfn);
 int of_pci_get_devfn(struct device_node *np);
+int of_pci_parse_bus_range(struct device_node *node, struct resource *res);
 
 #endif