/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
* irsndconfig.h\r
*\r
- * Copyright (c) 2010-2011 Frank Meyer - frank(at)fli4l.de\r
+ * DO NOT INCLUDE THIS FILE, WILL BE INCLUDED BY IRSND.H!\r
*\r
- * $Id: irsndconfig.h,v 1.27 2011/09/20 10:45:28 fm Exp $\r
+ * Copyright (c) 2010-2013 Frank Meyer - frank(at)fli4l.de\r
+ *\r
+ * $Id: irsndconfig.h,v 1.61 2014/07/10 10:38:07 fm Exp $\r
*\r
* ATMEGA88 @ 8 MHz\r
*\r
*---------------------------------------------------------------------------------------------------------------------------------------------------\r
*/\r
\r
+#ifndef _IRSNDCONFIG_H_\r
+#define _IRSNDCONFIG_H_\r
+\r
+#if !defined(_IRSND_H_)\r
+# error please include only irsnd.h, not irsndconfig.h\r
+#endif\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
+# define F_INTERRUPTS 15000 // interrupts per second\r
#endif\r
\r
/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
*/\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_SIRCS_PROTOCOL 1 // Sony SIRCS >= 10000 ~200 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
+#define IRSND_SUPPORT_KASEIKYO_PROTOCOL 1 // Kaseikyo >= 10000 ~300 bytes\r
\r
// more protocols, enable here! Enable Remarks F_INTERRUPTS Program Space\r
+#define IRSND_SUPPORT_DENON_PROTOCOL 0 // DENON, Sharp >= 10000 ~200 bytes\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 0 // IR60 (SAB2008) >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
+#define IRSND_SUPPORT_IR60_PROTOCOL 0 // IR60 (SDA2008) >= 10000 ~250 bytes\r
#define IRSND_SUPPORT_GRUNDIG_PROTOCOL 0 // 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
// 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_SPEAKER_PROTOCOL 0 // SPEAKER >= 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_RECS80_PROTOCOL 0 // RECS80 >= 15000 ~100 bytes\r
+#define IRSND_SUPPORT_RECS80EXT_PROTOCOL 0 // RECS80EXT >= 15000 ~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_ORTEK_PROTOCOL 0 // ORTEK (Hama) >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
+#define IRSND_SUPPORT_TELEFUNKEN_PROTOCOL 0 // Telefunken 1560 >= 10000 ~150 bytes\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_ROOMBA_PROTOCOL 0 // iRobot Roomba >= 10000 ~150 bytes\r
+#define IRSND_SUPPORT_RUWIDO_PROTOCOL 0 // RUWIDO, T-Home >= 15000 ~250 bytes\r
+#define IRSND_SUPPORT_A1TVBOX_PROTOCOL 0 // A1 TV BOX >= 15000 (better 20000) ~200 bytes\r
#define IRSND_SUPPORT_LEGO_PROTOCOL 0 // LEGO Power RC >= 20000 ~150 bytes\r
-\r
-\r
-/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * DO NOT CHANGE:\r
- *---------------------------------------------------------------------------------------------------------------------------------------------------\r
- */\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
+#define IRSND_SUPPORT_RCMM_PROTOCOL 0 // RCMM 12,24, or 32 >= 20000 DON'T CHANGE, NOT SUPPORTED YET!\r
+#define IRSND_SUPPORT_LGAIR_PROTOCOL 0 // LG Air Condition >= 10000 ~150 bytes.\r
+#define IRSND_SUPPORT_SAMSUNG48_PROTOCOL 0 // Samsung48 >= 10000 ~100 bytes\r
\r
/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * AVR\r
+ * AVR section:\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_OC0A = OC0A on ATmegas/ATtinys supporting OC0A, e.g. ATtiny84, ATtiny85, ATtiny87/167\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
+#if defined(ATMEL_AVR)\r
+# define IRSND_OCx IRSND_OC2B // use OC2B\r
\r
/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * PIC C18\r
+ * PIC C18 section:\r
*\r
* Change hardware pin here: IRSND_PIC_CCP1 = RC2 on PIC 18F2550/18F4550, ...\r
- * IRSND_PIC_CCP2 = RC1 on PIC 18F2550/18F4550, ...\r
+ * IRSND_PIC_CCP2 = RC1 on PIC 18F2550/18F4550, ...\r
*---------------------------------------------------------------------------------------------------------------------------------------------------\r
*/\r
-\r
-#else\r
-#define IRSND_OCx IRSND_PIC_CCP2 // Use PWMx for PIC\r
+#elif defined(PIC_C18)\r
+# define IRSND_OCx IRSND_PIC_CCP2 // Use PWMx for PIC\r
+ // change other PIC C18 specific settings:\r
+# define F_CPU 48000000UL // PIC frequency: set your 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
/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * PIC C18 - change other PIC specific settings - ignore it when using AVR\r
+ * ARM STM32 section:\r
*---------------------------------------------------------------------------------------------------------------------------------------------------\r
*/\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
+#elif defined (ARM_STM32) // use B6 as IR output on STM32\r
+# define IRSND_PORT_LETTER B\r
+# define IRSND_BIT_NUMBER 6\r
+# define IRSND_TIMER_NUMBER 4\r
+# define IRSND_TIMER_CHANNEL_NUMBER 1 // only channel 1 can be used at the moment, others won't work\r
\r
/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * Use Callbacks to indicate output signal or something else\r
+ * Other target system\r
*---------------------------------------------------------------------------------------------------------------------------------------------------\r
*/\r
-#define IRSND_USE_CALLBACK 0 // flag: 0 = don't use callbacks, 1 = use callbacks, default is 0\r
+#elif !defined (UNIX_OR_WINDOWS)\r
+# error target system not defined.\r
+#endif\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
+ * Use Callbacks to indicate output signal or something else\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
+#ifndef IRSND_USE_CALLBACK\r
+# define IRSND_USE_CALLBACK 0 // flag: 0 = don't use callbacks, 1 = use callbacks, default is 0\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
+#endif // _IRSNDCONFIG_H_\r