]> granicus.if.org Git - llvm/commit
AMDGPU/GlobalISel: Don't constrain source register of VCC copies
authorMatt Arsenault <Matthew.Arsenault@amd.com>
Mon, 15 Jul 2019 19:48:36 +0000 (19:48 +0000)
committerMatt Arsenault <Matthew.Arsenault@amd.com>
Mon, 15 Jul 2019 19:48:36 +0000 (19:48 +0000)
commit848db45c88cc88ad16b4d5e61897c8bc417336d6
treebc9448714a7cabfaaa0e4673834c6a3ff1a01f67
parentfcd8db8a7db1996bfdd28d832c81baced2b45ecb
AMDGPU/GlobalISel: Don't constrain source register of VCC copies

This is a hack until I come up with a better way of dealing with the
pseudo-register banks used for boolean values. If the use instruction
constrains the register, the selector for the def instruction won't
see that the bank was VCC. A 1-bit SReg_32 is could ambiguously have
been SCCRegBank or VCCRegBank in wave32.

This is necessary to successfully select branches with and and/or/xor
condition.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@366120 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/AMDGPU/AMDGPUInstructionSelector.cpp
test/CodeGen/AMDGPU/GlobalISel/inst-select-copy.mir