Commit 70c2e03e authored by Mika Westerberg's avatar Mika Westerberg

thunderbolt: dma_test: Use correct value for absent rings when creating paths

Both tb_xdomain_enable_paths() and tb_xdomain_disable_paths() expect -1,
not 0, if the corresponding ring is not needed. For this reason change
the driver to use correct value for the rings that are not needed.

Fixes: 180b0689 ("thunderbolt: Allow multiple DMA tunnels over a single XDomain connection")
Cc: stable@vger.kernel.org
Reported-by: default avatarPengfei Xu <pengfei.xu@intel.com>
Tested-by: default avatarPengfei Xu <pengfei.xu@intel.com>
Signed-off-by: default avatarMika Westerberg <mika.westerberg@linux.intel.com>
parent 44c026a7
...@@ -192,9 +192,9 @@ static int dma_test_start_rings(struct dma_test *dt) ...@@ -192,9 +192,9 @@ static int dma_test_start_rings(struct dma_test *dt)
} }
ret = tb_xdomain_enable_paths(dt->xd, dt->tx_hopid, ret = tb_xdomain_enable_paths(dt->xd, dt->tx_hopid,
dt->tx_ring ? dt->tx_ring->hop : 0, dt->tx_ring ? dt->tx_ring->hop : -1,
dt->rx_hopid, dt->rx_hopid,
dt->rx_ring ? dt->rx_ring->hop : 0); dt->rx_ring ? dt->rx_ring->hop : -1);
if (ret) { if (ret) {
dma_test_free_rings(dt); dma_test_free_rings(dt);
return ret; return ret;
...@@ -218,9 +218,9 @@ static void dma_test_stop_rings(struct dma_test *dt) ...@@ -218,9 +218,9 @@ static void dma_test_stop_rings(struct dma_test *dt)
tb_ring_stop(dt->tx_ring); tb_ring_stop(dt->tx_ring);
ret = tb_xdomain_disable_paths(dt->xd, dt->tx_hopid, ret = tb_xdomain_disable_paths(dt->xd, dt->tx_hopid,
dt->tx_ring ? dt->tx_ring->hop : 0, dt->tx_ring ? dt->tx_ring->hop : -1,
dt->rx_hopid, dt->rx_hopid,
dt->rx_ring ? dt->rx_ring->hop : 0); dt->rx_ring ? dt->rx_ring->hop : -1);
if (ret) if (ret)
dev_warn(&dt->svc->dev, "failed to disable DMA paths\n"); dev_warn(&dt->svc->dev, "failed to disable DMA paths\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment