]>
Commit | Line | Data |
---|---|---|
4225a882 | 1 | /*---------------------------------------------------------------------------------------------------------------------------------------------------\r |
2 | * irmp.h\r | |
3 | *\r | |
7365350c | 4 | * Copyright (c) 2009-2016 Frank Meyer - frank(at)fli4l.de\r |
4225a882 | 5 | *\r |
7365350c | 6 | * $Id: irmp.h,v 1.103 2016/09/09 07:53:29 fm Exp $\r |
4225a882 | 7 | *\r |
8 | * This program is free software; you can redistribute it and/or modify\r | |
9 | * it under the terms of the GNU General Public License as published by\r | |
10 | * the Free Software Foundation; either version 2 of the License, or\r | |
11 | * (at your option) any later version.\r | |
12 | *---------------------------------------------------------------------------------------------------------------------------------------------------\r | |
13 | */\r | |
14 | \r | |
08f2dd9d | 15 | #ifndef _IRMP_H_\r |
16 | #define _IRMP_H_\r | |
4225a882 | 17 | \r |
08f2dd9d | 18 | #include "irmpsystem.h"\r |
93ba2e01 | 19 | \r |
08f2dd9d | 20 | #ifndef IRMP_USE_AS_LIB\r |
21 | # include "irmpconfig.h"\r | |
9405f84a | 22 | #endif\r |
c7a47e89 | 23 | \r |
ad4d3d41 | 24 | #if defined (__AVR_XMEGA__)\r |
25 | # define _CONCAT(a,b) a##b\r | |
26 | # define CONCAT(a,b) _CONCAT(a,b)\r | |
27 | # define IRMP_PORT_PRE CONCAT(PORT, IRMP_PORT_LETTER)\r | |
22a5040e | 28 | # define IRMP_DDR_PRE CONCAT(PORT, IRMP_PORT_LETTER)\r |
29 | # define IRMP_PIN_PRE CONCAT(PORT, IRMP_PORT_LETTER)\r | |
ad4d3d41 | 30 | # define IRMP_PORT IRMP_PORT_PRE.OUT\r |
31 | # define IRMP_DDR IRMP_DDR_PRE.DIR\r | |
32 | # define IRMP_PIN IRMP_PIN_PRE.IN\r | |
33 | # define IRMP_BIT IRMP_BIT_NUMBER\r | |
34 | # define input(x) ((x) & (1 << IRMP_BIT))\r | |
35 | \r | |
36 | #elif defined (ATMEL_AVR)\r | |
08f2dd9d | 37 | # define _CONCAT(a,b) a##b\r |
38 | # define CONCAT(a,b) _CONCAT(a,b)\r | |
39 | # define IRMP_PORT CONCAT(PORT, IRMP_PORT_LETTER)\r | |
40 | # define IRMP_DDR CONCAT(DDR, IRMP_PORT_LETTER)\r | |
41 | # define IRMP_PIN CONCAT(PIN, IRMP_PORT_LETTER)\r | |
42 | # define IRMP_BIT IRMP_BIT_NUMBER\r | |
43 | # define input(x) ((x) & (1 << IRMP_BIT))\r | |
ad4d3d41 | 44 | \r |
45 | #elif defined (PIC_C18) || defined (PIC_CCS)\r | |
08f2dd9d | 46 | # define input(x) (x)\r |
ad4d3d41 | 47 | \r |
08f2dd9d | 48 | #elif defined (ARM_STM32)\r |
49 | # define _CONCAT(a,b) a##b\r | |
50 | # define CONCAT(a,b) _CONCAT(a,b)\r | |
51 | # define IRMP_PORT CONCAT(GPIO, IRMP_PORT_LETTER)\r | |
52 | # if defined (ARM_STM32L1XX)\r | |
53 | # define IRMP_PORT_RCC CONCAT(RCC_AHBPeriph_GPIO, IRMP_PORT_LETTER)\r | |
54 | # elif defined (ARM_STM32F10X)\r | |
55 | # define IRMP_PORT_RCC CONCAT(RCC_APB2Periph_GPIO, IRMP_PORT_LETTER)\r | |
56 | # elif defined (ARM_STM32F4XX)\r | |
57 | # define IRMP_PORT_RCC CONCAT(RCC_AHB1Periph_GPIO, IRMP_PORT_LETTER)\r | |
58 | # endif\r | |
59 | # define IRMP_BIT CONCAT(GPIO_Pin_, IRMP_BIT_NUMBER)\r | |
60 | # define IRMP_PIN IRMP_PORT // for use with input(x) below\r | |
61 | # define input(x) (GPIO_ReadInputDataBit(x, IRMP_BIT))\r | |
62 | # ifndef USE_STDPERIPH_DRIVER\r | |
63 | # warning The STM32 port of IRMP uses the ST standard peripheral drivers which are not enabled in your build configuration.\r | |
64 | # endif\r | |
ad4d3d41 | 65 | \r |
a8915151 | 66 | #elif defined (LIBOPENCM3)\r |
4d08a2f7 L |
67 | # define _CONCAT(a,b) a##b\r |
68 | # define CONCAT(a,b) _CONCAT(a,b)\r | |
69 | # define IRMP_PORT CONCAT(GPIO, IRMP_PORT_LETTER)\r | |
a8915151 | 70 | # define IRMP_PORT_RCC CONCAT(RCC_GPIO, IRMP_PORT_LETTER)\r |
4d08a2f7 | 71 | \r |
a8915151 | 72 | # define IRMP_BIT CONCAT(GPIO, IRMP_BIT_NUMBER)\r |
4d08a2f7 | 73 | # define IRMP_PIN IRMP_PORT // for use with input(x) below\r |
a8915151 | 74 | # define input(x) ((GPIO_IDR(x) & IRMP_BIT) != 0)\r |
4d08a2f7 | 75 | \r |
afd1e690 | 76 | #elif defined (STELLARIS_ARM_CORTEX_M4)\r |
77 | # define _CONCAT(a,b) a##b\r | |
78 | # define CONCAT(a,b) _CONCAT(a,b)\r | |
79 | # define IRMP_PORT_PERIPH CONCAT(SYSCTL_PERIPH_GPIO, IRMP_PORT_LETTER)\r | |
80 | # define IRMP_PORT_BASE CONCAT(GPIO_PORT, CONCAT(IRMP_PORT_LETTER, _BASE))\r | |
81 | # define IRMP_PORT_PIN CONCAT(GPIO_PIN_, IRMP_BIT_NUMBER)\r | |
82 | # define IRMP_PIN IRMP_PORT_PIN\r | |
83 | # define input(x) ((uint8_t)(ROM_GPIOPinRead(IRMP_PORT_BASE, IRMP_PORT_PIN)))\r | |
84 | # define sei() IntMasterEnable()\r | |
ad4d3d41 | 85 | \r |
aa276d72 | 86 | #elif defined(__SDCC_stm8)\r |
87 | # define _CONCAT(a,b) a##b\r | |
88 | # define CONCAT(a,b) _CONCAT(a,b)\r | |
89 | # define IRMP_GPIO_STRUCT CONCAT(GPIO, IRMP_PORT_LETTER)\r | |
90 | # define IRMP_BIT IRMP_BIT_NUMBER\r | |
91 | # define input(x) ((x) & (1 << IRMP_BIT))\r | |
92 | \r | |
95b27043 | 93 | #elif defined (TEENSY_ARM_CORTEX_M4)\r |
94 | # define input(x) ((uint8_t)(digitalReadFast(x)))\r | |
95 | \r | |
96 | #elif defined(__xtensa__)\r | |
df24bb50 | 97 | # define IRMP_BIT IRMP_BIT_NUMBER\r |
98 | # define input(x) GPIO_INPUT_GET(IRMP_BIT_NUMBER)\r | |
08f2dd9d | 99 | #endif\r |
a7054daf | 100 | \r |
3d2da98a | 101 | #if IRMP_SUPPORT_TECHNICS_PROTOCOL == 1\r |
102 | # undef IRMP_SUPPORT_MATSUSHITA_PROTOCOL\r | |
103 | # define IRMP_SUPPORT_MATSUSHITA_PROTOCOL 1\r | |
104 | #endif\r | |
105 | \r | |
0834784c | 106 | #if IRMP_SUPPORT_DENON_PROTOCOL == 1 && IRMP_SUPPORT_RUWIDO_PROTOCOL == 1\r |
107 | # warning DENON protocol conflicts wih RUWIDO, please enable only one of both protocols\r | |
08f2dd9d | 108 | # warning RUWIDO protocol disabled\r |
109 | # undef IRMP_SUPPORT_RUWIDO_PROTOCOL\r | |
110 | # define IRMP_SUPPORT_RUWIDO_PROTOCOL 0\r | |
111 | #endif\r | |
b5ea7869 | 112 | \r |
95b27043 | 113 | #if IRMP_SUPPORT_KASEIKYO_PROTOCOL == 1 && IRMP_SUPPORT_PANASONIC_PROTOCOL == 1\r |
114 | # warning KASEIKYO protocol conflicts wih PANASONIC, please enable only one of both protocols\r | |
115 | # warning PANASONIC protocol disabled\r | |
116 | # undef IRMP_SUPPORT_PANASONIC_PROTOCOL\r | |
117 | # define IRMP_SUPPORT_PANASONIC_PROTOCOL 0\r | |
118 | #endif\r | |
119 | \r | |
43c535be | 120 | #if IRMP_SUPPORT_DENON_PROTOCOL == 1 && IRMP_SUPPORT_ACP24_PROTOCOL == 1\r |
121 | # warning DENON protocol conflicts wih ACP24, please enable only one of both protocols\r | |
122 | # warning ACP24 protocol disabled\r | |
123 | # undef IRMP_SUPPORT_ACP24_PROTOCOL\r | |
3d2da98a | 124 | # define IRMP_SUPPORT_ACP24_PROTOCOL 0\r |
43c535be | 125 | #endif\r |
126 | \r | |
40ca4604 | 127 | #if IRMP_SUPPORT_RC6_PROTOCOL == 1 && IRMP_SUPPORT_ROOMBA_PROTOCOL == 1\r |
128 | # warning RC6 protocol conflicts wih ROOMBA, please enable only one of both protocols\r | |
129 | # warning ROOMBA protocol disabled\r | |
130 | # undef IRMP_SUPPORT_ROOMBA_PROTOCOL\r | |
131 | # define IRMP_SUPPORT_ROOMBA_PROTOCOL 0\r | |
132 | #endif\r | |
133 | \r | |
7365350c | 134 | #if IRMP_SUPPORT_PANASONIC_PROTOCOL == 1 && IRMP_SUPPORT_MITSU_HEAVY_PROTOCOL == 1\r |
135 | # warning PANASONIC protocol conflicts wih MITSU_HEAVY, please enable only one of both protocols\r | |
136 | # warning MITSU_HEAVY protocol disabled\r | |
137 | # undef IRMP_SUPPORT_MITSU_HEAVY_PROTOCOL\r | |
138 | # define IRMP_SUPPORT_MITSU_HEAVY_PROTOCOL 0\r | |
139 | #endif\r | |
140 | \r | |
cb93f9e9 | 141 | #if IRMP_SUPPORT_RC5_PROTOCOL == 1 && IRMP_SUPPORT_ORTEK_PROTOCOL == 1\r |
142 | # warning RC5 protocol conflicts wih ORTEK, please enable only one of both protocols\r | |
143 | # warning ORTEK protocol disabled\r | |
144 | # undef IRMP_SUPPORT_ORTEK_PROTOCOL\r | |
145 | # define IRMP_SUPPORT_ORTEK_PROTOCOL 0\r | |
146 | #endif\r | |
147 | \r | |
c2b70f0b | 148 | #if IRMP_SUPPORT_RC5_PROTOCOL == 1 && IRMP_SUPPORT_S100_PROTOCOL == 1\r |
149 | # warning RC5 protocol conflicts wih S100, please enable only one of both protocols\r | |
150 | # warning S100 protocol disabled\r | |
151 | # undef IRMP_SUPPORT_S100_PROTOCOL\r | |
152 | # define IRMP_SUPPORT_S100_PROTOCOL 0\r | |
153 | #endif\r | |
154 | \r | |
155 | #if IRMP_SUPPORT_NUBERT_PROTOCOL == 1 && IRMP_SUPPORT_FAN_PROTOCOL == 1\r | |
156 | # warning NUBERT protocol conflicts wih FAN, please enable only one of both protocols\r | |
157 | # warning FAN protocol disabled\r | |
158 | # undef IRMP_SUPPORT_FAN_PROTOCOL\r | |
159 | # define IRMP_SUPPORT_FAN_PROTOCOL 0\r | |
160 | #endif\r | |
161 | \r | |
cb93f9e9 | 162 | #if IRMP_SUPPORT_FDC_PROTOCOL == 1 && IRMP_SUPPORT_ORTEK_PROTOCOL == 1\r |
163 | # warning FDC protocol conflicts wih ORTEK, please enable only one of both protocols\r | |
164 | # warning ORTEK protocol disabled\r | |
165 | # undef IRMP_SUPPORT_ORTEK_PROTOCOL\r | |
166 | # define IRMP_SUPPORT_ORTEK_PROTOCOL 0\r | |
167 | #endif\r | |
168 | \r | |
169 | #if IRMP_SUPPORT_ORTEK_PROTOCOL == 1 && IRMP_SUPPORT_NETBOX_PROTOCOL == 1\r | |
170 | # warning ORTEK protocol conflicts wih NETBOX, please enable only one of both protocols\r | |
171 | # warning NETBOX protocol disabled\r | |
172 | # undef IRMP_SUPPORT_NETBOX_PROTOCOL\r | |
173 | # define IRMP_SUPPORT_NETBOX_PROTOCOL 0\r | |
174 | #endif\r | |
175 | \r | |
08f2dd9d | 176 | #if IRMP_SUPPORT_SIEMENS_PROTOCOL == 1 && F_INTERRUPTS < 15000\r |
177 | # warning F_INTERRUPTS too low, SIEMENS protocol disabled (should be at least 15000)\r | |
178 | # undef IRMP_SUPPORT_SIEMENS_PROTOCOL\r | |
179 | # define IRMP_SUPPORT_SIEMENS_PROTOCOL 0\r | |
180 | #endif\r | |
9e16d699 | 181 | \r |
08f2dd9d | 182 | #if IRMP_SUPPORT_RUWIDO_PROTOCOL == 1 && F_INTERRUPTS < 15000\r |
183 | # warning F_INTERRUPTS too low, RUWIDO protocol disabled (should be at least 15000)\r | |
184 | # undef IRMP_SUPPORT_RUWIDO_PROTOCOL\r | |
185 | # define IRMP_SUPPORT_RUWIDO_PROTOCOL 0\r | |
186 | #endif\r | |
770a1a9d | 187 | \r |
08f2dd9d | 188 | #if IRMP_SUPPORT_RECS80_PROTOCOL == 1 && F_INTERRUPTS < 15000\r |
189 | # warning F_INTERRUPTS too low, RECS80 protocol disabled (should be at least 15000)\r | |
190 | # undef IRMP_SUPPORT_RECS80_PROTOCOL\r | |
191 | # define IRMP_SUPPORT_RECS80_PROTOCOL 0\r | |
192 | #endif\r | |
9405f84a | 193 | \r |
08f2dd9d | 194 | #if IRMP_SUPPORT_RECS80EXT_PROTOCOL == 1 && F_INTERRUPTS < 15000\r |
195 | # warning F_INTERRUPTS too low, RECS80EXT protocol disabled (should be at least 15000)\r | |
196 | # undef IRMP_SUPPORT_RECS80EXT_PROTOCOL\r | |
197 | # define IRMP_SUPPORT_RECS80EXT_PROTOCOL 0\r | |
198 | #endif\r | |
111d6191 | 199 | \r |
08f2dd9d | 200 | #if IRMP_SUPPORT_LEGO_PROTOCOL == 1 && F_INTERRUPTS < 20000\r |
201 | # warning F_INTERRUPTS too low, LEGO protocol disabled (should be at least 20000)\r | |
202 | # undef IRMP_SUPPORT_LEGO_PROTOCOL\r | |
203 | # define IRMP_SUPPORT_LEGO_PROTOCOL 0\r | |
204 | #endif\r | |
deba2a0a | 205 | \r |
956ea3ea | 206 | #if IRMP_SUPPORT_SAMSUNG48_PROTOCOL == 1 && IRMP_SUPPORT_SAMSUNG_PROTOCOL == 0\r |
207 | # warning SAMSUNG48 protocol needs also SAMSUNG protocol, SAMSUNG protocol enabled\r | |
208 | # undef IRMP_SUPPORT_SAMSUNG_PROTOCOL\r | |
209 | # define IRMP_SUPPORT_SAMSUNG_PROTOCOL 1\r | |
210 | #endif\r | |
211 | \r | |
08f2dd9d | 212 | #if IRMP_SUPPORT_JVC_PROTOCOL == 1 && IRMP_SUPPORT_NEC_PROTOCOL == 0\r |
213 | # warning JVC protocol needs also NEC protocol, NEC protocol enabled\r | |
214 | # undef IRMP_SUPPORT_NEC_PROTOCOL\r | |
215 | # define IRMP_SUPPORT_NEC_PROTOCOL 1\r | |
216 | #endif\r | |
f50e01e7 | 217 | \r |
08f2dd9d | 218 | #if IRMP_SUPPORT_NEC16_PROTOCOL == 1 && IRMP_SUPPORT_NEC_PROTOCOL == 0\r |
219 | # warning NEC16 protocol needs also NEC protocol, NEC protocol enabled\r | |
220 | # undef IRMP_SUPPORT_NEC_PROTOCOL\r | |
221 | # define IRMP_SUPPORT_NEC_PROTOCOL 1\r | |
222 | #endif\r | |
beda975f | 223 | \r |
08f2dd9d | 224 | #if IRMP_SUPPORT_NEC42_PROTOCOL == 1 && IRMP_SUPPORT_NEC_PROTOCOL == 0\r |
225 | # warning NEC42 protocol needs also NEC protocol, NEC protocol enabled\r | |
226 | # undef IRMP_SUPPORT_NEC_PROTOCOL\r | |
227 | # define IRMP_SUPPORT_NEC_PROTOCOL 1\r | |
69da6090 | 228 | #endif\r |
229 | \r | |
230 | #if IRMP_SUPPORT_LGAIR_PROTOCOL == 1 && IRMP_SUPPORT_NEC_PROTOCOL == 0\r | |
231 | # warning LGAIR protocol needs also NEC protocol, NEC protocol enabled\r | |
232 | # undef IRMP_SUPPORT_NEC_PROTOCOL\r | |
233 | # define IRMP_SUPPORT_NEC_PROTOCOL 1\r | |
08f2dd9d | 234 | #endif\r |
4225a882 | 235 | \r |
cb93f9e9 | 236 | #if IRMP_SUPPORT_RCMM_PROTOCOL == 1 && F_INTERRUPTS < 20000\r |
237 | # warning F_INTERRUPTS too low, RCMM protocol disabled (should be at least 20000)\r | |
238 | # undef IRMP_SUPPORT_RCMM_PROTOCOL\r | |
239 | # define IRMP_SUPPORT_RCMM_PROTOCOL 0\r | |
240 | #endif\r | |
241 | \r | |
08f2dd9d | 242 | #if F_INTERRUPTS > 20000\r |
243 | #error F_INTERRUPTS too high (should be not greater than 20000)\r | |
244 | #endif\r | |
4225a882 | 245 | \r |
08f2dd9d | 246 | #include "irmpprotocols.h"\r |
4225a882 | 247 | \r |
08f2dd9d | 248 | #define IRMP_FLAG_REPETITION 0x01\r |
4225a882 | 249 | \r |
95b27043 | 250 | #ifdef __cplusplus\r |
251 | extern "C"\r | |
252 | {\r | |
253 | #endif\r | |
254 | \r | |
1f54e86c | 255 | extern void irmp_init (void);\r |
061e654c | 256 | extern uint_fast8_t irmp_get_data (IRMP_DATA *);\r |
061e654c | 257 | extern uint_fast8_t irmp_ISR (void);\r |
4225a882 | 258 | \r |
1f54e86c | 259 | #if IRMP_PROTOCOL_NAMES == 1\r |
622f5f59 | 260 | extern const char * const irmp_protocol_names[IRMP_N_PROTOCOLS + 1] PROGMEM;\r |
4225a882 | 261 | #endif\r |
262 | \r | |
7644ac04 | 263 | #if IRMP_USE_CALLBACK == 1\r |
061e654c | 264 | extern void irmp_set_callback_ptr (void (*cb)(uint_fast8_t));\r |
08f2dd9d | 265 | #endif // IRMP_USE_CALLBACK == 1\r |
7644ac04 | 266 | \r |
95b27043 | 267 | #ifdef __cplusplus\r |
268 | }\r | |
269 | #endif\r | |
270 | \r | |
08f2dd9d | 271 | #endif /* _IRMP_H_ */\r |