]> cloudbase.mooo.com Git - irmp.git/blobdiff - irmp.h
Version 1.6.2: added FDC2 protocol
[irmp.git] / irmp.h
diff --git a/irmp.h b/irmp.h
index f95263774a3ed3221a8db1a2b7c9cef64ac73874..d9ddfa23d7409f858604e1ca8c170d27f2d154d6 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.27 2010/06/10 10:05:56 fm Exp $\r
+ * $Id: irmp.h,v 1.28 2010/06/10 21:24:50 fm Exp $\r
  *\r
  * ATMEGA88 @ 8 MHz\r
  *\r
@@ -43,7 +43,8 @@ extern "C"
 #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_FDC1_PROTOCOL                      18                              // FDC keyboard - protocol 1\r
+#define IRMP_FDC2_PROTOCOL                      19                              // FDC keyboard - protocol 2\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
@@ -265,19 +266,33 @@ extern "C"
 #define SIEMENS_STOP_BIT                        0                               // has no stop bit\r
 #define SIEMENS_LSB                             0                               // MSB...LSB\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_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_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 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
 \r