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. Sub-$20 802.11n USB WiFi Adapter That's Linux Friendly
  2. The Lenovo T450s Is Working Beautifully With Linux
  3. Linux 4.0 SSD EXT4 / Btrfs / XFS / F2FS Benchmarks
  4. Linux 4.0 Hard Drive Comparison With Six File-Systems
  5. Lenovo ThinkPad T450s Broadwell Preview
  6. How Open-Source Allowed Valve To Implement VULKAN Much Faster On The Source 2 Engine
Latest Linux News
  1. SuperTuxKart 0.9 Released With Its New OpenGL 3 Engine
  2. 6-Disk ZFS On Linux RAID Server Benchmarks
  3. Daily Builds Of Wayland & Weston For Ubuntu Linux
  4. AMD Open-Sources "Addrlib" From Catalyst
  5. AMD Releases New "AMDGPU" Linux Kernel Driver & Mesa Support
  6. A Gigabyte Sandy/Ivy Bridge Motherboard Now Handled By Coreboot
  7. Linux 3.16 Through Linux 4.0 Performance Benchmarks
  8. Intel's Windows Driver Now Supports OpenGL 4.4, Linux Driver Still With OpenGL 3.3
  9. DRM Graphics Updates Sent In For The Linux 4.1 Kernel
  10. More eBPF Improvements Heading To Linux 4.1
Most Viewed News This Week
  1. Nouveau: NVIDIA's New Hardware Is "VERY Open-Source Unfriendly"
  2. LibreOffice 4.5 Bumped To Become LibreOffice 5.0
  3. Linux Audio Is Being Further Modernized With The 4.1 Kernel
  4. KDBUS Is Taking A Lot Of Heat, Might Be Delayed From Mainline Linux Kernel
  5. VirtualBox 5.0 Beta 2 Released
  6. Ubuntu 15.04 Now Under Final Freeze
  7. ZFS & Libdvdcss Should Soon Be In Debian
  8. EXT4 In Linux 4.1 Adds File-System Level Encryption