[Bug middle-end/37813] assert with IRA_COVER_CLASSES with singleton
hp at gcc dot gnu dot org
gcc-bugzilla@gcc.gnu.org
Wed Oct 22 22:18:00 GMT 2008
------- Comment #5 from hp at gcc dot gnu dot org 2008-10-22 22:17 -------
Created an attachment (id=16531)
--> (http://gcc.gnu.org/bugzilla/attachment.cgi?id=16531&action=view)
Reduced test-case for updated cris.h at r141228. Compile with -O2.
After fixing REGNO_REG_CLASS (but still with the singleton version of
IRA_COVER_CLASSES), see the cris.h patch, I still get an ICE in IRA, during
build, compiling ldtoa.c from newlib:
dtoa2.c: In function 'emovo':
ldtoa2.c:24: error: unrecognizable insn:
(insn 144 57 140 4 ldtoa2.c:12 (set (reg:HI 13 r13)
(mem:HI (post_inc:SI (reg/v/f:SI 15 acr [orig:63 p.37 ] [63])) [2 S2
A8])) -1 (expr_list:REG_INC (reg/v/f:SI 15\
acr [orig:63 p.37 ] [63])
(nil)))
ldtoa2.c:24: internal compiler error: in extract_insn, at recog.c:2027
The last dump file is from IRA. It appears IRA (or reload) allocates ACR (reg
15) for an address with post-increment. It's just that this register can't be
used for that addressing mode - which is one of the reasons it's in a separate
class. This doesn't happen with the non-singleton IRA_COVER_CLASSES.
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=37813
More information about the Gcc-bugs
mailing list