diff options
author | Oleg Endo <olegendo@gcc.gnu.org> | 2012-09-25 19:06:28 +0000 |
---|---|---|
committer | Oleg Endo <olegendo@gcc.gnu.org> | 2012-09-25 19:06:28 +0000 |
commit | 780405350cee277933a7835a10d960dcea3a0947 (patch) | |
tree | ecbd8ddaf619969c907ae05cf2c8c9a8a4ea0ee0 /libcpp/line-map.c | |
parent | 91cad09b08a860dccace9d1e7050e8765b3556e9 (diff) | |
download | gcc-780405350cee277933a7835a10d960dcea3a0947.zip gcc-780405350cee277933a7835a10d960dcea3a0947.tar.gz gcc-780405350cee277933a7835a10d960dcea3a0947.tar.bz2 |
re PR target/54089 ([SH] Refactor shift patterns)
PR target/54089
* config/sh/constraints.md (Jhb): New constraint.
* config/sh/predicates.md (negt_reg_shl31_operand): New predicate.
* config/sh/sh.md (rotrsi3): New expander.
(rotrsi3_1, *rotrsi3_1, *rotlsi3_1): New insns.
(rotlsi3, rotlhi3): Use const_int_operand predicate instead of
immediate_operand and remove CONST_INT_P checks in expansion code.
(*rotcr): Cleanup variable usage. Handle preceding nott insn. Add
split with swapped operands.
(*rotcr_neg_t, *movt_msb, *negt_msb): New insns and splits.
PR target/54089
* gcc.target/sh/pr54089-1.c (test_15, test_16, test_17, test_18,
test_19, test_20, test_21, test_22, test_23): New functions.
* gcc.target/sh/pr54089-4.c: New.
* gcc.target/sh/pr54089-5.c: New.
* gcc.target/sh/pr54089-6.c: New.
* gcc.target/sh/pr54089-7.c: New.
From-SVN: r191743
Diffstat (limited to 'libcpp/line-map.c')
0 files changed, 0 insertions, 0 deletions