Next: Blackfin Options, Previous: ARM Options, Up: Submodel Options
These options are defined for AVR implementations:
-mmcu=mcuFor a complete list of mcu values that are supported by avr-gcc,
see the compiler output when called with the --help=target
command line option. 
The default for this option is avr2.
     
avr-gcc supports the following AVR devices and ISAs:
avr1at90s1200,
attiny10, attiny11, attiny12, attiny15,
attiny28.
          avr2at90s2313, attiny26, at90c8534,
...
          avr25MOVW instruction. 
attiny2313, attiny261, attiny24,
...
          avr3at43usb355, at76c711.
          avr31atmega103, at43usb320.
          avr35MOVW instruction. 
at90usb162, atmega8u2,
attiny167, ...
          avr4atmega8, atmega88, at90pwm81,
...
          avr5atmega16, atmega6490, at90can64,
...
          avr51atmega128, at90can128, at90usb1287,
...
          avr6atmega2560, atmega2561.
     -maccumulate-argsPopping the arguments after the function call can be expensive on AVR so that accumulating the stack space might lead to smaller executables because arguments need not to be removed from the stack after such a function call.
This option can lead to reduced code size for functions that perform
several calls to functions that get their arguments on the stack like
calls to printf-like functions.
     
-mbranch-cost=cost-mcall-prologues-mint8-mno-interrupts-mrelaxCALL resp. JMP instruction by the shorter
RCALL resp. RJMP instruction if applicable. 
Setting -mrelax just adds the --relax option to the
linker command line when the linker is called.
     Jump relaxing is performed by the linker because jump offsets are not
known before code is located. Therefore, the assembler code generated by the
compiler will be the same, but the instructions in the executable may
differ from instructions in the assembler code.
     
-mshort-callsRCALL/RJMP instructions even on devices with
16 KiB or more of program memory, i.e. on devices that
have the CALL and JMP instructions. 
See also the -mrelax command line option.
     -mstrict-XX in a way proposed by the hardware.  This means
that X will only be used in indirect, post-increment or
pre-decrement addressing.
     Without this option, the X register may be used in the same way
as Y or Z which then is emulated by additional
instructions. 
For example, loading a value with X+const addressing with a
small non-negative const < 64 to a register Rn will be
performed as
     
          adiw r26, const   ; X += const
          ld   Rn, X        ; Rn = *X
          sbiw r26, const   ; X -= const
     
     -mtiny-stackEIND and Devices with more than 128 Ki Bytes of FlashPointers in the implementation are 16 bits wide. The address of a function or label is represented as word address so that indirect jumps and calls can target any code address in the range of 64 Ki words.
In order to facilitate indirect jump on devices with more than 128 Ki
bytes of program memory space, there is a special function register called
EIND that serves as most significant part of the target address
when EICALL or EIJMP instructions are used.
 
Indirect jumps and calls on these devices are handled as follows by the compiler and are subject to some limitations:
EIND.
     EIND. 
Notice that startup code is a blend of code from libgcc and avr-libc. 
For the impact of avr-libc on EIND, see the
avr-libc user manual.
     EIND implicitely in EICALL/EIJMP
instructions or might read EIND directly in order to emulate an
indirect call/jump by means of a RET instruction.
     EIND never changes during the startup
code or during the application. In particular, EIND is not
saved/restored in function or interrupt service routine
prologue/epilogue.
     EIND
early, for example by means of initialization code located in
section .init3. Such code runs prior to general startup code
that initializes RAM and calls constructors.
     gs modifier
(short for generate stubs) like so:
                         LDI r24, lo8(gs(func))
               LDI r25, hi8(gs(func))
          
          gs modifiers for code labels in the
following situations:
          gs() modifier explained above. 
EIND = 0. 
If code is supposed to work for a setup with EIND != 0, a custom
linker script has to be used in order to place the sections whose
name start with .trampolines into the segment where EIND
points to.
               int main (void)
          {
              /* Call function at word address 0x2 */
              return ((int(*)(void)) 0x2)();
          }
     
     Instead, a stub has to be set up, i.e. the function has to be called
through a symbol (func_4 in the example):
     
          int main (void)
          {
              extern int func_4 (void);
          
              /* Call function at byte address 0x4 */
              return func_4();
          }
     
     and the application be linked with -Wl,--defsym,func_4=0x4. 
Alternatively, func_4 can be defined in the linker script. 
avr-gcc defines several built-in macros so that the user code can test
for presence of absence of features.  Almost any of the following
built-in macros are deduced from device capabilities and thus
triggered by the -mmcu= command-line option.
 
For even more AVR-specific built-in macros see AVR Named Address Spaces and AVR Built-in Functions.
__AVR_Device__-mmcu=device defines this built-in macro which reflects
the device's name. For example, -mmcu=atmega8 will define the
built-in macro __AVR_ATmega8__, -mmcu=attiny261a defines
__AVR_ATtiny261A__, etc.
     The built-in macros' names follow
the scheme __AVR_Device__ where Device is
the device name as from the AVR user manual. The difference between
Device in the built-in macro and device in
-mmcu=device is that the latter is always lowercase.
     
__AVR_HAVE_RAMPZ____AVR_HAVE_ELPM__RAMPZ special function register and thus the
ELPM instruction.
     __AVR_HAVE_ELPMX__ELPM Rn,Z and ELPM
Rn,Z+ instructions.
     __AVR_HAVE_MOVW__MOVW instruction to perform 16-bit
register-register moves.
     __AVR_HAVE_LPMX__LPM Rn,Z and LPM
Rn,Z+ instructions.
     __AVR_HAVE_MUL____AVR_HAVE_JMP_CALL__JMP and CALL instructions. 
This is the case for devices with at least 16 KiB of program
memory and if -mshort-calls is not set.
     __AVR_HAVE_EIJMP_EICALL____AVR_3_BYTE_PC__EIJMP and EICALL instructions. 
This is the case for devices with at least 256 KiB of program memory. 
This also means that the program counter
(PC) is 3 bytes wide.
     __AVR_2_BYTE_PC____AVR_HAVE_8BIT_SP____AVR_HAVE_16BIT_SP__-mtiny-stack.
     __NO_INTERRUPTS__-mno-interrupts command line option.
     __AVR_ERRATA_SKIP____AVR_ERRATA_SKIP_JMP_CALL__SBRS, SBRC, SBIS, SBIC and CPSE. 
The second macro is only defined if __AVR_HAVE_JMP_CALL__ is also
set.
     __AVR_SFR_OFFSET__=offsetIN, OUT, SBI, etc. may use a different
address as if addressed by an instruction to access RAM like LD
or STS. This offset depends on the device architecture and has
to be subtracted from the RAM address in order to get the
respective I/O address.