define_split question

Ian Lance Taylor iant@google.com
Wed Jan 24 15:46:00 GMT 2007


Lars Poeschel <larsi@wh2.tu-dresden.de> writes:

> I have the following statement, which fails with general compiler errror in 
> gen_rtx_SUBREG, at emit-rtl.c:729
> 
> (define_split
>   [(set (match_operand:DI 0 "memory_operand" "=m")
>         (match_operand:DI 1 "register_operand" "r"))]
>   ""
>   [(set (mem:SI (match_dup 0) )
>         (subreg:SI (match_dup 1) 0))
>   (set (mem:SI (plus:SI (match_dup 0) (const_int 4)))
>        (subreg:SI (match_dup 1) 1))]
>   "")
> 
> What I want to do is implementing the movdi on a 32 bit platform. This split 
> is a special case for memory destination and register source. I want to split 
> the 64 bit move into 2 32 bit moves. What am I doing wrong ? Anyone an idea ?

In general, with some exceptions, you shouldn't use an explicit subreg
in an insn pattern.  You should instead just use (match_dup N), and in
your C code use operands[N] = simplify_gen_subreg (...).

Otherwise you can wind up with a subreg of a subreg which is
forbidden.

Ian



More information about the Gcc-help mailing list