This fixes an ICE with -O0 at LTO link time. The assertion that the destination result is equal to the promote_decl_mode result is only true for pseudos - but with -O0 we commit all autos to stack variables, so SA.partition_to_pseudo[] can contain MEMs.
Fixed by adjusting the assertion and always using the SA.partition_to_pseudo[] mode as destination mode. Bootstrapped and tested on x86_64-unknown-linux-gnu and on alpha by Uros, committed. Richard. 2011-12-21 Richard Guenther <rguent...@suse.de> PR lto/41159 * tree-outof-ssa.c (insert_value_copy_on_edge): Use the mode of the pseudo as destination mode. Only assert that is equal to the promoted mode of the decl if it is a REG. Index: gcc/tree-outof-ssa.c =================================================================== --- gcc/tree-outof-ssa.c (revision 182525) +++ gcc/tree-outof-ssa.c (working copy) @@ -237,9 +237,10 @@ insert_value_copy_on_edge (edge e, int d var = SSA_NAME_VAR (partition_to_var (SA.map, dest)); src_mode = TYPE_MODE (TREE_TYPE (src)); - dest_mode = promote_decl_mode (var, &unsignedp); + dest_mode = GET_MODE (SA.partition_to_pseudo[dest]); gcc_assert (src_mode == TYPE_MODE (TREE_TYPE (var))); - gcc_assert (dest_mode == GET_MODE (SA.partition_to_pseudo[dest])); + gcc_assert (!REG_P (SA.partition_to_pseudo[dest]) + || dest_mode == promote_decl_mode (var, &unsignedp)); if (src_mode != dest_mode) {