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/PowerPC/PPCSchedule.td | |
| 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/PowerPC/PPCSchedule.td')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCSchedule.td | 63 | 
1 files changed, 32 insertions, 31 deletions
| 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 | 

