drivers/video/au*fb.c: use devm_ functions
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>
This commit is contained in:
parent
92a9c19a89
commit
1c16697bf9
@ -477,7 +477,8 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev)
|
|||||||
u32 sys_clksrc;
|
u32 sys_clksrc;
|
||||||
|
|
||||||
/* Allocate new device private */
|
/* 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) {
|
if (!fbdev) {
|
||||||
print_err("fail to allocate device private record");
|
print_err("fail to allocate device private record");
|
||||||
return -ENOMEM;
|
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_start = regs_res->start;
|
||||||
au1100fb_fix.mmio_len = resource_size(regs_res);
|
au1100fb_fix.mmio_len = resource_size(regs_res);
|
||||||
|
|
||||||
if (!request_mem_region(au1100fb_fix.mmio_start, au1100fb_fix.mmio_len,
|
if (!devm_request_mem_region(au1100fb_fix.mmio_start,
|
||||||
DRIVER_NAME)) {
|
au1100fb_fix.mmio_len,
|
||||||
|
DRIVER_NAME)) {
|
||||||
print_err("fail to lock memory region at 0x%08lx",
|
print_err("fail to lock memory region at 0x%08lx",
|
||||||
au1100fb_fix.mmio_start);
|
au1100fb_fix.mmio_start);
|
||||||
return -EBUSY;
|
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->fb_len = fbdev->panel->xres * fbdev->panel->yres *
|
||||||
(fbdev->panel->bpp >> 3) * AU1100FB_NBR_VIDEO_BUFFERS;
|
(fbdev->panel->bpp >> 3) * AU1100FB_NBR_VIDEO_BUFFERS;
|
||||||
|
|
||||||
fbdev->fb_mem = dma_alloc_coherent(&dev->dev, PAGE_ALIGN(fbdev->fb_len),
|
fbdev->fb_mem = dmam_alloc_coherent(&dev->dev, &dev->dev,
|
||||||
&fbdev->fb_phys, GFP_KERNEL);
|
PAGE_ALIGN(fbdev->fb_len),
|
||||||
|
&fbdev->fb_phys, GFP_KERNEL);
|
||||||
if (!fbdev->fb_mem) {
|
if (!fbdev->fb_mem) {
|
||||||
print_err("fail to allocate frambuffer (size: %dK))",
|
print_err("fail to allocate frambuffer (size: %dK))",
|
||||||
fbdev->fb_len / 1024);
|
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.fbops = &au1100fb_ops;
|
||||||
fbdev->info.fix = au1100fb_fix;
|
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;
|
return -ENOMEM;
|
||||||
}
|
|
||||||
|
|
||||||
if (fb_alloc_cmap(&fbdev->info.cmap, AU1100_LCD_NBR_PALETTE_ENTRIES, 0) < 0) {
|
if (fb_alloc_cmap(&fbdev->info.cmap, AU1100_LCD_NBR_PALETTE_ENTRIES, 0) < 0) {
|
||||||
print_err("Fail to allocate colormap (%d entries)",
|
print_err("Fail to allocate colormap (%d entries)",
|
||||||
AU1100_LCD_NBR_PALETTE_ENTRIES);
|
AU1100_LCD_NBR_PALETTE_ENTRIES);
|
||||||
kfree(fbdev->info.pseudo_palette);
|
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -582,9 +585,6 @@ static int __devinit au1100fb_drv_probe(struct platform_device *dev)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
failed:
|
failed:
|
||||||
if (fbdev->regs) {
|
|
||||||
release_mem_region(fbdev->regs_phys, fbdev->regs_len);
|
|
||||||
}
|
|
||||||
if (fbdev->fb_mem) {
|
if (fbdev->fb_mem) {
|
||||||
dma_free_noncoherent(&dev->dev, fbdev->fb_len, fbdev->fb_mem,
|
dma_free_noncoherent(&dev->dev, fbdev->fb_len, fbdev->fb_mem,
|
||||||
fbdev->fb_phys);
|
fbdev->fb_phys);
|
||||||
@ -592,10 +592,9 @@ failed:
|
|||||||
if (fbdev->info.cmap.len != 0) {
|
if (fbdev->info.cmap.len != 0) {
|
||||||
fb_dealloc_cmap(&fbdev->info.cmap);
|
fb_dealloc_cmap(&fbdev->info.cmap);
|
||||||
}
|
}
|
||||||
kfree(fbdev);
|
|
||||||
platform_set_drvdata(dev, NULL);
|
platform_set_drvdata(dev, NULL);
|
||||||
|
|
||||||
return 0;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
|
||||||
int au1100fb_drv_remove(struct platform_device *dev)
|
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 */
|
/* Clean up all probe data */
|
||||||
unregister_framebuffer(&fbdev->info);
|
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);
|
fb_dealloc_cmap(&fbdev->info.cmap);
|
||||||
kfree(fbdev->info.pseudo_palette);
|
|
||||||
kfree((void*)fbdev);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -1724,7 +1724,7 @@ static int __devinit au1200fb_drv_probe(struct platform_device *dev)
|
|||||||
/* Allocate the framebuffer to the maximum screen size */
|
/* Allocate the framebuffer to the maximum screen size */
|
||||||
fbdev->fb_len = (win->w[plane].xres * win->w[plane].yres * bpp) / 8;
|
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),
|
PAGE_ALIGN(fbdev->fb_len),
|
||||||
&fbdev->fb_phys, GFP_KERNEL);
|
&fbdev->fb_phys, GFP_KERNEL);
|
||||||
if (!fbdev->fb_mem) {
|
if (!fbdev->fb_mem) {
|
||||||
@ -1788,9 +1788,6 @@ static int __devinit au1200fb_drv_probe(struct platform_device *dev)
|
|||||||
|
|
||||||
failed:
|
failed:
|
||||||
/* NOTE: This only does the current plane/window that failed; others are still active */
|
/* 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) {
|
||||||
if (fbi->cmap.len != 0)
|
if (fbi->cmap.len != 0)
|
||||||
fb_dealloc_cmap(&fbi->cmap);
|
fb_dealloc_cmap(&fbi->cmap);
|
||||||
@ -1817,10 +1814,6 @@ static int __devexit au1200fb_drv_remove(struct platform_device *dev)
|
|||||||
|
|
||||||
/* Clean up all probe data */
|
/* Clean up all probe data */
|
||||||
unregister_framebuffer(fbi);
|
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)
|
if (fbi->cmap.len != 0)
|
||||||
fb_dealloc_cmap(&fbi->cmap);
|
fb_dealloc_cmap(&fbi->cmap);
|
||||||
kfree(fbi->pseudo_palette);
|
kfree(fbi->pseudo_palette);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user