*\r
* Copyright (c) 2009-2010 Frank Meyer - frank(at)fli4l.de\r
*\r
- * $Id: irmp.h,v 1.39 2010/06/25 13:18:36 fm Exp $\r
+ * $Id: irmp.h,v 1.43 2010/08/31 15:22:24 fm Exp $\r
*\r
* ATMEGA88 @ 8 MHz\r
*\r
{\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
#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 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
#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 RCCAR_LSB 1 // LSB...MSB\r
#define RCCAR_FLAGS 0 // flags\r
\r
-#define AUTO_FRAME_REPETITION_TIME 50.0e-3 // SIRCS/SAMSUNG32/NUBERT: automatic repetition after 25-50ms\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 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