]> cloudbase.mooo.com Git - irmp.git/blobdiff - irmp.h
version 1.9.6: corrected RECS80 decoder
[irmp.git] / irmp.h
diff --git a/irmp.h b/irmp.h
index 4d47a5975a28bb25dd2289f5b71ea63c8f1350c8..55a44c8281f40f7b25de2e11e28561f546053ea0 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.44 2010/11/09 19:18:32 fm Exp $\r
+ * $Id: irmp.h,v 1.55 2011/02/25 08:35:33 fm Exp $\r
  *\r
  * ATMEGA88 @ 8 MHz\r
  *\r
@@ -55,7 +55,7 @@ typedef uint8_t     PAUSE_LEN;
 #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_DENON_PROTOCOL                      8              // Denon, Sharp\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
@@ -70,10 +70,16 @@ typedef uint8_t     PAUSE_LEN;
 #define IRMP_JVC_PROTOCOL                       20              // JVC\r
 #define IRMP_RC6A_PROTOCOL                      21              // RC6A, e.g. Kathrein, XBOX\r
 #define IRMP_NIKON_PROTOCOL                     22              // Nikon\r
+#define IRMP_RUWIDO_PROTOCOL                    23              // Ruwido, e.g. T-Home Mediareceiver\r
+#define IRMP_IR60_PROTOCOL                      24              // IR60 (SAB2008)\r
+#define IRMP_KATHREIN_PROTOCOL                  25              // Kathrein\r
+#define IRMP_NETBOX_PROTOCOL                    26              // Netbox keyboard (bitserial)\r
+#define IRMP_IMON_PROTOCOL                      27              // Imon (bitserial)\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
+#define IRMP_PARAM_FLAG_IS_SERIAL               0x04\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
@@ -171,17 +177,18 @@ typedef uint8_t     PAUSE_LEN;
 #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_FRAME_REPEAT_PAUSE_TIME            45.0e-3                       // frame repeat after 45ms\r
-#define RECS80_ADDRESS_OFFSET                   2                               // skip 2 bits (2nd start + 1 toggle)\r
+#define RECS80_ADDRESS_OFFSET                   1                               // skip 1 bit (toggle bit)\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_OFFSET                   4                               // 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_COMPLETE_DATA_LEN                10                              // 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
+\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
@@ -191,9 +198,9 @@ typedef uint8_t     PAUSE_LEN;
 #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
-#define DENON_0_PAUSE_TIME                       775.0e-6                       //  775 usec pause\r
+#define DENON_PULSE_TIME                         310.0e-6                       //  310 usec pulse in practice,  275 in theory\r
+#define DENON_1_PAUSE_TIME                      1780.0e-6                       // 1780 usec pause in practice, 1900 in theory\r
+#define DENON_0_PAUSE_TIME                       745.0e-6                       //  745 usec pause in practice,  775 in theory\r
 #define DENON_FRAMES                            2                               // DENON sends each frame 2 times\r
 #define DENON_AUTO_REPETITION_PAUSE_TIME          65.0e-3                       // inverted repetition after 65ms\r
 #define DENON_FRAME_REPEAT_PAUSE_TIME             65.0e-3                       // frame repeat after 65ms\r
@@ -277,12 +284,12 @@ typedef uint8_t     PAUSE_LEN;
 #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
+#define GRUNDIG_NOKIA_IR60_BIT_TIME             528.0e-6                        // 528 usec pulse/pause\r
+#define GRUNDIG_NOKIA_IR60_PRE_PAUSE_TIME       2639.0e-6                       // 2639 usec pause after pre bit\r
+#define GRUNDIG_NOKIA_IR60_FRAME_REPEAT_PAUSE_TIME  117.76e-3                   // info frame repeat after 117.76 ms\r
+#define GRUNDIG_NOKIA_IR60_STOP_BIT             0                               // has no stop bit\r
+#define GRUNDIG_NOKIA_IR60_LSB                  1                               // MSB...LSB\r
+#define GRUNDIG_NOKIA_IR60_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
@@ -300,16 +307,35 @@ typedef uint8_t     PAUSE_LEN;
 #define NOKIA_COMMAND_LEN                       8                               // read 8 command bits\r
 #define NOKIA_COMPLETE_DATA_LEN                 17                              // complete length: 1 start bit + 8 address bits + 8 command bits\r
 \r
