]> cloudbase.mooo.com Git - irmp.git/blobdiff - irmp.h
Version 1.7.3: better support of Kaseikyo and Apple remote controls
[irmp.git] / irmp.h
diff --git a/irmp.h b/irmp.h
index d9ddfa23d7409f858604e1ca8c170d27f2d154d6..c8c709acf50fabf13b79a1bc9da954428959d6a8 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.28 2010/06/10 21:24:50 fm Exp $\r
+ * $Id: irmp.h,v 1.41 2010/08/18 12:03:26 fm Exp $\r
  *\r
  * ATMEGA88 @ 8 MHz\r
  *\r
@@ -26,25 +26,30 @@ extern "C"
  * 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_FDC1_PROTOCOL                      18                              // FDC keyboard - protocol 1\r
-#define IRMP_FDC2_PROTOCOL                      19                              // FDC keyboard - protocol 2\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
+\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
@@ -62,6 +67,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
@@ -77,6 +83,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
@@ -93,6 +100,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
@@ -114,13 +122,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
@@ -128,6 +138,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
@@ -142,6 +154,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
@@ -152,6 +165,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
@@ -166,6 +180,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
@@ -180,6 +195,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
@@ -194,6 +210,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
@@ -211,6 +228,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
@@ -233,12 +251,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
@@ -265,36 +285,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
-\r
-#define FDC1_START_BIT_PULSE_TIME                1390.0e-6                       // 1390 usec pulse\r
-#define FDC1_START_BIT_PAUSE_TIME                 640.0e-6                       //  640 usec pause\r
-#define FDC1_PULSE_TIME                           200.0e-6                       //  200 usec pulse\r
-#define FDC1_1_PAUSE_TIME                         475.0e-6                       //  475 usec pause\r
-#define FDC1_0_PAUSE_TIME                         145.0e-6                       //  145 usec pause\r
-#define FDC1_FRAME_REPEAT_PAUSE_TIME               40.0e-3                       // frame repeat after 40ms\r
-#define FDC1_ADDRESS_OFFSET                       0                              // skip 0 bits\r
-#define FDC1_ADDRESS_LEN                          8                              // read 8 address bits\r
-#define FDC1_COMMAND_OFFSET                      24                              // skip 24 bits (8 address bits + 12 status bits + 4 repeat bits)\r
-#define FDC1_COMMAND_LEN                          8                              // read 8 bits\r
-#define FDC1_COMPLETE_DATA_LEN                   40                              // complete length\r
-#define FDC1_STOP_BIT                            1                               // has stop bit\r
-#define FDC1_LSB                                 1                               // LSB...MSB\r
-\r
-#define FDC2_START_BIT_PULSE_TIME                2120.0e-6                       // 2120 usec pulse\r
-#define FDC2_START_BIT_PAUSE_TIME                 920.0e-6                       //  920 usec pause\r
-#define FDC2_PULSE_TIME                           400.0e-6                       //  400 usec pulse\r
-#define FDC2_1_PAUSE_TIME                         660.0e-6                       //  660 usec pause\r
-#define FDC2_0_PAUSE_TIME                         145.0e-6                       //  140 usec pause\r
-#define FDC2_FRAME_REPEAT_PAUSE_TIME               40.0e-3                       // frame repeat after 40ms\r
-#define FDC2_ADDRESS_OFFSET                       0                              // skip 0 bits\r
-#define FDC2_ADDRESS_LEN                          8                              // read 8 address bits\r
-#define FDC2_COMMAND_OFFSET                      24                              // skip 24 bits (8 address bits + 12 status bits + 4 repeat bits)\r
-#define FDC2_COMMAND_LEN                          8                              // read 8 bits\r
-#define FDC2_COMPLETE_DATA_LEN                   40                              // complete length\r
-#define FDC2_STOP_BIT                            1                               // has stop bit\r
-#define FDC2_LSB                                 1                               // LSB...MSB\r
-\r
-#define AUTO_FRAME_REPETITION_TIME              50.0e-3                         // SIRCS/SAMSUNG32/NUBERT: automatic repetition after 25-50ms\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                 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                         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               25.0e-3                       // frame repeat after 25ms\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              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