Commit 7f7211fb by Jakub Jelinek Committed by Jakub Jelinek

re PR rtl-optimization/42475 (ICE at -O1 and above: internal compiler error: in…

re PR rtl-optimization/42475 (ICE at -O1 and above: internal compiler error: in simplify_subreg, at simplify-rtx.c:4954)

	PR rtl-optimization/42475
	* combine.c (make_compound_operation) <case SUBREG>: Use mode of
	SUBREG_REG (x) instead of tem's mode.

	* gcc.dg/pr42475.c: New test.

From-SVN: r155430
parent 374b9cb8
2009-12-23 Jakub Jelinek <jakub@redhat.com>
PR rtl-optimization/42475
* combine.c (make_compound_operation) <case SUBREG>: Use mode of
SUBREG_REG (x) instead of tem's mode.
2009-12-23 Jakub Jelinek <jakub@redhat.com>
Cary Coutant <ccoutant@google.com>
PR debug/42454
......@@ -7306,15 +7306,14 @@ make_compound_operation (rtx x, enum rtx_code in_code)
tem = make_compound_operation (SUBREG_REG (x), in_code);
{
rtx simplified;
simplified = simplify_subreg (GET_MODE (x), tem, GET_MODE (tem),
rtx simplified = simplify_subreg (mode, tem, GET_MODE (SUBREG_REG (x)),
SUBREG_BYTE (x));
if (simplified)
tem = simplified;
if (GET_CODE (tem) != GET_CODE (SUBREG_REG (x))
&& GET_MODE_SIZE (mode) < GET_MODE_SIZE (GET_MODE (tem))
&& GET_MODE_SIZE (mode) < GET_MODE_SIZE (GET_MODE (SUBREG_REG (x)))
&& subreg_lowpart_p (x))
{
rtx newer = force_to_mode (tem, mode, ~(HOST_WIDE_INT) 0,
......
2009-12-23 Jakub Jelinek <jakub@redhat.com>
PR rtl-optimization/42475
* gcc.dg/pr42475.c: New test.
2009-12-23 Jakub Jelinek <jakub@redhat.com>
Cary Coutant <ccoutant@google.com>
PR debug/42454
......
/* PR rtl-optimization/42475 */
/* { dg-do compile } */
/* { dg-options "-O2" } */
typedef struct { float x, y; } B;
typedef struct { float z; } C;
typedef struct { B b; C c; } D;
B
foo (float x, float y)
{
B b = { .x = x, .y = y };
return b;
}
B
bar (B b, B y)
{
return foo (y.x + b.x, b.y);
}
B
baz (D p)
{
D d = { };
B y = bar (foo (0, (p.c.z) / 2), d.b);
return y;
}
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