-#define SIEMENS_BIT_TIME                        250.0e-6                        // 250 usec pulse/pause\r
-#define SIEMENS_FRAME_REPEAT_PAUSE_TIME          45.0e-3                        // frame repeat after 45ms\r
-#define SIEMENS_ADDRESS_OFFSET                  2                               // skip 2 start bits\r
-#define SIEMENS_ADDRESS_LEN                     12                              // read 12 address bits\r
-#define SIEMENS_COMMAND_OFFSET                  15                              // skip 15 bits (2 start bits + 12 address bits + 1 inverted bit)\r
-#define SIEMENS_COMMAND_LEN                     8                               // read 7 + 1 command bits, last bit is only check bit.\r
-#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
+#define IR60_TIMEOUT_TIME                       5000.0e-6                       // timeout grundig frame, switch to IR60\r
+#define IR60_ADDRESS_OFFSET                     0                               // skip 1 bits\r
+#define IR60_ADDRESS_LEN                        0                               // read 0 address bits\r
+#define IR60_COMMAND_OFFSET                     0                               // skip 1 bit (start bit after pre bit, always 1)\r
+#define IR60_COMMAND_LEN                        7                               // read 6 command bits\r
+#define IR60_COMPLETE_DATA_LEN                  7                               // complete length\r
+\r
+#define SIEMENS_OR_RUWIDO_START_BIT_PULSE_TIME    275.0e-6                      //  275 usec pulse\r
+#define SIEMENS_OR_RUWIDO_START_BIT_PAUSE_TIME    550.0e-6                      //  550 usec pause\r
+#define SIEMENS_OR_RUWIDO_BIT_PULSE_TIME          275.0e-6                      //  275 usec short pulse\r
+#define SIEMENS_OR_RUWIDO_BIT_PULSE_TIME_2        550.0e-6                      //  550 usec long pulse\r
+#define SIEMENS_OR_RUWIDO_BIT_PAUSE_TIME          275.0e-6                      //  275 usec short pause\r
+#define SIEMENS_OR_RUWIDO_BIT_PAUSE_TIME_2        550.0e-6                      //  550 usec long pause\r
+#define SIEMENS_OR_RUWIDO_FRAME_REPEAT_PAUSE_TIME 45.0e-3                       // frame repeat after 45ms\r
+#define SIEMENS_OR_RUWIDO_STOP_BIT                0                             // has no stop bit\r
+#define SIEMENS_OR_RUWIDO_LSB                     0                             // MSB...LSB\r
+#define SIEMENS_OR_RUWIDO_FLAGS                   (IRMP_PARAM_FLAG_IS_MANCHESTER | IRMP_PARAM_FLAG_1ST_PULSE_IS_1)  // flags\r
+\r
+#define RUWIDO_ADDRESS_OFFSET                   0                               // skip 0 bits\r
+#define RUWIDO_ADDRESS_LEN                      9                               // read 9 address bits\r
+#define RUWIDO_COMMAND_OFFSET                   9                               // skip 9 bits\r
+#define RUWIDO_COMMAND_LEN                      8                               // read 7 + 1 command bits, last bit is only check bit\r
+#define RUWIDO_COMPLETE_DATA_LEN                17                              // complete length\r
+\r
+#define SIEMENS_ADDRESS_OFFSET                  0                               // skip 0 bits\r
+#define SIEMENS_ADDRESS_LEN                     11                              // read 11 bits\r
+#define SIEMENS_COMMAND_OFFSET                  11                              // skip 11 bits\r
+#define SIEMENS_COMMAND_LEN                     11                              // read 10 + 1 command bits, last bit is only check bit\r
+#define SIEMENS_COMPLETE_DATA_LEN               22                              // complete length\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
@@ -371,6 +397,57 @@ typedef uint8_t     PAUSE_LEN;
 #define NIKON_LSB                               0                               // LSB...MSB\r
 #define NIKON_FLAGS                             0                               // flags\r
 \r
