Am 08/11/2015 um 12:04 PM schrieb Klaus Rudolph:
can someone explain how interrupt vectors are handled in gcc internally?

ISR functions are implemented as function attributes, i.e. there are avr-specific function attribute (__interrupt__, __signal__) which turn an ordinary function into an ISR. Main outcome of these attributes is that ./gcc/config/avr/avr.c::avr_expand_prologue() emits a different prologue for ISRs. Similar for avr_expand_epilogue().

Attribute handling like special diagnostics for ISRs is performed by avr_set_current_function().


OK, I saw that in  
/opt/avr_5.2.0/lib/gcc/avr/5.2.0/../../../../avr/lib/avr5/crtatmega32.o

the empty vector table is included, like:

Disassembly of section .vectors:
00000000 <__vectors>:
0:   0c 94 00 00     jmp     0       ; 0x0 <__vectors>
4:   0c 94 00 00     jmp     0       ; 0x0 <__vectors>
8:   0c 94 00 00     jmp     0       ; 0x0 <__vectors>

And I also can see, that my code results in:

Disassembly of section .text:
00000000 <__vector_7>:

The .vectors section is implemented in AVR-LibC's gcrt1.S.
ISR and similar macros are provided by interrupt.h.


but where can I see that __vector_7 goes to the correct place in the table?

To see the macros after expansion compile with -save-temps and read the respective .i file (C) or .ii file (C++).

Johann


_______________________________________________
AVR-GCC-list mailing list
AVR-GCC-list@nongnu.org
https://lists.nongnu.org/mailman/listinfo/avr-gcc-list

Reply via email to