mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-07 14:33:15 +00:00
convert the last 4 X86ISD nodes that should have memoperands to have them.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114523 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2156b79c49
commit
492a43e6f6
@ -1168,11 +1168,7 @@ bool X86DAGToDAGISel::SelectAddr(SDNode *Parent, SDValue N, SDValue &Base,
|
||||
// that are not a MemSDNode, and thus don't have proper addrspace info.
|
||||
Parent->getOpcode() != ISD::PREFETCH &&
|
||||
Parent->getOpcode() != ISD::INTRINSIC_W_CHAIN && // unaligned loads, fixme
|
||||
Parent->getOpcode() != ISD::INTRINSIC_VOID && // nontemporal stores.
|
||||
Parent->getOpcode() != X86ISD::FLD &&
|
||||
Parent->getOpcode() != X86ISD::FILD &&
|
||||
Parent->getOpcode() != X86ISD::FILD_FLAG &&
|
||||
Parent->getOpcode() != X86ISD::FST) {
|
||||
Parent->getOpcode() != ISD::INTRINSIC_VOID) { // nontemporal stores.
|
||||
unsigned AddrSpace =
|
||||
cast<MemSDNode>(Parent)->getPointerInfo().getAddrSpace();
|
||||
// AddrSpace 256 -> GS, 257 -> FS.
|
||||
|
@ -6321,9 +6321,8 @@ SDValue X86TargetLowering::LowerSINT_TO_FP(SDValue Op,
|
||||
EVT SrcVT = Op.getOperand(0).getValueType();
|
||||
|
||||
if (SrcVT.isVector()) {
|
||||
if (SrcVT == MVT::v2i32 && Op.getValueType() == MVT::v2f64) {
|
||||
if (SrcVT == MVT::v2i32 && Op.getValueType() == MVT::v2f64)
|
||||
return Op;
|
||||
}
|
||||
return SDValue();
|
||||
}
|
||||
|
||||
@ -6355,16 +6354,27 @@ SDValue X86TargetLowering::BuildFILD(SDValue Op, EVT SrcVT, SDValue Chain,
|
||||
SDValue StackSlot,
|
||||
SelectionDAG &DAG) const {
|
||||
// Build the FILD
|
||||
DebugLoc dl = Op.getDebugLoc();
|
||||
DebugLoc DL = Op.getDebugLoc();
|
||||
SDVTList Tys;
|
||||
bool useSSE = isScalarFPTypeInSSEReg(Op.getValueType());
|
||||
if (useSSE)
|
||||
Tys = DAG.getVTList(MVT::f64, MVT::Other, MVT::Flag);
|
||||
else
|
||||
Tys = DAG.getVTList(Op.getValueType(), MVT::Other);
|
||||
|
||||
unsigned ByteSize = SrcVT.getSizeInBits()/8;
|
||||
|
||||
int SSFI = cast<FrameIndexSDNode>(StackSlot)->getIndex();
|
||||
MachineMemOperand *MMO =
|
||||
DAG.getMachineFunction()
|
||||
.getMachineMemOperand(MachinePointerInfo::getFixedStack(SSFI),
|
||||
MachineMemOperand::MOLoad, ByteSize, ByteSize);
|
||||
|
||||
SDValue Ops[] = { Chain, StackSlot, DAG.getValueType(SrcVT) };
|
||||
SDValue Result = DAG.getNode(useSSE ? X86ISD::FILD_FLAG : X86ISD::FILD, dl,
|
||||
Tys, Ops, array_lengthof(Ops));
|
||||
SDValue Result = DAG.getMemIntrinsicNode(useSSE ? X86ISD::FILD_FLAG :
|
||||
X86ISD::FILD, DL,
|
||||
Tys, Ops, array_lengthof(Ops),
|
||||
SrcVT, MMO);
|
||||
|
||||
if (useSSE) {
|
||||
Chain = Result.getValue(1);
|
||||
@ -6380,8 +6390,15 @@ SDValue X86TargetLowering::BuildFILD(SDValue Op, EVT SrcVT, SDValue Chain,
|
||||
SDValue Ops[] = {
|
||||
Chain, Result, StackSlot, DAG.getValueType(Op.getValueType()), InFlag
|
||||
};
|
||||
Chain = DAG.getNode(X86ISD::FST, dl, Tys, Ops, array_lengthof(Ops));
|
||||
Result = DAG.getLoad(Op.getValueType(), dl, Chain, StackSlot,
|
||||
MachineMemOperand *MMO =
|
||||
DAG.getMachineFunction()
|
||||
.getMachineMemOperand(MachinePointerInfo::getFixedStack(SSFI),
|
||||
MachineMemOperand::MOStore, 8, 8);
|
||||
|
||||
Chain = DAG.getMemIntrinsicNode(X86ISD::FST, DL, Tys,
|
||||
Ops, array_lengthof(Ops),
|
||||
Op.getValueType(), MMO);
|
||||
Result = DAG.getLoad(Op.getValueType(), DL, Chain, StackSlot,
|
||||
MachinePointerInfo::getFixedStack(SSFI),
|
||||
false, false, 0);
|
||||
}
|
||||
@ -6564,9 +6581,16 @@ SDValue X86TargetLowering::LowerUINT_TO_FP(SDValue Op,
|
||||
// DAGTypeLegalizer::ExpandIntOp_UNIT_TO_FP, and for it to be safe here,
|
||||
// we must be careful to do the computation in x87 extended precision, not
|
||||
// in SSE. (The generic code can't know it's OK to do this, or how to.)
|
||||
int SSFI = cast<FrameIndexSDNode>(StackSlot)->getIndex();
|
||||
MachineMemOperand *MMO =
|
||||
DAG.getMachineFunction()
|
||||
.getMachineMemOperand(MachinePointerInfo::getFixedStack(SSFI),
|
||||
MachineMemOperand::MOLoad, 8, 8);
|
||||
|
||||
SDVTList Tys = DAG.getVTList(MVT::f80, MVT::Other);
|
||||
SDValue Ops[] = { Store, StackSlot, DAG.getValueType(MVT::i64) };
|
||||
SDValue Fild = DAG.getNode(X86ISD::FILD, dl, Tys, Ops, 3);
|
||||
SDValue Fild = DAG.getMemIntrinsicNode(X86ISD::FILD, dl, Tys, Ops, 3,
|
||||
MVT::i64, MMO);
|
||||
|
||||
APInt FF(32, 0x5F800000ULL);
|
||||
|
||||
@ -6640,16 +6664,22 @@ FP_TO_INTHelper(SDValue Op, SelectionDAG &DAG, bool IsSigned) const {
|
||||
|
||||
SDValue Chain = DAG.getEntryNode();
|
||||
SDValue Value = Op.getOperand(0);
|
||||
if (isScalarFPTypeInSSEReg(Op.getOperand(0).getValueType())) {
|
||||
EVT TheVT = Op.getOperand(0).getValueType();
|
||||
if (isScalarFPTypeInSSEReg(TheVT)) {
|
||||
assert(DstTy == MVT::i64 && "Invalid FP_TO_SINT to lower!");
|
||||
Chain = DAG.getStore(Chain, DL, Value, StackSlot,
|
||||
MachinePointerInfo::getFixedStack(SSFI),
|
||||
false, false, 0);
|
||||
SDVTList Tys = DAG.getVTList(Op.getOperand(0).getValueType(), MVT::Other);
|
||||
SDValue Ops[] = {
|
||||
Chain, StackSlot, DAG.getValueType(Op.getOperand(0).getValueType())
|
||||
Chain, StackSlot, DAG.getValueType(TheVT)
|
||||
};
|
||||
Value = DAG.getNode(X86ISD::FLD, DL, Tys, Ops, 3);
|
||||
|
||||
MachineMemOperand *MMO =
|
||||
MF.getMachineMemOperand(MachinePointerInfo::getFixedStack(SSFI),
|
||||
MachineMemOperand::MOLoad, MemSize, MemSize);
|
||||
Value = DAG.getMemIntrinsicNode(X86ISD::FLD, DL, Tys, Ops, 3,
|
||||
DstTy, MMO);
|
||||
Chain = Value.getValue(1);
|
||||
SSFI = MF.getFrameInfo()->CreateStackObject(MemSize, MemSize, false);
|
||||
StackSlot = DAG.getFrameIndex(SSFI, getPointerTy());
|
||||
|
@ -57,26 +57,6 @@ namespace llvm {
|
||||
/// corresponds to X86::PSRLDQ.
|
||||
FSRL,
|
||||
|
||||
/// FILD, FILD_FLAG - This instruction implements SINT_TO_FP with the
|
||||
/// integer source in memory and FP reg result. This corresponds to the
|
||||
/// X86::FILD*m instructions. It has three inputs (token chain, address,
|
||||
/// and source type) and two outputs (FP value and token chain). FILD_FLAG
|
||||
/// also produces a flag).
|
||||
FILD,
|
||||
FILD_FLAG,
|
||||
|
||||
/// FLD - This instruction implements an extending load to FP stack slots.
|
||||
/// This corresponds to the X86::FLD32m / X86::FLD64m. It takes a chain
|
||||
/// operand, ptr to load from, and a ValueType node indicating the type
|
||||
/// to load to.
|
||||
FLD,
|
||||
|
||||
/// FST - This instruction implements a truncating store to FP stack
|
||||
/// slots. This corresponds to the X86::FST32m / X86::FST64m. It takes a
|
||||
/// chain operand, value to store, address, and a ValueType to store it
|
||||
/// as.
|
||||
FST,
|
||||
|
||||
/// CALL - These operations represent an abstract X86 call
|
||||
/// instruction, which includes a bunch of information. In particular the
|
||||
/// operands of these node are:
|
||||
@ -309,7 +289,27 @@ namespace llvm {
|
||||
/// and token chain).
|
||||
FP_TO_INT16_IN_MEM,
|
||||
FP_TO_INT32_IN_MEM,
|
||||
FP_TO_INT64_IN_MEM
|
||||
FP_TO_INT64_IN_MEM,
|
||||
|
||||
/// FILD, FILD_FLAG - This instruction implements SINT_TO_FP with the
|
||||
/// integer source in memory and FP reg result. This corresponds to the
|
||||
/// X86::FILD*m instructions. It has three inputs (token chain, address,
|
||||
/// and source type) and two outputs (FP value and token chain). FILD_FLAG
|
||||
/// also produces a flag).
|
||||
FILD,
|
||||
FILD_FLAG,
|
||||
|
||||
/// FLD - This instruction implements an extending load to FP stack slots.
|
||||
/// This corresponds to the X86::FLD32m / X86::FLD64m. It takes a chain
|
||||
/// operand, ptr to load from, and a ValueType node indicating the type
|
||||
/// to load to.
|
||||
FLD,
|
||||
|
||||
/// FST - This instruction implements a truncating store to FP stack
|
||||
/// slots. This corresponds to the X86::FST32m / X86::FST64m. It takes a
|
||||
/// chain operand, value to store, address, and a ValueType to store it
|
||||
/// as.
|
||||
FST
|
||||
|
||||
// WARNING: Do not add anything in the end unless you want the node to
|
||||
// have memop! In fact, starting from ATOMADD64_DAG all opcodes will be
|
||||
|
@ -32,13 +32,15 @@ def SDTX86FpToIMem : SDTypeProfile<0, 2, [SDTCisFP<0>, SDTCisPtrTy<1>]>;
|
||||
def SDTX86CwdStore : SDTypeProfile<0, 1, [SDTCisPtrTy<0>]>;
|
||||
|
||||
def X86fld : SDNode<"X86ISD::FLD", SDTX86Fld,
|
||||
[SDNPHasChain, SDNPMayLoad]>;
|
||||
[SDNPHasChain, SDNPMayLoad, SDNPMemOperand]>;
|
||||
def X86fst : SDNode<"X86ISD::FST", SDTX86Fst,
|
||||
[SDNPHasChain, SDNPInFlag, SDNPMayStore]>;
|
||||
[SDNPHasChain, SDNPInFlag, SDNPMayStore,
|
||||
SDNPMemOperand]>;
|
||||
def X86fild : SDNode<"X86ISD::FILD", SDTX86Fild,
|
||||
[SDNPHasChain, SDNPMayLoad]>;
|
||||
[SDNPHasChain, SDNPMayLoad, SDNPMemOperand]>;
|
||||
def X86fildflag : SDNode<"X86ISD::FILD_FLAG", SDTX86Fild,
|
||||
[SDNPHasChain, SDNPOutFlag, SDNPMayLoad]>;
|
||||
[SDNPHasChain, SDNPOutFlag, SDNPMayLoad,
|
||||
SDNPMemOperand]>;
|
||||
def X86fp_to_i16mem : SDNode<"X86ISD::FP_TO_INT16_IN_MEM", SDTX86FpToIMem,
|
||||
[SDNPHasChain, SDNPMayStore, SDNPMemOperand]>;
|
||||
def X86fp_to_i32mem : SDNode<"X86ISD::FP_TO_INT32_IN_MEM", SDTX86FpToIMem,
|
||||
|
Loading…
x
Reference in New Issue
Block a user