Home > PC Home Cinema > LIRC – Quelques explications

LIRC – Quelques explications

On trouve de nombreux tutoriels sur le net à propos de LIRC. « Fais ci », « édite ce fichier », et « relance ça comme ça ». Et puis « bidouille ce truc aussi s’il te plaît ! ». Bref, beaucoup d’actions opérées en aveugles et un bon paquet de lignes de commande absconces pour la plupart des utilisateurs. Plutôt que de « réécrire la roue » (magnifique figure de style, n’est ce pas ?) avec un autre tuto, je vais profiter de cet article pour faire quelque chose qu’on voit rarement : décrire le fonctionnement de l’application, le pourquoi des fichiers de configuration et leur rôle.
Attention : dans cette article je ne couvrirai que les systèmes basés sur Debian.

LIRC, mais c’est quoi en fait?

LIRC est une excellente suite logicielle visant à utiliser des télécommandes avec GNU/Linux. Sa compatibilité avec tout et n’importe quoi et sa versatilité en font un incontournable de tout PC orienté Home Cinema.
Concrètement, et c’est souvent ce qu’on a du mal à comprendre la première fois qu’on y touche,  LIRC est un mot fourre-tout pour ce qui est à la fois une paquet d’éxécutables  (sous forme de démon ou non), un framework (utilisable par les application tierces), et un ensemble de modules noyaux (pour piloter le hardware de vos récepteurs).
Mais assez de présentations, entrons dans le vif du sujet :

/etc/lirc/hardware.conf, le fichier de configuration du matériel

C’est ici qu’est défini le matériel. Ça vous l’aviez compris tout seul, non?
Par contre, et là je pense que je vous apprends quelque chose,  il ne fait pas partie de LIRC ! Ce fichier de configuration est une aide, laissée par les packageurs de votre distribution afin de simplifier l’utilisation des démons contrôlant LIRC. Il est donc nécessaire de faire attention à ce que vous lisez sur Internet, car en fonction de votre distribution les paramètres peuvent drastiquement changer. Le fichier peut même être totalement inutile. (Pour l’anecdote, je l’ai appris à mes dépends en perdant quelques heures lors d’une migration Ubuntu vers Debian)
Concrètement, ce fichier est lu par le script de démarrage de LIRC (/etc/init.d/lirc,  dont le contenu change selon les distributions). Celui-ci  prépare l’environnement et construit la ligne de commande adéquate pour lancer le démon LIRC.

Je ne vais pas tout couvrir, mais les paramètres les plus importants sont :

  • REMOTE : Ah non, en fait ce paramètre ne sert pas à grand chose. Je vous ai bien eu non? Il est principalement esthétique. Mettez y ce qu’on vous dit d’y mettre et puis c’est tout.
  • REMOTE_MODULE : Le script d’initialisation parcourt ce paramètre et avant toute opération charge les modules noyaux mentionnés ici. Bien entendu ces modules doivent être installés et compatibles avec le noyau que vous utilisez actuellement.  Où les trouver ? Ils sont généralement issue directement du projet LIRC. Soit vous avez de la chance et ils sont disponibles directement dans votre distribution, patiemment reconstruit par les packageurs à chaque nouvelle version de noyau, soit vous devrez les faire vous même avec la commande m-a, acronyme de module-assistant (reportez vous aux différents tuto sur le sujet). Pour vérifier que le module est OK, n’hésitez pas à vous amuser avec les commandes lsmod, modprobe et rmmod afin de voir si celui ci se charge correctement. Le chargement du module, si OK, devrait faire apparaître un fichier périphérique dans /dev/ (exemple /dev/ttyUSB0 pour mon USBuirt)
  • REMOTE_DRIVER : Ceci indique à LIRC quel pilote utiliser pour dialoguer. Cette notion de pilote est cette fois interne à LIRC  : Il ne s’agit pas de périphérique noyau mais juste de définir comment LIRC va dialoguer avec votre périphérique /dev/machin. La subtilité, c’est que LIRC peut très bien avoir été compilé sans le support du périphérique que vous voulez utiliser. Un petit coup de /usr/sbin/lircd -H help ôtera vos doutes rapidement.
  • REMOTE_DEVICE : C’est le fichier périphérique qui a été créé par le module noyau que vous avez chargé. Ceci indique au démon LIRC avec qui il va devoir dialoguer.
  • REMOTE_LIRCD_CONF : L’emplacement du fichier de configuration des télécommandes (habituellement /etc/lirc/lircd.conf, mais vous pouvez mettre ce que vous voulez) . Voir plus bas.

