]> cloudbase.mooo.com Git - irmp.git/blobdiff - irmp.h
Version 2.5.0: added SPEAKER protocol (IRMP)
[irmp.git] / irmp.h
diff --git a/irmp.h b/irmp.h
index 6f718f8fca0a03b18f6fd2b826a484d0365e7b5f..bf53e3c8b62af216e296648b0b31b24362bd61ee 100644 (file)
--- a/irmp.h
+++ b/irmp.h
@@ -1,9 +1,9 @@
 /*---------------------------------------------------------------------------------------------------------------------------------------------------\r
  * irmp.h\r
  *\r
- * Copyright (c) 2009-2010 Frank Meyer - frank(at)fli4l.de\r
+ * Copyright (c) 2009-2013 Frank Meyer - frank(at)fli4l.de\r
  *\r
- * $Id: irmp.h,v 1.14 2010/05/15 17:13:07 fm Exp $\r
+ * $Id: irmp.h,v 1.84 2014/02/19 12:57:36 fm Exp $\r
  *\r
  * ATMEGA88 @ 8 MHz\r
  *\r
  *---------------------------------------------------------------------------------------------------------------------------------------------------\r
  */\r
 \r
-#ifndef _WC_IRMP_H_\r
-#define _WC_IRMP_H_\r
+#ifndef _IRMP_H_\r
+#define _IRMP_H_\r
 \r
