]> cloudbase.mooo.com Git - irmp.git/blobdiff - irsndconfig.h
Version 2.0.4
[irmp.git] / irsndconfig.h
index f08506e7e52abfeb651f26e8162ea0f13248b332..7af7e8e31e0c9b89b1cb5b1a667ea7aa8c1b6dfd 100644 (file)
@@ -1,9 +1,9 @@
 /*---------------------------------------------------------------------------------------------------------------------------------------------------\r
  * irsndconfig.h\r
  *\r
- * Copyright (c) 2010 Frank Meyer - frank(at)fli4l.de\r
+ * Copyright (c) 2010-2011 Frank Meyer - frank(at)fli4l.de\r
  *\r
- * $Id: irsndconfig.h,v 1.3 2010/05/26 08:34:30 fm Exp $\r
+ * $Id: irsndconfig.h,v 1.31 2012/02/24 15:00:18 fm Exp $\r
  *\r
  * ATMEGA88 @ 8 MHz\r
  *\r
  *---------------------------------------------------------------------------------------------------------------------------------------------------\r
  */\r
 \r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ * F_INTERRUPTS: number of interrupts per second, should be in the range from 10000 to 20000, typically 15000\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+#ifndef F_INTERRUPTS\r
+#define F_INTERRUPTS                            15000   // interrupts per second\r
+#endif\r
+\r
 /*---------------------------------------------------------------------------------------------------------------------------------------------------\r
  * Change settings from 1 to 0 if you want to disable one or more encoders.\r
  * This saves program space.\r
  * 0 disable decoder\r
  *---------------------------------------------------------------------------------------------------------------------------------------------------\r
  */\r
