summaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel
diff options
context:
space:
mode:
authorJoerg Roedel <joerg.roedel@amd.com>2008-11-25 12:56:12 +0100
committerJoerg Roedel <joerg.roedel@amd.com>2008-12-03 12:20:46 +0100
commitf91ba190648be4ff127d6aaf3993ac19d66dc2c2 (patch)
tree1e56d253b20759ca9c11fba0dd8ca5b243b8e47e /arch/x86/kernel
parenteac9fbc6a90ab3440f4d98a8c52b15a724fc6f4f (diff)
downloadblackbird-op-linux-f91ba190648be4ff127d6aaf3993ac19d66dc2c2.tar.gz
blackbird-op-linux-f91ba190648be4ff127d6aaf3993ac19d66dc2c2.zip
AMD IOMMU: set device table entry for aliased devices
In some rare cases a request can arrive an IOMMU with its originial requestor id even it is aliased. Handle this by setting the device table entry to the same protection domain for the original and the aliased requestor id. Signed-off-by: Joerg Roedel <joerg.roedel@amd.com>
Diffstat (limited to 'arch/x86/kernel')
-rw-r--r--arch/x86/kernel/amd_iommu.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/x86/kernel/amd_iommu.c b/arch/x86/kernel/amd_iommu.c
index e4899e0e8787..a232e5a85d48 100644
--- a/arch/x86/kernel/amd_iommu.c
+++ b/arch/x86/kernel/amd_iommu.c
@@ -858,6 +858,9 @@ static int get_device_resources(struct device *dev,
print_devid(_bdf, 1);
}
+ if (domain_for_device(_bdf) == NULL)
+ set_device_domain(*iommu, *domain, _bdf);
+
return 1;
}
OpenPOWER on IntegriCloud