+#define KATHREIN_START_BIT_PULSE_TIME            210.0e-6                       // 1340 usec pulse\r
+#define KATHREIN_START_BIT_PAUSE_TIME           6218.0e-6                       //  340 usec pause\r
+#define KATHREIN_1_PULSE_TIME                    210.0e-6                       // 1340 usec pulse\r
+#define KATHREIN_1_PAUSE_TIME                   3000.0e-6                       //  340 usec pause\r
+#define KATHREIN_0_PULSE_TIME                    210.0e-6                       //  500 usec pulse\r
+#define KATHREIN_0_PAUSE_TIME                   1400.0e-6                       // 1300 usec pause\r
+#define KATHREIN_SYNC_BIT_PAUSE_LEN_TIME        4600.0e-6                       // 4600 usec sync (on 6th and/or 8th bit)\r
+#define KATHREIN_FRAMES                         1                               // Kathrein sends 1 frame\r
+#define KATHREIN_AUTO_REPETITION_PAUSE_TIME     35.0e-3                         // auto repetition after 35ms\r
+#define KATHREIN_FRAME_REPEAT_PAUSE_TIME        35.0e-3                         // frame repeat after 35ms\r
+#define KATHREIN_ADDRESS_OFFSET                 1                               // skip 1 bits\r
+#define KATHREIN_ADDRESS_LEN                    4                               // read 4 address bits\r
+#define KATHREIN_COMMAND_OFFSET                 5                               // skip 5 bits\r
+#define KATHREIN_COMMAND_LEN                    7                               // read 7 bits\r
+#define KATHREIN_COMPLETE_DATA_LEN              13                              // complete length\r
+#define KATHREIN_STOP_BIT                       1                               // has stop bit\r
+#define KATHREIN_LSB                            0                               // MSB\r
+#define KATHREIN_FLAGS                          0                               // flags\r
+\r
+#define NETBOX_START_BIT_PULSE_TIME             2400.0e-6                       // 2400 usec pulse\r
+#define NETBOX_START_BIT_PAUSE_TIME              800.0e-6                       //  800 usec pause\r
+#define NETBOX_PULSE_TIME                        800.0e-6                       //  800 usec pulse\r
+#define NETBOX_PAUSE_TIME                        800.0e-6                       //  800 usec pause\r
+#define NETBOX_FRAMES                           1                               // Netbox sends 1 frame\r
+#define NETBOX_AUTO_REPETITION_PAUSE_TIME       35.0e-3                         // auto repetition after 35ms\r
+#define NETBOX_FRAME_REPEAT_PAUSE_TIME          35.0e-3                         // frame repeat after 35ms\r
+#define NETBOX_ADDRESS_OFFSET                   0                               // skip 0 bits\r
+#define NETBOX_ADDRESS_LEN                      3                               // read 3 address bits\r
+#define NETBOX_COMMAND_OFFSET                   3                               // skip 3 bits\r
+#define NETBOX_COMMAND_LEN                      13                              // read 13 bits\r
+#define NETBOX_COMPLETE_DATA_LEN                16                              // complete length\r
+#define NETBOX_STOP_BIT                         0                               // has no stop bit\r
+#define NETBOX_LSB                              1                               // LSB\r
+#define NETBOX_FLAGS                            IRMP_PARAM_FLAG_IS_SERIAL       // flags\r
+\r
+#define IMON_START_BIT_PULSE_TIME               1333.0e-6                       // 1333 usec pulse\r
+#define IMON_START_BIT_PAUSE_TIME               1172.0e-6                       // 1333 usec pause\r
+#define IMON_PULSE_TIME                          500.0e-6                       //  500 usec pulse\r
+#define IMON_PAUSE_TIME                          500.0e-6                       //  500 usec pause\r
+#define IMON_FRAMES                             1                               // Imon sends 1 frame\r
+#define IMON_AUTO_REPETITION_PAUSE_TIME         35.0e-3                         // auto repetition after 35ms\r
+#define IMON_FRAME_REPEAT_PAUSE_TIME            35.0e-3                         // frame repeat after 35ms\r
+#define IMON_ADDRESS_OFFSET                     0                               // skip 0 bits\r
+#define IMON_ADDRESS_LEN                        0                               // read 0 address bits\r
+#define IMON_COMMAND_OFFSET                     26                              // skip 26 bits\r
+#define IMON_COMMAND_LEN                        16                              // read last 16 bits, ignore rest\r
+#define IMON_COMPLETE_DATA_LEN                  42                              // complete length, last is stop bit\r
+#define IMON_STOP_BIT                           1                               // has stop bit\r
+#define IMON_LSB                                1                               // LSB\r
+#define IMON_FLAGS                              IRMP_PARAM_FLAG_IS_SERIAL       // 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