Dmitry Babokin
2013-Oct-03 16:34 UTC
[LLVMdev] "target-features" and "target-cpu" attributes
Bill, Ben, everyone, Some time ago "target-features" and "target-cpu" attributes were introduced. As I understand, they are intended to support generation of "fat binaries" (binaries with functions generated for different CPUs), particularly to support LTO compilation, when different source files have different targets (say, one of files should support SSE2, another one SSE4). Please correct me if I'm wrong in this assumptions. My attempts to utilize this feature fail (I generate LLVM IR directly, I'm not using clang) and this looks very similar to the one described by Benjamin in this mail thread: http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20130218/166710.html So the question - what is the state of supporting fat binaries. Is it expected to work on x86? Thanks in advance, Dmitry. -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20131003/ef082432/attachment.html>
Bill Wendling
2013-Oct-09 20:34 UTC
[LLVMdev] "target-features" and "target-cpu" attributes
On Oct 3, 2013, at 9:34 AM, Dmitry Babokin <babokin at gmail.com> wrote:> Bill, Ben, everyone, > > Some time ago "target-features" and "target-cpu" attributes were introduced. As I understand, they are intended to support generation of "fat binaries" (binaries with functions generated for different CPUs), particularly to support LTO compilation, when different source files have different targets (say, one of files should support SSE2, another one SSE4). Please correct me if I'm wrong in this assumptions. > > My attempts to utilize this feature fail (I generate LLVM IR directly, I'm not using clang) and this looks very similar to the one described by Benjamin in this mail thread: http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20130218/166710.html > > So the question - what is the state of supporting fat binaries. Is it expected to work on x86? >Hi Dmitry, I did it not so much to support fat binaries, but to support correct code generation in LTO. The problem was that it wasn't implemented correctly. Many of the objects that rely upon those features weren't updated when those features were changed. I have a new way of doing this, but it's still in the alpha stage (I haven't yet sent the whitepaper to the group). Support for fat binaries is done on Darwin with the `lipo' command. Otherwise, I'm not sure if this really answers your question. :-) -bw -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20131009/2fd103ac/attachment.html>
Dmitry Babokin
2013-Oct-10 11:22 UTC
[LLVMdev] "target-features" and "target-cpu" attributes
Bill, Thanks for answering. To make sure that we are on the same page, let's agree on definitions :) Here, by fat binaries I mean the binary, where some functions are compiled for one flavor of x86, while others are compiled for another flavor of x86. I care about the usage model, which is important for LTO - a dispatch function (compiled for the least common denominator) + plus set of specialized functions for sse4, avx ,avx2 and etc., which are called by dispatch function depending on runtime cpu id check. lipo may help achieving this on Darwin, but it's not exactly what I need. I need a solution suitable for LTO. Actually lipo may work for me as a workaround, but I need cross platform solution. The current solution doesn't really address this (on x86 at least), as sub-target is not recreated if feature string doesn't match the sub-target. Instead it tries to satisfy feature string requirements using existing sub-target and this leads to the fails, that were noticed by Ben. Please correct me if my understanding is wrong. So do I understand you correctly, that your new solution supposed to solve this problem? Dmitry. On Thu, Oct 10, 2013 at 12:34 AM, Bill Wendling <isanbard at gmail.com> wrote:> On Oct 3, 2013, at 9:34 AM, Dmitry Babokin <babokin at gmail.com> wrote: > > Bill, Ben, everyone, > > Some time ago "target-features" and "target-cpu" attributes were > introduced. As I understand, they are intended to support generation of > "fat binaries" (binaries with functions generated for different CPUs), > particularly to support LTO compilation, when different source files have > different targets (say, one of files should support SSE2, another one > SSE4). Please correct me if I'm wrong in this assumptions. > > My attempts to utilize this feature fail (I generate LLVM IR directly, I'm > not using clang) and this looks very similar to the one described by > Benjamin in this mail thread: > http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20130218/166710.html > > So the question - what is the state of supporting fat binaries. Is it > expected to work on x86? > > Hi Dmitry, > > I did it not so much to support fat binaries, but to support correct code > generation in LTO. The problem was that it wasn't implemented correctly. > Many of the objects that rely upon those features weren't updated when > those features were changed. I have a new way of doing this, but it's still > in the alpha stage (I haven't yet sent the whitepaper to the group). > > Support for fat binaries is done on Darwin with the `lipo' command. > Otherwise, I'm not sure if this really answers your question. :-) > > -bw > > >-------------- next part -------------- An HTML attachment was scrubbed... URL: <http://lists.llvm.org/pipermail/llvm-dev/attachments/20131010/f78e3c17/attachment.html>
Apparently Analagous Threads
- [LLVMdev] "target-features" and "target-cpu" attributes
- [LLVMdev] "target-features" and "target-cpu" attributes
- [LLVMdev] "target-features" and "target-cpu" attributes
- [LLVMdev] "target-features" and "target-cpu" attributes
- [LLVMdev] "target-features" and "target-cpu" attributes