parisc: fix possible memory leak in pat_query_module()
authorWei Yongjun <yongjun_wei@trendmicro.com.cn>
Sun, 2 Sep 2012 14:23:59 +0000 (14:23 +0000)
committerHelge Deller <deller@gmx.de>
Wed, 20 Feb 2013 21:47:11 +0000 (22:47 +0100)
pa_pdc_cell has been allocated in this function and so should be
freed before leaving from the error handling cases.

spatch with a semantic match is used to found this problem.
(http://coccinelle.lip6.fr/)

Signed-off-by: Wei Yongjun <yongjun_wei@trendmicro.com.cn>
Signed-off-by: Helge Deller <deller@gmx.de>
arch/parisc/kernel/inventory.c

index 08324aa..3295ef4 100644 (file)
@@ -186,12 +186,14 @@ pat_query_module(ulong pcell_loc, ulong mod_index)
 
        if (status != PDC_OK) {
                /* no more cell modules or error */
+               kfree(pa_pdc_cell);
                return status;
        }
 
        temp = pa_pdc_cell->cba;
        dev = alloc_pa_dev(PAT_GET_CBA(temp), &(pa_pdc_cell->mod_path));
        if (!dev) {
+               kfree(pa_pdc_cell);
                return PDC_OK;
        }