2016-06-30 21:18:56 +08:00
|
|
|
.. -*- coding: utf-8; mode: rst -*-
|
|
|
|
|
2016-07-12 17:12:32 +08:00
|
|
|
.. _lirc-read:
|
2016-06-30 21:18:56 +08:00
|
|
|
|
2016-07-10 08:03:57 +08:00
|
|
|
***********
|
|
|
|
LIRC read()
|
|
|
|
***********
|
|
|
|
|
|
|
|
Name
|
|
|
|
====
|
|
|
|
|
|
|
|
lirc-read - Read from a LIRC device
|
|
|
|
|
|
|
|
|
|
|
|
Synopsis
|
|
|
|
========
|
|
|
|
|
|
|
|
.. code-block:: c
|
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
|
2016-08-19 23:00:43 +08:00
|
|
|
.. c:function:: ssize_t read( int fd, void *buf, size_t count )
|
2016-07-10 08:03:57 +08:00
|
|
|
|
|
|
|
|
|
|
|
Arguments
|
|
|
|
=========
|
|
|
|
|
|
|
|
``fd``
|
|
|
|
File descriptor returned by ``open()``.
|
|
|
|
|
|
|
|
``buf``
|
|
|
|
``count``
|
|
|
|
|
|
|
|
|
|
|
|
Description
|
|
|
|
===========
|
|
|
|
|
|
|
|
:ref:`read() <lirc-read>` attempts to read up to ``count`` bytes from file
|
|
|
|
descriptor ``fd`` into the buffer starting at ``buf``. If ``count`` is zero,
|
|
|
|
:ref:`read() <lirc-read>` returns zero and has no other results. If ``count``
|
|
|
|
is greater than ``SSIZE_MAX``, the result is unspecified.
|
2016-06-30 21:18:56 +08:00
|
|
|
|
|
|
|
The lircd userspace daemon reads raw IR data from the LIRC chardev. The
|
|
|
|
exact format of the data depends on what modes a driver supports, and
|
|
|
|
what mode has been selected. lircd obtains supported modes and sets the
|
2016-07-12 20:35:26 +08:00
|
|
|
active mode via the ioctl interface, detailed at :ref:`lirc_func`.
|
|
|
|
The generally preferred mode for receive is
|
|
|
|
:ref:`LIRC_MODE_MODE2 <lirc-mode-mode2>`, in which packets containing an
|
|
|
|
int value describing an IR signal are read from the chardev.
|
2016-06-30 21:18:56 +08:00
|
|
|
|
|
|
|
See also
|
|
|
|
`http://www.lirc.org/html/technical.html <http://www.lirc.org/html/technical.html>`__
|
|
|
|
for more info.
|
2016-07-10 08:03:57 +08: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.
|