Hi,

I'm trying to port gcc 4.6.1 for a new  target for which Pmode=PSI.
I have an ICE in size_binop_loc, at fold-const.c:1433 when compiling
gcc.c-torture/compile/921111-1.c

Here is the back trace
#1  0x000000000060f8f3 in size_binop_loc (loc=0, code=PLUS_EXPR,
arg0=0x2aaaae8d8150, arg1=0x2aaaae874dc0)
    at /home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/fold-const.c:1432
#2  0x00000000007ddefd in dr_analyze_innermost (dr=0xf5b0f0) at
/home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-data-ref.c:765
#3  0x00000000007de881 in create_data_ref (nest=0x0,
loop=0x2aaaae8917f8, memref=0x2aaaae87c558, stmt=0x2aaaae88ca00,
is_read=1 '\001')
    at /home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-data-ref.c:970
#4  0x00000000007e7d0d in find_data_references_in_stmt (nest=0x0,
stmt=0x2aaaae88ca00, datarefs=0xf57c98)
    at /home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-data-ref.c:4238
#5  0x00000000007e810d in find_data_references_in_bb (loop=0x0,
bb=0x2aaaae879548, datarefs=0xf57c98)
    at /home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-data-ref.c:4307
#6  0x00000000007e8838 in compute_data_dependences_for_bb
(bb=0x2aaaae879548, compute_self_and_read_read_dependences=1 '\001',
datarefs=0xf57c98,
    dependence_relations=0xf57ca0) at
/home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-data-ref.c:4493
#7  0x0000000000a91c71 in vect_analyze_data_refs (loop_vinfo=0x0,
bb_vinfo=0xf57c80, min_vf=0x7fffffffd17c)
    at /home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-vect-data-refs.c:2533
#8  0x000000000092705c in vect_slp_analyze_bb (bb=0x2aaaae879548) at
/home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-vect-slp.c:1704
#9  0x0000000000929d1b in execute_vect_slp () at
/home/buhrig/work/embedded/sdk/gcc/v2/src/gcc/tree-vectorizer.c:256

It seems dr_analyze_innermost calls size_binop (PLUS_EXPR, poffset,
TREE_OPERAND (base, 1))
with poffset an intreger SImode, and TREE_OPERAND (base, 1) a pointer, PSI.
So int_binop_types_match_p fails in TYPE_MODE (type1) == TYPE_MODE (type2).

I'm not sure where is the bug, if it is TREE_OPERAND (base, 1)) that
should be INTEGER (where should the conversion be?), or size_binop
that should work with PSI/SI ...

Thanks,
Aurélien

Reply via email to