5.8 Supporting Interrupts for AVR® Devices
This section demonstrates how to enable interrupts in the bootloader and application code for AVR® devices.
Description: It is always recommended to avoid using interrupts in the bootloader code, when possible, to avoid errors due to complexity, but user applications can freely support interrupts. Enabling interrupts for AVR devices in the application space is as simple as setting up the interrupt sources and creating the desired functionality. There are no additional steps required within the bootloader project in order to achieve basic interrupt support in the application space. The following section will walk through the setup of an application that is blinking the LED using a timer interrupt instead of using the delay driver.
- Set the bootloader project as the main project. From the Projects tab, right click on the project folder and select Set as Main Project.
- Open MCC by clicking the icon in the toolbar.
- Open the Interrupt Manager tab and enable the sliders for Global Interrupt Enable and Interrupt Vector Select Enable.
- Set the application project as the main project. From the Projects tab, right click on the project folder and select Set as Main Project.
- Open MCC by clicking the icon in the toolbar.
- Navigate to the Project Resources tab, and click the red x-box next to the Delay module.
- Navigate to the Device Resources
tab and add the TCA0 driver.
- Setup the TCA0 driver to use a time-out of 150 ms or more and then enable the Overflow Interrupt.
- Notice that once the Overflow Interrupt is enabled, there is a notification for enabling global interrupts. Navigate to the Interrupt Manager tab and flip the switch for Global Interrupt Enable.
- Generate the new timer code and observe the new files being generated in the Output window.
- Lastly, update the
main.c
to blink the LED using the overflow interrupt callback. Remove the calls to the Delay driver and update themain.c
similar to the example below.