[LLVMdev] LLVM Weekly - #61, Mar 2nd 2015
asb at asbradbury.org
Mon Mar 2 03:10:18 PST 2015
LLVM Weekly - #61, Mar 2nd 2015
If you prefer, you can read a HTML version of this email at
Welcome to the sixty-first issue of LLVM Weekly, a weekly newsletter
(published every Monday) covering developments in LLVM, Clang, and related
projects. LLVM Weekly is brought to you by [Alex
Bradbury](http://asbradbury.org). Subscribe to future issues at
<http://llvmweekly.org> and pass it on to anyone else you think may be
interested. Please send any tips or feedback to <asb at asbradbury.org>, or
@llvmweekly or @asbradbury on Twitter.
## News and articles from around the web
The biggest headline this week is undoubtedly the release of LLVM/Clang 3.6.
See the [LLVM 3.6 release
notes](http://llvm.org/releases/3.6.0/docs/ReleaseNotes.html) and the [Clang
a full run-down of the major changes.
The [LLVMSharp](http://www.llvmsharp.org/) C# and .NET bindings to LLVM have
Pyston, the LLVM-based Python JIT developed by Dropbox has had its [0.3
It is now minimally self-hosting. You can also see [performance
Readers may enjoy this [walkthrough of creating a basic compiler with
## On the mailing lists
* Diego Novillo has [announced Google's intention to work on PGO profiling
LLVM](http://article.gmane.org/gmane.comp.compilers.llvm.devel/82814). We can
expect a document soon to give more detail on the plans and stimulate further
* Ashutosh Nema is [proposing a new loop versioning
This is where multiple versions of the loop are generated and the
implementation chosen based on runtime memory aliasing tests. It was suggested
that some recent work on Loop Access Analysis provides some of this
* Philip Reames has [suggested writing a performance guide for frontend
Unsurprisingly, the idea is popular.
* Zachary Turner has suggested [separating embedded Python from the rest of
detailed in the post, it is difficult to provide compatibility with the
standard Python binary build for Windows and precompiled Python modules.
* Ahmed Bougacha started a discussion on [disabling
which is currently enabled for ARM and AARch64. Much of the ensuing discussion
centers around understanding why there seems to be a performance degradation
when using GlobalMerge with LTO.
* Katya Romanova moved a [discussion on a jump threading optimisation
llvm-dev. The issue is due to the fact an unreachable block is generated with
ill-formed instruction, and there is a lot of follow on discussion about
whether passes should generate unreachable blocks.
* Dibyendu Majumdar wrote to the list to [ask about issues eliminating
managed to [work out the
## LLVM commits
* Work has started on the move towards opaque pointer types. See the commit
messages for more details and help on migrating existing textual IR.
* The PlaceSafepoints and RewriteGCForStatepoints passes have been documented.
* The GC statepoints documentation has been cleaned up and extended with
example IR, assembly, and stackmaps.
* The loop-invariant code motion pass has been refactored to expose its core
functionality as utility functions that other transformations could use.
* Implementation of support for alloca on MIPS fast-isel has started.
* The PowerPC backend gained support for the QPX vector instruction set.
* InductiveRangeCheckElimination can now handle loops with decreasing
induction variables. [r230618](http://reviews.llvm.org/rL230618).
* Among other improvements, llvm-pdbdump gained colorized output.
* The Forward Control Flow Integrity Pass has been removed as it is being
rethought and is currently unused.
* The Performance Tips for Frontend Authors document was born.
## Clang commits
* The control flow integrity design docs has been updated to document
## Other project commits
* Remote testing support was added to the libc++ and libc++abi test suites.
* LLD learned to understand .gnu.linkonce input sections.
More information about the llvm-dev