diff options
| author | Chris Lattner <sabre@nondot.org> | 2006-11-10 23:58:45 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2006-11-10 23:58:45 +0000 |
| commit | c9fa36d7067fe443dc70c8187d67a386ee8bd7cf (patch) | |
| tree | 04cdab5a04b2afca221f27de8b4b86fae999ca23 /llvm/lib/Target/PowerPC/PPCISelLowering.cpp | |
| parent | d4dee405cbe030806fec016499e9e90d55062a55 (diff) | |
| download | bcm5719-llvm-c9fa36d7067fe443dc70c8187d67a386ee8bd7cf.tar.gz bcm5719-llvm-c9fa36d7067fe443dc70c8187d67a386ee8bd7cf.zip | |
implement preinc support for r+i loads on ppc64
llvm-svn: 31654
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCISelLowering.cpp')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCISelLowering.cpp | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp index 3ad4bbcc57d..7eb6bec28f9 100644 --- a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp +++ b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp @@ -53,9 +53,15 @@ PPCTargetLowering::PPCTargetLowering(PPCTargetMachine &TM) // PowerPC does not have truncstore for i1. setStoreXAction(MVT::i1, Promote); - // PowerPC has i32 and i64 pre-inc load and store's. + // PowerPC has pre-inc load and store's. + setIndexedLoadAction(ISD::PRE_INC, MVT::i1, Legal); + setIndexedLoadAction(ISD::PRE_INC, MVT::i8, Legal); + setIndexedLoadAction(ISD::PRE_INC, MVT::i16, Legal); setIndexedLoadAction(ISD::PRE_INC, MVT::i32, Legal); setIndexedLoadAction(ISD::PRE_INC, MVT::i64, Legal); + setIndexedStoreAction(ISD::PRE_INC, MVT::i1, Legal); + setIndexedStoreAction(ISD::PRE_INC, MVT::i8, Legal); + setIndexedStoreAction(ISD::PRE_INC, MVT::i16, Legal); setIndexedStoreAction(ISD::PRE_INC, MVT::i32, Legal); setIndexedStoreAction(ISD::PRE_INC, MVT::i64, Legal); @@ -870,6 +876,9 @@ bool PPCTargetLowering::getPreIndexedAddressParts(SDNode *N, SDOperand &Base, SDOperand Ptr; if (LoadSDNode *LD = dyn_cast<LoadSDNode>(N)) { Ptr = LD->getBasePtr(); + + // FIXME: PPC has no LWAU! + } else if (StoreSDNode *ST = dyn_cast<StoreSDNode>(N)) { ST = ST; //Ptr = ST->getBasePtr(); |

