re PR target/81910 ([avr] ICE with "address" attribute on type)
authorGeorg-Johann Lay <avr@gjlay.de>
Tue, 22 Aug 2017 07:52:42 +0000 (07:52 +0000)
committerGeorg-Johann Lay <gjl@gcc.gnu.org>
Tue, 22 Aug 2017 07:52:42 +0000 (07:52 +0000)
gcc/
PR target/81910
* config/avr/avr.c (avr_handle_addr_attribute): Early return if
not VAR_P. Filter attribute warnings with OPT_Wattributes.
(avr_attribute_table) <io, io_low, address>: Initialize
.decl_required with true.

From-SVN: r251256

gcc/ChangeLog
gcc/config/avr/avr.c

index f9b07cdbdf6efb1ca8638fb4bea7ae10a7f2c9fb..5866bb0d8a86720db15e498c4010e18c73857d3a 100644 (file)
@@ -1,3 +1,11 @@
+2017-08-22  Georg-Johann Lay  <avr@gjlay.de>
+
+       PR target/81910
+       * config/avr/avr.c (avr_handle_addr_attribute): Early return if
+       not VAR_P. Filter attribute warnings with OPT_Wattributes.
+       (avr_attribute_table) <io, io_low, address>: Initialize
+       .decl_required with true.
+
 2017-08-21  Michael Meissner  <meissner@linux.vnet.ibm.com>
 
        * config/rs6000/rs6000-cpus.def (-mvsx-scalar-float): Delete
index 3baa61d5cf3aecd9a93fa0a1f4b92f4cdf698b9d..c91f6c485c32de08c4619dafa23c51d5fb4d5eea 100644 (file)
@@ -9790,10 +9790,12 @@ avr_handle_addr_attribute (tree *node, tree name, tree args,
   bool io_p = (strncmp (IDENTIFIER_POINTER (name), "io", 2) == 0);
   location_t loc = DECL_SOURCE_LOCATION (*node);
 
-  if (TREE_CODE (*node) != VAR_DECL)
+  if (!VAR_P (*node))
     {
-      warning_at (loc, 0, "%qE attribute only applies to variables", name);
+      warning_at (loc, OPT_Wattributes, "%qE attribute only applies to "
+                 "variables", name);
       *no_add = true;
+      return NULL_TREE;
     }
 
   if (args != NULL_TREE)
@@ -9803,8 +9805,8 @@ avr_handle_addr_attribute (tree *node, tree name, tree args,
       tree arg = TREE_VALUE (args);
       if (TREE_CODE (arg) != INTEGER_CST)
        {
-         warning (0, "%qE attribute allows only an integer constant argument",
-                  name);
+         warning_at (loc, OPT_Wattributes, "%qE attribute allows only an "
+                     "integer constant argument", name);
          *no_add = true;
        }
       else if (io_p
@@ -9813,19 +9815,20 @@ avr_handle_addr_attribute (tree *node, tree name, tree args,
                        ? low_io_address_operand : io_address_operand)
                         (GEN_INT (TREE_INT_CST_LOW (arg)), QImode)))
        {
-         warning_at (loc, 0, "%qE attribute address out of range", name);
+         warning_at (loc, OPT_Wattributes, "%qE attribute address "
+                     "out of range", name);
          *no_add = true;
        }
       else
        {
          tree attribs = DECL_ATTRIBUTES (*node);
-         const char *names[] = { "io", "io_low", "address", NULL } ;
+         const char *names[] = { "io", "io_low", "address", NULL };
          for (const char **p = names; *p; p++)
            {
              tree other = lookup_attribute (*p, attribs);
              if (other && TREE_VALUE (other))
                {
-                 warning_at (loc, 0,
+                 warning_at (loc, OPT_Wattributes,
                              "both %s and %qE attribute provide address",
                              *p, name);
                  *no_add = true;
@@ -9836,7 +9839,8 @@ avr_handle_addr_attribute (tree *node, tree name, tree args,
     }
 
   if (*no_add == false && io_p && !TREE_THIS_VOLATILE (*node))
-    warning_at (loc, 0, "%qE attribute on non-volatile variable", name);
+    warning_at (loc, OPT_Wattributes, "%qE attribute on non-volatile variable",
+               name);
 
   return NULL_TREE;
 }
@@ -9886,11 +9890,11 @@ avr_attribute_table[] =
     false },
   { "OS_main",   0, 0, false, true,  true,   avr_handle_fntype_attribute,
     false },
-  { "io",        0, 1, false, false, false,  avr_handle_addr_attribute,
+  { "io",        0, 1, true, false, false,  avr_handle_addr_attribute,
     false },
-  { "io_low",    0, 1, false, false, false,  avr_handle_addr_attribute,
+  { "io_low",    0, 1, true, false, false,  avr_handle_addr_attribute,
     false },
-  { "address",   1, 1, false, false, false,  avr_handle_addr_attribute,
+  { "address",   1, 1, true, false, false,  avr_handle_addr_attribute,
     false },
   { "absdata",   0, 0, true, false, false,  avr_handle_absdata_attribute,
     false },