media: lirc: scancode rc devices should have a lirc device too
authorSean Young <sean@mess.org>
Sun, 24 Sep 2017 16:43:24 +0000 (12:43 -0400)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Thu, 14 Dec 2017 15:35:22 +0000 (10:35 -0500)
Now that the lirc interface supports scancodes, RC scancode devices
can also have a lirc device. The only receiving feature they will have
enabled is LIRC_CAN_REC_SCANCODE.

Note that CEC devices have no lirc device, since they can be controlled
from their /dev/cecN chardev.

Signed-off-by: Sean Young <sean@mess.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@s-opensource.com>
drivers/media/rc/ir-lirc-codec.c
drivers/media/rc/lirc_dev.c
drivers/media/rc/rc-main.c

index 817258c87b5c57ab066f36c5979517133c332625..8c5df6e8579ebf6178688cd667bebac3089b45cd 100644 (file)
@@ -304,6 +304,9 @@ static long ir_lirc_ioctl(struct file *filep, unsigned int cmd,
 
        switch (cmd) {
        case LIRC_GET_FEATURES:
+               if (dev->driver_type == RC_DRIVER_SCANCODE)
+                       val |= LIRC_CAN_REC_SCANCODE;
+
                if (dev->driver_type == RC_DRIVER_IR_RAW) {
                        val |= LIRC_CAN_REC_MODE2 | LIRC_CAN_REC_SCANCODE;
                        if (dev->rx_resolution)
@@ -344,11 +347,19 @@ static long ir_lirc_ioctl(struct file *filep, unsigned int cmd,
                break;
 
        case LIRC_SET_REC_MODE:
-               if (dev->driver_type == RC_DRIVER_IR_RAW_TX)
+               switch (dev->driver_type) {
+               case RC_DRIVER_IR_RAW_TX:
                        return -ENOTTY;
-
-               if (!(val == LIRC_MODE_MODE2 || val == LIRC_MODE_SCANCODE))
-                       return -EINVAL;
+               case RC_DRIVER_SCANCODE:
+                       if (val != LIRC_MODE_SCANCODE)
+                               return -EINVAL;
+                       break;
+               case RC_DRIVER_IR_RAW:
+                       if (!(val == LIRC_MODE_MODE2 ||
+                             val == LIRC_MODE_SCANCODE))
+                               return -EINVAL;
+                       break;
+               }
 
                dev->rec_mode = val;
                return 0;
index d766abcffeac8156115c1fbe0d303c80945e9d57..2a0c48698309ca3ba04bfe65599c1b543bcb2ef6 100644 (file)
@@ -57,7 +57,10 @@ int ir_lirc_register(struct rc_dev *dev)
        dev->lirc_dev.release = lirc_release_device;
        dev->send_mode = LIRC_MODE_PULSE;
 
-       dev->rec_mode = LIRC_MODE_MODE2;
+       if (dev->driver_type == RC_DRIVER_SCANCODE)
+               dev->rec_mode = LIRC_MODE_SCANCODE;
+       else
+               dev->rec_mode = LIRC_MODE_MODE2;
 
        if (dev->driver_type == RC_DRIVER_IR_RAW) {
                if (kfifo_alloc(&dev->rawir, MAX_IR_EVENT_SIZE, GFP_KERNEL))
index 058807bc80dccd029ca4bb825a8524128b2b5eca..5830cb2c59436d01013254cafd230aad4573d04f 100644 (file)
@@ -1814,7 +1814,7 @@ int rc_register_device(struct rc_dev *dev)
        }
 
        /* Ensure that the lirc kfifo is setup before we start the thread */
-       if (dev->driver_type != RC_DRIVER_SCANCODE) {
+       if (dev->allowed_protocols != RC_PROTO_BIT_CEC) {
                rc = ir_lirc_register(dev);
                if (rc < 0)
                        goto out_rx;
@@ -1835,7 +1835,7 @@ int rc_register_device(struct rc_dev *dev)
        return 0;
 
 out_lirc:
-       if (dev->driver_type != RC_DRIVER_SCANCODE)
+       if (dev->allowed_protocols != RC_PROTO_BIT_CEC)
                ir_lirc_unregister(dev);
 out_rx:
        rc_free_rx_device(dev);
@@ -1898,7 +1898,7 @@ void rc_unregister_device(struct rc_dev *dev)
         * lirc device should be freed with dev->registered = false, so
         * that userspace polling will get notified.
         */
-       if (dev->driver_type != RC_DRIVER_SCANCODE)
+       if (dev->allowed_protocols != RC_PROTO_BIT_CEC)
                ir_lirc_unregister(dev);
 
        device_del(&dev->dev);