]> cloudbase.mooo.com Git - irmp.git/blobdiff - irmp.h
Version 1.8.0: added JVC in irsnd, fitted APPLE protocol to IRMP 1.7.3
[irmp.git] / irmp.h
diff --git a/irmp.h b/irmp.h
index ba3beb7b16f98a9265f29c9277dd80cc90540b2d..21ff7dbfa2f3e0eac7d571919265b193f4f6dff0 100644 (file)
--- a/irmp.h
+++ b/irmp.h
@@ -3,7 +3,7 @@
  *\r
  * Copyright (c) 2009-2010 Frank Meyer - frank(at)fli4l.de\r
  *\r
- * $Id: irmp.h,v 1.26 2010/06/08 23:34:14 fm Exp $\r
+ * $Id: irmp.h,v 1.43 2010/08/31 15:22:24 fm Exp $\r
  *\r
  * ATMEGA88 @ 8 MHz\r
  *\r
@@ -22,28 +22,50 @@ extern "C"
 {\r
 #endif\r
 \r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ * timing constants:\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+#define IRMP_TIMEOUT_TIME                       16500.0e-6                  // timeout after 16.5 ms darkness\r
+#define IRMP_TIMEOUT_TIME_MS                    16500L                      // timeout after 16.5 ms darkness\r
+\r
+#if (F_INTERRUPTS * IRMP_TIMEOUT_TIME_MS) / 1000000 >= 254\r
+typedef uint16_t    PAUSE_LEN;\r
+#else\r
+typedef uint8_t     PAUSE_LEN;\r
+#endif\r
+\r
+#define IRMP_TIMEOUT_LEN                        (PAUSE_LEN)(F_INTERRUPTS * IRMP_TIMEOUT_TIME + 0.5)\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
-#define IRMP_NOKIA_PROTOCOL                     16                              // Nokia\r
-#define IRMP_SIEMENS_PROTOCOL                   17                              // Siemens, e.g. Gigaset\r
-#define IRMP_FDC_PROTOCOL                       18                              // FDC keyboard\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
+#define IRMP_NOKIA_PROTOCOL                     16              // Nokia\r
+#define IRMP_SIEMENS_PROTOCOL                   17              // Siemens, e.g. Gigaset\r
+#define IRMP_FDC_PROTOCOL                       18              // FDC keyboard\r
+#define IRMP_RCCAR_PROTOCOL                     19              // RC Car\r
+#define IRMP_JVC_PROTOCOL                       20              // JVC\r
+#define IRMP_RC6A_PROTOCOL                      21              // RC6A, e.g. Kathrein, XBOX\r
+\r
+// some flags of struct IRMP_PARAMETER:\r
+#define IRMP_PARAM_FLAG_IS_MANCHESTER           0x01\r
+#define IRMP_PARAM_FLAG_1ST_PULSE_IS_1          0x02\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
@@ -61,6 +83,7 @@ extern "C"
 #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
+#define SIRCS_FLAGS                             0                               // flags\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
@@ -76,6 +99,7 @@ extern "C"
 #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
+#define NEC_FLAGS                               0                               // flags\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
@@ -92,6 +116,7 @@ extern "C"
 #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
+#define SAMSUNG_FLAGS                           0                               // flags\r
 \r
 #define SAMSUNG32_COMMAND_OFFSET                16                              // skip 16 bits\r
 #define SAMSUNG32_COMMAND_LEN                   16                              // read 16 command bits\r
@@ -113,13 +138,15 @@ extern "C"
 #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
+#define MATSUSHITA_FLAGS                        0                               // flags\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_FRAME_REPEAT_PAUSE_TIME          45.0e-3                       // frame repeat after 45ms\r
+#define KASEIKYO_AUTO_REPETITION_PAUSE_TIME       74.0e-3                       // repetition after 74 ms\r
+#define KASEIKYO_FRAME_REPEAT_PAUSE_TIME          74.0e-3                       // frame repeat after 74 ms\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
@@ -127,6 +154,8 @@ extern "C"
 #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
+#define KASEIKYO_FRAMES                         2                               // KASEIKYO sends 1st frame 2 times\r
+#define KASEIKYO_FLAGS                          0                               // flags\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
@@ -141,6 +170,7 @@ extern "C"
 #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
+#define RECS80_FLAGS                            0                               // flags\r
 \r
 #define RC5_BIT_TIME                             889.0e-6                       // 889 usec pulse/pause\r
 #define RC5_FRAME_REPEAT_PAUSE_TIME               45.0e-3                       // frame repeat after 45ms\r
@@ -151,6 +181,7 @@ extern "C"
 #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
+#define RC5_FLAGS                               IRMP_PARAM_FLAG_IS_MANCHESTER   // flags\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
@@ -165,6 +196,7 @@ extern "C"
 #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
+#define DENON_FLAGS                             0                               // flags\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
@@ -179,6 +211,7 @@ extern "C"
 #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
+#define RC6_FLAGS                               (IRMP_PARAM_FLAG_IS_MANCHESTER | IRMP_PARAM_FLAG_1ST_PULSE_IS_1)   // flags\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
@@ -193,6 +226,7 @@ extern "C"
 #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
+#define RECS80EXT_FLAGS                         0                               // flags\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
@@ -210,6 +244,7 @@ extern "C"
 #define NUBERT_COMPLETE_DATA_LEN                10                              // complete length\r
 #define NUBERT_STOP_BIT                         1                               // has stop bit\r
 #define NUBERT_LSB                              0                               // MSB?\r
+#define NUBERT_FLAGS                            0                               // flags\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
@@ -232,12 +267,14 @@ extern "C"
 #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
+#define BANG_OLUFSEN_FLAGS                      0                               // flags\r
 \r
 #define GRUNDIG_OR_NOKIA_BIT_TIME               528.0e-6                        // 528 usec pulse/pause\r
 #define GRUNDIG_OR_NOKIA_PRE_PAUSE_TIME         2639.0e-6                       // 2639 usec pause after pre bit\r
 #define GRUNDIG_OR_NOKIA_FRAME_REPEAT_PAUSE_TIME  117.76e-3                     // info frame repeat after 117.76 ms\r
 #define GRUNDIG_OR_NOKIA_STOP_BIT               0                               // has no stop bit\r
 #define GRUNDIG_OR_NOKIA_LSB                    1                               // MSB...LSB\r
+#define GRUNDIG_OR_NOKIA_FLAGS                  (IRMP_PARAM_FLAG_IS_MANCHESTER | IRMP_PARAM_FLAG_1ST_PULSE_IS_1)  // flags\r
 \r
 #define GRUNDIG_FRAMES                          2                               // GRUNDIG sends each frame 1+1 times\r
 #define GRUNDIG_AUTO_REPETITION_PAUSE_TIME        20.0e-3                       // repetition after 20ms\r
@@ -264,22 +301,55 @@ extern "C"
 #define SIEMENS_COMPLETE_DATA_LEN               23                              // complete length\r
 #define SIEMENS_STOP_BIT                        0                               // has no stop bit\r
 #define SIEMENS_LSB                             0                               // MSB...LSB\r
+#define SIEMENS_FLAGS                           (IRMP_PARAM_FLAG_IS_MANCHESTER | IRMP_PARAM_FLAG_1ST_PULSE_IS_1)  // flags\r
 \r
-#define FDC_START_BIT_PULSE_TIME                1390.0e-6                       // 1390 usec pulse\r
-#define FDC_START_BIT_PAUSE_TIME                 640.0e-6                       //  640 usec pause\r
-#define FDC_PULSE_TIME                           200.0e-6                       //  200 usec pulse\r
-#define FDC_1_PAUSE_TIME                         475.0e-6                       //  475 usec pause\r
-#define FDC_0_PAUSE_TIME                         145.0e-6                       //  145 usec pause\r
-#define FDC_FRAME_REPEAT_PAUSE_TIME               40.0e-3                       // frame repeat after 40ms\r
+#define FDC_START_BIT_PULSE_TIME                 2085.0e-6                      // 2085 usec pulse\r
+#define FDC_START_BIT_PAUSE_TIME                  966.0e-6                      //  966 usec pause\r
+#define FDC_PULSE_TIME                            300.0e-6                      //  300 usec pulse\r
+#define FDC_1_PAUSE_TIME                          715.0e-6                      //  715 usec pause\r
+#define FDC_0_PAUSE_TIME                          220.0e-6                      //  220 usec pause\r
+#define FDC_FRAME_REPEAT_PAUSE_TIME                60.0e-3                      // frame repeat after 60ms\r
 #define FDC_ADDRESS_OFFSET                       0                              // skip 0 bits\r
-#define FDC_ADDRESS_LEN                         16                              // read 16 address bits\r
-#define FDC_COMMAND_OFFSET                      25                              // skip 25 bits (16 address + 9 0-bits)\r
+#define FDC_ADDRESS_LEN                         14                              // read 14 address bits, but use only 6, shift 8 into command\r
+#define FDC_COMMAND_OFFSET                      20                              // skip 20 bits\r
 #define FDC_COMMAND_LEN                         12                              // read 12 bits\r
 #define FDC_COMPLETE_DATA_LEN                   40                              // complete length\r
 #define FDC_STOP_BIT                            1                               // has stop bit\r
 #define FDC_LSB                                 1                               // LSB...MSB\r
+#define FDC_FLAGS                               0                               // flags\r
+\r
+#define RCCAR_START_BIT_PULSE_TIME               2000.0e-6                      // 2000 usec pulse\r
+#define RCCAR_START_BIT_PAUSE_TIME               2000.0e-6                      // 2000 usec pause\r
+#define RCCAR_PULSE_TIME                          600.0e-6                      //  360 usec pulse\r
+#define RCCAR_1_PAUSE_TIME                        450.0e-6                      //  650 usec pause\r
+#define RCCAR_0_PAUSE_TIME                        900.0e-6                      //  180 usec pause\r
+#define RCCAR_FRAME_REPEAT_PAUSE_TIME              40.0e-3                      // frame repeat after 40ms\r
+#define RCCAR_ADDRESS_OFFSET                     0                              // skip 0 bits\r
+#define RCCAR_ADDRESS_LEN                        0                              // read 0 address bits\r
+#define RCCAR_COMMAND_OFFSET                     0                              // skip 0 bits\r
+#define RCCAR_COMMAND_LEN                       13                              // read 13 bits\r
+#define RCCAR_COMPLETE_DATA_LEN                 13                              // complete length\r
+#define RCCAR_STOP_BIT                          1                               // has stop bit\r
+#define RCCAR_LSB                               1                               // LSB...MSB\r
+#define RCCAR_FLAGS                             0                               // flags\r
+\r
+#define JVC_START_BIT_PULSE_TIME                9000.0e-6                       // 9000 usec pulse\r
+#define JVC_START_BIT_PAUSE_TIME                4500.0e-6                       // 4500 usec pause\r
+#define JVC_PULSE_TIME                           560.0e-6                       //  560 usec pulse\r
+#define JVC_1_PAUSE_TIME                        1690.0e-6                       // 1690 usec pause\r
+#define JVC_0_PAUSE_TIME                         560.0e-6                       //  560 usec pause\r
+#define JVC_FRAME_REPEAT_PAUSE_TIME               22.0e-3                       // frame repeat after 22ms\r
+#define JVC_ADDRESS_OFFSET                       0                              // skip 0 bits\r
+#define JVC_ADDRESS_LEN                          4                              // read 4 address bits\r
+#define JVC_COMMAND_OFFSET                       4                              // skip 4 bits\r
+#define JVC_COMMAND_LEN                         12                              // read 12 bits\r
+#define JVC_COMPLETE_DATA_LEN                   16                              // complete length\r
+#define JVC_STOP_BIT                            1                               // has stop bit\r
+#define JVC_LSB                                 1                               // LSB...MSB\r
+#define JVC_FLAGS                               0                               // flags\r
 \r
-#define AUTO_FRAME_REPETITION_TIME              50.0e-3                         // SIRCS/SAMSUNG32/NUBERT: automatic repetition after 25-50ms\r
+#define AUTO_FRAME_REPETITION_TIME              80.0e-3                         // SIRCS/SAMSUNG32/NUBERT: automatic repetition after 25-50ms\r
+                                                                                // KASEIKYO: automatic repetition after 75ms\r
 \r
 #define TRUE                                    1\r
 #define FALSE                                   0\r
@@ -313,7 +383,7 @@ extern uint8_t                        irmp_get_data (IRMP_DATA *);
  *  ISR routine\r
  *  @details  ISR routine, called 10000 times per second\r
  */\r
-extern void                           irmp_ISR (void);\r
+extern uint8_t                        irmp_ISR (void);\r
 \r
 #ifdef __cplusplus\r
 }\r