]> cloudbase.mooo.com Git - irmp.git/blame - irsndconfig.h
Version 3.0.7 - added SAMSUNGAH protocol, improved some code for ESP8266
[irmp.git] / irsndconfig.h
CommitLineData
46dd89b7 1/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
2 * irsndconfig.h\r
3 *\r
08f2dd9d 4 * DO NOT INCLUDE THIS FILE, WILL BE INCLUDED BY IRSND.H!\r
5 *\r
7365350c 6 * Copyright (c) 2010-2016 Frank Meyer - frank(at)fli4l.de\r
46dd89b7 7 *\r
30d1689d 8 * $Id: irsndconfig.h,v 1.89 2016/12/19 09:01:41 fm Exp $\r
46dd89b7 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
08f2dd9d 17#ifndef _IRSNDCONFIG_H_\r
18#define _IRSNDCONFIG_H_\r
19\r
20#if !defined(_IRSND_H_)\r
21# error please include only irsnd.h, not irsndconfig.h\r
22#endif\r
23\r
30d1689d 24// #define IRSND_DEBUG 1 // activate debugging\r
7fe8188d 25\r
b5ea7869 26/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
9c86ff1a 27 * F_INTERRUPTS: number of interrupts per second, should be in the range from 10000 to 20000, typically 15000\r
b5ea7869 28 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
29 */\r
30#ifndef F_INTERRUPTS\r
08f2dd9d 31# define F_INTERRUPTS 15000 // interrupts per second\r
b5ea7869 32#endif\r
33\r
46dd89b7 34/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
35 * Change settings from 1 to 0 if you want to disable one or more encoders.\r
36 * This saves program space.\r
37 * 1 enable decoder\r
38 * 0 disable decoder\r
39 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
40 */\r
f50e01e7 41\r
42// typical protocols, disable here! Enable Remarks F_INTERRUPTS Program Space\r
08f2dd9d 43#define IRSND_SUPPORT_SIRCS_PROTOCOL 1 // Sony SIRCS >= 10000 ~200 bytes\r
f50e01e7 44#define IRSND_SUPPORT_NEC_PROTOCOL 1 // NEC + APPLE >= 10000 ~100 bytes\r
45#define IRSND_SUPPORT_SAMSUNG_PROTOCOL 1 // Samsung + Samsung32 >= 10000 ~300 bytes\r
46#define IRSND_SUPPORT_MATSUSHITA_PROTOCOL 1 // Matsushita >= 10000 ~200 bytes\r
08f2dd9d 47#define IRSND_SUPPORT_KASEIKYO_PROTOCOL 1 // Kaseikyo >= 10000 ~300 bytes\r
f50e01e7 48\r
49// more protocols, enable here! Enable Remarks F_INTERRUPTS Program Space\r
03148c47 50#define IRSND_SUPPORT_DENON_PROTOCOL 0 // DENON, Sharp >= 10000 ~200 bytes\r
30d1689d 51#define IRSND_SUPPORT_RC5_PROTOCOL 1 // RC5 >= 10000 ~150 bytes\r
f50e01e7 52#define IRSND_SUPPORT_RC6_PROTOCOL 0 // RC6 >= 10000 ~250 bytes\r
53#define IRSND_SUPPORT_RC6A_PROTOCOL 0 // RC6A >= 10000 ~250 bytes\r
54#define IRSND_SUPPORT_JVC_PROTOCOL 0 // JVC >= 10000 ~150 bytes\r
7644ac04 55#define IRSND_SUPPORT_NEC16_PROTOCOL 0 // NEC16 >= 10000 ~150 bytes\r
56#define IRSND_SUPPORT_NEC42_PROTOCOL 0 // NEC42 >= 10000 ~150 bytes\r
08f2dd9d 57#define IRSND_SUPPORT_IR60_PROTOCOL 0 // IR60 (SDA2008) >= 10000 ~250 bytes\r
58#define IRSND_SUPPORT_GRUNDIG_PROTOCOL 0 // Grundig >= 10000 ~300 bytes\r
f50e01e7 59#define IRSND_SUPPORT_SIEMENS_PROTOCOL 0 // Siemens, Gigaset >= 15000 ~150 bytes\r
03148c47 60#define IRSND_SUPPORT_NOKIA_PROTOCOL 0 // Nokia >= 10000 ~400 bytes\r
f50e01e7 61\r
62// exotic protocols, enable here! Enable Remarks F_INTERRUPTS Program Space\r
df24bb50 63#define IRSND_SUPPORT_BOSE_PROTOCOL 0 // BOSE >= 10000 ~100 bytes\r
f50e01e7 64#define IRSND_SUPPORT_KATHREIN_PROTOCOL 0 // Kathrein >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
65#define IRSND_SUPPORT_NUBERT_PROTOCOL 0 // NUBERT >= 10000 ~100 bytes\r
11ef7234 66#define IRSND_SUPPORT_FAN_PROTOCOL 0 // FAN (ventilator) >= 10000 ~100 bytes\r
15dd9c32 67#define IRSND_SUPPORT_SPEAKER_PROTOCOL 0 // SPEAKER >= 10000 ~100 bytes\r
f50e01e7 68#define IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL 0 // Bang&Olufsen >= 10000 ~250 bytes\r
e664a9f3 69#define IRSND_SUPPORT_RECS80_PROTOCOL 0 // RECS80 >= 15000 ~100 bytes\r
70#define IRSND_SUPPORT_RECS80EXT_PROTOCOL 0 // RECS80EXT >= 15000 ~100 bytes\r
7644ac04 71#define IRSND_SUPPORT_THOMSON_PROTOCOL 0 // Thomson >= 10000 ~250 bytes\r
f50e01e7 72#define IRSND_SUPPORT_NIKON_PROTOCOL 0 // NIKON >= 10000 ~150 bytes\r
73#define IRSND_SUPPORT_NETBOX_PROTOCOL 0 // Netbox keyboard >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
9c07687e 74#define IRSND_SUPPORT_ORTEK_PROTOCOL 0 // ORTEK (Hama) >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
75#define IRSND_SUPPORT_TELEFUNKEN_PROTOCOL 0 // Telefunken 1560 >= 10000 ~150 bytes\r
f50e01e7 76#define IRSND_SUPPORT_FDC_PROTOCOL 0 // FDC IR keyboard >= 10000 (better 15000) ~150 bytes\r
77#define IRSND_SUPPORT_RCCAR_PROTOCOL 0 // RC CAR >= 10000 (better 15000) ~150 bytes\r
c9b6916a 78#define IRSND_SUPPORT_ROOMBA_PROTOCOL 0 // iRobot Roomba >= 10000 ~150 bytes\r
03148c47 79#define IRSND_SUPPORT_RUWIDO_PROTOCOL 0 // RUWIDO, T-Home >= 15000 ~250 bytes\r
fa09ce10 80#define IRSND_SUPPORT_A1TVBOX_PROTOCOL 0 // A1 TV BOX >= 15000 (better 20000) ~200 bytes\r
f50e01e7 81#define IRSND_SUPPORT_LEGO_PROTOCOL 0 // LEGO Power RC >= 20000 ~150 bytes\r
c1dfa01f 82#define IRSND_SUPPORT_RCMM_PROTOCOL 0 // RCMM 12,24, or 32 >= 20000 DON'T CHANGE, NOT SUPPORTED YET!\r
83#define IRSND_SUPPORT_LGAIR_PROTOCOL 0 // LG Air Condition >= 10000 ~150 bytes.\r
ac8504f8 84#define IRSND_SUPPORT_SAMSUNG48_PROTOCOL 0 // Samsung48 >= 10000 ~100 bytes\r
003c1008 85#define IRSND_SUPPORT_PENTAX_PROTOCOL 0 // Pentax >= 10000 ~150 bytes\r
c2b70f0b 86#define IRSND_SUPPORT_S100_PROTOCOL 0 // S100 >= 10000 ~150 bytes\r
e8238947 87#define IRSND_SUPPORT_ACP24_PROTOCOL 0 // ACP24 >= 10000 ~150 bytes\r
95b27043 88#define IRSND_SUPPORT_TECHNICS_PROTOCOL 0 // TECHNICS >= 10000 DON'T CHANGE, NOT SUPPORTED YET!\r
89#define IRSND_SUPPORT_PANASONIC_PROTOCOL 0 // PANASONIC Beamer >= 10000 ~150 bytes\r
7365350c 90#define IRSND_SUPPORT_MITSU_HEAVY_PROTOCOL 0 // Mitsubishi-Heavy Aircondition, similar Timing to Panasonic beamer\r
770a1a9d 91\r
ad4d3d41 92\r
93/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
94 * AVR XMega section:\r
95 *\r
96 * Change hardware pin here: IRSND_XMEGA_OC0A = OC0A on ATxmegas supporting OC0A, e.g. ATxmega128A1U\r
97 * IRSND_XMEGA_OC0B = OC0B on ATxmegas supporting OC0B, e.g. ATxmega128A1U\r
98 * IRSND_XMEGA_OC0C = OC0C on ATxmegas supporting OC0C, e.g. ATxmega128A1U\r
99 * IRSND_XMEGA_OC0D = OC0D on ATxmegas supporting OC0D, e.g. ATxmega128A1U\r
22a5040e 100 * IRSND_XMEGA_OC1A = OC1A on ATxmegas supporting OC1A, e.g. ATxmega128A1U\r
101 * IRSND_XMEGA_OC1B = OC1B on ATxmegas supporting OC1B, e.g. ATxmega128A1U\r
ad4d3d41 102 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
103 */\r
104#if defined(__AVR_XMEGA__) // XMEGA\r
30d1689d 105# define IRSND_PORT_PRE PORTD\r
ad4d3d41 106# define XMEGA_Timer TCD0\r
107# define IRSND_OCx IRSND_XMEGA_OC0B // use OC0B\r
108\r
1f54e86c 109/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
ad4d3d41 110 * AVR ATMega/ATTiny section:\r
9c86ff1a 111 *\r
1f54e86c 112 * Change hardware pin here: IRSND_OC2 = OC2 on ATmegas supporting OC2, e.g. ATmega8\r
113 * IRSND_OC2A = OC2A on ATmegas supporting OC2A, e.g. ATmega88\r
114 * IRSND_OC2B = OC2B on ATmegas supporting OC2B, e.g. ATmega88\r
115 * IRSND_OC0 = OC0 on ATmegas supporting OC0, e.g. ATmega162\r
21a4e0ee 116 * IRSND_OC0A = OC0A on ATmegas/ATtinys supporting OC0A, e.g. ATtiny84, ATtiny85, ATtiny87/167\r
7644ac04 117 * IRSND_OC0B = OC0B on ATmegas/ATtinys supporting OC0B, e.g. ATtiny84, ATtiny85\r
1f54e86c 118 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
119 */\r
ad4d3d41 120#elif defined(ATMEL_AVR)\r
08f2dd9d 121# define IRSND_OCx IRSND_OC2B // use OC2B\r
f2906202 122\r
9c86ff1a 123/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
7fe8188d 124 * PIC C18 or XC8 section:\r
9c86ff1a 125 *\r
126 * Change hardware pin here: IRSND_PIC_CCP1 = RC2 on PIC 18F2550/18F4550, ...\r
08f2dd9d 127 * IRSND_PIC_CCP2 = RC1 on PIC 18F2550/18F4550, ...\r
9c86ff1a 128 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
129 */\r
7fe8188d 130#elif defined(PIC_C18) // C18 or XC8 compiler\r
ad4d3d41 131# if defined(__12F1840) // XC8 compiler\r
132# define Pre_Scaler 1 // define prescaler for timer2 e.g. 1,4,16\r
133# define F_CPU 32000000UL // PIC frequency: set your freq here\r
134# define PIC_Scaler 2 // PIC needs /2 extra in IRSND_FREQ_32_KHZ calculation for right value\r
7fe8188d 135\r
ad4d3d41 136# else // C18 compiler\r
137# define IRSND_OCx IRSND_PIC_CCP2 // Use PWMx for PIC\r
df24bb50 138 // change other PIC C18 specific settings:\r
ad4d3d41 139# define F_CPU 48000000UL // PIC frequency: set your freq here\r
140# define Pre_Scaler 4 // define prescaler for timer2 e.g. 1,4,16\r
141# define PIC_Scaler 2 // PIC needs /2 extra in IRSND_FREQ_32_KHZ calculation for right value\r
142# endif\r
9c86ff1a 143\r
144/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
08f2dd9d 145 * ARM STM32 section:\r
9c86ff1a 146 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
147 */\r
c6a60200 148#elif defined (ARM_STM32) // use B6 as IR output on STM32\r
149# define IRSND_PORT_LETTER B\r
08f2dd9d 150# define IRSND_BIT_NUMBER 6\r
c6a60200 151# define IRSND_TIMER_NUMBER 4\r
acd29fb9 152# define IRSND_TIMER_CHANNEL_NUMBER 1 // only channel 1 can be used at the moment, others won't work\r
9c86ff1a 153\r
95b27043 154/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
155 * Teensy 3.x with teensyduino gcc compiler\r
156 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
157 */\r
158#elif defined (TEENSY_ARM_CORTEX_M4)\r
159# define IRSND_PIN 5 // choose an arduino pin with PWM function!\r
160\r
f50e01e7 161/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
ad4d3d41 162 * Other target systems\r
f50e01e7 163 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
164 */\r
08f2dd9d 165#elif !defined (UNIX_OR_WINDOWS)\r
166# error target system not defined.\r
167#endif\r
f2906202 168\r
30d1689d 169/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
170 * ESP8266 (Arduino, see IRSEND.ino)\r
171 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
172 */\r
173#elif defined (__xtensa__)\r
174# define IRSND_PIN 0 // choose an arduino pin with PWM function!\r
175\r
f50e01e7 176/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
08f2dd9d 177 * Use Callbacks to indicate output signal or something else\r
f50e01e7 178 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
179 */\r
08f2dd9d 180#ifndef IRSND_USE_CALLBACK\r
181# define IRSND_USE_CALLBACK 0 // flag: 0 = don't use callbacks, 1 = use callbacks, default is 0\r
f50e01e7 182#endif\r
183\r
08f2dd9d 184#endif // _IRSNDCONFIG_H_\r