https://gcc.gnu.org/bugzilla/show_bug.cgi?id=106101
--- Comment #14 from Andreas Krebbel <krebbel at gcc dot gnu.org> --- (In reply to Segher Boessenkool from comment #13) > (Sorry I missed this) > > (In reply to Andreas Krebbel from comment #11) > > I've tried to change our movstrict backend patterns to use a predicate on > > the dest operand which enforces a subreg. However, since reload strips the > > subreg away when assigning hard regs we end up with a STRICT_LOW_PART of a > > reg again. At least after reload something like this should be acceptable - > > right? > > > > 298r.ira: > > (insn 8 16 17 3 (set (strict_low_part (subreg:SI (reg/v:DI 64 [ e ]) 4)) > > (const_int 0 [0])) "t.cc":37:17 1485 {movstrictsi} > > (nil)) > > > > 299r.reload: > > (insn 8 16 17 3 (set (strict_low_part (reg:SI 11 %r11 [orig:64 e+4 ] [64])) > > (mem/u/c:SI (symbol_ref/u:DI ("*.LC0") [flags 0x2]) [0 S4 A32])) > > "t.cc":37:17 1485 {movstrictsi} > > (nil)) > > So you are suggesting that every strict_low_part after reload can just be > removed? If that is true, should we not just do exactly that then? I think we have 3 options: (1) Prevent reload from removing SUBREGs in STRICT_LOW_PARTs. (2) Remove the STRICT_LOW_PART when resolving the inner SUBREG (3) Define what a (STRICT_LOW_PART (reg:mode x)) means. (1) For that, all passes after reload must be able to deal with these SUBREGs. Since SUBREGs are rare after reload it is hard to say how robust that handling is right now. (2) Here the question to me is which passes after reload currently do something with the strict-low-part info. Clearly a non-option if we would loose any optimizations with that. (3) E.g. it means that the bits of hardreg x in its hardware mode (the mode for UNITS_PER_WORD) which are not covered by MODE are not touched by the SET.