[PATCH 01/32] of: Fix property supplier parsing
Damien Le Moal
damien.lemoal at wdc.com
Sat Nov 7 03:13:49 EST 2020
The DesignWare GPIO driver gpio-dwapb ("snps,dw-apb-gpio" or
"apm,xgene-gpio-v2" compatible string) defines the property
"snps,nr-gpios" for the user to specify the number of GPIOs available
on a port. The "-gpios" suffix of this property name ends up being
interpreted as a cell reference when properties are parsed in
of_link_to_suppliers(), leading to error messages such as:
OF: /soc/bus at 50200000/gpio-controller at 50200000/gpio-port at 0: could not
find phandle
Fix this by manually defining a parse_gpios() function which ignores
this property, skipping the search for the supplier and thus avoiding
the device tree parsing error.
Signed-off-by: Damien Le Moal <damien.lemoal at wdc.com>
---
drivers/of/property.c | 17 ++++++++++++++++-
1 file changed, 16 insertions(+), 1 deletion(-)
diff --git a/drivers/of/property.c b/drivers/of/property.c
index 408a7b5f06a9..d16111c0d6da 100644
--- a/drivers/of/property.c
+++ b/drivers/of/property.c
@@ -1308,7 +1308,6 @@ DEFINE_SIMPLE_PROP(pinctrl7, "pinctrl-7", NULL)
DEFINE_SIMPLE_PROP(pinctrl8, "pinctrl-8", NULL)
DEFINE_SUFFIX_PROP(regulators, "-supply", NULL)
DEFINE_SUFFIX_PROP(gpio, "-gpio", "#gpio-cells")
-DEFINE_SUFFIX_PROP(gpios, "-gpios", "#gpio-cells")
static struct device_node *parse_iommu_maps(struct device_node *np,
const char *prop_name, int index)
@@ -1319,6 +1318,22 @@ static struct device_node *parse_iommu_maps(struct device_node *np,
return of_parse_phandle(np, prop_name, (index * 4) + 1);
}
+static struct device_node *parse_gpios(struct device_node *np,
+ const char *prop_name, int index)
+{
+ /*
+ * Quirck for the DesignWare gpio-dwapb GPIO driver which defines
+ * the "snps,nr-gpios" property to indicate the total number of GPIOs
+ * available. As this conflict with "xx-gpios" reference properties,
+ * ignore it.
+ */
+ if (strcmp(prop_name, "snps,nr-gpios") == 0)
+ return NULL;
+
+ return parse_suffix_prop_cells(np, prop_name, index,
+ "-gpios", "#gpio-cells");
+}
+
static const struct supplier_bindings of_supplier_bindings[] = {
{ .parse_prop = parse_clocks, },
{ .parse_prop = parse_interconnects, },
--
2.28.0
More information about the linux-riscv
mailing list