Commit dde7edff authored by Sean Young's avatar Sean Young Committed by Mauro Carvalho Chehab

media: lirc: when transmitting scancodes, block until transmit is done

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: default avatarSean Young <sean@mess.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
parent fb7ccc61
...@@ -60,8 +60,8 @@ When in :ref:`LIRC_MODE_SCANCODE <lirc-mode-scancode>` mode, one ...@@ -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 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 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, 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 ``EINVAL`` is returned. The write function blocks until the scancode
is transmitted. is transmitted by the hardware.
Return Value Return Value
......
...@@ -354,18 +354,18 @@ static ssize_t ir_lirc_transmit_ir(struct file *file, const char __user *buf, ...@@ -354,18 +354,18 @@ static ssize_t ir_lirc_transmit_ir(struct file *file, const char __user *buf,
duration += txbuf[i]; duration += txbuf[i];
ret *= sizeof(unsigned int); ret *= sizeof(unsigned int);
}
/* /*
* The lircd gap calculation expects the write function to * The lircd gap calculation expects the write function to
* wait for the actual IR signal to be transmitted before * wait for the actual IR signal to be transmitted before
* returning. * returning.
*/ */
towait = ktime_us_delta(ktime_add_us(start, duration), towait = ktime_us_delta(ktime_add_us(start, duration),
ktime_get()); ktime_get());
if (towait > 0) { if (towait > 0) {
set_current_state(TASK_INTERRUPTIBLE); set_current_state(TASK_INTERRUPTIBLE);
schedule_timeout(usecs_to_jiffies(towait)); schedule_timeout(usecs_to_jiffies(towait));
}
} }
out: out:
......
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