8.1 gnu Object Attributes

The .gnu_attribute directive records an object attribute with vendor gnu.

Except for Tag_compatibility, which has both an integer and a string for its value, gnu attributes have a string value if the tag number is odd and an integer value if the tag number is even. The second bit (tag & 2 is set for architecture-independent attributes and clear for architecture-dependent ones.

8.1.1 Common gnu attributes

These attributes are valid on all architectures.

Tag_compatibility (32)
The compatibility attribute takes an integer flag value and a vendor name. If the flag value is 0, the file is compatible with other toolchains. If it is 1, then the file is only compatible with the named toolchain. If it is greater than 1, the file can only be processed by other toolchains under some private arrangement indicated by the flag value and the vendor name.

8.1.2 MIPS Attributes

Tag_GNU_MIPS_ABI_FP (4)
The floating-point ABI used by this object file. The value will be:
  • 0 for files not affected by the floating-point ABI.
  • 1 for files using the hardware floating-point with a standard double-precision FPU.
  • 2 for files using the hardware floating-point ABI with a single-precision FPU.
  • 3 for files using the software floating-point ABI.
  • 4 for files using the hardware floating-point ABI with 64-bit wide double-precision floating-point registers and 32-bit wide general purpose registers.

8.1.3 PowerPC Attributes

Tag_GNU_Power_ABI_FP (4)
The floating-point ABI used by this object file. The value will be:
  • 0 for files not affected by the floating-point ABI.
  • 1 for files using double-precision hardware floating-point ABI.
  • 2 for files using the software floating-point ABI.
  • 3 for files using single-precision hardware floating-point ABI.

Tag_GNU_Power_ABI_Vector (8)
The vector ABI used by this object file. The value will be:
  • 0 for files not affected by the vector ABI.
  • 1 for files using general purpose registers to pass vectors.
  • 2 for files using AltiVec registers to pass vectors.
  • 3 for files using SPE registers to pass vectors.

The text of the Arduino reference is licensed under a Creative Commons Attribution-ShareAlike 3.0 License. Code samples in the reference are released into the public domain.