void dw_pcie_disable_atu(struct dw_pcie *pci, int index,
                         enum dw_pcie_region_type type)
 {
-       int region;
+       u32 region;
 
        switch (type) {
        case DW_PCIE_REGION_INBOUND:
                return;
        }
 
-       dw_pcie_writel_dbi(pci, PCIE_ATU_VIEWPORT, region | index);
-       dw_pcie_writel_dbi(pci, PCIE_ATU_CR2, ~(u32)PCIE_ATU_ENABLE);
+       if (pci->iatu_unroll_enabled) {
+               if (region == PCIE_ATU_REGION_INBOUND) {
+                       dw_pcie_writel_ib_unroll(pci, index, PCIE_ATU_UNR_REGION_CTRL2,
+                                                ~(u32)PCIE_ATU_ENABLE);
+               } else {
+                       dw_pcie_writel_ob_unroll(pci, index, PCIE_ATU_UNR_REGION_CTRL2,
+                                                ~(u32)PCIE_ATU_ENABLE);
+               }
+       } else {
+               dw_pcie_writel_dbi(pci, PCIE_ATU_VIEWPORT, region | index);
+               dw_pcie_writel_dbi(pci, PCIE_ATU_CR2, ~(u32)PCIE_ATU_ENABLE);
+       }
 }
 
 int dw_pcie_wait_for_link(struct dw_pcie *pci)