-#define IRSND_SUPPORT_SIRCS_PROTOCOL            1       // flag: support SIRCS                  uses ~150 bytes\r
-#define IRSND_SUPPORT_NEC_PROTOCOL              1       // flag: support NEC + APPLE            uses ~100 bytes\r
-#define IRSND_SUPPORT_SAMSUNG_PROTOCOL          1       // flag: support Samsung + Samsung32    uses ~300 bytes\r
-#define IRSND_SUPPORT_MATSUSHITA_PROTOCOL       1       // flag: support Matsushita             uses ~150 bytes\r
-#define IRSND_SUPPORT_KASEIKYO_PROTOCOL         0       // flag: support Kaseikyo               NOT SUPPORTED YET!\r
-#define IRSND_SUPPORT_RECS80_PROTOCOL           1       // flag: support RECS80                 uses ~100 bytes\r
-#define IRSND_SUPPORT_RC5_PROTOCOL              1       // flag: support RC5                    uses ~250 bytes\r
-#define IRSND_SUPPORT_DENON_PROTOCOL            1       // flag: support DENON                  uses ~200 bytes\r
-#define IRSND_SUPPORT_RC6_PROTOCOL              0       // flag: support RC6                    NOT SUPPORTED YET!\r
-#define IRSND_SUPPORT_RECS80EXT_PROTOCOL        1       // flag: support RECS80EXT              uses ~100 bytes\r
-#define IRSND_SUPPORT_NUBERT_PROTOCOL           1       // flag: support NUBERT                 uses ~100 bytes\r
-#define IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL     1       // flag: support Bang&Olufsen           uses ~250 bytes\r
-#define IRSND_SUPPORT_GRUNDIG_PROTOCOL          1       // flag: support Grundig                uses ~250 bytes\r
-#define IRSND_SUPPORT_NOKIA_PROTOCOL            1       // flag: support Nokia                  uses ~150 bytes\r
+\r
+// typical protocols, disable here!             Enable  Remarks                 F_INTERRUPTS            Program Space\r
+#define IRSND_SUPPORT_SIRCS_PROTOCOL            1       // Sony SIRCS           >= 10000                 ~150 bytes\r
+#define IRSND_SUPPORT_NEC_PROTOCOL              1       // NEC + APPLE          >= 10000                 ~100 bytes\r
+#define IRSND_SUPPORT_SAMSUNG_PROTOCOL          1       // Samsung + Samsung32  >= 10000                 ~300 bytes\r
+#define IRSND_SUPPORT_MATSUSHITA_PROTOCOL       1       // Matsushita           >= 10000                 ~200 bytes\r
+#define IRSND_SUPPORT_KASEIKYO_PROTOCOL         1       // Kaseikyo             >= 10000                 ~150 bytes\r
+#define IRSND_SUPPORT_DENON_PROTOCOL            1       // DENON, Sharp         >= 10000                 ~200 bytes\r
+\r
+// more protocols, enable here!                 Enable  Remarks                 F_INTERRUPTS            Program Space\r
+#define IRSND_SUPPORT_RC5_PROTOCOL              0       // RC5                  >= 10000                 ~150 bytes\r
+#define IRSND_SUPPORT_RC6_PROTOCOL              0       // RC6                  >= 10000                 ~250 bytes\r
+#define IRSND_SUPPORT_RC6A_PROTOCOL             0       // RC6A                 >= 10000                 ~250 bytes\r
+#define IRSND_SUPPORT_JVC_PROTOCOL              0       // JVC                  >= 10000                 ~150 bytes\r
+#define IRSND_SUPPORT_NEC16_PROTOCOL            0       // NEC16                >= 10000                 ~150 bytes\r
+#define IRSND_SUPPORT_NEC42_PROTOCOL            0       // NEC42                >= 10000                 ~150 bytes\r
+#define IRSND_SUPPORT_IR60_PROTOCOL             1       // IR60 (SDA2008)       >= 10000                 ~250 bytes\r
+#define IRSND_SUPPORT_GRUNDIG_PROTOCOL          1       // Grundig              >= 10000                 ~300 bytes\r
+#define IRSND_SUPPORT_SIEMENS_PROTOCOL          0       // Siemens, Gigaset     >= 15000                 ~150 bytes\r
+#define IRSND_SUPPORT_NOKIA_PROTOCOL            0       // Nokia                >= 10000                 ~400 bytes\r
+\r
+// exotic protocols, enable here!               Enable  Remarks                 F_INTERRUPTS            Program Space\r
+#define IRSND_SUPPORT_KATHREIN_PROTOCOL         0       // Kathrein             >= 10000                 DON'T CHANGE, NOT SUPPORTED YET!\r
+#define IRSND_SUPPORT_NUBERT_PROTOCOL           0       // NUBERT               >= 10000                 ~100 bytes\r
+#define IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL     0       // Bang&Olufsen         >= 10000                 ~250 bytes\r
+#define IRSND_SUPPORT_RECS80_PROTOCOL           0       // RECS80               >= 20000                 ~100 bytes\r
+#define IRSND_SUPPORT_RECS80EXT_PROTOCOL        0       // RECS80EXT            >= 20000                 ~100 bytes\r
+#define IRSND_SUPPORT_THOMSON_PROTOCOL          0       // Thomson              >= 10000                 ~250 bytes\r
+#define IRSND_SUPPORT_NIKON_PROTOCOL            0       // NIKON                >= 10000                 ~150 bytes\r
+#define IRSND_SUPPORT_NETBOX_PROTOCOL           0       // Netbox keyboard      >= 10000                 DON'T CHANGE, NOT SUPPORTED YET!\r
+#define IRSND_SUPPORT_FDC_PROTOCOL              0       // FDC IR keyboard      >= 10000 (better 15000)  ~150 bytes\r
+#define IRSND_SUPPORT_RCCAR_PROTOCOL            0       // RC CAR               >= 10000 (better 15000)  ~150 bytes\r
+#define IRSND_SUPPORT_RUWIDO_PROTOCOL           0       // RUWIDO, T-Home       >= 15000                 DON'T CHANGE, NOT SUPPORTED YET!\r
+#define IRSND_SUPPORT_LEGO_PROTOCOL             0       // LEGO Power RC        >= 20000                 ~150 bytes\r
 \r
 \r
 /*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * Change hardware pin here:\r
+ * DO NOT CHANGE:\r
  *---------------------------------------------------------------------------------------------------------------------------------------------------\r
  */\r
