aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Nelson <markn@au1.ibm.com>2008-07-24 00:28:48 -0400
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2008-07-25 01:44:40 -0400
commit7886250e9d71b24d0205ac6798ee855fb3836318 (patch)
treef961bc97510d86aa56ab47b6154b2835c59965d8
parentd6a61bfc06d6f2248f3e75f208d64e794082013c (diff)
powerpc/cell: Fixed IOMMU mapping uses weak ordering for a pcie endpoint
At the moment the fixed mapping is by default strongly ordered (the iommu_fixed=weak boot option must be used to make the fixed mapping weakly ordered). If we're on a setup where the southbridge is being used in endpoint mode (triblade and CAB boards) the default should be a weakly ordered fixed mapping. This adds a check so that if a node of type pcie-endpoint can be found in the device tree the fixed mapping is set to be weak by default (but can be overridden using iommu_fixed=strong). Signed-off-by: Mark Nelson <markn@au1.ibm.com> Acked-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
-rw-r--r--arch/powerpc/platforms/cell/iommu.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/arch/powerpc/platforms/cell/iommu.c b/arch/powerpc/platforms/cell/iommu.c
index 208005ca262c..031124a8e37b 100644
--- a/arch/powerpc/platforms/cell/iommu.c
+++ b/arch/powerpc/platforms/cell/iommu.c
@@ -1150,12 +1150,23 @@ static int iommu_fixed_disabled;
1150 1150
1151static int __init setup_iommu_fixed(char *str) 1151static int __init setup_iommu_fixed(char *str)
1152{ 1152{
1153 struct device_node *pciep;
1154
1153 if (strcmp(str, "off") == 0) 1155 if (strcmp(str, "off") == 0)
1154 iommu_fixed_disabled = 1; 1156 iommu_fixed_disabled = 1;
1155 1157
1156 else if (strcmp(str, "weak") == 0) 1158 /* If we can find a pcie-endpoint in the device tree assume that
1159 * we're on a triblade or a CAB so by default the fixed mapping
1160 * should be set to be weakly ordered; but only if the boot
1161 * option WASN'T set for strong ordering
1162 */
1163 pciep = of_find_node_by_type(NULL, "pcie-endpoint");
1164
1165 if (strcmp(str, "weak") == 0 || (pciep && strcmp(str, "strong") != 0))
1157 iommu_fixed_is_weak = 1; 1166 iommu_fixed_is_weak = 1;
1158 1167
1168 of_node_put(pciep);
1169
1159 return 1; 1170 return 1;
1160} 1171}
1161__setup("iommu_fixed=", setup_iommu_fixed); 1172__setup("iommu_fixed=", setup_iommu_fixed);