aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrank Schaefer <fschaefer.oss@googlemail.com>2013-02-17 07:40:05 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2013-03-05 15:10:43 -0500
commitfa563073281d7be6c685a0bb8ca6b2737e00f368 (patch)
tree086457f506908d82ca16d67a9573df0ae8c3d7f3
parente6a60d768bc7b767439c56e34e345eb2fe873b06 (diff)
[media] bttv: make remote controls of devices with i2c ir decoder working
Request module ir-kbd-i2c if an i2c ir decoder is detected. Tested with device "Hauppauge WinTV Theatre" (model 37284 rev B421). Signed-off-by: Frank Schäfer <fschaefer.oss@googlemail.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
-rw-r--r--drivers/media/pci/bt8xx/bttv-input.c22
1 files changed, 13 insertions, 9 deletions
diff --git a/drivers/media/pci/bt8xx/bttv-input.c b/drivers/media/pci/bt8xx/bttv-input.c
index 04207a799055..01c71214f9ec 100644
--- a/drivers/media/pci/bt8xx/bttv-input.c
+++ b/drivers/media/pci/bt8xx/bttv-input.c
@@ -375,6 +375,7 @@ void init_bttv_i2c_ir(struct bttv *btv)
375 I2C_CLIENT_END 375 I2C_CLIENT_END
376 }; 376 };
377 struct i2c_board_info info; 377 struct i2c_board_info info;
378 struct i2c_client *i2c_dev;
378 379
379 if (0 != btv->i2c_rc) 380 if (0 != btv->i2c_rc)
380 return; 381 return;
@@ -390,7 +391,12 @@ void init_bttv_i2c_ir(struct bttv *btv)
390 btv->init_data.ir_codes = RC_MAP_PV951; 391 btv->init_data.ir_codes = RC_MAP_PV951;
391 info.addr = 0x4b; 392 info.addr = 0x4b;
392 break; 393 break;
393 default: 394 }
395
396 if (btv->init_data.name) {
397 info.platform_data = &btv->init_data;
398 i2c_dev = i2c_new_device(&btv->c.i2c_adap, &info);
399 } else {
394 /* 400 /*
395 * The external IR receiver is at i2c address 0x34 (0x35 for 401 * The external IR receiver is at i2c address 0x34 (0x35 for
396 * reads). Future Hauppauge cards will have an internal 402 * reads). Future Hauppauge cards will have an internal
@@ -399,16 +405,14 @@ void init_bttv_i2c_ir(struct bttv *btv)
399 * internal. 405 * internal.
400 * That's why we probe 0x1a (~0x34) first. CB 406 * That's why we probe 0x1a (~0x34) first. CB
401 */ 407 */
402 408 i2c_dev = i2c_new_probed_device(&btv->c.i2c_adap, &info, addr_list, NULL);
403 i2c_new_probed_device(&btv->c.i2c_adap, &info, addr_list, NULL);
404 return;
405 } 409 }
410 if (NULL == i2c_dev)
411 return;
406 412
407 if (btv->init_data.name) 413#if defined(CONFIG_MODULES) && defined(MODULE)
408 info.platform_data = &btv->init_data; 414 request_module("ir-kbd-i2c");
409 i2c_new_device(&btv->c.i2c_adap, &info); 415#endif
410
411 return;
412} 416}
413 417
414int fini_bttv_i2c(struct bttv *btv) 418int fini_bttv_i2c(struct bttv *btv)