Files
clang-p2996/clang/test/CodeGenCXX/pr13396.cpp
Rafael Espindola 06b2b4a7c9 Handle functions with struct arguments or return types and the regparm
attribute. It is a variation of the x86_64 ABI:

* A struct returned indirectly uses the first register argument to pass the
  pointer.
* Floats, Doubles and structs containing only one of them are not passed in
  registers.
* Other structs are split into registers if they fit on the remaining ones.
  Otherwise they are passed in memory.
* When a struct doesn't fit it still consumes the registers.

llvm-svn: 161022
2012-07-31 02:44:24 +00:00

27 lines
880 B
C++

// RUN: %clang_cc1 -triple i686-pc-linux-gnu %s -emit-llvm -o - | FileCheck %s
struct foo {
template<typename T>
__attribute__ ((regparm (3))) foo(T x) {}
__attribute__ ((regparm (3))) foo();
__attribute__ ((regparm (3))) ~foo();
};
foo::foo() {
// CHECK: define void @_ZN3fooC1Ev(%struct.foo* inreg %this)
// CHECK: define void @_ZN3fooC2Ev(%struct.foo* inreg %this)
}
foo::~foo() {
// CHECK: define void @_ZN3fooD1Ev(%struct.foo* inreg %this)
// CHECK: define void @_ZN3fooD2Ev(%struct.foo* inreg %this)
}
void dummy() {
// FIXME: how can we explicitly instantiate a template constructor? Gcc and
// older clangs accept:
// template foo::foo(int x);
foo x(10);
// CHECK: define linkonce_odr void @_ZN3fooC1IiEET_(%struct.foo* inreg %this, i32 inreg %x)
// CHECK: define linkonce_odr void @_ZN3fooC2IiEET_(%struct.foo* inreg %this, i32 inreg %x)
}