iommu/amd: Allocate memory below 4G for dev table if translation pre-enabled
authorBaoquan He <bhe@redhat.com>
Wed, 9 Aug 2017 08:33:42 +0000 (16:33 +0800)
committerJoerg Roedel <jroedel@suse.de>
Tue, 15 Aug 2017 16:14:40 +0000 (18:14 +0200)
commitb336781b82cc12c7940a2b1c806fbe7f78ecd72a
treeaf88008707223a08b2f7a44d43d5c8aa11baa00a
parentdf3f7a6e8e855e4ff533508807cd7c3723faa51f
iommu/amd: Allocate memory below 4G for dev table if translation pre-enabled

AMD pointed out it's unsafe to update the device-table while iommu
is enabled. It turns out that device-table pointer update is split
up into two 32bit writes in the IOMMU hardware. So updating it while
the IOMMU is enabled could have some nasty side effects.

The safe way to work around this is to always allocate the device-table
below 4G, including the old device-table in normal kernel and the
device-table used for copying the content of the old device-table in kdump
kernel. Meanwhile we need check if the address of old device-table is
above 4G because it might has been touched accidentally in corrupted
1st kernel.

Signed-off-by: Baoquan He <bhe@redhat.com>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/amd_iommu_init.c