-#if defined (__AVR_ATmega32__) || defined (__AVR_ATmega644P__)\r
-#define IRSND_PORT          PORTD                       // port D\r
-#define IRSND_DDR           DDRD                        // ddr D\r
-#define IRSND_BIT           7                           // OC2A\r
+#define IRSND_OC2                               0       // OC2\r
+#define IRSND_OC2A                              1       // OC2A\r
+#define IRSND_OC2B                              2       // OC2B\r
+#define IRSND_OC0                               3       // OC0\r
+#define IRSND_OC0A                              4       // OC0A\r
+#define IRSND_OC0B                              5       // OC0B\r
+\r
+//PIC Microchip C18\r
+#define IRSND_PIC_CCP1                          1       // PIC C18 RC2 = PWM1 module\r
+#define IRSND_PIC_CCP2                          2       // PIC C18 RC1 = PWM2 module\r
+\r
+#ifndef PIC_C18                                                                 // AVR part\r
+\r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ * AVR\r
+ *\r
+ * Change hardware pin here:                    IRSND_OC2  = OC2  on ATmegas         supporting OC2,  e.g. ATmega8\r
+ *                                              IRSND_OC2A = OC2A on ATmegas         supporting OC2A, e.g. ATmega88\r
+ *                                              IRSND_OC2B = OC2B on ATmegas         supporting OC2B, e.g. ATmega88\r
+ *                                              IRSND_OC0  = OC0  on ATmegas         supporting OC0,  e.g. ATmega162\r
+ *                                              IRSND_OC0A = OC0A on ATmegas/ATtinys supporting OC0A, e.g. ATtiny84, ATtiny85\r
+ *                                              IRSND_OC0B = OC0B on ATmegas/ATtinys supporting OC0B, e.g. ATtiny84, ATtiny85\r
+ *                                                                                              IRSND_PIC_CCP1 = RC2 on PIC 18F2550/18F4550, ...\r
+ *                                                                                              IRSND_PIC_CCP2 = RC1 on PIC 18F2550/18F4550, ...\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+\r
+#define IRSND_OCx                               IRSND_OC2B          // use OC2B\r
+\r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ * PIC C18\r
+ *\r
+ * Change hardware pin here:                    IRSND_PIC_CCP1 = RC2 on PIC 18F2550/18F4550, ...\r
+ *                                                                                              IRSND_PIC_CCP2 = RC1 on PIC 18F2550/18F4550, ...\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+\r
 #else\r
-#define IRSND_PORT          PORTB                       // port B\r
-#define IRSND_DDR           DDRB                        // ddr B\r
-#define IRSND_BIT           3                           // OC2A\r
-#endif // __AVR...\r
+#define IRSND_OCx                                   IRSND_PIC_CCP2      // Use PWMx for PIC\r
 \r
 /*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * Change F_INTERRUPTS if you change the number of interrupts per second, F_INTERRUPTS should be in the range from 10000 to 15000\r
+ * PIC C18 - change other PIC specific settings - ignore it when using AVR\r
  *---------------------------------------------------------------------------------------------------------------------------------------------------\r
  */\r