-#ifdef __cplusplus\r
-extern "C"\r
-{\r
-#endif\r
-\r
-/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * IR protocols\r
- *---------------------------------------------------------------------------------------------------------------------------------------------------\r
- */\r
-#define IRMP_SIRCS_PROTOCOL                      1                            // Sony\r
-#define IRMP_NEC_PROTOCOL                        2                            // NEC, Pioneer, JVC, Toshiba, NoName etc.\r
-#define IRMP_SAMSUNG_PROTOCOL                    3                            // Samsung\r
-#define IRMP_MATSUSHITA_PROTOCOL                 4                            // Matsushita\r
-#define IRMP_KASEIKYO_PROTOCOL                   5                            // Kaseikyo (Panasonic etc)\r
-#define IRMP_RECS80_PROTOCOL                     6                            // Philips, Thomson, Nordmende, Telefunken, Saba\r
-#define IRMP_RC5_PROTOCOL                        7                            // Philips etc\r
-#define IRMP_DENON_PROTOCOL                      8                            // Denon\r
-#define IRMP_RC6_PROTOCOL                        9                            // Philips etc\r
-#define IRMP_SAMSUNG32_PROTOCOL                 10                            // Samsung32: no sync pulse at bit 16, length 32 instead of 37\r
-#define IRMP_APPLE_PROTOCOL                     11                            // Apple, very similar to NEC\r
-#define IRMP_RECS80EXT_PROTOCOL                 12                            // Philips, Technisat, Thomson, Nordmende, Telefunken, Saba\r
-#define IRMP_NUBERT_PROTOCOL                    13                            // Nubert\r
-#define IRMP_BANG_OLUFSEN_PROTOCOL              14                            // Bang & Olufsen\r
-#define IRMP_GRUNDIG_PROTOCOL                   15                            // Grundig\r
-\r
-#define SIRCS_START_BIT_PULSE_TIME              2400.0e-6                     // 2400 usec pulse\r
-#define SIRCS_START_BIT_PAUSE_TIME               600.0e-6                     //  600 usec pause\r
-#define SIRCS_1_PULSE_TIME                      1200.0e-6                     // 1200 usec pulse\r
-#define SIRCS_0_PULSE_TIME                       600.0e-6                     //  600 usec pulse\r
-#define SIRCS_PAUSE_TIME                         600.0e-6                     //  600 usec pause\r
-#define SIRCS_REPETITION_TIME                     45.0e-3                     // repetition after 45ms\r
-#define SIRCS_REPETITION_CNT                    3                             // SIRCS repeats each frame 3 times\r
-#define SIRCS_ADDRESS_OFFSET                    15                            // skip 15 bits\r
-#define SIRCS_ADDRESS_LEN                       5                             // read up to 5 address bits\r
-#define SIRCS_COMMAND_OFFSET                    0                             // skip 0 bits\r
-#define SIRCS_COMMAND_LEN                       15                            // read 12-15 command bits\r
-#define SIRCS_MINIMUM_DATA_LEN                  12                            // minimum data length\r
-#define SIRCS_COMPLETE_DATA_LEN                 20                            // complete length - may be up to 20\r
-#define SIRCS_STOP_BIT                          0                             // has no stop bit\r
-#define SIRCS_LSB                               1                             // LSB...MSB\r
-\r
-#define NEC_START_BIT_PULSE_TIME                9000.0e-6                     // 9000 usec pulse\r
-#define NEC_START_BIT_PAUSE_TIME                4500.0e-6                     // 4500 usec pause\r
-#define NEC_REPEAT_START_BIT_PAUSE_TIME         2250.0e-6                     // 2250 usec pause\r
-#define NEC_PULSE_TIME                           560.0e-6                     //  560 usec pulse\r
-#define NEC_1_PAUSE_TIME                        1690.0e-6                     // 1690 usec pause\r
-#define NEC_0_PAUSE_TIME                         560.0e-6                     //  560 usec pause\r
-#define NEC_ADDRESS_OFFSET                       0                            // skip 0 bits\r
-#define NEC_ADDRESS_LEN                         16                            // read 16 address bits\r
-#define NEC_COMMAND_OFFSET                      16                            // skip 16 bits (8 address + 8 /address)\r
-#define NEC_COMMAND_LEN                         16                            // read 16 bits (8 command + 8 /command)\r
-#define NEC_COMPLETE_DATA_LEN                   32                            // complete length\r
-#define NEC_STOP_BIT                            1                             // has stop bit\r
-#define NEC_LSB                                 1                             // LSB...MSB\r
+#include "irmpsystem.h"\r
 \r
-#define SAMSUNG_START_BIT_PULSE_TIME            4500.0e-6                     // 4500 usec pulse\r
-#define SAMSUNG_START_BIT_PAUSE_TIME            4500.0e-6                     // 4500 usec pause\r
-#define SAMSUNG_PULSE_TIME                       550.0e-6                     //  550 usec pulse\r
-#define SAMSUNG_1_PAUSE_TIME                    1450.0e-6                     // 1450 usec pause\r
-#define SAMSUNG_0_PAUSE_TIME                     450.0e-6                     //  450 usec pause\r
-#define SAMSUNG_ADDRESS_OFFSET                   0                            // skip 0 bits\r
-#define SAMSUNG_ADDRESS_LEN                     16                            // read 16 address bits\r
-#define SAMSUNG_ID_OFFSET                       17                            // skip 16 + 1 sync bit\r
-#define SAMSUNG_ID_LEN                          4                             // read 4 id bits\r
-#define SAMSUNG_COMMAND_OFFSET                  21                            // skip 16 + 1 sync + 4 data bits\r
-#define SAMSUNG_COMMAND_LEN                     16                            // read 16 command bits\r
-#define SAMSUNG_COMPLETE_DATA_LEN               37                            // complete length\r
-#define SAMSUNG_STOP_BIT                        1                             // has stop bit\r
-#define SAMSUNG_LSB                             1                             // LSB...MSB?\r
+#ifndef IRMP_USE_AS_LIB\r
+#  include "irmpconfig.h"\r
+#endif\r
 \r
-#define SAMSUNG32_COMMAND_OFFSET                16                            // skip 16 bits\r
-#define SAMSUNG32_COMMAND_LEN                   16                            // read 16 command bits\r
-#define SAMSUNG32_COMPLETE_DATA_LEN             32                            // complete length\r
+#if defined (ATMEL_AVR)\r
+#  define _CONCAT(a,b)                          a##b\r
+#  define CONCAT(a,b)                           _CONCAT(a,b)\r
+#  define IRMP_PORT                             CONCAT(PORT, IRMP_PORT_LETTER)\r
+#  define IRMP_DDR                              CONCAT(DDR, IRMP_PORT_LETTER)\r
+#  define IRMP_PIN                              CONCAT(PIN, IRMP_PORT_LETTER)\r
+#  define IRMP_BIT                              IRMP_BIT_NUMBER\r
+#  define input(x)                              ((x) & (1 << IRMP_BIT))\r
+#elif defined (PIC_C18)\r
+#  define input(x)                              (x)\r
+#elif defined (PIC_CCS)\r
+#  define input(x)                              (x)\r
+#elif defined (ARM_STM32)\r
+#  define _CONCAT(a,b)                          a##b\r
+#  define CONCAT(a,b)                           _CONCAT(a,b)\r
+#  define IRMP_PORT                             CONCAT(GPIO, IRMP_PORT_LETTER)\r
+#  if defined (ARM_STM32L1XX)\r
+#    define IRMP_PORT_RCC                       CONCAT(RCC_AHBPeriph_GPIO, IRMP_PORT_LETTER)\r
+#  elif defined (ARM_STM32F10X)\r
+#    define IRMP_PORT_RCC                       CONCAT(RCC_APB2Periph_GPIO, IRMP_PORT_LETTER)\r
+#  elif defined (ARM_STM32F4XX)\r
+#    define IRMP_PORT_RCC                       CONCAT(RCC_AHB1Periph_GPIO, IRMP_PORT_LETTER)\r
+#  endif\r
+#  define IRMP_BIT                              CONCAT(GPIO_Pin_, IRMP_BIT_NUMBER)\r
+#  define IRMP_PIN                              IRMP_PORT   // for use with input(x) below\r
+#  define input(x)                              (GPIO_ReadInputDataBit(x, IRMP_BIT))\r
+#  ifndef USE_STDPERIPH_DRIVER\r
+#    warning The STM32 port of IRMP uses the ST standard peripheral drivers which are not enabled in your build configuration.\r
+#  endif\r
+#elif defined (STELLARIS_ARM_CORTEX_M4)\r
+#  define _CONCAT(a,b)                          a##b\r
+#  define CONCAT(a,b)                           _CONCAT(a,b)\r
+#  define IRMP_PORT_PERIPH                      CONCAT(SYSCTL_PERIPH_GPIO, IRMP_PORT_LETTER)\r
+#  define IRMP_PORT_BASE                        CONCAT(GPIO_PORT, CONCAT(IRMP_PORT_LETTER, _BASE))\r
+#  define IRMP_PORT_PIN                         CONCAT(GPIO_PIN_, IRMP_BIT_NUMBER)\r
+#  define IRMP_PIN                              IRMP_PORT_PIN\r
+#  define input(x)                              ((uint8_t)(ROM_GPIOPinRead(IRMP_PORT_BASE, IRMP_PORT_PIN)))\r
+#  define sei()                                 IntMasterEnable()\r
+#endif\r
 \r
-#define MATSUSHITA_START_BIT_PULSE_TIME         3488.0e-6                     // 3488 usec pulse\r
-#define MATSUSHITA_START_BIT_PAUSE_TIME         3488.0e-6                     // 3488 usec pause\r
-#define MATSUSHITA_PULSE_TIME                    872.0e-6                     //  872 usec pulse\r
-#define MATSUSHITA_1_PAUSE_TIME                 2616.0e-6                     // 2616 usec pause\r
-#define MATSUSHITA_0_PAUSE_TIME                  872.0e-6                     //  872 usec pause\r
-#define MATSUSHITA_ADDRESS_OFFSET               12                            // skip 12 bits\r
-#define MATSUSHITA_ADDRESS_LEN                  12                            // read 12 address bits\r
-#define MATSUSHITA_COMMAND_OFFSET               0                             // skip 0 bits\r
-#define MATSUSHITA_COMMAND_LEN                  12                            // read 12 bits (6 custom + 6 command)\r
-#define MATSUSHITA_COMPLETE_DATA_LEN            24                            // complete length\r
-#define MATSUSHITA_STOP_BIT                     1                             // has stop bit\r
-#define MATSUSHITA_LSB                          1                             // LSB...MSB?\r
+#if IRMP_SUPPORT_DENON_PROTOCOL == 1 && IRMP_SUPPORT_RUWIDO_PROTOCOL == 1\r
+#  warning DENON protocol conflicts wih RUWIDO, please enable only one of both protocols\r
+#  warning RUWIDO protocol disabled\r
+#  undef IRMP_SUPPORT_RUWIDO_PROTOCOL\r
+#  define IRMP_SUPPORT_RUWIDO_PROTOCOL          0\r
+#endif\r
 \r
-#define KASEIKYO_START_BIT_PULSE_TIME           3380.0e-6                     // 3380 usec pulse\r
-#define KASEIKYO_START_BIT_PAUSE_TIME           1690.0e-6                     // 1690 usec pause\r
-#define KASEIKYO_PULSE_TIME                      423.0e-6                     //  525 usec pulse\r
-#define KASEIKYO_1_PAUSE_TIME                   1269.0e-6                     //  525 usec pause\r
-#define KASEIKYO_0_PAUSE_TIME                    423.0e-6                     // 1690 usec pause\r
-#define KASEIKYO_ADDRESS_OFFSET                  0                            // skip 0 bits\r
-#define KASEIKYO_ADDRESS_LEN                    16                            // read 16 address bits\r
-#define KASEIKYO_COMMAND_OFFSET                 28                            // skip 28 bits (16 manufacturer & 4 parity & 8 genre)\r
-#define KASEIKYO_COMMAND_LEN                    12                            // read 12 command bits (10 real command & 2 id)\r
-#define KASEIKYO_COMPLETE_DATA_LEN              48                            // complete length\r
-#define KASEIKYO_STOP_BIT                       1                             // has stop bit\r
-#define KASEIKYO_LSB                            1                             // LSB...MSB?\r
+#if IRMP_SUPPORT_RC6_PROTOCOL == 1 && IRMP_SUPPORT_ROOMBA_PROTOCOL == 1\r
+#  warning RC6 protocol conflicts wih ROOMBA, please enable only one of both protocols\r
+#  warning ROOMBA protocol disabled\r
+#  undef IRMP_SUPPORT_ROOMBA_PROTOCOL\r
+#  define IRMP_SUPPORT_ROOMBA_PROTOCOL          0\r
+#endif\r
 \r
-#define RECS80_START_BIT_PULSE_TIME              158.0e-6                     //  158 usec pulse\r
-#define RECS80_START_BIT_PAUSE_TIME             7432.0e-6                     // 7432 usec pause\r
-#define RECS80_PULSE_TIME                        158.0e-6                     //  158 usec pulse\r
-#define RECS80_1_PAUSE_TIME                     7432.0e-6                     // 7432 usec pause\r
-#define RECS80_0_PAUSE_TIME                     4902.0e-6                     // 4902 usec pause\r
-#define RECS80_ADDRESS_OFFSET                   2                             // skip 2 bits (2nd start + 1 toggle)\r
-#define RECS80_ADDRESS_LEN                      3                             // read 3 address bits\r
-#define RECS80_COMMAND_OFFSET                   5                             // skip 5 bits (2nd start + 1 toggle + 3 address)\r
-#define RECS80_COMMAND_LEN                      6                             // read 6 command bits\r
-#define RECS80_COMPLETE_DATA_LEN                11                            // complete length\r
-#define RECS80_STOP_BIT                         1                             // has stop bit\r
-#define RECS80_LSB                              0                             // MSB...LSB\r
+#if IRMP_SUPPORT_RC5_PROTOCOL == 1 && IRMP_SUPPORT_ORTEK_PROTOCOL == 1\r
+#  warning RC5 protocol conflicts wih ORTEK, please enable only one of both protocols\r
+#  warning ORTEK protocol disabled\r
+#  undef IRMP_SUPPORT_ORTEK_PROTOCOL\r
+#  define IRMP_SUPPORT_ORTEK_PROTOCOL           0\r
+#endif\r
 \r
-#define RC5_BIT_TIME                            889.0e-6                      // 889 usec pulse/pause\r
-#define RC5_ADDRESS_OFFSET                      2                             // skip 2 bits (2nd start + 1 toggle)\r
-#define RC5_ADDRESS_LEN                         5                             // read 5 address bits\r
-#define RC5_COMMAND_OFFSET                      7                             // skip 5 bits (2nd start + 1 toggle + 5 address)\r
-#define RC5_COMMAND_LEN                         6                             // read 6 command bits\r
-#define RC5_COMPLETE_DATA_LEN                   13                            // complete length\r
-#define RC5_STOP_BIT                            0                             // has no stop bit\r
-#define RC5_LSB                                 0                             // MSB...LSB\r
+#if IRMP_SUPPORT_FDC_PROTOCOL == 1 && IRMP_SUPPORT_ORTEK_PROTOCOL == 1\r
+#  warning FDC protocol conflicts wih ORTEK, please enable only one of both protocols\r
+#  warning ORTEK protocol disabled\r
+#  undef IRMP_SUPPORT_ORTEK_PROTOCOL\r
+#  define IRMP_SUPPORT_ORTEK_PROTOCOL           0\r
+#endif\r
 \r
-#define DENON_PULSE_TIME                        275.0e-6                      //  275 usec pulse\r
-#define DENON_1_PAUSE_TIME                      1900.0e-6                     // 1900 usec pause\r
-#define DENON_0_PAUSE_TIME                      1050.0e-6                     // 1050 usec pause\r
-#define DENON_REPETITION_TIME                     65.0e-3                     // inverted repetition after 65ms\r
-#define DENON_ADDRESS_OFFSET                    0                             // skip 0 bits\r
-#define DENON_ADDRESS_LEN                       5                             // read 5 address bits\r
-#define DENON_COMMAND_OFFSET                    5                             // skip 5\r
-#define DENON_COMMAND_LEN                       10                            // read 10 command bits\r
-#define DENON_COMPLETE_DATA_LEN                 15                            // complete length\r
-#define DENON_STOP_BIT                          1                             // has stop bit\r
-#define DENON_LSB                               0                             // MSB...LSB\r
+#if IRMP_SUPPORT_ORTEK_PROTOCOL == 1 && IRMP_SUPPORT_NETBOX_PROTOCOL == 1\r
+#  warning ORTEK protocol conflicts wih NETBOX, please enable only one of both protocols\r
+#  warning NETBOX protocol disabled\r
+#  undef IRMP_SUPPORT_NETBOX_PROTOCOL\r
+#  define IRMP_SUPPORT_NETBOX_PROTOCOL          0\r
+#endif\r
 \r
-#define RC6_START_BIT_PULSE_TIME                2666.0e-6                     // 2.666 msec pulse\r
-#define RC6_START_BIT_PAUSE_TIME                889.0e-6                      // 889 usec pause\r
-#define RC6_TOGGLE_BIT_TIME                     889.0e-6                      // 889 msec pulse/pause\r
-#define RC6_BIT_TIME                            444.0e-6                      // 889 usec pulse/pause\r
-#define RC6_ADDRESS_OFFSET                      5                             // skip "1" + 3 mode bits + 1 toggle bit\r
-#define RC6_ADDRESS_LEN                         8                             // read 8 address bits\r
-#define RC6_COMMAND_OFFSET                      13                            // skip 12 bits ("1" + 3 mode + 1 toggle + 8 address)\r
-#define RC6_COMMAND_LEN                         8                             // read 8 command bits\r
-#define RC6_COMPLETE_DATA_LEN_SHORT             21                            // complete length\r
-#define RC6_COMPLETE_DATA_LEN_LONG              36                            // complete length\r
-#define RC6_STOP_BIT                            0                             // has no stop bit\r
-#define RC6_LSB                                 0                             // MSB...LSB\r
+#if IRMP_SUPPORT_SIEMENS_PROTOCOL == 1 && F_INTERRUPTS < 15000\r
+#  warning F_INTERRUPTS too low, SIEMENS protocol disabled (should be at least 15000)\r
+#  undef IRMP_SUPPORT_SIEMENS_PROTOCOL\r
+#  define IRMP_SUPPORT_SIEMENS_PROTOCOL         0\r
+#endif\r
 \r
-#define RECS80EXT_START_BIT_PULSE_TIME           158.0e-6                     //  158 usec pulse\r
-#define RECS80EXT_START_BIT_PAUSE_TIME          3637.0e-6                     // 3637 usec pause\r
-#define RECS80EXT_PULSE_TIME                     158.0e-6                     //  158 usec pulse\r
-#define RECS80EXT_1_PAUSE_TIME                  7432.0e-6                     // 7432 usec pause\r
-#define RECS80EXT_0_PAUSE_TIME                  4902.0e-6                     // 4902 usec pause\r
-#define RECS80EXT_ADDRESS_OFFSET                2                             // skip 2 bits (2nd start + 1 toggle)\r
-#define RECS80EXT_ADDRESS_LEN                   4                             // read 3 address bits\r
-#define RECS80EXT_COMMAND_OFFSET                6                             // skip 6 bits (2nd start + 1 toggle + 4 address)\r
-#define RECS80EXT_COMMAND_LEN                   6                             // read 6 command bits\r
-#define RECS80EXT_COMPLETE_DATA_LEN             12                            // complete length\r
-#define RECS80EXT_STOP_BIT                      1                             // has stop bit\r
-#define RECS80EXT_LSB                           0                             // MSB...LSB\r
+#if IRMP_SUPPORT_RUWIDO_PROTOCOL == 1 && F_INTERRUPTS < 15000\r
+#  warning F_INTERRUPTS too low, RUWIDO protocol disabled (should be at least 15000)\r
+#  undef IRMP_SUPPORT_RUWIDO_PROTOCOL\r
+#  define IRMP_SUPPORT_RUWIDO_PROTOCOL          0\r
+#endif\r
 \r
-#define NUBERT_START_BIT_PULSE_TIME             1340.0e-6                     // 1340 usec pulse\r
-#define NUBERT_START_BIT_PAUSE_TIME              340.0e-6                     //  340 usec pause\r
-#define NUBERT_1_PULSE_TIME                     1340.0e-6                     // 1340 usec pulse\r
-#define NUBERT_1_PAUSE_TIME                      340.0e-6                     //  340 usec pause\r
-#define NUBERT_0_PULSE_TIME                      500.0e-6                     //  500 usec pulse\r
-#define NUBERT_0_PAUSE_TIME                     1300.0e-6                     // 1300 usec pause\r
-#define NUBERT_REPETITION_TIME                  35.0e-3                       // repetition after 35ms\r
-#define NUBERT_ADDRESS_OFFSET                   0                             // skip 0 bits\r
-#define NUBERT_ADDRESS_LEN                      0                             // read 0 address bits\r
-#define NUBERT_COMMAND_OFFSET                   0                             // skip 0 bits\r
-#define NUBERT_COMMAND_LEN                      10                            // read 10 bits\r
-#define NUBERT_COMPLETE_DATA_LEN                10                            // complete length\r
-#define NUBERT_STOP_BIT                         1                             // has stop bit\r
-#define NUBERT_LSB                              0                             // MSB?\r
+#if IRMP_SUPPORT_RECS80_PROTOCOL == 1 && F_INTERRUPTS < 15000\r
+#  warning F_INTERRUPTS too low, RECS80 protocol disabled (should be at least 15000)\r
+#  undef IRMP_SUPPORT_RECS80_PROTOCOL\r
+#  define IRMP_SUPPORT_RECS80_PROTOCOL          0\r
+#endif\r
 \r
-#define BANG_OLUFSEN_START_BIT1_PULSE_TIME       200.0e-6                     //   200 usec pulse\r
-#define BANG_OLUFSEN_START_BIT1_PAUSE_TIME      3125.0e-6                     //  3125 usec pause\r
-#define BANG_OLUFSEN_START_BIT2_PULSE_TIME       200.0e-6                     //   200 usec pulse\r
-#define BANG_OLUFSEN_START_BIT2_PAUSE_TIME      3125.0e-6                     //  3125 usec pause\r
-#define BANG_OLUFSEN_START_BIT3_PULSE_TIME       200.0e-6                     //   200 usec pulse\r
-#define BANG_OLUFSEN_START_BIT3_PAUSE_TIME     15625.0e-6                     // 15625 usec pause\r
-#define BANG_OLUFSEN_START_BIT4_PULSE_TIME       200.0e-6                     //   200 usec pulse\r
-#define BANG_OLUFSEN_START_BIT4_PAUSE_TIME      3125.0e-6                     //  3125 usec pause\r
-#define BANG_OLUFSEN_PULSE_TIME                  200.0e-6                     //   200 usec pulse\r
-#define BANG_OLUFSEN_1_PAUSE_TIME               9375.0e-6                     //  9375 usec pause\r
-#define BANG_OLUFSEN_0_PAUSE_TIME               3125.0e-6                     //  3125 usec pause\r
-#define BANG_OLUFSEN_R_PAUSE_TIME               6250.0e-6                     //  6250 usec pause (repeat last bit)\r
-#define BANG_OLUFSEN_TRAILER_BIT_PAUSE_TIME    12500.0e-6                     // 12500 usec pause (trailer bit)\r
-#define BANG_OLUFSEN_ADDRESS_OFFSET             0                             // no address bits\r
-#define BANG_OLUFSEN_ADDRESS_LEN                0                             // no address bits\r
-#define BANG_OLUFSEN_COMMAND_OFFSET             3                             // skip startbits 2, 3, 4\r
-#define BANG_OLUFSEN_COMMAND_LEN                16                            // read 16 command bits\r
-#define BANG_OLUFSEN_COMPLETE_DATA_LEN          20                            // complete length: startbits 2, 3, 4 + 16 data bits + trailer bit\r
-#define BANG_OLUFSEN_STOP_BIT                   1                             // has stop bit\r
-#define BANG_OLUFSEN_LSB                        0                             // MSB...LSB\r
+#if IRMP_SUPPORT_RECS80EXT_PROTOCOL == 1 && F_INTERRUPTS < 15000\r
+#  warning F_INTERRUPTS too low, RECS80EXT protocol disabled (should be at least 15000)\r
+#  undef IRMP_SUPPORT_RECS80EXT_PROTOCOL\r
+#  define IRMP_SUPPORT_RECS80EXT_PROTOCOL       0\r
+#endif\r
 \r
-#define GRUNDIG_BIT_TIME                        528.0e-6                      // 528 usec pulse/pause\r
-#define GRUNDIG_PRE_PAUSE_TIME                  2639.0e-6                     // 2639 usec pause after pre bit\r
-#define GRUNDIG_ADDRESS_OFFSET                  0                             // skip 2 bits (2nd start + 1 toggle)\r
-#define GRUNDIG_ADDRESS_LEN                     0                             // read 5 address bits\r
-#define GRUNDIG_COMMAND_OFFSET                  1                             // skip 2 bits (1 start bit)\r
-#define GRUNDIG_COMMAND_LEN                     9                             // read 9 command bits\r
-#define GRUNDIG_COMPLETE_DATA_LEN               10                            // complete length: 1 start bit + 9 data bits\r
-#define GRUNDIG_STOP_BIT                        0                             // has no stop bit\r
-#define GRUNDIG_LSB                             1                             // MSB...LSB\r
+#if IRMP_SUPPORT_LEGO_PROTOCOL == 1 && F_INTERRUPTS < 20000\r
+#  warning F_INTERRUPTS too low, LEGO protocol disabled (should be at least 20000)\r
+#  undef IRMP_SUPPORT_LEGO_PROTOCOL\r
+#  define IRMP_SUPPORT_LEGO_PROTOCOL            0\r
+#endif\r
 \r
-#define AUTO_REPETITION_TIME                    50.0e-3                       // SIRCS or SAMSUNG32: automatic repetition after 45-50ms\r
+#if IRMP_SUPPORT_JVC_PROTOCOL == 1 && IRMP_SUPPORT_NEC_PROTOCOL == 0\r
+#  warning JVC protocol needs also NEC protocol, NEC protocol enabled\r
+#  undef IRMP_SUPPORT_NEC_PROTOCOL\r
+#  define IRMP_SUPPORT_NEC_PROTOCOL             1\r
+#endif\r
 \r
-#define TRUE                                    1\r
-#define FALSE                                   0\r
+#if IRMP_SUPPORT_NEC16_PROTOCOL == 1 && IRMP_SUPPORT_NEC_PROTOCOL == 0\r
+#  warning NEC16 protocol needs also NEC protocol, NEC protocol enabled\r
+#  undef IRMP_SUPPORT_NEC_PROTOCOL\r
+#  define IRMP_SUPPORT_NEC_PROTOCOL             1\r
+#endif\r
 \r
-#define IRMP_FLAG_REPETITION                    0x01\r
+#if IRMP_SUPPORT_NEC42_PROTOCOL == 1 && IRMP_SUPPORT_NEC_PROTOCOL == 0\r
+#  warning NEC42 protocol needs also NEC protocol, NEC protocol enabled\r
+#  undef IRMP_SUPPORT_NEC_PROTOCOL\r
+#  define IRMP_SUPPORT_NEC_PROTOCOL             1\r
+#endif\r
 \r
-typedef struct\r
-{\r
-  uint8_t               protocol;                                             // protocol, i.e. NEC_PROTOCOL\r
-  uint16_t              address;                                              // address\r
-  uint16_t              command;                                              // command\r
-  uint8_t               flags;                                                // flags, e.g. repetition\r
-} IRMP_DATA;\r
+#if IRMP_SUPPORT_RCMM_PROTOCOL == 1 && F_INTERRUPTS < 20000\r
+#  warning F_INTERRUPTS too low, RCMM protocol disabled (should be at least 20000)\r
+#  undef IRMP_SUPPORT_RCMM_PROTOCOL\r
+#  define IRMP_SUPPORT_RCMM_PROTOCOL            0\r
+#endif\r
 \r
+#if F_INTERRUPTS > 20000\r
+#error F_INTERRUPTS too high (should be not greater than 20000)\r
+#endif\r
 \r
-/**\r
- *  Initialize IRMP decoder\r
- *  @details  Configures IRMP input pin\r
- */\r
-extern void                           irmp_init (void);\r
+#include "irmpprotocols.h"\r
 \r
-/**\r
- *  Get IRMP data\r
- *  @details  gets decoded IRMP data\r
- *  @param    pointer in order to store IRMP data\r
- *  @return    TRUE: successful, FALSE: failed\r
- */\r
-extern uint8_t                        irmp_get_data (IRMP_DATA *);\r
+#define IRMP_FLAG_REPETITION            0x01\r
 \r
-/**\r
- *  ISR routine\r
- *  @details  ISR routine, called 10000 times per second\r
- */\r
-extern void                           irmp_ISR (void);\r
+extern void                             irmp_init (void);\r
+extern uint8_t                          irmp_get_data (IRMP_DATA *);\r
+extern uint8_t                          irmp_is_busy (void);\r
+extern uint8_t                          irmp_ISR (void);\r
 \r
-#ifdef __cplusplus\r
-}\r
+#if IRMP_PROTOCOL_NAMES == 1\r
+extern char *                           irmp_protocol_names[IRMP_N_PROTOCOLS + 1];\r
 #endif\r
 \r
-#endif /* _WC_IRMP_H_ */\r
+#if IRMP_USE_CALLBACK == 1\r
+extern void                             irmp_set_callback_ptr (void (*cb)(uint8_t));\r
+#endif // IRMP_USE_CALLBACK == 1\r
+\r
+#endif /* _IRMP_H_ */\r