diff options
| author | Hal Finkel <hfinkel@anl.gov> | 2012-04-01 04:44:16 +0000 | 
|---|---|---|
| committer | Hal Finkel <hfinkel@anl.gov> | 2012-04-01 04:44:16 +0000 | 
| commit | 59607e63cbb2d69820ae1007e77379952fcbbefd (patch) | |
| tree | 21a1a3e3e5b9d644047aa3dfa2ca9c26e346d3c4 /llvm/lib/Target | |
| parent | 1eaae507341bd15b2861c4f32245b5418e5fe69f (diff) | |
| download | bcm5719-llvm-59607e63cbb2d69820ae1007e77379952fcbbefd.tar.gz bcm5719-llvm-59607e63cbb2d69820ae1007e77379952fcbbefd.zip | |
Split the LdStGeneral PPC itin. class into LdStLoad and LdStStore.
Loads and stores can have different pipeline behavior, especially on
embedded chips. This change allows those differences to be expressed.
Except for the 440 scheduler, there are no functionality changes.
On the 440, the latency adjustment is only by one cycle, and so this
probably does not affect much. Nevertheless, it will make a larger
difference in the future and this removes a FIXME from the 440 itin.
llvm-svn: 153821
Diffstat (limited to 'llvm/lib/Target')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCInstr64Bit.td | 36 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCInstrAltivec.td | 48 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCInstrInfo.td | 54 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCSchedule.td | 63 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCSchedule440.td | 34 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCScheduleG3.td | 3 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCScheduleG4.td | 3 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCScheduleG4Plus.td | 3 | ||||
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCScheduleG5.td | 3 | 
9 files changed, 140 insertions, 107 deletions
| diff --git a/llvm/lib/Target/PowerPC/PPCInstr64Bit.td b/llvm/lib/Target/PowerPC/PPCInstr64Bit.td index e1d8b65b8af..7f67a4159df 100644 --- a/llvm/lib/Target/PowerPC/PPCInstr64Bit.td +++ b/llvm/lib/Target/PowerPC/PPCInstr64Bit.td @@ -524,7 +524,7 @@ def LWAX : XForm_1<31, 341, (outs G8RC:$rD), (ins memrr:$src),  let mayLoad = 1 in  def LHAU8 : DForm_1a<43, (outs G8RC:$rD, ptr_rc:$ea_result), (ins symbolLo:$disp,                              ptr_rc:$rA), -                    "lhau $rD, $disp($rA)", LdStGeneral, +                    "lhau $rD, $disp($rA)", LdStLoad,                      []>, RegConstraint<"$rA = $ea_result">,                      NoEncode<"$ea_result">;  // NO LWAU! @@ -534,38 +534,38 @@ def LHAU8 : DForm_1a<43, (outs G8RC:$rD, ptr_rc:$ea_result), (ins symbolLo:$disp  // Zero extending loads.  let canFoldAsLoad = 1, PPC970_Unit = 2 in {  def LBZ8 : DForm_1<34, (outs G8RC:$rD), (ins memri:$src), -                  "lbz $rD, $src", LdStGeneral, +                  "lbz $rD, $src", LdStLoad,                    [(set G8RC:$rD, (zextloadi8 iaddr:$src))]>;  def LHZ8 : DForm_1<40, (outs G8RC:$rD), (ins memri:$src), -                  "lhz $rD, $src", LdStGeneral, +                  "lhz $rD, $src", LdStLoad,                    [(set G8RC:$rD, (zextloadi16 iaddr:$src))]>;  def LWZ8 : DForm_1<32, (outs G8RC:$rD), (ins memri:$src), -                  "lwz $rD, $src", LdStGeneral, +                  "lwz $rD, $src", LdStLoad,                    [(set G8RC:$rD, (zextloadi32 iaddr:$src))]>, isPPC64;  def LBZX8 : XForm_1<31,  87, (outs G8RC:$rD), (ins memrr:$src), -                   "lbzx $rD, $src", LdStGeneral, +                   "lbzx $rD, $src", LdStLoad,                     [(set G8RC:$rD, (zextloadi8 xaddr:$src))]>;  def LHZX8 : XForm_1<31, 279, (outs G8RC:$rD), (ins memrr:$src), -                   "lhzx $rD, $src", LdStGeneral, +                   "lhzx $rD, $src", LdStLoad,                     [(set G8RC:$rD, (zextloadi16 xaddr:$src))]>;  def LWZX8 : XForm_1<31,  23, (outs G8RC:$rD), (ins memrr:$src), -                   "lwzx $rD, $src", LdStGeneral, +                   "lwzx $rD, $src", LdStLoad,                     [(set G8RC:$rD, (zextloadi32 xaddr:$src))]>;  // Update forms.  let mayLoad = 1 in {  def LBZU8 : DForm_1<35, (outs G8RC:$rD, ptr_rc:$ea_result), (ins memri:$addr), -                    "lbzu $rD, $addr", LdStGeneral, +                    "lbzu $rD, $addr", LdStLoad,                      []>, RegConstraint<"$addr.reg = $ea_result">,                      NoEncode<"$ea_result">;  def LHZU8 : DForm_1<41, (outs G8RC:$rD, ptr_rc:$ea_result), (ins memri:$addr), -                    "lhzu $rD, $addr", LdStGeneral, +                    "lhzu $rD, $addr", LdStLoad,                      []>, RegConstraint<"$addr.reg = $ea_result">,                      NoEncode<"$ea_result">;  def LWZU8 : DForm_1<33, (outs G8RC:$rD, ptr_rc:$ea_result), (ins memri:$addr), -                    "lwzu $rD, $addr", LdStGeneral, +                    "lwzu $rD, $addr", LdStLoad,                      []>, RegConstraint<"$addr.reg = $ea_result">,                      NoEncode<"$ea_result">;  } @@ -613,24 +613,24 @@ def : Pat<(PPCload xaddr:$src),  let PPC970_Unit = 2 in {  // Truncating stores.                         def STB8 : DForm_1<38, (outs), (ins G8RC:$rS, memri:$src), -                   "stb $rS, $src", LdStGeneral, +                   "stb $rS, $src", LdStStore,                     [(truncstorei8 G8RC:$rS, iaddr:$src)]>;  def STH8 : DForm_1<44, (outs), (ins G8RC:$rS, memri:$src), -                   "sth $rS, $src", LdStGeneral, +                   "sth $rS, $src", LdStStore,                     [(truncstorei16 G8RC:$rS, iaddr:$src)]>;  def STW8 : DForm_1<36, (outs), (ins G8RC:$rS, memri:$src), -                   "stw $rS, $src", LdStGeneral, +                   "stw $rS, $src", LdStStore,                     [(truncstorei32 G8RC:$rS, iaddr:$src)]>;  def STBX8 : XForm_8<31, 215, (outs), (ins G8RC:$rS, memrr:$dst), -                   "stbx $rS, $dst", LdStGeneral, +                   "stbx $rS, $dst", LdStStore,                     [(truncstorei8 G8RC:$rS, xaddr:$dst)]>,                      PPC970_DGroup_Cracked;  def STHX8 : XForm_8<31, 407, (outs), (ins G8RC:$rS, memrr:$dst), -                   "sthx $rS, $dst", LdStGeneral, +                   "sthx $rS, $dst", LdStStore,                     [(truncstorei16 G8RC:$rS, xaddr:$dst)]>,                      PPC970_DGroup_Cracked;  def STWX8 : XForm_8<31, 151, (outs), (ins G8RC:$rS, memrr:$dst), -                   "stwx $rS, $dst", LdStGeneral, +                   "stwx $rS, $dst", LdStStore,                     [(truncstorei32 G8RC:$rS, xaddr:$dst)]>,                     PPC970_DGroup_Cracked;  // Normal 8-byte stores. @@ -647,14 +647,14 @@ let PPC970_Unit = 2 in {  def STBU8 : DForm_1a<38, (outs ptr_rc:$ea_res), (ins G8RC:$rS,                               symbolLo:$ptroff, ptr_rc:$ptrreg), -                    "stbu $rS, $ptroff($ptrreg)", LdStGeneral, +                    "stbu $rS, $ptroff($ptrreg)", LdStStore,                      [(set ptr_rc:$ea_res,                            (pre_truncsti8 G8RC:$rS, ptr_rc:$ptrreg,                                            iaddroff:$ptroff))]>,                      RegConstraint<"$ptrreg = $ea_res">, NoEncode<"$ea_res">;  def STHU8 : DForm_1a<45, (outs ptr_rc:$ea_res), (ins G8RC:$rS,                               symbolLo:$ptroff, ptr_rc:$ptrreg), -                    "sthu $rS, $ptroff($ptrreg)", LdStGeneral, +                    "sthu $rS, $ptroff($ptrreg)", LdStStore,                      [(set ptr_rc:$ea_res,                          (pre_truncsti16 G8RC:$rS, ptr_rc:$ptrreg,                                           iaddroff:$ptroff))]>, diff --git a/llvm/lib/Target/PowerPC/PPCInstrAltivec.td b/llvm/lib/Target/PowerPC/PPCInstrAltivec.td index 707fa411cc2..6c0f3d3f06e 100644 --- a/llvm/lib/Target/PowerPC/PPCInstrAltivec.td +++ b/llvm/lib/Target/PowerPC/PPCInstrAltivec.td @@ -188,85 +188,85 @@ class VX2_Int<bits<11> xo, string opc, Intrinsic IntID>  def DSS      : DSS_Form<822, (outs),                          (ins u5imm:$ZERO0, u5imm:$STRM,u5imm:$ZERO1,u5imm:$ZERO2), -                        "dss $STRM", LdStGeneral /*FIXME*/, []>; +                        "dss $STRM", LdStLoad /*FIXME*/, []>;  def DSSALL   : DSS_Form<822, (outs),                          (ins u5imm:$ONE, u5imm:$ZERO0,u5imm:$ZERO1,u5imm:$ZERO2), -                        "dssall", LdStGeneral /*FIXME*/, []>; +                        "dssall", LdStLoad /*FIXME*/, []>;  def DST      : DSS_Form<342, (outs),                          (ins u5imm:$ZERO, u5imm:$STRM, GPRC:$rA, GPRC:$rB), -                        "dst $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dst $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def DSTT     : DSS_Form<342, (outs),                          (ins u5imm:$ONE, u5imm:$STRM, GPRC:$rA, GPRC:$rB), -                        "dstt $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dstt $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def DSTST    : DSS_Form<374, (outs),                          (ins u5imm:$ZERO, u5imm:$STRM, GPRC:$rA, GPRC:$rB), -                        "dstst $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dstst $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def DSTSTT   : DSS_Form<374, (outs),                          (ins u5imm:$ONE, u5imm:$STRM, GPRC:$rA, GPRC:$rB), -                        "dststt $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dststt $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def DST64    : DSS_Form<342, (outs),                          (ins u5imm:$ZERO, u5imm:$STRM, G8RC:$rA, GPRC:$rB), -                        "dst $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dst $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def DSTT64   : DSS_Form<342, (outs),                          (ins u5imm:$ONE, u5imm:$STRM, G8RC:$rA, GPRC:$rB), -                        "dstt $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dstt $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def DSTST64  : DSS_Form<374, (outs),                          (ins u5imm:$ZERO, u5imm:$STRM, G8RC:$rA, GPRC:$rB), -                        "dstst $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dstst $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def DSTSTT64 : DSS_Form<374, (outs),                          (ins u5imm:$ONE, u5imm:$STRM, G8RC:$rA, GPRC:$rB), -                        "dststt $rA, $rB, $STRM", LdStGeneral /*FIXME*/, []>; +                        "dststt $rA, $rB, $STRM", LdStLoad /*FIXME*/, []>;  def MFVSCR : VXForm_4<1540, (outs VRRC:$vD), (ins), -                      "mfvscr $vD", LdStGeneral, +                      "mfvscr $vD", LdStStore,                        [(set VRRC:$vD, (int_ppc_altivec_mfvscr))]>;   def MTVSCR : VXForm_5<1604, (outs), (ins VRRC:$vB), -                      "mtvscr $vB", LdStGeneral, +                      "mtvscr $vB", LdStLoad,                        [(int_ppc_altivec_mtvscr VRRC:$vB)]>;   let canFoldAsLoad = 1, PPC970_Unit = 2 in {  // Loads.  def LVEBX: XForm_1<31,   7, (outs VRRC:$vD), (ins memrr:$src), -                   "lvebx $vD, $src", LdStGeneral, +                   "lvebx $vD, $src", LdStLoad,                     [(set VRRC:$vD, (int_ppc_altivec_lvebx xoaddr:$src))]>;  def LVEHX: XForm_1<31,  39, (outs VRRC:$vD), (ins memrr:$src), -                   "lvehx $vD, $src", LdStGeneral, +                   "lvehx $vD, $src", LdStLoad,                     [(set VRRC:$vD, (int_ppc_altivec_lvehx xoaddr:$src))]>;  def LVEWX: XForm_1<31,  71, (outs VRRC:$vD), (ins memrr:$src), -                   "lvewx $vD, $src", LdStGeneral, +                   "lvewx $vD, $src", LdStLoad,                     [(set VRRC:$vD, (int_ppc_altivec_lvewx xoaddr:$src))]>;  def LVX  : XForm_1<31, 103, (outs VRRC:$vD), (ins memrr:$src), -                   "lvx $vD, $src", LdStGeneral, +                   "lvx $vD, $src", LdStLoad,                     [(set VRRC:$vD, (int_ppc_altivec_lvx xoaddr:$src))]>;  def LVXL : XForm_1<31, 359, (outs VRRC:$vD), (ins memrr:$src), -                   "lvxl $vD, $src", LdStGeneral, +                   "lvxl $vD, $src", LdStLoad,                     [(set VRRC:$vD, (int_ppc_altivec_lvxl xoaddr:$src))]>;  }  def LVSL : XForm_1<31,   6, (outs VRRC:$vD), (ins memrr:$src), -                   "lvsl $vD, $src", LdStGeneral, +                   "lvsl $vD, $src", LdStLoad,                     [(set VRRC:$vD, (int_ppc_altivec_lvsl xoaddr:$src))]>,                     PPC970_Unit_LSU;  def LVSR : XForm_1<31,  38, (outs VRRC:$vD), (ins memrr:$src), -                   "lvsr $vD, $src", LdStGeneral, +                   "lvsr $vD, $src", LdStLoad,                     [(set VRRC:$vD, (int_ppc_altivec_lvsr xoaddr:$src))]>,                     PPC970_Unit_LSU;  let PPC970_Unit = 2 in {   // Stores.  def STVEBX: XForm_8<31, 135, (outs), (ins VRRC:$rS, memrr:$dst), -                   "stvebx $rS, $dst", LdStGeneral, +                   "stvebx $rS, $dst", LdStStore,                     [(int_ppc_altivec_stvebx VRRC:$rS, xoaddr:$dst)]>;  def STVEHX: XForm_8<31, 167, (outs), (ins VRRC:$rS, memrr:$dst), -                   "stvehx $rS, $dst", LdStGeneral, +                   "stvehx $rS, $dst", LdStStore,                     [(int_ppc_altivec_stvehx VRRC:$rS, xoaddr:$dst)]>;  def STVEWX: XForm_8<31, 199, (outs), (ins VRRC:$rS, memrr:$dst), -                   "stvewx $rS, $dst", LdStGeneral, +                   "stvewx $rS, $dst", LdStStore,                     [(int_ppc_altivec_stvewx VRRC:$rS, xoaddr:$dst)]>;  def STVX  : XForm_8<31, 231, (outs), (ins VRRC:$rS, memrr:$dst), -                   "stvx $rS, $dst", LdStGeneral, +                   "stvx $rS, $dst", LdStStore,                     [(int_ppc_altivec_stvx VRRC:$rS, xoaddr:$dst)]>;  def STVXL : XForm_8<31, 487, (outs), (ins VRRC:$rS, memrr:$dst), -                   "stvxl $rS, $dst", LdStGeneral, +                   "stvxl $rS, $dst", LdStStore,                     [(int_ppc_altivec_stvxl VRRC:$rS, xoaddr:$dst)]>;  } diff --git a/llvm/lib/Target/PowerPC/PPCInstrInfo.td b/llvm/lib/Target/PowerPC/PPCInstrInfo.td index 1b15df058c4..3a6dbcaab37 100644 --- a/llvm/lib/Target/PowerPC/PPCInstrInfo.td +++ b/llvm/lib/Target/PowerPC/PPCInstrInfo.td @@ -640,7 +640,7 @@ def STWCX : XForm_1<31, 150, (outs), (ins GPRC:$rS, memrr:$dst),                     isDOT;  let isTerminator = 1, isBarrier = 1, hasCtrlDep = 1 in -def TRAP  : XForm_24<31, 4, (outs), (ins), "trap", LdStGeneral, [(trap)]>; +def TRAP  : XForm_24<31, 4, (outs), (ins), "trap", LdStLoad, [(trap)]>;  //===----------------------------------------------------------------------===//  // PPC32 Load Instructions. @@ -649,17 +649,17 @@ def TRAP  : XForm_24<31, 4, (outs), (ins), "trap", LdStGeneral, [(trap)]>;  // Unindexed (r+i) Loads.   let canFoldAsLoad = 1, PPC970_Unit = 2 in {  def LBZ : DForm_1<34, (outs GPRC:$rD), (ins memri:$src), -                  "lbz $rD, $src", LdStGeneral, +                  "lbz $rD, $src", LdStLoad,                    [(set GPRC:$rD, (zextloadi8 iaddr:$src))]>;  def LHA : DForm_1<42, (outs GPRC:$rD), (ins memri:$src),                    "lha $rD, $src", LdStLHA,                    [(set GPRC:$rD, (sextloadi16 iaddr:$src))]>,                    PPC970_DGroup_Cracked;  def LHZ : DForm_1<40, (outs GPRC:$rD), (ins memri:$src), -                  "lhz $rD, $src", LdStGeneral, +                  "lhz $rD, $src", LdStLoad,                    [(set GPRC:$rD, (zextloadi16 iaddr:$src))]>;  def LWZ : DForm_1<32, (outs GPRC:$rD), (ins memri:$src), -                  "lwz $rD, $src", LdStGeneral, +                  "lwz $rD, $src", LdStLoad,                    [(set GPRC:$rD, (load iaddr:$src))]>;  def LFS : DForm_1<48, (outs F4RC:$rD), (ins memri:$src), @@ -673,22 +673,22 @@ def LFD : DForm_1<50, (outs F8RC:$rD), (ins memri:$src),  // Unindexed (r+i) Loads with Update (preinc).  let mayLoad = 1 in {  def LBZU : DForm_1<35, (outs GPRC:$rD, ptr_rc:$ea_result), (ins memri:$addr), -                   "lbzu $rD, $addr", LdStGeneral, +                   "lbzu $rD, $addr", LdStLoad,                     []>, RegConstraint<"$addr.reg = $ea_result">,                     NoEncode<"$ea_result">;  def LHAU : DForm_1<43, (outs GPRC:$rD, ptr_rc:$ea_result), (ins memri:$addr), -                   "lhau $rD, $addr", LdStGeneral, +                   "lhau $rD, $addr", LdStLoad,                     []>, RegConstraint<"$addr.reg = $ea_result">,                     NoEncode<"$ea_result">;  def LHZU : DForm_1<41, (outs GPRC:$rD, ptr_rc:$ea_result), (ins memri:$addr), -                   "lhzu $rD, $addr", LdStGeneral, +                   "lhzu $rD, $addr", LdStLoad,                     []>, RegConstraint<"$addr.reg = $ea_result">,                     NoEncode<"$ea_result">;  def LWZU : DForm_1<33, (outs GPRC:$rD, ptr_rc:$ea_result), (ins memri:$addr), -                   "lwzu $rD, $addr", LdStGeneral, +                   "lwzu $rD, $addr", LdStLoad,                     []>, RegConstraint<"$addr.reg = $ea_result">,                     NoEncode<"$ea_result">; @@ -708,25 +708,25 @@ def LFDU : DForm_1<51, (outs F8RC:$rD, ptr_rc:$ea_result), (ins memri:$addr),  //  let canFoldAsLoad = 1, PPC970_Unit = 2 in {  def LBZX : XForm_1<31,  87, (outs GPRC:$rD), (ins memrr:$src), -                   "lbzx $rD, $src", LdStGeneral, +                   "lbzx $rD, $src", LdStLoad,                     [(set GPRC:$rD, (zextloadi8 xaddr:$src))]>;  def LHAX : XForm_1<31, 343, (outs GPRC:$rD), (ins memrr:$src),                     "lhax $rD, $src", LdStLHA,                     [(set GPRC:$rD, (sextloadi16 xaddr:$src))]>,                     PPC970_DGroup_Cracked;  def LHZX : XForm_1<31, 279, (outs GPRC:$rD), (ins memrr:$src), -                   "lhzx $rD, $src", LdStGeneral, +                   "lhzx $rD, $src", LdStLoad,                     [(set GPRC:$rD, (zextloadi16 xaddr:$src))]>;  def LWZX : XForm_1<31,  23, (outs GPRC:$rD), (ins memrr:$src), -                   "lwzx $rD, $src", LdStGeneral, +                   "lwzx $rD, $src", LdStLoad,                     [(set GPRC:$rD, (load xaddr:$src))]>;  def LHBRX : XForm_1<31, 790, (outs GPRC:$rD), (ins memrr:$src), -                   "lhbrx $rD, $src", LdStGeneral, +                   "lhbrx $rD, $src", LdStLoad,                     [(set GPRC:$rD, (PPClbrx xoaddr:$src, i16))]>;  def LWBRX : XForm_1<31,  534, (outs GPRC:$rD), (ins memrr:$src), -                   "lwbrx $rD, $src", LdStGeneral, +                   "lwbrx $rD, $src", LdStLoad,                     [(set GPRC:$rD, (PPClbrx xoaddr:$src, i32))]>;  def LFSX   : XForm_25<31, 535, (outs F4RC:$frD), (ins memrr:$src), @@ -744,13 +744,13 @@ def LFDX   : XForm_25<31, 599, (outs F8RC:$frD), (ins memrr:$src),  // Unindexed (r+i) Stores.  let PPC970_Unit = 2 in {  def STB  : DForm_1<38, (outs), (ins GPRC:$rS, memri:$src), -                   "stb $rS, $src", LdStGeneral, +                   "stb $rS, $src", LdStStore,                     [(truncstorei8 GPRC:$rS, iaddr:$src)]>;  def STH  : DForm_1<44, (outs), (ins GPRC:$rS, memri:$src), -                   "sth $rS, $src", LdStGeneral, +                   "sth $rS, $src", LdStStore,                     [(truncstorei16 GPRC:$rS, iaddr:$src)]>;  def STW  : DForm_1<36, (outs), (ins GPRC:$rS, memri:$src), -                   "stw $rS, $src", LdStGeneral, +                   "stw $rS, $src", LdStStore,                     [(store GPRC:$rS, iaddr:$src)]>;  def STFS : DForm_1<52, (outs), (ins F4RC:$rS, memri:$dst),                     "stfs $rS, $dst", LdStUX, @@ -764,33 +764,33 @@ def STFD : DForm_1<54, (outs), (ins F8RC:$rS, memri:$dst),  let PPC970_Unit = 2 in {  def STBU  : DForm_1a<39, (outs ptr_rc:$ea_res), (ins GPRC:$rS,                               symbolLo:$ptroff, ptr_rc:$ptrreg), -                    "stbu $rS, $ptroff($ptrreg)", LdStGeneral, +                    "stbu $rS, $ptroff($ptrreg)", LdStStore,                      [(set ptr_rc:$ea_res,                            (pre_truncsti8 GPRC:$rS, ptr_rc:$ptrreg,                                            iaddroff:$ptroff))]>,                      RegConstraint<"$ptrreg = $ea_res">, NoEncode<"$ea_res">;  def STHU  : DForm_1a<45, (outs ptr_rc:$ea_res), (ins GPRC:$rS,                               symbolLo:$ptroff, ptr_rc:$ptrreg), -                    "sthu $rS, $ptroff($ptrreg)", LdStGeneral, +                    "sthu $rS, $ptroff($ptrreg)", LdStStore,                      [(set ptr_rc:$ea_res,                          (pre_truncsti16 GPRC:$rS, ptr_rc:$ptrreg,                                           iaddroff:$ptroff))]>,                      RegConstraint<"$ptrreg = $ea_res">, NoEncode<"$ea_res">;  def STWU  : DForm_1a<37, (outs ptr_rc:$ea_res), (ins GPRC:$rS,                               symbolLo:$ptroff, ptr_rc:$ptrreg), -                    "stwu $rS, $ptroff($ptrreg)", LdStGeneral, +                    "stwu $rS, $ptroff($ptrreg)", LdStStore,                      [(set ptr_rc:$ea_res, (pre_store GPRC:$rS, ptr_rc:$ptrreg,                                                        iaddroff:$ptroff))]>,                      RegConstraint<"$ptrreg = $ea_res">, NoEncode<"$ea_res">;  def STFSU : DForm_1a<37, (outs ptr_rc:$ea_res), (ins F4RC:$rS,                               symbolLo:$ptroff, ptr_rc:$ptrreg), -                    "stfsu $rS, $ptroff($ptrreg)", LdStGeneral, +                    "stfsu $rS, $ptroff($ptrreg)", LdStStore,                      [(set ptr_rc:$ea_res, (pre_store F4RC:$rS,  ptr_rc:$ptrreg,                                             iaddroff:$ptroff))]>,                      RegConstraint<"$ptrreg = $ea_res">, NoEncode<"$ea_res">;  def STFDU : DForm_1a<37, (outs ptr_rc:$ea_res), (ins F8RC:$rS,                               symbolLo:$ptroff, ptr_rc:$ptrreg), -                    "stfdu $rS, $ptroff($ptrreg)", LdStGeneral, +                    "stfdu $rS, $ptroff($ptrreg)", LdStStore,                      [(set ptr_rc:$ea_res, (pre_store F8RC:$rS, ptr_rc:$ptrreg,                                             iaddroff:$ptroff))]>,                      RegConstraint<"$ptrreg = $ea_res">, NoEncode<"$ea_res">; @@ -801,29 +801,29 @@ def STFDU : DForm_1a<37, (outs ptr_rc:$ea_res), (ins F8RC:$rS,  //  let PPC970_Unit = 2 in {  def STBX  : XForm_8<31, 215, (outs), (ins GPRC:$rS, memrr:$dst), -                   "stbx $rS, $dst", LdStGeneral, +                   "stbx $rS, $dst", LdStStore,                     [(truncstorei8 GPRC:$rS, xaddr:$dst)]>,                      PPC970_DGroup_Cracked;  def STHX  : XForm_8<31, 407, (outs), (ins GPRC:$rS, memrr:$dst), -                   "sthx $rS, $dst", LdStGeneral, +                   "sthx $rS, $dst", LdStStore,                     [(truncstorei16 GPRC:$rS, xaddr:$dst)]>,                      PPC970_DGroup_Cracked;  def STWX  : XForm_8<31, 151, (outs), (ins GPRC:$rS, memrr:$dst), -                   "stwx $rS, $dst", LdStGeneral, +                   "stwx $rS, $dst", LdStStore,                     [(store GPRC:$rS, xaddr:$dst)]>,                     PPC970_DGroup_Cracked;  let mayStore = 1 in {  def STWUX : XForm_8<31, 183, (outs), (ins GPRC:$rS, GPRC:$rA, GPRC:$rB), -                   "stwux $rS, $rA, $rB", LdStGeneral, +                   "stwux $rS, $rA, $rB", LdStStore,                     []>;  }  def STHBRX: XForm_8<31, 918, (outs), (ins GPRC:$rS, memrr:$dst), -                   "sthbrx $rS, $dst", LdStGeneral, +                   "sthbrx $rS, $dst", LdStStore,                     [(PPCstbrx GPRC:$rS, xoaddr:$dst, i16)]>,                      PPC970_DGroup_Cracked;  def STWBRX: XForm_8<31, 662, (outs), (ins GPRC:$rS, memrr:$dst), -                   "stwbrx $rS, $dst", LdStGeneral, +                   "stwbrx $rS, $dst", LdStStore,                     [(PPCstbrx GPRC:$rS, xoaddr:$dst, i32)]>,                     PPC970_DGroup_Cracked; diff --git a/llvm/lib/Target/PowerPC/PPCSchedule.td b/llvm/lib/Target/PowerPC/PPCSchedule.td index 4e37d0a695e..237870e2409 100644 --- a/llvm/lib/Target/PowerPC/PPCSchedule.td +++ b/llvm/lib/Target/PowerPC/PPCSchedule.td @@ -50,7 +50,8 @@ def BrMCRX       : InstrItinClass;  def LdStDCBA     : InstrItinClass;  def LdStDCBF     : InstrItinClass;  def LdStDCBI     : InstrItinClass; -def LdStGeneral  : InstrItinClass; +def LdStLoad     : InstrItinClass; +def LdStStore    : InstrItinClass;  def LdStDSS      : InstrItinClass;  def LdStICBI     : InstrItinClass;  def LdStUX       : InstrItinClass; @@ -150,8 +151,8 @@ include "PPCScheduleG5.td"  //    dcbf       LdStDCBF  //    dcbi       LdStDCBI  //    dcbst      LdStDCBF -//    dcbt       LdStGeneral -//    dcbtst     LdStGeneral +//    dcbt       LdStLoad +//    dcbtst     LdStLoad  //    dcbz       LdStDCBF  //    divd       IntDivD  //    divdu      IntDivD @@ -160,9 +161,9 @@ include "PPCScheduleG5.td"  //    dss        LdStDSS  //    dst        LdStDSS  //    dstst      LdStDSS -//    eciwx      LdStGeneral -//    ecowx      LdStGeneral -//    eieio      LdStGeneral +//    eciwx      LdStLoad +//    ecowx      LdStLoad +//    eieio      LdStLoad  //    eqv        IntGeneral  //    extsb      IntGeneral  //    extsh      IntGeneral @@ -202,10 +203,10 @@ include "PPCScheduleG5.td"  //    fsubs      FPGeneral  //    icbi       LdStICBI  //    isync      SprISYNC -//    lbz        LdStGeneral -//    lbzu       LdStGeneral +//    lbz        LdStLoad +//    lbzu       LdStLoad  //    lbzux      LdStUX -//    lbzx       LdStGeneral +//    lbzx       LdStLoad  //    ld         LdStLD  //    ldarx      LdStLDARX  //    ldu        LdStLD @@ -223,11 +224,11 @@ include "PPCScheduleG5.td"  //    lhau       LdStLHA  //    lhaux      LdStLHA  //    lhax       LdStLHA -//    lhbrx      LdStGeneral -//    lhz        LdStGeneral -//    lhzu       LdStGeneral +//    lhbrx      LdStLoad +//    lhz        LdStLoad +//    lhzu       LdStLoad  //    lhzux      LdStUX -//    lhzx       LdStGeneral +//    lhzx       LdStLoad  //    lmw        LdStLMW  //    lswi       LdStLMW  //    lswx       LdStLMW @@ -242,11 +243,11 @@ include "PPCScheduleG5.td"  //    lwarx      LdStLWARX  //    lwaux      LdStLHA  //    lwax       LdStLHA -//    lwbrx      LdStGeneral -//    lwz        LdStGeneral -//    lwzu       LdStGeneral +//    lwbrx      LdStLoad +//    lwz        LdStLoad +//    lwzu       LdStLoad  //    lwzux      LdStUX -//    lwzx       LdStGeneral +//    lwzx       LdStLoad  //    mcrf       BrMCR  //    mcrfs      FPGeneral  //    mcrxr      BrMCRX @@ -307,10 +308,10 @@ include "PPCScheduleG5.td"  //    srawi      IntShift  //    srd        IntRotateD  //    srw        IntGeneral -//    stb        LdStGeneral -//    stbu       LdStGeneral -//    stbux      LdStGeneral -//    stbx       LdStGeneral +//    stb        LdStStore +//    stbu       LdStStore +//    stbux      LdStStore +//    stbx       LdStStore  //    std        LdStSTD  //    stdcx.     LdStSTDCX  //    stdu       LdStSTD @@ -325,11 +326,11 @@ include "PPCScheduleG5.td"  //    stfsu      LdStUX  //    stfsux     LdStUX  //    stfsx      LdStUX -//    sth        LdStGeneral -//    sthbrx     LdStGeneral -//    sthu       LdStGeneral -//    sthux      LdStGeneral -//    sthx       LdStGeneral +//    sth        LdStStore +//    sthbrx     LdStStore +//    sthu       LdStStore +//    sthux      LdStStore +//    sthx       LdStStore  //    stmw       LdStLMW  //    stswi      LdStLMW  //    stswx      LdStLMW @@ -338,12 +339,12 @@ include "PPCScheduleG5.td"  //    stvewx     LdStSTVEBX  //    stvx       LdStSTVEBX  //    stvxl      LdStSTVEBX -//    stw        LdStGeneral -//    stwbrx     LdStGeneral +//    stw        LdStStore +//    stwbrx     LdStStore  //    stwcx.     LdStSTWCX -//    stwu       LdStGeneral -//    stwux      LdStGeneral -//    stwx       LdStGeneral +//    stwu       LdStStore +//    stwux      LdStStore +//    stwx       LdStStore  //    subf       IntGeneral  //    subfc      IntGeneral  //    subfe      IntGeneral diff --git a/llvm/lib/Target/PowerPC/PPCSchedule440.td b/llvm/lib/Target/PowerPC/PPCSchedule440.td index 76f74655f2f..9921fc8b952 100644 --- a/llvm/lib/Target/PowerPC/PPCSchedule440.td +++ b/llvm/lib/Target/PowerPC/PPCSchedule440.td @@ -270,15 +270,23 @@ def PPC440Itineraries : ProcessorItineraries<                                 InstrStage<1, [LWB]>],                                [8, 5],                                [NoBypass, GPR_Bypass]>, -  InstrItinData<LdStGeneral , [InstrStage<1, [IFTH1, IFTH2]>, +  InstrItinData<LdStLoad    , [InstrStage<1, [IFTH1, IFTH2]>,                                 InstrStage<1, [PDCD1, PDCD2]>,                                 InstrStage<1, [DISS1, DISS2]>,                                 InstrStage<1, [LRACC]>,                                 InstrStage<1, [AGEN]>,                                 InstrStage<1, [CRD]>,                                 InstrStage<2, [LWB]>], -                              [9, 5], // FIXME: should be [9, 5] for loads and -                                       // [8, 5] for stores. +                              [9, 5], +                              [GPR_Bypass, GPR_Bypass]>, +  InstrItinData<LdStStore   , [InstrStage<1, [IFTH1, IFTH2]>, +                               InstrStage<1, [PDCD1, PDCD2]>, +                               InstrStage<1, [DISS1, DISS2]>, +                               InstrStage<1, [LRACC]>, +                               InstrStage<1, [AGEN]>, +                               InstrStage<1, [CRD]>, +                               InstrStage<2, [LWB]>], +                              [8, 5],                                [NoBypass, GPR_Bypass]>,    InstrItinData<LdStICBI    , [InstrStage<1, [IFTH1, IFTH2]>,                                 InstrStage<1, [PDCD1, PDCD2]>, @@ -345,6 +353,26 @@ def PPC440Itineraries : ProcessorItineraries<                                 InstrStage<1, [LWB]>],                                [8, 5],                                [NoBypass, GPR_Bypass]>, +  InstrItinData<LdStSTD     , [InstrStage<1, [IFTH1, IFTH2]>, +                               InstrStage<1, [PDCD1, PDCD2]>, +                               InstrStage<1, [DISS1, DISS2]>, +                               InstrStage<1, [LRACC]>, +                               InstrStage<1, [AGEN]>, +                               InstrStage<1, [CRD]>, +                               InstrStage<2, [LWB]>], +                              [8, 5], +                              [NoBypass, GPR_Bypass]>, +  InstrItinData<LdStSTDCX   , [InstrStage<1, [IFTH1, IFTH2]>, +                               InstrStage<1, [PDCD1, PDCD2]>, +                               InstrStage<1, [DISS1]>, +                               InstrStage<1, [IRACC], 0>, +                               InstrStage<4, [LWARX_Hold], 0>, +                               InstrStage<1, [LRACC]>, +                               InstrStage<1, [AGEN]>, +                               InstrStage<1, [CRD]>, +                               InstrStage<1, [LWB]>], +                              [8, 5], +                              [NoBypass, GPR_Bypass]>,    InstrItinData<LdStSTWCX   , [InstrStage<1, [IFTH1, IFTH2]>,                                 InstrStage<1, [PDCD1, PDCD2]>,                                 InstrStage<1, [DISS1]>, diff --git a/llvm/lib/Target/PowerPC/PPCScheduleG3.td b/llvm/lib/Target/PowerPC/PPCScheduleG3.td index e7e54987664..bc926f7bb2b 100644 --- a/llvm/lib/Target/PowerPC/PPCScheduleG3.td +++ b/llvm/lib/Target/PowerPC/PPCScheduleG3.td @@ -32,7 +32,8 @@ def G3Itineraries : ProcessorItineraries<    InstrItinData<LdStDCBA    , [InstrStage<2, [SLU]>]>,    InstrItinData<LdStDCBF    , [InstrStage<3, [SLU]>]>,    InstrItinData<LdStDCBI    , [InstrStage<3, [SLU]>]>, -  InstrItinData<LdStGeneral , [InstrStage<2, [SLU]>]>, +  InstrItinData<LdStLoad    , [InstrStage<2, [SLU]>]>, +  InstrItinData<LdStStore   , [InstrStage<2, [SLU]>]>,    InstrItinData<LdStICBI    , [InstrStage<3, [SLU]>]>,    InstrItinData<LdStUX      , [InstrStage<2, [SLU]>]>,    InstrItinData<LdStLFD     , [InstrStage<2, [SLU]>]>, diff --git a/llvm/lib/Target/PowerPC/PPCScheduleG4.td b/llvm/lib/Target/PowerPC/PPCScheduleG4.td index 87a3151e7c7..f7ec1e01333 100644 --- a/llvm/lib/Target/PowerPC/PPCScheduleG4.td +++ b/llvm/lib/Target/PowerPC/PPCScheduleG4.td @@ -31,7 +31,8 @@ def G4Itineraries : ProcessorItineraries<    InstrItinData<BrMCRX      , [InstrStage<1, [SRU]>]>,    InstrItinData<LdStDCBF    , [InstrStage<2, [SLU]>]>,    InstrItinData<LdStDCBI    , [InstrStage<2, [SLU]>]>, -  InstrItinData<LdStGeneral , [InstrStage<2, [SLU]>]>, +  InstrItinData<LdStLoad    , [InstrStage<2, [SLU]>]>, +  InstrItinData<LdStStore   , [InstrStage<2, [SLU]>]>,    InstrItinData<LdStDSS     , [InstrStage<2, [SLU]>]>,    InstrItinData<LdStICBI    , [InstrStage<2, [SLU]>]>,    InstrItinData<LdStUX      , [InstrStage<2, [SLU]>]>, diff --git a/llvm/lib/Target/PowerPC/PPCScheduleG4Plus.td b/llvm/lib/Target/PowerPC/PPCScheduleG4Plus.td index f76557afc8b..37ebfc59880 100644 --- a/llvm/lib/Target/PowerPC/PPCScheduleG4Plus.td +++ b/llvm/lib/Target/PowerPC/PPCScheduleG4Plus.td @@ -34,7 +34,8 @@ def G4PlusItineraries : ProcessorItineraries<    InstrItinData<BrMCRX      , [InstrStage<2, [IU2]>]>,    InstrItinData<LdStDCBF    , [InstrStage<3, [SLU]>]>,    InstrItinData<LdStDCBI    , [InstrStage<3, [SLU]>]>, -  InstrItinData<LdStGeneral , [InstrStage<3, [SLU]>]>, +  InstrItinData<LdStLoad    , [InstrStage<3, [SLU]>]>, +  InstrItinData<LdStStore   , [InstrStage<3, [SLU]>]>,    InstrItinData<LdStDSS     , [InstrStage<3, [SLU]>]>,    InstrItinData<LdStICBI    , [InstrStage<3, [IU2]>]>,    InstrItinData<LdStUX      , [InstrStage<3, [SLU]>]>, diff --git a/llvm/lib/Target/PowerPC/PPCScheduleG5.td b/llvm/lib/Target/PowerPC/PPCScheduleG5.td index bc0820b1020..d1e40cef963 100644 --- a/llvm/lib/Target/PowerPC/PPCScheduleG5.td +++ b/llvm/lib/Target/PowerPC/PPCScheduleG5.td @@ -35,7 +35,8 @@ def G5Itineraries : ProcessorItineraries<    InstrItinData<BrMCR       , [InstrStage<2, [BPU]>]>,    InstrItinData<BrMCRX      , [InstrStage<3, [BPU]>]>,    InstrItinData<LdStDCBF    , [InstrStage<3, [SLU]>]>, -  InstrItinData<LdStGeneral , [InstrStage<3, [SLU]>]>, +  InstrItinData<LdStLoad    , [InstrStage<3, [SLU]>]>, +  InstrItinData<LdStStore   , [InstrStage<3, [SLU]>]>,    InstrItinData<LdStDSS     , [InstrStage<10, [SLU]>]>,    InstrItinData<LdStICBI    , [InstrStage<40, [SLU]>]>,    InstrItinData<LdStUX      , [InstrStage<4, [SLU]>]>, | 

