[media] tm6000: bugfix data check
authorStefan Ringel <linuxtv@stefanringel.de>
Mon, 28 Nov 2011 18:46:20 +0000 (15:46 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Mon, 28 Nov 2011 23:31:09 +0000 (21:31 -0200)
beholder use a map with 3 bytes, but many rc maps have 2 bytes, so I add a workaround for beholder rc.

Signed-off-by: Stefan Ringel <linuxtv@stefanringel.de>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/video/tm6000/tm6000-input.c

index 405d12729d057c0d6eebce12d5614f266c3211a8..ae7772e7f2664f48eed262186f6767edca81ae1d 100644 (file)
@@ -178,9 +178,21 @@ static int default_polling_getkey(struct tm6000_IR *ir,
                        poll_result->rc_data = ir->urb_data[0];
                        break;
                case RC_TYPE_NEC:
-                       if (ir->urb_data[1] == ((ir->key_addr >> 8) & 0xff)) {
+                       switch (dev->model) {
+                       case 10:
+                       case 11:
+                       case 14:
+                       case 15:
+                               if (ir->urb_data[1] ==
+                                       ((ir->key_addr >> 8) & 0xff)) {
+                                       poll_result->rc_data =
+                                       ir->urb_data[0]
+                                       | ir->urb_data[1] << 8;
+                               }
+                               break;
+                       default:
                                poll_result->rc_data = ir->urb_data[0]
-                                                       | ir->urb_data[1] << 8;
+                                       | ir->urb_data[1] << 8;
                        }
                        break;
                default:
@@ -238,8 +250,6 @@ static void tm6000_ir_handle_key(struct tm6000_IR *ir)
                return;
        }
 
-       dprintk("ir->get_key result data=%04x\n", poll_result.rc_data);
-
        if (ir->pwled) {
                if (ir->pwledcnt >= PWLED_OFF) {
                        ir->pwled = 0;
@@ -250,6 +260,7 @@ static void tm6000_ir_handle_key(struct tm6000_IR *ir)
        }
 
        if (ir->key) {
+               dprintk("ir->get_key result data=%04x\n", poll_result.rc_data);
                rc_keydown(ir->rc, poll_result.rc_data, 0);
                ir->key = 0;
                ir->pwled = 1;
@@ -333,7 +344,7 @@ int tm6000_ir_int_start(struct tm6000_core *dev)
                ir->int_urb->transfer_buffer, size,
                tm6000_ir_urb_received, dev,
                dev->int_in.endp->desc.bInterval);
-       err = usb_submit_urb(ir->int_urb, GFP_KERNEL);
+       err = usb_submit_urb(ir->int_urb, GFP_ATOMIC);
        if (err) {
                kfree(ir->int_urb->transfer_buffer);
                usb_free_urb(ir->int_urb);