aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/iommu
diff options
context:
space:
mode:
authorDan Carpenter <dan.carpenter@oracle.com>2012-10-02 04:34:40 -0400
committerJoerg Roedel <joerg.roedel@amd.com>2012-10-02 06:08:07 -0400
commit821f0f68ca5fa93c757a892129392e751a7407a3 (patch)
treec943c1462eba7bbc0355dbd6bbbf6b49c501d0ac /drivers/iommu
parentbdddadcb0783b965f524b6f43c475390f5f76765 (diff)
iommu/amd: Fix possible use after free in get_irq_table()
We should return NULL on error instead of the freed pointer. Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: Joerg Roedel <joerg.roedel@amd.com>
Diffstat (limited to 'drivers/iommu')
-rw-r--r--drivers/iommu/amd_iommu.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/iommu/amd_iommu.c b/drivers/iommu/amd_iommu.c
index 312dd4dd4791..ff16c5ece735 100644
--- a/drivers/iommu/amd_iommu.c
+++ b/drivers/iommu/amd_iommu.c
@@ -3865,6 +3865,7 @@ static struct irq_remap_table *get_irq_table(u16 devid, bool ioapic)
3865 table->table = kmem_cache_alloc(amd_iommu_irq_cache, GFP_ATOMIC); 3865 table->table = kmem_cache_alloc(amd_iommu_irq_cache, GFP_ATOMIC);
3866 if (!table->table) { 3866 if (!table->table) {
3867 kfree(table); 3867 kfree(table);
3868 table = NULL;
3868 goto out; 3869 goto out;
3869 } 3870 }
3870 3871