IRMP: Unterschied zwischen den Versionen

Aus Ethersex_Wiki
Wechseln zu: Navigation, Suche
(Anschluss)
(Der Seiteninhalt wurde durch einen anderen Text ersetzt: „[http://ethersex.de/index.php/IRMP IRMP im neuen WIKI] Category:Ethersex Category:IR Category:ECMD Category:Control6“)
 
(40 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
IRMP ist eine Portierung des [http://www.mikrocontroller.net/articles/IRMP Infrarot-Multiprotokoll-Decoders] nach [[Ethersex]].
+
[http://ethersex.de/index.php/IRMP IRMP im neuen WIKI]
 
 
 
 
== Anschluss ==
 
 
 
Der Empfang der IR-Signale erfolgt durch einen Empfänger vom Typ TSOP1736 (oder ähnlich). Dieser kann an einem beliebigen Pin angeschlossen werden. Die Abfrage des Pins und die Dekodierung des IR-Protokolls erfolgt in einer ISR, die einen 8-Bit-Timer des ATMEGAs belegt.
 
 
 
Beim Senden wird das Signal mit der Trägerfrequenz des jeweiligen IR-Protokolls über [[PWM]] moduliert. Dazu wird ein weiterer 8-Bit Timer des ATMEGAs (OC0/OC2) belegt.
 
 
 
Beispiel für einen ATMega32 aus: ''pinning/hardware/pollin_evalboard.m4''
 
 
 
  ifdef(`conf_IRMP', `dnl
 
    pin(IRMP_RX, PD2)
 
  #define IRMP_USE_TIMER0
 
  #define IRMP_RX_LOW_ACTIVE
 
  #undef IRMP_RX_LED_LOW_ACTIVE
 
    pin(IRMP_TX, PD7) dnl OC2
 
  ')
 
 
 
Bedeutung:
 
 
 
* IRMP_RX - Pin an dem der IR-Empfänger angeschlossen ist
 
* IRMP_USE_TIMER0 - benutzer Timer0 für den Empfang, Timer2 für das Senden (undef = umgekehrt)
 
* IRMP_RX_LOW_ACTIVE - der IR-Empfänger ist Low-Akriv (undef = High-aktiv)
 
* IRMP_RX_LED_LOW_ACTIVE - die Kontroll-LED des Empfängers ist gegen USS geschaltet (undef = gegen GND geschaltet)
 
* IRMP_TX - Pin an dem der IR-Sender angschlossen is (=Ausgang des Timer0 oder Timer2, vgl. IRMP_USE_TIMER0)
 
 
 
 
 
'''Etherape''': IRMP moduliert das IR Signal per PWM auf die Trägerfrequenz. Auf dem Etherape-Board übernimmt ein NE555 diese Funktion, d.h. die Funktionen irmp_tx_on() und irmp_tx_off() in hardware/ir/irmp/irmp.c sind entsprechend anzupassen.
 
 
 
== Konfiguration ==
 
 
 
Jedes unterstützte IR-Protokoll "verbrät" Speicher an Code. Deshalb sollte man nur die benötigten Protokolle auswählen. Eine detailierte Übersicht über die Protokolle gibt der [http://www.mikrocontroller.net/articles/IRMP#Die_IR-Protokolle_im_Detail Artikel im Mikrocontroller Forum].
 
 
 
  │ │          Load a Default Configuration  --->
 
  │ │          General Setup  --->
 
  │ │              [*] Status LEDs  --->
 
  │ │                  [*] Status LED (Received)
 
  │ │                  [-]    RFM12 RX
 
  │ │                  [ ]    ZBUS RX
 
  │ │                  [*]    IRMP RX
 
  ...
 
  │ │          Network --->
 
  │ │          I/O --->
 
  ...
 
  │ │              [*] IR Receivers --->
 
  ...
 
  │ │                  [ ] RC5 IR  --->
 
  │ │                  [*] IRMP IR --->
 
  ...
 
  │ │                      [*] Send IRMP IR-codes
 
  │ │                      [*] IRMP ecmd
 
  │ │                      --- Protocols
 
  │ │                      [ ] SIRCS
 
  │ │                      [*] NEC
 
  │ │                      [ ] JVC
 
  │ │                      [ ] SAMSUNG
 
  │ │                      [ ] MATSUSHITA
 
  │ │                      [ ] KASEIKYO
 
  │ │                      [*] DENON
 
  │ │                      [ ] RECS80
 
  │ │                      [ ] RECS80EXT
 
  │ │                      [*] RC5(X)
 
  │ │                      [ ] RC6
 
  │ │                      [ ] NUBERT
 
  │ │                      [*] BANG&OLUFSEN
 
  │ │                      [*] GRUNDIG
 
  │ │                      [ ] NOKIA
 
  │ │                      [*] SIEMENS
 
  │ │                      [ ] FDC
 
  │ │                      [ ] RCCAR
 
  │ │                      --- Debugging Flags
 
  │ │                      [ ] IRMP Debug
 
 
 
 
 
IRMP dekodiert auch das RC5-Protokoll, so dass der separat in [[Ethersex]] enthaltene [[RC5]]-Dekoder nicht länger benötigt wird.
 
 
 
== [[ECMD]] ==
 
 
 
IRMP implementiert eine [[ECMD]] Schnittestelle zum Auslesen empfangener und dekodierter IR-Kommandos und zum Senden von IR-Kommandos. Siehe [[Ecmd_Reference|ECMD Referenz]].
 
 
 
== [[Control6]] ==
 
 
 
Ausgabe empfangener IR-Zeichen via [[SYSLOG|Syslog]]:
 
 
 
<source lang="text">
 
 
 
CONTROL_START
 
 
 
THREAD(read_irmp)
 
ON IRMP_READ > 0 DO
 
  SYSLOG("IRMP %02d:%04X:%04X:%02X\n",
 
        IRMP_PROTOCOL, IRMP_ADDRESS, IRMP_COMMAND, IRMP_FLAGS);
 
END
 
THREAD_END(read_temp)
 
 
 
ON STARTUP DO
 
  THREAD_START(read_irmp);
 
END
 
 
 
CONTROL_END
 
 
 
</source>
 
 
 
Mit IRMP_READ wird auf empfangenen IR-Code geprüft und dieser in die Variablen IRMP_PROTOCOL, IRMP_ADDRESS, IRMP_COMMAND und IRMP_FLAGS gespeichert. Rückgabewerte größer Null signalisieren die Gültigkeit der Variablen. Bei IRMP_FLAGS=1 handelt es sich um eine Wiederholung.
 
 
 
 
 
 
[[Category:Ethersex]]
 
[[Category:Ethersex]]
 
[[Category:IR]]
 
[[Category:IR]]
 
[[Category:ECMD]]
 
[[Category:ECMD]]
 
[[Category:Control6]]
 
[[Category:Control6]]

Aktuelle Version vom 5. Juni 2013, 07:40 Uhr