diff options
| author | Jonas Paulsson <paulsson@linux.vnet.ibm.com> | 2017-03-17 06:47:08 +0000 | 
|---|---|---|
| committer | Jonas Paulsson <paulsson@linux.vnet.ibm.com> | 2017-03-17 06:47:08 +0000 | 
| commit | 8a7bd24c82afd5fd344a58a7cc2062356ef2e34b (patch) | |
| tree | 9cccf9b2200318c1a68f0d68574b1b9d2545b1f9 /llvm/lib/Target/AMDGPU/AMDGPUTargetTransformInfo.cpp | |
| parent | 6a1290a0fd35776f87c81dbf631f1b73c6a9b59a (diff) | |
| download | bcm5719-llvm-8a7bd24c82afd5fd344a58a7cc2062356ef2e34b.tar.gz bcm5719-llvm-8a7bd24c82afd5fd344a58a7cc2062356ef2e34b.zip | |
[SystemZ]  Add use of super-reg in splitMove()
If one of the subregs of the 128 bit reg is undefined when splitMove() splits
a store into two instructions, a use of an undefined physical register
results.
To remedy this, an implicit use of the super register is added onto both new
instructions, along with propagated kill and undef flags.
This was discovered with llvm-stress, and that test case is attached as
test/CodeGen/SystemZ/splitMove_undefReg_mverifier.ll
Thanks to Matthias Braun for helping with a nice explanation.
Review: Ulrich Weigand
llvm-svn: 298047
Diffstat (limited to 'llvm/lib/Target/AMDGPU/AMDGPUTargetTransformInfo.cpp')
0 files changed, 0 insertions, 0 deletions

