Blame SOURCES/gcc34-rh233941.patch

4e62ec
2007-04-02  Jakub Jelinek  <jakub@redhat.com>
4e62ec
4e62ec
	* expr.c (expand_expr_real) <case COMPLEX_EXPR>: Force op1
4e62ec
	into register if target overlaps with op1.
4e62ec
4e62ec
	* g77.f-torture/execute/20070402.f: New test.
4e62ec
4e62ec
--- gcc/expr.c.jj	2006-10-05 00:37:01.000000000 +0200
4e62ec
+++ gcc/expr.c	2007-04-02 13:28:52.000000000 +0200
4e62ec
@@ -8949,6 +8949,9 @@ expand_expr_real (tree exp, rtx target, 
4e62ec
 
4e62ec
 	if (! target)
4e62ec
 	  target = gen_reg_rtx (TYPE_MODE (TREE_TYPE (exp)));
4e62ec
+	else if (GET_CODE (target) == MEM
4e62ec
+		 && reg_overlap_mentioned_p (target, op1))
4e62ec
+	  op1 = force_reg (mode, op1);
4e62ec
 
4e62ec
 	start_sequence ();
4e62ec
 
4e62ec
--- gcc/testsuite/g77.f-torture/execute/20070402.f.jj	2007-04-02 13:29:51.000000000 +0200
4e62ec
+++ gcc/testsuite/g77.f-torture/execute/20070402.f	2007-04-02 12:11:00.000000000 +0200
4e62ec
@@ -0,0 +1,21 @@
4e62ec
+      program rh233941
4e62ec
+      implicit none
4e62ec
+      complex*16 z
4e62ec
+      z = dcmplx(1.0, 2.0)
4e62ec
+      call sub(z)
4e62ec
+      stop
4e62ec
+      end program rh233941
4e62ec
+
4e62ec
+      subroutine sub(z)
4e62ec
+      implicit none
4e62ec
+      complex*16 z
4e62ec
+      z = dcmplx(-dimag(z), dreal(z))
4e62ec
+      call sub2(z)
4e62ec
+      return
4e62ec
+      end subroutine sub
4e62ec
+
4e62ec
+      subroutine sub2(z)
4e62ec
+      implicit none
4e62ec
+      complex*16 z
4e62ec
+      if (dreal(z).ne.-2.0.or.dimag(z).ne.1.0) call abort
4e62ec
+      end subroutine sub2