forked from OSchip/llvm-project
Darwin x86_32: When coercing a "single element" structure, make sure
to use a wide enough type. This might be wider than the "single element"'s type in the presence of padding bit-fields. - Darwin x86_32 now passes the first 1k ABI tests with bit-field generation enabled. llvm-svn: 71270
This commit is contained in:
parent
8881780832
commit
4752783057
|
@ -404,15 +404,19 @@ ABIArgInfo X86_32ABIInfo::classifyReturnType(QualType RetTy,
|
|||
// Classify "single element" structs as their element type.
|
||||
if (const Type *SeltTy = isSingleElementStruct(RetTy, Context)) {
|
||||
if (const BuiltinType *BT = SeltTy->getAsBuiltinType()) {
|
||||
// FIXME: This is gross, it would be nice if we could just
|
||||
// pass back SeltTy and have clients deal with it. Is it worth
|
||||
// supporting coerce to both LLVM and clang Types?
|
||||
if (BT->isIntegerType()) {
|
||||
uint64_t Size = Context.getTypeSize(SeltTy);
|
||||
// We need to use the size of the structure, padding
|
||||
// bit-fields can adjust that to be larger than the single
|
||||
// element type.
|
||||
uint64_t Size = Context.getTypeSize(RetTy);
|
||||
return ABIArgInfo::getCoerce(llvm::IntegerType::get((unsigned) Size));
|
||||
} else if (BT->getKind() == BuiltinType::Float) {
|
||||
assert(Context.getTypeSize(RetTy) == Context.getTypeSize(SeltTy) &&
|
||||
"Unexpect single element structure size!");
|
||||
return ABIArgInfo::getCoerce(llvm::Type::FloatTy);
|
||||
} else if (BT->getKind() == BuiltinType::Double) {
|
||||
assert(Context.getTypeSize(RetTy) == Context.getTypeSize(SeltTy) &&
|
||||
"Unexpect single element structure size!");
|
||||
return ABIArgInfo::getCoerce(llvm::Type::DoubleTy);
|
||||
}
|
||||
} else if (SeltTy->isPointerType()) {
|
||||
|
|
|
@ -133,4 +133,10 @@ struct s30 { char a; char b : 4; } f30(void) {}
|
|||
// RUN: grep 'define float @f31()' %t &&
|
||||
struct s31 { char : 0; float b; char : 0} f31(void) {}
|
||||
|
||||
// RUN: grep 'define i32 @f32()' %t &&
|
||||
struct s32 { char a; unsigned : 0; } f32(void) {}
|
||||
|
||||
// RUN: grep 'define float @f33()' %t &&
|
||||
struct s33 { float a; long long : 0; } f33(void) {}
|
||||
|
||||
// RUN: true
|
||||
|
|
Loading…
Reference in New Issue