The State Of 64-Bit ARM (AArch64) On LLVM/Clang

Posted by Michael Larabel on November 20, 2012

ARM's AArch64 back-end for LLVM to handle the 64-bit ARMv8 architecture is working, but there's still more work ahead of the hardware's general availability in about one year's time.

There's AArch64 in GCC's code-base with version 4.8 following months of development and its approval by the steering committee. Initial AArch64 architecture support was also merged into the Linux 3.7 kernel. However, on the LLVM/Clang side there hasn't been much public-facing news.

Earlier this month, however, at the LLVM Developers' Meeting in San Jose, ARM Holdings provided an update on their AArch64 back-end. ARM engineers have been working on a 64-bit ARMv8 LLVM back-end targeting ELF output on Linux with an integrated assembler by default, using all of the latest LLVM APIs, strong-testing, and compiling standard-compliant C/C++ code. However, of expressed lower priority were optimizations and not commonly used features of the C and C++ languages. ARM will ultimately focus upon AArch64 compiler optimizations, but for now they just want working executables.

In the San Jose meeting, ARM shared that their C++98 and C99 coverage is now well supported and that SPEC2000 and SPEC2006 tests are being built and running successfully. Self-built Clang and LLVM binaries also pass the regression test suite. There's also NEON work for ARM64 that's still going on, a few failures within the LLVM test-suite, and MC Hammer passing on just scalar instructions.

For the AArch64 back-end so far it required about one and a half months to work on the basic layout, four months for implementing instructions systematically, and about another four months of integration work.

More information on the AArch64 LLVM back-end status can be found from the PDF slides.

Discuss this article in our forums, IRC channel, or email the author. You can also follow our content via RSS and on social networks like Facebook, Identi.ca, and Twitter (@Phoronix and @MichaelLarabel). Subscribe to Phoronix Premium to view our content without advertisements, view entire articles on a single page, and experience other benefits.
Latest Hardware Reviews
  1. Intel Haswell HD Graphics 4600 vs. AMD Radeon Graphics On Linux
  2. Intel Haswell HD Graphics 4600 Performance On Ubuntu Linux
  3. Intel Core i7 4770K "Haswell" Benchmarks On Ubuntu Linux
  4. The First Experience Of Intel Haswell On Linux
Latest Software Articles
  1. Optimized Binaries Provide Great Benefits For Intel Haswell
  2. 11-Way Linux, BSD Platform Comparison
  3. SNA Acceleration Works Great For Intel Core i7 Haswell
  4. The Linux Evolution For Intel Haswell's Performance
Latest Linux News
  1. KDE's KWin Made Lots Of Progress In 4.11
  2. Ubuntu Announces Carrier Advisory Group
  3. Qt 5.1 Release Candidate 1 Has Arrived
  4. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  5. Subversion 1.8 Presents New Features
  6. LLVM 3.3 Officially Released
  7. LLVM/Clang Now Uses Loop Vectorizer At New Levels
  8. Intel GPU Driver Tries To Rip Out FBDEV Support
  9. Coreboot Doing AMD USB 3.0, Q35 QEMU Emulation
  10. VP9 Codec Now Enabled By Default In Chrome
  11. openSUSE 13.1 M2 Plays On PulseAudio 4.0
Latest Forum Talk
  1. The Wayland Situation: Facts About X vs. Wayland
  2. In-Fighting Continues Over Mir On Non-Unity Ubuntu
  3. Intel GPU Driver Tries To Rip Out FBDEV Support
  4. Ubuntu Announces Carrier Advisory Group
  5. Intel Haswell HD Graphics 4600 vs. AMD Radeon...
  6. Planetary Annihilation Plans To Come To Linux
  1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Motherboards
  5. Peripherals
  6. Processors
  7. Software
  8. Operating Systems
  9. All Articles
  1. Linux Benchmarking
  2. OpenBenchmarking.org
  3. Phoronix Test Suite