mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-23 17:32:49 +00:00
Add back convertFromSignExtendedInteger.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@42735 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7a7bc0f724
commit
f16c595252
@ -194,6 +194,8 @@ namespace llvm {
|
|||||||
opStatus convert(const fltSemantics &, roundingMode);
|
opStatus convert(const fltSemantics &, roundingMode);
|
||||||
opStatus convertToInteger(integerPart *, unsigned int, bool,
|
opStatus convertToInteger(integerPart *, unsigned int, bool,
|
||||||
roundingMode) const;
|
roundingMode) const;
|
||||||
|
opStatus convertFromSignExtendedInteger(const integerPart *, unsigned int,
|
||||||
|
bool, roundingMode);
|
||||||
opStatus convertFromZeroExtendedInteger(const integerPart *, unsigned int,
|
opStatus convertFromZeroExtendedInteger(const integerPart *, unsigned int,
|
||||||
bool, roundingMode);
|
bool, roundingMode);
|
||||||
opStatus convertFromString(const char *, roundingMode);
|
opStatus convertFromString(const char *, roundingMode);
|
||||||
|
@ -1587,6 +1587,36 @@ APFloat::convertFromUnsignedParts(const integerPart *src,
|
|||||||
return normalize(rounding_mode, lost_fraction);
|
return normalize(rounding_mode, lost_fraction);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Convert a two's complement integer SRC to a floating point number,
|
||||||
|
rounding according to ROUNDING_MODE. ISSIGNED is true if the
|
||||||
|
integer is signed, in which case it must be sign-extended. */
|
||||||
|
APFloat::opStatus
|
||||||
|
APFloat::convertFromSignExtendedInteger(const integerPart *src,
|
||||||
|
unsigned int srcCount,
|
||||||
|
bool isSigned,
|
||||||
|
roundingMode rounding_mode)
|
||||||
|
{
|
||||||
|
opStatus status;
|
||||||
|
|
||||||
|
if (isSigned
|
||||||
|
&& APInt::tcExtractBit(src, srcCount * integerPartWidth - 1)) {
|
||||||
|
integerPart *copy;
|
||||||
|
|
||||||
|
/* If we're signed and negative negate a copy. */
|
||||||
|
sign = true;
|
||||||
|
copy = new integerPart[srcCount];
|
||||||
|
APInt::tcAssign(copy, src, srcCount);
|
||||||
|
APInt::tcNegate(copy, srcCount);
|
||||||
|
status = convertFromUnsignedParts(copy, srcCount, rounding_mode);
|
||||||
|
delete [] copy;
|
||||||
|
} else {
|
||||||
|
sign = false;
|
||||||
|
status = convertFromUnsignedParts(src, srcCount, rounding_mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
return status;
|
||||||
|
}
|
||||||
|
|
||||||
/* FIXME: should this just take a const APInt reference? */
|
/* FIXME: should this just take a const APInt reference? */
|
||||||
APFloat::opStatus
|
APFloat::opStatus
|
||||||
APFloat::convertFromZeroExtendedInteger(const integerPart *parts,
|
APFloat::convertFromZeroExtendedInteger(const integerPart *parts,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user