Alors, tout ce beau monde, qu’est ce que ça fait au final ?
Si je prends mon exemple personnel et relativement simple de boitier USBuirt, un passage de /etc/init.d/lirc start me donne maintenant un démon lancé comme ça:

/usr/sbin/lircd --driver=usb_uirt_raw --device=/dev/ttyUSB0 --output=/dev/lircd --listen

Tout ça pour ça, pourrait-on se dire…
Mais au moins, maintenant, à chaque fois que je lance LIRC par le script d’initialisation j’obtiens : des modules chargés, un périphérique bloc /dev/ttyUSB0 monté, un joli démon lancé sur ma machine pour dialoguer avec ce /dev/ttyUSB0 selon le langage « usb_uirt_raw », et ce même démon me crée une jolie socket unix /dev/lircd pour mes logiciels favoris (voir plus bas le rôle de cette socket). Pas mal non? C’est un bon début.

Le fichier de configuration /etc/init.d/lircd.conf

Jusqu’ici le démon lircd que vous pouvez maintenant lancer sait comment dialoguer avec votre périphérique émetteur ou récepteur. Mais il ne sait pas vraiment ce qu’il va trouver pendant son dialogue, qu’est ce qu’il doit garder et qu’est ce qu’il doit jeter. Ce fichier lircd.conf est là pour ça : c’est une sorte de « carte » de votre télécommande. A l’intérieur, des listes de télécommande (si vous en utilisez plusieurs) et pour chaque télécommande des touches avec des jolis noms « user-friendly » et les codes infrarouges correspondant.

Où trouver ce fichier de configuration? Par exemple ici.
Mais si il ne s’y trouve pas, vous pouvez le faire vous même. Vous allez devoir utiliser irrecord pour ça. C’est un exécutable livré ordinairement avec LIRC. Il prend grosso modo les même paramètres que le démon « lircd », donc si vous êtes capables de configurer le fichier hardware.conf et que celui ci vous génère à chaque lancement de /etc/init.d/lirc une belle ligne de commande, alors le plus gros du travail est fait.
Exemple :

irrecord --driver=usb_uirt_raw --device=/dev/ttyUSB0 monlircd.conf

Comme irrecord dialogue directement avec le bloc périphérique, comme lircd, il ne faut pas que ce dernier soit lancé (ils sont exclusifs et très jaloux).
Coté utilisation, c’est très facile : vous suivez les instructions, et il enregistre toutes vos touches les unes après les autres en leur attribuant le joli nom que vous souhaitez.

Mais alors, comment mes applications savent jouer avec LIRC ?

C’est simple, vous vous souvenez de la socket unix dont je parlais plus haut, celle qui est préparée par le démon LIRC? Et bien les applications  se connectent à celle-ci  et écoutent toutes les touches que vous pouvez taper.
Cette socket est nommée /dev/lircd le plus souvent. Si vous souhaitez donner son chemin vous même (par exemple si vous en avez plusieurs), il est défini par le paramètre –output du démon lircd. La plupart des application vont se connecter à /dev/lircd, mais certaines d’entre elles peuvent être configurées pour se connecter au chemin de votre choix (c’est le cas par exemple de mon cher mythtv qui possède ce paramètre dans un coin de la configuration du frontend). Je vous conseille de tout laisser par défaut, c’est suffisant pour 90% des cas.

Vous l’avez compris, mais je me permets de le rappeler : pour qu’une application fonctionne avec LIRC, il faut qu’elle se branche sur la socket unix, et donc qu’elle ait été codée pour çà ! Cela semble évident au premier abord mais c’est pourtant loin d’être automatique si l’on se réfère aux questions qu’on trouve souvent sur les forums.

Et la configuration de ces applications, où se fait-elle?

/home/<user>/.lircrc, où comment en avoir marre de tous ces fichiers de configuration

Les applications se connectent à la socket lircd, OK. Mais comment l’application sait quoi faire selon la touche pressée? C’est ici qu’intervient le fichier .lircrc.
Contrairement à une autre idée fréquemment répandue, ce n’est pas un fichier de configuration de LIRC. C’est un fichier de configuration de vos applications finales !
En effet, celles ci parcourent immanquablement le fichier ~/.lircrc (et les éventuels sous fichier inclus avec la directive include), y repèrent leur propre marqueur (c’est le rôle de l’attribut « prog« ), et enregistre la carte des événements déclenchés en fonction des touches appuyées. Exemple :

begin
remote = NOVA-T500
prog = mplayer
button = Play
config = pause
end

