[PATCH] D42078: AMDGPU: Fold inline offset for loads properly in moveToVALU on GFX9
Marek Olšák via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Jan 25 16:32:47 PST 2018
mareko added inline comments.
================
Comment at: lib/Target/AMDGPU/SIInstrInfo.cpp:3768-3770
+ if (Add &&
+ (Add->getOpcode() == AMDGPU::V_ADD_I32_e32 ||
+ Add->getOpcode() == AMDGPU::V_ADD_U32_e64)) {
----------------
nhaehnle wrote:
> Why not V_ADD_I32_e64 and V_ADD_U32_e32 as well? Those should work the same.
>
> You can also remove the corresponding FIXME in the comment.
>
> Also, to support e64/VOP3, the code must check for clamp and imod (abs/neg) bits and bail out when they're set. Clamp is genuinely supported for integer ops since gfx9, and while imods will not do anything useful, they *will* affect the instruction (they just affect the MSB as if the instruction were a floating point operation).
I think that only V_ADD_I32_e64 (for gfx9) and V_ADD_U32_e32 (for others) can occur here, because integer addition is always translated to S_ADD and lowered in moveToVALU. If that is true, mods can't occur here.
I'll remove the FIXME.
Repository:
rL LLVM
https://reviews.llvm.org/D42078
More information about the llvm-commits
mailing list