diff options
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Target/X86/X86SchedSkylakeClient.td | 6 | ||||
-rw-r--r-- | llvm/lib/Target/X86/X86SchedSkylakeServer.td | 6 |
2 files changed, 8 insertions, 4 deletions
diff --git a/llvm/lib/Target/X86/X86SchedSkylakeClient.td b/llvm/lib/Target/X86/X86SchedSkylakeClient.td index b5d842a52b5..d4a3eb07b98 100644 --- a/llvm/lib/Target/X86/X86SchedSkylakeClient.td +++ b/llvm/lib/Target/X86/X86SchedSkylakeClient.td @@ -1133,7 +1133,8 @@ def SKLWriteResGroup91 : SchedWriteRes<[SKLPort23,SKLPort015]> { def: InstRW<[SKLWriteResGroup91], (instrs VINSERTF128rm, VINSERTI128rm, VPBLENDDrmi)>; -def: InstRW<[SKLWriteResGroup91], (instregex "(V?)PADD(B|D|Q|W)rm", +def: InstRW<[SKLWriteResGroup91, ReadAfterVecXLd], + (instregex "(V?)PADD(B|D|Q|W)rm", "(V?)PSUB(B|D|Q|W)rm")>; def SKLWriteResGroup92 : SchedWriteRes<[SKLPort5,SKLPort23]> { @@ -1230,7 +1231,8 @@ def SKLWriteResGroup110 : SchedWriteRes<[SKLPort23,SKLPort015]> { let ResourceCycles = [1,1]; } def: InstRW<[SKLWriteResGroup110], (instrs VPBLENDDYrmi)>; -def: InstRW<[SKLWriteResGroup110], (instregex "VPADD(B|D|Q|W)Yrm", +def: InstRW<[SKLWriteResGroup110, ReadAfterVecYLd], + (instregex "VPADD(B|D|Q|W)Yrm", "VPSUB(B|D|Q|W)Yrm")>; def SKLWriteResGroup112 : SchedWriteRes<[SKLPort0,SKLPort5,SKLPort23]> { diff --git a/llvm/lib/Target/X86/X86SchedSkylakeServer.td b/llvm/lib/Target/X86/X86SchedSkylakeServer.td index d3fa912be11..cbcb6a6e58b 100644 --- a/llvm/lib/Target/X86/X86SchedSkylakeServer.td +++ b/llvm/lib/Target/X86/X86SchedSkylakeServer.td @@ -1339,7 +1339,8 @@ def SKXWriteResGroup95 : SchedWriteRes<[SKXPort23,SKXPort015]> { } def: InstRW<[SKXWriteResGroup95], (instrs VMOVNTDQAZ128rm, VPBLENDDrmi)>; -def: InstRW<[SKXWriteResGroup95], (instregex "VBLENDMPDZ128rm(b?)", +def: InstRW<[SKXWriteResGroup95, ReadAfterVecXLd], + (instregex "VBLENDMPDZ128rm(b?)", "VBLENDMPSZ128rm(b?)", "VBROADCASTI32X2Z128m(b?)", "VBROADCASTSSZ128m(b?)", @@ -1534,7 +1535,8 @@ def SKXWriteResGroup121 : SchedWriteRes<[SKXPort23,SKXPort015]> { } def: InstRW<[SKXWriteResGroup121], (instrs VMOVNTDQAZ256rm, VPBLENDDYrmi)>; -def: InstRW<[SKXWriteResGroup121], (instregex "VBLENDMPD(Z|Z256)rm(b?)", +def: InstRW<[SKXWriteResGroup121, ReadAfterVecYLd], + (instregex "VBLENDMPD(Z|Z256)rm(b?)", "VBLENDMPS(Z|Z256)rm(b?)", "VBROADCASTF32X2Z256m(b?)", "VBROADCASTF32X2Zm(b?)", |