summaryrefslogtreecommitdiff
path: root/drivers/iommu/amd_iommu_init.c
diff options
context:
space:
mode:
authorAaron Campbell <aaron@monkey.org>2016-07-02 21:23:24 -0300
committerJoerg Roedel <jroedel@suse.de>2016-07-04 13:34:52 +0200
commit0caa7616a6aca449dd68b58cb29bd491d296c2d5 (patch)
treecaa80d64be89509628aea83babbc05dc3fcb2539 /drivers/iommu/amd_iommu_init.c
parenta99cde438de0c4c0cecc1d1af1a55a75b10bfdef (diff)
downloadlwn-0caa7616a6aca449dd68b58cb29bd491d296c2d5.tar.gz
lwn-0caa7616a6aca449dd68b58cb29bd491d296c2d5.zip
iommu/vt-d: Fix infinite loop in free_all_cpu_cached_iovas
Per VT-d spec Section 10.4.2 ("Capability Register"), the maximum number of possible domains is 64K; indeed this is the maximum value that the cap_ndoms() macro will expand to. Since the value 65536 will not fix in a u16, the 'did' variable must be promoted to an int, otherwise the test for < 65536 will always be true and the loop will never end. The symptom, in my case, was a hung machine during suspend. Fixes: 3bd4f9112f87 ("iommu/vt-d: Fix overflow of iommu->domains array") Signed-off-by: Aaron Campbell <aaron@monkey.org> Signed-off-by: Joerg Roedel <jroedel@suse.de>
Diffstat (limited to 'drivers/iommu/amd_iommu_init.c')
0 files changed, 0 insertions, 0 deletions