[Bug rtl-optimization/15521] New: sched1 extends life of hard registers on SMALL_REGISTER_CLASSES targets when exceptions are enabled

amylaar at gcc dot gnu dot org gcc-bugzilla@gcc.gnu.org
Wed May 19 09:56:00 GMT 2004


The current mailine fails to build libstdc++-v3 for sh-elf.  We get
a reload failure compiling locale-inst.cc for -m4-single-only .
The first scheduling pass moves the instruction that moves the call
value from a hard to a pseudo register away from the call, which extends
the lifetime of r0 across an instruction with indexed addressing.
The problem is that the call is in a different scheduling region, as
exception handling causes it to end a basic block.
Thus, sched_analyze doesn't see the CALL_INSN during the current region
scheduling, in_post_call_group_p does not get set, and thus the return
value copy instruction doesn't get the SCHED_GROUP_P bit set.

A patch is here:
http://gcc.gnu.org/ml/gcc-patches/2004-05/msg00857.html

-- 
           Summary: sched1 extends life of hard registers on
                    SMALL_REGISTER_CLASSES targets when exceptions are
                    enabled
           Product: gcc
           Version: 3.5.0
            Status: UNCONFIRMED
          Keywords: ice-on-valid-code, build, patch, EH
          Severity: critical
          Priority: P2
         Component: rtl-optimization
        AssignedTo: unassigned at gcc dot gnu dot org
        ReportedBy: amylaar at gcc dot gnu dot org
                CC: gcc-bugs at gcc dot gnu dot org
 GCC build triplet: any
  GCC host triplet: any
GCC target triplet: sh-elf and other SMALL_REGISTER_CLASSES targets


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=15521



More information about the Gcc-bugs mailing list