forked from OSchip/llvm-project
Don't do SRA for unions with long double fields.
Fixes a SWB crash. llvm-svn: 42422
This commit is contained in:
parent
f91d1c92ba
commit
1d1d0e7735
|
@ -905,6 +905,9 @@ static bool MergeInType(const Type *In, const Type *&Accum,
|
||||||
case Type::PointerTyID: Accum = TD.getIntPtrType(); break;
|
case Type::PointerTyID: Accum = TD.getIntPtrType(); break;
|
||||||
case Type::FloatTyID: Accum = Type::Int32Ty; break;
|
case Type::FloatTyID: Accum = Type::Int32Ty; break;
|
||||||
case Type::DoubleTyID: Accum = Type::Int64Ty; break;
|
case Type::DoubleTyID: Accum = Type::Int64Ty; break;
|
||||||
|
case Type::X86_FP80TyID: return true;
|
||||||
|
case Type::FP128TyID: return true;
|
||||||
|
case Type::PPC_FP128TyID: return true;
|
||||||
default:
|
default:
|
||||||
assert(Accum->isInteger() && "Unknown FP type!");
|
assert(Accum->isInteger() && "Unknown FP type!");
|
||||||
break;
|
break;
|
||||||
|
@ -914,6 +917,9 @@ static bool MergeInType(const Type *In, const Type *&Accum,
|
||||||
case Type::PointerTyID: In = TD.getIntPtrType(); break;
|
case Type::PointerTyID: In = TD.getIntPtrType(); break;
|
||||||
case Type::FloatTyID: In = Type::Int32Ty; break;
|
case Type::FloatTyID: In = Type::Int32Ty; break;
|
||||||
case Type::DoubleTyID: In = Type::Int64Ty; break;
|
case Type::DoubleTyID: In = Type::Int64Ty; break;
|
||||||
|
case Type::X86_FP80TyID: return true;
|
||||||
|
case Type::FP128TyID: return true;
|
||||||
|
case Type::PPC_FP128TyID: return true;
|
||||||
default:
|
default:
|
||||||
assert(In->isInteger() && "Unknown FP type!");
|
assert(In->isInteger() && "Unknown FP type!");
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in New Issue