irqchip/gic-v3-its: Free unused vpt_page when alloc vpe table fail
authorNianyao Tang <tangnianyao@huawei.com>
Fri, 26 Jul 2019 09:32:57 +0000 (17:32 +0800)
committerMarc Zyngier <maz@kernel.org>
Fri, 26 Jul 2019 13:27:21 +0000 (14:27 +0100)
In its_vpe_init, when its_alloc_vpe_table fails, we should free
vpt_page allocated just before, instead of vpe->vpt_page.
Let's fix it.

Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Jason Cooper <jason@lakedaemon.net>
Cc: Marc Zyngier <marc.zyngier@arm.com>
Signed-off-by: Nianyao Tang <tangnianyao@huawei.com>
Signed-off-by: Shaokun Zhang <zhangshaokun@hisilicon.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
drivers/irqchip/irq-gic-v3-its.c

index cfb9b4e..4439ed8 100644 (file)
@@ -3008,7 +3008,7 @@ static int its_vpe_init(struct its_vpe *vpe)
 
        if (!its_alloc_vpe_table(vpe_id)) {
                its_vpe_id_free(vpe_id);
-               its_free_pending_table(vpe->vpt_page);
+               its_free_pending_table(vpt_page);
                return -ENOMEM;
        }