-#define F_INTERRUPTS                            10000   // interrupts per second\r
+\r
+#define F_CPU                                   48000000UL          // PIC freq.; Set you Freq here\r
+#define Pre_Scaler                              4                   // define prescaler for Timer2 e.g. 1,4,16 !!!\r
+#define PIC_Scaler                              2                   // PIC needs /2 extra in IRSND_FREQ_32_KHZ calculation for right value\r
+#warning Timer2 used for IRSND (PWM out) ! Do not use/setup Timer 2 yourself !\r
+\r
+//Do not change lines below until you have a diffrent HW !! Example for 18F2550/18F4550\r
+//Setup macro for PWM used PWM module\r
+\r
+#if IRSND_OCx == IRSND_PIC_CCP2        \r
+#define IRSND_PIN                               TRISCbits.TRISC1    // RC1 = PWM2\r
+\r
+#define SetDCPWM(x)                             SetDCPWM2(x)                    \r
+#define ClosePWM                                        ClosePWM2\r
+#define OpenPWM(x)                                      OpenPWM2(x) \r
+#endif\r
+\r
+#if IRSND_OCx == IRSND_PIC_CCP1        \r
+#define IRSND_PIN                               TRISCbits.TRISC2    // RC2 = PWM1\r
+\r
+#define SetDCPWM(x)                             SetDCPWM1(x)\r
+#define ClosePWM                                ClosePWM1\r
+#define OpenPWM(x)                              OpenPWM1(x)\r
+#endif\r
+\r
+//Setup macro for OpenTimer with defined Pre_Scaler\r
+#if Pre_Scaler == 1\r
+#define OpenTimer                               OpenTimer2(TIMER_INT_OFF & T2_PS_1_1); \r
+#elif Pre_Scaler == 4\r
+#define OpenTimer                               OpenTimer2(TIMER_INT_OFF & T2_PS_1_4); \r
+#elif Pre_Scaler == 16\r
+#define OpenTimer                               OpenTimer2(TIMER_INT_OFF & T2_PS_1_16); \r
+#else\r
+#error Incorrect value for Pre_Scaler\r
+#endif\r
+\r
+#endif //PIC_C18\r
+\r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ * Use Callbacks to indicate output signal or something else\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+#define IRSND_USE_CALLBACK                      0       // flag: 0 = don't use callbacks, 1 = use callbacks, default is 0\r
+\r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ *                              D O   N O T   C H A N G E   T H E   F O L L O W I N G   L I N E S   !\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+#if IRSND_SUPPORT_SIEMENS_PROTOCOL == 1 && F_INTERRUPTS < 15000\r
+#warning F_INTERRUPTS too low, SIEMENS protocol disabled (should be at least 15000)\r
+#undef IRSND_SUPPORT_SIEMENS_PROTOCOL\r
+#define IRSND_SUPPORT_SIEMENS_PROTOCOL          0       // DO NOT CHANGE! F_INTERRUPTS too low!\r
+#endif\r
+\r
+#if IRSND_SUPPORT_RECS80_PROTOCOL == 1 && F_INTERRUPTS < 20000\r
+#warning F_INTERRUPTS too low, RECS80 protocol disabled (should be at least 20000)\r
+#undef IRSND_SUPPORT_RECS80_PROTOCOL\r
+#define IRSND_SUPPORT_RECS80_PROTOCOL           0       // DO NOT CHANGE! F_INTERRUPTS too low!\r
+#endif\r
+\r
+#if IRSND_SUPPORT_RECS80EXT_PROTOCOL == 1 && F_INTERRUPTS < 20000\r
+#warning F_INTERRUPTS too low, RECS80EXT protocol disabled (should be at least 20000)\r
+#undef IRSND_SUPPORT_RECS80EXT_PROTOCOL\r
+#define IRSND_SUPPORT_RECS80EXT_PROTOCOL        0       // DO NOT CHANGE! F_INTERRUPTS too low!\r
+#endif\r
+\r
+#if IRSND_SUPPORT_LEGO_PROTOCOL == 1 && F_INTERRUPTS < 20000\r
+#warning F_INTERRUPTS too low, LEGO protocol disabled (should be at least 20000)\r
+#undef IRSND_SUPPORT_LEGO_PROTOCOL\r
+#define IRSND_SUPPORT_LEGO_PROTOCOL             0       // DO NOT CHANGE! F_INTERRUPTS too low!\r
+#endif\r