Commit 99552e40 by Richard Guenther Committed by Richard Biener

re PR tree-optimization/34113 (ICE in get_addr_dereference_operands, at tree-ssa-operands.c:1746)

2007-11-16  Richard Guenther  <rguenther@suse.de>

	PR tree-optimization/34113
	* tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars):
	Use correct conversion direction for checking type compatibility.

	* gcc.c-torture/compile/pr34113.c: New testcase.

From-SVN: r130223
parent 7f879c96
2007-11-16 Richard Guenther <rguenther@suse.de> 2007-11-16 Richard Guenther <rguenther@suse.de>
PR tree-optimization/34113
* tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars):
Use correct conversion direction for checking type compatibility.
2007-11-16 Richard Guenther <rguenther@suse.de>
PR tree-optimization/34099 PR tree-optimization/34099
* tree-ssa-ccp.c (likely_value): Use a whitelist for operators * tree-ssa-ccp.c (likely_value): Use a whitelist for operators
that produce UNDEFINED result if at least one of its operands that produce UNDEFINED result if at least one of its operands
2007-11-16 Richard Guenther <rguenther@suse.de> 2007-11-16 Richard Guenther <rguenther@suse.de>
PR tree-optimization/34113
* gcc.c-torture/compile/pr34113.c: New testcase.
2007-11-16 Richard Guenther <rguenther@suse.de>
PR tree-optimization/34099 PR tree-optimization/34099
* g++.dg/torture/pr3499.C: New testcase. * g++.dg/torture/pr3499.C: New testcase.
* gcc.c-torture/execute/pr34099.c: Likewise. * gcc.c-torture/execute/pr34099.c: Likewise.
struct sockaddr_in { int sin_addr; };
static void ConvertAddr (struct sockaddr_in *saddr, void **addr)
{
*addr = (void *) &saddr->sin_addr;
}
unsigned char EnableLocalHost (struct sockaddr_in *ifa_addr)
{
unsigned char * addr;
ConvertAddr(ifa_addr, (void **)&addr);
return addr[0];
}
...@@ -959,8 +959,8 @@ tree_ssa_forward_propagate_single_use_vars (void) ...@@ -959,8 +959,8 @@ tree_ssa_forward_propagate_single_use_vars (void)
|| TREE_CODE (rhs) == CONVERT_EXPR) || TREE_CODE (rhs) == CONVERT_EXPR)
&& TREE_CODE (TREE_OPERAND (rhs, 0)) == ADDR_EXPR && TREE_CODE (TREE_OPERAND (rhs, 0)) == ADDR_EXPR
&& POINTER_TYPE_P (TREE_TYPE (rhs)) && POINTER_TYPE_P (TREE_TYPE (rhs))
&& useless_type_conversion_p (TREE_TYPE (TREE_TYPE (rhs)), && useless_type_conversion_p (TREE_TYPE (TREE_TYPE (TREE_OPERAND (rhs, 0))),
TREE_TYPE (TREE_TYPE (TREE_OPERAND (rhs, 0)))))) TREE_TYPE (TREE_TYPE (rhs)))))
{ {
if (forward_propagate_addr_expr (lhs, rhs)) if (forward_propagate_addr_expr (lhs, rhs))
{ {
......
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