Commit 3626621a by Richard Biener Committed by Richard Biener

re PR tree-optimization/55890 (calling a builtin func through a cast triggers an ICE)

2013-01-07  Richard Biener  <rguenther@suse.de>

	PR middle-end/55890
	* gimple.h (gimple_call_builtin_p): New overload.
	* gimple.c (validate_call): New function.
	(gimple_call_builtin_p): Likewise.
	* tree-ssa-structalias.c (find_func_aliases_for_builtin_call):
	Use gimple_call_builtin_p.
	(find_func_clobbers): Likewise.
	* tree-ssa-strlen.c (adjust_last_stmt): Likewise.
	(strlen_optimize_stmt): Likewise.

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

From-SVN: r194975
parent 8b2ea410
2013-01-07 Richard Biener <rguenther@suse.de>
PR middle-end/55890
* gimple.h (gimple_call_builtin_p): New overload.
* gimple.c (validate_call): New function.
(gimple_call_builtin_p): Likewise.
* tree-ssa-structalias.c (find_func_aliases_for_builtin_call):
Use gimple_call_builtin_p.
(find_func_clobbers): Likewise.
* tree-ssa-strlen.c (adjust_last_stmt): Likewise.
(strlen_optimize_stmt): Likewise.
2013-01-07 James Greenhalgh <james.greenhalgh@arm.com> 2013-01-07 James Greenhalgh <james.greenhalgh@arm.com>
* config/aarch64/arm_neon.h (vld1_dup_*): Make argument const. * config/aarch64/arm_neon.h (vld1_dup_*): Make argument const.
......
...@@ -4137,16 +4137,60 @@ is_gimple_builtin_call (gimple stmt) ...@@ -4137,16 +4137,60 @@ is_gimple_builtin_call (gimple stmt)
return false; return false;
} }
/* Return true when STMT is builtins call to CODE. */ /* Return true when STMTs arguments match those of FNDECL. */
static bool
validate_call (gimple stmt, tree fndecl)
{
tree targs = TYPE_ARG_TYPES (TREE_TYPE (fndecl));
unsigned nargs = gimple_call_num_args (stmt);
for (unsigned i = 0; i < nargs; ++i)
{
/* Variadic args follow. */
if (!targs)
return true;
tree arg = gimple_call_arg (stmt, i);
if (INTEGRAL_TYPE_P (TREE_TYPE (arg))
&& INTEGRAL_TYPE_P (TREE_VALUE (targs)))
;
else if (POINTER_TYPE_P (TREE_TYPE (arg))
&& POINTER_TYPE_P (TREE_VALUE (targs)))
;
else if (TREE_CODE (TREE_TYPE (arg))
!= TREE_CODE (TREE_VALUE (targs)))
return false;
targs = TREE_CHAIN (targs);
}
if (targs && !VOID_TYPE_P (TREE_VALUE (targs)))
return false;
return true;
}
/* Return true when STMT is builtins call to CLASS. */
bool
gimple_call_builtin_p (gimple stmt, enum built_in_class klass)
{
tree fndecl;
if (is_gimple_call (stmt)
&& (fndecl = gimple_call_fndecl (stmt)) != NULL_TREE
&& DECL_BUILT_IN_CLASS (fndecl) == klass)
return validate_call (stmt, fndecl);
return false;
}
/* Return true when STMT is builtins call to CODE of CLASS. */
bool bool
gimple_call_builtin_p (gimple stmt, enum built_in_function code) gimple_call_builtin_p (gimple stmt, enum built_in_function code)
{ {
tree fndecl; tree fndecl;
return (is_gimple_call (stmt) if (is_gimple_call (stmt)
&& (fndecl = gimple_call_fndecl (stmt)) != NULL && (fndecl = gimple_call_fndecl (stmt)) != NULL_TREE
&& DECL_BUILT_IN_CLASS (fndecl) == BUILT_IN_NORMAL && DECL_BUILT_IN_CLASS (fndecl) == BUILT_IN_NORMAL
&& DECL_FUNCTION_CODE (fndecl) == code); && DECL_FUNCTION_CODE (fndecl) == code)
return validate_call (stmt, fndecl);
return false;
} }
/* Return true if STMT clobbers memory. STMT is required to be a /* Return true if STMT clobbers memory. STMT is required to be a
......
...@@ -893,6 +893,7 @@ extern bool walk_stmt_load_store_ops (gimple, void *, ...@@ -893,6 +893,7 @@ extern bool walk_stmt_load_store_ops (gimple, void *,
bool (*)(gimple, tree, void *), bool (*)(gimple, tree, void *),
bool (*)(gimple, tree, void *)); bool (*)(gimple, tree, void *));
extern bool gimple_ior_addresses_taken (bitmap, gimple); extern bool gimple_ior_addresses_taken (bitmap, gimple);
extern bool gimple_call_builtin_p (gimple, enum built_in_class);
extern bool gimple_call_builtin_p (gimple, enum built_in_function); extern bool gimple_call_builtin_p (gimple, enum built_in_function);
extern bool gimple_asm_clobbers_memory_p (const_gimple); extern bool gimple_asm_clobbers_memory_p (const_gimple);
......
2013-01-07 Richard Biener <rguenther@suse.de>
PR middle-end/55890
* gcc.dg/torture/pr55890-1.c: New testcase.
* gcc.dg/torture/pr55890-2.c: Likewise.
2013-01-07 James Greenhalgh <james.greenhalgh@arm.com> 2013-01-07 James Greenhalgh <james.greenhalgh@arm.com>
* gcc.target/aarch64/fmovd.c: New. * gcc.target/aarch64/fmovd.c: New.
......
/* { dg-do compile } */
extern void *memmove(void *, void *, __SIZE_TYPE__);
typedef int (*_TEST_fun_) ();
static _TEST_fun_ i = (_TEST_fun_) memmove;
main() { i(); }
/* { dg-do compile } */
extern void *memcpy();
main() { memcpy(); }
...@@ -807,12 +807,10 @@ adjust_last_stmt (strinfo si, gimple stmt, bool is_strcat) ...@@ -807,12 +807,10 @@ adjust_last_stmt (strinfo si, gimple stmt, bool is_strcat)
return; return;
} }
if (!is_gimple_call (last.stmt)) if (!gimple_call_builtin_p (last.stmt, BUILT_IN_NORMAL))
return;
callee = gimple_call_fndecl (last.stmt);
if (callee == NULL_TREE || DECL_BUILT_IN_CLASS (callee) != BUILT_IN_NORMAL)
return; return;
callee = gimple_call_fndecl (last.stmt);
switch (DECL_FUNCTION_CODE (callee)) switch (DECL_FUNCTION_CODE (callee))
{ {
case BUILT_IN_MEMCPY: case BUILT_IN_MEMCPY:
...@@ -1750,7 +1748,7 @@ strlen_optimize_stmt (gimple_stmt_iterator *gsi) ...@@ -1750,7 +1748,7 @@ strlen_optimize_stmt (gimple_stmt_iterator *gsi)
if (is_gimple_call (stmt)) if (is_gimple_call (stmt))
{ {
tree callee = gimple_call_fndecl (stmt); tree callee = gimple_call_fndecl (stmt);
if (callee && DECL_BUILT_IN_CLASS (callee) == BUILT_IN_NORMAL) if (gimple_call_builtin_p (stmt, BUILT_IN_NORMAL))
switch (DECL_FUNCTION_CODE (callee)) switch (DECL_FUNCTION_CODE (callee))
{ {
case BUILT_IN_STRLEN: case BUILT_IN_STRLEN:
......
...@@ -4014,8 +4014,7 @@ find_func_aliases_for_builtin_call (gimple t) ...@@ -4014,8 +4014,7 @@ find_func_aliases_for_builtin_call (gimple t)
vec<ce_s> rhsc = vNULL; vec<ce_s> rhsc = vNULL;
varinfo_t fi; varinfo_t fi;
if (fndecl != NULL_TREE if (gimple_call_builtin_p (t, BUILT_IN_NORMAL))
&& DECL_BUILT_IN_CLASS (fndecl) == BUILT_IN_NORMAL)
/* ??? All builtins that are handled here need to be handled /* ??? All builtins that are handled here need to be handled
in the alias-oracle query functions explicitly! */ in the alias-oracle query functions explicitly! */
switch (DECL_FUNCTION_CODE (fndecl)) switch (DECL_FUNCTION_CODE (fndecl))
...@@ -4768,8 +4767,7 @@ find_func_clobbers (gimple origt) ...@@ -4768,8 +4767,7 @@ find_func_clobbers (gimple origt)
/* For builtins we do not have separate function info. For those /* For builtins we do not have separate function info. For those
we do not generate escapes for we have to generate clobbers/uses. */ we do not generate escapes for we have to generate clobbers/uses. */
if (decl if (gimple_call_builtin_p (t, BUILT_IN_NORMAL))
&& DECL_BUILT_IN_CLASS (decl) == BUILT_IN_NORMAL)
switch (DECL_FUNCTION_CODE (decl)) switch (DECL_FUNCTION_CODE (decl))
{ {
/* The following functions use and clobber memory pointed to /* The following functions use and clobber memory pointed to
......
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