Commit 29160019 authored by Pavel Shved's avatar Pavel Shved Committed by Paul Mundt

hecubafb: add module_put on error path in hecubafb_probe()

In hecubafb_probe(), after a successful try_module_get, vzalloc may
fail and make the hecubafb_probe return, but the module is not put on
this error path.

This patch adds an exit point that calls module_put in such situation.

Found by Linux Driver Verification project (linuxtesting.org).
Signed-off-by: default avatarPavel Shved <shved@ispras.ru>
Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent 9845afc8
...@@ -233,7 +233,7 @@ static int __devinit hecubafb_probe(struct platform_device *dev) ...@@ -233,7 +233,7 @@ static int __devinit hecubafb_probe(struct platform_device *dev)
videomemory = vzalloc(videomemorysize); videomemory = vzalloc(videomemorysize);
if (!videomemory) if (!videomemory)
return retval; goto err_videomem_alloc;
info = framebuffer_alloc(sizeof(struct hecubafb_par), &dev->dev); info = framebuffer_alloc(sizeof(struct hecubafb_par), &dev->dev);
if (!info) if (!info)
...@@ -275,6 +275,7 @@ static int __devinit hecubafb_probe(struct platform_device *dev) ...@@ -275,6 +275,7 @@ static int __devinit hecubafb_probe(struct platform_device *dev)
framebuffer_release(info); framebuffer_release(info);
err_fballoc: err_fballoc:
vfree(videomemory); vfree(videomemory);
err_videomem_alloc:
module_put(board->owner); module_put(board->owner);
return retval; return retval;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment