[AArch64] Fix aarch64_rtx_costs of PLUS/MINUS
authorWilco Dijkstra <wdijkstr@arm.com>
Fri, 1 May 2015 12:52:34 +0000 (12:52 +0000)
committerKyrylo Tkachov <ktkachov@gcc.gnu.org>
Fri, 1 May 2015 12:52:34 +0000 (12:52 +0000)
On behalf of Wilco Dijkstra

2015-05-01  Wilco Dijkstra  <wdijkstr@arm.com>

* gcc/config/aarch64/aarch64.c (aarch64_rtx_costs):
Calculate cost of op0 and op1 in PLUS and MINUS cases.

From-SVN: r222676

gcc/ChangeLog
gcc/config/aarch64/aarch64.c

index 8646ae9c1bb485498e98bb64a168e4d230100e67..fd85f21353a5861c852af2364fce37f72aa5042f 100644 (file)
@@ -1,3 +1,8 @@
+2015-05-01  Wilco Dijkstra  <wdijkstr@arm.com>
+
+       * gcc/config/aarch64/aarch64.c (aarch64_rtx_costs):
+       Calculate cost of op0 and op1 in PLUS and MINUS cases.
+
 2015-05-01  Kyrylo Tkachov  <kyrylo.tkachov@arm.com>
 
        * config/aarch64/aarch64.c (aarch64_rtx_costs, COMPARE case):
index 4573fb411932119220813dab553a29dc7c231513..eed37dbd91f4c75f741bb7b9276dc5193f02d256 100644 (file)
@@ -5880,6 +5880,8 @@ aarch64_rtx_costs (rtx x, int code, int outer ATTRIBUTE_UNUSED,
        op1 = XEXP (x, 1);
 
 cost_minus:
+       *cost += rtx_cost (op0, MINUS, 0, speed);
+
        /* Detect valid immediates.  */
        if ((GET_MODE_CLASS (mode) == MODE_INT
             || (GET_MODE_CLASS (mode) == MODE_CC
@@ -5887,13 +5889,10 @@ cost_minus:
            && CONST_INT_P (op1)
            && aarch64_uimm12_shift (INTVAL (op1)))
          {
-           *cost += rtx_cost (op0, MINUS, 0, speed);
-
            if (speed)
              /* SUB(S) (immediate).  */
              *cost += extra_cost->alu.arith;
            return true;
-
          }
 
        /* Look for SUB (extended register).  */
@@ -5918,7 +5917,6 @@ cost_minus:
            *cost += aarch64_rtx_mult_cost (new_op1, MULT,
                                            (enum rtx_code) code,
                                            speed);
-           *cost += rtx_cost (op0, MINUS, 0, speed);
            return true;
          }
 
@@ -5965,6 +5963,8 @@ cost_plus:
            return true;
          }
 
+       *cost += rtx_cost (op1, PLUS, 1, speed);
+
        /* Look for ADD (extended register).  */
         if (aarch64_rtx_arith_op_extract_p (op0, mode))
          {
@@ -5986,12 +5986,10 @@ cost_plus:
          {
            *cost += aarch64_rtx_mult_cost (new_op0, MULT, PLUS,
                                            speed);
-           *cost += rtx_cost (op1, PLUS, 1, speed);
            return true;
          }
 
-       *cost += (rtx_cost (new_op0, PLUS, 0, speed)
-                 + rtx_cost (op1, PLUS, 1, speed));
+       *cost += rtx_cost (new_op0, PLUS, 0, speed);
 
        if (speed)
          {