SPRU514Z July 2001 – October 2023 SM320F28335-EP
The following GCC function attributes are supported:
The following additional TI-specific function attributes are supported:
For example, this function declaration uses the alias attribute to make "my_alias" a function alias for the "myFunc" function:
void my_alias() __attribute__((alias("myFunc")));
The aligned function attribute aligns the function using the specified alignment. The alignment must be a power of 2. This attribute has the same effect as the CODE_ALIGN pragma; see Section 6.9.3.
The always_inline function attribute has the same effect as the FUNC_ALWAYS_INLINE pragma. See Section 6.9.11
The calls attribute has the same effect as the CALLS pragma, which is described in Section 6.9.1.
The format attribute is applied to the declarations of printf, fprintf, sprintf, snprintf, vprintf, vfprintf, vsprintf, vsnprintf, scanf, fscanf, vfscanf, vscanf, vsscanf, and sscanf in stdio.h. Thus when GCC extensions are enabled, the data arguments of these functions are type checked against the format specifiers in the format string argument and warnings are issued when there is a mismatch. These warnings can be suppressed in the usual ways if they are not desired.
See Section 6.9.15 for more about using the interrupt function attribute.
The malloc attribute is applied to the declarations of malloc, calloc, realloc and memalign in stdlib.h.
The naked attribute identifies functions written as embedded assembly functions
using __asm
statements. The compiler does not generate prologue and
epilog sequences for such functions. See Section 6.8.
The noinline function attribute has the same effect as the FUNC_CANNOT_INLINE pragma. See Section 6.9.12
The ramfunc attribute specifies that a function will be placed in and executed from RAM. The ramfunc attribute allows the compiler to optimize functions for RAM execution, as well as to automatically copy functions to RAM on flash-based devices. For example:
__attribute__((ramfunc))
void f(void) {
...
}
The --ramfunc=on option specifies that all functions compiled with this option are placed in and executed from RAM, even if this function attribute is not used.
Newer TI linker command files support the ramfunc attribute automatically by placing functions with this attribute in the .TI.ramfunc section. If you have a linker command file that does not include a section specification for the .TI.ramfunc section, you can modify the linker command file to place this section in RAM. See the TMS320C28x Assembly Language Tools User's Guide for details on section placement.
Fast branch instructions are generated for ramfunc functions. Regular branch instructions are generated for all other functions.
The ramfunc attribute is ignored by the CLA compiler.
The retain attribute has the same effect as the RETAIN pragma (Section 6.9.22). That is, the section that contains the function will not be omitted from conditionally linked output even if it is not referenced elsewhere in the application.
The section attribute when used on a function has the same effect as the CODE_SECTION pragma. See Section 6.9.4
The weak attribute has the same effect as the WEAK pragma (Section 6.9.25).