[PATCH wwwdocs] Changes for ARM / AArch64 backends 4.9

Ramana Radhakrishnan ramrad01@arm.com
Thu Apr 10 08:42:00 GMT 2014


4.9 changes for ARM / AArch64. Sorry it's taken me a while to get this 
out but better late than never :)

Ok ?

Ramana
-- 
Ramana Radhakrishnan
Principal Engineer
ARM Ltd.
-------------- next part --------------
Index: htdocs/gcc-4.9/changes.html
===================================================================
RCS file: /cvs/gcc/wwwdocs/htdocs/gcc-4.9/changes.html,v
retrieving revision 1.64
diff -a -u -r1.64 changes.html
--- htdocs/gcc-4.9/changes.html	22 Mar 2014 14:20:02 -0000	1.64
+++ htdocs/gcc-4.9/changes.html	9 Apr 2014 15:00:01 -0000
@@ -437,6 +437,96 @@
 
 <h2 id="targets">New Targets and Target Specific Improvements</h2>
 
+<h3 id="aarch64">AArch64</h3>
+   <ul>
+     <li> The ARMv8-A crypto and CRC instructions are now supported through
+       intrinsics. These are enabled when the architecture supports these
+       and are available through the <code>-march=armv8-a+crc</code>
+       and <code>-march=armv8-a+crypto</code> options.
+     </li>
+     <li> Initial support for ILP32 has now been added to the
+       compiler. This is now available through the command line option
+       <code>-mabi=ilp32</code>. Support for ILP32 is
+       considered experimental as the ABI specification is still beta.
+     </li>
+     <li> Coverage of more of the ISA including the SIMD extensions has
+       been added. The Advanced SIMD intrinsics have also been improved.
+     </li>
+     <li> The new local register allocator (LRA) is now on by default
+       for the AArch64 backend.
+     </li>
+     <li> The REE (Redundant extension elimination) pass has now been enabled
+       by default for the AArch64 backend.
+     </li>
+     <li> Tuning for the Cortex-A53 and Cortex-A57 has been improved.
+     </li>
+     <li> Initial big.LITTLE tuning support for the combination of Cortex-A57
+       and Cortex-A53 was added through the <code>-mcpu=cortex-a57.cortex-a53
+       </code> option.
+     </li>
+     <li> A number of structural changes have been made to both the ARM
+       and AArch64 backends to facilitate improved code-generation.
+     </li>
+   </ul>
+
+<h3 id="arm">ARM</h3>
+     <ul>
+      <li> Use of Advanced SIMD (Neon) for 64-bit scalar computations has been
+	disabled by default. This was found to generate better code in only
+	a small number of cases. It can be turned back on with the
+	<code>-mneon-for-64bits</code> option.
+      </li>
+     <li> Further support for the ARMv8-A architecture, notably implementing
+       the restriction around IT blocks in the Thumb32 instruction set has
+       been added. The <code>-mrestrict-it</code> option can be used with
+       <code>-march=armv7-a</code> or the <code>-march=armv7ve</code> options
+       to make code generation fully compatible with the deprecated instructions
+       in ARMv8-A.
+     </li>
+     <li> Support has now been added for the ARMv7ve variant of the
+       architecture. This can be used by the <code>-march=armv7ve</code> option.
+     </li>
+     <li> The ARMv8-A crypto and CRC instructions are now supported through
+       intrinsics and are available through the <code>-march=armv8-a+crc</code>
+       and <code>mfpu=crypto-neon-fp-armv8</code> options.
+     </li>
+     <li> LRA is now on by default for the ARM target. This can be turned off
+       using the <code>-mno-lra</code> option. This option is purely
+       transitionary command line option and will be removed in a future
+       release. We are interested in any bug reports regarding functional and
+       performance regressions with LRA.
+     </li>
+     <li> A new option <code>-mslow-flash-data</code> to improve performance
+       of programs fetching data on slow flash memory has now been
+       introduced for the ARMv7-M profile cores.
+     </li>
+     <li> A new option <code>-mpic-data-is-text-relative</code> for targets
+       that allows data segments to be relative to text segments has
+       been added. This is on by default for all targets except VxWorks RTP.
+     </li>
+     <li> A number of infrastructural changes have been made to both the ARM
+       and AArch64 backends to facilitate improved code-generation.
+     </li>
+     <li> GCC now supports Cortex-A12 and the Cortex-R7 through the
+       <code>-mcpu=cortex-a12</code> and <code>-mcpu=cortex-r7</code> options.
+     </li>
+     <li> GCC now has tuning for the Cortex-A57 and Cortex-A53
+       through the <code>-mcpu=cortex-a57</code> and <code>-mcpu=cortex-a53
+       </code> options.
+     </li>
+     <li> Initial big.LITTLE tuning support for the combination of Cortex-A57
+       and Cortex-A53 was added through the <code>-mcpu=cortex-a57.cortex-a53
+       </code> option. Similar support was added for the combination of
+       Cortex-A15 and Cortex-A7 through the <code>-mcpu=cortex-a15.cortex-a7
+       </code> option.
+     </li>
+     <li> Further performance optimizations for the Cortex-A15 and the
+       Cortex-M4 have been added.
+     </li>
+     <li>A number of code generation improvements for Thumb2 to reduce code
+       size when compiling for the M-profile processors.
+     </li>
+     </ul>
 <h3 id="x86">IA-32/x86-64</h3>
   <ul>
     <li>Intel AVX-512 support was added to GCC.  That includes inline


More information about the Gcc-patches mailing list