]> cloudbase.mooo.com Git - irmp.git/blame - irsnd.c
version 2.0.0-pre7: added support for ATtiny84, added ISR in main.c, corrected timer1...
[irmp.git] / irsnd.c
CommitLineData
4225a882 1/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
2 * @file irsnd.c\r
3 *\r
f50e01e7 4 * Copyright (c) 2010-2011 Frank Meyer - frank(at)fli4l.de\r
4225a882 5 *\r
7644ac04 6 * Supported mikrocontrollers:\r
7 *\r
476267f4 8 * ATtiny45, ATtiny85\r
9 * ATtiny84\r
7644ac04 10 * ATmega8, ATmega16, ATmega32\r
11 * ATmega162\r
12 * ATmega164, ATmega324, ATmega644, ATmega644P, ATmega1284\r
13 * ATmega88, ATmega88P, ATmega168, ATmega168P, ATmega328P\r
14 *\r
15 * $Id: irsnd.c,v 1.40 2011/09/09 11:59:40 fm Exp $\r
5481e9cd 16 *\r
4225a882 17 * This program is free software; you can redistribute it and/or modify\r
18 * it under the terms of the GNU General Public License as published by\r
19 * the Free Software Foundation; either version 2 of the License, or\r
20 * (at your option) any later version.\r
21 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
22 */\r
23\r
24#ifdef unix // test/debug on linux/unix\r
25#include <stdio.h>\r
26#include <unistd.h>\r
27#include <stdlib.h>\r
28#include <string.h>\r
29#include <inttypes.h>\r
30\r
31#define DEBUG\r
32#define F_CPU 8000000L\r
33\r
34#else // not unix:\r
35\r
36#ifdef WIN32 // test/debug on windows\r
37#include <stdio.h>\r
c7a47e89 38#include <stdlib.h>\r
39#include <string.h>\r
40\r
4225a882 41#define F_CPU 8000000L\r
31c1f035 42typedef unsigned char uint8_t;\r
43typedef unsigned short uint16_t;\r
4225a882 44#define DEBUG\r
45\r
46#else\r
47\r
48#ifdef CODEVISION\r
49 #define COM2A0 6\r
50 #define WGM21 1\r
51 #define CS20 0\r
52#else\r
53 #include <inttypes.h>\r
54 #include <avr/io.h>\r
55 #include <util/delay.h>\r
56 #include <avr/pgmspace.h>\r
57#endif // CODEVISION\r
58\r
59#endif // WIN32\r
60#endif // unix\r
61\r
62#include "irmp.h"\r
46dd89b7 63#include "irsndconfig.h"\r
4225a882 64#include "irsnd.h"\r
65\r
f50e01e7 66/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
1f54e86c 67 * ATtiny pin definition of OC0A / OC0B\r
68 * ATmega pin definition of OC2 / OC2A / OC2B / OC0 / OC0A / OC0B\r
f50e01e7 69 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
70 */\r
1f54e86c 71/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
72 * ATtiny pin definition of OC0A / OC0B\r
73 * ATmega pin definition of OC2 / OC2A / OC2B / OC0 / OC0A / OC0B\r
74 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
75 */\r
476267f4 76#if defined (__AVR_ATtiny84__) // ATtiny84 uses OC0A = PB2 or OC0B = PA7\r
7644ac04 77#if IRSND_OCx == IRSND_OC0A // OC0A\r
78#define IRSND_PORT PORTB // port B\r
79#define IRSND_DDR DDRB // ddr B\r
80#define IRSND_BIT 2 // OC0A\r
81#elif IRSND_OCx == IRSND_OC0B // OC0B\r
82#define IRSND_PORT PORTA // port A\r
83#define IRSND_DDR DDRA // ddr A\r
84#define IRSND_BIT 7 // OC0B\r
85#else\r
86#error Wrong value for IRSND_OCx, choose IRSND_OC0A or IRSND_OC0B in irsndconfig.h\r
87#endif // IRSND_OCx\r
88\r
476267f4 89#elif defined (__AVR_ATtiny45__) || defined (__AVR_ATtiny85__) // ATtiny45/85 uses OC0A = PB0 or OC0B = PB1\r
1f54e86c 90#if IRSND_OCx == IRSND_OC0A // OC0A\r
f50e01e7 91#define IRSND_PORT PORTB // port B\r
92#define IRSND_DDR DDRB // ddr B\r
1f54e86c 93#define IRSND_BIT 0 // OC0A\r
94#elif IRSND_OCx == IRSND_OC0B // OC0B\r
95#define IRSND_PORT PORTB // port B\r
96#define IRSND_DDR DDRB // ddr B\r
97#define IRSND_BIT 1 // OC0B\r
98#else\r
99#error Wrong value for IRSND_OCx, choose IRSND_OC0A or IRSND_OC0B in irsndconfig.h\r
100#endif // IRSND_OCx\r
101\r
102#elif defined (__AVR_ATmega8__) // ATmega8 uses only OC2 = PB3\r
103#if IRSND_OCx == IRSND_OC2 // OC0A\r
104#define IRSND_PORT PORTB // port B\r
105#define IRSND_DDR DDRB // ddr B\r
106#define IRSND_BIT 3 // OC0A\r
107#else\r
108#error Wrong value for IRSND_OCx, choose IRSND_OC2 in irsndconfig.h\r
109#endif // IRSND_OCx\r
110\r
f50e01e7 111\r
112#elif defined (__AVR_ATmega16__) \\r
113 || defined (__AVR_ATmega32__) // ATmega16|32 uses OC2 = PD7\r
1f54e86c 114#if IRSND_OCx == IRSND_OC2 // OC2\r
f50e01e7 115#define IRSND_PORT PORTD // port D\r
116#define IRSND_DDR DDRD // ddr D\r
117#define IRSND_BIT 7 // OC2\r
1f54e86c 118#else\r
119#error Wrong value for IRSND_OCx, choose IRSND_OC2 in irsndconfig.h\r
120#endif // IRSND_OCx\r
f50e01e7 121\r
1f54e86c 122#elif defined (__AVR_ATmega162__) // ATmega162 uses OC2 = PB1 or OC0 = PB0\r
123#if IRSND_OCx == IRSND_OC2 // OC2\r
f50e01e7 124#define IRSND_PORT PORTB // port B\r
125#define IRSND_DDR DDRB // ddr B\r
126#define IRSND_BIT 1 // OC2\r
1f54e86c 127#elif IRSND_OCx == IRSND_OC0 // OC0\r
128#define IRSND_PORT PORTB // port B\r
129#define IRSND_DDR DDRB // ddr B\r
130#define IRSND_BIT 0 // OC0\r
131#else\r
132#error Wrong value for IRSND_OCx, choose IRSND_OC2 or IRSND_OC0 in irsndconfig.h\r
133#endif // IRSND_OCx\r
f50e01e7 134\r
135#elif defined (__AVR_ATmega164__) \\r
136 || defined (__AVR_ATmega324__) \\r
137 || defined (__AVR_ATmega644__) \\r
138 || defined (__AVR_ATmega644P__) \\r
1f54e86c 139 || defined (__AVR_ATmega1284__) // ATmega164|324|644|644P|1284 uses OC2A = PD7 or OC2B = PD6 or OC0A = PB3 or OC0B = PB4\r
140#if IRSND_OCx == IRSND_OC2A // OC2A\r
f50e01e7 141#define IRSND_PORT PORTD // port D\r
142#define IRSND_DDR DDRD // ddr D\r
143#define IRSND_BIT 7 // OC2A\r
1f54e86c 144#elif IRSND_OCx == IRSND_OC2B // OC2B\r
f50e01e7 145#define IRSND_PORT PORTD // port D\r
146#define IRSND_DDR DDRD // ddr D\r
147#define IRSND_BIT 6 // OC2B\r
1f54e86c 148#elif IRSND_OCx == IRSND_OC0A // OC0A\r
149#define IRSND_PORT PORTB // port B\r
150#define IRSND_DDR DDRB // ddr B\r
151#define IRSND_BIT 3 // OC0A\r
152#elif IRSND_OCx == IRSND_OC0B // OC0B\r
153#define IRSND_PORT PORTB // port B\r
154#define IRSND_DDR DDRB // ddr B\r
155#define IRSND_BIT 4 // OC0B\r
f50e01e7 156#else\r
1f54e86c 157#error Wrong value for IRSND_OCx, choose IRSND_OC2A, IRSND_OC2B, IRSND_OC0A, or IRSND_OC0B in irsndconfig.h\r
158#endif // IRSND_OCx\r
f50e01e7 159\r
160#elif defined (__AVR_ATmega48__) \\r
161 || defined (__AVR_ATmega88__) \\r
7644ac04 162 || defined (__AVR_ATmega88P__) \\r
f50e01e7 163 || defined (__AVR_ATmega168__) \\r
1f54e86c 164 || defined (__AVR_ATmega168P__) \\r
7644ac04 165 || defined (__AVR_ATmega328P__) // ATmega48|88|168|168|328 uses OC2A = PB3 or OC2B = PD3 or OC0A = PD6 or OC0B = PD5\r
1f54e86c 166#if IRSND_OCx == IRSND_OC2A // OC2A\r
f50e01e7 167#define IRSND_PORT PORTB // port B\r
168#define IRSND_DDR DDRB // ddr B\r
169#define IRSND_BIT 3 // OC2A\r
1f54e86c 170#elif IRSND_OCx == IRSND_OC2B // OC2B\r
f50e01e7 171#define IRSND_PORT PORTD // port D\r
172#define IRSND_DDR DDRD // ddr D\r
173#define IRSND_BIT 3 // OC2B\r
1f54e86c 174#elif IRSND_OCx == IRSND_OC0A // OC0A\r
175#define IRSND_PORT PORTB // port B\r
176#define IRSND_DDR DDRB // ddr B\r
177#define IRSND_BIT 6 // OC0A\r
178#elif IRSND_OCx == IRSND_OC0B // OC0B\r
179#define IRSND_PORT PORTD // port D\r
180#define IRSND_DDR DDRD // ddr D\r
181#define IRSND_BIT 5 // OC0B\r
f50e01e7 182#else\r
1f54e86c 183#error Wrong value for IRSND_OCx, choose IRSND_OC2A, IRSND_OC2B, IRSND_OC0A, or IRSND_OC0B in irsndconfig.h\r
184#endif // IRSND_OCx\r
f50e01e7 185\r
186#else\r
187#if !defined (unix) && !defined (WIN32)\r
1f54e86c 188#error mikrocontroller not defined, please fill in definitions here.\r
f50e01e7 189#endif // unix, WIN32\r
190#endif // __AVR...\r
191\r
9405f84a 192#if IRSND_SUPPORT_NIKON_PROTOCOL == 1\r
193typedef uint16_t IRSND_PAUSE_LEN;\r
194#else\r
195typedef uint8_t IRSND_PAUSE_LEN;\r
196#endif\r
197\r
f50e01e7 198/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
199 * IR timings\r
200 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
201 */\r
4225a882 202#define SIRCS_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * SIRCS_START_BIT_PULSE_TIME + 0.5)\r
203#define SIRCS_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * SIRCS_START_BIT_PAUSE_TIME + 0.5)\r
204#define SIRCS_1_PULSE_LEN (uint8_t)(F_INTERRUPTS * SIRCS_1_PULSE_TIME + 0.5)\r
205#define SIRCS_0_PULSE_LEN (uint8_t)(F_INTERRUPTS * SIRCS_0_PULSE_TIME + 0.5)\r
206#define SIRCS_PAUSE_LEN (uint8_t)(F_INTERRUPTS * SIRCS_PAUSE_TIME + 0.5)\r
a7054daf 207#define SIRCS_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * SIRCS_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
208#define SIRCS_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * SIRCS_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 209\r
210#define NEC_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * NEC_START_BIT_PULSE_TIME + 0.5)\r
211#define NEC_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NEC_START_BIT_PAUSE_TIME + 0.5)\r
a7054daf 212#define NEC_REPEAT_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NEC_REPEAT_START_BIT_PAUSE_TIME + 0.5)\r
4225a882 213#define NEC_PULSE_LEN (uint8_t)(F_INTERRUPTS * NEC_PULSE_TIME + 0.5)\r
214#define NEC_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NEC_1_PAUSE_TIME + 0.5)\r
215#define NEC_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NEC_0_PAUSE_TIME + 0.5)\r
a7054daf 216#define NEC_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * NEC_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 217\r
218#define SAMSUNG_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * SAMSUNG_START_BIT_PULSE_TIME + 0.5)\r
219#define SAMSUNG_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * SAMSUNG_START_BIT_PAUSE_TIME + 0.5)\r
220#define SAMSUNG_PULSE_LEN (uint8_t)(F_INTERRUPTS * SAMSUNG_PULSE_TIME + 0.5)\r
221#define SAMSUNG_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * SAMSUNG_1_PAUSE_TIME + 0.5)\r
222#define SAMSUNG_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * SAMSUNG_0_PAUSE_TIME + 0.5)\r
a7054daf 223#define SAMSUNG_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * SAMSUNG_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 224\r
a7054daf 225#define SAMSUNG32_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * SAMSUNG32_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
226#define SAMSUNG32_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * SAMSUNG32_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
5b437ff6 227\r
4225a882 228#define MATSUSHITA_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * MATSUSHITA_START_BIT_PULSE_TIME + 0.5)\r
229#define MATSUSHITA_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * MATSUSHITA_START_BIT_PAUSE_TIME + 0.5)\r
230#define MATSUSHITA_PULSE_LEN (uint8_t)(F_INTERRUPTS * MATSUSHITA_PULSE_TIME + 0.5)\r
231#define MATSUSHITA_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * MATSUSHITA_1_PAUSE_TIME + 0.5)\r
232#define MATSUSHITA_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * MATSUSHITA_0_PAUSE_TIME + 0.5)\r
a7054daf 233#define MATSUSHITA_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * MATSUSHITA_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 234\r
770a1a9d 235#define KASEIKYO_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * KASEIKYO_START_BIT_PULSE_TIME + 0.5)\r
236#define KASEIKYO_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * KASEIKYO_START_BIT_PAUSE_TIME + 0.5)\r
237#define KASEIKYO_PULSE_LEN (uint8_t)(F_INTERRUPTS * KASEIKYO_PULSE_TIME + 0.5)\r
238#define KASEIKYO_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * KASEIKYO_1_PAUSE_TIME + 0.5)\r
239#define KASEIKYO_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * KASEIKYO_0_PAUSE_TIME + 0.5)\r
240#define KASEIKYO_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * KASEIKYO_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
241#define KASEIKYO_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * KASEIKYO_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
242\r
4225a882 243#define RECS80_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * RECS80_START_BIT_PULSE_TIME + 0.5)\r
244#define RECS80_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RECS80_START_BIT_PAUSE_TIME + 0.5)\r
245#define RECS80_PULSE_LEN (uint8_t)(F_INTERRUPTS * RECS80_PULSE_TIME + 0.5)\r
246#define RECS80_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RECS80_1_PAUSE_TIME + 0.5)\r
247#define RECS80_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RECS80_0_PAUSE_TIME + 0.5)\r
a7054daf 248#define RECS80_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * RECS80_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 249\r
250#define RC5_START_BIT_LEN (uint8_t)(F_INTERRUPTS * RC5_BIT_TIME + 0.5)\r
251#define RC5_BIT_LEN (uint8_t)(F_INTERRUPTS * RC5_BIT_TIME + 0.5)\r
a7054daf 252#define RC5_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * RC5_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 253\r
254#define RC6_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * RC6_START_BIT_PULSE_TIME + 0.5)\r
255#define RC6_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RC6_START_BIT_PAUSE_TIME + 0.5)\r
256#define RC6_TOGGLE_BIT_LEN (uint8_t)(F_INTERRUPTS * RC6_TOGGLE_BIT_TIME + 0.5)\r
257#define RC6_BIT_LEN (uint8_t)(F_INTERRUPTS * RC6_BIT_TIME + 0.5)\r
a7054daf 258#define RC6_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * RC6_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 259\r
260#define DENON_PULSE_LEN (uint8_t)(F_INTERRUPTS * DENON_PULSE_TIME + 0.5)\r
261#define DENON_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * DENON_1_PAUSE_TIME + 0.5)\r
262#define DENON_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * DENON_0_PAUSE_TIME + 0.5)\r
a7054daf 263#define DENON_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * DENON_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
264#define DENON_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * DENON_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 265\r
beda975f 266#define THOMSON_PULSE_LEN (uint8_t)(F_INTERRUPTS * THOMSON_PULSE_TIME + 0.5)\r
267#define THOMSON_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * THOMSON_1_PAUSE_TIME + 0.5)\r
268#define THOMSON_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * THOMSON_0_PAUSE_TIME + 0.5)\r
269#define THOMSON_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * THOMSON_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
270#define THOMSON_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * THOMSON_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
271\r
4225a882 272#define RECS80EXT_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * RECS80EXT_START_BIT_PULSE_TIME + 0.5)\r
273#define RECS80EXT_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RECS80EXT_START_BIT_PAUSE_TIME + 0.5)\r
274#define RECS80EXT_PULSE_LEN (uint8_t)(F_INTERRUPTS * RECS80EXT_PULSE_TIME + 0.5)\r
275#define RECS80EXT_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RECS80EXT_1_PAUSE_TIME + 0.5)\r
276#define RECS80EXT_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RECS80EXT_0_PAUSE_TIME + 0.5)\r
a7054daf 277#define RECS80EXT_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * RECS80EXT_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 278\r
279#define NUBERT_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * NUBERT_START_BIT_PULSE_TIME + 0.5)\r
280#define NUBERT_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NUBERT_START_BIT_PAUSE_TIME + 0.5)\r
281#define NUBERT_1_PULSE_LEN (uint8_t)(F_INTERRUPTS * NUBERT_1_PULSE_TIME + 0.5)\r
282#define NUBERT_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NUBERT_1_PAUSE_TIME + 0.5)\r
283#define NUBERT_0_PULSE_LEN (uint8_t)(F_INTERRUPTS * NUBERT_0_PULSE_TIME + 0.5)\r
284#define NUBERT_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NUBERT_0_PAUSE_TIME + 0.5)\r
a7054daf 285#define NUBERT_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * NUBERT_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
286#define NUBERT_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * NUBERT_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
4225a882 287\r
5481e9cd 288#define BANG_OLUFSEN_START_BIT1_PULSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_START_BIT1_PULSE_TIME + 0.5)\r
289#define BANG_OLUFSEN_START_BIT1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_START_BIT1_PAUSE_TIME + 0.5)\r
290#define BANG_OLUFSEN_START_BIT2_PULSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_START_BIT2_PULSE_TIME + 0.5)\r
291#define BANG_OLUFSEN_START_BIT2_PAUSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_START_BIT2_PAUSE_TIME + 0.5)\r
292#define BANG_OLUFSEN_START_BIT3_PULSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_START_BIT3_PULSE_TIME + 0.5)\r
293#define BANG_OLUFSEN_START_BIT3_PAUSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_START_BIT3_PAUSE_TIME + 0.5)\r
294#define BANG_OLUFSEN_PULSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_PULSE_TIME + 0.5)\r
295#define BANG_OLUFSEN_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_1_PAUSE_TIME + 0.5)\r
296#define BANG_OLUFSEN_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_0_PAUSE_TIME + 0.5)\r
297#define BANG_OLUFSEN_R_PAUSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_R_PAUSE_TIME + 0.5)\r
298#define BANG_OLUFSEN_TRAILER_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * BANG_OLUFSEN_TRAILER_BIT_PAUSE_TIME + 0.5)\r
a7054daf 299#define BANG_OLUFSEN_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * BANG_OLUFSEN_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
5481e9cd 300\r
89e8cafb 301#define GRUNDIG_NOKIA_IR60_PRE_PAUSE_LEN (uint8_t)(F_INTERRUPTS * GRUNDIG_NOKIA_IR60_PRE_PAUSE_TIME + 0.5)\r
302#define GRUNDIG_NOKIA_IR60_BIT_LEN (uint8_t)(F_INTERRUPTS * GRUNDIG_NOKIA_IR60_BIT_TIME + 0.5)\r
a7054daf 303#define GRUNDIG_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * GRUNDIG_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
304#define NOKIA_AUTO_REPETITION_PAUSE_LEN (uint16_t)(F_INTERRUPTS * NOKIA_AUTO_REPETITION_PAUSE_TIME + 0.5) // use uint16_t!\r
89e8cafb 305#define GRUNDIG_NOKIA_IR60_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * GRUNDIG_NOKIA_IR60_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
a7054daf 306\r
02ccdb69 307#define SIEMENS_START_BIT_LEN (uint8_t)(F_INTERRUPTS * SIEMENS_OR_RUWIDO_START_BIT_PULSE_TIME + 0.5)\r
308#define SIEMENS_BIT_LEN (uint8_t)(F_INTERRUPTS * SIEMENS_OR_RUWIDO_BIT_PULSE_TIME + 0.5)\r
309#define SIEMENS_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * SIEMENS_OR_RUWIDO_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
5b437ff6 310\r
4225a882 311#define IRSND_FREQ_32_KHZ (uint8_t) ((F_CPU / 32000 / 2) - 1)\r
312#define IRSND_FREQ_36_KHZ (uint8_t) ((F_CPU / 36000 / 2) - 1)\r
313#define IRSND_FREQ_38_KHZ (uint8_t) ((F_CPU / 38000 / 2) - 1)\r
314#define IRSND_FREQ_40_KHZ (uint8_t) ((F_CPU / 40000 / 2) - 1)\r
315#define IRSND_FREQ_56_KHZ (uint8_t) ((F_CPU / 56000 / 2) - 1)\r
5481e9cd 316#define IRSND_FREQ_455_KHZ (uint8_t) ((F_CPU / 455000 / 2) - 1)\r
4225a882 317\r
48664931 318#define FDC_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * FDC_START_BIT_PULSE_TIME + 0.5)\r
319#define FDC_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * FDC_START_BIT_PAUSE_TIME + 0.5)\r
320#define FDC_PULSE_LEN (uint8_t)(F_INTERRUPTS * FDC_PULSE_TIME + 0.5)\r
321#define FDC_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * FDC_1_PAUSE_TIME + 0.5)\r
322#define FDC_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * FDC_0_PAUSE_TIME + 0.5)\r
323#define FDC_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * FDC_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
b5ea7869 324\r
c7c9a4a1 325#define RCCAR_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * RCCAR_START_BIT_PULSE_TIME + 0.5)\r
326#define RCCAR_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RCCAR_START_BIT_PAUSE_TIME + 0.5)\r
327#define RCCAR_PULSE_LEN (uint8_t)(F_INTERRUPTS * RCCAR_PULSE_TIME + 0.5)\r
328#define RCCAR_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RCCAR_1_PAUSE_TIME + 0.5)\r
329#define RCCAR_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * RCCAR_0_PAUSE_TIME + 0.5)\r
330#define RCCAR_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * RCCAR_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
331\r
c7a47e89 332#define JVC_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * JVC_START_BIT_PULSE_TIME + 0.5)\r
333#define JVC_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * JVC_START_BIT_PAUSE_TIME + 0.5)\r
334#define JVC_REPEAT_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * JVC_REPEAT_START_BIT_PAUSE_TIME + 0.5)\r
335#define JVC_PULSE_LEN (uint8_t)(F_INTERRUPTS * JVC_PULSE_TIME + 0.5)\r
336#define JVC_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * JVC_1_PAUSE_TIME + 0.5)\r
337#define JVC_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * JVC_0_PAUSE_TIME + 0.5)\r
338#define JVC_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * JVC_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
339\r
9405f84a 340#define NIKON_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * NIKON_START_BIT_PULSE_TIME + 0.5)\r
341#define NIKON_START_BIT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * NIKON_START_BIT_PAUSE_TIME + 0.5)\r
342#define NIKON_REPEAT_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NIKON_REPEAT_START_BIT_PAUSE_TIME + 0.5)\r
343#define NIKON_PULSE_LEN (uint8_t)(F_INTERRUPTS * NIKON_PULSE_TIME + 0.5)\r
344#define NIKON_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NIKON_1_PAUSE_TIME + 0.5)\r
345#define NIKON_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * NIKON_0_PAUSE_TIME + 0.5)\r
f50e01e7 346#define NIKON_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * NIKON_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
347\r
348#define LEGO_START_BIT_PULSE_LEN (uint8_t)(F_INTERRUPTS * LEGO_START_BIT_PULSE_TIME + 0.5)\r
349#define LEGO_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * LEGO_START_BIT_PAUSE_TIME + 0.5)\r
350#define LEGO_REPEAT_START_BIT_PAUSE_LEN (uint8_t)(F_INTERRUPTS * LEGO_REPEAT_START_BIT_PAUSE_TIME + 0.5)\r
351#define LEGO_PULSE_LEN (uint8_t)(F_INTERRUPTS * LEGO_PULSE_TIME + 0.5)\r
352#define LEGO_1_PAUSE_LEN (uint8_t)(F_INTERRUPTS * LEGO_1_PAUSE_TIME + 0.5)\r
353#define LEGO_0_PAUSE_LEN (uint8_t)(F_INTERRUPTS * LEGO_0_PAUSE_TIME + 0.5)\r
354#define LEGO_FRAME_REPEAT_PAUSE_LEN (uint16_t)(F_INTERRUPTS * LEGO_FRAME_REPEAT_PAUSE_TIME + 0.5) // use uint16_t!\r
9405f84a 355\r
4225a882 356static volatile uint8_t irsnd_busy;\r
357static volatile uint8_t irsnd_protocol;\r
d155e9ab 358static volatile uint8_t irsnd_buffer[6];\r
a7054daf 359static volatile uint8_t irsnd_repeat;\r
4225a882 360static volatile uint8_t irsnd_is_on = FALSE;\r
361\r
f50e01e7 362#if IRSND_USE_CALLBACK == 1\r
363static void (*irsnd_callback_ptr) (uint8_t);\r
364#endif // IRSND_USE_CALLBACK == 1\r
365\r
4225a882 366/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
367 * Switch PWM on\r
368 * @details Switches PWM on with a narrow spike on all 3 channels -> leds glowing\r
369 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
370 */\r
371static void\r
372irsnd_on (void)\r
373{\r
374 if (! irsnd_is_on)\r
375 {\r
376#ifndef DEBUG\r
1f54e86c 377#if IRSND_OCx == IRSND_OC2 // use OC2\r
378 TCCR2 |= (1<<COM20)|(1<<WGM21); // toggle OC2 on compare match, clear Timer 2 at compare match OCR2\r
379#elif IRSND_OCx == IRSND_OC2A // use OC2A\r
f50e01e7 380 TCCR2A |= (1<<COM2A0)|(1<<WGM21); // toggle OC2A on compare match, clear Timer 2 at compare match OCR2A\r
1f54e86c 381#elif IRSND_OCx == IRSND_OC2B // use OC2B\r
f50e01e7 382 TCCR2A |= (1<<COM2B0)|(1<<WGM21); // toggle OC2B on compare match, clear Timer 2 at compare match OCR2A (yes: A, not B!)\r
1f54e86c 383#elif IRSND_OCx == IRSND_OC0 // use OC0\r
384 TCCR0 |= (1<<COM00)|(1<<WGM01); // toggle OC0 on compare match, clear Timer 0 at compare match OCR0\r
385#elif IRSND_OCx == IRSND_OC0A // use OC0A\r
386 TCCR0A |= (1<<COM0A0)|(1<<WGM01); // toggle OC0A on compare match, clear Timer 0 at compare match OCR0A\r
387#elif IRSND_OCx == IRSND_OC0B // use OC0B\r
388 TCCR0A |= (1<<COM0B0)|(1<<WGM01); // toggle OC0B on compare match, clear Timer 0 at compare match OCR0A (yes: A, not B!)\r
389#else\r
390#error wrong value of IRSND_OCx\r
391#endif // IRSND_OCx\r
4225a882 392#endif // DEBUG\r
f50e01e7 393\r
394#if IRSND_USE_CALLBACK == 1\r
395 if (irsnd_callback_ptr)\r
396 {\r
397 (*irsnd_callback_ptr) (TRUE);\r
398 }\r
399#endif // IRSND_USE_CALLBACK == 1\r
400\r
4225a882 401 irsnd_is_on = TRUE;\r
402 }\r
403}\r
404\r
405/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
406 * Switch PWM off\r
407 * @details Switches PWM off\r
408 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
409 */\r
410static void\r
411irsnd_off (void)\r
412{\r
413 if (irsnd_is_on)\r
414 {\r
415#ifndef DEBUG\r
1f54e86c 416#if IRSND_OCx == IRSND_OC2 // use OC2\r
f50e01e7 417 TCCR2 &= ~(1<<COM20); // normal port operation, OC2 disconnected.\r
1f54e86c 418#elif IRSND_OCx == IRSND_OC2A // use OC2A\r
f50e01e7 419 TCCR2A &= ~(1<<COM2A0); // normal port operation, OC2A disconnected.\r
1f54e86c 420#elif IRSND_OCx == IRSND_OC2B // use OC2B\r
f50e01e7 421 TCCR2A &= ~(1<<COM2B0); // normal port operation, OC2B disconnected.\r
1f54e86c 422#elif IRSND_OCx == IRSND_OC0 // use OC0\r
423 TCCR0 &= ~(1<<COM00); // normal port operation, OC0 disconnected.\r
424#elif IRSND_OCx == IRSND_OC0A // use OC0A\r
425 TCCR0A &= ~(1<<COM0A0); // normal port operation, OC0A disconnected.\r
426#elif IRSND_OCx == IRSND_OC0B // use OC0B\r
427 TCCR0A &= ~(1<<COM0B0); // normal port operation, OC0B disconnected.\r
428#else\r
429#error wrong value of IRSND_OCx\r
430#endif // IRSND_OCx\r
f50e01e7 431 IRSND_PORT &= ~(1<<IRSND_BIT); // set IRSND_BIT to low\r
4225a882 432#endif // DEBUG\r
f50e01e7 433\r
434#if IRSND_USE_CALLBACK == 1\r
435 if (irsnd_callback_ptr)\r
436 {\r
437 (*irsnd_callback_ptr) (FALSE);\r
438 }\r
439#endif // IRSND_USE_CALLBACK == 1\r
440\r
4225a882 441 irsnd_is_on = FALSE;\r
442 }\r
443}\r
444\r
445/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
446 * Set PWM frequency\r
447 * @details sets pwm frequency\r
448 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
449 */\r
450static void\r
451irsnd_set_freq (uint8_t freq)\r
452{\r
453#ifndef DEBUG\r
1f54e86c 454#if IRSND_OCx == IRSND_OC2\r
f50e01e7 455 OCR2 = freq; // use register OCR2 for OC2\r
1f54e86c 456#elif IRSND_OCx == IRSND_OC2A // use OC2A\r
457 OCR2A = freq; // use register OCR2A for OC2A and OC2B!\r
458#elif IRSND_OCx == IRSND_OC2B // use OC2B\r
f50e01e7 459 OCR2A = freq; // use register OCR2A for OC2A and OC2B!\r
1f54e86c 460#elif IRSND_OCx == IRSND_OC0 // use OC0\r
461 OCR0 = freq; // use register OCR2 for OC2\r
462#elif IRSND_OCx == IRSND_OC0A // use OC0A\r
463 OCR0A = freq; // use register OCR0A for OC0A and OC0B!\r
464#elif IRSND_OCx == IRSND_OC0B // use OC0B\r
465 OCR0A = freq; // use register OCR0A for OC0A and OC0B!\r
466#else\r
467#error wrong value of IRSND_OCx\r
f50e01e7 468#endif\r
4225a882 469#endif // DEBUG\r
470}\r
471\r
472/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
473 * Initialize the PWM\r
474 * @details Configures 0CR0A, 0CR0B and 0CR2B as PWM channels\r
475 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
476 */\r
477void\r
478irsnd_init (void)\r
479{\r
480#ifndef DEBUG\r
481 IRSND_PORT &= ~(1<<IRSND_BIT); // set IRSND_BIT to low\r
482 IRSND_DDR |= (1<<IRSND_BIT); // set IRSND_BIT to output\r
483\r
1f54e86c 484#if IRSND_OCx == IRSND_OC2 // use OC2\r
4225a882 485 TCCR2 = (1<<WGM21); // CTC mode\r
486 TCCR2 |= (1<<CS20); // 0x01, start Timer 2, no prescaling\r
1f54e86c 487#elif IRSND_OCx == IRSND_OC2A || IRSND_OCx == IRSND_OC2B // use OC2A or OC2B\r
4225a882 488 TCCR2A = (1<<WGM21); // CTC mode\r
489 TCCR2B |= (1<<CS20); // 0x01, start Timer 2, no prescaling\r
1f54e86c 490#elif IRSND_OCx == IRSND_OC0 // use OC0\r
491 TCCR0 = (1<<WGM01); // CTC mode\r
492 TCCR0 |= (1<<CS00); // 0x01, start Timer 0, no prescaling\r
493#elif IRSND_OCx == IRSND_OC0A || IRSND_OCx == IRSND_OC0B // use OC0A or OC0B\r
494 TCCR0A = (1<<WGM01); // CTC mode\r
495 TCCR0B |= (1<<CS00); // 0x01, start Timer 0, no prescaling\r
496#else\r
497#error wrong value of IRSND_OCx\r
498#endif\r
4225a882 499\r
500 irsnd_set_freq (IRSND_FREQ_36_KHZ); // default frequency\r
501#endif // DEBUG\r
502}\r
503\r
f50e01e7 504#if IRSND_USE_CALLBACK == 1\r
505void\r
506irsnd_set_callback_ptr (void (*cb)(uint8_t))\r
507{\r
508 irsnd_callback_ptr = cb;\r
509}\r
510#endif // IRSND_USE_CALLBACK == 1\r
511\r
4225a882 512uint8_t\r
513irsnd_is_busy (void)\r
514{\r
515 return irsnd_busy;\r
516}\r
517\r
518static uint16_t\r
519bitsrevervse (uint16_t x, uint8_t len)\r
520{\r
521 uint16_t xx = 0;\r
522\r
523 while(len)\r
524 {\r
525 xx <<= 1;\r
526 if (x & 1)\r
527 {\r
528 xx |= 1;\r
529 }\r
530 x >>= 1;\r
531 len--;\r
532 }\r
533 return xx;\r
534}\r
535\r
536\r
9547ee89 537#if IRSND_SUPPORT_SIRCS_PROTOCOL == 1\r
538static uint8_t sircs_additional_bitlen;\r
539#endif // IRSND_SUPPORT_SIRCS_PROTOCOL == 1\r
540\r
4225a882 541uint8_t\r
879b06c2 542irsnd_send_data (IRMP_DATA * irmp_data_p, uint8_t do_wait)\r
4225a882 543{\r
544#if IRSND_SUPPORT_RECS80_PROTOCOL == 1\r
545 static uint8_t toggle_bit_recs80;\r
546#endif\r
547#if IRSND_SUPPORT_RECS80EXT_PROTOCOL == 1\r
548 static uint8_t toggle_bit_recs80ext;\r
549#endif\r
550#if IRSND_SUPPORT_RC5_PROTOCOL == 1\r
551 static uint8_t toggle_bit_rc5;\r
9547ee89 552#endif\r
779fbc81 553#if IRSND_SUPPORT_RC6_PROTOCOL == 1 || IRSND_SUPPORT_RC6A_PROTOCOL == 1\r
9547ee89 554 static uint8_t toggle_bit_rc6;\r
beda975f 555#endif\r
556#if IRSND_SUPPORT_THOMSON_PROTOCOL == 1\r
557 static uint8_t toggle_bit_thomson;\r
4225a882 558#endif\r
559 uint16_t address;\r
560 uint16_t command;\r
561\r
879b06c2 562 if (do_wait)\r
4225a882 563 {\r
879b06c2 564 while (irsnd_busy)\r
565 {\r
566 // do nothing;\r
567 }\r
568 }\r
569 else if (irsnd_busy)\r
570 {\r
571 return (FALSE);\r
4225a882 572 }\r
573\r
574 irsnd_protocol = irmp_data_p->protocol;\r
beda975f 575 irsnd_repeat = irmp_data_p->flags & IRSND_REPETITION_MASK;\r
4225a882 576\r
577 switch (irsnd_protocol)\r
578 {\r
579#if IRSND_SUPPORT_SIRCS_PROTOCOL == 1\r
580 case IRMP_SIRCS_PROTOCOL:\r
581 {\r
9547ee89 582 uint8_t sircs_additional_command_len;\r
583 uint8_t sircs_additional_address_len;\r
584\r
585 sircs_additional_bitlen = (irmp_data_p->address & 0xFF00) >> 8; // additional bitlen\r
586\r
587 if (sircs_additional_bitlen > 15 - SIRCS_MINIMUM_DATA_LEN)\r
588 {\r
589 sircs_additional_command_len = 15 - SIRCS_MINIMUM_DATA_LEN;\r
590 sircs_additional_address_len = sircs_additional_bitlen - (15 - SIRCS_MINIMUM_DATA_LEN);\r
591 }\r
592 else\r
593 {\r
594 sircs_additional_command_len = sircs_additional_bitlen;\r
595 sircs_additional_address_len = 0;\r
596 }\r
4225a882 597\r
9547ee89 598 command = bitsrevervse (irmp_data_p->command, 15);\r
599\r
600 irsnd_buffer[0] = (command & 0x7F80) >> 7; // CCCCCCCC\r
601 irsnd_buffer[1] = (command & 0x007F) << 1; // CCCC****\r
602\r
603 if (sircs_additional_address_len > 0)\r
604 {\r
605 address = bitsrevervse (irmp_data_p->address, 5);\r
606 irsnd_buffer[1] |= (address & 0x0010) >> 4;\r
607 irsnd_buffer[2] = (address & 0x000F) << 4;\r
608 }\r
4225a882 609 irsnd_busy = TRUE;\r
610 break;\r
611 }\r
612#endif\r
613#if IRSND_SUPPORT_NEC_PROTOCOL == 1\r
46dd89b7 614 case IRMP_APPLE_PROTOCOL:\r
c7a47e89 615 {\r
616 command = irmp_data_p->command | (irmp_data_p->address << 8); // store address as ID in upper byte of command\r
617 address = 0x87EE; // set fixed NEC-lookalike address (customer ID of apple)\r
618\r
619 address = bitsrevervse (address, NEC_ADDRESS_LEN);\r
620 command = bitsrevervse (command, NEC_COMMAND_LEN);\r
621\r
622 irsnd_protocol = IRMP_NEC_PROTOCOL; // APPLE protocol is NEC with id instead of inverted command\r
623\r
7644ac04 624 irsnd_buffer[0] = (address & 0xFF00) >> 8; // AAAAAAAA\r
625 irsnd_buffer[1] = (address & 0x00FF); // AAAAAAAA\r
626 irsnd_buffer[2] = (command & 0xFF00) >> 8; // CCCCCCCC\r
627 irsnd_buffer[3] = 0x8B; // 10001011 (id)\r
c7a47e89 628 irsnd_busy = TRUE;\r
629 break;\r
630 }\r
631 case IRMP_NEC_PROTOCOL:\r
4225a882 632 {\r
633 address = bitsrevervse (irmp_data_p->address, NEC_ADDRESS_LEN);\r
634 command = bitsrevervse (irmp_data_p->command, NEC_COMMAND_LEN);\r
635\r
4225a882 636 irsnd_buffer[0] = (address & 0xFF00) >> 8; // AAAAAAAA\r
637 irsnd_buffer[1] = (address & 0x00FF); // AAAAAAAA\r
638 irsnd_buffer[2] = (command & 0xFF00) >> 8; // CCCCCCCC\r
7644ac04 639 irsnd_buffer[3] = ~((command & 0xFF00) >> 8); // cccccccc\r
640 irsnd_busy = TRUE;\r
641 break;\r
642 }\r
643#endif\r
644#if IRSND_SUPPORT_NEC16_PROTOCOL == 1\r
645 case IRMP_NEC16_PROTOCOL:\r
646 {\r
647 address = bitsrevervse (irmp_data_p->address, NEC16_ADDRESS_LEN);\r
648 command = bitsrevervse (irmp_data_p->command, NEC16_COMMAND_LEN);\r
46dd89b7 649\r
7644ac04 650 irsnd_buffer[0] = (address & 0x00FF); // AAAAAAAA\r
651 irsnd_buffer[1] = (command & 0x00FF); // CCCCCCCC\r
652 irsnd_busy = TRUE;\r
653 break;\r
654 }\r
655#endif\r
656#if IRSND_SUPPORT_NEC42_PROTOCOL == 1\r
657 case IRMP_NEC42_PROTOCOL:\r
658 {\r
659 address = bitsrevervse (irmp_data_p->address, NEC42_ADDRESS_LEN);\r
660 command = bitsrevervse (irmp_data_p->command, NEC42_COMMAND_LEN);\r
661\r
662 irsnd_buffer[0] = ( (address & 0x1FE0) >> 5); // AAAAAAAA\r
663 irsnd_buffer[1] = ( (address & 0x001F) << 3) | ((~address & 0x1C00) >> 10); // AAAAAaaa\r
664 irsnd_buffer[2] = ((~address & 0x03FC) >> 2); // aaaaaaaa\r
665 irsnd_buffer[3] = ((~address & 0x0003) << 6) | ( (command & 0x00FC) >> 2); // aaCCCCCC\r
666 irsnd_buffer[4] = ( (command & 0x0003) << 6) | ((~command & 0x00FC) >> 2); // CCcccccc\r
667 irsnd_buffer[5] = ((~command & 0x0003) << 6); // cc\r
4225a882 668 irsnd_busy = TRUE;\r
669 break;\r
670 }\r
671#endif\r
672#if IRSND_SUPPORT_SAMSUNG_PROTOCOL == 1\r
673 case IRMP_SAMSUNG_PROTOCOL:\r
674 {\r
675 address = bitsrevervse (irmp_data_p->address, SAMSUNG_ADDRESS_LEN);\r
676 command = bitsrevervse (irmp_data_p->command, SAMSUNG_COMMAND_LEN);\r
677\r
4225a882 678 irsnd_buffer[0] = (address & 0xFF00) >> 8; // AAAAAAAA\r
679 irsnd_buffer[1] = (address & 0x00FF); // AAAAAAAA\r
680 irsnd_buffer[2] = (command & 0x00F0) | ((command & 0xF000) >> 12); // IIIICCCC\r
681 irsnd_buffer[3] = ((command & 0x0F00) >> 4) | ((~(command & 0xF000) >> 12) & 0x0F); // CCCCcccc\r
682 irsnd_buffer[4] = (~(command & 0x0F00) >> 4) & 0xF0; // cccc0000\r
683 irsnd_busy = TRUE;\r
684 break;\r
685 }\r
686 case IRMP_SAMSUNG32_PROTOCOL:\r
687 {\r
688 address = bitsrevervse (irmp_data_p->address, SAMSUNG_ADDRESS_LEN);\r
689 command = bitsrevervse (irmp_data_p->command, SAMSUNG32_COMMAND_LEN);\r
690\r
4225a882 691 irsnd_buffer[0] = (address & 0xFF00) >> 8; // AAAAAAAA\r
692 irsnd_buffer[1] = (address & 0x00FF); // AAAAAAAA\r
693 irsnd_buffer[2] = (command & 0xFF00) >> 8; // CCCCCCCC\r
694 irsnd_buffer[3] = (command & 0x00FF); // CCCCCCCC\r
695 irsnd_busy = TRUE;\r
696 break;\r
697 }\r
698#endif\r
699#if IRSND_SUPPORT_MATSUSHITA_PROTOCOL == 1\r
700 case IRMP_MATSUSHITA_PROTOCOL:\r
701 {\r
702 address = bitsrevervse (irmp_data_p->address, MATSUSHITA_ADDRESS_LEN);\r
703 command = bitsrevervse (irmp_data_p->command, MATSUSHITA_COMMAND_LEN);\r
704\r
4225a882 705 irsnd_buffer[0] = (command & 0x0FF0) >> 4; // CCCCCCCC\r
706 irsnd_buffer[1] = ((command & 0x000F) << 4) | ((address & 0x0F00) >> 8); // CCCCAAAA\r
707 irsnd_buffer[2] = (address & 0x00FF); // AAAAAAAA\r
708 irsnd_busy = TRUE;\r
709 break;\r
710 }\r
711#endif\r
770a1a9d 712#if IRSND_SUPPORT_KASEIKYO_PROTOCOL == 1\r
713 case IRMP_KASEIKYO_PROTOCOL:\r
714 {\r
715 uint8_t xor;\r
716\r
717 address = bitsrevervse (irmp_data_p->address, KASEIKYO_ADDRESS_LEN);\r
718 command = bitsrevervse (irmp_data_p->command, KASEIKYO_COMMAND_LEN + 4);\r
719\r
720 xor = ((address & 0x000F) ^ ((address & 0x00F0) >> 4) ^ ((address & 0x0F00) >> 8) ^ ((address & 0xF000) >> 12)) & 0x0F;\r
721\r
722 irsnd_buffer[0] = (address & 0xFF00) >> 8; // AAAAAAAA\r
723 irsnd_buffer[1] = (address & 0x00FF); // AAAAAAAA\r
724 irsnd_buffer[2] = xor << 4 | (command & 0x000F); // XXXXCCCC\r
725 irsnd_buffer[3] = 0 | (command & 0xF000) >> 12; // 0000CCCC\r
726 irsnd_buffer[4] = (command & 0x0FF0) >> 4; // CCCCCCCC\r
727\r
728 xor = irsnd_buffer[2] ^ irsnd_buffer[3] ^ irsnd_buffer[4];\r
729\r
730 irsnd_buffer[5] = xor;\r
731 irsnd_busy = TRUE;\r
732 break;\r
733 }\r
734#endif\r
4225a882 735#if IRSND_SUPPORT_RECS80_PROTOCOL == 1\r
736 case IRMP_RECS80_PROTOCOL:\r
737 {\r
738 toggle_bit_recs80 = toggle_bit_recs80 ? 0x00 : 0x40;\r
739\r
4225a882 740 irsnd_buffer[0] = 0x80 | toggle_bit_recs80 | ((irmp_data_p->address & 0x0007) << 3) |\r
741 ((irmp_data_p->command & 0x0038) >> 3); // STAAACCC\r
742 irsnd_buffer[1] = (irmp_data_p->command & 0x07) << 5; // CCC00000\r
743 irsnd_busy = TRUE;\r
744 break;\r
745 }\r
746#endif\r
747#if IRSND_SUPPORT_RECS80EXT_PROTOCOL == 1\r
748 case IRMP_RECS80EXT_PROTOCOL:\r
749 {\r
750 toggle_bit_recs80ext = toggle_bit_recs80ext ? 0x00 : 0x40;\r
751\r
4225a882 752 irsnd_buffer[0] = 0x80 | toggle_bit_recs80ext | ((irmp_data_p->address & 0x000F) << 2) |\r
753 ((irmp_data_p->command & 0x0030) >> 4); // STAAAACC\r
754 irsnd_buffer[1] = (irmp_data_p->command & 0x0F) << 4; // CCCC0000\r
755 irsnd_busy = TRUE;\r
756 break;\r
757 }\r
758#endif\r
759#if IRSND_SUPPORT_RC5_PROTOCOL == 1\r
760 case IRMP_RC5_PROTOCOL:\r
761 {\r
762 toggle_bit_rc5 = toggle_bit_rc5 ? 0x00 : 0x40;\r
763\r
4225a882 764 irsnd_buffer[0] = ((irmp_data_p->command & 0x40) ? 0x00 : 0x80) | toggle_bit_rc5 |\r
765 ((irmp_data_p->address & 0x001F) << 1) | ((irmp_data_p->command & 0x20) >> 5); // CTAAAAAC\r
766 irsnd_buffer[1] = (irmp_data_p->command & 0x1F) << 3; // CCCCC000\r
767 irsnd_busy = TRUE;\r
768 break;\r
769 }\r
770#endif\r
9547ee89 771#if IRSND_SUPPORT_RC6_PROTOCOL == 1\r
772 case IRMP_RC6_PROTOCOL:\r
773 {\r
774 toggle_bit_rc6 = toggle_bit_rc6 ? 0x00 : 0x08;\r
775\r
776 irsnd_buffer[0] = 0x80 | toggle_bit_rc6 | ((irmp_data_p->address & 0x00E0) >> 5); // 1MMMTAAA, MMM = 000\r
777 irsnd_buffer[1] = ((irmp_data_p->address & 0x001F) << 3) | ((irmp_data_p->command & 0xE0) >> 5); // AAAAACCC\r
778 irsnd_buffer[2] = (irmp_data_p->command & 0x1F) << 3; // CCCCC\r
779 irsnd_busy = TRUE;\r
780 break;\r
781 }\r
782#endif\r
783#if IRSND_SUPPORT_RC6A_PROTOCOL == 1\r
784 case IRMP_RC6A_PROTOCOL:\r
785 {\r
786 toggle_bit_rc6 = toggle_bit_rc6 ? 0x00 : 0x08;\r
787\r
788 irsnd_buffer[0] = 0x80 | 0x60 | ((irmp_data_p->address & 0x3000) >> 12); // 1MMMT0AA, MMM = 110\r
789 irsnd_buffer[1] = ((irmp_data_p->address & 0x0FFF) >> 4) ; // AAAAAAAA\r
790 irsnd_buffer[2] = ((irmp_data_p->address & 0x000F) << 4) | ((irmp_data_p->command & 0xF000) >> 12) | toggle_bit_rc6; // AAAACCCC\r
791 irsnd_buffer[3] = (irmp_data_p->command & 0x0FF0) >> 4; // CCCCCCCC\r
792 irsnd_buffer[4] = (irmp_data_p->command & 0x000F) << 4; // CCCC\r
793 irsnd_busy = TRUE;\r
794 break;\r
795 }\r
796#endif\r
4225a882 797#if IRSND_SUPPORT_DENON_PROTOCOL == 1\r
798 case IRMP_DENON_PROTOCOL:\r
799 {\r
d155e9ab 800 irsnd_buffer[0] = ((irmp_data_p->address & 0x1F) << 3) | ((irmp_data_p->command & 0x0380) >> 7); // AAAAACCC (1st frame)\r
801 irsnd_buffer[1] = (irmp_data_p->command & 0x7F) << 1; // CCCCCCC\r
802 irsnd_buffer[2] = ((irmp_data_p->address & 0x1F) << 3) | (((~irmp_data_p->command) & 0x0380) >> 7); // AAAAACCC (2nd frame)\r
803 irsnd_buffer[3] = (~(irmp_data_p->command) & 0x7F) << 1; // CCCCCCC\r
4225a882 804 irsnd_busy = TRUE;\r
805 break;\r
806 }\r
807#endif\r
beda975f 808#if IRSND_SUPPORT_THOMSON_PROTOCOL == 1\r
809 case IRMP_THOMSON_PROTOCOL:\r
810 {\r
811 toggle_bit_thomson = toggle_bit_thomson ? 0x00 : 0x08;\r
812\r
813 irsnd_buffer[0] = ((irmp_data_p->address & 0x0F) << 4) | toggle_bit_thomson | ((irmp_data_p->command & 0x0070) >> 4); // AAAATCCC (1st frame)\r
814 irsnd_buffer[1] = (irmp_data_p->command & 0x0F) << 4; // CCCC\r
815 irsnd_busy = TRUE;\r
816 break;\r
817 }\r
818#endif\r
4225a882 819#if IRSND_SUPPORT_NUBERT_PROTOCOL == 1\r
820 case IRMP_NUBERT_PROTOCOL:\r
821 {\r
4225a882 822 irsnd_buffer[0] = irmp_data_p->command >> 2; // CCCCCCCC\r
823 irsnd_buffer[1] = (irmp_data_p->command & 0x0003) << 6; // CC000000\r
824 irsnd_busy = TRUE;\r
825 break;\r
826 }\r
5481e9cd 827#endif\r
828#if IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL == 1\r
829 case IRMP_BANG_OLUFSEN_PROTOCOL:\r
830 {\r
5481e9cd 831 irsnd_buffer[0] = irmp_data_p->command >> 11; // SXSCCCCC\r
832 irsnd_buffer[1] = irmp_data_p->command >> 3; // CCCCCCCC\r
833 irsnd_buffer[2] = (irmp_data_p->command & 0x0007) << 5; // CCC00000\r
834 irsnd_busy = TRUE;\r
835 break;\r
836 }\r
4225a882 837#endif\r
5b437ff6 838#if IRSND_SUPPORT_GRUNDIG_PROTOCOL == 1\r
839 case IRMP_GRUNDIG_PROTOCOL:\r
840 {\r
841 command = bitsrevervse (irmp_data_p->command, GRUNDIG_COMMAND_LEN);\r
842\r
d155e9ab 843 irsnd_buffer[0] = 0xFF; // S1111111 (1st frame)\r
844 irsnd_buffer[1] = 0xC0; // 11\r
845 irsnd_buffer[2] = 0x80 | (command >> 2); // SCCCCCCC (2nd frame)\r
846 irsnd_buffer[3] = (command << 6) & 0xC0; // CC\r
847\r
848 irsnd_busy = TRUE;\r
849 break;\r
850 }\r
851#endif\r
852#if IRSND_SUPPORT_NOKIA_PROTOCOL == 1\r
853 case IRMP_NOKIA_PROTOCOL:\r
854 {\r
855 address = bitsrevervse (irmp_data_p->address, NOKIA_ADDRESS_LEN);\r
856 command = bitsrevervse (irmp_data_p->command, NOKIA_COMMAND_LEN);\r
857\r
858 irsnd_buffer[0] = 0xBF; // S0111111 (1st + 3rd frame)\r
859 irsnd_buffer[1] = 0xFF; // 11111111\r
860 irsnd_buffer[2] = 0x80; // 1\r
861 irsnd_buffer[3] = 0x80 | command >> 1; // SCCCCCCC (2nd frame)\r
862 irsnd_buffer[4] = (command << 7) | (address >> 1); // CAAAAAAA\r
863 irsnd_buffer[5] = (address << 7); // A\r
5b437ff6 864\r
865 irsnd_busy = TRUE;\r
866 break;\r
867 }\r
868#endif\r
a7054daf 869#if IRSND_SUPPORT_SIEMENS_PROTOCOL == 1\r
870 case IRMP_SIEMENS_PROTOCOL:\r
871 {\r
872 irsnd_buffer[0] = ((irmp_data_p->address & 0x0FFF) >> 5); // SAAAAAAA\r
873 irsnd_buffer[1] = ((irmp_data_p->address & 0x1F) << 3) | ((irmp_data_p->command & 0x7F) >> 5); // AAAAA0CC\r
9405f84a 874 irsnd_buffer[2] = (irmp_data_p->command << 3) | ((~irmp_data_p->command & 0x01) << 2); // CCCCCc\r
875\r
a7054daf 876 irsnd_busy = TRUE;\r
877 break;\r
878 }\r
b5ea7869 879#endif\r
48664931 880#if IRSND_SUPPORT_FDC_PROTOCOL == 1\r
881 case IRMP_FDC_PROTOCOL:\r
b5ea7869 882 {\r
48664931 883 address = bitsrevervse (irmp_data_p->address, FDC_ADDRESS_LEN);\r
884 command = bitsrevervse (irmp_data_p->command, FDC_COMMAND_LEN);\r
b5ea7869 885\r
c7c9a4a1 886 irsnd_buffer[0] = (address & 0xFF); // AAAAAAAA\r
887 irsnd_buffer[1] = 0; // 00000000\r
888 irsnd_buffer[2] = 0; // 0000RRRR\r
889 irsnd_buffer[3] = (command & 0xFF); // CCCCCCCC\r
890 irsnd_buffer[4] = ~(command & 0xFF); // cccccccc\r
891 irsnd_busy = TRUE;\r
892 break;\r
893 }\r
894#endif\r
895#if IRSND_SUPPORT_RCCAR_PROTOCOL == 1\r
896 case IRMP_RCCAR_PROTOCOL:\r
897 {\r
898 address = bitsrevervse (irmp_data_p->address, 2); // A0 A1\r
899 command = bitsrevervse (irmp_data_p->command, RCCAR_COMMAND_LEN - 2); // D0 D1 D2 D3 D4 D5 D6 D7 C0 C1 V\r
900\r
901 irsnd_buffer[0] = ((command & 0x06) << 5) | ((address & 0x0003) << 4) | ((command & 0x0780) >> 7); // C0 C1 A0 A1 D0 D1 D2 D3\r
902 irsnd_buffer[1] = ((command & 0x78) << 1) | ((command & 0x0001) << 3); // D4 D5 D6 D7 V 0 0 0\r
903 \r
b5ea7869 904 irsnd_busy = TRUE;\r
905 break;\r
906 }\r
a7054daf 907#endif\r
c7a47e89 908#if IRSND_SUPPORT_JVC_PROTOCOL == 1\r
909 case IRMP_JVC_PROTOCOL:\r
910 {\r
911 address = bitsrevervse (irmp_data_p->address, JVC_ADDRESS_LEN);\r
912 command = bitsrevervse (irmp_data_p->command, JVC_COMMAND_LEN);\r
913\r
914 irsnd_buffer[0] = ((address & 0x000F) << 4) | (command & 0x0F00) >> 8; // AAAACCCC\r
915 irsnd_buffer[1] = (command & 0x00FF); // CCCCCCCC\r
916\r
917 irsnd_busy = TRUE;\r
918 break;\r
919 }\r
920#endif\r
9405f84a 921#if IRSND_SUPPORT_NIKON_PROTOCOL == 1\r
922 case IRMP_NIKON_PROTOCOL:\r
923 {\r
924 irsnd_buffer[0] = (irmp_data_p->command & 0x0003) << 6; // CC\r
925 irsnd_busy = TRUE;\r
926 break;\r
927 }\r
f50e01e7 928#endif\r
929#if IRSND_SUPPORT_LEGO_PROTOCOL == 1\r
930 case IRMP_LEGO_PROTOCOL:\r
931 {\r
932 uint8_t crc = 0x0F ^ ((irmp_data_p->command & 0x0F00) >> 8) ^ ((irmp_data_p->command & 0x00F0) >> 4) ^ (irmp_data_p->command & 0x000F);\r
933\r
934 irsnd_buffer[0] = (irmp_data_p->command & 0x0FF0) >> 4; // CCCCCCCC\r
935 irsnd_buffer[1] = ((irmp_data_p->command & 0x000F) << 4) | crc; // CCCCcccc\r
936\r
937 irsnd_protocol = IRMP_LEGO_PROTOCOL;\r
938 irsnd_busy = TRUE;\r
939 break;\r
940 }\r
9405f84a 941#endif\r
4225a882 942 default:\r
943 {\r
944 break;\r
945 }\r
946 }\r
947\r
948 return irsnd_busy;\r
949}\r
950\r
beda975f 951void\r
952irsnd_stop (void)\r
953{\r
acf7fb44 954 irsnd_repeat = 0;\r
beda975f 955}\r
956\r
4225a882 957/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
958 * ISR routine\r
959 * @details ISR routine, called 10000 times per second\r
960 *---------------------------------------------------------------------------------------------------------------------------------------------------\r
961 */\r
962uint8_t\r
963irsnd_ISR (void)\r
964{\r
965 static uint8_t current_bit = 0xFF;\r
966 static uint8_t pulse_counter;\r
9405f84a 967 static IRSND_PAUSE_LEN pause_counter;\r
4225a882 968 static uint8_t startbit_pulse_len;\r
9405f84a 969 static IRSND_PAUSE_LEN startbit_pause_len;\r
4225a882 970 static uint8_t pulse_1_len;\r
971 static uint8_t pause_1_len;\r
972 static uint8_t pulse_0_len;\r
973 static uint8_t pause_0_len;\r
974 static uint8_t has_stop_bit;\r
975 static uint8_t new_frame = TRUE;\r
976 static uint8_t complete_data_len;\r
acf7fb44 977 static uint8_t n_repeat_frames; // number of repetition frames\r
a7054daf 978 static uint8_t n_auto_repetitions; // number of auto_repetitions\r
979 static uint8_t auto_repetition_counter; // auto_repetition counter\r
980 static uint16_t auto_repetition_pause_len; // pause before auto_repetition, uint16_t!\r
981 static uint16_t auto_repetition_pause_counter; // pause before auto_repetition, uint16_t!\r
a7054daf 982 static uint8_t repeat_counter; // repeat counter\r
983 static uint16_t repeat_frame_pause_len; // pause before repeat, uint16_t!\r
984 static uint16_t packet_repeat_pause_counter; // pause before repeat, uint16_t!\r
5481e9cd 985#if IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL == 1\r
986 static uint8_t last_bit_value;\r
987#endif\r
988 static uint8_t pulse_len = 0xFF;\r
9405f84a 989 static IRSND_PAUSE_LEN pause_len = 0xFF;\r
4225a882 990\r
991 if (irsnd_busy)\r
992 {\r
993 if (current_bit == 0xFF && new_frame) // start of transmission...\r
994 {\r
a7054daf 995 if (auto_repetition_counter > 0)\r
4225a882 996 {\r
a7054daf 997 auto_repetition_pause_counter++;\r
4225a882 998\r
a7054daf 999 if (auto_repetition_pause_counter >= auto_repetition_pause_len)\r
4225a882 1000 {\r
a7054daf 1001 auto_repetition_pause_counter = 0;\r
4225a882 1002\r
1003 if (irsnd_protocol == IRMP_DENON_PROTOCOL)\r
1004 {\r
1005 current_bit = 16;\r
1006 complete_data_len = 2 * DENON_COMPLETE_DATA_LEN + 1;\r
1007 }\r
a7054daf 1008 else if (irsnd_protocol == IRMP_GRUNDIG_PROTOCOL) // n'th grundig info frame\r
5b437ff6 1009 {\r
1010 current_bit = 15;\r
1011 complete_data_len = 16 + GRUNDIG_COMPLETE_DATA_LEN;\r
1012 }\r
a7054daf 1013 else if (irsnd_protocol == IRMP_NOKIA_PROTOCOL) // n'th nokia info frame\r
d155e9ab 1014 {\r
a7054daf 1015 if (auto_repetition_counter + 1 < n_auto_repetitions)\r
d155e9ab 1016 {\r
1017 current_bit = 23;\r
1018 complete_data_len = 24 + NOKIA_COMPLETE_DATA_LEN;\r
1019 }\r
a7054daf 1020 else // nokia stop frame\r
d155e9ab 1021 {\r
1022 current_bit = 0xFF;\r
1023 complete_data_len = NOKIA_COMPLETE_DATA_LEN;\r
1024 }\r
1025 }\r
4225a882 1026 }\r
1027 else\r
1028 {\r
1029#ifdef DEBUG\r
1030 if (irsnd_is_on)\r
1031 {\r
1032 putchar ('0');\r
1033 }\r
1034 else\r
1035 {\r
1036 putchar ('1');\r
1037 }\r
1038#endif\r
1039 return irsnd_busy;\r
1040 }\r
1041 }\r
beda975f 1042#if 0\r
a7054daf 1043 else if (repeat_counter > 0 && packet_repeat_pause_counter < repeat_frame_pause_len)\r
beda975f 1044#else\r
1045 else if (packet_repeat_pause_counter < repeat_frame_pause_len)\r
1046#endif\r
a7054daf 1047 {\r
1048 packet_repeat_pause_counter++;\r
1049\r
1050#ifdef DEBUG\r
1051 if (irsnd_is_on)\r
1052 {\r
1053 putchar ('0');\r
1054 }\r
1055 else\r
1056 {\r
1057 putchar ('1');\r
1058 }\r
1059#endif\r
1060 return irsnd_busy;\r
1061 }\r
4225a882 1062 else\r
1063 {\r
a7054daf 1064 n_repeat_frames = irsnd_repeat;\r
beda975f 1065\r
1066 if (n_repeat_frames == IRSND_ENDLESS_REPETITION)\r
1067 {\r
1068 n_repeat_frames = 255;\r
1069 }\r
1070\r
a7054daf 1071 packet_repeat_pause_counter = 0;\r
1072 pulse_counter = 0;\r
1073 pause_counter = 0;\r
5481e9cd 1074\r
4225a882 1075 switch (irsnd_protocol)\r
1076 {\r
1077#if IRSND_SUPPORT_SIRCS_PROTOCOL == 1\r
1078 case IRMP_SIRCS_PROTOCOL:\r
1079 {\r
a7054daf 1080 startbit_pulse_len = SIRCS_START_BIT_PULSE_LEN;\r
53c11f07 1081 startbit_pause_len = SIRCS_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1082 pulse_1_len = SIRCS_1_PULSE_LEN;\r
53c11f07 1083 pause_1_len = SIRCS_PAUSE_LEN - 1;\r
a7054daf 1084 pulse_0_len = SIRCS_0_PULSE_LEN;\r
53c11f07 1085 pause_0_len = SIRCS_PAUSE_LEN - 1;\r
a7054daf 1086 has_stop_bit = SIRCS_STOP_BIT;\r
9547ee89 1087 complete_data_len = SIRCS_MINIMUM_DATA_LEN + sircs_additional_bitlen;\r
a7054daf 1088 n_auto_repetitions = (repeat_counter == 0) ? SIRCS_FRAMES : 1; // 3 frames auto repetition if first frame\r
1089 auto_repetition_pause_len = SIRCS_AUTO_REPETITION_PAUSE_LEN; // 25ms pause\r
1090 repeat_frame_pause_len = SIRCS_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1091 irsnd_set_freq (IRSND_FREQ_40_KHZ);\r
1092 break;\r
1093 }\r
1094#endif\r
1095#if IRSND_SUPPORT_NEC_PROTOCOL == 1\r
1096 case IRMP_NEC_PROTOCOL:\r
1097 {\r
a7054daf 1098 startbit_pulse_len = NEC_START_BIT_PULSE_LEN;\r
1099\r
1100 if (repeat_counter > 0)\r
1101 {\r
53c11f07 1102 startbit_pause_len = NEC_REPEAT_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1103 complete_data_len = 0;\r
1104 }\r
1105 else\r
1106 {\r
53c11f07 1107 startbit_pause_len = NEC_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1108 complete_data_len = NEC_COMPLETE_DATA_LEN;\r
1109 }\r
1110\r
1111 pulse_1_len = NEC_PULSE_LEN;\r
53c11f07 1112 pause_1_len = NEC_1_PAUSE_LEN - 1;\r
a7054daf 1113 pulse_0_len = NEC_PULSE_LEN;\r
53c11f07 1114 pause_0_len = NEC_0_PAUSE_LEN - 1;\r
a7054daf 1115 has_stop_bit = NEC_STOP_BIT;\r
1116 n_auto_repetitions = 1; // 1 frame\r
1117 auto_repetition_pause_len = 0;\r
1118 repeat_frame_pause_len = NEC_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1119 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1120 break;\r
1121 }\r
1122#endif\r
7644ac04 1123#if IRSND_SUPPORT_NEC16_PROTOCOL == 1\r
1124 case IRMP_NEC16_PROTOCOL:\r
1125 {\r
1126 startbit_pulse_len = NEC_START_BIT_PULSE_LEN;\r
1127 startbit_pause_len = NEC_START_BIT_PAUSE_LEN - 1;\r
1128 pulse_1_len = NEC_PULSE_LEN;\r
1129 pause_1_len = NEC_1_PAUSE_LEN - 1;\r
1130 pulse_0_len = NEC_PULSE_LEN;\r
1131 pause_0_len = NEC_0_PAUSE_LEN - 1;\r
1132 has_stop_bit = NEC_STOP_BIT;\r
1133 complete_data_len = NEC16_COMPLETE_DATA_LEN + 1; // 1 more: sync bit\r
1134 n_auto_repetitions = 1; // 1 frame\r
1135 auto_repetition_pause_len = 0;\r
1136 repeat_frame_pause_len = NEC_FRAME_REPEAT_PAUSE_LEN;\r
1137 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1138 break;\r
1139 }\r
1140#endif\r
1141#if IRSND_SUPPORT_NEC42_PROTOCOL == 1\r
1142 case IRMP_NEC42_PROTOCOL:\r
1143 {\r
1144 startbit_pulse_len = NEC_START_BIT_PULSE_LEN;\r
1145 startbit_pause_len = NEC_START_BIT_PAUSE_LEN - 1;\r
1146 pulse_1_len = NEC_PULSE_LEN;\r
1147 pause_1_len = NEC_1_PAUSE_LEN - 1;\r
1148 pulse_0_len = NEC_PULSE_LEN;\r
1149 pause_0_len = NEC_0_PAUSE_LEN - 1;\r
1150 has_stop_bit = NEC_STOP_BIT;\r
1151 complete_data_len = NEC42_COMPLETE_DATA_LEN;\r
1152 n_auto_repetitions = 1; // 1 frame\r
1153 auto_repetition_pause_len = 0;\r
1154 repeat_frame_pause_len = NEC_FRAME_REPEAT_PAUSE_LEN;\r
1155 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1156 break;\r
1157 }\r
1158#endif\r
4225a882 1159#if IRSND_SUPPORT_SAMSUNG_PROTOCOL == 1\r
1160 case IRMP_SAMSUNG_PROTOCOL:\r
1161 {\r
a7054daf 1162 startbit_pulse_len = SAMSUNG_START_BIT_PULSE_LEN;\r
53c11f07 1163 startbit_pause_len = SAMSUNG_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1164 pulse_1_len = SAMSUNG_PULSE_LEN;\r
53c11f07 1165 pause_1_len = SAMSUNG_1_PAUSE_LEN - 1;\r
a7054daf 1166 pulse_0_len = SAMSUNG_PULSE_LEN;\r
53c11f07 1167 pause_0_len = SAMSUNG_0_PAUSE_LEN - 1;\r
a7054daf 1168 has_stop_bit = SAMSUNG_STOP_BIT;\r
1169 complete_data_len = SAMSUNG_COMPLETE_DATA_LEN;\r
1170 n_auto_repetitions = 1; // 1 frame\r
1171 auto_repetition_pause_len = 0;\r
1172 repeat_frame_pause_len = SAMSUNG_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1173 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1174 break;\r
1175 }\r
1176\r
1177 case IRMP_SAMSUNG32_PROTOCOL:\r
1178 {\r
a7054daf 1179 startbit_pulse_len = SAMSUNG_START_BIT_PULSE_LEN;\r
53c11f07 1180 startbit_pause_len = SAMSUNG_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1181 pulse_1_len = SAMSUNG_PULSE_LEN;\r
53c11f07 1182 pause_1_len = SAMSUNG_1_PAUSE_LEN - 1;\r
a7054daf 1183 pulse_0_len = SAMSUNG_PULSE_LEN;\r
53c11f07 1184 pause_0_len = SAMSUNG_0_PAUSE_LEN - 1;\r
a7054daf 1185 has_stop_bit = SAMSUNG_STOP_BIT;\r
1186 complete_data_len = SAMSUNG32_COMPLETE_DATA_LEN;\r
1187 n_auto_repetitions = SAMSUNG32_FRAMES; // 2 frames\r
1188 auto_repetition_pause_len = SAMSUNG32_AUTO_REPETITION_PAUSE_LEN; // 47 ms pause\r
1189 repeat_frame_pause_len = SAMSUNG32_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1190 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1191 break;\r
1192 }\r
1193#endif\r
1194#if IRSND_SUPPORT_MATSUSHITA_PROTOCOL == 1\r
1195 case IRMP_MATSUSHITA_PROTOCOL:\r
1196 {\r
a7054daf 1197 startbit_pulse_len = MATSUSHITA_START_BIT_PULSE_LEN;\r
53c11f07 1198 startbit_pause_len = MATSUSHITA_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1199 pulse_1_len = MATSUSHITA_PULSE_LEN;\r
53c11f07 1200 pause_1_len = MATSUSHITA_1_PAUSE_LEN - 1;\r
a7054daf 1201 pulse_0_len = MATSUSHITA_PULSE_LEN;\r
53c11f07 1202 pause_0_len = MATSUSHITA_0_PAUSE_LEN - 1;\r
a7054daf 1203 has_stop_bit = MATSUSHITA_STOP_BIT;\r
1204 complete_data_len = MATSUSHITA_COMPLETE_DATA_LEN;\r
1205 n_auto_repetitions = 1; // 1 frame\r
1206 auto_repetition_pause_len = 0;\r
1207 repeat_frame_pause_len = MATSUSHITA_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1208 irsnd_set_freq (IRSND_FREQ_36_KHZ);\r
1209 break;\r
1210 }\r
1211#endif\r
770a1a9d 1212#if IRSND_SUPPORT_KASEIKYO_PROTOCOL == 1\r
1213 case IRMP_KASEIKYO_PROTOCOL:\r
1214 {\r
1215 startbit_pulse_len = KASEIKYO_START_BIT_PULSE_LEN;\r
53c11f07 1216 startbit_pause_len = KASEIKYO_START_BIT_PAUSE_LEN - 1;\r
770a1a9d 1217 pulse_1_len = KASEIKYO_PULSE_LEN;\r
53c11f07 1218 pause_1_len = KASEIKYO_1_PAUSE_LEN - 1;\r
770a1a9d 1219 pulse_0_len = KASEIKYO_PULSE_LEN;\r
53c11f07 1220 pause_0_len = KASEIKYO_0_PAUSE_LEN - 1;\r
770a1a9d 1221 has_stop_bit = KASEIKYO_STOP_BIT;\r
1222 complete_data_len = KASEIKYO_COMPLETE_DATA_LEN;\r
1223 n_auto_repetitions = (repeat_counter == 0) ? KASEIKYO_FRAMES : 1; // 2 frames auto repetition if first frame\r
1224 auto_repetition_pause_len = KASEIKYO_AUTO_REPETITION_PAUSE_LEN; // 75 ms pause\r
1225 repeat_frame_pause_len = KASEIKYO_FRAME_REPEAT_PAUSE_LEN;\r
1226 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1227 break;\r
1228 }\r
1229#endif\r
4225a882 1230#if IRSND_SUPPORT_RECS80_PROTOCOL == 1\r
1231 case IRMP_RECS80_PROTOCOL:\r
1232 {\r
a7054daf 1233 startbit_pulse_len = RECS80_START_BIT_PULSE_LEN;\r
53c11f07 1234 startbit_pause_len = RECS80_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1235 pulse_1_len = RECS80_PULSE_LEN;\r
53c11f07 1236 pause_1_len = RECS80_1_PAUSE_LEN - 1;\r
a7054daf 1237 pulse_0_len = RECS80_PULSE_LEN;\r
53c11f07 1238 pause_0_len = RECS80_0_PAUSE_LEN - 1;\r
a7054daf 1239 has_stop_bit = RECS80_STOP_BIT;\r
1240 complete_data_len = RECS80_COMPLETE_DATA_LEN;\r
1241 n_auto_repetitions = 1; // 1 frame\r
1242 auto_repetition_pause_len = 0;\r
1243 repeat_frame_pause_len = RECS80_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1244 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1245 break;\r
1246 }\r
1247#endif\r
1248#if IRSND_SUPPORT_RECS80EXT_PROTOCOL == 1\r
1249 case IRMP_RECS80EXT_PROTOCOL:\r
1250 {\r
a7054daf 1251 startbit_pulse_len = RECS80EXT_START_BIT_PULSE_LEN;\r
53c11f07 1252 startbit_pause_len = RECS80EXT_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1253 pulse_1_len = RECS80EXT_PULSE_LEN;\r
53c11f07 1254 pause_1_len = RECS80EXT_1_PAUSE_LEN - 1;\r
a7054daf 1255 pulse_0_len = RECS80EXT_PULSE_LEN;\r
53c11f07 1256 pause_0_len = RECS80EXT_0_PAUSE_LEN - 1;\r
a7054daf 1257 has_stop_bit = RECS80EXT_STOP_BIT;\r
1258 complete_data_len = RECS80EXT_COMPLETE_DATA_LEN;\r
1259 n_auto_repetitions = 1; // 1 frame\r
1260 auto_repetition_pause_len = 0;\r
1261 repeat_frame_pause_len = RECS80EXT_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1262 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1263 break;\r
1264 }\r
1265#endif\r
1266#if IRSND_SUPPORT_RC5_PROTOCOL == 1\r
1267 case IRMP_RC5_PROTOCOL:\r
1268 {\r
a7054daf 1269 startbit_pulse_len = RC5_BIT_LEN;\r
1270 startbit_pause_len = RC5_BIT_LEN;\r
1271 pulse_len = RC5_BIT_LEN;\r
1272 pause_len = RC5_BIT_LEN;\r
1273 has_stop_bit = RC5_STOP_BIT;\r
1274 complete_data_len = RC5_COMPLETE_DATA_LEN;\r
1275 n_auto_repetitions = 1; // 1 frame\r
1276 auto_repetition_pause_len = 0;\r
1277 repeat_frame_pause_len = RC5_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1278 irsnd_set_freq (IRSND_FREQ_36_KHZ);\r
1279 break;\r
1280 }\r
1281#endif\r
9547ee89 1282#if IRSND_SUPPORT_RC6_PROTOCOL == 1\r
1283 case IRMP_RC6_PROTOCOL:\r
1284 {\r
1285 startbit_pulse_len = RC6_START_BIT_PULSE_LEN;\r
53c11f07 1286 startbit_pause_len = RC6_START_BIT_PAUSE_LEN - 1;\r
9547ee89 1287 pulse_len = RC6_BIT_LEN;\r
1288 pause_len = RC6_BIT_LEN;\r
1289 has_stop_bit = RC6_STOP_BIT;\r
1290 complete_data_len = RC6_COMPLETE_DATA_LEN_SHORT;\r
1291 n_auto_repetitions = 1; // 1 frame\r
1292 auto_repetition_pause_len = 0;\r
1293 repeat_frame_pause_len = RC6_FRAME_REPEAT_PAUSE_LEN;\r
1294 irsnd_set_freq (IRSND_FREQ_36_KHZ);\r
1295 break;\r
1296 }\r
1297#endif\r
1298#if IRSND_SUPPORT_RC6A_PROTOCOL == 1\r
1299 case IRMP_RC6A_PROTOCOL:\r
1300 {\r
1301 startbit_pulse_len = RC6_START_BIT_PULSE_LEN;\r
53c11f07 1302 startbit_pause_len = RC6_START_BIT_PAUSE_LEN - 1;\r
9547ee89 1303 pulse_len = RC6_BIT_LEN;\r
1304 pause_len = RC6_BIT_LEN;\r
1305 has_stop_bit = RC6_STOP_BIT;\r
1306 complete_data_len = RC6_COMPLETE_DATA_LEN_LONG;\r
1307 n_auto_repetitions = 1; // 1 frame\r
1308 auto_repetition_pause_len = 0;\r
1309 repeat_frame_pause_len = RC6_FRAME_REPEAT_PAUSE_LEN;\r
1310 irsnd_set_freq (IRSND_FREQ_36_KHZ);\r
1311 break;\r
1312 }\r
1313#endif\r
4225a882 1314#if IRSND_SUPPORT_DENON_PROTOCOL == 1\r
1315 case IRMP_DENON_PROTOCOL:\r
1316 {\r
a7054daf 1317 startbit_pulse_len = 0x00;\r
1318 startbit_pause_len = 0x00;\r
1319 pulse_1_len = DENON_PULSE_LEN;\r
53c11f07 1320 pause_1_len = DENON_1_PAUSE_LEN - 1;\r
a7054daf 1321 pulse_0_len = DENON_PULSE_LEN;\r
53c11f07 1322 pause_0_len = DENON_0_PAUSE_LEN - 1;\r
a7054daf 1323 has_stop_bit = DENON_STOP_BIT;\r
1324 complete_data_len = DENON_COMPLETE_DATA_LEN;\r
1325 n_auto_repetitions = DENON_FRAMES; // 2 frames, 2nd with inverted command\r
1326 auto_repetition_pause_len = DENON_AUTO_REPETITION_PAUSE_LEN; // 65 ms pause after 1st frame\r
1327 repeat_frame_pause_len = DENON_FRAME_REPEAT_PAUSE_LEN;\r
779fbc81 1328 irsnd_set_freq (IRSND_FREQ_36_KHZ); // in theory 32kHz, in practice 36kHz is better\r
4225a882 1329 break;\r
1330 }\r
1331#endif\r
beda975f 1332#if IRSND_SUPPORT_THOMSON_PROTOCOL == 1\r
1333 case IRMP_THOMSON_PROTOCOL:\r
1334 {\r
1335 startbit_pulse_len = 0x00;\r
1336 startbit_pause_len = 0x00;\r
1337 pulse_1_len = THOMSON_PULSE_LEN;\r
1338 pause_1_len = THOMSON_1_PAUSE_LEN - 1;\r
1339 pulse_0_len = THOMSON_PULSE_LEN;\r
1340 pause_0_len = THOMSON_0_PAUSE_LEN - 1;\r
1341 has_stop_bit = THOMSON_STOP_BIT;\r
1342 complete_data_len = THOMSON_COMPLETE_DATA_LEN;\r
1343 n_auto_repetitions = THOMSON_FRAMES; // only 1 frame\r
1344 auto_repetition_pause_len = THOMSON_AUTO_REPETITION_PAUSE_LEN;\r
1345 repeat_frame_pause_len = DENON_FRAME_REPEAT_PAUSE_LEN;\r
1346 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1347 break;\r
1348 }\r
1349#endif\r
4225a882 1350#if IRSND_SUPPORT_NUBERT_PROTOCOL == 1\r
1351 case IRMP_NUBERT_PROTOCOL:\r
1352 {\r
a7054daf 1353 startbit_pulse_len = NUBERT_START_BIT_PULSE_LEN;\r
53c11f07 1354 startbit_pause_len = NUBERT_START_BIT_PAUSE_LEN - 1;\r
a7054daf 1355 pulse_1_len = NUBERT_1_PULSE_LEN;\r
53c11f07 1356 pause_1_len = NUBERT_1_PAUSE_LEN - 1;\r
a7054daf 1357 pulse_0_len = NUBERT_0_PULSE_LEN;\r
53c11f07 1358 pause_0_len = NUBERT_0_PAUSE_LEN - 1;\r
a7054daf 1359 has_stop_bit = NUBERT_STOP_BIT;\r
1360 complete_data_len = NUBERT_COMPLETE_DATA_LEN;\r
1361 n_auto_repetitions = NUBERT_FRAMES; // 2 frames\r
1362 auto_repetition_pause_len = NUBERT_AUTO_REPETITION_PAUSE_LEN; // 35 ms pause\r
1363 repeat_frame_pause_len = NUBERT_FRAME_REPEAT_PAUSE_LEN;\r
4225a882 1364 irsnd_set_freq (IRSND_FREQ_36_KHZ);\r
1365 break;\r
1366 }\r
5481e9cd 1367#endif\r
1368#if IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL == 1\r
1369 case IRMP_BANG_OLUFSEN_PROTOCOL:\r
1370 {\r
a7054daf 1371 startbit_pulse_len = BANG_OLUFSEN_START_BIT1_PULSE_LEN;\r
53c11f07 1372 startbit_pause_len = BANG_OLUFSEN_START_BIT1_PAUSE_LEN - 1;\r
a7054daf 1373 pulse_1_len = BANG_OLUFSEN_PULSE_LEN;\r
53c11f07 1374 pause_1_len = BANG_OLUFSEN_1_PAUSE_LEN - 1;\r
a7054daf 1375 pulse_0_len = BANG_OLUFSEN_PULSE_LEN;\r
53c11f07 1376 pause_0_len = BANG_OLUFSEN_0_PAUSE_LEN - 1;\r
a7054daf 1377 has_stop_bit = BANG_OLUFSEN_STOP_BIT;\r
1378 complete_data_len = BANG_OLUFSEN_COMPLETE_DATA_LEN;\r
1379 n_auto_repetitions = 1; // 1 frame\r
1380 auto_repetition_pause_len = 0;\r
1381 repeat_frame_pause_len = BANG_OLUFSEN_FRAME_REPEAT_PAUSE_LEN;\r
1382 last_bit_value = 0;\r
5481e9cd 1383 irsnd_set_freq (IRSND_FREQ_455_KHZ);\r
1384 break;\r
1385 }\r
5b437ff6 1386#endif\r
1387#if IRSND_SUPPORT_GRUNDIG_PROTOCOL == 1\r
1388 case IRMP_GRUNDIG_PROTOCOL:\r
1389 {\r
89e8cafb 1390 startbit_pulse_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
1391 startbit_pause_len = GRUNDIG_NOKIA_IR60_PRE_PAUSE_LEN - 1;\r
1392 pulse_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
1393 pause_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
1394 has_stop_bit = GRUNDIG_NOKIA_IR60_STOP_BIT;\r
a7054daf 1395 complete_data_len = GRUNDIG_COMPLETE_DATA_LEN;\r
1396 n_auto_repetitions = GRUNDIG_FRAMES; // 2 frames\r
1397 auto_repetition_pause_len = GRUNDIG_AUTO_REPETITION_PAUSE_LEN; // 20m sec pause\r
89e8cafb 1398 repeat_frame_pause_len = GRUNDIG_NOKIA_IR60_FRAME_REPEAT_PAUSE_LEN; // 117 msec pause\r
d155e9ab 1399 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
a7054daf 1400\r
d155e9ab 1401 break;\r
1402 }\r
1403#endif\r
1404#if IRSND_SUPPORT_NOKIA_PROTOCOL == 1\r
1405 case IRMP_NOKIA_PROTOCOL:\r
1406 {\r
89e8cafb 1407 startbit_pulse_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
1408 startbit_pause_len = GRUNDIG_NOKIA_IR60_PRE_PAUSE_LEN - 1;\r
1409 pulse_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
1410 pause_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
1411 has_stop_bit = GRUNDIG_NOKIA_IR60_STOP_BIT;\r
a7054daf 1412 complete_data_len = NOKIA_COMPLETE_DATA_LEN;\r
f50e01e7 1413 n_auto_repetitions = NOKIA_FRAMES; // 2 frames\r
1414 auto_repetition_pause_len = NOKIA_AUTO_REPETITION_PAUSE_LEN; // 20 msec pause\r
1415 repeat_frame_pause_len = GRUNDIG_NOKIA_IR60_FRAME_REPEAT_PAUSE_LEN; // 117 msec pause\r
d155e9ab 1416 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
5b437ff6 1417 break;\r
1418 }\r
a7054daf 1419#endif\r
1420#if IRSND_SUPPORT_SIEMENS_PROTOCOL == 1\r
1421 case IRMP_SIEMENS_PROTOCOL:\r
1422 {\r
1423 startbit_pulse_len = SIEMENS_BIT_LEN;\r
1424 startbit_pause_len = SIEMENS_BIT_LEN;\r
1425 pulse_len = SIEMENS_BIT_LEN;\r
1426 pause_len = SIEMENS_BIT_LEN;\r
02ccdb69 1427 has_stop_bit = SIEMENS_OR_RUWIDO_STOP_BIT;\r
a7054daf 1428 complete_data_len = SIEMENS_COMPLETE_DATA_LEN - 1;\r
1429 n_auto_repetitions = 1; // 1 frame\r
1430 auto_repetition_pause_len = 0;\r
1431 repeat_frame_pause_len = SIEMENS_FRAME_REPEAT_PAUSE_LEN;\r
1432 irsnd_set_freq (IRSND_FREQ_36_KHZ);\r
1433 break;\r
1434 }\r
b5ea7869 1435#endif\r
48664931 1436#if IRSND_SUPPORT_FDC_PROTOCOL == 1\r
1437 case IRMP_FDC_PROTOCOL:\r
b5ea7869 1438 {\r
48664931 1439 startbit_pulse_len = FDC_START_BIT_PULSE_LEN;\r
53c11f07 1440 startbit_pause_len = FDC_START_BIT_PAUSE_LEN - 1;\r
48664931 1441 complete_data_len = FDC_COMPLETE_DATA_LEN;\r
1442 pulse_1_len = FDC_PULSE_LEN;\r
53c11f07 1443 pause_1_len = FDC_1_PAUSE_LEN - 1;\r
48664931 1444 pulse_0_len = FDC_PULSE_LEN;\r
53c11f07 1445 pause_0_len = FDC_0_PAUSE_LEN - 1;\r
48664931 1446 has_stop_bit = FDC_STOP_BIT;\r
b5ea7869 1447 n_auto_repetitions = 1; // 1 frame\r
1448 auto_repetition_pause_len = 0;\r
48664931 1449 repeat_frame_pause_len = FDC_FRAME_REPEAT_PAUSE_LEN;\r
b5ea7869 1450 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1451 break;\r
1452 }\r
c7c9a4a1 1453#endif\r
1454#if IRSND_SUPPORT_RCCAR_PROTOCOL == 1\r
1455 case IRMP_RCCAR_PROTOCOL:\r
1456 {\r
1457 startbit_pulse_len = RCCAR_START_BIT_PULSE_LEN;\r
53c11f07 1458 startbit_pause_len = RCCAR_START_BIT_PAUSE_LEN - 1;\r
c7c9a4a1 1459 complete_data_len = RCCAR_COMPLETE_DATA_LEN;\r
1460 pulse_1_len = RCCAR_PULSE_LEN;\r
53c11f07 1461 pause_1_len = RCCAR_1_PAUSE_LEN - 1;\r
c7c9a4a1 1462 pulse_0_len = RCCAR_PULSE_LEN;\r
53c11f07 1463 pause_0_len = RCCAR_0_PAUSE_LEN - 1;\r
c7c9a4a1 1464 has_stop_bit = RCCAR_STOP_BIT;\r
1465 n_auto_repetitions = 1; // 1 frame\r
1466 auto_repetition_pause_len = 0;\r
1467 repeat_frame_pause_len = RCCAR_FRAME_REPEAT_PAUSE_LEN;\r
1468 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1469 break;\r
1470 }\r
4225a882 1471#endif\r
c7a47e89 1472#if IRSND_SUPPORT_JVC_PROTOCOL == 1\r
1473 case IRMP_JVC_PROTOCOL:\r
1474 {\r
1475 if (repeat_counter != 0) // skip start bit if repetition frame\r
1476 {\r
1477 current_bit = 0;\r
1478 }\r
1479\r
1480 startbit_pulse_len = JVC_START_BIT_PULSE_LEN;\r
53c11f07 1481 startbit_pause_len = JVC_START_BIT_PAUSE_LEN - 1;\r
c7a47e89 1482 complete_data_len = JVC_COMPLETE_DATA_LEN;\r
1483 pulse_1_len = JVC_PULSE_LEN;\r
53c11f07 1484 pause_1_len = JVC_1_PAUSE_LEN - 1;\r
c7a47e89 1485 pulse_0_len = JVC_PULSE_LEN;\r
53c11f07 1486 pause_0_len = JVC_0_PAUSE_LEN - 1;\r
c7a47e89 1487 has_stop_bit = JVC_STOP_BIT;\r
1488 n_auto_repetitions = 1; // 1 frame\r
1489 auto_repetition_pause_len = 0;\r
1490 repeat_frame_pause_len = JVC_FRAME_REPEAT_PAUSE_LEN;\r
1491 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1492\r
1493 break;\r
1494 }\r
1495#endif\r
9405f84a 1496#if IRSND_SUPPORT_NIKON_PROTOCOL == 1\r
1497 case IRMP_NIKON_PROTOCOL:\r
1498 {\r
1499 startbit_pulse_len = NIKON_START_BIT_PULSE_LEN;\r
53c11f07 1500 startbit_pause_len = 271 - 1; // NIKON_START_BIT_PAUSE_LEN;\r
9405f84a 1501 complete_data_len = NIKON_COMPLETE_DATA_LEN;\r
1502 pulse_1_len = NIKON_PULSE_LEN;\r
53c11f07 1503 pause_1_len = NIKON_1_PAUSE_LEN - 1;\r
9405f84a 1504 pulse_0_len = NIKON_PULSE_LEN;\r
53c11f07 1505 pause_0_len = NIKON_0_PAUSE_LEN - 1;\r
9405f84a 1506 has_stop_bit = NIKON_STOP_BIT;\r
1507 n_auto_repetitions = 1; // 1 frame\r
1508 auto_repetition_pause_len = 0;\r
1509 repeat_frame_pause_len = NIKON_FRAME_REPEAT_PAUSE_LEN;\r
1510 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1511\r
1512 break;\r
1513 }\r
1514#endif\r
f50e01e7 1515#if IRSND_SUPPORT_LEGO_PROTOCOL == 1\r
1516 case IRMP_LEGO_PROTOCOL:\r
1517 {\r
1518 startbit_pulse_len = LEGO_START_BIT_PULSE_LEN;\r
1519 startbit_pause_len = LEGO_START_BIT_PAUSE_LEN - 1;\r
1520 complete_data_len = LEGO_COMPLETE_DATA_LEN;\r
1521 pulse_1_len = LEGO_PULSE_LEN;\r
1522 pause_1_len = LEGO_1_PAUSE_LEN - 1;\r
1523 pulse_0_len = LEGO_PULSE_LEN;\r
1524 pause_0_len = LEGO_0_PAUSE_LEN - 1;\r
1525 has_stop_bit = LEGO_STOP_BIT;\r
1526 n_auto_repetitions = 1; // 1 frame\r
1527 auto_repetition_pause_len = 0;\r
1528 repeat_frame_pause_len = LEGO_FRAME_REPEAT_PAUSE_LEN;\r
1529 irsnd_set_freq (IRSND_FREQ_38_KHZ);\r
1530 break;\r
1531 }\r
1532#endif\r
4225a882 1533 default:\r
1534 {\r
1535 irsnd_busy = FALSE;\r
1536 break;\r
1537 }\r
1538 }\r
1539 }\r
1540 }\r
1541\r
1542 if (irsnd_busy)\r
1543 {\r
1544 new_frame = FALSE;\r
a7054daf 1545\r
4225a882 1546 switch (irsnd_protocol)\r
1547 {\r
1548#if IRSND_SUPPORT_SIRCS_PROTOCOL == 1\r
1549 case IRMP_SIRCS_PROTOCOL:\r
1550#endif\r
1551#if IRSND_SUPPORT_NEC_PROTOCOL == 1\r
1552 case IRMP_NEC_PROTOCOL:\r
1553#endif\r
7644ac04 1554#if IRSND_SUPPORT_NEC16_PROTOCOL == 1\r
1555 case IRMP_NEC16_PROTOCOL:\r
1556#endif\r
1557#if IRSND_SUPPORT_NEC42_PROTOCOL == 1\r
1558 case IRMP_NEC42_PROTOCOL:\r
1559#endif\r
4225a882 1560#if IRSND_SUPPORT_SAMSUNG_PROTOCOL == 1\r
1561 case IRMP_SAMSUNG_PROTOCOL:\r
1562 case IRMP_SAMSUNG32_PROTOCOL:\r
1563#endif\r
1564#if IRSND_SUPPORT_MATSUSHITA_PROTOCOL == 1\r
1565 case IRMP_MATSUSHITA_PROTOCOL:\r
1566#endif\r
770a1a9d 1567#if IRSND_SUPPORT_KASEIKYO_PROTOCOL == 1\r
1568 case IRMP_KASEIKYO_PROTOCOL:\r
1569#endif\r
4225a882 1570#if IRSND_SUPPORT_RECS80_PROTOCOL == 1\r
1571 case IRMP_RECS80_PROTOCOL:\r
1572#endif\r
1573#if IRSND_SUPPORT_RECS80EXT_PROTOCOL == 1\r
1574 case IRMP_RECS80EXT_PROTOCOL:\r
1575#endif\r
1576#if IRSND_SUPPORT_DENON_PROTOCOL == 1\r
1577 case IRMP_DENON_PROTOCOL:\r
1578#endif\r
beda975f 1579#if IRSND_SUPPORT_THOMSON_PROTOCOL == 1\r
1580 case IRMP_THOMSON_PROTOCOL:\r
1581#endif\r
4225a882 1582#if IRSND_SUPPORT_NUBERT_PROTOCOL == 1\r
1583 case IRMP_NUBERT_PROTOCOL:\r
5481e9cd 1584#endif\r
1585#if IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL == 1\r
1586 case IRMP_BANG_OLUFSEN_PROTOCOL:\r
4225a882 1587#endif\r
c7c9a4a1 1588#if IRSND_SUPPORT_FDC_PROTOCOL == 1\r
48664931 1589 case IRMP_FDC_PROTOCOL:\r
b5ea7869 1590#endif\r
c7c9a4a1 1591#if IRSND_SUPPORT_RCCAR_PROTOCOL == 1\r
1592 case IRMP_RCCAR_PROTOCOL:\r
1593#endif\r
c7a47e89 1594#if IRSND_SUPPORT_JVC_PROTOCOL == 1\r
1595 case IRMP_JVC_PROTOCOL:\r
1596#endif\r
9405f84a 1597#if IRSND_SUPPORT_NIKON_PROTOCOL == 1\r
1598 case IRMP_NIKON_PROTOCOL:\r
1599#endif\r
f50e01e7 1600#if IRSND_SUPPORT_LEGO_PROTOCOL == 1\r
1601 case IRMP_LEGO_PROTOCOL:\r
1602#endif\r
a7054daf 1603\r
1604\r
7644ac04 1605#if IRSND_SUPPORT_SIRCS_PROTOCOL == 1 || IRSND_SUPPORT_NEC_PROTOCOL == 1 || IRSND_SUPPORT_NEC16_PROTOCOL == 1 || IRSND_SUPPORT_NEC42_PROTOCOL == 1 || \\r
1606 IRSND_SUPPORT_SAMSUNG_PROTOCOL == 1 || IRSND_SUPPORT_MATSUSHITA_PROTOCOL == 1 || \\r
770a1a9d 1607 IRSND_SUPPORT_KASEIKYO_PROTOCOL == 1 || IRSND_SUPPORT_RECS80_PROTOCOL == 1 || IRSND_SUPPORT_RECS80EXT_PROTOCOL == 1 || IRSND_SUPPORT_DENON_PROTOCOL == 1 || \\r
c7a47e89 1608 IRSND_SUPPORT_NUBERT_PROTOCOL == 1 || IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL == 1 || IRSND_SUPPORT_FDC_PROTOCOL == 1 || IRSND_SUPPORT_RCCAR_PROTOCOL == 1 || \\r
beda975f 1609 IRSND_SUPPORT_JVC_PROTOCOL == 1 || IRSND_SUPPORT_NIKON_PROTOCOL == 1 || IRSND_SUPPORT_LEGO_PROTOCOL == 1 || IRSND_SUPPORT_THOMSON_PROTOCOL == 1 \r
4225a882 1610 {\r
5481e9cd 1611 if (pulse_counter == 0)\r
4225a882 1612 {\r
5481e9cd 1613 if (current_bit == 0xFF) // send start bit\r
1614 {\r
1615 pulse_len = startbit_pulse_len;\r
1616 pause_len = startbit_pause_len;\r
1617 }\r
1618 else if (current_bit < complete_data_len) // send n'th bit\r
4225a882 1619 {\r
5481e9cd 1620#if IRSND_SUPPORT_SAMSUNG_PROTOCOL == 1\r
1621 if (irsnd_protocol == IRMP_SAMSUNG_PROTOCOL)\r
4225a882 1622 {\r
5481e9cd 1623 if (current_bit < SAMSUNG_ADDRESS_LEN) // send address bits\r
1624 {\r
1625 pulse_len = SAMSUNG_PULSE_LEN;\r
1626 pause_len = (irsnd_buffer[current_bit / 8] & (1<<(7-(current_bit % 8)))) ?\r
53c11f07 1627 (SAMSUNG_1_PAUSE_LEN - 1) : (SAMSUNG_0_PAUSE_LEN - 1);\r
5481e9cd 1628 }\r
1629 else if (current_bit == SAMSUNG_ADDRESS_LEN) // send SYNC bit (16th bit)\r
1630 {\r
1631 pulse_len = SAMSUNG_PULSE_LEN;\r
53c11f07 1632 pause_len = SAMSUNG_START_BIT_PAUSE_LEN - 1;\r
5481e9cd 1633 }\r
1634 else if (current_bit < SAMSUNG_COMPLETE_DATA_LEN) // send n'th bit\r
1635 {\r
1636 uint8_t cur_bit = current_bit - 1; // sync skipped, offset = -1 !\r
1637\r
1638 pulse_len = SAMSUNG_PULSE_LEN;\r
1639 pause_len = (irsnd_buffer[cur_bit / 8] & (1<<(7-(cur_bit % 8)))) ?\r
53c11f07 1640 (SAMSUNG_1_PAUSE_LEN - 1) : (SAMSUNG_0_PAUSE_LEN - 1);\r
5481e9cd 1641 }\r
4225a882 1642 }\r
5481e9cd 1643 else\r
1644#endif\r
1645\r
7644ac04 1646#if IRSND_SUPPORT_NEC16_PROTOCOL == 1\r
1647 if (irsnd_protocol == IRMP_NEC16_PROTOCOL)\r
1648 {\r
1649 if (current_bit < NEC16_ADDRESS_LEN) // send address bits\r
1650 {\r
1651 pulse_len = NEC_PULSE_LEN;\r
1652 pause_len = (irsnd_buffer[current_bit / 8] & (1<<(7-(current_bit % 8)))) ?\r
1653 (NEC_1_PAUSE_LEN - 1) : (NEC_0_PAUSE_LEN - 1);\r
1654 }\r
1655 else if (current_bit == NEC16_ADDRESS_LEN) // send SYNC bit (8th bit)\r
1656 {\r
1657 pulse_len = NEC_PULSE_LEN;\r
1658 pause_len = NEC_START_BIT_PAUSE_LEN - 1;\r
1659 }\r
1660 else if (current_bit < NEC16_COMPLETE_DATA_LEN + 1) // send n'th bit\r
1661 {\r
1662 uint8_t cur_bit = current_bit - 1; // sync skipped, offset = -1 !\r
1663\r
1664 pulse_len = NEC_PULSE_LEN;\r
1665 pause_len = (irsnd_buffer[cur_bit / 8] & (1<<(7-(cur_bit % 8)))) ?\r
1666 (NEC_1_PAUSE_LEN - 1) : (NEC_0_PAUSE_LEN - 1);\r
1667 }\r
1668 }\r
1669 else\r
1670#endif\r
1671\r
5481e9cd 1672#if IRSND_SUPPORT_BANG_OLUFSEN_PROTOCOL == 1\r
1673 if (irsnd_protocol == IRMP_BANG_OLUFSEN_PROTOCOL)\r
4225a882 1674 {\r
5481e9cd 1675 if (current_bit == 0) // send 2nd start bit\r
1676 {\r
1677 pulse_len = BANG_OLUFSEN_START_BIT2_PULSE_LEN;\r
53c11f07 1678 pause_len = BANG_OLUFSEN_START_BIT2_PAUSE_LEN - 1;\r
5481e9cd 1679 }\r
1680 else if (current_bit == 1) // send 3rd start bit\r
1681 {\r
1682 pulse_len = BANG_OLUFSEN_START_BIT3_PULSE_LEN;\r
53c11f07 1683 pause_len = BANG_OLUFSEN_START_BIT3_PAUSE_LEN - 1;\r
5481e9cd 1684 }\r
1685 else if (current_bit == 2) // send 4th start bit\r
1686 {\r
1687 pulse_len = BANG_OLUFSEN_START_BIT2_PULSE_LEN;\r
53c11f07 1688 pause_len = BANG_OLUFSEN_START_BIT2_PAUSE_LEN - 1;\r
5481e9cd 1689 }\r
1690 else if (current_bit == 19) // send trailer bit\r
1691 {\r
1692 pulse_len = BANG_OLUFSEN_PULSE_LEN;\r
53c11f07 1693 pause_len = BANG_OLUFSEN_TRAILER_BIT_PAUSE_LEN - 1;\r
5481e9cd 1694 }\r
1695 else if (current_bit < BANG_OLUFSEN_COMPLETE_DATA_LEN) // send n'th bit\r
1696 {\r
1697 uint8_t cur_bit_value = (irsnd_buffer[current_bit / 8] & (1<<(7-(current_bit % 8)))) ? 1 : 0;\r
1698 pulse_len = BANG_OLUFSEN_PULSE_LEN;\r
1699\r
1700 if (cur_bit_value == last_bit_value)\r
1701 {\r
53c11f07 1702 pause_len = BANG_OLUFSEN_R_PAUSE_LEN - 1;\r
5481e9cd 1703 }\r
1704 else\r
1705 {\r
53c11f07 1706 pause_len = cur_bit_value ? (BANG_OLUFSEN_1_PAUSE_LEN - 1) : (BANG_OLUFSEN_0_PAUSE_LEN - 1);\r
5481e9cd 1707 last_bit_value = cur_bit_value;\r
1708 }\r
1709 }\r
4225a882 1710 }\r
5481e9cd 1711 else\r
1712#endif\r
1713 if (irsnd_buffer[current_bit / 8] & (1<<(7-(current_bit % 8))))\r
4225a882 1714 {\r
5481e9cd 1715 pulse_len = pulse_1_len;\r
1716 pause_len = pause_1_len;\r
1717 }\r
1718 else\r
1719 {\r
1720 pulse_len = pulse_0_len;\r
1721 pause_len = pause_0_len;\r
4225a882 1722 }\r
1723 }\r
5481e9cd 1724 else if (has_stop_bit) // send stop bit\r
4225a882 1725 {\r
1726 pulse_len = pulse_0_len;\r
4225a882 1727\r
a7054daf 1728 if (auto_repetition_counter < n_auto_repetitions)\r
5481e9cd 1729 {\r
1730 pause_len = pause_0_len;\r
1731 }\r
1732 else\r
1733 {\r
1734 pause_len = 255; // last frame: pause of 255\r
1735 }\r
4225a882 1736 }\r
1737 }\r
1738\r
1739 if (pulse_counter < pulse_len)\r
1740 {\r
1741 if (pulse_counter == 0)\r
1742 {\r
1743 irsnd_on ();\r
1744 }\r
1745 pulse_counter++;\r
1746 }\r
1747 else if (pause_counter < pause_len)\r
1748 {\r
1749 if (pause_counter == 0)\r
1750 {\r
1751 irsnd_off ();\r
1752 }\r
1753 pause_counter++;\r
1754 }\r
1755 else\r
1756 {\r
1757 current_bit++;\r
1758\r
1759 if (current_bit >= complete_data_len + has_stop_bit)\r
1760 {\r
1761 current_bit = 0xFF;\r
a7054daf 1762 auto_repetition_counter++;\r
4225a882 1763\r
a7054daf 1764 if (auto_repetition_counter == n_auto_repetitions)\r
4225a882 1765 {\r
1766 irsnd_busy = FALSE;\r
a7054daf 1767 auto_repetition_counter = 0;\r
4225a882 1768 }\r
1769 new_frame = TRUE;\r
1770 }\r
1771\r
1772 pulse_counter = 0;\r
1773 pause_counter = 0;\r
1774 }\r
1775 break;\r
1776 }\r
a7054daf 1777#endif\r
1778\r
4225a882 1779#if IRSND_SUPPORT_RC5_PROTOCOL == 1\r
1780 case IRMP_RC5_PROTOCOL:\r
a7054daf 1781#endif\r
9547ee89 1782#if IRSND_SUPPORT_RC6_PROTOCOL == 1\r
1783 case IRMP_RC6_PROTOCOL:\r
1784#endif\r
1785#if IRSND_SUPPORT_RC6A_PROTOCOL == 1\r
1786 case IRMP_RC6A_PROTOCOL:\r
1787#endif\r
a7054daf 1788#if IRSND_SUPPORT_SIEMENS_PROTOCOL == 1\r
1789 case IRMP_SIEMENS_PROTOCOL:\r
1790#endif\r
1791#if IRSND_SUPPORT_GRUNDIG_PROTOCOL == 1\r
1792 case IRMP_GRUNDIG_PROTOCOL:\r
1793#endif\r
1794#if IRSND_SUPPORT_NOKIA_PROTOCOL == 1\r
1795 case IRMP_NOKIA_PROTOCOL:\r
1796#endif\r
4225a882 1797\r
9547ee89 1798#if IRSND_SUPPORT_RC5_PROTOCOL == 1 || IRSND_SUPPORT_RC6_PROTOCOL == 1 || IRSND_SUPPORT_RC6A_PROTOCOL == 1 || IRSND_SUPPORT_SIEMENS_PROTOCOL == 1 || \\r
1799 IRSND_SUPPORT_GRUNDIG_PROTOCOL == 1 || IRSND_SUPPORT_NOKIA_PROTOCOL == 1\r
a7054daf 1800 {\r
1801 if (pulse_counter == pulse_len && pause_counter == pause_len)\r
4225a882 1802 {\r
a7054daf 1803 current_bit++;\r
4225a882 1804\r
a7054daf 1805 if (current_bit >= complete_data_len)\r
4225a882 1806 {\r
a7054daf 1807 current_bit = 0xFF;\r
1808\r
1809#if IRSND_SUPPORT_GRUNDIG_PROTOCOL == 1 || IRSND_SUPPORT_NOKIA_PROTOCOL == 1\r
1810 if (irsnd_protocol == IRMP_GRUNDIG_PROTOCOL || irsnd_protocol == IRMP_NOKIA_PROTOCOL)\r
4225a882 1811 {\r
a7054daf 1812 auto_repetition_counter++;\r
1813\r
1814 if (repeat_counter > 0)\r
1815 { // set 117 msec pause time\r
89e8cafb 1816 auto_repetition_pause_len = GRUNDIG_NOKIA_IR60_FRAME_REPEAT_PAUSE_LEN;\r
a7054daf 1817 }\r
1818\r
1819 if (repeat_counter < n_repeat_frames) // tricky: repeat n info frames per auto repetition before sending last stop frame\r
1820 {\r
1821 n_auto_repetitions++; // increment number of auto repetitions\r
1822 repeat_counter++;\r
1823 }\r
1824 else if (auto_repetition_counter == n_auto_repetitions)\r
1825 {\r
1826 irsnd_busy = FALSE;\r
1827 auto_repetition_counter = 0;\r
1828 }\r
4225a882 1829 }\r
a7054daf 1830 else\r
1831#endif\r
4225a882 1832 {\r
a7054daf 1833 irsnd_busy = FALSE;\r
4225a882 1834 }\r
4225a882 1835\r
4225a882 1836 new_frame = TRUE;\r
1837 irsnd_off ();\r
1838 }\r
1839\r
1840 pulse_counter = 0;\r
1841 pause_counter = 0;\r
1842 }\r
5b437ff6 1843\r
a7054daf 1844 if (! new_frame)\r
5b437ff6 1845 {\r
a7054daf 1846 uint8_t first_pulse;\r
5b437ff6 1847\r
a7054daf 1848#if IRSND_SUPPORT_GRUNDIG_PROTOCOL == 1 || IRSND_SUPPORT_NOKIA_PROTOCOL == 1\r
1849 if (irsnd_protocol == IRMP_GRUNDIG_PROTOCOL || irsnd_protocol == IRMP_NOKIA_PROTOCOL)\r
5b437ff6 1850 {\r
a7054daf 1851 if (current_bit == 0xFF || // start bit of start-frame\r
1852 (irsnd_protocol == IRMP_GRUNDIG_PROTOCOL && current_bit == 15) || // start bit of info-frame (Grundig)\r
1853 (irsnd_protocol == IRMP_NOKIA_PROTOCOL && (current_bit == 23 || current_bit == 47))) // start bit of info- or stop-frame (Nokia)\r
5b437ff6 1854 {\r
a7054daf 1855 pulse_len = startbit_pulse_len;\r
1856 pause_len = startbit_pause_len;\r
1857 first_pulse = TRUE;\r
5b437ff6 1858 }\r
a7054daf 1859 else // send n'th bit\r
5b437ff6 1860 {\r
89e8cafb 1861 pulse_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
1862 pause_len = GRUNDIG_NOKIA_IR60_BIT_LEN;\r
a7054daf 1863 first_pulse = (irsnd_buffer[current_bit / 8] & (1<<(7-(current_bit % 8)))) ? TRUE : FALSE;\r
5b437ff6 1864 }\r
5b437ff6 1865 }\r
9547ee89 1866 else // if (irsnd_protocol == IRMP_RC5_PROTOCOL || irsnd_protocol == IRMP_RC6_PROTOCOL || irsnd_protocol == IRMP_RC6A_PROTOCOL ||\r
1867 // irsnd_protocol == IRMP_SIEMENS_PROTOCOL)\r
a7054daf 1868#endif\r
5b437ff6 1869 {\r
a7054daf 1870 if (current_bit == 0xFF) // 1 start bit\r
1871 {\r
9547ee89 1872#if IRSND_SUPPORT_RC6_PROTOCOL == 1 || IRSND_SUPPORT_RC6A_PROTOCOL == 1\r
1873 if (irsnd_protocol == IRMP_RC6_PROTOCOL || irsnd_protocol == IRMP_RC6A_PROTOCOL)\r
1874 {\r
1875 pulse_len = startbit_pulse_len;\r
1876 pause_len = startbit_pause_len;\r
1877 }\r
1878#endif\r
a7054daf 1879 first_pulse = TRUE;\r
1880 }\r
1881 else // send n'th bit\r
1882 {\r
9547ee89 1883#if IRSND_SUPPORT_RC6_PROTOCOL == 1 || IRSND_SUPPORT_RC6A_PROTOCOL == 1\r
1884 if (irsnd_protocol == IRMP_RC6_PROTOCOL || irsnd_protocol == IRMP_RC6A_PROTOCOL)\r
1885 {\r
1886 pulse_len = RC6_BIT_LEN;\r
1887 pause_len = RC6_BIT_LEN;\r
1888\r
1889 if (irsnd_protocol == IRMP_RC6_PROTOCOL)\r
1890 {\r
1891 if (current_bit == 4) // toggle bit (double len)\r
1892 {\r
1893 pulse_len = 2 * RC6_BIT_LEN;\r
1894 pause_len = 2 * RC6_BIT_LEN;\r
1895 }\r
1896 }\r
1897 else // if (irsnd_protocol == IRMP_RC6A_PROTOCOL)\r
1898 {\r
1899 if (current_bit == 4) // toggle bit (double len)\r
1900 {\r
1901 pulse_len = 2 * RC6_BIT_LEN + RC6_BIT_LEN; // hack!\r
1902 pause_len = 2 * RC6_BIT_LEN;\r
1903 }\r
1904 else if (current_bit == 5) // toggle bit (double len)\r
1905 {\r
1906 pause_len = 2 * RC6_BIT_LEN;\r
1907 }\r
1908 }\r
1909 }\r
1910#endif\r
a7054daf 1911 first_pulse = (irsnd_buffer[current_bit / 8] & (1<<(7-(current_bit % 8)))) ? TRUE : FALSE;\r
1912 }\r
5b437ff6 1913\r
a7054daf 1914 if (irsnd_protocol == IRMP_RC5_PROTOCOL)\r
1915 {\r
1916 first_pulse = first_pulse ? FALSE : TRUE;\r
1917 }\r
1918 }\r
5b437ff6 1919\r
1920 if (first_pulse)\r
1921 {\r
a7054daf 1922 if (pulse_counter < pulse_len)\r
5b437ff6 1923 {\r
1924 if (pulse_counter == 0)\r
1925 {\r
1926 irsnd_on ();\r
1927 }\r
1928 pulse_counter++;\r
1929 }\r
a7054daf 1930 else // if (pause_counter < pause_len)\r
5b437ff6 1931 {\r
1932 if (pause_counter == 0)\r
1933 {\r
1934 irsnd_off ();\r
1935 }\r
1936 pause_counter++;\r
1937 }\r
5b437ff6 1938 }\r
1939 else\r
1940 {\r
a7054daf 1941 if (pause_counter < pause_len)\r
5b437ff6 1942 {\r
1943 if (pause_counter == 0)\r
1944 {\r
1945 irsnd_off ();\r
1946 }\r
1947 pause_counter++;\r
1948 }\r
a7054daf 1949 else // if (pulse_counter < pulse_len)\r
5b437ff6 1950 {\r
1951 if (pulse_counter == 0)\r
1952 {\r
1953 irsnd_on ();\r
1954 }\r
1955 pulse_counter++;\r
1956 }\r
5b437ff6 1957 }\r
1958 }\r
1959 break;\r
1960 }\r
9547ee89 1961#endif // IRSND_SUPPORT_RC5_PROTOCOL == 1 || IRSND_SUPPORT_RC6_PROTOCOL == 1 || || IRSND_SUPPORT_RC6A_PROTOCOL == 1 || IRSND_SUPPORT_SIEMENS_PROTOCOL == 1 ||\r
1962 // IRSND_SUPPORT_GRUNDIG_PROTOCOL == 1 || IRSND_SUPPORT_NOKIA_PROTOCOL == 1\r
5b437ff6 1963\r
4225a882 1964 default:\r
1965 {\r
1966 irsnd_busy = FALSE;\r
1967 break;\r
1968 }\r
1969 }\r
1970 }\r
a7054daf 1971\r
1972 if (! irsnd_busy)\r
1973 {\r
1974 if (repeat_counter < n_repeat_frames)\r
1975 {\r
c7c9a4a1 1976#if IRSND_SUPPORT_FDC_PROTOCOL == 1\r
1977 if (irsnd_protocol == IRMP_FDC_PROTOCOL)\r
1978 {\r
1979 irsnd_buffer[2] |= 0x0F;\r
1980 }\r
1981#endif\r
a7054daf 1982 repeat_counter++;\r
1983 irsnd_busy = TRUE;\r
1984 }\r
1985 else\r
1986 {\r
1987 n_repeat_frames = 0;\r
1988 repeat_counter = 0;\r
1989 }\r
1990 }\r
4225a882 1991 }\r
1992\r
1993#ifdef DEBUG\r
1994 if (irsnd_is_on)\r
1995 {\r
1996 putchar ('0');\r
1997 }\r
1998 else\r
1999 {\r
2000 putchar ('1');\r
2001 }\r
2002#endif\r
2003\r
2004 return irsnd_busy;\r
2005}\r
2006\r
2007#ifdef DEBUG\r
2008\r
2009// main function - for unix/linux + windows only!\r
2010// AVR: see main.c!\r
2011// Compile it under linux with:\r
2012// cc irsnd.c -o irsnd\r
2013//\r
2014// usage: ./irsnd protocol hex-address hex-command >filename\r
2015\r
2016int\r
2017main (int argc, char ** argv)\r
2018{\r
2019 int idx;\r
4225a882 2020 int protocol;\r
2021 int address;\r
2022 int command;\r
4225a882 2023 IRMP_DATA irmp_data;\r
2024\r
a7054daf 2025 if (argc != 4 && argc != 5)\r
4225a882 2026 {\r
a7054daf 2027 fprintf (stderr, "usage: %s protocol hex-address hex-command [repeat] > filename\n", argv[0]);\r
4225a882 2028 return 1;\r
2029 }\r
2030\r
2031 if (sscanf (argv[1], "%d", &protocol) == 1 &&\r
2032 sscanf (argv[2], "%x", &address) == 1 &&\r
2033 sscanf (argv[3], "%x", &command) == 1)\r
2034 {\r
2035 irmp_data.protocol = protocol;\r
2036 irmp_data.address = address;\r
2037 irmp_data.command = command;\r
2038\r
a7054daf 2039 if (argc == 5)\r
2040 {\r
2041 irmp_data.flags = atoi (argv[4]);\r
2042 }\r
2043 else\r
2044 {\r
2045 irmp_data.flags = 0;\r
2046 }\r
2047\r
4225a882 2048 irsnd_init ();\r
2049\r
879b06c2 2050 (void) irsnd_send_data (&irmp_data, TRUE);\r
4225a882 2051\r
a7054daf 2052 while (irsnd_busy)\r
2053 {\r
2054 irsnd_ISR ();\r
2055 }\r
beda975f 2056\r
a7054daf 2057 for (idx = 0; idx < 20; idx++)\r
2058 {\r
2059 irsnd_ISR ();\r
4225a882 2060 }\r
2061\r
2062 putchar ('\n');\r
2063 }\r
2064 else\r
2065 {\r
2066 fprintf (stderr, "%s: wrong arguments\n", argv[0]);\r
2067 return 1;\r
2068 }\r
2069 return 0;\r
2070}\r
2071\r
2072#endif // DEBUG\r