[X86] Merge shift/rotate schedule class instregexs

Helps reduce cost of instrw collection

llvm-svn: 340123
This commit is contained in:
Simon Pilgrim 2018-08-18 15:58:19 +00:00
parent 68c706ceb7
commit ebfd6ebba7
5 changed files with 51 additions and 102 deletions

View File

@ -654,10 +654,8 @@ def BWWriteResGroup13 : SchedWriteRes<[BWPort06]> {
let NumMicroOps = 2; let NumMicroOps = 2;
let ResourceCycles = [2]; let ResourceCycles = [2];
} }
def: InstRW<[BWWriteResGroup13], (instregex "ROL(8|16|32|64)r1", def: InstRW<[BWWriteResGroup13], (instregex "ROL(8|16|32|64)r(1|i)",
"ROL(8|16|32|64)ri", "ROR(8|16|32|64)r(1|i)")>;
"ROR(8|16|32|64)r1",
"ROR(8|16|32|64)ri")>;
def BWWriteResGroup14 : SchedWriteRes<[BWPort0156]> { def BWWriteResGroup14 : SchedWriteRes<[BWPort0156]> {
let Latency = 2; let Latency = 2;
@ -781,10 +779,8 @@ def BWWriteResGroup35 : SchedWriteRes<[BWPort06,BWPort0156]> {
let NumMicroOps = 3; let NumMicroOps = 3;
let ResourceCycles = [1,2]; let ResourceCycles = [1,2];
} }
def: InstRW<[BWWriteResGroup35], (instregex "RCL(8|16|32|64)r1", def: InstRW<[BWWriteResGroup35], (instregex "RCL(8|16|32|64)r(1|i)",
"RCL(8|16|32|64)ri", "RCR(8|16|32|64)r(1|i)")>;
"RCR(8|16|32|64)r1",
"RCR(8|16|32|64)ri")>;
def BWWriteResGroup36 : SchedWriteRes<[BWPort06,BWPort0156]> { def BWWriteResGroup36 : SchedWriteRes<[BWPort06,BWPort0156]> {
let Latency = 3; let Latency = 3;
@ -1056,12 +1052,9 @@ def BWWriteResGroup69 : SchedWriteRes<[BWPort4,BWPort23,BWPort237,BWPort06]> {
def: InstRW<[BWWriteResGroup69], (instregex "BTC(16|32|64)mi8", def: InstRW<[BWWriteResGroup69], (instregex "BTC(16|32|64)mi8",
"BTR(16|32|64)mi8", "BTR(16|32|64)mi8",
"BTS(16|32|64)mi8", "BTS(16|32|64)mi8",
"SAR(8|16|32|64)m1", "SAR(8|16|32|64)m(1|i)",
"SAR(8|16|32|64)mi", "SHL(8|16|32|64)m(1|i)",
"SHL(8|16|32|64)m1", "SHR(8|16|32|64)m(1|i)")>;
"SHL(8|16|32|64)mi",
"SHR(8|16|32|64)m1",
"SHR(8|16|32|64)mi")>;
def BWWriteResGroup70 : SchedWriteRes<[BWPort4,BWPort23,BWPort237,BWPort0156]> { def BWWriteResGroup70 : SchedWriteRes<[BWPort4,BWPort23,BWPort237,BWPort0156]> {
let Latency = 6; let Latency = 6;
@ -1136,10 +1129,8 @@ def BWWriteResGroup87 : SchedWriteRes<[BWPort4,BWPort23,BWPort237,BWPort06]> {
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[BWWriteResGroup87], (instregex "ROL(8|16|32|64)m1", def: InstRW<[BWWriteResGroup87], (instregex "ROL(8|16|32|64)m(1|i)",
"ROL(8|16|32|64)mi", "ROR(8|16|32|64)m(1|i)")>;
"ROR(8|16|32|64)m1",
"ROR(8|16|32|64)mi")>;
def BWWriteResGroup88 : SchedWriteRes<[BWPort4,BWPort23,BWPort237,BWPort0156]> { def BWWriteResGroup88 : SchedWriteRes<[BWPort4,BWPort23,BWPort237,BWPort0156]> {
let Latency = 7; let Latency = 7;
@ -1205,10 +1196,8 @@ def BWWriteResGroup97 : SchedWriteRes<[BWPort23,BWPort237,BWPort06,BWPort0156]>
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[BWWriteResGroup97], (instregex "RCL(8|16|32|64)m1", def: InstRW<[BWWriteResGroup97], (instregex "RCL(8|16|32|64)m(1|i)",
"RCL(8|16|32|64)mi", "RCR(8|16|32|64)m(1|i)")>;
"RCR(8|16|32|64)m1",
"RCR(8|16|32|64)mi")>;
def BWWriteResGroup98 : SchedWriteRes<[BWPort23,BWPort237,BWPort06,BWPort0156]> { def BWWriteResGroup98 : SchedWriteRes<[BWPort23,BWPort237,BWPort06,BWPort0156]> {
let Latency = 8; let Latency = 8;

View File

@ -1092,12 +1092,9 @@ def HWWriteResGroup25 : SchedWriteRes<[HWPort4,HWPort23,HWPort237,HWPort06]> {
def: InstRW<[HWWriteResGroup25], (instregex "BTC(16|32|64)mi8", def: InstRW<[HWWriteResGroup25], (instregex "BTC(16|32|64)mi8",
"BTR(16|32|64)mi8", "BTR(16|32|64)mi8",
"BTS(16|32|64)mi8", "BTS(16|32|64)mi8",
"SAR(8|16|32|64)m1", "SAR(8|16|32|64)m(1|i)",
"SAR(8|16|32|64)mi", "SHL(8|16|32|64)m(1|i)",
"SHL(8|16|32|64)m1", "SHR(8|16|32|64)m(1|i)")>;
"SHL(8|16|32|64)mi",
"SHR(8|16|32|64)m1",
"SHR(8|16|32|64)mi")>;
def HWWriteResGroup26 : SchedWriteRes<[HWPort4,HWPort23,HWPort237,HWPort0156]> { def HWWriteResGroup26 : SchedWriteRes<[HWPort4,HWPort23,HWPort237,HWPort0156]> {
let Latency = 7; let Latency = 7;
@ -1119,10 +1116,8 @@ def HWWriteResGroup29 : SchedWriteRes<[HWPort06]> {
let NumMicroOps = 2; let NumMicroOps = 2;
let ResourceCycles = [2]; let ResourceCycles = [2];
} }
def: InstRW<[HWWriteResGroup29], (instregex "ROL(8|16|32|64)r1", def: InstRW<[HWWriteResGroup29], (instregex "ROL(8|16|32|64)r(1|i)",
"ROL(8|16|32|64)ri", "ROR(8|16|32|64)r(1|i)")>;
"ROR(8|16|32|64)r1",
"ROR(8|16|32|64)ri")>;
def HWWriteResGroup30 : SchedWriteRes<[HWPort0156]> { def HWWriteResGroup30 : SchedWriteRes<[HWPort0156]> {
let Latency = 2; let Latency = 2;
@ -1215,10 +1210,8 @@ def HWWriteResGroup46 : SchedWriteRes<[HWPort4,HWPort23,HWPort237,HWPort06]> {
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[HWWriteResGroup46], (instregex "ROL(8|16|32|64)m1", def: InstRW<[HWWriteResGroup46], (instregex "ROL(8|16|32|64)m(1|i)",
"ROL(8|16|32|64)mi", "ROR(8|16|32|64)m(1|i)")>;
"ROR(8|16|32|64)m1",
"ROR(8|16|32|64)mi")>;
def HWWriteResGroup47 : SchedWriteRes<[HWPort4,HWPort23,HWPort237,HWPort0156]> { def HWWriteResGroup47 : SchedWriteRes<[HWPort4,HWPort23,HWPort237,HWPort0156]> {
let Latency = 8; let Latency = 8;
@ -1309,10 +1302,8 @@ def HWWriteResGroup59 : SchedWriteRes<[HWPort06,HWPort0156]> {
let NumMicroOps = 3; let NumMicroOps = 3;
let ResourceCycles = [1,2]; let ResourceCycles = [1,2];
} }
def: InstRW<[HWWriteResGroup59], (instregex "RCL(8|16|32|64)r1", def: InstRW<[HWWriteResGroup59], (instregex "RCL(8|16|32|64)r(1|i)",
"RCL(8|16|32|64)ri", "RCR(8|16|32|64)r(1|i)")>;
"RCR(8|16|32|64)r1",
"RCR(8|16|32|64)ri")>;
def HWWriteResGroup60 : SchedWriteRes<[HWPort06,HWPort0156]> { def HWWriteResGroup60 : SchedWriteRes<[HWPort06,HWPort0156]> {
let Latency = 3; let Latency = 3;
@ -1345,10 +1336,8 @@ def HWWriteResGroup66 : SchedWriteRes<[HWPort23,HWPort237,HWPort06,HWPort0156]>
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[HWWriteResGroup66], (instregex "RCL(8|16|32|64)m1", def: InstRW<[HWWriteResGroup66], (instregex "RCL(8|16|32|64)m(1|i)",
"RCL(8|16|32|64)mi", "RCR(8|16|32|64)m(1|i)")>;
"RCR(8|16|32|64)m1",
"RCR(8|16|32|64)mi")>;
def HWWriteResGroup67 : SchedWriteRes<[HWPort23,HWPort237,HWPort06,HWPort0156]> { def HWWriteResGroup67 : SchedWriteRes<[HWPort23,HWPort237,HWPort06,HWPort0156]> {
let Latency = 9; let Latency = 9;

View File

@ -588,10 +588,8 @@ def SBWriteResGroup9 : SchedWriteRes<[SBPort05]> {
let NumMicroOps = 2; let NumMicroOps = 2;
let ResourceCycles = [2]; let ResourceCycles = [2];
} }
def: InstRW<[SBWriteResGroup9], (instregex "ROL(8|16|32|64)r1", def: InstRW<[SBWriteResGroup9], (instregex "ROL(8|16|32|64)r(1|i)",
"ROL(8|16|32|64)ri", "ROR(8|16|32|64)r(1|i)",
"ROR(8|16|32|64)r1",
"ROR(8|16|32|64)ri",
"SET(A|BE)r")>; "SET(A|BE)r")>;
def SBWriteResGroup11 : SchedWriteRes<[SBPort015]> { def SBWriteResGroup11 : SchedWriteRes<[SBPort015]> {
@ -939,12 +937,9 @@ def SBWriteResGroup69 : SchedWriteRes<[SBPort4,SBPort23,SBPort05]> {
def: InstRW<[SBWriteResGroup69], (instregex "BTC(16|32|64)mi8", def: InstRW<[SBWriteResGroup69], (instregex "BTC(16|32|64)mi8",
"BTR(16|32|64)mi8", "BTR(16|32|64)mi8",
"BTS(16|32|64)mi8", "BTS(16|32|64)mi8",
"SAR(8|16|32|64)m1", "SAR(8|16|32|64)m(1|i)",
"SAR(8|16|32|64)mi", "SHL(8|16|32|64)m(1|i)",
"SHL(8|16|32|64)m1", "SHR(8|16|32|64)m(1|i)")>;
"SHL(8|16|32|64)mi",
"SHR(8|16|32|64)m1",
"SHR(8|16|32|64)mi")>;
def SBWriteResGroup77 : SchedWriteRes<[SBPort0,SBPort1,SBPort23]> { def SBWriteResGroup77 : SchedWriteRes<[SBPort0,SBPort1,SBPort23]> {
let Latency = 8; let Latency = 8;
@ -982,10 +977,8 @@ def SBWriteResGroup85 : SchedWriteRes<[SBPort4,SBPort23,SBPort05]> {
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,2,2]; let ResourceCycles = [1,2,2];
} }
def: InstRW<[SBWriteResGroup85], (instregex "ROL(8|16|32|64)m1", def: InstRW<[SBWriteResGroup85], (instregex "ROL(8|16|32|64)m(1|i)",
"ROL(8|16|32|64)mi", "ROR(8|16|32|64)m(1|i)")>;
"ROR(8|16|32|64)m1",
"ROR(8|16|32|64)mi")>;
def SBWriteResGroup86 : SchedWriteRes<[SBPort4,SBPort23,SBPort015]> { def SBWriteResGroup86 : SchedWriteRes<[SBPort4,SBPort23,SBPort015]> {
let Latency = 8; let Latency = 8;

View File

@ -669,10 +669,8 @@ def SKLWriteResGroup15 : SchedWriteRes<[SKLPort06]> {
let NumMicroOps = 2; let NumMicroOps = 2;
let ResourceCycles = [2]; let ResourceCycles = [2];
} }
def: InstRW<[SKLWriteResGroup15], (instregex "ROL(8|16|32|64)r1", def: InstRW<[SKLWriteResGroup15], (instregex "ROL(8|16|32|64)r(1|i)",
"ROL(8|16|32|64)ri", "ROR(8|16|32|64)r(1|i)",
"ROR(8|16|32|64)r1",
"ROR(8|16|32|64)ri",
"SET(A|BE)r")>; "SET(A|BE)r")>;
def SKLWriteResGroup17 : SchedWriteRes<[SKLPort0156]> { def SKLWriteResGroup17 : SchedWriteRes<[SKLPort0156]> {
@ -820,10 +818,8 @@ def SKLWriteResGroup42 : SchedWriteRes<[SKLPort06,SKLPort0156]> {
let NumMicroOps = 3; let NumMicroOps = 3;
let ResourceCycles = [1,2]; let ResourceCycles = [1,2];
} }
def: InstRW<[SKLWriteResGroup42], (instregex "RCL(8|16|32|64)r1", def: InstRW<[SKLWriteResGroup42], (instregex "RCL(8|16|32|64)r(1|i)",
"RCL(8|16|32|64)ri", "RCR(8|16|32|64)r(1|i)")>;
"RCR(8|16|32|64)r1",
"RCR(8|16|32|64)ri")>;
def SKLWriteResGroup43 : SchedWriteRes<[SKLPort0,SKLPort4,SKLPort237]> { def SKLWriteResGroup43 : SchedWriteRes<[SKLPort0,SKLPort4,SKLPort237]> {
let Latency = 3; let Latency = 3;
@ -1097,12 +1093,9 @@ def SKLWriteResGroup82 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort06]
def: InstRW<[SKLWriteResGroup82], (instregex "BTC(16|32|64)mi8", def: InstRW<[SKLWriteResGroup82], (instregex "BTC(16|32|64)mi8",
"BTR(16|32|64)mi8", "BTR(16|32|64)mi8",
"BTS(16|32|64)mi8", "BTS(16|32|64)mi8",
"SAR(8|16|32|64)m1", "SAR(8|16|32|64)m(1|i)",
"SAR(8|16|32|64)mi", "SHL(8|16|32|64)m(1|i)",
"SHL(8|16|32|64)m1", "SHR(8|16|32|64)m(1|i)")>;
"SHL(8|16|32|64)mi",
"SHR(8|16|32|64)m1",
"SHR(8|16|32|64)mi")>;
def SKLWriteResGroup83 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort0156]> { def SKLWriteResGroup83 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort0156]> {
let Latency = 6; let Latency = 6;
@ -1217,10 +1210,8 @@ def SKLWriteResGroup100 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort06
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[SKLWriteResGroup100], (instregex "ROL(8|16|32|64)m1", def: InstRW<[SKLWriteResGroup100], (instregex "ROL(8|16|32|64)m(1|i)",
"ROL(8|16|32|64)mi", "ROR(8|16|32|64)m(1|i)")>;
"ROR(8|16|32|64)m1",
"ROR(8|16|32|64)mi")>;
def SKLWriteResGroup101 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort0156]> { def SKLWriteResGroup101 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort0156]> {
let Latency = 7; let Latency = 7;
@ -1306,10 +1297,8 @@ def SKLWriteResGroup116 : SchedWriteRes<[SKLPort23,SKLPort237,SKLPort06,SKLPort0
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[SKLWriteResGroup116], (instregex "RCL(8|16|32|64)m1", def: InstRW<[SKLWriteResGroup116], (instregex "RCL(8|16|32|64)m(1|i)",
"RCL(8|16|32|64)mi", "RCR(8|16|32|64)m(1|i)")>;
"RCR(8|16|32|64)m1",
"RCR(8|16|32|64)mi")>;
def SKLWriteResGroup117 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort06]> { def SKLWriteResGroup117 : SchedWriteRes<[SKLPort4,SKLPort23,SKLPort237,SKLPort06]> {
let Latency = 8; let Latency = 8;

View File

@ -693,10 +693,8 @@ def SKXWriteResGroup15 : SchedWriteRes<[SKXPort06]> {
let NumMicroOps = 2; let NumMicroOps = 2;
let ResourceCycles = [2]; let ResourceCycles = [2];
} }
def: InstRW<[SKXWriteResGroup15], (instregex "ROL(8|16|32|64)r1", def: InstRW<[SKXWriteResGroup15], (instregex "ROL(8|16|32|64)r(1|i)",
"ROL(8|16|32|64)ri", "ROR(8|16|32|64)r(1|i)",
"ROR(8|16|32|64)r1",
"ROR(8|16|32|64)ri",
"SET(A|BE)r")>; "SET(A|BE)r")>;
def SKXWriteResGroup17 : SchedWriteRes<[SKXPort0156]> { def SKXWriteResGroup17 : SchedWriteRes<[SKXPort0156]> {
@ -887,10 +885,8 @@ def SKXWriteResGroup44 : SchedWriteRes<[SKXPort06,SKXPort0156]> {
let NumMicroOps = 3; let NumMicroOps = 3;
let ResourceCycles = [1,2]; let ResourceCycles = [1,2];
} }
def: InstRW<[SKXWriteResGroup44], (instregex "RCL(8|16|32|64)r1", def: InstRW<[SKXWriteResGroup44], (instregex "RCL(8|16|32|64)r(1|i)",
"RCL(8|16|32|64)ri", "RCR(8|16|32|64)r(1|i)")>;
"RCR(8|16|32|64)r1",
"RCR(8|16|32|64)ri")>;
def SKXWriteResGroup45 : SchedWriteRes<[SKXPort0,SKXPort4,SKXPort237]> { def SKXWriteResGroup45 : SchedWriteRes<[SKXPort0,SKXPort4,SKXPort237]> {
let Latency = 3; let Latency = 3;
@ -1271,12 +1267,9 @@ def SKXWriteResGroup86 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort06]
def: InstRW<[SKXWriteResGroup86], (instregex "BTC(16|32|64)mi8", def: InstRW<[SKXWriteResGroup86], (instregex "BTC(16|32|64)mi8",
"BTR(16|32|64)mi8", "BTR(16|32|64)mi8",
"BTS(16|32|64)mi8", "BTS(16|32|64)mi8",
"SAR(8|16|32|64)m1", "SAR(8|16|32|64)m(1|i)",
"SAR(8|16|32|64)mi", "SHL(8|16|32|64)m(1|i)",
"SHL(8|16|32|64)m1", "SHR(8|16|32|64)m(1|i)")>;
"SHL(8|16|32|64)mi",
"SHR(8|16|32|64)m1",
"SHR(8|16|32|64)mi")>;
def SKXWriteResGroup87 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort0156]> { def SKXWriteResGroup87 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort0156]> {
let Latency = 6; let Latency = 6;
@ -1487,10 +1480,8 @@ def SKXWriteResGroup107 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort06
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[SKXWriteResGroup107], (instregex "ROL(8|16|32|64)m1", def: InstRW<[SKXWriteResGroup107], (instregex "ROL(8|16|32|64)m(1|i)",
"ROL(8|16|32|64)mi", "ROR(8|16|32|64)m(1|i)")>;
"ROR(8|16|32|64)m1",
"ROR(8|16|32|64)mi")>;
def SKXWriteResGroup108 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort0156]> { def SKXWriteResGroup108 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort0156]> {
let Latency = 7; let Latency = 7;
@ -1665,10 +1656,8 @@ def SKXWriteResGroup127 : SchedWriteRes<[SKXPort23,SKXPort237,SKXPort06,SKXPort0
let NumMicroOps = 5; let NumMicroOps = 5;
let ResourceCycles = [1,1,1,2]; let ResourceCycles = [1,1,1,2];
} }
def: InstRW<[SKXWriteResGroup127], (instregex "RCL(8|16|32|64)m1", def: InstRW<[SKXWriteResGroup127], (instregex "RCL(8|16|32|64)m(1|i)",
"RCL(8|16|32|64)mi", "RCR(8|16|32|64)m(1|i)")>;
"RCR(8|16|32|64)m1",
"RCR(8|16|32|64)mi")>;
def SKXWriteResGroup128 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort06]> { def SKXWriteResGroup128 : SchedWriteRes<[SKXPort4,SKXPort23,SKXPort237,SKXPort06]> {
let Latency = 8; let Latency = 8;