[LLVMdev] Build Attributes Proposal

Bob Wilson bob.wilson at apple.com
Fri Nov 12 11:53:31 PST 2010


On Nov 12, 2010, at 10:13 AM, Devang Patel wrote:

> 
> On Nov 12, 2010, at 8:20 AM, Duncan Sands wrote:
> 
>> Hi Renato,
>> 
>>> So, after long rounds to define how the build attributes are going to
>>> be represented in IR, and after Jason has implemented build attributes
>>> in MC, I have a proposal on how to represent this in IR.
>>> 
>>> First, we need to distinguish between target dependent and independent
>>> attributes. Generic things like optimization level, specific
>>> optimizations, use of vector instructions, use of exceptions,
>>> floating-point compatibility can all go in to the generic list of
>>> attributes.
>> 
>> I don't see why you would want to put any of these things in the module
>> at all:
> 
> In fact they are more suitable as function attributes. For example, we already have function attributes for -Os.

I think some of this discussion is missing the context.  ARM has defined per-object file build attributes to record things like the optimization level, whether the code is ARM vs. Thumb, etc.  This is not something new nor is it specific to LLVM.  As far as I know, the linker is not obligated to do anything with this information, but compilers that follow ARM's specifications are expected to provide it.

Putting the build attributes on individual functions is not a good match for the final result, which is a single set of attributes for the entire object file.  If you put separate attributes on the functions, then code gen will have to scan all the functions to see if they have the same attribute values.



More information about the llvm-dev mailing list