summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/overflow-1.c
diff options
context:
space:
mode:
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2003-12-07 12:57:13 +0000
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2003-12-07 12:57:13 +0000
commita16d8734b4f365cfbdd1147fe45f1333f710f85a (patch)
treec7a279fc1d15b2c2928f94eb4317e4a017ab688b /gcc/testsuite/gcc.dg/overflow-1.c
parent2c9d4f1cf880a12e4581858ede874a1f7956dc0f (diff)
downloadgcc-a16d8734b4f365cfbdd1147fe45f1333f710f85a.tar.gz
PR optimization/13318
* loop.c (express_from): Protect integer division from overflow. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@74387 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/testsuite/gcc.dg/overflow-1.c')
-rw-r--r--gcc/testsuite/gcc.dg/overflow-1.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.dg/overflow-1.c b/gcc/testsuite/gcc.dg/overflow-1.c
new file mode 100644
index 00000000000..db51a5ef129
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/overflow-1.c
@@ -0,0 +1,25 @@
+/* PR optimization/13318 */
+/* Origin: <bremner@unb.ca> */
+/* Reduced testcase: Wolfgang Bangerth <bangerth@dealii.org> */
+
+/* Verify that the big multiplier doesn't cause an integer
+ overflow in the loop optimizer. */
+
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+
+struct S {
+ int key;
+ int rnext,rprev;
+};
+
+void foo(struct S* H)
+{
+ int i, k;
+ for (i=0; i<2; i++){
+ struct S* cell=H+k;
+ cell->key=i*(0xffffffffUL/2);
+ cell->rnext=k+(1-i);
+ cell->rprev=k+(1-i);
+ }
+}