From: Julia Lawall <julia.law...@lip6.fr>

The various devm_ functions allocate memory that is released when a driver
detaches.  This patch uses these functions for data that is allocated in
the probe function of a platform device and is only freed in the remove
function.

Signed-off-by: Julia Lawall <julia.law...@lip6.fr>

---
Not compiled.

 drivers/i2c/busses/i2c-ibm_iic.c |    4 +---
 1 file changed, 1 insertion(+), 3 deletions(-)

diff --git a/drivers/i2c/busses/i2c-ibm_iic.c b/drivers/i2c/busses/i2c-ibm_iic.c
index 806e225..76435c2 100644
--- a/drivers/i2c/busses/i2c-ibm_iic.c
+++ b/drivers/i2c/busses/i2c-ibm_iic.c
@@ -699,7 +699,7 @@ static int __devinit iic_probe(struct platform_device 
*ofdev)
        const u32 *freq;
        int ret;
 
-       dev = kzalloc(sizeof(*dev), GFP_KERNEL);
+       dev = devm_kzalloc(&ofdev->dev, sizeof(*dev), GFP_KERNEL);
        if (!dev) {
                dev_err(&ofdev->dev, "failed to allocate device data\n");
                return -ENOMEM;
@@ -774,7 +774,6 @@ error_cleanup:
                iounmap(dev->vaddr);
 
        dev_set_drvdata(&ofdev->dev, NULL);
-       kfree(dev);
        return ret;
 }
 
@@ -795,7 +794,6 @@ static int __devexit iic_remove(struct platform_device 
*ofdev)
        }
 
        iounmap(dev->vaddr);
-       kfree(dev);
 
        return 0;
 }

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to