arm64: dts: hisi: Disable hisilicon smmu node on hip06/hip07
authorShameerali Kolothum Thodi <shameerali.kolothum.thodi@huawei.com>
Thu, 14 Dec 2017 16:09:57 +0000 (16:09 +0000)
committerWei Xu <xuwei5@hisilicon.com>
Fri, 2 Mar 2018 16:19:41 +0000 (16:19 +0000)
The HiSilicon erratum 161010801 describes the limitation of
HiSilicon platforms hip06/hip07 to support the SMMUv3 mappings
for MSI transactions.

PCIe controller on these platforms has to differentiate the
MSI payload against other DMA payload and has to modify the
MSI  payload. This makes it difficult for these platforms to
have SMMU translation for MSI. In order to workaround this,
ARM SMMUv3 driver requires a quirk to treat the MSI regions
separately. Such a quirk is currently missing for DT based
systems and therefore we need to explicitly disable the
hip06/hip07 smmu entries in dts.

Signed-off-by: Shameer Kolothum <shameerali.kolothum.thodi@huawei.com>
Signed-off-by: Wei Xu <xuwei5@hisilicon.com>
arch/arm64/boot/dts/hisilicon/hip06.dtsi
arch/arm64/boot/dts/hisilicon/hip07.dtsi

index a049b64f2101e419a83266741cd073607bd3eade..35202ebe62a744decfad6b40823620d31ee300f0 100644 (file)
                        #interrupt-cells = <2>;
                        num-pins = <128>;
                };
+
+               mbigen_pcie0: intc_pcie0 {
+                       msi-parent = <&its_dsa 0x40085>;
+                       interrupt-controller;
+                       #interrupt-cells = <2>;
+                       num-pins = <10>;
+               };
        };
 
        mbigen_dsa@c0080000 {
                };
        };
 
+       /**
+        *  HiSilicon erratum 161010801: This describes the limitation
+        *  of HiSilicon platforms hip06/hip07 to support the SMMUv3
+        *  mappings for PCIe MSI transactions.
+        *  PCIe controller on these platforms has to differentiate the
+        *  MSI payload against other DMA payload and has to modify the
+        *  MSI payload. This makes it difficult for these platforms to
+        *  have a SMMU translation for MSI. In order to workaround this,
+        *  ARM SMMUv3 driver requires a quirk to treat the MSI regions
+        *  separately. Such a quirk is currently missing for DT based
+        *  systems. Hence please make sure that the smmu pcie node on
+        *  hip06 is disabled as this will break the PCIe functionality
+        *  when iommu-map entry is used along with the PCIe node.
+        *  Refer:https://www.spinics.net/lists/arm-kernel/msg602812.html
+        */
+       smmu0: smmu_pcie {
+               compatible = "arm,smmu-v3";
+               reg = <0x0 0xa0040000 0x0 0x20000>;
+               #iommu-cells = <1>;
+               dma-coherent;
+               smmu-cb-memtype = <0x0 0x1>;
+               hisilicon,broken-prefetch-cmd;
+               status = "disabled";
+       };
+
        soc {
                compatible = "simple-bus";
                #address-cells = <2>;
                                     <637 1>,<638 1>,<639 1>;
                        status = "disabled";
                };
+
+               pcie0: pcie@a0090000 {
+                       compatible = "hisilicon,hip06-pcie-ecam";
+                       reg = <0 0xb0000000 0 0x2000000>,
+                             <0 0xa0090000 0 0x10000>;
+                       bus-range = <0  31>;
+                       msi-map = <0x0000 &its_dsa 0x0000 0x2000>;
+                       msi-map-mask = <0xffff>;
+                       #address-cells = <3>;
+                       #size-cells = <2>;
+                       device_type = "pci";
+                       dma-coherent;
+                       ranges = <0x02000000 0 0xb2000000 0x0 0xb2000000 0
+                                0x5ff0000 0x01000000 0 0 0 0xb7ff0000
+                                0 0x10000>;
+                       #interrupt-cells = <1>;
+                       interrupt-map-mask = <0xf800 0 0 7>;
+                       interrupt-map = <0x0 0 0 1 &mbigen_pcie0 650 4
+                                       0x0 0 0 2 &mbigen_pcie0 650 4
+                                       0x0 0 0 3 &mbigen_pcie0 650 4
+                                       0x0 0 0 4 &mbigen_pcie0 650 4>;
+                       status = "disabled";
+               };
+
        };
 
 };
index 4bd6416122d5b88c9ee6cf86b731a4c84f46931f..0600a6a84ab7d1a2c72b792ce1693e14daecf55a 100644 (file)
                };
        };
 
+       /**
+        *  HiSilicon erratum 161010801: This describes the limitation
+        *  of HiSilicon platforms hip06/hip07 to support the SMMUv3
+        *  mappings for PCIe MSI transactions.
+        *  PCIe controller on these platforms has to differentiate the
+        *  MSI payload against other DMA payload and has to modify the
+        *  MSI payload. This makes it difficult for these platforms to
+        *  have a SMMU translation for MSI. In order to workaround this,
+        *  ARM SMMUv3 driver requires a quirk to treat the MSI regions
+        *  separately. Such a quirk is currently missing for DT based
+        *  systems. Hence please make sure that the smmu pcie node on
+        *  hip07 is disabled as this will break the PCIe functionality
+        *  when iommu-map entry is used along with the PCIe node.
+        *  Refer:https://www.spinics.net/lists/arm-kernel/msg602812.html
+        */
+       smmu0: smmu_pcie {
+               compatible = "arm,smmu-v3";
+               reg = <0x0 0xa0040000 0x0 0x20000>;
+               #iommu-cells = <1>;
+               dma-coherent;
+               smmu-cb-memtype = <0x0 0x1>;
+               hisilicon,broken-prefetch-cmd;
+               status = "disabled";
+       };
+
        soc {
                compatible = "simple-bus";
                #address-cells = <2>;