media: lirc: when transmitting scancodes, block until transmit is done
authorSean Young <sean@mess.org>
Mon, 11 Dec 2017 22:12:09 +0000 (17:12 -0500)
committerMauro Carvalho Chehab <mchehab@s-opensource.com>
Mon, 18 Dec 2017 20:19:57 +0000 (15:19 -0500)
The semantics for lirc IR transmit with raw IR is that the write call
should block until the IR is transmitted. Some drivers have no idea
when this actually is (e.g. mceusb), so there is a wait.

This is useful for userspace, as it might want to send a IR button press,
a gap of a predefined number of milliseconds, and then send a repeat
message.

It turns out that for transmitting scancodes this feature is even more
useful, as user space has no idea how long the IR is. So, maintain
the existing semantics for IR scancode transmit.

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

index dd3d1fe807a62edb2e438c4db015b3ef5fb6ef64..d4566b0a2015f796750ef44cb5d19c726bc9c1ed 100644 (file)
@@ -60,8 +60,8 @@ When in :ref:`LIRC_MODE_SCANCODE <lirc-mode-scancode>` mode, one
 and the protocol in the :c:type:`rc_proto`: member. All other members must be
 set to 0, else ``EINVAL`` is returned. If there is no protocol encoder
 for the protocol or the scancode is not valid for the specified protocol,
-``EINVAL`` is returned. The write function may not wait until the scancode
-is transmitted.
+``EINVAL`` is returned. The write function blocks until the scancode
+is transmitted by the hardware.
 
 
 Return Value
index 218658917cf62607f55995fac6b19b22c5e5480c..6cedb546c3e0fe1346a2cbea867e2830d1b328bd 100644 (file)
@@ -354,18 +354,18 @@ static ssize_t ir_lirc_transmit_ir(struct file *file, const char __user *buf,
                        duration += txbuf[i];
 
                ret *= sizeof(unsigned int);
+       }
 
-               /*
-                * The lircd gap calculation expects the write function to
-                * wait for the actual IR signal to be transmitted before
-                * returning.
-                */
-               towait = ktime_us_delta(ktime_add_us(start, duration),
-                                       ktime_get());
-               if (towait > 0) {
-                       set_current_state(TASK_INTERRUPTIBLE);
-                       schedule_timeout(usecs_to_jiffies(towait));
-               }
+       /*
+        * The lircd gap calculation expects the write function to
+        * wait for the actual IR signal to be transmitted before
+        * returning.
+        */
+       towait = ktime_us_delta(ktime_add_us(start, duration),
+                               ktime_get());
+       if (towait > 0) {
+               set_current_state(TASK_INTERRUPTIBLE);
+               schedule_timeout(usecs_to_jiffies(towait));
        }
 
 out: