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. Sumo Lounge Emperor
  2. Gallium3D Continues Improving OpenGL For Older Radeon GPUs
  3. 15-Way Open vs. Closed Source NVIDIA/AMD Linux GPU Comparison
  4. Nouveau vs. NVIDIA Linux Comparison Shows Shortcomings
Latest Software Articles
  1. GCC 4.8.0 vs. LLVM Clang 3.3 Compiler Performance
  2. Intel Linux OpenGL Driver Leading Over Apple OS X
  3. The Cost Of Ubuntu Disk Encryption
  4. Btrfs vs. EXT4 vs. XFS vs. F2FS On Linux 3.10
Latest Linux News
  1. A New X.Org-Free Wayland LiveCD Released
  2. Unity 8, Mir Made Progress This Week On Features
  3. LLVM Clang 3.3 RC2 Is Ready For Testing
  4. AMD RadeonSI Gallium3D Begins Simple CL Demos
  5. Intel Shows Off GNOME3-Based Tizen Shell
  6. Linux Desktop Security Could Be A Whole Lot Better
  7. KDE 4.11 Will Be The Last Major KDE4 Workspaces Feature Release
  8. New NVIDIA Linux Driver Supports The GeForce GTX 780
  9. Chrome 28 To Offer More Speed Improvements
  10. Digia Announces "Boot To Qt" Project
  11. X.Org Libraries Hit By Round Of Security Issues
Latest Forum Talk
  1. AMD RadeonSI Gallium3D Begins Simple CL Demos
  2. A New X.Org-Free Wayland LiveCD Released
  3. X.Org Libraries Hit By Round Of Security Issues
  4. Wayland's Weston Gets Output Scaling Support
  5. GCC 4.8.0 vs. LLVM Clang 3.3 Compiler Performance
  6. Linux's "Ondemand" Governor Is No...
  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