This is the mail archive of the gcc-bugs@gcc.gnu.org mailing list for the GCC project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[Bug target/55195] [4.8 Regression] shorten_branches generates incorrect forward branch distances


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

--- Comment #16 from John David Anglin <danglin at gcc dot gnu.org> 2012-11-13 00:37:01 UTC ---
Author: danglin
Date: Tue Nov 13 00:36:54 2012
New Revision: 193464

URL: http://gcc.gnu.org/viewcvs?root=gcc&view=rev&rev=193464
Log:
    PR target/55195
    * config/pa/pa.md (type): Add sibcall and sh_func_adrs insn types.
    (in_branch_delay): Don't allow sibcall or sh_func_adrs insns.
    (in_nullified_branch_delay): Likewise.
    (in_call_delay): Likewise.
    Define delay for sibcall insns.  Adjust Z3 and Z4 insn reservations for
    new types.  Add opaque cond to mark all calls, sibcalls, dyncalls and
    the $$sh_func_adrs call as variable.  Update type of sibcalls and
    $$sh_func_adrs call.
    * config/pa/pa.c (pa_adjust_insn_length): Revise to return updated
    length instead of adjustment.  Handle negative and undefined call
    adjustments for insn_default_length.  Remove adjustment for millicode
    insn with unfilled delay slot.
    (pa_output_millicode_call): Update for revised millicode length.
    * config/pa/pa.h (ADJUST_INSN_LENGTH): Revise to set LENGTH.


Modified:
    trunk/gcc/ChangeLog
    trunk/gcc/config/pa/pa.c
    trunk/gcc/config/pa/pa.h
    trunk/gcc/config/pa/pa.md


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]