Commit 2a82beaa by Richard Biener Committed by Richard Biener

re PR c/71598 (Wrong optimization with aliasing enums)

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.

	c/
	* 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.

	* gcc.dg/torture/pr71598-1.c: New testcase.
	* gcc.dg/torture/pr71598-2.c: Likewise.
	* gcc.dg/torture/pr71598-3.c: Likewise.

From-SVN: r270052
parent acf8e57a
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
......
......@@ -265,3 +265,22 @@ c_vla_unspec_p (tree x, tree fn ATTRIBUTE_UNUSED)
{
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);
}
......@@ -43,7 +43,7 @@ along with GCC; see the file COPYING3. If not see
#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
......
......@@ -623,6 +623,7 @@ extern bool c_missing_noreturn_ok_p (tree);
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;
......
......@@ -44,6 +44,7 @@ along with GCC; see the file COPYING3. If not see
#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
......@@ -2587,6 +2588,16 @@ gimple_get_alias_set (tree t)
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 { }.
......
/* { 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;
}
/* { 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;
}
/* { 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;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment