[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