Commit 0cc11867 authored by Mike Isely's avatar Mike Isely Committed by Mauro Carvalho Chehab

V4L/DVB (8901): pvrusb2: Disable virtual IR device when not needed.

Disable "virtual" IR receiver on for 24xxx devices that have an
internal IR blaster.  In that case there's another another IR
receiver present and to leave the virtual receiver available
just causes confusion.  This means that 24xxx users will no
longer see a phantom IR chip.
Signed-off-by: default avatarMike Isely <isely@pobox.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 432907f7
...@@ -948,22 +948,32 @@ static struct i2c_adapter pvr2_i2c_adap_template = { ...@@ -948,22 +948,32 @@ static struct i2c_adapter pvr2_i2c_adap_template = {
.client_unregister = pvr2_i2c_detach_inform, .client_unregister = pvr2_i2c_detach_inform,
}; };
static void do_i2c_scan(struct pvr2_hdw *hdw)
/* Return true if device exists at given address */
static int do_i2c_probe(struct pvr2_hdw *hdw, int addr)
{ {
struct i2c_msg msg[1]; struct i2c_msg msg[1];
int i,rc; int rc;
msg[0].addr = 0; msg[0].addr = 0;
msg[0].flags = I2C_M_RD; msg[0].flags = I2C_M_RD;
msg[0].len = 0; msg[0].len = 0;
msg[0].buf = NULL; msg[0].buf = NULL;
printk("%s: i2c scan beginning\n",hdw->name); msg[0].addr = addr;
rc = i2c_transfer(&hdw->i2c_adap, msg, ARRAY_SIZE(msg));
return rc == 1;
}
static void do_i2c_scan(struct pvr2_hdw *hdw)
{
int i;
printk(KERN_INFO "%s: i2c scan beginning\n", hdw->name);
for (i = 0; i < 128; i++) { for (i = 0; i < 128; i++) {
msg[0].addr = i; if (do_i2c_probe(hdw, i)) {
rc = i2c_transfer(&hdw->i2c_adap,msg, ARRAY_SIZE(msg)); printk(KERN_INFO "%s: i2c scan: found device @ 0x%x\n",
if (rc != 1) continue; hdw->name, i);
printk("%s: i2c scan: found device @ 0x%x\n",hdw->name,i); }
} }
printk("%s: i2c scan done.\n",hdw->name); printk(KERN_INFO "%s: i2c scan done.\n", hdw->name);
} }
void pvr2_i2c_core_init(struct pvr2_hdw *hdw) void pvr2_i2c_core_init(struct pvr2_hdw *hdw)
...@@ -1008,6 +1018,16 @@ void pvr2_i2c_core_init(struct pvr2_hdw *hdw) ...@@ -1008,6 +1018,16 @@ void pvr2_i2c_core_init(struct pvr2_hdw *hdw)
mutex_init(&hdw->i2c_list_lock); mutex_init(&hdw->i2c_list_lock);
hdw->i2c_linked = !0; hdw->i2c_linked = !0;
i2c_add_adapter(&hdw->i2c_adap); i2c_add_adapter(&hdw->i2c_adap);
if (hdw->i2c_func[0x18] == i2c_24xxx_ir) {
/* Probe for a different type of IR receiver on this
device. If present, disable the emulated IR receiver. */
if (do_i2c_probe(hdw, 0x71)) {
pvr2_trace(PVR2_TRACE_INFO,
"Device has newer IR hardware;"
" disabling unneeded virtual IR device");
hdw->i2c_func[0x18] = NULL;
}
}
if (i2c_scan) do_i2c_scan(hdw); if (i2c_scan) do_i2c_scan(hdw);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment