1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking Benchmarking Platform
Phoromatic Test Orchestration

LLVM 3.2 Vastly Improves Processor Support

Compiler

Published on 15 December 2012 04:05 AM EST
Written by Michael Larabel in Compiler
Comment On This Article

The soon-to-be-released LLVM 3.2 compiler infrastructure will expand upon its coverage of processor support and CPU capabilities.

Some of the noteworthy improvements to the LLVM 3.2 processor/hardware support includes:

- Minor code-generation improvements for x86 and x86_64.

- With the x86/x86_64 improvements, there's particular improvements around LLVM's support for AVX2. The Advanced Vector Extensions 2, which will premiere with Intel's Haswell processors next year, build upon the AVX support originally introduced in the Sandy Bridge processors. The additions found in Advanced Vector Extensions 2 / Haswell New Instructions include expanding most integer instructions to 256 bits, three-operand general-purpose bit manipulation and multiply, Gather support to enable vector elements to be loaded from non-contiguous memory, DWORD/QDWORD-granularity any-to-any permutes, vector shifts, and three-operand fused multiply-accumulate support.

- Better support for PowerPC processors with LLVM 3.2.

- Support, including performance tuning, for the ARM-based A6 Swift processor. The A6 Swift is Apple's SoC found within the iPhone 5 that is twice as fast as the A5 ARM SoC.

- The LLVM ARM support now includes a full-featured macro assembler. This ARM integrated assembler has support for Thumb1/Thumb2/ARM modes along with VFP2, VFP3, and NEON extensions.

- The MIPS target improvements include integrated assembler support, fast calling convention, an Android MIPS tool-chain for Clang, a MIPS32/MIPS64 disassembler, experimental MIPS32 DSP intrinsics handling, experimental support for MIPS16, and improved register allocation.

Aside from the processor-specific work in LLVM 3.2, this compiler infrastructure update due out this month also features an automatic loop vectorizer, Polly optimizations, and other improvements to be talked about in future Phoronix articles.

About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Articles & Reviews
  1. Turning A Basement Into A Big Linux Server Room
  2. NVIDIA's $1000+ GeForce GTX TITAN X Delivers Maximum Linux Performance
  3. OS X 10.10 vs. Ubuntu 15.04 vs. Fedora 21 Tests: Linux Sweeps The Board
  4. The New Place Where Linux Code Is Constantly Being Benchmarked
  5. 18-GPU NVIDIA/AMD Linux Comparison Of BioShock: Infinite
  6. Phoronix Test Suite 5.6 Adds New Phoromatic Enterprise Benchmarking Features
Latest Linux News
  1. Linux 4.0-rc6 Kernel Released
  2. Automatically Managing The Linux Benchmarks Firing Constantly
  3. The Big Features Of The Linux 4.0 Kernel
  4. Mesa's Android Support Is Currently In Bad Shape
  5. Wayland's Weston Terminal Can Now Be Minimized
  6. Phoronix - Working Towards Faster Page Loads
  7. Improved OpenCL Support For Blender's Cycles Renderer
  8. Mesa 10.5.2 Packs In A Handful Of Fixes
  9. More Fedora/Ubuntu Linux vs. OS X OpenGL Benchmarks
  10. Intel Adds Mesa IR To NIR Translator & Makes Other NIR Improvements
Most Viewed News This Week
  1. Introducing The Library Operating System For Linux
  2. Allwinner Continues Jerking Around The Open-Source Community
  3. Open-Source Driver Fans Will Love NVIDIA's New OpenGL Demo
  4. Systemd Change Allows For Stateless Systems With Tmpfs
  5. GNOME 3.16 Released: It's Their Best Release Yet
  6. GNOME Shell & Mutter 3.16.0 Released
  7. GNU Nano 2.4.0 Brings Complete Undo System, Linter Support & More
  8. Red Hat Is Rolling Out A VirtIO DRM/KMS GPU Driver