> In our ARC port, we found the following situation after expand:
> 
> (insn 23 22 24 5 (set (reg:SI 176)
>         (subreg:SI (mem/c:DI (plus:SI (reg/f:SI 147 virtual-stack-vars)
>                     (const_int -268 [0xfffffffffffffef4])) [3
> tmpoutst.st_size+0 S8 A32]) 4)) t02.c:64 -1 (nil))
> 
> The virtual-stack-vars should be handled by GCC's VREGS step, in
> instantiate_virtual_regs_in_insn(). However, this is not happening as the
> subroutine is not designed to handle subregs of a mem. As a consequence,
> virtual-stack-vars is not eliminated, and the compilation fails later on.
> To solve this issue, I am proposing the attached patch on vregs, that
> implements handling of such situation by
> instantiate_virtual_regs_in_insn().
> 
> Can you please let me know if this is an acceptable solution for the given
> issue?

Very likely not, there should be no SUBREGs of MEMs after expand.

-- 
Eric Botcazou

Reply via email to