]>
Commit | Line | Data |
---|---|---|
4225a882 | 1 | /*---------------------------------------------------------------------------------------------------------------------------------------------------\r |
775fabfa | 2 | * irsndmain.c - demo main module to test IRSND encoder on AVRs\r |
4225a882 | 3 | *\r |
ea29682a | 4 | * Copyright (c) 2010-2016 Frank Meyer - frank(at)fli4l.de\r |
4225a882 | 5 | *\r |
775fabfa | 6 | * ATMEGA88 @ 8 MHz internal RC Osc with BODLEVEL 4.3V: lfuse: 0xE2 hfuse: 0xDC efuse: 0xF9\r |
7 | * ATMEGA88 @ 8 MHz external Crystal Osc with BODLEVEL 4.3V: lfuse: 0xFF hfuse: 0xDC efuse: 0xF9\r | |
4225a882 | 8 | *\r |
9 | * This program is free software; you can redistribute it and/or modify\r | |
10 | * it under the terms of the GNU General Public License as published by\r | |
11 | * the Free Software Foundation; either version 2 of the License, or\r | |
12 | * (at your option) any later version.\r | |
13 | *---------------------------------------------------------------------------------------------------------------------------------------------------\r | |
14 | */\r | |
4225a882 | 15 | #include "irsnd.h"\r |
16 | \r | |
4225a882 | 17 | #ifndef F_CPU\r |
061e654c | 18 | # error F_CPU unknown\r |
4225a882 | 19 | #endif\r |
20 | \r | |
21 | void\r | |
1f54e86c | 22 | timer1_init (void)\r |
4225a882 | 23 | {\r |
476267f4 | 24 | #if defined (__AVR_ATtiny45__) || defined (__AVR_ATtiny85__) // ATtiny45 / ATtiny85:\r |
b743217b | 25 | OCR1C = (F_CPU / F_INTERRUPTS / 4) - 1; // compare value: 1/15000 of CPU frequency, presc = 4\r |
476267f4 | 26 | TCCR1 = (1 << CTC1) | (1 << CS11) | (1 << CS10); // switch CTC Mode on, set prescaler to 4\r |
27 | #else // ATmegaXX:\r | |
28 | OCR1A = (F_CPU / F_INTERRUPTS) - 1; // compare value: 1/15000 of CPU frequency\r | |
29 | TCCR1B = (1 << WGM12) | (1 << CS10); // switch CTC Mode on, set prescaler to 1\r | |
1f54e86c | 30 | #endif\r |
4225a882 | 31 | \r |
1f54e86c | 32 | #ifdef TIMSK1\r |
476267f4 | 33 | TIMSK1 = 1 << OCIE1A; // OCIE1A: Interrupt by timer compare\r |
4225a882 | 34 | #else\r |
476267f4 | 35 | TIMSK = 1 << OCIE1A; // OCIE1A: Interrupt by timer compare\r |
1f54e86c | 36 | #endif\r |
4225a882 | 37 | }\r |
38 | \r | |
775fabfa | 39 | #ifdef TIM1_COMPA_vect // ATtiny84\r |
40 | #define COMPA_VECT TIM1_COMPA_vect\r | |
41 | #else\r | |
42 | #define COMPA_VECT TIMER1_COMPA_vect // ATmega\r | |
43 | #endif\r | |
44 | \r | |
4225a882 | 45 | /*---------------------------------------------------------------------------------------------------------------------------------------------------\r |
46 | * timer 1 compare handler, called every 1/10000 sec\r | |
47 | *---------------------------------------------------------------------------------------------------------------------------------------------------\r | |
48 | */\r | |
775fabfa | 49 | ISR(COMPA_VECT) // Timer1 output compare A interrupt service routine, called every 1/15000 sec\r |
4225a882 | 50 | {\r |
51 | (void) irsnd_ISR(); // call irsnd ISR\r | |
1f54e86c | 52 | // call other timer interrupt routines here...\r |
4225a882 | 53 | }\r |
54 | \r | |
55 | /*---------------------------------------------------------------------------------------------------------------------------------------------------\r | |
56 | * MAIN: main routine\r | |
57 | *---------------------------------------------------------------------------------------------------------------------------------------------------\r | |
58 | */\r | |
4225a882 | 59 | int\r |
60 | main (void)\r | |
61 | {\r | |
1f54e86c | 62 | IRMP_DATA irmp_data;\r |
63 | \r | |
775fabfa | 64 | irsnd_init(); // initialize irsnd\r |
65 | timer1_init(); // initialize timer\r | |
66 | sei (); // enable interrupts\r | |
1f54e86c | 67 | \r |
68 | for (;;)\r | |
69 | {\r | |
775fabfa | 70 | irmp_data.protocol = IRMP_NEC_PROTOCOL; // use NEC protocol\r |
71 | irmp_data.address = 0x00FF; // set address to 0x00FF\r | |
72 | irmp_data.command = 0x0001; // set command to 0x0001\r | |
73 | irmp_data.flags = 0; // don't repeat frame\r | |
1f54e86c | 74 | \r |
775fabfa | 75 | irsnd_send_data (&irmp_data, TRUE); // send frame, wait for completion\r |
1f54e86c | 76 | _delay_ms (1000);\r |
77 | }\r | |
4225a882 | 78 | }\r |