]> cloudbase.mooo.com Git - irmp.git/blobdiff - main.c
Version 2.3.4: improved detection of DENON frame repetition per key
[irmp.git] / main.c
diff --git a/main.c b/main.c
index 2327ac6bc5adda3e94dbbc7229c2e0c27736a0ae..88deb316a552749ff72f708e8147bf30fa0d11f7 100644 (file)
--- a/main.c
+++ b/main.c
@@ -3,11 +3,12 @@
  *\r
  * Copyright (c) 2009-2012 Frank Meyer - frank(at)fli4l.de\r
  *\r
- * $Id: main.c,v 1.15 2012/11/18 17:51:26 fm Exp $\r
+ * $Id: main.c,v 1.16 2012/12/06 08:49:33 fm Exp $\r
  *\r
- * ATMEGA88 @ 8 MHz\r
+ * This demo module is runnable on AVRs and LM4F120 Launchpad (ARM Cortex M4)\r
  *\r
- * Fuses: lfuse: 0xE2 hfuse: 0xDC efuse: 0xF9\r
+ * ATMEGA88 @ 8 MHz internal RC      Osc with BODLEVEL 4.3V: lfuse: 0xE2 hfuse: 0xDC efuse: 0xF9\r
+ * ATMEGA88 @ 8 MHz external Crystal Osc with BODLEVEL 4.3V: lfuse: 0xFF hfuse: 0xDC efuse: 0xF9\r
  *\r
  * This program is free software; you can redistribute it and/or modify\r
  * it under the terms of the GNU General Public License as published by\r
 #error F_CPU unkown\r
 #endif\r
 \r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ * ATMEL AVR part:\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+#if defined (ATMEL_AVR)\r
+\r
 void\r
 timer1_init (void)\r
 {\r
@@ -35,59 +42,89 @@ timer1_init (void)
     TCCR1   = (1 << CTC1) | (1 << CS11) | (1 << CS10);                      // switch CTC Mode on, set prescaler to 4\r
 #endif\r
 \r
-#elif defined(STELLARIS_ARM_CORTEX_M4)\r
-    SysCtlPeripheralEnable(SYSCTL_PERIPH_TIMER1);\r
-    TimerConfigure(TIMER1_BASE, TIMER_CFG_32_BIT_PER);\r
-\r
-    TimerLoadSet(TIMER1_BASE, TIMER_A, (F_CPU / F_INTERRUPTS) -1);\r
-    IntEnable(INT_TIMER1A);\r
-    TimerIntEnable(TIMER1_BASE, TIMER_TIMA_TIMEOUT);\r
-    TimerEnable(TIMER1_BASE, TIMER_A);\r
-    // Important: Timer1IntHandler has to be configured in startup_ccs.c !\r
 #else                                                                       // ATmegaXX:\r
     OCR1A   =  (F_CPU / F_INTERRUPTS) - 1;                                  // compare value: 1/15000 of CPU frequency\r
     TCCR1B  = (1 << WGM12) | (1 << CS10);                                   // switch CTC Mode on, set prescaler to 1\r
 #endif\r
 \r
-#if (!defined(STELLARIS_ARM_CORTEX_M4))\r
-#  ifdef TIMSK1\r
+#ifdef TIMSK1\r
     TIMSK1  = 1 << OCIE1A;                                                  // OCIE1A: Interrupt by timer compare\r
-#  else\r
+#else\r
     TIMSK   = 1 << OCIE1A;                                                  // OCIE1A: Interrupt by timer compare\r
-#  endif\r
 #endif\r
 }\r
 \r
-/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
- * Timer 1 output compare A interrupt service routine, called every 1/15000 sec\r
- *---------------------------------------------------------------------------------------------------------------------------------------------------\r
- */\r
 #ifdef TIM1_COMPA_vect                                                      // ATtiny84\r
-ISR(TIM1_COMPA_vect)\r
-#elif defined(STELLARIS_ARM_CORTEX_M4)\r
-void Timer1IntHandler(void)\r
+#define COMPA_VECT  TIM1_COMPA_vect\r
 #else\r
-ISR(TIMER1_COMPA_vect)\r
+#define COMPA_VECT  TIMER1_COMPA_vect                                       // ATmega\r
 #endif\r
+\r
+ISR(COMPA_VECT)                                                             // Timer1 output compare A interrupt service routine, called every 1/15000 sec\r
 {\r
   (void) irmp_ISR();                                                        // call irmp ISR\r
   // call other timer interrupt routines...\r
 }\r
 \r
+int\r
+main (void)\r
+{\r
+    IRMP_DATA irmp_data;\r
+\r
+    irmp_init();                                                            // initialize irmp\r
+    timer1_init();                                                          // initialize timer1\r
+    sei ();                                                                 // enable interrupts\r
+\r
+    for (;;)\r
+    {\r
+        if (irmp_get_data (&irmp_data))\r
+        {\r
+            // ir signal decoded, do something here...\r
+            // irmp_data.protocol is the protocol, see irmp.h\r
+            // irmp_data.address is the address/manufacturer code of ir sender\r
+            // irmp_data.command is the command code\r
+            // irmp_protocol_names[irmp_data.protocol] is the protocol name (if enabled, see irmpconfig.h)\r
+        }\r
+    }\r
+}\r
+\r
+/*---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ * LM4F120 Launchpad (ARM Cortex M4):\r
+ *---------------------------------------------------------------------------------------------------------------------------------------------------\r
+ */\r
+#elif defined(STELLARIS_ARM_CORTEX_M4)\r
+\r
+void\r
+timer1_init (void)\r
+{\r
+    SysCtlPeripheralEnable(SYSCTL_PERIPH_TIMER1);\r
+    TimerConfigure(TIMER1_BASE, TIMER_CFG_32_BIT_PER);\r
+\r
+    TimerLoadSet(TIMER1_BASE, TIMER_A, (F_CPU / F_INTERRUPTS) -1);\r
+    IntEnable(INT_TIMER1A);\r
+    TimerIntEnable(TIMER1_BASE, TIMER_TIMA_TIMEOUT);\r
+    TimerEnable(TIMER1_BASE, TIMER_A);\r
+    // Important: Timer1IntHandler has to be configured in startup_ccs.c !\r
+}\r
+\r
+void\r
+Timer1IntHandler(void)                                                      // Timer1 Interrupt Handler\r
+{\r
+  (void) irmp_ISR();                                                        // call irmp ISR\r
+  // call other timer interrupt routines...\r
+}\r
 \r
 int\r
 main (void)\r
 {\r
     IRMP_DATA irmp_data;\r
 \r
-#if defined(STELLARIS_ARM_CORTEX_M4)\r
     ROM_FPUEnable();\r
     ROM_FPUStackingEnable();\r
     ROM_SysCtlClockSet(SYSCTL_SYSDIV_5|SYSCTL_USE_PLL|SYSCTL_XTAL_16MHZ|SYSCTL_OSC_MAIN);\r
-#endif\r
 \r
     irmp_init();                                                            // initialize irmp\r
-    timer1_init();                                                          // initialize timer 1\r
+    timer1_init();                                                          // initialize timer1\r
     sei ();                                                                 // enable interrupts\r
 \r
     for (;;)\r
@@ -102,3 +139,5 @@ main (void)
         }\r
     }\r
 }\r
+\r
+#endif\r