Commit 32302324 authored by Joerg Roedel's avatar Joerg Roedel

iommu/amd: Use swiotlb in passthrough mode

In passthrough mode (iommu=pt) all devices are identity
mapped. If a device does not support 64bit DMA it might
still need remapping. Make sure swiotlb is initialized to
provide this remapping.
Signed-off-by: default avatarJoerg Roedel <jroedel@suse.de>
parent 02ca2021
...@@ -2282,12 +2282,10 @@ static int amd_iommu_add_device(struct device *dev) ...@@ -2282,12 +2282,10 @@ static int amd_iommu_add_device(struct device *dev)
/* Domains are initialized for this device - have a look what we ended up with */ /* Domains are initialized for this device - have a look what we ended up with */
domain = iommu_get_domain_for_dev(dev); domain = iommu_get_domain_for_dev(dev);
if (domain->type == IOMMU_DOMAIN_IDENTITY) { if (domain->type == IOMMU_DOMAIN_IDENTITY)
dev_data->passthrough = true; dev_data->passthrough = true;
dev->archdata.dma_ops = &nommu_dma_ops; else
} else {
dev->archdata.dma_ops = &amd_iommu_dma_ops; dev->archdata.dma_ops = &amd_iommu_dma_ops;
}
out: out:
iommu_completion_wait(iommu); iommu_completion_wait(iommu);
...@@ -2852,8 +2850,8 @@ int __init amd_iommu_init_api(void) ...@@ -2852,8 +2850,8 @@ int __init amd_iommu_init_api(void)
int __init amd_iommu_init_dma_ops(void) int __init amd_iommu_init_dma_ops(void)
{ {
swiotlb = iommu_pass_through ? 1 : 0;
iommu_detected = 1; iommu_detected = 1;
swiotlb = 0;
amd_iommu_stats_init(); amd_iommu_stats_init();
......
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