2020-11-26 14:13:36 +03:00
.. SPDX-License-Identifier: GPL-2.0 OR GFDL-1.1-no-invariants-or-later
2020-09-25 08:29:25 +03:00
.. c:namespace :: RC
2018-08-30 17:15:26 +03:00
2016-07-12 12:12:32 +03:00
.. _lirc-read:
2016-06-30 16:18:56 +03:00
2016-07-10 03:03:57 +03:00
***** ***** *
LIRC read()
***** ***** *
Name
====
lirc-read - Read from a LIRC device
Synopsis
========
.. code-block :: c
#include <unistd.h>
2016-08-19 18:00:43 +03:00
.. c:function :: ssize_t read( int fd, void *buf, size_t count )
2016-07-10 03:03:57 +03:00
Arguments
=========
`` fd ``
File descriptor returned by `` open() `` .
`` buf ``
2016-08-19 22:59:31 +03:00
Buffer to be filled
2016-07-10 03:03:57 +03:00
2016-08-19 22:59:31 +03:00
`` count ``
Max number of bytes to read
2016-07-10 03:03:57 +03:00
Description
===========
2020-09-25 08:29:25 +03:00
:c:func: `read()` attempts to read up to `` count `` bytes from file
2016-07-10 03:03:57 +03:00
descriptor `` fd `` into the buffer starting at `` buf `` . If `` count `` is zero,
2020-09-25 08:29:25 +03:00
:c:func: `read()` returns zero and has no other results. If `` count ``
2016-07-10 03:03:57 +03:00
is greater than `` SSIZE_MAX `` , the result is unspecified.
2016-06-30 16:18:56 +03:00
2017-02-08 20:10:30 +03:00
The exact format of the data depends on what :ref: `lirc_modes` a driver
2017-02-25 14:51:34 +03:00
uses. Use :ref: `lirc_get_features` to get the supported mode, and use
:ref: `lirc_set_rec_mode` set the current active mode.
2016-06-30 16:18:56 +03:00
2017-02-25 14:51:34 +03:00
The mode :ref: `LIRC_MODE_MODE2 <lirc-mode-mode2>` is for raw IR,
in which packets containing an unsigned int value describing an IR signal are
2017-02-08 20:10:30 +03:00
read from the chardev.
2016-07-10 03:03:57 +03:00
2017-02-25 14:51:34 +03:00
Alternatively, :ref: `LIRC_MODE_SCANCODE <lirc-mode-scancode>` can be available,
in this mode scancodes which are either decoded by software decoders, or
2017-11-30 16:00:45 +03:00
by hardware decoders. The :c:type: `rc_proto` member is set to the
2019-07-25 22:32:31 +03:00
:ref: `IR protocol <Remote_controllers_Protocols>`
used for transmission, and `` scancode `` to the decoded scancode,
2017-02-25 14:51:34 +03:00
and the `` keycode `` set to the keycode or `` KEY_RESERVED `` .
2016-07-10 03:03:57 +03:00
Return Value
============
On success, the number of bytes read is returned. It is not an error if
this number is smaller than the number of bytes requested, or the amount
of data required for one frame. On error, -1 is returned, and the `` errno ``
variable is set appropriately.