AVR Function Attributes (Using the GNU Compiler Collection (GCC)) (original) (raw)

signal

interrupt

The function is an interrupt service routine (ISR). The compiler generates function entry and exit sequences suitable for use in an interrupt handler when one of the attributes is present.

The AVR hardware globally disables interrupts when an interrupt is executed.

The recommended way to use these attributes is by means of theISR macro provided by avr/interrupt.h fromAVR-LibC:

#include <avr/interrupt.h>

ISR (INT0_vect) // Uses the "signal" attribute. { // Code }

ISR (ADC_vect, ISR_NOBLOCK) // Uses the "interrupt" attribute. { // Code }

When both signal and interrupt are specified for the same function, then signal is silently ignored.

naked

This attribute allows the compiler to construct the requisite function declaration, while allowing the body of the function to be assembly code. The specified function will not have prologue/epilogue sequences generated by the compiler. Only basicasm statements can safely be included in naked functions (see Basic Asm — Assembler Instructions Without Operands). While using extended asm or a mixture of basic asm and C code may appear to work, they cannot be depended upon to work reliably and are not supported.

no_gccisr

Do not use the __gcc_isr pseudo instructionin a function with the interrupt or signal attribute aka. interrupt service routine (ISR). Use this attribute if the preamble of the ISR prologue should always read

push zero_reg push tmp_reg in tmp_reg, SREG push tmp_reg clr zero_reg

and accordingly for the postamble of the epilogue — no matter whether the mentioned registers are actually used in the ISR or not. Situations where you might want to use this attribute include:

To disable __gcc_isr generation for the whole compilation unit, there is option -mno-gas-isr-prologues, see AVR Options.

OS_main

OS_task

On AVR, functions with the OS_main or OS_task attribute do not save/restore any call-saved register in their prologue/epilogue.

The OS_main attribute can be used when there is guarantee that interrupts are disabled at the time when the function is entered. This saves resources when the stack pointer has to be changed to set up a frame for local variables.

The OS_task attribute can be used when there is no guarantee that interrupts are disabled at that time when the function is entered like for, e.g. task functions in a multi-threading operating system. In that case, changing the stack pointer register is guarded by save/clear/restore of the global interrupt enable flag.

The differences to the naked function attribute are: