Remote-plugin

Aus VDR Wiki
(Unterschied zwischen Versionen)
Wechseln zu: Navigation, Suche
(Immer das gleiche Device für DVB-Karten Infrarotreceiver)
(Immer das gleiche Device für DVB-Karten Infrarotreceiver)
Zeile 173: Zeile 173:
 
'''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'''.
 
'''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:'''
+
'''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):
 
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):
  

Version vom 25. September 2007, 18:57 Uhr

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 J2 Jumperblock 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) {
       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"

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.

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):

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 



Links

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