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