[LLVMdev] struct as a function argument

Domagoj Babic babic.domagoj at gmail.com
Tue Oct 2 10:28:19 PDT 2007


Chris,

Thank you for quick reply. Much appreciated.

Domagoj

On 10/2/07, Chris Lattner <sabre at nondot.org> wrote:
> On Oct 2, 2007, at 1:03 AM, Domagoj Babic wrote:
> > Hi all,
> >
> > I have the same problem. My guess is that when a structure
> > is passed as a parameter, you cast it into an array for optimization
> > reasons (less parameters, less stack space).
>
> This is not an optimization.  This behavior is to be ABI complaint
> when emitting code for your OS.
>
> That said, this is not a very good way to do this.  Rafael is working
> on adding the 'byref' attribute which will support this much more
> gracefully in the future.
>
> > This is, certainly, a reasonable optimization, but makes
> > inter-procedural static analysis more complex. Is there a way to
> > disable it (my guess is that this should be doable by passing
> > some parameter to llvm-gcc)?
>
> The easiest way to disable this is to hack it out of llvm-gcc.
> Change this (gcc/llvm-abi.h):
>
> #ifndef LLVM_SHOULD_PASS_AGGREGATE_IN_INTEGER_REGS
> #define LLVM_SHOULD_PASS_AGGREGATE_IN_INTEGER_REGS(X) \
>     !isSingleElementStructOrArray(type)
> #endif
>
> to:
>
> #undef LLVM_SHOULD_PASS_AGGREGATE_IN_INTEGER_REGS
> #define LLVM_SHOULD_PASS_AGGREGATE_IN_INTEGER_REGS(X) 0
>
> Note that you won't be able to mix and match .o files with GCC where
> structs are passed by value.
>
> -Chris
> _______________________________________________
> LLVM Developers mailing list
> LLVMdev at cs.uiuc.edu         http://llvm.cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev
>



More information about the llvm-dev mailing list