re PR fortran/57071 (Optimize (-1)**k to 1 - 2 * mod(K, 2))
authorThomas Koenig <tkoenig@gcc.gnu.org>
Tue, 30 Apr 2013 21:45:13 +0000 (21:45 +0000)
committerThomas Koenig <tkoenig@gcc.gnu.org>
Tue, 30 Apr 2013 21:45:13 +0000 (21:45 +0000)
2013-04-30  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/57071
* frontend-passes.c (optimize_power):  Simplify
1**k to 1.

2013-04-30  Thomas Koenig  <tkoenig@gcc.gnu.org>

PR fortran/57071
* gfortran.dg/power_5.f90:  New test.

From-SVN: r198476

gcc/fortran/ChangeLog
gcc/fortran/frontend-passes.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/power_5.f90 [new file with mode: 0644]

index 9e47b13f0ec5ba2b75023444c05130beb3d75baf..4439749dbaa7c3d8cb630528ed23ed64fcebb1ca 100644 (file)
@@ -1,3 +1,9 @@
+2013-04-30  Thomas Koenig  <tkoenig@gcc.gnu.org>
+
+       PR fortran/57071
+       * frontend-passes.c (optimize_power):  Simplify
+       1**k to 1.
+
 2013-04-28  Tobias Burnus  <burnus@net-b.de>
 
        PR fortran/57114
index 63efb9f919c122c7e48d57c2520e369f35ba1903..a2e88b4f4084b50dd3cfc6cc9b7b467c3a71906d 100644 (file)
@@ -1148,6 +1148,24 @@ optimize_power (gfc_expr *e)
       *e = *ishft;
       return true;
     }
+
+  else if (mpz_cmp_si (op1->value.integer, 1L) == 0)
+    {
+      op2 = e->value.op.op2;
+      if (op2 == NULL)
+       return false;
+
+      gfc_free_expr (op1);
+      gfc_free_expr (op2);
+
+      e->expr_type = EXPR_CONSTANT;
+      e->value.op.op1 = NULL;
+      e->value.op.op2 = NULL;
+      mpz_init_set_si (e->value.integer, 1);
+      /* Typespec cand location are still OK.  */
+      return true;
+    }
+
   return false;
 }
 
index ae111b265c888489e5403318d7fbbb66c952360a..1016036dca39b0de13ea0cea9b602fe4e3f3ca3f 100644 (file)
@@ -1,3 +1,8 @@
+2013-04-30  Thomas Koenig  <tkoenig@gcc.gnu.org>
+
+       PR fortran/57071
+       * gfortran.dg/power_5.f90:  New test.
+
 2013-04-30  Richard Biener  <rguenther@suse.de>
 
        PR middle-end/57122
diff --git a/gcc/testsuite/gfortran.dg/power_5.f90 b/gcc/testsuite/gfortran.dg/power_5.f90
new file mode 100644 (file)
index 0000000..f42b260
--- /dev/null
@@ -0,0 +1,36 @@
+! { dg-do run }
+! { dg-options "-ffrontend-optimize -fdump-tree-original" }
+! PR 57071 - Check that 1**k is transformed into 1
+program main
+  implicit none
+  integer, parameter :: n = 3
+  integer(kind=8), dimension(-n:n) :: a
+  integer, dimension(-n:n) :: c, d
+  integer :: m
+  integer :: i, v
+  integer (kind=2) :: i2
+
+  v = 1
+  m = n
+  ! Test in scalar expressions
+  do i=-n,n
+     if (v /= 1**i) call abort
+  end do
+
+  ! Test in array constructors
+  a(-m:m) = [ (1**i, i= -m, m) ]
+  if (any(a .ne. v)) call abort
+
+  ! Test in array expressions
+  c = [ ( i, i = -n , n ) ]
+  d = 1**c
+  if (any(d .ne. v)) call abort
+
+  ! Test in different kind expressions
+  do i2=-n,n
+     if (v /= 1**i2) call abort
+  end do
+
+end program main
+! { dg-final { scan-tree-dump-times "_gfortran_pow_i4_i4" 0 "original" } }
+! { dg-final { cleanup-tree-dump "original" } }