]> cloudbase.mooo.com Git - irmp.git/blob - irsndconfig.h
Version 2.9.5: added TECHNICS protocol
[irmp.git] / irsndconfig.h
1 /*---------------------------------------------------------------------------------------------------------------------------------------------------
2 * irsndconfig.h
3 *
4 * DO NOT INCLUDE THIS FILE, WILL BE INCLUDED BY IRSND.H!
5 *
6 * Copyright (c) 2010-2015 Frank Meyer - frank(at)fli4l.de
7 *
8 * $Id: irsndconfig.h,v 1.77 2015/09/21 12:44:16 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 1 // Sony SIRCS >= 10000 ~200 bytes
44 #define IRSND_SUPPORT_NEC_PROTOCOL 1 // NEC + APPLE >= 10000 ~100 bytes
45 #define IRSND_SUPPORT_SAMSUNG_PROTOCOL 1 // Samsung + Samsung32 >= 10000 ~300 bytes
46 #define IRSND_SUPPORT_MATSUSHITA_PROTOCOL 1 // Matsushita >= 10000 ~200 bytes
47 #define IRSND_SUPPORT_KASEIKYO_PROTOCOL 1 // 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 0 // 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 0 // 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_KATHREIN_PROTOCOL 0 // Kathrein >= 10000 DON'T CHANGE, NOT SUPPORTED YET!
64 #define IRSND_SUPPORT_NUBERT_PROTOCOL 0 // NUBERT >= 10000 ~100 bytes
65 #define IRSND_SUPPORT_FAN_PROTOCOL 1 // FAN (ventilator) >= 10000 ~100 bytes
66 #define IRSND_SUPPORT_SPEAKER_PROTOCOL 0 // SPEAKER >= 10000 ~100 bytes
67 #define IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL 0 // Bang&Olufsen >= 10000 ~250 bytes
68 #define IRSND_SUPPORT_RECS80_PROTOCOL 0 // RECS80 >= 15000 ~100 bytes
69 #define IRSND_SUPPORT_RECS80EXT_PROTOCOL 0 // RECS80EXT >= 15000 ~100 bytes
70 #define IRSND_SUPPORT_THOMSON_PROTOCOL 0 // Thomson >= 10000 ~250 bytes
71 #define IRSND_SUPPORT_NIKON_PROTOCOL 0 // NIKON >= 10000 ~150 bytes
72 #define IRSND_SUPPORT_NETBOX_PROTOCOL 0 // Netbox keyboard >= 10000 DON'T CHANGE, NOT SUPPORTED YET!
73 #define IRSND_SUPPORT_ORTEK_PROTOCOL 0 // ORTEK (Hama) >= 10000 DON'T CHANGE, NOT SUPPORTED YET!
74 #define IRSND_SUPPORT_TELEFUNKEN_PROTOCOL 0 // Telefunken 1560 >= 10000 ~150 bytes
75 #define IRSND_SUPPORT_FDC_PROTOCOL 0 // FDC IR keyboard >= 10000 (better 15000) ~150 bytes
76 #define IRSND_SUPPORT_RCCAR_PROTOCOL 0 // RC CAR >= 10000 (better 15000) ~150 bytes
77 #define IRSND_SUPPORT_ROOMBA_PROTOCOL 0 // iRobot Roomba >= 10000 ~150 bytes
78 #define IRSND_SUPPORT_RUWIDO_PROTOCOL 0 // RUWIDO, T-Home >= 15000 ~250 bytes
79 #define IRSND_SUPPORT_A1TVBOX_PROTOCOL 0 // A1 TV BOX >= 15000 (better 20000) ~200 bytes
80 #define IRSND_SUPPORT_LEGO_PROTOCOL 0 // LEGO Power RC >= 20000 ~150 bytes
81 #define IRSND_SUPPORT_RCMM_PROTOCOL 0 // RCMM 12,24, or 32 >= 20000 DON'T CHANGE, NOT SUPPORTED YET!
82 #define IRSND_SUPPORT_LGAIR_PROTOCOL 0 // LG Air Condition >= 10000 ~150 bytes.
83 #define IRSND_SUPPORT_SAMSUNG48_PROTOCOL 0 // Samsung48 >= 10000 ~100 bytes
84 #define IRSND_SUPPORT_PENTAX_PROTOCOL 0 // Pentax >= 10000 ~150 bytes
85 #define IRSND_SUPPORT_S100_PROTOCOL 0 // S100 >= 10000 ~150 bytes
86 #define IRSND_SUPPORT_ACP24_PROTOCOL 0 // ACP24 >= 10000 ~150 bytes
87 #define IRSND_SUPPORT_TECHNICS_PROTOCOL 0 // TECHNICS >= 10000 ~150 bytes
88
89
90 /*---------------------------------------------------------------------------------------------------------------------------------------------------
91 * AVR XMega section:
92 *
93 * Change hardware pin here: IRSND_XMEGA_OC0A = OC0A on ATxmegas supporting OC0A, e.g. ATxmega128A1U
94 * IRSND_XMEGA_OC0B = OC0B on ATxmegas supporting OC0B, e.g. ATxmega128A1U
95 * IRSND_XMEGA_OC0C = OC0C on ATxmegas supporting OC0C, e.g. ATxmega128A1U
96 * IRSND_XMEGA_OC0D = OC0D on ATxmegas supporting OC0D, e.g. ATxmega128A1U
97 * IRSND_XMEGA_OC1A = OC1A on ATxmegas supporting OC1A, e.g. ATxmega128A1U
98 * IRSND_XMEGA_OC1B = OC1B on ATxmegas supporting OC1B, e.g. ATxmega128A1U
99 *---------------------------------------------------------------------------------------------------------------------------------------------------
100 */
101 #if defined(__AVR_XMEGA__) // XMEGA
102 # define IRSND_PORT_PRE PORTD
103 # define XMEGA_Timer TCD0
104 # define IRSND_OCx IRSND_XMEGA_OC0B // use OC0B
105
106 /*---------------------------------------------------------------------------------------------------------------------------------------------------
107 * AVR ATMega/ATTiny section:
108 *
109 * Change hardware pin here: IRSND_OC2 = OC2 on ATmegas supporting OC2, e.g. ATmega8
110 * IRSND_OC2A = OC2A on ATmegas supporting OC2A, e.g. ATmega88
111 * IRSND_OC2B = OC2B on ATmegas supporting OC2B, e.g. ATmega88
112 * IRSND_OC0 = OC0 on ATmegas supporting OC0, e.g. ATmega162
113 * IRSND_OC0A = OC0A on ATmegas/ATtinys supporting OC0A, e.g. ATtiny84, ATtiny85, ATtiny87/167
114 * IRSND_OC0B = OC0B on ATmegas/ATtinys supporting OC0B, e.g. ATtiny84, ATtiny85
115 *---------------------------------------------------------------------------------------------------------------------------------------------------
116 */
117 #elif defined(ATMEL_AVR)
118 # define IRSND_OCx IRSND_OC2B // use OC2B
119
120 /*---------------------------------------------------------------------------------------------------------------------------------------------------
121 * PIC C18 or XC8 section:
122 *
123 * Change hardware pin here: IRSND_PIC_CCP1 = RC2 on PIC 18F2550/18F4550, ...
124 * IRSND_PIC_CCP2 = RC1 on PIC 18F2550/18F4550, ...
125 *---------------------------------------------------------------------------------------------------------------------------------------------------
126 */
127 #elif defined(PIC_C18) // C18 or XC8 compiler
128 # if defined(__12F1840) // XC8 compiler
129 # define Pre_Scaler 1 // define prescaler for timer2 e.g. 1,4,16
130 # define F_CPU 32000000UL // PIC frequency: set your freq here
131 # define PIC_Scaler 2 // PIC needs /2 extra in IRSND_FREQ_32_KHZ calculation for right value
132
133 # else // C18 compiler
134 # define IRSND_OCx IRSND_PIC_CCP2 // Use PWMx for PIC
135 // change other PIC C18 specific settings:
136 # define F_CPU 48000000UL // PIC frequency: set your freq here
137 # define Pre_Scaler 4 // define prescaler for timer2 e.g. 1,4,16
138 # define PIC_Scaler 2 // PIC needs /2 extra in IRSND_FREQ_32_KHZ calculation for right value
139 # endif
140
141 /*---------------------------------------------------------------------------------------------------------------------------------------------------
142 * ARM STM32 section:
143 *---------------------------------------------------------------------------------------------------------------------------------------------------
144 */
145 #elif defined (ARM_STM32) // use B6 as IR output on STM32
146 # define IRSND_PORT_LETTER B
147 # define IRSND_BIT_NUMBER 6
148 # define IRSND_TIMER_NUMBER 4
149 # define IRSND_TIMER_CHANNEL_NUMBER 1 // only channel 1 can be used at the moment, others won't work
150
151 /*---------------------------------------------------------------------------------------------------------------------------------------------------
152 * Other target systems
153 *---------------------------------------------------------------------------------------------------------------------------------------------------
154 */
155 #elif !defined (UNIX_OR_WINDOWS)
156 # error target system not defined.
157 #endif
158
159 /*---------------------------------------------------------------------------------------------------------------------------------------------------
160 * Use Callbacks to indicate output signal or something else
161 *---------------------------------------------------------------------------------------------------------------------------------------------------
162 */
163 #ifndef IRSND_USE_CALLBACK
164 # define IRSND_USE_CALLBACK 0 // flag: 0 = don't use callbacks, 1 = use callbacks, default is 0
165 #endif
166
167 #endif // _IRSNDCONFIG_H_