+2016-07-29 Marek Polacek <polacek@redhat.com>
+
+ PR c/71574
+ * c-common.c (handle_alloc_align_attribute): Also check FUNCTION_DECL.
+
2016-07-28 Martin Liska <mliska@suse.cz>
PR gcov-profile/68025
{
unsigned arg_count = type_num_arguments (*node);
tree position = TREE_VALUE (args);
- if (position && TREE_CODE (position) != IDENTIFIER_NODE)
+ if (position && TREE_CODE (position) != IDENTIFIER_NODE
+ && TREE_CODE (position) != FUNCTION_DECL)
position = default_conversion (position);
if (!tree_fits_uhwi_p (position)
+2016-07-29 Marek Polacek <polacek@redhat.com>
+
+ PR c/71574
+ * c-c++-common/pr71574.c: New test.
+
2016-07-29 Kugan Vivekanandarajah <kuganv@linaro.org>
PR middle-end/68217
--- /dev/null
+/* PR c/71574 */
+/* { dg-do compile } */
+
+int fn1 (void);
+int fn2 (void) __attribute__ ((alloc_align (fn1))); /* { dg-warning "parameter outside range" } */
+int fn3 (void) __attribute__ ((alloc_size (fn1))); /* { dg-warning "parameter outside range" } */
+int fn4 (void) __attribute__ ((assume_aligned (fn1))); /* { dg-warning "not integer constant" } */
+int fn5 (char *, char *) __attribute__((nonnull (fn1))); /* { dg-error "nonnull argument has invalid operand" } */
+int fn6 (const char *, ...) __attribute__ ((sentinel (fn1))); /* { dg-warning "not an integer constant" } */
+
+typedef int __attribute__((vector_size (fn1))) v4si; /* { dg-warning "attribute ignored" } */
+typedef int T __attribute__((aligned (fn1))); /* { dg-error "requested alignment is not" } */