Remote-plugin

Aus VDR Wiki
Wechseln zu: Navigation, Suche

Inhaltsverzeichnis

Beschreibung

Autor: Oliver Endriss

Das Plugin (auch genannt: Remote Control Plugin) erweitert die Möglichkeiten zur Fernbedienung des VDR. Es handelt sich um einen modularen Zusatz zur VDR-Software, mit dem sich insbesondere der IR-Original-Empfänger der DVB-Karte Hauppauge Nexus 2.1/2.2 nutzen lässt. Es werden die mit den Karten mitgelieferten Fernbedienungen (sowohl die alte schwarze als auch die neue silberne) unterstützt. Außerdem kann prinzipiell jede Fernbedienung verwendet werden, die RC5-Code sendet.

Anmerkung: Bei "full-featured" Karten der Version 1.3/1.5/1.6 kann ein IR-Empfänger am FF Karten Jumperblock J2 angeschlossen werden. Dieser Empfänger wird ebenfalls unterstützt, ebenfalls die in CI-Modulen integrierten Empfänger.

Unterstützte Eingabegeräte

Wer genauer wissen möchte, welche Eingabegeräte verwendet werden können, der entnehme der Readme-Datei des Plugins die folgenden Hinweise (hier in übersetzter Version, weiter unten im Original nachzulesen):

(a) Linux Eingabegeräte ('/dev/input/eventX', X=0,1,2,...)

  • eingebauter Fernbedienungs-Port av7110-basierter DVB-Karten (sog. full-featured card), wie z.B. DVB-S Nexus [1] (bis Rev 2.2) und Technotrend Revisionen 1.3,1.5 und 1.6 (auch über Erweiterungsplatinen z.B. das AVBoard)
  • Fernbedienungs-Ports einiger budget cards, wie z.B. Nova-CI [2] und Hauppauge nova-t usb2
  • HTPC Panelknöpfe/Tastaturen(USB), z.B. Silverstone LC16M(R) siehe hier
  • andere Eingabegeräte (noch nicht getestet, bitte erfolgreiche Geräte melden!)
  • Siehe die FAQ-Datei mit einer Liste erfolgreich verwendeter Geräte.

(b) Tastatur (tty driver): /dev/console, /dev/ttyX, optional auch mit OSD (wie bei TCP, s.u.)

(c) TCP-Verbindung (telnet)

(d) LIRC

Anmerkungen:
[1] wird von DVB und DVB-Kernel unterstützt
[2] wird nur vom DVB-Kernel unterstützt

[Das Zusammenspiel von LIRC und Remote-Plugin -anscheinend ein neues Feature- verdient eine eigene Erklärung...]

Bilder

tcp

Konfiguration

Parameter

Parameter (kurz) Parameter (lang) Beschreibung
-i <DEV> --input=<DEV> kernel input device (/dev/input/...)
-l <DEV> --lirc=<DEV> lirc device (/dev/lircd)
-p <TCP:n> --port=<TCP:n > listen on tcp port <n>
-t <DEV> --tty=<DEV> tty device
-T <DEV> --TTY=<DEV> tty device with OSD

Probleme

Infrarot-Port x 1

Es funktioniert immer nur der Infrarot-Port der zuletzt initialisierten Karte. Deshalb kann es passieren, dass mit zwei Premium Karten das Remote-Plugin nicht läuft. Dann hilft das Tauschen der PCI-Slots. Auch durch das Erneuern der DVB-Treiber kann sich die Initialisierungsreihenfolge ändern.

Ergänzung: Für aktuelle Versionen scheint diese Einschränkung nicht mehr zu gelten. U. U. können damit auch Probleme mit udev gelöst werden. In der Praxis kann es nämlich vorkommen, daß z. B. die event-Devices einer Budget-CI und einer Full-Featured Karte von Booten zu Booten die Positionen ändern. Mittels z. B. "-i /dev/input/event1 -i /dev/input/event2" können dann beide Devices angegeben werden - wichtig vor allem, wenn eine andere als die Standard-Fernbedienung verwendet wird.

Wiederholrate zu schnell

