Blame SOURCES/gcc48-pr82274.patch

5ed81e
2017-10-13  Jakub Jelinek  <jakub@redhat.com>
5ed81e
5ed81e
	PR target/82274
5ed81e
	* libgcc2.c (__mulvDI3): If both operands have
5ed81e
	the same highpart of -1 and the topmost bit of lowpart is 0,
5ed81e
	multiplication overflows even if both lowparts are 0.
5ed81e
5ed81e
	* gcc.dg/pr82274-1.c: New test.
5ed81e
5ed81e
--- libgcc/libgcc2.c	2017/10/13 16:50:13	253733
5ed81e
+++ libgcc/libgcc2.c	2017/10/13 17:19:12	253734
5ed81e
@@ -375,7 +375,8 @@
5ed81e
 		}
5ed81e
 	      else
5ed81e
 		{
5ed81e
-		  if (uu.s.high == (Wtype) -1 && vv.s.high == (Wtype) - 1)
5ed81e
+		  if ((uu.s.high & vv.s.high) == (Wtype) -1
5ed81e
+		      && (uu.s.low | vv.s.low) != 0)
5ed81e
 		    {
5ed81e
 		      DWunion ww = {.ll = (UDWtype) (UWtype) uu.s.low
5ed81e
 				    * (UDWtype) (UWtype) vv.s.low};
5ed81e
--- /dev/null
5ed81e
+++ gcc/testsuite/gcc.dg/pr82274-1.c
5ed81e
@@ -0,0 +1,16 @@
5ed81e
+/* PR target/82274 */
5ed81e
+/* { dg-do run } */
5ed81e
+/* { dg-shouldfail "trapv" } */
5ed81e
+/* { dg-options "-ftrapv" } */
5ed81e
+
5ed81e
+int
5ed81e
+main ()
5ed81e
+{
5ed81e
+#ifdef __SIZEOF_INT128__
5ed81e
+  volatile __int128 m = -(((__int128) 1) << (__CHAR_BIT__ * __SIZEOF_INT128__ / 2));
5ed81e
+#else
5ed81e
+  volatile long long m = -(1LL << (__CHAR_BIT__ * __SIZEOF_LONG_LONG__ / 2));
5ed81e
+#endif
5ed81e
+  m = m * m;
5ed81e
+  return 0;
5ed81e
+}