]> 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 91283aa2635c9ac5a9e99939d04dd32bee0f1aa7..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.23 2010/06/02 13:18:03 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,6 +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_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
@@ -153,7 +155,7 @@ extern "C"
 \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_0_PAUSE_TIME                       775.0e-6                       //  775 usec pause\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
@@ -264,6 +266,34 @@ extern "C"
 #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
 \r
 #define TRUE                                    1\r
@@ -298,7 +328,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