[PATCH] D47721: [X86] Fix skylake server scheduling info.
Clement Courbet via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Jun 11 05:49:27 PDT 2018
courbet added a comment.
Thanks !
================
Comment at: lib/Target/X86/X86SchedSkylakeServer.td:378
// Conversion between integer and float.
-defm : SKXWriteResPair<WriteCvtSS2I, [SKXPort0,SKXPort015], 6, [1,1], 2>;
-defm : SKXWriteResPair<WriteCvtPS2I, [SKXPort1], 3>;
-defm : SKXWriteResPair<WriteCvtPS2IY, [SKXPort1], 3>;
-defm : SKXWriteResPair<WriteCvtSD2I, [SKXPort0,SKXPort015], 6, [1,1], 2>;
-defm : SKXWriteResPair<WriteCvtPD2I, [SKXPort1], 3>;
-defm : SKXWriteResPair<WriteCvtPD2IY, [SKXPort1], 3>;
+defm : SKXWriteResPair<WriteCvtSS2I, [SKXPort01], 6, [2], 2>; // Needs more work: DD vs DQ.
+defm : SKXWriteResPair<WriteCvtPS2I, [SKXPort01], 3>;
----------------
RKSimon wrote:
> The QQ conversions might be best off with instrw overrides?
I guess so. I'll do it in a separate commit as there are already a lot of changes here :(
================
Comment at: lib/Target/X86/X86SchedSkylakeServer.td:406
+defm : X86WriteRes<WriteCvtPH2PS, [SKXPort5,SKXPort01], 5, [1,1], 2>;
+defm : X86WriteRes<WriteCvtPH2PSY, [SKXPort5,SKXPort01], 7, [1,1], 2>; // Needs more work.
+defm : X86WriteRes<WriteCvtPH2PSZ, [SKXPort5,SKXPort0], 7, [1,1], 2>;
----------------
RKSimon wrote:
> WriteCvtPH2PSY is the one that does pass your tests - it's WriteCvtPH2PS and WriteCvtPH2PSZ that are irregular?
Thanks for the catch. This has been addressed indeed. The other two are a tiny bit irregular but nothing crazy - I think it's just noise.
================
Comment at: lib/Target/X86/X86SchedSkylakeServer.td:609
}
-def: InstRW<[SKXWriteResGroup7], (instrs CDQ, CQO, CLAC, STAC)>;
+def: InstRW<[SKXWriteResGroup7], (instrs CDQ, CQO, CLAC, STAC, LAHF, SAHF)>;
def: InstRW<[SKXWriteResGroup7], (instregex "BT(16|32|64)ri8",
----------------
RKSimon wrote:
> Worth pulling the LAHF/SAHF change out into its own patch as IIRC a lot of Intel models have dodgy values for this?
Will do.
Repository:
rL LLVM
https://reviews.llvm.org/D47721
More information about the llvm-commits
mailing list