aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/of
diff options
context:
space:
mode:
authorBenjamin Herrenschmidt <benh@kernel.crashing.org>2013-07-03 16:01:10 +1000
committerBen Hutchings <ben@decadent.org.uk>2014-04-02 00:58:48 +0100
commit57200657f1cd8d9d579ee4b110c7eeada3e61d0d (patch)
tree3dcd72aa829445fe494e5bfc1172b85f3e8a33cd /drivers/of
parent9735862809c0aad5cb427a13868ce1a1997871fb (diff)
downloadkernel_samsung_smdk4412-57200657f1cd8d9d579ee4b110c7eeada3e61d0d.zip
kernel_samsung_smdk4412-57200657f1cd8d9d579ee4b110c7eeada3e61d0d.tar.gz
kernel_samsung_smdk4412-57200657f1cd8d9d579ee4b110c7eeada3e61d0d.tar.bz2
of: Fix address decoding on Bimini and js2x machines
commit 6dd18e4684f3d188277bbbc27545248487472108 upstream. Commit: e38c0a1fbc5803cbacdaac0557c70ac8ca5152e7 of/address: Handle #address-cells > 2 specially broke real time clock access on Bimini, js2x, and similar powerpc machines using the "maple" platform. That code was indirectly relying on the old (broken) behaviour of the translation for the hypertransport to ISA bridge. This fixes it by treating hypertransport as a PCI bus Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org> Acked-by: Rob Herring <rob.herring@calxeda.com> Signed-off-by: Grant Likely <grant.likely@linaro.org> Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
Diffstat (limited to 'drivers/of')
-rw-r--r--drivers/of/address.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/of/address.c b/drivers/of/address.c
index 72c33fb..066c1eb 100644
--- a/drivers/of/address.c
+++ b/drivers/of/address.c
@@ -97,8 +97,12 @@ static unsigned int of_bus_default_get_flags(const __be32 *addr)
static int of_bus_pci_match(struct device_node *np)
{
- /* "vci" is for the /chaos bridge on 1st-gen PCI powermacs */
- return !strcmp(np->type, "pci") || !strcmp(np->type, "vci");
+ /*
+ * "vci" is for the /chaos bridge on 1st-gen PCI powermacs
+ * "ht" is hypertransport
+ */
+ return !strcmp(np->type, "pci") || !strcmp(np->type, "vci") ||
+ !strcmp(np->type, "ht");
}
static void of_bus_pci_count_cells(struct device_node *np,