aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@redhat.com>2012-01-09 19:28:13 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2012-01-10 19:35:28 -0500
commit90bf3aab42937f760e5b645ab63df46d26b5e620 (patch)
treeed1dec61c0283b4ef0beae71dbbebbf11bf57b4c
parentc53a8e951b9cb5689a510ef31c85fb9b1ff78f11 (diff)
[media] cx231xx-input: stop polling if the device got removed.
If the device got removed, stops polling it. Also, un-registers it at input/evdev, as it won't work anymore. We can't free the IR structure yet, as the ir_remove method will be called later. Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r--drivers/media/video/cx231xx/cx231xx-input.c6
-rw-r--r--drivers/media/video/ir-kbd-i2c.c17
2 files changed, 18 insertions, 5 deletions
diff --git a/drivers/media/video/cx231xx/cx231xx-input.c b/drivers/media/video/cx231xx/cx231xx-input.c
index 45e14cac4622..8a75a908e709 100644
--- a/drivers/media/video/cx231xx/cx231xx-input.c
+++ b/drivers/media/video/cx231xx/cx231xx-input.c
@@ -27,12 +27,16 @@
27static int get_key_isdbt(struct IR_i2c *ir, u32 *ir_key, 27static int get_key_isdbt(struct IR_i2c *ir, u32 *ir_key,
28 u32 *ir_raw) 28 u32 *ir_raw)
29{ 29{
30 int rc;
30 u8 cmd, scancode; 31 u8 cmd, scancode;
31 32
32 dev_dbg(&ir->rc->input_dev->dev, "%s\n", __func__); 33 dev_dbg(&ir->rc->input_dev->dev, "%s\n", __func__);
33 34
34 /* poll IR chip */ 35 /* poll IR chip */
35 if (1 != i2c_master_recv(ir->c, &cmd, 1)) 36 rc = i2c_master_recv(ir->c, &cmd, 1);
37 if (rc < 0)
38 return rc;
39 if (rc != 1)
36 return -EIO; 40 return -EIO;
37 41
38 /* it seems that 0xFE indicates that a button is still hold 42 /* it seems that 0xFE indicates that a button is still hold
diff --git a/drivers/media/video/ir-kbd-i2c.c b/drivers/media/video/ir-kbd-i2c.c
index 3ab875d036e1..37d0c2012519 100644
--- a/drivers/media/video/ir-kbd-i2c.c
+++ b/drivers/media/video/ir-kbd-i2c.c
@@ -244,7 +244,7 @@ static int get_key_avermedia_cardbus(struct IR_i2c *ir,
244 244
245/* ----------------------------------------------------------------------- */ 245/* ----------------------------------------------------------------------- */
246 246
247static void ir_key_poll(struct IR_i2c *ir) 247static int ir_key_poll(struct IR_i2c *ir)
248{ 248{
249 static u32 ir_key, ir_raw; 249 static u32 ir_key, ir_raw;
250 int rc; 250 int rc;
@@ -253,20 +253,28 @@ static void ir_key_poll(struct IR_i2c *ir)
253 rc = ir->get_key(ir, &ir_key, &ir_raw); 253 rc = ir->get_key(ir, &ir_key, &ir_raw);
254 if (rc < 0) { 254 if (rc < 0) {
255 dprintk(2,"error\n"); 255 dprintk(2,"error\n");
256 return; 256 return rc;
257 } 257 }
258 258
259 if (rc) { 259 if (rc) {
260 dprintk(1, "%s: keycode = 0x%04x\n", __func__, ir_key); 260 dprintk(1, "%s: keycode = 0x%04x\n", __func__, ir_key);
261 rc_keydown(ir->rc, ir_key, 0); 261 rc_keydown(ir->rc, ir_key, 0);
262 } 262 }
263 return 0;
263} 264}
264 265
265static void ir_work(struct work_struct *work) 266static void ir_work(struct work_struct *work)
266{ 267{
268 int rc;
267 struct IR_i2c *ir = container_of(work, struct IR_i2c, work.work); 269 struct IR_i2c *ir = container_of(work, struct IR_i2c, work.work);
268 270
269 ir_key_poll(ir); 271 rc = ir_key_poll(ir);
272 if (rc == -ENODEV) {
273 rc_unregister_device(ir->rc);
274 ir->rc = NULL;
275 return;
276 }
277
270 schedule_delayed_work(&ir->work, msecs_to_jiffies(ir->polling_interval)); 278 schedule_delayed_work(&ir->work, msecs_to_jiffies(ir->polling_interval));
271} 279}
272 280
@@ -446,7 +454,8 @@ static int ir_remove(struct i2c_client *client)
446 cancel_delayed_work_sync(&ir->work); 454 cancel_delayed_work_sync(&ir->work);
447 455
448 /* unregister device */ 456 /* unregister device */
449 rc_unregister_device(ir->rc); 457 if (ir->rc)
458 rc_unregister_device(ir->rc);
450 459
451 /* free memory */ 460 /* free memory */
452 kfree(ir); 461 kfree(ir);