drivers/video/au*fb.c: use devm_ functions
authorJulia Lawall <julia.lawall@lip6.fr>
Sat, 21 Jan 2012 15:01:58 +0000 (16:01 +0100)
committerFlorian Tobias Schandinat <FlorianSchandinat@gmx.de>
Sat, 28 Jan 2012 20:47:52 +0000 (20:47 +0000)
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.

In au1100fb.c, the probe function now returns -ENODEV on failure.

Signed-off-by: Julia Lawall <Julia.Lawall@lip6.fr>
Acked-by: Manuel Lauss <manuel.lauss@googlemail.com>
Signed-off-by: Florian Tobias Schandinat <FlorianSchandinat@gmx.de>
drivers/video/au1100fb.c
drivers/video/au1200fb.c

index de9da67..befcbd8 100644 (file)
@@ -477,7 +477,8 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev)
        u32 sys_clksrc;
 
        /* Allocate new device private */
-       fbdev = kzalloc(sizeof(struct au1100fb_device), GFP_KERNEL);
+       fbdev = devm_kzalloc(&dev->dev, sizeof(struct au1100fb_device),
+                            GFP_KERNEL);
        if (!fbdev) {
                print_err("fail to allocate device private record");
                return -ENOMEM;
@@ -498,8 +499,9 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev)
        au1100fb_fix.mmio_start = regs_res->start;
        au1100fb_fix.mmio_len = resource_size(regs_res);
 
-       if (!request_mem_region(au1100fb_fix.mmio_start, au1100fb_fix.mmio_len,
-                               DRIVER_NAME)) {
+       if (!devm_request_mem_region(au1100fb_fix.mmio_start,
+                                    au1100fb_fix.mmio_len,
+                                    DRIVER_NAME)) {
                print_err("fail to lock memory region at 0x%08lx",
                                au1100fb_fix.mmio_start);
                return -EBUSY;
@@ -514,8 +516,9 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev)
        fbdev->fb_len = fbdev->panel->xres * fbdev->panel->yres *
                        (fbdev->panel->bpp >> 3) * AU1100FB_NBR_VIDEO_BUFFERS;
 
-       fbdev->fb_mem = dma_alloc_coherent(&dev->dev, PAGE_ALIGN(fbdev->fb_len),
-                                       &fbdev->fb_phys, GFP_KERNEL);
+       fbdev->fb_mem = dmam_alloc_coherent(&dev->dev, &dev->dev,
+                                           PAGE_ALIGN(fbdev->fb_len),
+                                           &fbdev->fb_phys, GFP_KERNEL);
        if (!fbdev->fb_mem) {
                print_err("fail to allocate frambuffer (size: %dK))",
                          fbdev->fb_len / 1024);
@@ -557,14 +560,14 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev)
        fbdev->info.fbops = &au1100fb_ops;
        fbdev->info.fix = au1100fb_fix;
 
-       if (!(fbdev->info.pseudo_palette = kzalloc(sizeof(u32) * 16, GFP_KERNEL))) {
+       fbdev->info.pseudo_palette =
+               devm_kzalloc(&dev->dev, sizeof(u32) * 16, GFP_KERNEL);
+       if (!fbdev->info.pseudo_palette)
                return -ENOMEM;
-       }
 
        if (fb_alloc_cmap(&fbdev->info.cmap, AU1100_LCD_NBR_PALETTE_ENTRIES, 0) < 0) {
                print_err("Fail to allocate colormap (%d entries)",
                           AU1100_LCD_NBR_PALETTE_ENTRIES);
-               kfree(fbdev->info.pseudo_palette);
                return -EFAULT;
        }
 
@@ -582,9 +585,6 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev)
        return 0;
 
 failed:
-       if (fbdev->regs) {
-               release_mem_region(fbdev->regs_phys, fbdev->regs_len);
-       }
        if (fbdev->fb_mem) {
                dma_free_noncoherent(&dev->dev, fbdev->fb_len, fbdev->fb_mem,
                                     fbdev->fb_phys);
@@ -592,10 +592,9 @@ failed:
        if (fbdev->info.cmap.len != 0) {
                fb_dealloc_cmap(&fbdev->info.cmap);
        }
-       kfree(fbdev);
        platform_set_drvdata(dev, NULL);
 
-       return 0;
+       return -ENODEV;
 }
 
 int au1100fb_drv_remove(struct platform_device *dev)
@@ -615,14 +614,7 @@ int au1100fb_drv_remove(struct platform_device *dev)
        /* Clean up all probe data */
        unregister_framebuffer(&fbdev->info);
 
-       release_mem_region(fbdev->regs_phys, fbdev->regs_len);
-
-       dma_free_coherent(&dev->dev, PAGE_ALIGN(fbdev->fb_len), fbdev->fb_mem,
-                         fbdev->fb_phys);
-
        fb_dealloc_cmap(&fbdev->info.cmap);
-       kfree(fbdev->info.pseudo_palette);
-       kfree((void*)fbdev);
 
        return 0;
 }
index 04e4479..3e9a773 100644 (file)
@@ -1724,7 +1724,7 @@ static int __devinit au1200fb_drv_probe(struct platform_device *dev)
                /* Allocate the framebuffer to the maximum screen size */
                fbdev->fb_len = (win->w[plane].xres * win->w[plane].yres * bpp) / 8;
 
-               fbdev->fb_mem = dma_alloc_noncoherent(&dev->dev,
+               fbdev->fb_mem = dmam_alloc_noncoherent(&dev->dev, &dev->dev,
                                PAGE_ALIGN(fbdev->fb_len),
                                &fbdev->fb_phys, GFP_KERNEL);
                if (!fbdev->fb_mem) {
@@ -1788,9 +1788,6 @@ static int __devinit au1200fb_drv_probe(struct platform_device *dev)
 
 failed:
        /* NOTE: This only does the current plane/window that failed; others are still active */
-       if (fbdev->fb_mem)
-               dma_free_noncoherent(&dev->dev, PAGE_ALIGN(fbdev->fb_len),
-                               fbdev->fb_mem, fbdev->fb_phys);
        if (fbi) {
                if (fbi->cmap.len != 0)
                        fb_dealloc_cmap(&fbi->cmap);
@@ -1817,10 +1814,6 @@ static int __devexit au1200fb_drv_remove(struct platform_device *dev)
 
                /* Clean up all probe data */
                unregister_framebuffer(fbi);
-               if (fbdev->fb_mem)
-                       dma_free_noncoherent(&dev->dev,
-                                       PAGE_ALIGN(fbdev->fb_len),
-                                       fbdev->fb_mem, fbdev->fb_phys);
                if (fbi->cmap.len != 0)
                        fb_dealloc_cmap(&fbi->cmap);
                kfree(fbi->pseudo_palette);