iommu/vt-d: Fix ATSR handling for Root-Complex integrated endpoints
authorDavid Woodhouse <David.Woodhouse@intel.com>
Thu, 15 Oct 2015 08:28:06 +0000 (09:28 +0100)
committerZefan Li <lizefan@huawei.com>
Wed, 26 Oct 2016 15:15:25 +0000 (23:15 +0800)
commitb7d44ef53eb257900c6f0183a39e4dee6fad6072
tree80113e4d7fcbe8114440d08861ff1095b2862fa1
parentb0daf15db552d07fb66375ca63fc89ff67db0e26
iommu/vt-d: Fix ATSR handling for Root-Complex integrated endpoints

commit d14053b3c714178525f22660e6aaf41263d00056 upstream.

The VT-d specification says that "Software must enable ATS on endpoint
devices behind a Root Port only if the Root Port is reported as
supporting ATS transactions."

We walk up the tree to find a Root Port, but for integrated devices we
don't find one — we get to the host bridge. In that case we *should*
allow ATS. Currently we don't, which means that we are incorrectly
failing to use ATS for the integrated graphics. Fix that.

We should never break out of this loop "naturally" with bus==NULL,
since we'll always find bridge==NULL in that case (and now return 1).

So remove the check for (!bridge) after the loop, since it can never
happen. If it did, it would be worthy of a BUG_ON(!bridge). But since
it'll oops anyway in that case, that'll do just as well.

Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
[lizf: Backported to 3.4:
 - adjust context
 - drop the last part of the changes of the patch]
Signed-off-by: Zefan Li <lizefan@huawei.com>
drivers/iommu/intel-iommu.c