aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree.c
diff options
context:
space:
mode:
authorRichard Earnshaw <rearnsha@arm.com>2019-10-18 19:03:43 +0000
committerRichard Earnshaw <rearnsha@gcc.gnu.org>2019-10-18 19:03:43 +0000
commit8b8ab8f473b42933b9c1e292c4b1ab02adf1863a (patch)
tree94de7034a2c5cbea058927af8f467102b05226f4 /gcc/tree.c
parent22060d0e575e7754eb1355763d22bbe37c3caa13 (diff)
downloadgcc-8b8ab8f473b42933b9c1e292c4b1ab02adf1863a.zip
gcc-8b8ab8f473b42933b9c1e292c4b1ab02adf1863a.tar.gz
gcc-8b8ab8f473b42933b9c1e292c4b1ab02adf1863a.tar.bz2
[arm] early split most DImode comparison operations.
This patch does most of the work for early splitting the DImode comparisons. We now handle EQ, NE, LT, GE, LTU and GEU during early expansion, in addition to EQ and NE, for which the expansion has now been reworked to use a standard conditional-compare pattern already in the back-end. To handle this we introduce two new condition flag modes that are used when comparing the upper words of decomposed DImode values: one for signed, and one for unsigned comparisons. CC_Bmode (B for Borrow) is essentially the inverse of CC_Cmode and is used when the carry flag is set by a subtraction of unsigned values. * config/arm/arm-modes.def (CC_NV, CC_B): New CC modes. * config/arm/arm.c (arm_select_cc_mode): Recognize constructs that need these modes. (arm_gen_dicompare_reg): New code to early expand the sub-operations of EQ, NE, LT, GE, LTU and GEU. * config/arm/iterators.md (CC_EXTEND): New code attribute. * config/arm/predicates.md (arm_adcimm_operand): New predicate.. * config/arm/arm.md (cmpsi3_carryin_<CC_EXTEND>out): New pattern. (cmpsi3_imm_carryin_<CC_EXTEND>out): Likewise. (cmpsi3_0_carryin_<CC_EXTEND>out): Likewise. From-SVN: r277179
Diffstat (limited to 'gcc/tree.c')
0 files changed, 0 insertions, 0 deletions