re PR c/52577 (__builtin_shuffle -Wunused-but-set-* false positives)
authorJakub Jelinek <jakub@redhat.com>
Tue, 13 Mar 2012 21:19:50 +0000 (22:19 +0100)
committerJakub Jelinek <jakub@gcc.gnu.org>
Tue, 13 Mar 2012 21:19:50 +0000 (22:19 +0100)
PR c/52577
* c-parser.c (c_parser_postfix_expression)
<case RID_BUILTIN_SHUFFLE>: Call mark_exp_read on argument values.

* gcc.dg/Wunused-var-3.c: New test.

From-SVN: r185355

gcc/ChangeLog
gcc/c-parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/Wunused-var-3.c [new file with mode: 0644]

index 2854c117360447970512402a1356e01c629ff3e2..079fcba199ab2a615fd11745d37acf28b7767e46 100644 (file)
@@ -1,5 +1,9 @@
 2012-03-13  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c/52577
+       * c-parser.c (c_parser_postfix_expression)
+       <case RID_BUILTIN_SHUFFLE>: Call mark_exp_read on argument values.
+
        * config/i386/smmintrin.h: Avoid /* within a comment.
        * config/i386/nmmintrin.h: Likewise.
 
index 867ab4183ad3bac5ee223ffff46f4a94b8f4ca18..56134c24e50a27d3ad47ade5c919d24b0fe25d3e 100644 (file)
@@ -1,7 +1,7 @@
 /* Parser for C and Objective-C.
    Copyright (C) 1987, 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,
-   1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010, 2011
-   Free Software Foundation, Inc.
+   1999, 2000, 2001, 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010, 2011,
+   2012 Free Software Foundation, Inc.
 
    Parser actions based on the old Bison parser; structure somewhat
    influenced by and fragments based on the C++ parser.
@@ -6647,6 +6647,8 @@ c_parser_postfix_expression (c_parser *parser)
        case RID_BUILTIN_SHUFFLE:
          {
            VEC(c_expr_t,gc) *cexpr_list;
+           unsigned int i;
+           c_expr_t *p;
 
            c_parser_consume_token (parser);
            if (!c_parser_get_builtin_args (parser,
@@ -6657,6 +6659,9 @@ c_parser_postfix_expression (c_parser *parser)
                break;
              }
 
+           FOR_EACH_VEC_ELT (c_expr_t, cexpr_list, i, p)
+             mark_exp_read (p->value);
+
            if (VEC_length (c_expr_t, cexpr_list) == 2)
              expr.value =
                c_build_vec_perm_expr
index 96b775ea7468e6aaae0cc507716d2fbb90b006d7..2824244a7f8656d740430086bee4a58a63995f79 100644 (file)
@@ -1,3 +1,8 @@
+2012-03-13  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/52577
+       * gcc.dg/Wunused-var-3.c: New test.
+
 2012-03-13  Martin Jambor  <mjambor@suse.cz>
 
        * gcc.dg/misaligned-expand-2.c: New test.
diff --git a/gcc/testsuite/gcc.dg/Wunused-var-3.c b/gcc/testsuite/gcc.dg/Wunused-var-3.c
new file mode 100644 (file)
index 0000000..5954c3b
--- /dev/null
@@ -0,0 +1,34 @@
+/* PR c/52577 */
+/* { dg-do compile } */
+/* { dg-options "-Wunused" } */
+
+typedef int V __attribute__((vector_size (sizeof (int) * 4)));
+
+void
+f1 (V *p)
+{
+  V mask = { 1, 2, 3, 0 };
+  *p = __builtin_shuffle (*p, mask);
+}
+
+void
+f2 (V *p, V *q)
+{
+  V mask = { 1, 2, 3, 0 };
+  *p = __builtin_shuffle (*p, *q, mask);
+}
+
+void
+f3 (V *p, V *mask)
+{
+  V a = { 1, 2, 3, 0 };
+  *p = __builtin_shuffle (a, *mask);
+}
+
+void
+f4 (V *p, V *mask)
+{
+  V a = { 1, 2, 3, 0 };
+  V b = { 2, 3, 4, 1 };
+  *p = __builtin_shuffle (a, b, *mask);
+}