Sent from my iPhone

On Apr 19, 2010, at 12:02 AM, "jakub at gcc dot gnu dot org" <gcc-bugzi...@gcc.gnu.org > wrote:



------- Comment #11 from jakub at gcc dot gnu dot org 2010-04-19 07:02 -------
This change broke building wine on x86-64.


There was already a bug filed for this and a patch was committed today or yesterday to the trunk to fix this ice.



Distilled testcase:
__attribute__ ((ms_abi)) fn2 (int, int);
struct S { int s; };
struct T { int t; struct S *u; };

void
foo (struct T *x, void *y)
{
 int a, b, c, d;
 fn1 (0, &a, &b, &c, &d);
 x->u[x->t].s = fn2 (fn3 (), a);
 fn1 (y, &a, &b, &c, &d);
}

__attribute__ ((ms_abi)) void
bar (int x)
{
}

void
baz (int x)
{
}

now ICEs at -O2 on x86_64-linux with:
wineice.i: In function 'foo':
wineice.i:12: internal compiler error: in insert_save, at caller- save.c:1171
Please submit a full bug report,
with preprocessed source if appropriate.
See <http://gcc.gnu.org/bugs.html> for instructions.

Apparently setup_save_areas
                 saved_reg->slot
                   = assign_stack_local_1
                     (regno_save_mode[regno][1],
GET_MODE_SIZE (regno_save_mode[regno][1]), 0, true); creates a slot where regno_save_mode[regno][1] for regno 4 is VOIDmode, and the
VOIDmode MEM which has MEM_ALIGN 0 then confuses everything.


--

jakub at gcc dot gnu dot org changed:

          What    |Removed                     |Added
--- --- ----------------------------------------------------------------------
            Status|RESOLVED                    |UNCONFIRMED
        Resolution|FIXED                       |


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=43562

Reply via email to