aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/dvb-frontends/s5h1432.c
diff options
context:
space:
mode:
authorPeter Senna Tschudin <peter.senna@gmail.com>2012-09-12 07:56:02 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2012-10-06 10:13:07 -0400
commit47aab4ab20259526419712df4c5d98b914d968dc (patch)
treefda268eb9f96da41de8e828afd9e93fd24dfcc96 /drivers/media/dvb-frontends/s5h1432.c
parent1a5d2da1134c4d7371db71377815aa3fff9f75cd (diff)
[media] drivers/media/dvb-frontends/s5h1432.c: Removes useless kfree()
Remove useless kfree() and clean up code related to the removal. The semantic patch that finds this problem is as follows: (http://coccinelle.lip6.fr/) // <smpl> @r exists@ position p1,p2; expression x; @@ if (x@p1 == NULL) { ... kfree@p2(x); ... return ...; } @unchanged exists@ position r.p1,r.p2; expression e <= r.x,x,e1; iterator I; statement S; @@ if (x@p1 == NULL) { ... when != I(x,...) S when != e = e1 when != e += e1 when != e -= e1 when != ++e when != --e when != e++ when != e-- when != &e kfree@p2(x); ... return ...; } @ok depends on unchanged exists@ position any r.p1; position r.p2; expression x; @@ ... when != true x@p1 == NULL kfree@p2(x); @depends on !ok && unchanged@ position r.p2; expression x; @@ *kfree@p2(x); // </smpl> Signed-off-by: Peter Senna Tschudin <peter.senna@gmail.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/dvb-frontends/s5h1432.c')
-rw-r--r--drivers/media/dvb-frontends/s5h1432.c8
1 files changed, 2 insertions, 6 deletions
diff --git a/drivers/media/dvb-frontends/s5h1432.c b/drivers/media/dvb-frontends/s5h1432.c
index 8352ce1c9556..6ec16a243741 100644
--- a/drivers/media/dvb-frontends/s5h1432.c
+++ b/drivers/media/dvb-frontends/s5h1432.c
@@ -351,8 +351,8 @@ struct dvb_frontend *s5h1432_attach(const struct s5h1432_config *config,
351 printk(KERN_INFO " Enter s5h1432_attach(). attach success!\n"); 351 printk(KERN_INFO " Enter s5h1432_attach(). attach success!\n");
352 /* allocate memory for the internal state */ 352 /* allocate memory for the internal state */
353 state = kmalloc(sizeof(struct s5h1432_state), GFP_KERNEL); 353 state = kmalloc(sizeof(struct s5h1432_state), GFP_KERNEL);
354 if (state == NULL) 354 if (!state)
355 goto error; 355 return NULL;
356 356
357 /* setup the state */ 357 /* setup the state */
358 state->config = config; 358 state->config = config;
@@ -367,10 +367,6 @@ struct dvb_frontend *s5h1432_attach(const struct s5h1432_config *config,
367 state->frontend.demodulator_priv = state; 367 state->frontend.demodulator_priv = state;
368 368
369 return &state->frontend; 369 return &state->frontend;
370
371error:
372 kfree(state);
373 return NULL;
374} 370}
375EXPORT_SYMBOL(s5h1432_attach); 371EXPORT_SYMBOL(s5h1432_attach);
376 372