aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJulia Lawall <julia@diku.dk>2011-05-20 15:31:59 -0300
committerMauro Carvalho Chehab <mchehab@redhat.com>2011-05-20 16:34:24 -0300
commitaeb35ebc5f54bcdd7163f5282a3f39bc48c75cae (patch)
treef60e6cc36643cc7d424d3f7dcc923b7535e36f5a
parentda4b7b2011ecbdc0377b0c0263e85c2d474e3d5a (diff)
downloadkernel_samsung_aries-aeb35ebc5f54bcdd7163f5282a3f39bc48c75cae.zip
kernel_samsung_aries-aeb35ebc5f54bcdd7163f5282a3f39bc48c75cae.tar.gz
kernel_samsung_aries-aeb35ebc5f54bcdd7163f5282a3f39bc48c75cae.tar.bz2
[media] imon: Correct call to input_free_device
ictx->touch is intialied in imon_init_intf1, to the result of calling the function that contains this code. Thus, in this code, input_free_device should be called on touch itself. A simplified version of the semantic match that finds this problem is: (http://coccinelle.lip6.fr/) // <smpl> @r exists@ local idexpression struct input_dev * x; expression ra,rr; position p1,p2; @@ x = input_allocate_device@p1(...) ... when != x = rr when != input_free_device(x,...) when != if (...) { ... input_free_device(x,...) ...} if(...) { ... when != x = ra when forall when != input_free_device(x,...) \(return <+...x...+>; \| return@p2...; \) } @script:python@ p1 << r.p1; p2 << r.p2; @@ cocci.print_main("input_allocate_device",p1) cocci.print_secs("input_free_device",p2) // </smpl> Signed-off-by: Julia Lawall <julia@diku.dk> Signed-off-by: Jarod Wilson <jarod@redhat.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r--drivers/media/rc/imon.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/media/rc/imon.c b/drivers/media/rc/imon.c
index 2d2476d..3f3c707 100644
--- a/drivers/media/rc/imon.c
+++ b/drivers/media/rc/imon.c
@@ -1970,7 +1970,7 @@ static struct input_dev *imon_init_touch(struct imon_context *ictx)
return touch;
touch_register_failed:
- input_free_device(ictx->touch);
+ input_free_device(touch);
touch_alloc_failed:
return NULL;