]> cloudbase.mooo.com Git - irmp.git/blame - irmpconfig.h
Version 1.6.2: added FDC2 protocol
[irmp.git] / irmpconfig.h
CommitLineData
cb8474cc 1/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
2 * irmpconfig.h\r
3 *\r
4 * Copyright (c) 2010 Frank Meyer - frank(at)fli4l.de\r
5 *\r
eaaf80c3 6 * $Id: irmpconfig.h,v 1.13 2010/06/10 21:24:50 fm Exp $\r
cb8474cc 7 *\r
8 * ATMEGA88 @ 8 MHz\r
9 *\r
10 * This program is free software; you can redistribute it and/or modify\r
11 * it under the terms of the GNU General Public License as published by\r
12 * the Free Software Foundation; either version 2 of the License, or\r
13 * (at your option) any later version.\r
14 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
15 */\r
16\r
17#ifndef _IRMPCONFIG_H_\r
18#define _IRMPCONFIG_H_\r
19\r
20/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
21 * Change F_INTERRUPTS if you change the number of interrupts per second, F_INTERRUPTS should be in the range from 10000 to 15000\r
22 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
23 */\r
b5ea7869 24#ifndef F_INTERRUPTS\r
879b06c2 25#define F_INTERRUPTS 10000 // interrupts per second, min: 10000, max: 15000\r
b5ea7869 26#endif\r
cb8474cc 27\r
28/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
29 * Change settings from 1 to 0 if you want to disable one or more decoders.\r
30 * This saves program space.\r
31 * 1 enable decoder\r
32 * 0 disable decoder\r
33 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
34 */\r
b5ea7869 35#define IRMP_SUPPORT_SIRCS_PROTOCOL 1 // flag: support SIRCS uses ~100 bytes\r
36#define IRMP_SUPPORT_NEC_PROTOCOL 1 // flag: support NEC + APPLE uses ~250 bytes\r
37#define IRMP_SUPPORT_SAMSUNG_PROTOCOL 1 // flag: support Samsung + Samsung32 uses ~250 bytes\r
38#define IRMP_SUPPORT_MATSUSHITA_PROTOCOL 1 // flag: support Matsushita uses ~50 bytes\r
39#define IRMP_SUPPORT_KASEIKYO_PROTOCOL 1 // flag: support Kaseikyo uses ~50 bytes\r
40#define IRMP_SUPPORT_RECS80_PROTOCOL 1 // flag: support RECS80 uses ~50 bytes\r
41#define IRMP_SUPPORT_RC5_PROTOCOL 1 // flag: support RC5 uses ~250 bytes\r
42#define IRMP_SUPPORT_DENON_PROTOCOL 1 // flag: support DENON uses ~250 bytes\r
43#define IRMP_SUPPORT_RC6_PROTOCOL 1 // flag: support RC6 uses ~200 bytes\r
44#define IRMP_SUPPORT_RECS80EXT_PROTOCOL 1 // flag: support RECS80EXT uses ~50 bytes\r
45#define IRMP_SUPPORT_NUBERT_PROTOCOL 1 // flag: support NUBERT uses ~50 bytes\r
46#define IRMP_SUPPORT_BANG_OLUFSEN_PROTOCOL 1 // flag: support Bang & Olufsen uses ~200 bytes\r
47#define IRMP_SUPPORT_GRUNDIG_PROTOCOL 1 // flag: support Grundig uses ~150 bytes\r
48#define IRMP_SUPPORT_NOKIA_PROTOCOL 1 // flag: support Nokia uses ~150 bytes\r
49\r
50/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
51 * THE FOLLOWING DECODERS WORK ONLY FOR F_INTERRUPTS > 14500!\r
52 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
53 */\r
54#if F_INTERRUPTS >= 14500\r
55#define IRMP_SUPPORT_SIEMENS_PROTOCOL 1 // flag: support Siemens Gigaset uses ~150 bytes\r
eaaf80c3 56#define IRMP_SUPPORT_FDC1_PROTOCOL 1 // flag: support FDC1 keyboard uses ~150 bytes\r
57#define IRMP_SUPPORT_FDC2_PROTOCOL 1 // flag: support FDC2 keyboard uses ~150 bytes\r
b5ea7869 58#else\r
59#define IRMP_SUPPORT_SIEMENS_PROTOCOL 0 // DO NOT CHANGE! F_INTERRUPTS too low!\r
eaaf80c3 60#define IRMP_SUPPORT_FDC1_PROTOCOL 0 // DO NOT CHANGE! F_INTERRUPTS too low!\r
61#define IRMP_SUPPORT_FDC2_PROTOCOL 0 // DO NOT CHANGE! F_INTERRUPTS too low!\r
b5ea7869 62#endif\r
cb8474cc 63\r
02dbaeff 64\r
65#if IRMP_SUPPORT_FDC2_PROTOCOL == 1 && IRMP_SUPPORT_RC5_PROTOCOL == 1\r
66#error Protocols RC5 and FDC2 may not be enabled both at the same time. Please disable one of them in irmpconfig.h.\r
67#endif\r
68\r
cb8474cc 69/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
70 * Change hardware pin here:\r
71 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
72 */\r
73#ifdef PIC_CCS_COMPILER // PIC CCS Compiler:\r
74\r
75#define IRMP_PIN PIN_B4 // use PB4 as IR input on PIC\r
76\r
77#else // AVR:\r
78\r
79#define IRMP_PORT PORTB\r
80#define IRMP_DDR DDRB\r
81#define IRMP_PIN PINB\r
82#define IRMP_BIT 6 // use PB6 as IR input on AVR\r
83\r
84#define input(x) ((x) & (1 << IRMP_BIT))\r
85#endif\r
86\r
87/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
88 * Set IRMP_LOGGING to 1 if want to log data to UART with 9600Bd\r
89 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
90 */\r
879b06c2 91#ifndef IRMP_LOGGING\r
92#define IRMP_LOGGING 0 // 1: log IR signal (scan), 0: do not (default)\r
93#endif\r
cb8474cc 94\r
95#endif /* _WC_IRMPCONFIG_H_ */\r