Wenn die Wiederholrate der Tastendrücke zu schnell ist (dass der VDR sie nicht mehr verarbeiten kann), hilft dieses Programm:

#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <linux/input.h>
#include <sys/ioctl.h>

#ifndef EVIOCSREP
#define EVIOCSREP _IOW('E', 0x03, int[2])
#endif

/* compile with gcc -o setspeed setspeed.c */


int main(int argc, char** argv) {
   int retval = 0;
   int fd = 0;
   int rep[2];

   rep[0] = 400; // delay
   rep[1] = 200; // repeat rate

   if ((fd = open( "/dev/input/event4", O_RDWR )) < 0) {   // better use /dev/input/ir
       printf("unable to access /dev/input/event4, exiting..\n");
       exit(1);
   }
   if (ioctl(fd, EVIOCSREP, rep)) {
       perror("unable to set delay and repeat rate for input devices");
       exit(1);
   }

   close(fd);
}

Tipps

irexec für den remote port

Für /dev/input/eventX ist auf der Homepage des Entwicklers ein kleiner daemon verfügbar. (siehe Links)

Mit diesem ist es möglich Befehle unabhängig von VDR auszuführen, quasi "irexec" für den "remote port" der DVB Karte.

Übersetzt wird "evexec" wie folgt:

gcc -o /usr/local/bin/evexec evexec.c

Starten könnte man "evexec" zbs. über die runvdr, wichtig hierbei, das der DVB Driver zuvor geladen wurde.

grep -s ^[0-9]: "/etc/evexec.conf" |
while IFS=: read a b c ; do
    evexec /dev/input/event${a} ${b} "${c}" 2>/dev/null &
done

Suse 10.0 mit hotplug

Bei Suse 10.0 mit hotplug usw

-P'remote -i /dev/input/ir'

ir zeigt immer auf das aktuelle eventX, egal ob der VDR mit oder ohne Tastatur gestartet wird.

Immer das gleiche Device für DVB-Karten Infrarotreceiver

Falls man "udev" für die Erstellung der Devices nutzt, kann man durch Anpassung der udev Regeln immer das gleiche Device für den Infrarotempfänger zuweisen lassen, so das das aktuelle eventX des Infrarotempfängers immer auf "/dev/event/ir" zeigt

  • Bei Suse 10.0 mit hotplug:
KERNEL=="event*", SYSFS{name}=="DVB on-card IR receiver", NAME="input/%k", SYMLINK="input/ir"
  • Bei LFS SVN-Version (hier vom 11.11.2006) folgendes in die /etc/udev/lfs.rules hinzufügen:
KERNEL=="input*", ATTRS{name}=="DVB on-card IR receiver", SYMLINK+="input/ir"
  • Bei Ubuntu o.a., einen udev-Regelsatz mit folgendem Inhalt anlegen.
Datei
/etc/udev/rules.d/70-remote-device.rules
  SUBSYSTEM!="input", GOTO="remote_event_grp_end"
  ATTRS{name}=="*dvb*|*DVB*|* IR *", ENV{ID_CLASS}="ir" GROUP="vdr" SYMLINK+="input/ir"
  LABEL="remote_event_grp_end"


  • Bei Debian Lenny an das Ende der Datei /etc/udev/rules.d/50-udev.rules die fogende Zeile
 KERNELS=="input*", ATTRS{name}=="DVB on-card IR receiver", SYMLINK+="input/ir"

Alternativ kann man dem remote plugin ab version 0.4. so was /dev/input/by-path/pci-0000:00:14.0-event-ir mitgeben.

Falls es mit diesen Regeln nicht funktionieren sollte kann man auch eine eigene Regel erstellen in dem man die Daten des Devices aus dem "SYSFS" ausliest. Dann wie folgt verfahren:

udevinfo -q path -n /dev/input/event2

gibt an wo sich das Device im SYSFS befindet, hier ist es /class/input/input40/event2. Dann mit dieser Adresse folgendes:

udevinfo -a -p /class/input/input40/event2

