diff options
author | Axel Lin <axel.lin@gmail.com> | 2010-11-08 08:35:10 +0300 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2010-11-08 09:08:42 +0300 |
commit | 899be96db75451ba98cb217109ef4cf2ee6de927 (patch) | |
tree | b84ded26b414c160a6a430f55b38f4cc9c28dfa7 /drivers/rtc/rtc-sh.c | |
parent | 151f52f09c5728ecfdd0c289da1a4b30bb416f2c (diff) | |
download | linux-899be96db75451ba98cb217109ef4cf2ee6de927.tar.xz |
rtc: rtc-sh - fix a memory leak
request_mem_region() will call kzalloc to allocate memory for struct resource.
release_resource() unregisters the resource but does not free the allocated
memory, thus use release_mem_region() instead to fix the memory leak.
Signed-off-by: Axel Lin <axel.lin@gmail.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'drivers/rtc/rtc-sh.c')
-rw-r--r-- | drivers/rtc/rtc-sh.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/rtc/rtc-sh.c b/drivers/rtc/rtc-sh.c index 5efbd5990ff8..06e41ed93230 100644 --- a/drivers/rtc/rtc-sh.c +++ b/drivers/rtc/rtc-sh.c @@ -761,7 +761,7 @@ err_unmap: clk_put(rtc->clk); iounmap(rtc->regbase); err_badmap: - release_resource(rtc->res); + release_mem_region(rtc->res->start, rtc->regsize); err_badres: kfree(rtc); @@ -786,7 +786,7 @@ static int __exit sh_rtc_remove(struct platform_device *pdev) } iounmap(rtc->regbase); - release_resource(rtc->res); + release_mem_region(rtc->res->start, rtc->regsize); clk_disable(rtc->clk); clk_put(rtc->clk); |