-
- Downloads
re PR target/51244 ([SH] Inefficient conditional branch and code around T bit)
PR target/51244 * config/sh/predicates.md (t_reg_operand, negt_reg_operand): New predicates. * config/sh/sh-protos.h (get_t_reg_rtx): New prototype. * config/sh/sh.c (get_t_reg_rtx): New function. Use it when invoking gen_branch_true and gen_branch_false. * config/sh/sh.md: Use get_t_reg_rtx when invoking gen_branch_true and gen_branch_false. (branch_true, branch_false): Use t_reg_operand predicate. (*branch_true, *branch_false): Delete. (movt): Use t_reg_operand predicate. (*negnegt): Use negt_reg_operand predicate and fold little and big endian variants. (*movtt): Use t_reg_operand and fold little and big endian variants. (*movt_qi): Delete. PR target/51244 * gcc.target/sh/pr51244-1.c: Check that movt insn is not generated. From-SVN: r189177
Showing
- gcc/ChangeLog 18 additions, 0 deletionsgcc/ChangeLog
- gcc/config/sh/predicates.md 39 additions, 0 deletionsgcc/config/sh/predicates.md
- gcc/config/sh/sh-protos.h 1 addition, 0 deletionsgcc/config/sh/sh-protos.h
- gcc/config/sh/sh.c 18 additions, 9 deletionsgcc/config/sh/sh.c
- gcc/config/sh/sh.md 16 additions, 97 deletionsgcc/config/sh/sh.md
- gcc/testsuite/ChangeLog 5 additions, 0 deletionsgcc/testsuite/ChangeLog
- gcc/testsuite/gcc.target/sh/pr51244-1.c 1 addition, 1 deletiongcc/testsuite/gcc.target/sh/pr51244-1.c
Loading
Please register or sign in to comment