@@ -340,15 +340,7 @@ static int __upstream_bridge_distance(struct pci_dev *provider,
dist_a++;
}
- /*
- * Allow the connection if both devices are on a whitelisted root
- * complex, but add an arbitrary large value to the distance.
- */
- if (root_complex_whitelist(provider) &&
- root_complex_whitelist(client))
- return (dist_a + dist_b) | P2PDMA_THRU_HOST_BRIDGE;
-
- return (dist_a + dist_b) | P2PDMA_NOT_SUPPORTED;
+ return (dist_a + dist_b) | P2PDMA_THRU_HOST_BRIDGE;
check_b_path_acs:
bb = b;
@@ -366,7 +358,8 @@ static int __upstream_bridge_distance(struct pci_dev *provider,
}
if (acs_cnt)
- return P2PDMA_NOT_SUPPORTED | P2PDMA_ACS_FORCES_UPSTREAM;
+ return (dist_a + dist_b) | P2PDMA_ACS_FORCES_UPSTREAM |
+ P2PDMA_THRU_HOST_BRIDGE;
return dist_a + dist_b;
}
@@ -413,7 +406,17 @@ static int upstream_bridge_distance(struct pci_dev *provider,
struct pci_dev *client,
struct seq_buf *acs_list)
{
- return __upstream_bridge_distance(provider, client, acs_list);
+ int dist;
+
+ dist = __upstream_bridge_distance(provider, client, acs_list);
+
+ if (!(dist & P2PDMA_THRU_HOST_BRIDGE))
+ return dist;
+
+ if (root_complex_whitelist(provider) && root_complex_whitelist(client))
+ return dist;
+
+ return dist | P2PDMA_NOT_SUPPORTED;
}
static int upstream_bridge_distance_warn(struct pci_dev *provider,