mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-12 03:32:10 +00:00
Allow the inverse transform x86_fp80 -> i80 (also
fires during the Ada build). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@63731 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a06aef6ec5
commit
09750273a4
@ -161,17 +161,12 @@ static Constant *FoldBitCast(Constant *V, const Type *DestTy) {
|
||||
// Otherwise, can't fold this (vector?)
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
// Handle ConstantFP input.
|
||||
if (const ConstantFP *FP = dyn_cast<ConstantFP>(V)) {
|
||||
if (const ConstantFP *FP = dyn_cast<ConstantFP>(V))
|
||||
// FP -> Integral.
|
||||
if (DestTy == Type::Int32Ty) {
|
||||
return ConstantInt::get(FP->getValueAPF().bitcastToAPInt());
|
||||
} else {
|
||||
assert(DestTy == Type::Int64Ty && "only support f32/f64 for now!");
|
||||
return ConstantInt::get(FP->getValueAPF().bitcastToAPInt());
|
||||
}
|
||||
}
|
||||
return ConstantInt::get(FP->getValueAPF().bitcastToAPInt());
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -5,3 +5,8 @@ define x86_fp80 @cast() {
|
||||
%tmp = bitcast i80 0 to x86_fp80 ; <x86_fp80> [#uses=1]
|
||||
ret x86_fp80 %tmp
|
||||
}
|
||||
|
||||
define i80 @invcast() {
|
||||
%tmp = bitcast x86_fp80 0xK00000000000000000000 to i80 ; <i80> [#uses=1]
|
||||
ret i80 %tmp
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user