diff options
author | Suresh Siddha <suresh.b.siddha@intel.com> | 2008-09-03 16:58:35 -0700 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-10-16 16:53:05 +0200 |
commit | 1c7d1bcad218808a4f67a4492a5e1d920e85c239 (patch) | |
tree | c38074ceba9a32fd42a815b459205cc0ed715923 /drivers/pci/dmar.c | |
parent | 04e2ea67069e285404192a35c24dfe7c53b9c61f (diff) | |
download | kernel-crypto-1c7d1bcad218808a4f67a4492a5e1d920e85c239.tar.gz kernel-crypto-1c7d1bcad218808a4f67a4492a5e1d920e85c239.tar.xz kernel-crypto-1c7d1bcad218808a4f67a4492a5e1d920e85c239.zip |
dmar: fix dmar_parse_dev() devices_cnt error condition check
It is possible that,
instead of PCI endpoint/sub-hierarchy structures, only IO-APIC/HPET
devices may be reported under device scope structures. Fix the devices_cnt
error check, which cares about only PCI structures and removes the
dma-remapping unit structure (dmaru) when the devices_cnt is zero
and include_all flag is not set.
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Acked-by: Yinghai Lu <yhlu.kernel@gmail.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'drivers/pci/dmar.c')
-rw-r--r-- | drivers/pci/dmar.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/pci/dmar.c b/drivers/pci/dmar.c index ceb338dfa3f..9527405ae19 100644 --- a/drivers/pci/dmar.c +++ b/drivers/pci/dmar.c @@ -212,7 +212,7 @@ dmar_parse_dev(struct dmar_drhd_unit *dmaru) include_all = 1; } - if (ret || (dmaru->devices_cnt == 0 && !dmaru->include_all)) { + if (ret) { list_del(&dmaru->list); kfree(dmaru); } |