+2019-04-01 Richard Biener <rguenther@suse.de>
+
+ PR c/71598
+ * gimple.c: Include langhooks.h.
+ (gimple_get_alias_set): Treat enumeral types as the underlying
+ integer type.
+
2019-03-29 Kugan Vivekanandarajah <kuganv@linaro.org>
Eric Botcazou <ebotcazou@adacore.com>
+2019-04-01 Richard Biener <rguenther@suse.de>
+
+ PR c/71598
+ * c-tree.h (c_get_alias_set): Declare.
+ * c-objc-common.h (LANG_HOOKS_GET_ALIAS_SET): Use c_get_alias_set.
+ * c-objc-common.c (c_get_alias_set): Treat enumeral types
+ as the underlying integer type.
+
2019-03-19 Martin Sebor <msebor@redhat.com>
PR tree-optimization/89688
{
return c_vla_type_p (x);
}
+
+/* Special routine to get the alias set of T for C. */
+
+alias_set_type
+c_get_alias_set (tree t)
+{
+ /* Allow aliasing between enumeral types and the underlying
+ integer type. This is required since those are compatible types. */
+ if (TREE_CODE (t) == ENUMERAL_TYPE)
+ {
+ tree t1 = c_common_type_for_size (tree_to_uhwi (TYPE_SIZE (t)),
+ /* short-cut commoning to signed
+ type. */
+ false);
+ return get_alias_set (t1);
+ }
+
+ return c_common_get_alias_set (t);
+}
#undef LANG_HOOKS_POST_OPTIONS
#define LANG_HOOKS_POST_OPTIONS c_common_post_options
#undef LANG_HOOKS_GET_ALIAS_SET
-#define LANG_HOOKS_GET_ALIAS_SET c_common_get_alias_set
+#define LANG_HOOKS_GET_ALIAS_SET c_get_alias_set
#undef LANG_HOOKS_PARSE_FILE
#define LANG_HOOKS_PARSE_FILE c_common_parse_file
#undef LANG_HOOKS_FINISH_INCOMPLETE_DECL
extern bool c_warn_unused_global_decl (const_tree);
extern void c_initialize_diagnostics (diagnostic_context *);
extern bool c_vla_unspec_p (tree x, tree fn);
+extern alias_set_type c_get_alias_set (tree);
/* in c-typeck.c */
extern int in_alignof;
#include "stringpool.h"
#include "attribs.h"
#include "asan.h"
+#include "langhooks.h"
/* All the tuples have their operand vector (if present) at the very bottom
return get_alias_set (t1);
}
+ /* Allow aliasing between enumeral types and the underlying
+ integer type. This is required for C since those are
+ compatible types. */
+ else if (TREE_CODE (t) == ENUMERAL_TYPE)
+ {
+ tree t1 = lang_hooks.types.type_for_size (tree_to_uhwi (TYPE_SIZE (t)),
+ false /* short-cut above */);
+ return get_alias_set (t1);
+ }
+
return -1;
}
+2019-04-01 Richard Biener <rguenther@suse.de>
+
+ PR c/71598
+ * gcc.dg/torture/pr71598-1.c: New testcase.
+ * gcc.dg/torture/pr71598-2.c: Likewise.
+ * gcc.dg/torture/pr71598-3.c: Likewise.
+
2019-03-31 Marek Polacek <polacek@redhat.com>
PR c++/89852 - ICE with C++11 functional cast with { }.
--- /dev/null
+/* { dg-do run } */
+/* { dg-additional-options "-fno-short-enums" } */
+
+enum e1 { c1 };
+
+__attribute__((noinline,noclone))
+int f(enum e1 *p, unsigned *q)
+{
+ *p = c1;
+ *q = 2;
+ return *p;
+}
+
+int main()
+{
+ unsigned x;
+
+ if (f(&x, &x) != 2)
+ __builtin_abort();
+ return 0;
+}
--- /dev/null
+/* { dg-do run } */
+/* { dg-additional-options "-fshort-enums" } */
+
+enum e1 { c1 = -__INT_MAX__ };
+
+__attribute__((noinline,noclone))
+int f(enum e1 *p, signed int *q)
+{
+ *p = c1;
+ *q = 2;
+ return *p;
+}
+
+enum e2 { c2 = __SHRT_MAX__ + 1};
+
+__attribute__((noinline,noclone))
+int g(enum e2 *p, unsigned short *q)
+{
+ *p = c2;
+ *q = 2;
+ return *p;
+}
+
+enum e3 { c3 = __SCHAR_MAX__ };
+
+__attribute__((noinline,noclone))
+int h(enum e3 *p, unsigned char *q)
+{
+ *p = c3;
+ *q = 2;
+ return *p;
+}
+
+int main()
+{
+ signed x;
+ unsigned short y;
+ unsigned char z;
+
+ if (f(&x, &x) != 2)
+ __builtin_abort();
+ if (g(&y, &y) != 2)
+ __builtin_abort();
+ if (h(&z, &z) != 2)
+ __builtin_abort();
+ return 0;
+}
--- /dev/null
+/* { dg-do run } */
+
+enum e1 { A, B };
+enum e2 { C, D };
+
+__attribute__((noinline,noclone))
+enum e1 f(unsigned int *p)
+{
+ *(enum e1 *)p = A;
+ *(enum e2 *)p = D;
+ return *(enum e1 *)p;
+}
+
+int main()
+{
+ unsigned int storage;
+
+ if (f(&storage) != B)
+ __builtin_abort();
+ return 0;
+}