+2011-04-14 Richard Sandiford <rdsandiford@googlemail.com>
+
+ * doc/options.texi (Negative): Explicitly mention that the
+ Negative chain must be circular.
+
+2011-04-14 Nathan Froyd <froydnj@codesourcery.com>
+
+ * function.h (block_chainon): Declare.
+ * function.c (block_chainon): Define.
+
+2011-04-14 Anatoly Sokolov <aesok@post.ru>
+ Eric Weddington <eric.weddington@atmel.com>
+ Georg-Johann Lay <avr@gjlay.de>
+
+ * config/avr/avr.c: ("insn-codes.h", "optabs.h", "langhooks.h"):
+ New Includes
+ (avr_init_builtins, avr_expand_builtin,
+ avr_expand_delay_cycles, avr_expand_unop_builtin,
+ avr_expand_binop_builtin ): New functions.
+ (avr_builtin_id): New enum
+ (struct avr_builtin_description): New struct
+ (bdesc_1arg, bdesc_2arg): New arrays describing some RTL builtins.
+ (TARGET_INIT_BUILTINS, TARGET_EXPAND_BUILTIN): Define.
+
+ * config/avr/avr.md (UNSPEC_FMUL, UNSPEC_FMULS, UNSPEC_FMULSU,
+ UNSPECV_ENABLE_IRQS, UNSPECV_NOP, UNSPECV_SLEEP, UNSPECV_WDR,
+ UNSPECV_DELAY_CYCLES): new enumeration values
+ (UNSPEC_SEI, UNSPEC_CLI): Remove enumeration values
+ ("enable_interrupt"): Use UNSPECV_ENABLE_IRQS
+ ("disable_interrupt"): Use UNSPECV_ENABLE_IRQS
+ ("*rotlqi3_4"): rename insn to "rotlqi3_4"
+ ("delay_cycles_1", "delay_cycles_2", "delay_cycles_3",
+ "delay_cycles_4", "nopv", "sleep", "wdr", "fmul", "fmuls",
+ "fmulsu"): New insns
+
+ * config/avr/avr-c.c: fix line endings
+ (avr_cpu_cpp_builtins): New builtin defines: __BUILTIN_AVR_NOP,
+ __BUILTIN_AVR_SEI, __BUILTIN_AVR_CLI, __BUILTIN_AVR_WDR,
+ __BUILTIN_AVR_SLEEP, __BUILTIN_AVR_SWAP,
+ __BUILTIN_AVR_DELAY_CYCLES, __BUILTIN_AVR_FMUL,
+ __BUILTIN_AVR_FMULS, __BUILTIN_AVR_FMULSU.
+
+ * doc/extend.texi (AVR Built-in Functions): New node
+ (Target Builtins): Add documentation of AVR
+ built-in functions.
+
+2011-04-14 Georg-Johann Lay <avr@gjlay.de>
+
+ PR target/44643
+ * config/avr/avr.c (avr_insert_attributes): Leave TREE_READONLY
+ alone. Error if non-const data has attribute progmem.
+
+2011-04-13 Nathan Froyd <froydnj@codesourcery.com>
+
+ * tree.h (struct tree_constructor): Include tree_typed instead of
+ tree_common.
+ * tree.c (initialize_tree_contains_struct): Mark TS_CONSTRUCTOR as
+ TS_TYPED instead of TS_COMMON.
+
+2011-04-12 Uros Bizjak <ubizjak@gmail.com>
+
+ * config/i386/sse.md (*sse2_uavgv16qi3): Merge with *avx_uavgv16qi3.
+ (*sse2_uavgv8hi3): Merge with *avx_uavgv8hi3.
+ (sse2_psadbw): Merge with *avx_psadbw.
+ (ssse3_phaddwv8hi3): Merge with *avx_phaddwv8hi3.
+ (ssse3_phadddv4si3): Merge with *avx_phadddv4si3.
+ (ssse3_phaddswv8hi3): Merge with *avx_phaddswv8hi3.
+ (ssse3_phsubwv8hi3): Merge with *avx_phsubwv8hi3.
+ (ssse3_phsubdv4si3): Merge with *avx_phsubdv4si3.
+ (ssse3_phsubswv8hi3): Merge with *avx_phsubswv8hi3.
+ (ssse3_pmaddubsw128): Merge with *avx_pmaddubsw128.
+ (*ssse3_pmulhrswv8hi3): Merge with *avx_pmulhrswv8hi3.
+ (ssse3_pshufbv16qi3): Merge with *avx_pshufbv16qi3.
+ (ssse3_psign<mode>3): Merge with *avx_psign<mode>3.
+ (ssse3_palignrti): Merge with *avx_palignrti.
+
+2011-04-13 Nathan Froyd <froydnj@codesourcery.com>
+
+ * tree-flow.h (struct gimple_df): Make free_ssanames a VEC.
+ * tree-ssanames.c (fini_ssanames): VEC_free it.
+ (make_ssa_name_fn): Update for VECness of free_ssanames.
+ (release_ssa_name, release_dead_ssa_names): Likewise.
+ * tree.h (struct tree_ssa_name): Include tree_typed instead of
+ tree_common.
+ * tree.c (initialize_tree_contains_struct): Mark TS_SSA_NAME as
+ TS_TYPED instead of TS_COMMON.
+
+2011-04-13 Nathan Froyd <froydnj@codesourcery.com>
+
+ * postreload-gcse.c (gcse_after_reload_main): Add calls to
+ statistics_counter_event.
+ * tree-ssa-copyrename.c (stats): Define.
+ (rename_ssa_copies): Count coalesced SSA_NAMEs. Add call to
+ statistics_counter_event.
+ * tree-ssa-math-opts.c (reciprocal_stats, sincos_stats): Define.
+ (bswap_stats, widen_mul_stats): Define.
+ (insert_reciprocals): Increment rdivs_inserted.
+ (execute_cse_reciprocals): Zeroize reciprocal_stats. Increment
+ rfuncs_inserted. Add calls to statistics_counter_event.
+ (execute_cse_sincos_1): Increment inserted.
+ (execute_cse_sincos): Zeroize sincos_stats. Add call to
+ statistics_counter_event.
+ (execute_optimize_bswap): Zeroize bswap_stats. Increment fields
+ of bswap_stats. Add calls to statistics_counter_event.
+ (convert_mult_to_widen): Increment widen_mults_inserted.
+ (convert_plusminus_to_widen): Increment maccs_inserted.
+ (convert_mult_to_fma): Increment fmas_inserted.
+ (execute_optimize_widening_mul): Zeroize widen_mul_stats. Add
+ calls to statistics_counter_event.
+
+2011-04-13 Vladimir Makarov <vmakarov@redhat.com>
+
+ PR rtl-optimization/48455
+ * ira-costs.c (find_costs_and_classes): Use i_mem_cost instead of
+ `temp_costs->mem_cost'.
+
+2011-04-13 Jan Hubicka <jh@suse.cz>
+
+ * ipa-inline.h: New file.
+ * ipa-inline-analysis.c: New file. Broken out of ...
+ * ipa-inline.c: ... this file; update toplevel comment;
+ include ipa-inline.h
+ (inline_summary): Move to ipa-inline.h
+ (cgraph_estimate_edge_time): Rename to estimate_edge_time; move to
+ ipa-inline-analysis.c.
+ (cgraph_estimate_time_after_inlining): Rename to estiamte_time_after_inlining;
+ move to ipa-inline-analysis.c
+ (cgraph_estimate_edge_growth): Move to ipa-inline-analysis.c; rename
+ to estimate_edge_growth.
+ (cgraph_estimate_size_after_inlining): Move to ipa-inline-analysis.c;
+ rename to estimate_size_after_inlining.
+ (cgraph_mark_inline_edge): Update for new naming convention.
+ (cgraph_check_inline_limits): Likewise.
+ (cgraph_edge_badness): Likewise.
+ (cgraph_decide_recursive_inlining): Likewise.
+ (cgraph_decide_inlining_of_small_functions): Likewise.
+ (cgraph_decide_inlining_incrementally): Likewise.
+ (cgraph_estimate_growth): Rename to estimate_growth; move to ipa-inline-analysis.c.
+ (eliminated_by_inlining_prob): Move to ipa-inline-analysis.c.
+ (estimate_function_body_sizes): Move to ipa-inline-analysis.c.
+ (compute_inline_parameters): Likewise.
+ (compute_inline_parameters_for_current): Likewise.
+ (pass_inline_parameters): Likewise.
+ (inline_indirect_intraprocedural_analysis): Likewise.
+ (analyze_function): Rename to inline_analyze_function; likewise.
+ (add_new_function): Move to ipa-inline-analysis.c.
+ (inline_generate_summary): Likewise.
+ (inline_read_summary): Likewise.
+ (inline_write_summary): Likewise.
+ * Makefile.in (ipa-inline-analysis.c): New file.
+
+2011-04-13 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE>
+
+ * configure.ac (gcc_cv_as_sparc_gotdata_op): Remove GNU ld check.
+ * configure: Regenerate.
+
+2011-04-13 Nathan Froyd <froydnj@codesourcery.com>
+
+ * tree.h (struct tree_int_cst, struct real_value): Include tree_typed
+ instead of tree_common.
+ (struct tree_fixed_cst, struct tree_string, struct tree_complex):
+ Likewise.
+ * tree.c (initialize_tree_contains_struct): Mark such nodes as being
+ TS_TYPED rather than TS_COMMON.
+ * print-tree.c (print_node) [STRING_CST]: Don't print TREE_CHAIN.
+
+2011-04-01 Georg-Johann Lay <avr@gjlay.de>
+
+ PR target/45263
+ * config/avr/libgcc.S (__do_global_ctors, __do_global_dtors): Don't use
+ r20 around calls of __tablejump_elpm__
+
+2011-04-13 Jakub Jelinek <jakub@redhat.com>
+
+ PR middle-end/48591
+ * omp-low.c (expand_omp_atomic_fetch_op): Return false if decl is
+ NULL.
+ (expand_omp_atomic_pipeline): Return false if cmpxchg is NULL.
+
+2011-04-13 Bernd Schmidt <bernds@codesourcery.com>
+
+ * dwarf2out.c (struct dw_cfi_struct): Remove member dw_cfi_next.
+ (dw_cfi_ref): Add DEF_VEC_P and some DEF_VEC_ALLOC_Ps.
+ (cfi_vec): New typedef.
+ (struct dw_fde_struct): Make dw_fde_cfi a cfi_vec. Replace
+ dw_fde_switch_cfi with an integer dw_fde_switch_cfi_index.
+ (cie_cfi_vec): New static variable.
+ (cie_cfi_head): Delete.
+ (add_cfi): Accept a cfi_vec * as first argument. All callers and
+ declaration changed. Use vector rather than list operations.
+ (new_cfi): Don't initialize the dw_cfi_next field.
+ (add_fde_cfi): Allocate cie_cfi_vec if necessary. Use vector
+ rather than list operations.
+ (lookup_cfa): Use vector rather than list operations.
+ (output_cfis): New argument upto. Accept a cfi_vec rather than
+ a dw_cfi_ref list head as argument. All callers changed.
+ Iterate over the vector using upto as a maximum index.
+ (output_all_cfis): New static function.
+ (output_fde): Use vector rather than list operations. Use the
+ new upto argument for output_cfis rather than manipulating a
+ list.
+ (dwarf2out_begin_prologue): Change initializations to match
+ new struct members.
+ (dwarf2out_switch_text_section): Initialize dw_fde_switch_cfi_index
+ from the vector length rather than searching for the end of a list.
+ Use output_all_cfis.
+ (convert_cfa_to_fb_loc_list): Use vector rather than list operations.
+
+2011-04-13 Nick Clifton <nickc@redhat.com>
+
+ * config/rx/rx.md (movmemsi): Do not use this pattern when
+ volatile pointers are involved.
+
+2011-04-13 Uros Bizjak <ubizjak@gmail.com>
+
+ * config/i386/sse.md (pinsrbits): Remove.
+ (sse2_packsswb): Merge with *avx_packsswb.
+ (sse2_packssdw): Merge with *avx_packssdw.
+ (sse2_packuswb): Merge with *avx_packuswb.
+ (vec_interleave_highv16qi): Merge with *avx_interleave_highv16qi.
+ (vec_interleave_lowv16qi): Merge with *avx_interleave_lowv16qi.
+ (vec_interleave_highv8hi): Merge with *avx_interleave_highv8hi.
+ (vec_interleave_lowv8hi): Merge with *avx_interleave_lowv8hi.
+ (vec_interleave_highv4si): Merge with *avx_interleave_highv4si.
+ (vec_interleave_lowv4si): Merge with *avx_interleave_lowv4si.
+ (*sse4_1_pinsrb): Merge with *avx_pinsr<ssevecsize>.
+ (*sse2_pinsrw): Merge with *avx_pinsr<ssevecsize>.
+ (*sse4_1_pinsrd): Merge with *avx_pinsr<ssevecsize>.
+ (*sse4_1_pinsrq): Merge with *avx_pinsrq.
+ (sse2_loadld): Merge with *avx_loadld.
+ (*vec_extractv2di_1_rex64): Merge with *vec_extractv2di_1_rex64_avx.
+ (*vec_extractv2di_1_sse2): Merge with *vec_extractv2di_1_avx.
+ (*vec_concatv2si_sse4_1): Merge with *vec_concatv2si_avx.
+ (*vec_concatv2di_rex64_sse4_1): Merge with *vec_concatv2di_rex64_avx.
+ (vec_concatv2di): Merge with *vec_concatv2di_avx.
+
+2011-04-12 Nathan Froyd <froydnj@codesourcery.com>
+
+ * c-decl.c (union lang_tree_node): Check for TS_COMMON before
+ calling TREE_CHAIN.
+ * print-tree.c (print_node): Likewise.
+ * tree-inline.c (copy_tree_r): Likewise.
+ * c-lang.c (LANG_HOOKS_INIT_TS): Define.
+ * lto-streamer-in.c (lto_input_tree_pointers): Check for TS_TYPED
+ instead of TS_COMMON.
+ * lto-streamer-out.c (lto_output_tree_pointers): Likewise.
+ * tree.c (initialize_tree_contains_struct): Handle TS_TYPED.
+ (copy_node_stat): Zero TREE_CHAIN only if necessary.
+ (MARK_TS_BASE, MARK_TS_TYPED, MARK_TS_COMMON): Move these...
+ (MARK_TS_DECL_COMMON, MARK_TS_DECL_COMMON, MARK_TS_DECL_WRTL):
+ ...and these...
+ (MARK_TS_DECL_WITH_VIS, MARK_TS_DECL_NON_COMMON): ...and these...
+ * tree.h: ...here.
+ (TREE_CHAIN): Check for a TS_COMMON structure.
+ (TREE_TYPE): Check for a TS_TYPED structure.
+
+2011-04-12 Pat Haugen <pthaugen@us.ibm.com>
+
+ * config/rs6000/rs6000.c (call_ABI_of_interest): Call
+ cgraph_get_create_node instead of cgraph_node.
+
+2011-04-12 Nicola Pero <nicola.pero@meta-innovation.com>
+
+ * c-parser.c (c_parser_initelt): Updated call to
+ objc_build_message_expr.
+ (c_parser_postfix_expression): Likewise.
+
+2011-04-12 Kai Tietz <ktietz@redhat.com>
+
+ * config/i386/mingw32.h (TARGET_SUBTARGET_DEFAULT): Add
+ MASK_MS_BITFIELD_LAYOUT bit.
+
+2011-04-12 Jakub Jelinek <jakub@redhat.com>
+
+ * combine.c (update_cfg_for_uncondjump): Instead of testing at_end
+ assert it is always true.
+ (try_combine): Don't call update_cfg_for_uncondjump for noop non-jump
+ moves.
+
+2011-04-12 Nicola Pero <nicola.pero@meta-innovation.com>
+
+ * c-parser.c (c_lex_one_token): Rewritten conditional used when
+ compiling Objective-C to be more efficient.
+
+2011-04-12 Axel Freyn <axel-freyn@gmx.de>
+
+ * opts-common.c (decode_cmdline_options_to_array): Remove variable
+ argv_copied.
+
+2011-04-12 Richard Sandiford <richard.sandiford@linaro.org>
+
+ * recog.h, genoutput.c, optabs.c: Revert last patch.
+
+2011-04-12 Ramana Radhakrishnan <ramana.radhakrishnan@linaro.org>
+
+ PR target/48090
+ * config/arm/arm.md (*arm_negdi2): Fix early clobber constraints.
+
+2011-04-12 Richard Sandiford <richard.sandiford@linaro.org>
+
+ * recog.h (insn_operand_data): Add an "allows_mem" field.
+ * genoutput.c (output_operand_data): Initialize it.
+ * optabs.c (maybe_legitimize_operand_same_code): New function.
+ (maybe_legitimize_operand): Use it when matching the original
+ op->value.
+
+2011-04-12 Richard Sandiford <richard.sandiford@linaro.org>
+
+ * genpreds.c (process_define_predicate): Move most processing
+ to gensupport.c. Continue to validate the expression.
+ * genrecog.c (did_you_mean_codes, compute_predicate_codes)
+ (process_define_predicate): Move processing to gensupport.c.
+ (main): Remove DEFINE_PREDICATE and DEFINE_SPECIAL_PREDICATE cases.
+ * gensupport.c (did_you_mean_codes): Moved from genrecog.c.
+ (compute_predicate_codes): Moved from genrecog.c. Add lineno
+ argument.
+ (valid_predicate_name_p): New function, split out from old
+ genpreds.c:process_define_predicate.
+ (process_define_predicate): New function, combining code from
+ old genpreds.c and genrecog.c functions.
+ (process_rtx): Call it for DEFINE_PREDICATE and
+ DEFINE_SPECIAL_PREDICATE.
+
+2011-04-12 Richard Sandiford <richard.sandiford@linaro.org>
+
+ * config/arm/arm.c (arm_print_operand): Use MEM_SIZE to get the
+ size of a '%A' memory reference.
+ (T_DREG, T_QREG): New neon_builtin_type_bits.
+ (arm_init_neon_builtins): Assert that the load and store operands
+ are neon_struct_operands.
+ (locate_neon_builtin_icode): Provide the neon_builtin_type_bits.
+ (NEON_ARG_MEMORY): New builtin_arg.
+ (neon_dereference_pointer): New function.
+ (arm_expand_neon_args): Add a neon_builtin_type_bits argument.
+ Handle NEON_ARG_MEMORY.
+ (arm_expand_neon_builtin): Update after above interface changes.
+ Use NEON_ARG_MEMORY for loads and stores.
+ * config/arm/predicates.md (neon_struct_operand): New predicate.
+ * config/arm/iterators.md (V_two_elem): Tweak formatting.
+ (V_three_elem): Use BLKmode for accesses that have no associated mode.
+ (V_four_elem): Tweak formatting.
+ * config/arm/neon.md (neon_vld1<mode>, neon_vld1_dup<mode>)
+ (neon_vst1_lane<mode>, neon_vst1<mode>, neon_vld2<mode>)
+ (neon_vld2_lane<mode>, neon_vld2_dup<mode>, neon_vst2<mode>)
+ (neon_vst2_lane<mode>, neon_vld3<mode>, neon_vld3_lane<mode>)
+ (neon_vld3_dup<mode>, neon_vst3<mode>, neon_vst3_lane<mode>)
+ (neon_vld4<mode>, neon_vld4_lane<mode>, neon_vld4_dup<mode>)
+ (neon_vst4<mode>): Replace pointer operand with a memory operand.
+ Use %A in the output template.
+ (neon_vld3qa<mode>, neon_vld3qb<mode>, neon_vst3qa<mode>)
+ (neon_vst3qb<mode>, neon_vld4qa<mode>, neon_vld4qb<mode>)
+ (neon_vst4qa<mode>, neon_vst4qb<mode>): Likewise, but halve
+ the width of the memory access. Remove post-increment.
+ * config/arm/neon-testgen.ml: Allow addresses to have an alignment.
+
+2011-04-12 Nick Clifton <nickc@redhat.com>
+
+ * config/v850/v850.c (expand_prologue): Do not use the CALLT
+ instruction for interrupt handlers if the target is the basic V850
+ architecture.
+ (expand_epilogue): Likewise.
+
+2011-04-12 Jakub Jelinek <jakub@redhat.com>
+
+ PR rtl-optimization/48549
+ * combine.c (propagate_for_debug): Also stop after BB_END of
+ this_basic_block. Process LAST and just stop processing after it.
+ (combine_instructions): If last_combined_insn has been deleted,
+ set last_combined_insn to its PREV_INSN.
+
+2011-04-12 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/46076
+ * gimple.h (struct gimple_statement_call): Add fntype field.
+ (gimple_call_fntype): Adjust.
+ (gimple_call_set_fntype): New function.
+ * gimple.c (gimple_build_call_1): Set the call function type.
+ * gimplify.c (gimplify_call_expr): Preserve the function
+ type the frontend used for the call.
+ (gimplify_modify_expr): Likewise.
+ * lto-streamer-in.c (input_gimple_stmt): Input the call stmts
+ function type.
+ * lto-streamer-out.c (output_gimple_stmt): Output the call stmts
+ function type.
+ * tree-ssa.c (useless_type_conversion_p): Function pointer
+ conversions are useless.
+
+2011-04-12 Martin Jambor <mjambor@suse.cz>
+
+ * cgraph.h (cgraph_node): Remove function declaration.
+ (cgraph_create_node): Declare.
+ (cgraph_get_create_node): Likewise.
+ * cgraph.c (cgraph_create_node): Renamed to cgraph_create_node_1.
+ Updated all callers.
+ (cgraph_node): Renamed to cgraph_create_node, assert that a node for
+ the decl does not already exist. Call cgraph_get_create_node instead
+ of cgraph_node.
+ (cgraph_get_create_node): New function.
+ (cgraph_same_body_alias): Update comment.
+ (cgraph_set_call_stmt): Call cgraph_get_node instead of cgraph_node,
+ assert it does not return NULL.
+ (cgraph_update_edges_for_call_stmt): Likewise.
+ (cgraph_clone_edge): Likewise.
+ (cgraph_create_virtual_clone): Likewise.
+ (cgraph_update_edges_for_call_stmt_node): Call cgraph_get_create_node
+ instead of cgraph_node.
+ (cgraph_add_new_function): Call cgraph_create_node or
+ cgraph_get_create_node instead of cgraph_node.
+ * cgraphbuild.c (record_reference): Call cgraph_get_create_node
+ instead of cgraph_node.
+ (record_eh_tables): Likewise.
+ (mark_address): Likewise.
+ (mark_load): Likewise.
+ (build_cgraph_edges): Call cgraph_get_create_node instead
+ of cgraph_node.
+ (rebuild_cgraph_edges): Likewise.
+ * cgraphunit.c (cgraph_finalize_function): Call cgraph_get_create_node
+ instead of cgraph_node.
+ (cgraph_copy_node_for_versioning): Call cgraph_create_node instead of
+ cgraph_node.
+ * lto-symtab.c (lto_symtab_merge_cgraph_nodes_1): Call
+ cgraph_create_node instead of cgraph_node.
+ * c-decl.c (finish_function): Call cgraph_get_create_node instead
+ of cgraph_node.
+ * lto-cgraph.c (input_node): Likewise.
+ * lto-streamer-in.c (input_function): Likewise.
+ * varasm.c (mark_decl_referenced): Likewise.
+ (assemble_alias): Likewise.
+
+2011-04-12 Martin Jambor <mjambor@suse.cz>
+
+ * tree-inline.c (tree_function_versioning): Call cgraph_get_node
+ instead of cgraph_node and assert it does not return NULL.
+ * lto-streamer-in.c (lto_read_body): Likewise.
+ * omp-low.c (new_omp_context): Likewise.
+ (create_task_copyfn): Likewise.
+ * tree-emutls.c (lower_emutls_function_body): Likewise.
+ * matrix-reorg.c (transform_allocation_sites): Likewise.
+
+2011-04-12 Jakub Jelinek <jakub@redhat.com>
+
+ PR c/48552
+ * c-typeck.c (build_asm_expr): Error out on attempts to use
+ void type outputs or inputs for constraints that allow reg or
+ don't allow memory.
+
+2011-04-11 Chung-Lin Tang <cltang@codesourcery.com>
+ Richard Earnshaw <rearnsha@arm.com>
+
+ PR target/48250
+ * config/arm/arm.c (arm_legitimize_reload_address): Update cases
+ to use sign-magnitude offsets. Reject unsupported unaligned
+ cases. Add detailed description in comments.
+ * config/arm/arm.md (reload_outdf): Disable for ARM mode; change
+ condition from TARGET_32BIT to TARGET_ARM.
+
+2011-04-11 Nathan Froyd <froydnj@codesourcery.com>
+
+ * tree.h (struct typed_tree): New.
+ (struct tree_common): Include it instead of tree_base.
+ (TREE_TYPE): Update for new location of type field.
+ (TYPE_USER_ALIGN, TYPE_PACKED): Refer to base field directly.
+ (DECL_USER_ALIGN, DECL_PACKED): Likewise.
+ (union tree_node): Add typed field.
+ * treestruct.def (TS_TYPED): New.
+ * lto-streamer.c (check_handled_ts_structures): Handle it.
+ * tree.c (MARK_TS_TYPED): New macro.
+ (MARK_TS_COMMON): Call it instead of MARK_TS_BASE.
+
+2011-04-11 Eric Botcazou <ebotcazou@adacore.com>
+
+ * cfghooks.c (redirect_edge_and_branch_force): Localize variable.
+ (force_nonfallthru): Do not alter the loop nest if no basic block
+ was created.
+
+2011-04-11 Uros Bizjak <ubizjak@gmail.com>
+
+ * config/i386/sse.md (VI): New mode iterator.
+ (SSEMODEI): Remove.
+ (AVX256MODEI): Ditto.
+ (AVXMODEF4P): Ditto.
+ (avxvecpsmode): Ditto.
+ (one_cmpl<mode>2): Enable for TARGET_SSE. Use VI mode iterator.
+ (sse2_andnot<mode>3): New expander.
+ (*andnot<mode>3): Merge with *sse2_andnot<mode>3 and
+ *avx_andnot<mode>3. Enable for TARGET_SSE. Use VI mode iterator.
+ (<any_logic:code><mode>3): Use VI mode iterator.
+ (*<any_logic:code><mode>3): Merge with *sse2_<any_logic:code><mode>3
+ and *avx_<any_logic:code><mode>3. Use VI mode iterator.
+ (*andnottf3): Handle AVX three-operand constraints.
+ (*<any_logic:code>tf3): Handle AVX three-operand constraints.
+
2011-04-11 Joseph Myers <joseph@codesourcery.com>
- Robert Millan <rmh@gnu.org>
+ Robert Millan <rmh@gnu.org>
* config.gcc (x86_64-*-kfreebsd*-gnu): Use i386/kfreebsd-gnu.h.
* config/i386/kfreebsd-gnu.h (GNU_USER_DYNAMIC_LINKER32,
* config/i386/knetbsd-gnu.h (GNU_USER_LINK_EMULATION): Define.
(REG_NAME): Don't undefine.
(MD_UNWIND_SUPPORT): Undefine.
- * config/i386/kopensolaris-gnu.h (GNU_USER_LINK_EMULATION):
- Define.
+ * config/i386/kopensolaris-gnu.h (GNU_USER_LINK_EMULATION): Define.
2011-04-11 Joseph Myers <joseph@codesourcery.com>
LINUX_TARGET_OS_CPP_BUILTINS to GNU_USER_TARGET_OS_CPP_BUILTINS.
* config/pa/pa-linux.h (TARGET_OS_CPP_BUILTINS): Change
LINUX_TARGET_OS_CPP_BUILTINS to GNU_USER_TARGET_OS_CPP_BUILTINS.
- (LINK_SPEC): Change LINUX_DYNAMIC_LINKER to
- GNU_USER_DYNAMIC_LINKER.
+ (LINK_SPEC): Change LINUX_DYNAMIC_LINKER to GNU_USER_DYNAMIC_LINKER.
* config/rs6000/linux64.h (LINUX_DYNAMIC_LINKER32): Rename to
GNU_USER_DYNAMIC_LINKER32.
(LINUX_DYNAMIC_LINKER64): Rename to GNU_USER_DYNAMIC_LINKER64.
LINUX_TARGET_OS_CPP_BUILTINS to GNU_USER_TARGET_OS_CPP_BUILTINS.
* config/xtensa/linux.h (TARGET_OS_CPP_BUILTINS): Change
LINUX_TARGET_OS_CPP_BUILTINS to GNU_USER_TARGET_OS_CPP_BUILTINS.
- (LINK_SPEC): Change LINUX_DYNAMIC_LINKER to
- GNU_USER_DYNAMIC_LINKER.
+ (LINK_SPEC): Change LINUX_DYNAMIC_LINKER to GNU_USER_DYNAMIC_LINKER.
2011-04-11 Joseph Myers <joseph@codesourcery.com>
* config.gcc (i[34567]86-*-linux* | i[34567]86-*-kfreebsd*-gnu |
i[34567]86-*-knetbsd*-gnu | i[34567]86-*-gnu* |
i[34567]86-*-kopensolaris*-gnu, x86_64-*-linux* |
- x86_64-*-kfreebsd*-gnu | x86_64-*-knetbsd*-gnu): Use the new
- headers.
+ x86_64-*-kfreebsd*-gnu | x86_64-*-knetbsd*-gnu): Use the new headers.
2011-04-11 Kai Tietz <ktietz@redhat.com>