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
27 lines
880 B
C++
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)
|
|
}
|