Difference between revisions of "LIRC"

From ArchWiki
Jump to navigation Jump to search
m (The LIRC Config File: remove redundant info)
m (Testing the Remote: reword)
Line 78: Line 78:
  000000037ff07bf2 01 Home mceusb
  000000037ff07bf2 01 Home mceusb
If this does not work (irw gives no output): double check your config files in /etc/lirc/lircd.conf.d/ for errors.
If {{ic|irw}} gives no output, double check the config files in {{ic|/etc/lirc/lircd.conf.d/}} for errors.
==Program Specific Configuration ==
==Program Specific Configuration ==

Revision as of 06:22, 22 October 2015

This article covers setup and usage of LIRC "Linux Infrared Remote Control" with serial or USB infrared devices.


LIRC is a daemon that can translate key presses on a supported remote into program specific commands. In this context, the term, "program specific" means that a key press can do different things depending on which program is running and taking commands from LIRC.

The Central Dogma of LIRC

The list below attempts to show the flow of information from the remote to the application using LIRC:

  • User hits a button on the remote causing it to transmit an IR or RF signal.
  • The signal is received by the receiver connected to the Linux box.
  • The kernel (via the correct module) use presents pulse data from the remote on a device like /dev/lirc0, /dev/input/eventX, /dev/ttyUSBX or /dev/ttyS0.
  • /usr/bin/lircd uses the information from /etc/lirc/lircd.conf.d/foo.conf to convert the pulse data into button press information.
  • Programs that use LIRC translate the button press info from /usr/bin/lircd into user-defined actions according to ~/.lircrc or to program-specific mappings.

Required Files

  • /etc/lirc/lircd.conf.d/foo.conf - System-level config translating scancodes --> keys. This directory may contain multiple conf files and each one is specific to each remote control/receiver on the system.
Note: These are user-created config files not directly supplied by lirc.

Optional Files

Depending on the application using LIRC, the following are optional. For example, mplayer and mythtv use the these files to define key maps and actions. Some other programs such as kodi for example do not make use of this at all but do have an internal system to achieve these mappings. Users should consult the documentation for the specific application to know if modifications to ~/.lircrc are needed.

  • ~/.lircrc - File containing an include statement pointing to each program's lirc map, i.e., ~/.lirc/foo, ~/.lirc/bar, etc.
  • ~/.lirc/foo - User-level config translating of keys --> actions. Is specific to each remote and to application foo.


Install the lirc package, which is available in the official repositories.

Note: Module support for older remotes (such as the Hauppauge PVR-250) have been officially dropped upstream. Search the AUR for packages to build a module if using unsupported hardware.


Note: This section is a quick n'dirty summary. More verbose documentation is available upstream.

The LIRC Config File

The definition of scancodes to keymaps is required to allow LIRC to manage a remote. Users have several options to obtain one.

Option 1. Upstream provided config files

Identify which remote/receiver is to be used and see if there is a known config for it. One can use irdb-get to search the remotes database of remotes or simply browse to the URL and do the same.

An example using irdb-get to find a config file for a Streamzap remote:

$ irdb-get find stream

$ irdb-get download streamzap/streamzap.lircd.conf 
Downloaded https://sourceforge.net/p/lirc-remotes/code/ci/master/tree/remotes/streamzap/streamzap.lircd.conf as streamzap.lircd.conf

Once identified, copy the needed conf to /etc/lirc/lircd.conf.d/ to allow the daemon to initialize support for it.

# cp streamzap.lircd.conf /etc/lirc/lircd.conf.d/

Option 2. User created config files

Users with unsupported hardware will need to either find a config file someone else has created (i.e. google) or create one. Creating one is fairly straightforward using the included /usr/bin/irrecord program which guides users along the needed process. If using a detected remote, invoke it like so:

irrecord --device=/dev/lirc0 MyRemote

The program will ask users to begin hitting keys on the remote in an attempt to learn it. If all goes well, the user will be prompted to map out each key press to a specific scancode LIRC uses to identify that specific key press. The process should take no more than 10 minutes. When finished, save the resulting file to /etc/lirc/lircd.conf.d/foo.conf and proceed.

Note: Consider sending the finished config file to the email address mentioned in the program so it can be made available to others.

Testing the Remote

Start lircd.service and enable it to run at boot time/shutdown (highly recommended).

Test the remote using /usr/bin/irw, which simply echos anything received by LIRC when users push buttons on the remote to stdout.


$ irw
000000037ff07bfe 00 One mceusb
000000037ff07bfd 00 Two mceusb
000000037ff07bfd 01 Two mceusb
000000037ff07bf2 00 Home mceusb
000000037ff07bf2 01 Home mceusb

If irw gives no output, double check the config files in /etc/lirc/lircd.conf.d/ for errors.

Program Specific Configuration

LIRC has the ability to allow for different programs to use the same keypress and result in unique commands. In other words, mplayer and vlc can respond differently to a given key press.

Decide which programs are to use LIRC commands. Common programs include: mplayer, mythtv, totem, vlc, and kodi.

Note: Kodi implements LIRC in a non-standard way. Users must edit ~/.xbmc/userdata/Lircmap.xml which is a unique xml file, rather than the LIRC standard files the rest of the programs use. Interested users should consult the Kodi#Using a remote control article.

Users should create the expected files showing LIRC where the various program-specific maps reside:

$ mkdir ~/.lirc
$ touch ~/.lircrc
  • Populate ~/.lirc with the program specific config files named for each program.


$ ls ~/.lirc
Note: Providing an exhaustive listing of keymaps for each program is beyond the scope of this wiki article. Many pre-made files unique to each remote/program are available via googling.
  • Edit ~/.lircrc to contain an include statement pointing to ~/.lirc/foo and repeat for each program that is to be controlled by LIRC.


include "~/.lirc/mplayer"
include "~/.lirc/mythtv"
include "~/.lirc/vlc"


Remote functions as a keyboard

Xorg detects some remotes, such as the Streamzap USB PC Remote, as a Human Interface Device (HID) which means some or all of the keys will show up as key strokes as if entered from the physical keyboard. This behavior will present problems if LIRC is to be used to manage the device. To disable, create the following file and restart X:

Section "InputClass"
  Identifier "Ignore Streamzap IR"
  MatchProduct "Streamzap"
  MatchIsKeyboard "true"
  Option "Ignore" "true"

Do not forget to alter the MatchProduct property according to one shown in Name from output of

$ cat /proc/bus/input/devices | grep -e IR

For example WinFast for N: Name="cx88 IR (WinFast DTV2000 H rev."

See also