<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/57498>57498</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[AMDGPU][MC][GFX10+] VOP3P op_sel_hi encoding is not consistent with SP3
</td>
</tr>
<tr>
<th>Labels</th>
<td>
backend:AMDGPU,
mc
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
dpreobra
</td>
</tr>
</table>
<pre>
This is a follow-up on https://github.com/llvm/llvm-project/issues/48707.
We have a patch which set `op_sel_hi` to 1 for unused operands. This was necessary to match SP3 behavior for GFX9. AFAIK, there were no other reasons for this patch. AMD documentation does not have any requirements for this case.
Now it turned out that SP3 does NOT set `op_sel_hi` to 1 for unused operands on GFX10 and GFX11. The question is: should we disable our patch for these GPUs to match SP3 behavior?
// SP3 GFX10 and GFX11:
v_pk_add_f16 v224, v224, v3 // 000000000000: CC0F00E0 180207E0
// LLVM GFX10 and GFX11:
v_pk_add_f16 v224, v224, v3 // 000000000000: CC0F40E0 180207E0
This issue was originally reported by Gleb Larochkin.
Added @rampitec and @Sisyph for awareness.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzFVE1v2zAM_TX2hWggy4mTHHxIk6YY1i9gXbdbIEt0rNWxXElukH8_Ssm6dlsP22WCIJKQRL5HUqqMOpT3jXZAU0Bt2tbsz4YeTAeN971L8kXC1zS32jdDNZJmR0bbPv8QZ70131B6MrVzAzpSxrMpm44StkrY4rh-QWjEM1KIXnjZwL7RtDr0kBTM9BuH7abRpIM3kBEOC0M3OFRgerSiU24EEeZeOOhQonPCHsLhXfT36S6HCimEppvh9uX663wEi_Xiw8eEL8E3aBH2YekMmGCCReFM5-JxH3xHaHTpegXKyGGHnRdeUyaUQYpq_IlDd6C7T4O2GI68ciCFwze0b8wetAc_2C5QGUhthI9oo8-b2_u_SkIoCzHLGIFQUctCXhCeKPERqg4VA9eYoVXEF5R2omqRYttT6o9o0SFc3n12f05hkq9f0wAaxy6Ip35BEFrk5Rg8b_rHjVBqU2cFWZyPQ_5fZA7vjlME9moELsslWzN2wSCbMc6mF-wdZFdXD9f_Adr4d2hwFKdnRW8idq2xeqs70bahe3pjPdW1OsBlixVcCWtk86i7U_cslKLdZMys2PXao4yUyP6k3aE_1lDshcWOHsKbjkuxzIqCs3w6z_NUlbma53OReu1bLJPJOTU3lT2ZrEi_Xh5lTFrCz8mCh9u7_A5emhGwk0bpbhv-h_ACJL0Y7Tz1PezpRwj9kA62Lf_9s5hMx_NZ2pQVVWU6r3mW4WxW1KpmNS9ULZicScVknbaiwtYFEgnnlZCP2CmKeGLEeSgiiZ0M-mSV6pIzztmcZVme8SwfVVjUshJcyslkkouC8ok7odtRgDYydpvaMqKshq2jzZaIup-bwjm97TCmMfgXg2-MLVVv0VRWpJFRGel8Bz7-nLY">