der Output wäre hier:

               looking at device '/class/input/input40/event2':
                KERNEL=="event2"
                SUBSYSTEM=="input"
                DRIVER==""
                ATTR{dev}=="13:66"

               looking at parent device '/class/input/input40':
       X------- KERNELS=="input40"
       I        SUBSYSTEMS=="input"
       I        DRIVERS==""
       I        ATTRS{uniq}==""
       I        ATTRS{phys}==""
       I   X--- ATTRS{name}=="DVB on-card IR receiver"
       I   I
       I   X-------------------------X                          Aktion
       I                             I                             I
KERNELS=="input*", ATTRS{name}=="DVB on-card IR receiver", SYMLINK+="input/ir"

daraus ergibt sich dann für die Regel, man wählt das Device aus welchen den Eintrag DVB on-card IR receiver enthält (hier /class/input/input40), an erster Stelle kommt dann die Gruppe (der Stern gibt an, alle Einträge mit input ohne Bezug auf die Nummer zu überprüfen) dann der Name und zuletzt die durchzuführende Aktion, als durchzuführende Aktion wäre auch ein PROGRAM="script oder ähnliches" denkbar

und dann noch entweder den udev daemon oder das System neu starten und das Plugin mit

-P'remote -i /dev/input/ir'

starten.

Bei Ubuntu 8.04 wird das remote Plugin automatisch gestarted. Die Optionen für das Plugin werden bem Start von VDR aus

/etc/vdr/plugins/plugin.remote.conf 

gelesen. Damit das remote Plugin auf /dev/input/ir zugreift also dort

-i /dev/input/ir

eintragen. (Ubuntu Standardeintrag ist -i autodetect)

ACHTUNG: eventX und inputX sind von System zu System unterschiedlich, um herauszufinden auf welchem input-device der IR-Receiver liegt, hilft ein "dmesg" und nach folgenden suchen input: DVB on-card IR receiver as /class/input/inputX.

Alternativvorschlag (ohne udev Regel): Ich habe hier mal ein "Mini-Skript" eingefügt, was bei mir (Opensuse) funktioniert und im runvdr vor dem Aufruf den Link passend auf /dev/input/ir setzt (geht bestimmt noch schöner, aber es klappt), eventuell mit sudo ausführen:

ln -sf $(for x in `ls /dev/input/event*` ; do  
 if [ -n "$(udevinfo -a -p `udevinfo -q path -n $x` | grep DVB)" ] ; then 
 echo $x; fi ; done) /dev/input/ir 

Weiterer Alternativ-Vorschlag Man kann auch aus der Ausgabe von lsinput (input-utils Paket) mittels Device und Vendor IDs das Input Device bestimmen (siehe auch [1], wo man auch den entsprechenden Befehl mit RegEx herauskopieren kann).

auswählen des Input Devices per PCI Slot ab Version 0.4.0 ist auch Auswahl über das PCI Device möglich (benötigt udev)

-P"remote -i /dev/input/by-path/pci-0000:02:06.0--event-ir"

Hinweis: Da dies device dynamisch vergeben wird, kann eine genaue Beobachtung von /dev/input/by-path/ nach verschiedenen Neustarts helfen, wenn es zu Problemen kommt. Wenn sich zum Beispiel die letzte Ziffer ändert, hilft dort ein wildcart, zum Beispiel:

-P"remote -i /dev/input/by-path/pci-0000:01:08.*--event-ir"
-P"remote -i /dev/input/by-path/pci-0000:01:08.[0-9]--event-ir"

Tastendruck wird immer noch nicht erkannt

Bei einigen Budget-Karten muss die rc5-Geräte-ID angepasst werden, damit der Treiber die empfangenen Signale nicht unpassend filtert. Dies kann als Parameter beim Laden des Moduls budget_ci gesetzt werden. Wobei der Parameterwert 255, dem Filter für alle rc5-Geräte-IDs außerkraft setzt. In den meisten Systemen kann für die Modulparameter eine Datei "/etc/modprobe.d/budget_ci" mit folgenden Inhalt angelegt werden.

options budget_ci rc5_device=255

Zur Kontrolle dient

cat /sys/module/budget_ci/parameters/rc5_device
255

Aktuelle Version

Version 0.5.0

Links

  1. Homepage des Plugins
  2. Evexec
  3. Readme des Plugins
  4. FAQ
In anderen Sprachen