Simon Pilgrim
706403bab8
[X86][MMX] Tag MMX Move/Load/Store as WriteVec schedule classes
...
Fixes an issue on SLM/Btver2 where we had instructions were being treated as scalar loads/stores
llvm-svn: 332104
2018-05-11 16:38:59 +00:00
Simon Pilgrim
22dd72b995
[X86] Split WriteF/WriteVec Move/Load/Store scheduler classes by vector width
...
Fixes a SNB issue that was missing vlddqu/vmovntdqa ymm instructions
llvm-svn: 332094
2018-05-11 14:30:54 +00:00
Simon Pilgrim
a3686c9a28
[X86] Convert/Merge more instregex patterns to reduce InstrRW compile time.
...
Use instrs lists or merge multiple instregex patterns.
llvm-svn: 332022
2018-05-10 19:08:06 +00:00
Simon Pilgrim
38ac0e9c6b
[X86] Split WriteVecALU/WriteVecLogic/WriteShuffle/WriteVarShuffle/WritePSADBW/WritePHAdd scheduler classes
...
Split off XMM classes from the default (MMX) classes.
llvm-svn: 331999
2018-05-10 17:06:09 +00:00
Simon Pilgrim
d5d4cdb49d
[X86] Merge instregex patterns to reduce InstrRW compile time.
...
llvm-svn: 331911
2018-05-09 19:04:15 +00:00
Simon Pilgrim
ab34aa8294
[X86] Cleanup WriteFStore/WriteVecStore schedules
...
MOVNTPD/MOVNTPS should be WriteFStore
Standardized BDW/HSW/SKL/SKX WriteFStore/WriteVecStore - fixes some missed instregex patterns. (V)MASKMOVDQU was already using the default, its costs gets increased but is still nowhere near the real cost of that nasty instruction....
llvm-svn: 331864
2018-05-09 11:01:16 +00:00
Simon Pilgrim
2864b46469
[X86] Split off WriteIMul64 from WriteIMul schedule class (PR36931)
...
This fixes a couple of BtVer2 missing instructions that weren't been handled in the override.
NOTE: There are still a lot of overrides that still need cleaning up!
llvm-svn: 331770
2018-05-08 14:55:16 +00:00
Simon Pilgrim
2580554333
[X86] Split WriteIDiv into div/idiv 8/16/32/64 implementations (PR36930)
...
I've created the necessary classes but there are still a lot of overrides that need cleaning up.
NOTE: The Znver1 model was missing some div/idiv variants in the instregex patterns and wasn't setting the resource cycles at all in the overrides.
llvm-svn: 331767
2018-05-08 13:51:45 +00:00
Simon Pilgrim
b0a3be04ec
[X86] Add vector masked load/store scheduler classes (PR32857)
...
Split off from existing vector load/store classes to remove InstRW overrides.
llvm-svn: 331760
2018-05-08 12:17:55 +00:00
Simon Pilgrim
210286ed8f
[X86] Add SchedWriteFTest/SchedWriteVecTest TEST scheduler classes
...
Split off from SchedWriteVecLogic to remove InstRW overrides.
llvm-svn: 331757
2018-05-08 10:28:03 +00:00
Simon Pilgrim
1233e1234a
[X86] Split WriteFAdd/WriteFCmp/WriteFMul schedule classes
...
Split to support single/double for scalar, XMM and YMM/ZMM instructions - removing InstrRW overrides for these instructions.
Fixes Atom ADDSUBPD instruction and reclassifies VFPCLASS as WriteFCmp which is closer in behaviour.
llvm-svn: 331672
2018-05-07 20:52:53 +00:00
Simon Pilgrim
e480ed0b9f
[X86][AVX2] Tag VPMOVSX/VPMOVZX ymm instructions as WriteShuffle256
...
These are more like cross-lane shuffles than regular shuffles - we already do this for AVX512 equivalents.
Differential Revision: https://reviews.llvm.org/D46229
llvm-svn: 331659
2018-05-07 18:25:19 +00:00
Simon Pilgrim
ac5d0a31ef
[X86] Split WriteFDiv schedule classes to support single/double scalar, XMM and YMM/ZMM instructions.
...
This removes all InstrRW overrides for these instructions - some x87 overrides remain but most use default (and realistic) values.
llvm-svn: 331643
2018-05-07 16:15:46 +00:00
Simon Pilgrim
f3ae50fca2
[X86] Split WriteFRcp/WriteFRsqrt/WriteFSqrt schedule classes
...
WriteFRcp/WriteFRsqrt are split to support scalar, XMM and YMM/ZMM instructions.
WriteFSqrt is split into single/double/long-double sizes and scalar, XMM, YMM and ZMM instructions.
This removes all InstrRW overrides for these instructions.
NOTE: There were a couple of typos in the Znver1 model - notably a 1cy throughput for SQRT that is highly unlikely and doesn't tally with Agner.
NOTE: I had to add Agner's numbers for several targets for WriteFSqrt80.
llvm-svn: 331629
2018-05-07 11:50:44 +00:00
Simon Pilgrim
0e51a125ea
[X86] Add WriteEMMS scheduler class
...
Filled in the missing values from Btver2 SoG or Agner
llvm-svn: 331546
2018-05-04 18:16:13 +00:00
Simon Pilgrim
d7ffbc5c7e
[X86] Finish splitting WriteVecShift and WriteVecIMul to remove InstRW overrides.
...
llvm-svn: 331543
2018-05-04 17:47:46 +00:00
Simon Pilgrim
67cc246dca
[X86] Cleanup SchedWriteFMA classes and use X86SchedWriteWidths directly.
...
Rename scalar and XMM versions, this is to match/simplify an upcoming change to split MUL/DIV/SQRT scalar/xmm/ymm/zmm classes.
llvm-svn: 331531
2018-05-04 15:20:18 +00:00
Simon Pilgrim
bf4c8c0ff2
[X86] Add WriteVecMOVMSKY scheduler class
...
llvm-svn: 331525
2018-05-04 14:54:33 +00:00
Simon Pilgrim
be51b20127
[X86] Add SchedWriteFRnd fp rounding scheduler classes
...
Split off from SchedWriteFAdd for fp rounding/bit-manipulation instructions.
Fixes an issue on btver2 which only had the ymm version using the JSTC pipe instead of JFPA.
llvm-svn: 331515
2018-05-04 12:59:24 +00:00
Simon Pilgrim
542b20d656
[X86] Add WriteDPPD/WriteDPPS dot product scheduler classes
...
llvm-svn: 331489
2018-05-03 22:31:19 +00:00
Simon Pilgrim
f2d2cedab4
[X86] Split WriteVecShift/WriteVarVecShift into MMX, XMM and YMM/ZMM scheduler classes
...
This took a bit of extra work as on Intel targets the old (V)PSLLDrr/(V)PSLLDrm style instructions act differently - I ended up creating WriteVecShiftImm classes for XMM/YMM/ZMM vector shift by immediate and retaining WriteVecShift as the default (used only by MMX) plus WriteVecShiftX/WriteVecShiftY. X86SchedWriteWidths hides most of this thank goodness.
llvm-svn: 331472
2018-05-03 17:56:43 +00:00
Simon Pilgrim
f7dd6069a5
[X86] Split WriteVecALU/WritePHAdd into XMM and YMM/ZMM scheduler classes
...
llvm-svn: 331453
2018-05-03 13:27:10 +00:00
Simon Pilgrim
93c878c76b
[X86] Split WriteVecIMul/WriteVecPMULLD/WriteMPSAD/WritePSADBW into XMM and YMM/ZMM scheduler classes
...
Also retagged VDBPSADBW instructions as SchedWritePSADBW instead of SchedWriteVecIMul which matches the behaviour on SkylakeServer (the only thing that supports it...)
llvm-svn: 331445
2018-05-03 10:31:20 +00:00
Simon Pilgrim
6732f6ea51
[X86] Split WriteShuffle/WriteVarShuffle + WriteBlend/WriteVarBlend into XMM and YMM/ZMM scheduler classes
...
llvm-svn: 331386
2018-05-02 18:48:23 +00:00
Simon Pilgrim
819f218f07
[X86] Cleanup WriteFShuffle/WriteFVarShuffle (+256 variants) scheduler classes with more common default values
...
llvm-svn: 331380
2018-05-02 17:58:50 +00:00
Simon Pilgrim
86d9f23ded
[X86] Cleanup WriteFMul scheduler classes with more common default values
...
Intel models were targeting x87 instead of packed sse.
llvm-svn: 331360
2018-05-02 14:25:32 +00:00
Simon Pilgrim
e93fd5f1e4
[X86] Cleanup WriteFAdd/WriteFCmp scheduler classes with more common default values
...
Intel models were targeting x87 instead of packed sse.
Also fixes XOP's VFRCZ to use WriteFAdd/WriteFAddY.
llvm-svn: 331340
2018-05-02 09:18:49 +00:00
Simon Pilgrim
21caf0124f
[X86] Split WriteFMul/WriteFDiv into XMM and YMM/ZMM scheduler classes
...
llvm-svn: 331293
2018-05-01 18:22:53 +00:00
Simon Pilgrim
c708868cb1
[X86] Split WriteFRcp/WriteFRsqrt/WriteFSqrt into XMM and YMM/ZMM scheduler classes
...
llvm-svn: 331290
2018-05-01 18:06:07 +00:00
Simon Pilgrim
c546f9424f
[X86] Split WriteFCmp into XMM and YMM/ZMM scheduler classes
...
Removes more WriteFCmp InstRW overrides
llvm-svn: 331283
2018-05-01 16:50:16 +00:00
Simon Pilgrim
5269167f5b
[X86] Split WriteFAdd into XMM and YMM/ZMM scheduler classes
...
Removes more WriteFAdd InstRW overrides
llvm-svn: 331276
2018-05-01 16:13:42 +00:00
Simon Pilgrim
dd8eae128b
[X86] Split WriteFShuffle into XMM and YMM/ZMM scheduler classes
...
Removes more WriteFShuffle InstRW overrides
llvm-svn: 331264
2018-05-01 14:25:01 +00:00
Simon Pilgrim
57f2b185ac
[X86] Split WriteVecLogic into XMM and YMM/ZMM scheduler classes
...
This removes all the WriteVecLogic InstRW overrides.
llvm-svn: 331258
2018-05-01 12:39:17 +00:00
Simon Pilgrim
fc0c26f1a6
[X86] Tag PSLLDQ/PSRLDQ as WriteShuffle scheduler classes instead of shifts.
...
Although they are encoded similar to bit shifts, the byte shifts behave like shuffles from a scheduling point of view.
llvm-svn: 331253
2018-05-01 11:05:42 +00:00
Simon Pilgrim
d5ada498db
[X86] Merge more instregex single matches to reduce InstrRW compile time.
...
llvm-svn: 331143
2018-04-29 15:33:15 +00:00
Craig Topper
ebd3e4a69c
[X86] Remove SLDT64m instruction.
...
It doesn't really exist. The instruction always writes 16-bits of memory. Putting a REX.w on it won't change anything.
While I was touching the encoding tests to remove it, I added some other missing register form test cases.
llvm-svn: 331135
2018-04-29 04:50:53 +00:00
Simon Pilgrim
39d7720354
[X86] Remove unnecessary shift/rotate folded InstRW overrides.
...
llvm-svn: 331110
2018-04-28 15:32:19 +00:00
Simon Pilgrim
8ee7d01dcf
[X86] Merge some x87 instruction instregex single matches. NFCI.
...
llvm-svn: 331084
2018-04-27 21:14:19 +00:00
Simon Pilgrim
8a937e00d8
[X86] Split WriteFBlend/WriteFVarBlend/WriteFVarShuffle into XMM and YMM/ZMM scheduler classes
...
This removes all the WriteFBlend/WriteFVarBlend InstRW overrides - some WriteFVarShuffle remain to be fixed.
llvm-svn: 331065
2018-04-27 18:19:48 +00:00
Simon Pilgrim
c3c767bf50
[X86] Split WriteFHadd into XMM and YMM/ZMM scheduler classes
...
This removes all the HADD/HSUB PS/PD InstRW overrides.
llvm-svn: 331054
2018-04-27 16:11:57 +00:00
Simon Pilgrim
b2aa89c909
[X86][AVX] Split WriteFLogic into XMM and YMM/ZMM scheduler classes
...
This removes all the AND/ANDN/OR/XOR PS/PD InstRW overrides.
llvm-svn: 331051
2018-04-27 15:50:33 +00:00
Simon Pilgrim
aef5ca7299
[X86] Replace some system instruction instregex single matches with instrs entry. NFCI.
...
llvm-svn: 331034
2018-04-27 13:32:42 +00:00
Simon Pilgrim
dbd1ae7ddd
[X86] Split WriteFMA into XMM, Scalar and YMM/ZMM scheduler classes
...
This removes all the FMA InstRW overrides.
If we ever get PR36924, then we can remove many of these declarations from models.
llvm-svn: 330820
2018-04-25 13:07:58 +00:00
Simon Pilgrim
27bc83e228
[X86] Split off PHMINPOSUW to their own schedule class
...
This also fixes Jaguar's schedule which was treating it as the WriteVecIMul default.
llvm-svn: 330756
2018-04-24 18:49:25 +00:00
Simon Pilgrim
f0945aa0e0
[X86][F16C] Add WriteCvtF2FSt scheduling class
...
Fixes the classification of VCVTPS2PHmr/VCVTPS2PHYmr which were tagged as WriteCvtF2FLd_WriteRMW (PR36887)
llvm-svn: 330737
2018-04-24 16:43:07 +00:00
Simon Pilgrim
16299273d0
[X86] Remove unnecessary FMA reg-mem InstRW scheduler overrides.
...
llvm-svn: 330720
2018-04-24 14:47:11 +00:00
Simon Pilgrim
f7d2a93d5f
[X86] Add vector element insertion/extraction scheduler classes
...
Split off pinsr/pextr and extractps instructions.
(Mostly) fixes PR36887.
Note: It might be worth adding a WriteFInsertLd class as well in the future.
Differential Revision: https://reviews.llvm.org/D45929
llvm-svn: 330714
2018-04-24 13:21:41 +00:00
Simon Pilgrim
e5e4bf02d6
[X86] Remove unnecessary vector memory folded InstRW overrides.
...
We have test coverage for these with resources-sse*/avx*
llvm-svn: 330662
2018-04-23 22:45:04 +00:00
Simon Pilgrim
eb6090941c
[X86] Remove unnecessary BMI2 InstRW overrides.
...
We have test coverage for these with resources-bmi2.s
llvm-svn: 330659
2018-04-23 22:19:55 +00:00
Simon Pilgrim
ed09ebb48d
[X86] Remove unnecessary WriteLEA InstRW overrides.
...
llvm-svn: 330648
2018-04-23 21:04:23 +00:00