From: Thierry Reding Date: Thu, 26 Jul 2012 19:55:10 +0000 (+0200) Subject: of/address: Handle #address-cells > 2 specially X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=e38c0a1fbc5803cbacdaac0557c70ac8ca5152e7;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git of/address: Handle #address-cells > 2 specially When a bus specifies #address-cells > 2, of_bus_default_map() now assumes that the mapping isn't for a physical address but rather an identifier that needs to match exactly. This is required by bindings that use multiple cells to translate a resource to the parent bus (device index, type, ...). See here for the discussion: https://lists.ozlabs.org/pipermail/devicetree-discuss/2012-June/016577.html Originally-by: Arnd Bergmann Signed-off-by: Thierry Reding Signed-off-by: Rob Herring --- diff --git a/drivers/of/address.c b/drivers/of/address.c index 7a07751428de..72e496f1e9b0 100644 --- a/drivers/of/address.c +++ b/drivers/of/address.c @@ -69,6 +69,14 @@ static u64 of_bus_default_map(u32 *addr, const __be32 *range, (unsigned long long)cp, (unsigned long long)s, (unsigned long long)da); + /* + * If the number of address cells is larger than 2 we assume the + * mapping doesn't specify a physical address. Rather, the address + * specifies an identifier that must match exactly. + */ + if (na > 2 && memcmp(range, addr, na * 4) != 0) + return OF_BAD_ADDR; + if (da < cp || da >= (cp + s)) return OF_BAD_ADDR; return da - cp;