L’appui de la touche « Play » (touche nommée ainsi dans le fichier /etc/lirc/lircd.conf qui établit la correspondance nom <–> code infrarouge), provoque l’événement « pause » dans l’application mplayer.

Et voilà ! C’était pas si compliqué (hum…)

Une synthèse s’il te plaît, pour finir un article trop long !

Comme je suis attentif à vos remarques, la voici :
lircd est un démon qui s’interface avec un périphérique /dev/machinX (donc le fichier bloc est créé par un module noyau appartenant parfois au projet LIRC) selon un protocole de communication appelé « driver » par LIRC. Une fois que lircd est lancé, celui ci va à son tour lire un fichier de conf (/etc/lirc/lircd.conf par défaut). Ce fichier décrit les codes infrarouges susceptibles d’être échangés avec le périphérique (les codes sont regroupés en appareil). Le démon créé ensuite une socket de type /dev/lircdX avec lequel les programmes peuvent s’interfacer facilement.
Les programmes se connectent à cette belle socket, lisent un fichier de conf .lircrc dans le home de l’utilisateur, repèrent le mappage touche <–> événement à déclencher, et VOUS POUVEZ ENFIN REGARDER DES VIDEOS DEPUIS VOTRE CANAPE.

Article sous licence « Creative Common Merciciel ». Vous en faites ce vous voulez, mais je veux un merci si vous l’avez bien aimé.

Tags: GNU/Linux LIRC PCHC

Comments:7

  1. quent57 Répondre
    décembre 21, 2010 at 5:51

    Merci 🙂
    Il faudrait un autre article pour expliquer comment cela marche avec evdev, mais c’est déjà très bien pour commencer à comprendre.
    Je file mettre un lien vers cette page sur la doc Ubuntu, si il n’y est pas déjà.
    Quent57

  2. Gwendal Répondre
    décembre 21, 2010 at 6:32

    Oui, effectivement, tu fais bien de le mentionner.
    C’est le gros chantier du moment, l’inrégration des pilotes de télécommandes dans le noyau impose de connaitre aussi evdev.

  3. quent57 Répondre
    décembre 23, 2010 at 5:35

    Bonjour,
    M’autorise-tu à user du copier coller intelligent et à modifier des phrases pour la doc Ubuntu ?
    J’ai bien vus Creative Common Merciciel, mais je demande quand même au cas ou.
    Je n’oublierai pas un merci !
    Tu pourra en retour copier les infos qui te semblent utiles sur ton site, comme la doc Ubuntu est aussi sous licence libre (CC by SA).

    Cordialement
    Quent 57

    • Gwendal Répondre
      décembre 23, 2010 at 6:07

      C’est avec grand plaisir que je t’autorise (et même que je t’encourage) à le modifier/copier comme tu le sens.

  4. quent57 Répondre
    décembre 23, 2010 at 5:39

    En faite, que veux tu dire par la : (Pour l’anecdote, je l’ai appris à mes dépends en perdant quelques heures lors d’une migration Ubuntu vers Debian) ??
    Merci d’avance 🙂

    • Gwendal Répondre
      décembre 23, 2010 at 6:17

      A l’époque de ma migration, le script d’init de lircd distribué avec Debian ne comptait pas toutes les possibilités de celui distribué sur Ubuntu.
      Je ne me souviens plus précisément, mais il me semble que celui d’Ubuntu est, entre autre, capable de gérer plusieurs démons (un pour la réception et un pour l’émission), ce qui n’était pas possible directement avec Debian.
      J’avais copié mon fichier de configuration d’Ubuntu directement sur ma Debian toute neuve, et je ne comprenais pas pourquoi cela ne fonctionnait pas. Il a fallu que je me plonge dans le fonctionnement de LIRC pour voir que les scripts init différaient, et que c’était lui qui était chargé de lire le fichier hardware.conf et de lancer le (les) démon(s) avec les bons paramètres.

      Bref, à l’époque, après toutes ces recherches, j’avais fini par copier l’excellent script d’initialisation d’Ubuntu dans ma Debian, avec quelques ajustements pour le faire marcher.

  5. quent57 Répondre
    décembre 23, 2010 at 6:23

    Merci pour ton accord et pour ces détails 🙂
    Si tu veux te tenir au courant de ce que je fait, je travail en ce moment sur cette page : http://doc.ubuntu-fr.org/utilisateurs/quent57/lirc_avancee .
    Ton avis est le bienvenue 🙂

Répondre à Gwendal Annuler la réponse

Votre adresse e-mail ne sera pas publiée.