/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
* irmp.h\r
*\r
- * Copyright (c) 2009-2010 Frank Meyer - frank(at)fli4l.de\r
+ * Copyright (c) 2009-2011 Frank Meyer - frank(at)fli4l.de\r
*\r
- * $Id: irmp.h,v 1.49 2011/02/21 11:49:37 fm Exp $\r
+ * $Id: irmp.h,v 1.70 2012/02/21 08:41:46 fm Exp $\r
*\r
* ATMEGA88 @ 8 MHz\r
*\r
#ifndef _WC_IRMP_H_\r
#define _WC_IRMP_H_\r
\r
-#ifdef __cplusplus\r
-extern "C"\r
-{\r
-#endif\r
+#if defined(__18CXX) // Microchip C18 declaration of missing typedef\r
+typedef unsigned char uint8_t;\r
+typedef unsigned int uint16_t;\r
+#endif //Microchip C18\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
+// fm 22.09.2011: may not be more than 16000L, otherwise some JVC codes will not be accepted\r
+#define IRMP_TIMEOUT_TIME 15500.0e-6 // timeout after 15.5 ms darkness\r
+#define IRMP_TIMEOUT_TIME_MS 15500L // timeout after 15.5 ms darkness\r
\r
#if IRMP_SUPPORT_NIKON_PROTOCOL == 1\r
#define IRMP_TIMEOUT_NIKON_TIME 29500.0e-6 // 2nd timeout after 29.5 ms darkness (only for NIKON!)\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_JVC_PROTOCOL 20 // JVC (NEC with 16 bits)\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_NEC16_PROTOCOL 27 // NEC with 16 bits (incl. sync)\r
+#define IRMP_NEC42_PROTOCOL 28 // NEC with 42 bits\r
+#define IRMP_LEGO_PROTOCOL 29 // LEGO Power Functions RC\r
+#define IRMP_THOMSON_PROTOCOL 30 // Thomson\r
+#define IRMP_GRUNDIG2_PROTOCOL 31 // Grundig, e.g. TP400\r
+\r
+#define IRMP_N_PROTOCOLS 31 // number of supported protocols\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
#define NEC_LSB 1 // LSB...MSB\r
#define NEC_FLAGS 0 // flags\r
\r
+#define NEC42_ADDRESS_OFFSET 0 // skip 0 bits\r
+#define NEC42_ADDRESS_LEN 13 // read 13 address bits\r
+#define NEC42_COMMAND_OFFSET 26 // skip 26 bits (2 x 13 address bits)\r
+#define NEC42_COMMAND_LEN 8 // read 8 command bits\r
+#define NEC42_COMPLETE_DATA_LEN 42 // complete length (2 x 13 + 2 x 8)\r
+\r
+#define NEC16_ADDRESS_OFFSET 0 // skip 0 bits\r
+#define NEC16_ADDRESS_LEN 8 // read 8 address bits\r
+#define NEC16_COMMAND_OFFSET 8 // skip 8 bits (8 address)\r
+#define NEC16_COMMAND_LEN 8 // read 8 bits (8 command)\r
+#define NEC16_COMPLETE_DATA_LEN 16 // complete length\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
#define SAMSUNG_PULSE_TIME 550.0e-6 // 550 usec pulse\r
-#define SAMSUNG_1_PAUSE_TIME 1450.0e-6 // 1450 usec pause\r
-#define SAMSUNG_0_PAUSE_TIME 450.0e-6 // 450 usec pause\r
-#define SAMSUNG_FRAME_REPEAT_PAUSE_TIME 45.0e-3 // frame repeat after 45ms\r
+#define SAMSUNG_1_PAUSE_TIME 1650.0e-6 // 1650 usec pause\r
+#define SAMSUNG_0_PAUSE_TIME 550.0e-6 // 550 usec pause\r
+\r
+#define SAMSUNG_FRAME_REPEAT_PAUSE_TIME 25.0e-3 // frame repeat after 25ms\r
#define SAMSUNG_ADDRESS_OFFSET 0 // skip 0 bits\r
#define SAMSUNG_ADDRESS_LEN 16 // read 16 address bits\r
#define SAMSUNG_ID_OFFSET 17 // skip 16 + 1 sync bit\r
#define SAMSUNG32_COMMAND_OFFSET 16 // skip 16 bits\r
#define SAMSUNG32_COMMAND_LEN 16 // read 16 command bits\r
#define SAMSUNG32_COMPLETE_DATA_LEN 32 // complete length\r
-#define SAMSUNG32_FRAMES 2 // SAMSUNG32 sends each frame 2 times\r
+#define SAMSUNG32_FRAMES 1 // SAMSUNG32 sends each frame 1 times\r
#define SAMSUNG32_AUTO_REPETITION_PAUSE_TIME 47.0e-3 // repetition after 47 ms\r
-#define SAMSUNG32_FRAME_REPEAT_PAUSE_TIME 47.0e-3 // frame repeat after 40ms\r
+#define SAMSUNG32_FRAME_REPEAT_PAUSE_TIME 47.0e-3 // frame repeat after 47ms\r
\r
#define MATSUSHITA_START_BIT_PULSE_TIME 3488.0e-6 // 3488 usec pulse\r
#define MATSUSHITA_START_BIT_PAUSE_TIME 3488.0e-6 // 3488 usec pause\r
#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 4 bits (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
#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_ADDRESS_OFFSET 1 // skip 1 bit (2nd start)\r
+#define RC5_ADDRESS_LEN 6 // read 1 toggle bit (for key repetition detection) + 5 address bits\r
#define RC5_COMMAND_OFFSET 7 // skip 5 bits (2nd start + 1 toggle + 5 address)\r
#define RC5_COMMAND_LEN 6 // read 6 command bits\r
#define RC5_COMPLETE_DATA_LEN 13 // complete length\r
#define RECS80EXT_0_PAUSE_TIME 4902.0e-6 // 4902 usec pause\r
#define RECS80EXT_FRAME_REPEAT_PAUSE_TIME 45.0e-3 // frame repeat after 45ms\r
#define RECS80EXT_ADDRESS_OFFSET 2 // skip 2 bits (2nd start + 1 toggle)\r
-#define RECS80EXT_ADDRESS_LEN 4 // read 3 address bits\r
+#define RECS80EXT_ADDRESS_LEN 4 // read 4 address bits\r
#define RECS80EXT_COMMAND_OFFSET 6 // skip 6 bits (2nd start + 1 toggle + 4 address)\r
#define RECS80EXT_COMMAND_LEN 6 // read 6 command bits\r
#define RECS80EXT_COMPLETE_DATA_LEN 12 // complete length\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
+#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
#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 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
\r
#define NIKON_START_BIT_PULSE_TIME 2200.0e-6 // 2200 usec pulse\r
#define NIKON_START_BIT_PAUSE_TIME 27100.0e-6 // 27100 usec pause\r
-#define NIKON_PULSE_TIME 500.0e-6 // 520 usec pulse\r
+#define NIKON_PULSE_TIME 500.0e-6 // 500 usec pulse\r
#define NIKON_1_PAUSE_TIME 3500.0e-6 // 3500 usec pause\r
#define NIKON_0_PAUSE_TIME 1500.0e-6 // 1500 usec pause\r
#define NIKON_FRAME_REPEAT_PAUSE_TIME 60.0e-3 // frame repeat after 60ms\r
#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 LEGO_START_BIT_PULSE_TIME 158.0e-6 // 158 usec pulse ( 6 x 1/38kHz)\r
+#define LEGO_START_BIT_PAUSE_TIME 1026.0e-6 // 1026 usec pause (39 x 1/38kHz)\r
+#define LEGO_PULSE_TIME 158.0e-6 // 158 usec pulse ( 6 x 1/38kHz)\r
+#define LEGO_1_PAUSE_TIME 553.0e-6 // 553 usec pause (21 x 1/38kHz)\r
+#define LEGO_0_PAUSE_TIME 263.0e-6 // 263 usec pause (10 x 1/38kHz)\r
+#define LEGO_FRAME_REPEAT_PAUSE_TIME 40.0e-3 // frame repeat after 40ms\r
+#define LEGO_ADDRESS_OFFSET 0 // skip 0 bits\r
+#define LEGO_ADDRESS_LEN 0 // read 0 address bits\r
+#define LEGO_COMMAND_OFFSET 0 // skip 0 bits\r
+#define LEGO_COMMAND_LEN 16 // read 16 bits (12 command + 4 CRC)\r
+#define LEGO_COMPLETE_DATA_LEN 16 // complete length\r
+#define LEGO_STOP_BIT 1 // has stop bit\r
+#define LEGO_LSB 0 // MSB...LSB\r
+#define LEGO_FLAGS 0 // flags\r
+\r
+#define THOMSON_PULSE_TIME 550.0e-6 // 550 usec pulse\r
+#define THOMSON_1_PAUSE_TIME 4500.0e-6 // 4500 usec pause\r
+#define THOMSON_0_PAUSE_TIME 2000.0e-6 // 2000 usec pause\r
+#define THOMSON_FRAMES 1 // THOMSON sends 1 frame\r
+#define THOMSON_AUTO_REPETITION_PAUSE_TIME 65.0e-3 // repetition after 65ms\r
+#define THOMSON_FRAME_REPEAT_PAUSE_TIME 65.0e-3 // frame repeat after 65ms\r
+#define THOMSON_ADDRESS_OFFSET 0 // skip 0 bits\r
+#define THOMSON_ADDRESS_LEN 4 // read 4 address bits\r
+#define THOMSON_COMMAND_OFFSET 5 // skip 4 address bits + 1 toggle bit\r
+#define THOMSON_COMMAND_LEN 7 // read 7 command bits\r
+#define THOMSON_COMPLETE_DATA_LEN 12 // complete length\r
+#define THOMSON_STOP_BIT 1 // has stop bit\r
+#define THOMSON_LSB 0 // MSB...LSB\r
+#define THOMSON_FLAGS 0 // flags\r
+\r
+#define GRUNDIG2_START_BIT_PULSE_TIME 550.0e-6 // 550 usec pulse\r
+#define GRUNDIG2_START_BIT_PAUSE_TIME 2700.0e-6 // 2700 usec pause\r
+#define GRUNDIG2_BIT_PULSE_TIME 550.0e-6 // 550 usec short pulse\r
+#define GRUNDIG2_BIT_PAUSE_TIME 550.0e-6 // 550 usec short pause\r
+#define GRUNDIG2_FRAME_REPEAT_PAUSE_TIME 100.0e-3 // frame repeat after 100ms\r
+#define GRUNDIG2_STOP_BIT 0 // has no stop bit\r
+#define GRUNDIG2_LSB 1 // MSB...LSB\r
+#define GRUNDIG2_FLAGS (IRMP_PARAM_FLAG_IS_MANCHESTER | IRMP_PARAM_FLAG_1ST_PULSE_IS_1) // flags\r
+#define GRUNDIG2_ADDRESS_OFFSET 0 // skip 0 bits\r
+#define GRUNDIG2_ADDRESS_LEN 0 // read 0 bits\r
+#define GRUNDIG2_COMMAND_OFFSET 0 // skip 0 bits\r
+#define GRUNDIG2_COMMAND_LEN 7 // read 6 + 1 command bits, last bit is always 1\r
+#define GRUNDIG2_COMPLETE_DATA_LEN 7 // complete length\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
uint8_t flags; // flags, e.g. repetition\r
} IRMP_DATA;\r
\r
+extern void irmp_init (void);\r
+extern uint8_t irmp_get_data (IRMP_DATA *);\r
+extern uint8_t irmp_is_busy (void);\r
+extern uint8_t irmp_ISR (void);\r
\r
-/**\r
- * Initialize IRMP decoder\r
- * @details Configures IRMP input pin\r
- */\r
-extern void irmp_init (void);\r
-\r
-/**\r
- * Get IRMP data\r
- * @details gets decoded IRMP data\r
- * @param pointer in order to store IRMP data\r
- * @return TRUE: successful, FALSE: failed\r
- */\r
-extern uint8_t irmp_get_data (IRMP_DATA *);\r
-\r
-/**\r
- * ISR routine\r
- * @details ISR routine, called 10000 times per second\r
- */\r
-extern uint8_t irmp_ISR (void);\r
-\r
-#ifdef __cplusplus\r
-}\r
+#if IRMP_PROTOCOL_NAMES == 1\r
+extern char * irmp_protocol_names[IRMP_N_PROTOCOLS + 1];\r
#endif\r
\r
+#if IRMP_USE_CALLBACK == 1\r
+extern void irmp_set_callback_ptr (void (*cb)(uint8_t));\r
+#endif // IRSND_USE_CALLBACK == 1\r
+\r
#endif /* _WC_IRMP_H_ */\r