amdgcn: Allow vector reductions on constants
authorAndrew Stubbs <ams@codesourcery.com>
Sat, 12 Feb 2022 23:44:48 +0000 (23:44 +0000)
committerAndrew Stubbs <ams@codesourcery.com>
Mon, 14 Feb 2022 13:39:13 +0000 (13:39 +0000)
Obviously it would be better if these reductions could be evaluated at compile
time, but this will avoid an ICE.

gcc/ChangeLog:

* config/gcn/gcn.cc (gcn_expand_reduc_scalar): Use force_reg.

gcc/config/gcn/gcn.cc

index 74819c6..402f025 100644 (file)
@@ -4460,7 +4460,7 @@ gcn_expand_reduc_scalar (machine_mode mode, rtx src, int unspec)
      pair of lanes, then on every pair of results from the previous
      iteration (thereby effectively reducing every 4 lanes) and so on until
      all lanes are reduced.  */
-  rtx in, out = src;
+  rtx in, out = force_reg (mode, src);
   for (int i = 0, shift = 1; i < 6; i++, shift <<= 1)
     {
       rtx shift_val = gen_rtx_CONST_INT (VOIDmode, shift);