]> cloudbase.mooo.com Git - irmp.git/blobdiff - irsndconfig.h
Version 1.7.0: stable release
[irmp.git] / irsndconfig.h
index 597a1a9eb014068cc687bab004a44d417a4f3c13..56317bb100c3566a0e430c502e32571d283f441a 100644 (file)
@@ -3,7 +3,7 @@
  *\r
  * Copyright (c) 2010 Frank Meyer - frank(at)fli4l.de\r
  *\r
- * $Id$\r
+ * $Id: irsndconfig.h,v 1.8 2010/06/15 15:47:21 fm Exp $\r
  *\r
  * ATMEGA88 @ 8 MHz\r
  *\r
  *---------------------------------------------------------------------------------------------------------------------------------------------------\r
  */\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
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+#ifndef F_INTERRUPTS\r
+#define F_INTERRUPTS                            10000   // 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
 #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_RC5_PROTOCOL              1       // flag: support RC5                    uses ~150 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
-\r
+#define IRSND_SUPPORT_GRUNDIG_PROTOCOL          1       // flag: support Grundig                uses ~300 bytes\r
+#define IRSND_SUPPORT_NOKIA_PROTOCOL            1       // flag: support Nokia                  uses ~400 bytes\r
+#define IRSND_SUPPORT_FDC_PROTOCOL              1       // flag: support FDC infrared keyboard  uses ~150 bytes\r
+#define IRSND_SUPPORT_RCCAR_PROTOCOL            1       // flag: support RC CAR                 uses ~150 bytes\r
 \r
 /*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * Change hardware pin here:\r
+ * THE FOLLOWING ENCODERS WORK ONLY FOR F_INTERRUPTS > 14500!\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
+#if F_INTERRUPTS >= 14500\r
+#define IRSND_SUPPORT_SIEMENS_PROTOCOL          1       // flag: support Siemens, e.g. Gigaset  uses ~150 bytes\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_SUPPORT_SIEMENS_PROTOCOL          0       // DO NOT CHANGE! F_INTERRUPTS too low!\r
+#endif\r
+\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
+ * Change hardware pin here:\r
  *---------------------------------------------------------------------------------------------------------------------------------------------------\r
  */\r
-#define F_INTERRUPTS                            10000   // interrupts per second\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
+#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