diff options
Diffstat (limited to 'gcc/ChangeLog-2009')
-rw-r--r-- | gcc/ChangeLog-2009 | 34876 |
1 files changed, 34876 insertions, 0 deletions
diff --git a/gcc/ChangeLog-2009 b/gcc/ChangeLog-2009 new file mode 100644 index 00000000000..af1a94f7bc9 --- /dev/null +++ b/gcc/ChangeLog-2009 @@ -0,0 +1,34876 @@ +2009-12-31 Jakub Jelinek <jakub@redhat.com> + + * tree-dump.c (dump_options): Don't set TDF_NOUID for all. + +2009-12-31 Dave Korn <dave.korn.cygwin@gmail.com> + Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk> + + PR target/41605 + * config/darwin.h (LINK_COMMAND_SPEC): Resolve fopenmp specifically + for target. + (LINK_SPEC): Replace dynamic libraries by static equivalents where + necessary. + * config/darwin9.h (LINK_COMMAND_SPEC): Resolve fopenmp specifically + for target. + +2009-12-30 Dave Korn <dave.korn.cygwin@gmail.com> + + PR lto/42531 + * lto-streamer-out.c (produce_asm): Skip any leading asterisk when + using DECL_ASSEMBLER_NAME to generate a section name. + (copy_function): Likewise. + +2009-12-30 Andreas Schwab <schwab@linux-m68k.org> + + PR target/42516 + * config/m68k/m68k.md (rotlsi_16): New insn. + +2009-12-30 Joseph Myers <joseph@codesourcery.com> + + PR c/42439 + * c-decl.c (check_bitfield_type_and_width): Only pedwarn if + pedantic for bit-field width not an integer constant expression + but folding to one. + +2009-12-30 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/41956 + * tree-vect-slp.c (vect_supported_load_permutation_p): Add check that + the load indices differ. + +2009-12-30 Uros Bizjak <ubizjak@gmail.com> + + PR target/42549 + * config/i386/mmx.md (*mmx_subv2sf3): Fix insn operand number for + alternative 1. + +2009-12-30 Robert Millan <rmh.gcc@aybabtu.com> + + PR other/42537 + * errors.c: Fix typo in comment. + * graphite-sese-to-poly.c: Likewise. + * profile.c (is_inconsistent): Fix typo in string. + +2009-12-29 Ian Lance Taylor <iant@google.com> + + PR middle-end/42099 + * expmed.c (expand_divmod): Don't shift HOST_WIDE_INT value more + than HOST_BITS_PER_WIDE_INT. + +2009-12-29 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (ix86_expand_int_vcond): Reformat. + +2009-12-29 Dave Korn <dave.korn.cygwin@gmail.com> + Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk> + + PR objective-c++/41595 + * config/darwin.c (darwin_label_is_anonymous_local_objc_name): + New function to recognize objective c/c++ internal symbols, + including mangled ones. + * config/darwin.h (ASM_OUTPUT_LABELREF): Use + darwin_label_is_anonymous_local_objc_name to detect both + mangled and clear ObjC internal symbols. + +2009-12-28 H.J. Lu <hongjiu.lu@intel.com> + + PR middle-end/41344 + * omp-low.c (diagnose_sb_2): Handle GIMPLE_COND. + +2009-12-24 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + PR target/42457 + * config/avr/avr.c (avr_extra_arch_macro): Remove static. + (avr_cpu_cpp_builtins): Remove. + * config/avr/avr.h (avr_extra_arch_macro): Add prototype. + * config/avr/avr-c.c: New File. + (avr_cpu_cpp_builtins) : Add. + * config/avr/t-avr: Add make information for avr-c. + * config.gcc (avr-*-*): Include avr-c.o as c and cpp object. + +2009-12-24 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + PR target/35013, 27192 + * config/avr/avr.c (print_operand_address): Print correct program + memory address. + Add warning for large device offset addresses. + (avr_assemble_integer): Ditto. + (print_operand): Add warnings for incorrect addressing. + (out_movqi_r_mr): Tag assembler with new address codes. + (out_movhi_r_mr): Ditto. + (out_movsi_r_mr): Ditto. + (out_movqi_mr_r): Ditto. + (out_movhi_mr_r): Ditto. + (out_movsi_mr_r): Ditto. + * config/avr/predicates.md (text_segment_operand): New predicate. + * config/avr/avr.md (jump): Tag assembler with new address codes. + (call_insn): Ditto. + (call_value_insn): Ditto. + (*tablejump_lib): Ditto. + (*cbi): Ditto. + (*sbi): Ditto. + (indirect_jump): New define_expand. + (jcindirect_jump): New pattern for constant expression jump. + (njcindirect_jump): Renamed old indirect_jump. + +2009-12-24 Steven Bosscher <steven@gcc.gnu.org> + + * store-motion.c (build_store_vectors): Clear regs_set_in_block at + the start of a loop over basic blocks. + +2009-12-24 Julian Brown <julian@codesourcery.com> + Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + PR target/40887 + * config/arm/arm.c (output_call_mem): Remove armv5 support. + * config/arm/arm.md (*call_mem): Disable for armv5. Add note. + (*call_value_mem): Likewise. + +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 + * dwarf2out.c (add_ranges_by_labels): Conditionally Add DW_AT_ranges + attribute. + (dwarf2out_finish): Change calls to add_ranges_by_labels. + +2009-12-23 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + PR target/42093 + * config/arm/arm.h (CASE_VECTOR_PC_RELATIVE): Fix macro usage + to TARGET_THUMB1. + (CASE_VECTOR_SHORTEN_MODE): Allow signed offsets + only for TARGET_THUMB1. + +2009-12-23 Ramana Radhakrishnan <ramrad01@arm.com> + + PR target/40670 + * config/arm/arm.md: Split for Thumb1 as well. + +2009-12-22 Cary Coutant <ccoutant@google.com> + + PR debug/42454 + * dwarf2out.c (dwarf2out_finish): Don't output range for .text + section unless .text section was used. Likewise for cold. + +2009-12-22 Brian Hackett <bhackett1024@gmail.com> + + * doc/plugins.texi: Rename pre-genericize event. + +2009-12-22 Paolo Carlini <paolo.carlini@oracle.com> + + PR driver/42463 + * params.def ([PARAM_PREDICTABLE_BRANCH_OUTCOME]): Fix typo in + help string. + + * doc/invoke.texi: Fix typo. + +2009-12-22 Paul Brook <paul@codesourcery.com> + + * doc/tm.texi (ARG_POINTER_CFA_OFFSET): Document new default. + * defaults.h (ARG_POINTER_CFA_OFFSET): Add pretend_args_size. + * config/spu/spu.h (ARG_POINTER_CFA_OFFSET): Add pretend_args_size. + +2009-12-21 Brian Hackett <bhackett1024@gmail.com> + + * plugin.def: Rename pre-genericize event. + * plugin.c (register_callback, invoke_plugin_callbacks): Same. + * c-decl.c (finish_function): Invoke callbacks on above event. + +2009-12-21 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/42429 + * reload.c (find_reloads_subreg_address): When adjusting mode of + MEM, update also MEM_SIZE if it is set. + +2009-12-21 H.J. Lu <hongjiu.lu@intel.com> + + PR bootstrap/42345 + * acinclude.m4 (gcc_GAS_FLAGS): New. + (gcc_GAS_CHECK_FEATURE): Use gcc_GAS_FLAGS. + * configure: Regenerated. + +2009-12-20 Michael Matz <matz@suse.de> + + PR tree-optimization/42027 + * cfgexpand.c (expand_gimple_cond): Use jumpy sequence for &, &&, | + and || if jumps are cheap. + +2009-12-19 Richard Guenther <rguenther@suse.de> + + PR lto/42401 + * lto-streamer-out.c (tree_is_indexable): Local statics are indexable. + (lto_output_tree_ref): Adjust assert. + +2009-12-19 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/42108 + * tree-ssa-sccvn.c (last_vuse_ptr): New variable. + (vn_reference_lookup_2): Update last seen VUSE. + (vn_reference_lookup_3): Avoid updating last seen VUSE after + translating. + (visit_reference_op_load): Use last seen VUSE from the first + lookup when entering into the table. + +2009-12-19 Joern Rennecke <amylaar@spamcop.net> + + * Makefile.in (PLUGIN_HEADERS): Add more headers. + + * tree-pass.h (GCC_PASS_LISTS): Define. + (PASS_LIST_NO_all_lowering_passes): New enumeration value. + (PASS_LIST_NO_all_small_ipa_passes): Likewise. + (PASS_LIST_NO_all_regular_ipa_passes): Likewise. + (PASS_LIST_NO_all_lto_gen_passes): Likewise. + (PASS_LIST_NO_all_passes): Likewise. + (PASS_LIST_NUM): Likewise. + (gcc_pass_lists): Declare. + * passes.c (gcc_pass_lists): Define. + +2009-12-18 Richard Guenther <rguenther@suse.de> + + * tree-ssa-sccvn.c (copy_nary): New function. + (copy_phis): Likewise. + (copy_references): Likewise. + (process_scc): Avoid last iteration by copying the + optimistic table to the valid table. + +2009-12-17 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (loc_descriptor): For SYMBOL_REFs and LABEL_REFs + use DW_OP_addr+DW_OP_stack_value instead of DW_OP_implicit_value. + (add_const_value_attribute): For CONST_STRING, SYMBOL_REFs and + LABEL_REFs use DW_OP_addr+DW_OP_stack_value DW_AT_location instead of + DW_AT_const_value. + +2009-12-17 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41679 + * var-tracking.c (count_uses): Count MO_VAL_USE of original + MO_VAL_SET value for COND_EXEC. + (add_stores): Handle conditional stores. + + PR debug/41679 + * var-tracking.c (use_type): Remove indirection from loc. + (count_uses): Dereference incoming loc early. + (add_uses): Dereference incoming loc early. + + PR debug/41679 + * var-tracking.c (add_stores): Avoid value mode mismatch for + promoted declarations. + +2009-12-17 Jakub Jelinek <jakub@redhat.com> + + PR c++/42386 + * ipa.c (function_and_variable_visibility): Clear same_comdat_group + links of DECL_EXTERNAL nodes. + +2009-12-17 Sandra Loosemore <sandra@codesourcery.com> + + * doc/rtl.texi (Vector Operations): Clarify vec_select result mode. + +2009-12-17 Julian Brown <julian@codesourcery.com> + + * config/arm/bpabi-v6m.S (test_div_by_zero): New macro. + (aeabi_ldivmod, aeabi_uldivmod): Use above macro. + * config/arm/bpabi.S (test_div_by_zero): New macro. + (aeabi_ldivmod, aeabi_uldivmod): Use above macro. + * config/arm/lib1funcs.asm (ARM_LDIV0): Tail-call int div-by-zero + handler for EABI. Add signed/unsigned argument, pass correct value + to that handler. + (THUMB_LDIV0): Same, for Thumb. + (DIV_FUNC_END): Add signed argument. + (WEAK): New macro (for EABI). + (__udivsi3, __umodsi3): Add unsigned argument to DIV_FUNC_END. For + __udivsi3, add entry point which skips division-by-zero test. + (__divsi3, __modsi3): Add signed argument to DIV_FUNC_END. + (__aeabi_uidivmod, __aeabi_idivmod): Check for division by zero. + Call __udivsi3 or __divsi3 via entry points which skip + division-by-zero tests. + (__div0): Rename to __aeabi_idiv0, __aeabi_ldiv0 for EABI, and + declare those names weak. + +2009-12-17 Richard Guenther <rguenther@suse.de> + + PR middle-end/42397 + * builtins.c (get_object_alignment): Properly deal with + a CONST_DECL base. + * expr.c (emit_block_move_hints): Assert the alignment makes sense. + +2009-12-17 Uros Bizjak <ubizjak@gmail.com> + + PR target/32280 + * config/i386/i386-modes.def (V1TI): New vector mode. + * config/i386/i386.h (VALID_SSE_REG_MODE): Add V1TImode. + (SSE_REG_MODE_P): Ditto. + * config/i386/sse.md (SSEMODE16): New mode iterator. + (AVXMODE16): Ditto. + (avxvecmode): Handle V1TI mode. + (*avx_mov<mode>_internal): Use AVXMODE16 instead of AVXMODE. + (mov<mode>): Use SSEMODE16 instead of SSEMODE. + (*mov<mode>_internal): Ditto. + (push<mode>1): Ditto. + (movmisalign<mode>): Ditto. + (sse2_ashlv1ti): Rename from sse2_ashlti. + (sse2_lshrv1ti): Rename from sse2_lshrti. + (*avx_ashlv1ti): Rename from *avx_ashlti and move from i386.md. + (*avx_lshrv1ti): Rename from *avx_lshrti and move from i386.md. + (vec_shl_<mode>): Convert operands to V1TImode and use V1TI shift. + (vec_shr_<mode>): Ditto. + (*sse2_mulv4si3): Update for renamed sse2_ashlv1ti3. + (udot_prodv4si): Ditto. + * config/i386/i386.c (classify_argument): Handle V1TImode. + (function_arg_advance_32): Ditto. + (function_arg_32): Ditto. + (ix86_expand_sse4_unpack): Convert operands to V1TImode and update + for renamed gen_sse2_lshrv1ti3. + (ix86_expand_args_builtin) <V2DI_FTYPE_V2DI_INT_CONVERT>: Set rmode + to V1TImode. + (struct builtin_description) <__builtin_ia32_pslldqi128>: Update + for renamed sse2_ashlv1ti3. + <__builtin_ia32_psrldqi128>: Update for renamed sse2_lshrv1ti3. + + Revert: + 2007-06-11 Uros Bizjak <ubizjak@gmail.com> + + PR target/32280 + * config/i386/sse.md ("sse2_ashlti", "sse2_lshrti3"): Move ... + * config/i386/i386.md ("sse2_ashlti", "sse2_lshrti3"): ... to here. + +2009-12-17 Richard Earnshaw <rearnsha@arm.com> + + PR target/42372 + * arm.md (pic_add_dot_plus_eight): Change output constraint from + update to write. + +2009-12-17 Shujing Zhao <pearly.zhao@oracle.com> + + * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): + Update build_indirect_ref calls. + +2009-12-17 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/sync.md (IMODE): Remove mode iterator. + (modesuffix): Remove mode attribute. + (modeconstraint): Ditto. + (immconstraint): Ditto. + (*sync_compare_and_swap<mode>): Use SWI mode iterator instead of + IMODE mode iterator, imodesuffix mode attribute instead of modesuffix, + <r> mode attribute instead of modeconstraint and <i> mode attribute + instead of immconstraint. + (sync_double_compare_and_swap<mode>): Ditto. + (sync_old_add<mode>): Ditto. + (sync_lock_test_and_set<mode>): Ditto. + (sync_add<mode>): Ditto. + (sync_sub<mode>): Ditto. + (sync_and<mode>): Ditto. + (sync_ior<mode>): Ditto. + (sync_xor<mode>): Ditto. + (sync_<code><mode>): Macroize insn pattern from + sync_{and,ior,xor}<mode> using any_logic code iterator. + +2009-12-17 Shujing Zhao <pearly.zhao@oracle.com> + + PR c/40885 + * c-common.h (ref_operator): New type. + (build_indirect_ref): Adjust prototype with new argument. + * c-typeck.c (build_indirect_ref): Accept ref_operator as argument and + emit the diagnostics for easy translation. + (build_array_ref): Update calls to build_indirect_ref. + * c-omp.c (c_finish_omp_atomic): Likewise. + * c-parser.c (c_parser_unary_expression, + c_parser_postfix_expression_after_primary): Likewise. + +2009-12-16 Richard Guenther <rguenther@suse.de> + + PR lto/42392 + * langhooks.c (lhd_begin_section): Make sure to switch back + to the text section, not some random one. + +2009-12-16 Jakub Jelinek <jakub@redhat.com> + + * tree-chrec.c (chrec_convert_1): Only fold (T2)(t +- x) to + (T2)t +- (T2)x if only integer types are involved. + +2009-12-16 Ben Elliston <bje@au.ibm.com> + + * tree-data-ref.h (dot_rdg): Remove prototype. + * tree-data-ref.c (dog_rdg_1, dot_rdg): Remove. + +2009-12-16 Kazu Hirata <kazu@codesourcery.com> + + * doc/invoke.texi, doc/options.texi, doc/plugins.texi, + doc/tm.texi: Fix typos. + +2009-12-15 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/extend.texi (Function Attributes, Extended Asm): + Replace TABs with spaces. + * doc/md.texi (Standard Names): Likewise. + * doc/plugins.texi (Plugins): Likewise. + + * doc/c-tree.texi (Expression trees): Use @itemx for all but + the first item for merged items. + * doc/extend.texi (Variable Attributes): Likewise. + * doc/install.texi (Configuration): Likewise. + * doc/invoke.texi (RS/6000 and PowerPC Options, RX Options): + Likewise. + +2009-12-15 Richard Guenther <rguenther@suse.de> + + * tree.c (free_lang_data_in_binfo): Do not free BINFO_OFFSET + and BINFO_VPTR_FIELD. + (free_lang_data_in_type): Do not free TYPE_STUB_DECL if we + generate debug information. + (free_lang_data_in_decl): Do not free DECL_SIZE_UNIT, + DECL_SIZE, DECL_FIELD_OFFSET and DECL_FCONTEXT. + (free_lang_data): Do not disable debuginfo. + * lto-streamer-out.c (write_symbol_vec): Deal with + non-constant DECL_SIZE. + (pack_ts_base_value_fields): Write types with false + TREE_ASM_WRITTEN. + (lto_output_ts_type_tree_pointers): Stream TYPE_STUB_DECL. + * lto-streamer-in.c (lto_input_ts_type_tree_pointers): Stream + TYPE_STUB_DECL. + * dwarf2out.c (add_pure_or_virtual_attribute): Check for + DECL_CONTEXT. + (gen_type_die_for_member): Test for TYPE_STUB_DECL. + * opts.c (decode_options): Do not disable var-tracking for lto. + * doc/invoke.texi (-flto): Document -flto vs. -g experimental + status. + (-fwhopr): Document experimental status. + +2009-12-15 Aldy Hernandez <aldyh@redhat.com> + + PR graphite/42185 + * graphite-sese-to-poly.c (is_reduction_operation_p): Assert that + we are a GIMPLE_ASSIGN. Do not calculate rhs code twice. + (follow_ssa_with_commutative_ops): Return NULL on non assignment. + +2009-12-15 Eric Botcazou <ebotcazou@adacore.com> + + * config/rs6000/rs6000.md (probe_stack): Use an enclosing SET. + +2009-12-15 Richard Guenther <rguenther@suse.de> + + * gimple.h (compare_field_offset): Declare. + * gimple.c (compare_field_offset): Export. + * lto-streamer-in.c (input_gimple_stmt): Use compare_field_offset. + +2009-12-15 Richard Guenther <rguenther@suse.de> + + * lto-cgraph.c (lto_output_node): Also stream the alias + for regular aliases. + (input_node): Likewise. + +2009-12-15 Paolo Bonzini <bonzini@gnu.org> + Shujing Zhao <pearly.zhao@oracle.com> + + * intl.c (get_spaces): New. + * intl.h (get_spaces): New. + +2009-12-14 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/42369 + * config/i386/i386.c (ix86_expand_special_args_builtin): Avoid + using switch with CODE_FOR_lwp_lwp* cases. + + * config/i386/i386-builtin-types.def (PVOID_FTYPE_VOID): Use + DEF_FUNCTION_TYPE (PVOID) instead of DEF_FUNCTION_TYPE (PVOID, VOID). + +2009-12-14 Eric Botcazou <ebotcazou@adacore.com> + + * cfgexpand.c (expand_debug_expr) <INDIRECT_REF>: Remove overzealous + assertion and useless code. + <TARGET_MEM_REF>: Likewise. + +2009-12-14 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41473 + * dwarf2out.c (AT_loc_list_ptr): New. + (resolve_addr): Remove unresolved attributes and loc_list entries. + + PR debug/41473 + * dwarf2out.c (add_var_loc_to_decl): Don't drop initial empty + locations. + (new_loc_list): Drop gensym arg. Move generation of ll_symbol... + (gen_llsym): ... here. New function. + (add_loc_descr_to_loc_list): Removed. + (loc_descriptor): Infer mode from CONST_DOUBLEs and CONST_VECTORs. + (single_element_loc_list): Removed. + (dw_loc_list): Don't create entries without a location. Don't + special-case the first node of the list, only single nodes. + (single_element_loc_list_p): Simplify. + (loc_list_from_tree): Don't use DECL_RTL if loc_list is nonempty. + (add_location_or_const_value_attribute): Test var loc for NULL. + (convert_cfa_to_fb_loc_list): Adjust calls to new new_loc_list, + call gen_llsym if needed. + +2009-12-14 Jakub Jelinek <jakub@redhat.com> + + * cgraph.h (cgraph_set_nothrow_flag, cgraph_set_readonly_flag, + cgraph_set_pure_flag, cgraph_set_looping_const_or_pure_flag): New + prototypes. + * cgraph.c (cgraph_set_nothrow_flag, cgraph_set_readonly_flag, + cgraph_set_pure_flag, cgraph_set_looping_const_or_pure_flag): New + functions. + * except.h (set_nothrow_function_flags): Remove prototype. + * except.c (set_nothrow_function_flags): Use cgraph_set_nothrow_flag. + Make static. + * ipa-pure-const.c (propagate): Use cgraph_set_nothrow_flag, + cgraph_set_readonly_flag, cgraph_set_pure_flag + and cgraph_set_looping_const_or_pure_flag. + (local_pure_const): Likewise. + +2009-12-14 Jakub Jelinek <jakub@redhat.com> + Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/i386-builtin-types.def (PVOID): Declared. + (VOID_FTYPE_PVOID): Declared. + (PVOID_FTYPE_VOID): Declared. + (UCHAR_FTYPE_USHORT_UINT_USHORT): Removed. + (VOID_FTYPE_USHORT_UINT_USHORT): Removed. + * config/i386/i386.c (IX86_BUILTIN_LLWPCB16, IX86_BUILTIN_LLWPCB32, + IX86_BUILTIN_LLWPCB64, IX86_BUILTIN_SLWPCB16, IX86_BUILTIN_SLWPCB32, + IX86_BUILTIN_SLWPCB64, IX86_BUILTIN_LWPVAL16, IX86_BUILTIN_LWPINS16): + Removed. + (IX86_BUILTIN_LLWPCB, IX86_BUILTIN_SLWPCB): New. + (bdesc_special_args): Adjust declaration of __builtin_ia32_llwpcb, + __builtin_ia32_slwpcb, __builtin_ia32_lwpval32, + __builtin_ia32_lwpval64, __builtin_ia32_lwpins32, and + __builtin_ia32_lwpins64. + (ix86_expand_special_args_builtin): Handle VOID_FTYPE_PVOID. + Do not handle VOID_FTYPE_USHORT_UINT_USHORT and + UCHAR_FTYPE_USHORT_UINT_USHORT. Warn when the third operand is + not an immediate. Also handle builtin functions with 3 arguments. + (ix86_expand_builtin): Handle IX86_BUILTIN_LLWPCB and + IX86_BUILTIN_SLWPCB. + * config/i386/i386.md (UNSPEC_LLWP_INTRINSIC, UNSPEC_SLWP_INTRINSIC): + Renamed UNSPECV_LLWP_INTRINSIC and UNSPECV_SLWP_INTRINSIC. + (memory attribute): Handle lwp. + (lwp*): Rewrite all the insn patterns for LWP. + * config/i386/lwpintrin.h (__llwpcb16, __llwpcb32, __llwpcb64, + __slwpcb16, __slwpcb32, __slwpcb64, __lwpval16, __lwpins16): Removed. + (__llwpcb, __slwpcb): New. + +2009-12-14 Dmitry Gorbachev <d.g.gorbachev@gmail.com> + + * dominance.c (set_immediate_dominator): Don't mark as inline. + +2009-12-14 Eric Botcazou <ebotcazou@adacore.com> + + * doc/tm.texi (STACK_CHECK_PROTECT): Document alternate default. + * doc/md.texi (check_stack): Clarify. + (probe_stack): Likewise. + * config/rs6000/rs6000.md (UNSPEC_PROBE_STACK): New constant. + (probe_stack): New insn. + +2009-12-14 Ben Elliston <bje@au.ibm.com> + + * lto-streamer-in.c (lto_get_builtin_tree): fclass can only be a + BUILT_IN_NORMAL or BUILT_IN_MD. + +2009-12-13 Eric Botcazou <ebotcazou@adacore.com> + + * doc/tm.texi (STACK_CHECK_PROBE_LOAD): Delete. + * expr.h (STACK_CHECK_PROBE_LOAD): Likewise. + * explow.c (emit_stack_probe): Do not test STACK_CHECK_PROBE_LOAD. + * system.h (STACK_CHECK_PROBE_LOAD): Poison. + +2009-12-13 Michael Matz <matz@suse.de> + + PR tree-optimization/42027 + * dojump.c (do_jump <TRUTH_AND_EXPR, TRUTH_OR_EXPR>): Go to + TRUTH_ANDIF_EXPR resp. TRUTH_ORIF_EXPR expander, instead of + falling through. + +2009-12-13 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + PR target/23726 + * config/avr/predicates.md (pseudo_register_operand): New predicate + for pseudos. + * config/avr/avr.md (divmodqi4): Replace with define_insn_and_split + to allow div/mod optimization. + (udivmodqi4): Ditto. + (divmodhi4): Ditto. + (udivmodhi4): Ditto. + (divmodsi4): Ditto. + (udivmodsi4): Ditto. + +2009-12-13 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/42357 + * tree-sra.c (sra_modify_assign): Do not tear apart struct copies. + +2009-12-12 Richard Guenther <rguenther@suse.de> + + * tree.c (need_assembler_name_p): Abstract decls do not need + an assembler name. + * dwarf2out.c (dwarf2out_abstract_function): Preserve + DECL_ABSTRACT properly. + +2009-12-11 Richard Guenther <rguenther@suse.de> + + * lto-streamer-in.c (lto_input_tree_ref): Do not register + DEBUG_EXPR_DECLs with the varpool. + +2009-12-11 Eric Botcazou <ebotcazou@adacore.com> + + * config/sparc/linux-unwind.h (MD_FROB_UPDATE_CONTEXT, 64-bit): Define. + (sparc64_frob_update_context): New function. + +2009-12-11 Richard Guenther <rguenther@suse.de> + + PR lto/41658 + PR lto/41657 + * lto-streamer-out.c (write_global_stream): Do not make decls + weak but resort to TREE_ASM_WRITTEN to avoid multiple definitions. + Make sure to mark all decls that we have written. + +2009-12-11 Sebastian Andrzej Siewior <bigeasy@linutronix.de> + + PR target/36047 + + * config/m68k/linux.h: Remove LABELNO from the mcount statement. It is + not used by glibc/uclibc and does not work with large binaries. + +2009-12-11 Richard Guenther <rguenther@suse.de> + + PR lto/41662 + * lto-streamer-in.c (lto_init_eh): Move eh_initialized_p + handling here. + (input_eh_regions): Adjust. + (lto_input_ts_function_decl_tree_pointers): Initialize EH + if a non-NULL DECL_FUNCTION_PERSONALITY was read in. + +2009-12-11 Duncan Sands <baldrick@free.fr> + + * passes.c (make_pass_instance): Allocate and copy the right amount of + memory for ipa passes, which are not the same size as other passes. + +2009-12-11 Joern Rennecke <amylaar@spamcop.net> + + * plugin.c (get_named_event_id): Fix hash table rebuild to include + dynamically allocated events. + +2009-12-11 Richard Guenther <rguenther@suse.de> + + PR lto/42320 + * lto-symtab.c (lto_symtab_resolve_can_prevail_p): Properly + detect non-prevailing decls. + +2009-12-10 Jakub Jelinek <jakub@redhat.com> + + PR c++/42317 + * cgraph.h (struct cgraph_node): Add same_comdat_group field. + * cgraph.c (cgraph_remove_node): Unchain node from same_comdat_group + circular list. + (cgraph_node_can_be_local_p): Return false for DECL_COMDAT with + node->same_comdat_group. + * ipa.c (cgraph_remove_unreachable_nodes): For any reachable node + mark all its same_comdat_group nodes as also reachable. + (cgraph_externally_visible_p): Return true even if any of + same_comdat_group nodes has address taken. + * lto-cgraph.c (lto_output_node): Stream out same_comdat_group. + (output_cgraph): Ensure other same_comdat_group nodes are also + included. + (input_node): Stream in same_comdat_group. + (input_cgraph_1): Fix up same_comdat_group fields from references + to pointers. + * cgraphunit.c (cgraph_analyze_functions): Mark all other + same_comdat_group nodes as reachable. + (cgraph_mark_functions_to_output): For each node->process process + also other same_comdat_group nodes. + * ipa-inline.c (cgraph_clone_inlined_nodes): Don't reuse nodes + with same_comdat_group non-NULL. + (cgraph_mark_inline_edge): Likewise. + +2009-12-10 Jan Hubicka <jh@suse.cz> + + PR middle-end/42228 + PR middle-end/42110 + * cgraph.c (cgraph_create_edge_including_clones): Add old_stmt + parameter; update edge if it already exists. + (cgraph_remove_node): Handle correctly cases where we are removing + node having clones. + * cgraph.h (cgraph_create_edge_including_clones): Declare. + (verify_cgraph_node): Add missing error_found = true code. + (cgraph_materialize_all_clones): Remove call edges of dead nodes. + * ipa.c (cgraph_remove_unreachable_nodes): Correctly look for master + clone; fix double linked list removal. + * tree-inline.c (copy_bb): Update cgraph_create_edge_including_clones + call; fix frequency of newly created edge. + +2009-12-10 Bernd Schmidt <bernd.schmidt@analog.com> + + PR rtl-opt/42216 + * regrename.c: Error out if MAX_RECOG_OPERANDS is larger than + HOST_BITS_PER_WIDE_INT. + (verify_reg_in_set): New function, broken out of verify_reg_tracked. + (verify_reg_tracked): Use it. + (scan_rtx_reg): When seeing a use involving a superset of the + registers in an existing chain, enlarge that chain. Otherwise, + allow subsets and set fail_current_block for all other kinds of + overlap. + (hide_operands): New argument UNTRACKED_OPERANDS; callers changed. + Do not modify operands when the bit with the corresponding number + is set in that bitmap. + (build_def_use): When we see matching operands with different + modes, don't set fail_current_block, but keep track of such + operands in a bitmap if their registers aren't already tracked + in an open chain. Pass this bitmap to all hide_operands calls. + +2009-12-10 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/42337 + * tree-ssa-pre.c (seen_during_translate): Remove. + (phi_translate_1): Collapse into ... + (phi_translate): ... this. Remove seen parameter and + adjust recursive calls. + +2009-12-10 Richard Guenther <rguenther@suse.de> + Allan Sandfeld Jensen <linux@carewolf.com> + + * tree-vectorizer.c (vectorize_loops): Properly guard + vectorizer verboseness. + +2009-12-10 Ben Elliston <bje@au.ibm.com> + + * fwprop.c (free_load_extend): Initialise `use'. + +2009-12-09 David Edelsohn <edelsohn@gnu.org> + + * builtins.c (do_mpc_ckconv): Pass the component type to + real_from_mpfr(). + +2009-12-09 Xinliang David Li <davidxl@google.com> + + PR tree-optimization/42337 + * tree-ssa-pre.c (phi_translate_1): Push and Pop SEEN set. + +2009-12-09 Nathan Froyd <froydnj@codesourcery.com> + + * config/rs6000/vector.md (absv2sf2, negv2sf2, addv2sf3, subv2sf3, + mulv2sf3, divv2sf3): New expanders. + * config/rs6000/spe.md (spe_evabs, spe_evand, spe_evaddw, spe_evsubfw, + spe_evdivws): Rename to use standard GCC names. + * config/rs6000/paired.md (negv2sf, absv2sf2, addv2sf3, subv2sf3, + mulv2sf3, divv2sf3): Rename to avoid conflict with the new expanders. + * config/rs6000/rs6000.c (bdesc_2arg, bdesc_1arg): Use new CODE_FOR_ + names for renamed patterns. + +2009-12-09 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.md ("copysign<mode>3"): Pattern removed. + +2009-12-09 Jakub Jelinek <jakub@redhat.com> + + * configure.ac: Compute ld_ver, ld_vers, ld_date, ld_vers_major, + ld_vers_minor and ld_vers_path always, not just when gcc_cv_ld_hidden + isn't cached. + * configure: Regenerated. + +2009-12-08 Richard Henderson <rth@redhat.com> + + * combine.c (setup_incoming_promotions): Fix sign-extend of + zero-extend case; tidy conditions. + +2009-12-08 Michael Matz <matz@suse.de> + + PR middle-end/38474 + * function.c (free_temp_slots): Only walk the temp slot + addresses and combine slots if we actually changes something. + (pop_temp_slots): Ditto. + +2009-12-08 Olga Golovanevsky <olga@il.ibm.com> + + PR middle-end/41843 + * ipa-struct-reorg.c (compare_fields): New function. + (find_field_in_struct_1): Use compare_fields function. + (is_equal_types): Likewise. + +2009-12-07 DJ Delorie <dj@redhat.com> + + PR c/42312 + * config/mep/mep.c (mep_expand_prologue): Set + really_need_stack_frame after frame_size is set. + +2009-12-07 Richard Henderson <rth@redhat.com> + + PR rtl-opt/42269 + * combine.c (setup_incoming_promotions): Improve the conditions + under which we respect the promotions applied. + +2009-12-07 Eric Botcazou <ebotcazou@adacore.com> + + * config/sparc/linux.h (ASM_SPEC): Pass -K PIC if -findirect-dispatch. + * config/sparc/linux64.h (ASM_SPEC): Likewise. + +2009-12-07 Richard Henderson <rth@redhat.com> + + PR debug/42299 + PR debug/42166 + * tree-ssa.c (insert_debug_temp_for_var_def): Skip propagation + for ssa names already registered for update. + +2009-12-07 Jakub Jelinek <jakub@redhat.com> + + PR debug/42244 + * ddg.c (add_inter_loop_mem_dep): Use ANTI_DEP if from or to + is a DEBUG_INSN. + +2009-12-07 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/driver-i386.c (host_detect_local_cpu): Add -mlwp to the + options when bit_LWP is set. + +2009-12-07 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/cpuid.h (bit_ABM): New. + * config/i386/driver-i386.c (host_detect_local_cpu): Add -mabm to the + options when bit_ABM is set. + +2009-12-07 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.c (bdesc_special_args): Move __builtin_clzs from + this array ... + (bdesc_args): ... here. + * config.gcc (i[34567]86-*-*): Include abmintrin.h. + (x86_64-*-*): Likewise. + +2009-12-07 Sebastian Pop <sebastian.pop@amd.com> + + * config.gcc (i[34567]86-*-*, x86_64-*-*): Add popcntintrin.h. + * config/i386/abmintrin.h (_mm_popcnt_u32, _mm_popcnt_u64): Moved... + * config/i386/i386-c.c (__POPCNT__): Defined. + * config/i386/popcntintrin.h: ...here. New file. + * config/i386/smmintrin.h (_mm_popcnt_u32, _mm_popcnt_u64): Moved... + Include popcntintrin.h. + * config/i386/x86intrin.h: Include popcntintrin.h when __POPCNT__ + is defined. + +2009-12-07 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/i386-protos.h (ix86_expand_fma4_multiple_memory): + Removed. + * config/i386/i386.c (ix86_expand_fma4_multiple_memory): Removed. + * config/i386/sse.md: Remove all XOP splitters. + Allow the second and fourth operands of XOP multiply-add insns + to be nonimmediate. + +2009-12-07 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/sse.md: Remove all FMA4 splitters. + Allow the second operand of FMA4 insns to be a nonimmediate. + Fix comments punctuation. + +2009-12-07 Julian Brown <julian@codesourcery.com> + + * config/arm/constraints.md (Ps, Pt): New constraint letters. + * config/arm/thumb2.md (*thumb2_addsi_short): Tighten constraints. + +2009-12-07 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + PR other/40302 + * configure.ac (HAVE_mpc): Don't define. + * config.in, configure: Regenerate. + + PR other/40302 + * builtins.c: Remove HAVE_mpc* checks throughout. + * fold-const.c: Likewise. + * real.h: Likewise. + * toplev.c: Likewise. + +2009-12-07 Edmar Wienskoski <edmar@freescale.com> + + * config.gcc (cpu_is_64bit): Add new core e500mc64. + (powerpc*-*-*): Add new core e500mc64. + * config/rs6000/e500mc64.md: New file. + * config/rs6000/rs6000.c (processor_costs): Add new costs for + e500mc64. + (rs6000_override_options): Add e500mc64 case to + processor_target_table. Altivec and Spe options not allowed with + e500mc64. Disable string instructions for e500mc64. Enable branch + targets alignment for both e500mc and e500mc64. Initialize + rs6000_cost for e500mc64. + (rs6000_emit_sISEL): New function. + (rs6000_emit_sCOND): Call rs6000_emit_sISEL for isel targets. + (rs6000_emit_int_cmove): Fix mode of 64 bit isel pattern + generation. + (rs6000_issue_rate): Set issue rate for e500mc64. + (rs6000_rtx_costs): Set more accurate cost for mfcr instruction + on architectures with isel. + * config/rs6000/rs6000-protos.h (rs6000_emit_sISEL): Declare. + * config/rs6000/rs6000.h (processor_type): Add + PROCESSOR_PPCE500MC64. + (ASM_CPU_SPEC): Add e500mc64. + * config/rs6000/rs6000.md (define_attr "cpu"): Add ppce500mc64. + Include e500mc64.md. + (abssi2_isel): Expand pattern to handle DImode. + (nabs<mode>2_isel): New pattern. + (absdi2): Change pattern to handle 64 bit isel targets. + (absdi2_internal): Exclude ISEL targets. + (nabsdi2): Exclude ISEL targets. + * doc/invoke.texi: Add e500mc64 to list of cpus. + +2009-12-07 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (any_or): New code iterator. + (any_logic): Rename from plogic code iterator. + (logicprefix): Rename from plogicprefix code attribute. + (<code><mode>3): Macroize expander from {ior,xor}<mode>3 using + any_or code iterator. + (*<code><mode>_1): Macroize insn from *{ior,xor}<mode>_1 using + any_or code iterator. + (*<code><mode>_2): Ditto from *{ior,xor}<mode>_2. + (*<code><mode>_3): Ditto from *{ior,xor}<mode>_3. + (ior and xor splitters): Ditto. + * config/i386/mmx.md: Updated for rename. + * config/i386/sse.md: Ditto. + +2009-12-07 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (float<SSEMODEI24:mode><X87MODEF:mode>2): + Remove quotes around condition logic code. + +2009-12-06 Richard Henderson <rth@redhat.com> + + PR debug/42234 + * tree-ssa-dom.c (degenerate_phi_result): Check for NULL phi + argument earlier. + +2009-12-06 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * doc/install.texi: Document MPC is required. + +2009-12-06 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (g): Add HImode and QImode. + (general_szext_operand): New mode attribute. + (*test<mode>_1): Macroize insn from *test{qi,hi,si}_1 using + SWI124 mode iterator. + (and<mode>3): Macroize expander from and{qi,hi,si,di}3 using + SWIM mode iterator. + (*and<mode>_2): Macroize insn from *and{qi,hi,si}_2 using + SWI124 mode iterator. + (ior<mode>3): Macroize expander from ior{qi,hi,si,di}3 using + SWIM mode iterator. + (*ior<mode>_1): Macroize insn from *ior{hi,si,di}_1 using + SWI248 mode iterator. + (*ior<mode>_2): Macroize insn from *ior{qi,hi,si,di}_2 using + SWI mode iterator. + (*ior<mode>_3): Macroize insn from *ior{qi,hi,si,di}_3 using + SWI mode iterator. + (xor<mode>3): Macroize expander from xor{qi,hi,si,di}3 using + SWIM mode iterator. + (*xor<mode>_1): Macroize insn from *xor{hi,si,di}_1 using + SWI248 mode iterator. + (*xor<mode>_2): Macroize insn from *xor{qi,hi,si,di}_2 using + SWI mode iterator. + (*xor<mode>_3): Macroize insn from *xor{qi,hi,si,di}_3 using + SWI mode iterator. + +2009-12-05 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/i386.c (TARGET_DEFAULT_TARGET_FLAGS): Add + MASK_FUSED_MADD. + * config/i386/i386.h (CC1_CPU_SPEC_1): Remove + "'-mfused-madd' was removed". + * config/i386/i386.opt (mfused-madd): New. + * config/i386/sse.md: Add TARGET_FUSED_MADD to FMA4 insns. + * doc/invoke.texi (-mfused-madd, -mno-fused-madd): Document. + +2009-12-05 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa64-hpux.h (LIB_SPEC): Handle -rdynamic. + * pa-hpux10.h (LIB_SPEC): Likewise. + * pa-hpux11.h (LIB_SPEC): Likewise. + + PR ada/41912 + * pa/linux-unwind.h (pa32_fallback_frame_state): Set fs->signal_frame + for signal frames. + * pa/hpux-unwind.h (pa32_fallback_frame_state): Likewise. + +2009-12-05 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * configure: Regenerate. + +2009-12-05 Richard Earnshaw <rearnsha@arm.com> + + * arm/thumb2.md (thumb2_mulsi_short_compare0): Use a low-register + for the scratch. + +2009-12-04 David Daney <ddaney@caviumnetworks.com> + + PR rtl-optimization/42164 + * combine.c (combine_simplify_rtx): Handle truncation of integer + constants. + +2009-12-04 Richard Guenther <rguenther@suse.de> + + * lto-streamer-out.c (pack_ts_decl_common_value_fields): + Revert previous change. + (lto_output_ts_decl_common_tree_pointers): Stream DECL_VALUE_EXPR. + * lto-streamer-in.c (lto_input_ts_decl_common_tree_pointers): + Likewise. + +2009-12-04 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Handle + BUILT_IN_MALLOC. + (call_may_clobber_ref_p_1): Likewise. + +2009-12-04 Matthias Klose <doko@ubuntu.com> + John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + PR target/40134 + * config.gcc (hppa*-*-linux*): Use config/t-slibgcc-libgcc. + * config/pa/pa-linux.h (LIB_SPEC): Remove. + +2009-12-03 Sebastian Pop <sebastian.pop@amd.com> + Richard Henderson <rth@redhat.com> + + * config/i386/i386-protos.h (ix86_fma4_valid_op_p): Remove. + * config/i386/i386.c (ix86_fma4_valid_op_p): Remove. + * config/i386/i386.md: Do not use ix86_fma4_valid_op_p. + * config/i386/sse.md (fma4_*): Remove alternative with operand 1 + matching a memory access. Do not use ix86_fma4_valid_op_p. + (xop_*): Same. + Do not use ix86_fma4_valid_op_p in FMA4 and XOP splitters. + +2009-12-03 Richard Henderson <rth@redhat.com> + + * config/i386/i386.c (ix86_fixup_binary_operands): For FMA4, force + all operands into registers. + +2009-12-03 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/i386.c (ix86_expand_fma4_multiple_memory): Remove unused + parameter. + * config/i386/i386-protos.h (ix86_expand_fma4_multiple_memory): Same. + * config/i386/sse.md: Same. + +2009-12-03 Richard Guenther <rguenther@suse.de> + + * cgraphunit.c (assemble_thunk): Use DECL_ASSEMBLER_NAME + instead of DECL_NAME for the entry point. + +2009-12-03 Richard Earnshaw <rearnsha@arm.com> + + * arm/linux-atomic.c (SYNC_LOCK_RELEASE): Place memory barrier + before the lock release. + +2009-12-03 Michael Matz <matz@suse.de> + + PR middle-end/38474 + * cfgexpand.c (struct stack_var): Add conflicts member. + (stack_vars_conflict, stack_vars_conflict_alloc, + n_stack_vars_conflict): Remove. + (add_stack_var): Initialize conflicts member. + (triangular_index, resize_stack_vars_conflict): Remove. + (add_stack_var_conflict, stack_var_conflict_p): Rewrite in + terms of new member. + (union_stack_vars): Only run over the conflicts. + (partition_stack_vars): Remove special case. + (expand_used_vars_for_block): Don't call resize_stack_vars_conflict, + don't create self-conflicts. + (account_used_vars_for_block): Don't create any conflicts. + (fini_vars_expansion): Free bitmaps, don't free or clear removed + globals. + +2009-12-03 Bernd Schmidt <bernd.schmidt@analog.com> + + PR middle-end/42202 + * regrename.c (live_in_chains): New variable. + (verify_reg_tracked): New static function. + (scan_rtx_reg): Update live_in_chains. + (scan_rtx): Only promote sets in COND_EXEC to OP_INOUT if + we're already tracking the reg. + (build_def_use): Likewise. Initialize live_in_chains. + +2009-12-03 Ken Werner <ken.werner@de.ibm.com> + + * config/spu/spu-elf.h (STARTFILE_SPEC): Add support for gprof + startup files. + * config/spu/spu-protos.h (spu_function_profiler): Add prototype. + * config/spu/spu.c (spu_function_profiler): New function. + * config/spu/spu.h (FUNCTION_PROFILER): Invoke + spu_function_profiler. + (NO_PROFILE_COUNTERS): Define. + (PROFILE_BEFORE_PROLOGUE): Likewise. + +2009-12-03 Dave Korn <dave.korn.cygwin@gmail.com> + + * ggc-page.c (struct free_object): Pull definition out ... + (struct globals): .. from here. + +2009-12-02 Richard Guenther <rguenther@suse.de> + + * fold-const.c (div_if_zero_remainder): Honor that sizetypes + are sign-extending. Simplify. + +2009-12-02 Richard Henderson <rth@redhat.com> + + PR tree-opt/42215 + * tree-loop-distribution.c (build_size_arg_loc): Tidy. + (generate_memset_zero): Convert to sizetype properly. Tidy. + +2009-12-02 Richard Guenther <rguenther@suse.de> + + * lto-streamer-out.c (pack_ts_decl_common_value_fields): + Do not pretend we have value exprs. + +2009-12-02 Richard Guenther <rguenther@suse.de> + + PR middle-end/41491 + * fold-const.c (try_move_mult_to_index): Do not leak + domain types into the IL. + +2009-12-02 Richard Guenther <rguenther@suse.de> + + PR middle-end/42088 + * tree.c (free_lang_data): Disable if not using LTO. + +2009-12-02 Richard Guenther <rguenther@suse.de> + + PR middle-end/42229 + * cfgloopmanip.c (remove_path): Avoid cancelling loops twice. + +2009-12-02 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + PR middle-end/42224 + * tree.h (int_or_pointer_precision): Remove. + * tree.c (int_or_pointer_precision): Remove. + (integer_pow2p): Use TYPE_PRECISION instead. + (tree_log2): Likewise. + (tree_floor_log2): Likewise. + (signed_or_unsigned_type_for): Likewise. + * fold-const.c (fit_double_type): Likewise. + * varasm.c (initializer_constant_valid_p): Likewise. + +2009-12-02 Ira Rosen <irar@il.ibm.com> + + * doc/invoke.texi (-fdump-tree-slp): Document. + (-ftree-vectorizer-verbose): Update. + (-ftree-slp-vectorize): Document. + +2009-12-02 Nick Clifton <nickc@redhat.com> + + * config/rx/rx.c (rx_conditional_register_usage): Do not warn if + no fixed registers are available for interrupt handlers. Do not + fix normal registers. + (MUST_SAVE_ACC_REGISTER): New macro. + (rx_get_stack_layout): Create a stack frame for fast interrupt + handlers, if necessary. Push extra registers if needed in order + to save the accumulator. + (rx_expand_prologue): Create a stack frame for fast interrupt + handlers, if necessary. + (rx_expand_builtin_mvfc): Handle the case where there is no target. + +2009-12-01 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/abmintrin.h (__lzcnt16): New. + (__lzcnt): New. + (__lzcnt64): New. + * config/i386/i386-builtin-types.def (UINT16_FTYPE_UINT16): New. + * config/i386/i386.c (IX86_BUILTIN_CLZS): New. + (bdesc_special_args): Add __builtin_clzs. + (ix86_expand_args_builtin): Handle UINT16_FTYPE_UINT16. + +2009-12-01 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/abmintrin.h (_mm_popcnt_u32): New. + (_mm_popcnt_u64): New. + +2009-12-01 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/abmintrin.h: New. + * config/i386/i386-c.c (ix86_target_macros_internal): Defined __ABM__. + * config/i386/x86intrin.h: Include abmintrin.h when __ABM__ is defined. + +2009-12-01 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (SWI124): Rename from CRC32MODE. + (crc32modesuffix): Remove. + (crc32modeconstraint): Ditto. + (sse4_2_crc32<mode>): Update for renamed mode iterator. Use + imodesuffix instead of crc32modesuffix and <r>m instead of + crc32modeconstraint. + +2009-12-01 Jakub Jelinek <jakub@redhat.com> + + PR c++/42234 + * tree-cfgcleanup.c (cleanup_omp_return): Don't ICE if control_bb + contains no statements. + +2009-12-01 Grigori Fursin <grigori.fursin@inria.fr> + Joern Rennecke <amylaar@spamcop.net> + + * cgraphunit.c (plugin.h): Include. + (ipa_passes): Invoke PLUGIN_ALL_IPA_PASSES_START / + PLUGIN_ALL_IPA_PASSES_END at start / end of processing. + * gcc-plugin.h (highlev-plugin-common.h, hashtab.h): Include. + (enum plugin_event): Define by including plugin.def. + Last enumerator is now called PLUGIN_EVENT_FIRST_DYNAMIC. + (plugin_event_name): Change type to const char **. + (get_event_last, get_named_event_id, unregister_callback): Declare. + (register_callback): Change type of event argument to int. + (highlev-plugin-common.h): New file. + * Makefile.in (GCC_PLUGIN_H): Add highlev-plugin-common.h and + $(HASHTAB_H) + (tree-optimize.o passes.o): Depend on $(PLUGIN_H). + (PLUGIN_HEADERS): Add opts.h, $(PARAMS_H) and plugin.def. + (s-header-vars): New rule. + (install-plugin): Depend on s-header-vars. Install b-header-vars. + * params.c (get_num_compiler_params): New function. + * params.h (get_num_compiler_params): Declare. + * passes.c (plugin.h): Include. + (make_pass_instance): Invoke PLUGIN_NEW_PASS. + (do_per_function_toporder, pass_init_dump_file): No longer static. + (pass_fini_dump_file): Likewise. + (execute_one_pass): Likewise. Invoke PLUGIN_OVERRIDE_GATE and + PLUGIN_PASS_EXECUTION. + (execute_ipa_pass_list): Invoke PLUGIN_EARLY_GIMPLE_PASSES_START and + PLUGIN_EARLY_GIMPLE_PASSES_END. + * plugin.c (plugin_event_name_init): New array, defined by + including plugin.def. + (FMT_FOR_PLUGIN_EVENT): Update. + (plugin_event_name): Change type to const char ** and initialize + to plugin_event_name_init. + (event_tab, event_last, event_horizon): New variable. + (get_event_last): New function. + (plugin_callbacks_init): New array. + (plugin_callbacks: Change type to struct callback_info **. + Initialize to plugin_callbacks_init. + (htab_event_eq, get_named_event_id, unregister_callback): New function. + (invoke_plugin_va_callbacks): Likewise. + (register_callback): Change type of event argument to int. + Handle new events. Allow dynamic events. + (invoke_plugin_callbacks): Likewise. Return success status. + (plugins_active_p): Allow dynamic callbacks. + * plugin.def: New file. + * plugin.h (invoke_plugin_callbacks): Update prototype. + (invoke_plugin_va_callbacks): Declare. + * tree-optimize.c (plugin.h): Include. + (tree_rest_of_compilation): Invoke PLUGIN_ALL_PASSES_START and + PLUGIN_ALL_PASSES_END. + * tree-pass.h (execute_one_pass, pass_init_dump_file): Declare. + (pass_fini_dump_file, do_per_function_toporder): Likewise. + * doc/plugin.texi: Document new event types. + +2009-12-01 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/42237 + * tree-sra.c (sra_ipa_modify_assign): Split gimple_reg_type assignments + in between references into two. + +2009-12-01 Richard Guenther <rguenther@suse.de> + + * tree-inline.c (copy_tree_body_r): Do not set TREE_BLOCK + to the block of the call when remapping a type. + +2009-12-01 Martin Jambor <mjambor@suse.cz> + + * cgraph.h (struct cgraph_edge): Reorder fields. Make loop_nest + unsigned short int. + * ipa-prop.h (struct ipa_param_call_note): Likewise. + * ipa-prop.c (ipa_note_param_call): Initialize note->loop_nest. + +2009-12-01 Richard Guenther <rguenther@suse.de> + + * final.c (rest_of_clean_state): If -fcompare-debug is + given dump final insns without UIDs. + * tree-ssa-live.c (remove_unused_scope_block_p): Remove + after_inlining checks. + +2009-11-30 Chao-ying Fu <fu@mips.com> + + * config/mips/mips-dsp.md (mips_lhx_<mode>): Use sign_extend. + +2009-11-30 Dave Korn <dave.korn.cygwin@gmail.com> + + * configure.ac (USE_CYGWIN_LIBSTDCXX_WRAPPERS): Define to reflect + status of AC_CHECK_FUNC for Cygwin DLL libstdc++ support wrappers. + * configure: Regenerate. + * config.in: Regenerate. + + * config/i386/cygwin.h (CXX_WRAP_SPEC_LIST): Define list of --wrap + options for Cygwin DLL libstdc++ support wrappers. + (CXX_WRAP_SPEC_OPT): Define spec to use wrappers or not by default + according to defined value of USE_CYGWIN_LIBSTDCXX_WRAPPERS. + (CXX_WRAP_SPEC): Define entire wrapper spec in or out according to + whether USE_CYGWIN_LIBSTDCXX_WRAPPERS is even defined or not. + (LINK_SPEC): Include CXX_WRAP_SPEC. + * gcc/config/i386/winnt.c (wrapper_strcmp): New qsort helper function. + (i386_find_on_wrapper_list): Check if a function is found on the list + of libstdc++ wrapper options. + (i386_pe_file_end): If we are importing a wrapped function, also emit + an external declaration for the real version. + * config/i386/cygming.opt (muse-libstdc-wrappers): New option for + Cygwin targets. Update copyright year. + +2009-11-30 Steve Ellcey <sje@cup.hp.com> + Jakub Jelinek <jakub@redhat.com> + + * function.c (instantiate_virtual_regs_in_insn): Copy to new reg + before forcing mode. + +2009-11-30 Anatoly Sokolov <aesok@post.ru> + + * config/sh/sh.c (sh_promote_prototypes): Make static. + (sh_function_value, sh_libcall_value, sh_function_value_regno_p): New + functions. + (TARGET_FUNCTION_VALUE, TARGET_LIBCALL_VALUE): Declare. + * config/sh/sh.h (FUNCTION_VALUE_REGNO_P): Redefine, use + sh_function_value_regno_p. + (FUNCTION_VALUE, LIBCALL_VALUE): Remove. + * config/sh/sh-protos.h (sh_function_value_regno_p): Declare. + (sh_promote_prototypes) : Remove. + +2009-11-30 Julian Brown <julian@codesourcery.com> + + * config/arm/arm.h (PREFERRED_RELOAD_CLASS): Don't restrict Thumb-2 + reloads to LO_REGS. + +2009-11-30 Richard Henderson <rth@redhat.com> + + * config/i386/i386.c (ix86_vec_interleave_v2df_operator_ok): New. + (bdesc_special_args): Update insn codes. + (avx_vpermilp_parallel): Correct range check. + (ix86_rtx_costs): Handle vector permutation rtx codes. + (struct expand_vec_perm_d): Move earlier. + (get_mode_wider_vector): New. + (expand_vec_perm_broadcast_1): New. + (ix86_expand_vector_init_duplicate): Use it. Tidy AVX modes. + (expand_vec_perm_broadcast): New. + (ix86_expand_vec_perm_builtin_1): Use it. + * config/i386/i386-protos.h: Update. + * config/i386/predicates.md (avx_vbroadcast_operand): New. + * config/i386/sse.md (AVX256MODE24P): New. + (ssescalarmodesuffix2s): New. + (avxhalfvecmode, avxscalarmode): Fill out to all modes. + (avxmodesuffixf2c): Add V8SI, V4DI. + (vec_dupv4sf): New expander. + (*vec_dupv4sf_avx): Add vbroadcastss alternative. + (*vec_set<mode>_0_avx, **vec_set<mode>_0_sse4_1): Macro-ize for + V4SF and V4SI. Move C alternatives to front. Add insertps and + pinsrd alternatives. + (*vec_set<mode>_0_sse2): Split out from ... + (vec_set<mode>_0): Macro-ize for V4SF and V4SI. + (vec_interleave_highv2df, vec_interleave_lowv2df): Require register + destination; use ix86_vec_interleave_v2df_operator_ok, instead of + ix86_fixup_binary_operands. + (*avx_interleave_highv2df, avx_interleave_lowv2df): Add movddup. + (*sse3_interleave_highv2df, sse3_interleave_lowv2df): New. + (*avx_movddup, *sse3_movddup): Remove. New splitter from + vec_select form to vec_duplicate form. + (*sse2_interleave_highv2df, sse2_interleave_lowv2df): Use + ix86_vec_interleave_v2df_operator_ok. + (avx_movddup256, avx_unpcklpd256): Change to expanders, merge into ... + (*avx_unpcklpd256): ... here. + (*vec_dupv4si_avx): New. + (*vec_dupv2di_avx): Add movddup alternative. + (*vec_dupv2di_sse3): New. + (vec_dup<AVX256MODE24P>): Replace avx_vbroadcasts<AVXMODEF4P> and + avx_vbroadcastss256; represent with vec_duplicate instead of + nested vec_concat operations. + (avx_vbroadcastf128_<mode>): Rename from + avx_vbroadcastf128_p<avxmodesuffixf2c>256. + (*avx_vperm_broadcast_v4sf): New. + (*avx_vperm_broadcast_<AVX256MODEF2P>): New. + +2009-11-30 Martin Jambor <mjambor@suse.cz> + + PR middle-end/42196 + * tree-sra.c (struct access): New field grp_different_types. + (dump_access): Dump grp_different_types. + (compare_access_positions): Prefer scalars and vectors over other + scalar types. + (sort_and_splice_var_accesses): Set grp_different_types if appropriate. + (sra_modify_expr): Use the original also when dealing with a complex + or vector group accessed as multiple types. + +2009-11-30 Richard Henderson <rth@redhat.com> + + * config/i386/i386.c (avx_vperm2f128_parallel): New. + * config/i386/i386-protos.h: Declare it. + * config/i386/predicates.md (avx_vperm2f128_v8sf_operand, + avx_vperm2f128_v8si_operand, avx_vperm2f128_v4df_operand): New. + * config/i386/sse.md (avx_vperm2f128<mode>3): Change to expander. + (*avx_vperm2f128<mode>_full): Renamed from avx_vperm2f128<mode>3. + (*avx_vperm2f128<mode>_nozero): New. + +2009-11-30 Richard Henderson <rth@redhat.com> + + * config/i386/i386-builtin-types.def (V4DF_FTYPE_V4DF_V4DF_V4DI): New. + (V8SF_FTYPE_V8SF_V8SF_V8SI): New. + * config/i386/i386.c (ix86_vectorize_builtin_vec_perm): Support + V4DF and V8SF for AVX; relax constraint on V4SF to SSE1 from SSE2. + (IX86_BUILTIN_VEC_PERM_V4DF, IX86_BUILTIN_VEC_PERM_V8SF): New. + (bdesc_args): Add them. + (ix86_expand_builtin): Expand them. + (expand_vec_perm_pshufb2): Only operate on 16-byte vectors. + +2009-11-30 Martin Jambor <mjambor@suse.cz> + + PR middle-end/42206 + * ipa-prop.c (ipa_write_node_info): Initialize note_count to zero. + +2009-11-30 Jakub Jelinek <jakub@redhat.com> + + * ipa-reference.c (propagate): Only dump bitmaps if computed. + +2009-11-30 Olga Golovanevsky <olga@il.ibm.com> + + PR middle-end/39806 + * ipa-struct-reorg.c (new_var_eq): Use DECL_UID to hash new variables. + (new_var_hash): Likewise. + (is_in_new_vars_htab): Likewise. + (add_to_new_vars_htab): Likewise. + +2009-11-30 Ira Rosen <irar@il.ibm.com> + + * tree-vect-stmts.c (vectorizable_assignment): Support + multiple types. + +2009-11-30 Richard Guenther <rguenther@suse.de> + + * doc/contrib.texi (Contributors): Add myself. + +2009-11-30 Richard Guenther <rguenther@suse.de> + + * tree.c (free_lang_data): Do not set debug_info_level to + none if terse. + +2009-11-30 Richard Guenther <rguenther@suse.de> + + PR middle-end/42119 + PR fortran/38530 + * expr.c (expand_expr_addr_expr_1): Properly expand the initializer + of CONST_DECLs. + +2009-11-30 Richard Guenther <rguenther@suse.de> + + * tree-into-ssa.c (insert_phi_nodes): Add PHI nodes in + variable UID order. + +2009-11-30 Richard Guenther <rguenther@suse.de> + + * tree-dump.c (dump_option_value_in): Add TDF_NOUID. + * tree-pass.h (TDF_NOUID): Likewise. + * print-rtl.c: Include tree-pass.h. + (print_mem_expr): Pass dump_flags. + (print_rtx): Likewise. + * print-tree.c: Include tree-pass.h. + (print_node_brief): Handle TDF_NOUID. + (print_node): Likewise. + * tree-pretty-print.c (dump_decl_name): Likewise. + (dump_generic_node): Likewise. + * Makefile.in (print-rtl.o, print-tree.o): Add $(TREE_PASS_H) + dependency. + +2009-11-30 Nick Clifton <nickc@redhat.com> + + * config/stormy16/stormy16-lib2-count-leading-zeros.c: Delete. + * config/stormy16/t-stormy16 (LIB2FUNCS_EXTRA): Remove + stormy16-lib2-count-leading-zeros.c. + * config/stormy16/stormy16-lib2.c (__clzhi2): Move code from + __stormy16_count_leading_zeros() into this function. + (__ctzhi2): Use __builtin_clz. + (__ffshi2): Likewise. + +2009-11-30 Eric Botcazou <ebotcazou@adacore.com> + + * config/sparc/sparc.c (DF_MODES): Simplify. + (TF_ONLY_MODES, OF_ONLY_MODES): Delete. + (TF_MODES, OF_MODES): Adjust for above change. + (TF_MODES_NO_S, OF_MODES_NO_S): Likewise. + * config/sparc/sparc.h (REGNO_REG_CLASS): Move around. + +2009-11-30 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/41812 + * fwprop.c (local_md, local_lr): New globals. + (process_defs, process_uses): Remove local_md argument. Never + consider dead pseudos to have singleton def-use chains. + (single_def_use_enter_block): Perform LR simulation. + (build_single_def_use_links): Remove local_md local variable. + Add DF_NOTE. Allocate local_lr. + (fwprop_done): Do not remove DF_CHAIN, we do not use it anymore. + * df-problems.c (df_md_scratch): New. + (df_md_alloc, df_md_free): Allocate/free it. + (df_md_local_compute): Only include live registers in init. + (df_md_transfer_function): Prune the in-set computed by + the confluence function, and the gen-set too. + +2009-11-30 Hans-Peter Nilsson <hp@axis.com> + + PR rtl-optimization/40086 + * reorg.c (relax_delay_slots): When looking for redundant insn at + the branch target, use next_real_insn, not next_active_insn. + +2009-11-30 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * doc/install.texi: Update minimum MPC version to 0.8. + +2009-09-09 Segher Boessenkool <segher@kernel.crashing.org> + + * config/rs6000/rs6000.md (fnmaddsf4_powerpc_1): Remove + HONOR_SIGNED_ZEROS final condition. + (fnmsubsf4_powerpc_1): Same. + (fnmadddf4_fpr_1): Same. + (fnmsubdf4_fpr_1): Same. + +2009-11-29 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/42193 + * tree-vect-stmts.c (vectorizable_operation): Set vectorization factor + to 1 in case of basic block SLP. + (vectorizable_load): Likewise. + +2009-11-28 Jan Hubicka <jh@suse.cz> + + * cgraph.c (same_body_alias_1): Break out of + (same_body_alias): ... here; remove comdat check; it is handled + in cp already. + (cgraph_add_thunk): New. + (dump_cgraph_node): Dump aliases and thunks. + * cgraph.h (cgraph_thunk_info): New structure. + (struct cgraph_node): Add thunk info. + (cgraph_add_thunk): New. + * cgraphunit.c (cgraph_emit_thunks): Remove. + (cgraph_finalize_compilation_unit): Do not call cgraph_emit_thunks. + (assemble_thunk): New function. + (cgraph_expand_function): Handle thunks. + (thunk_adjust): New. + (init_lowered_empty_function): New. + * cp-objcp-common.h (LANG_HOOKS_CALLGRAPH_EMIT_ASSOCIATED_THUNKS): + Remove. + * lto-cgraph.c (lto_output_node): Stream thunk info. + (input_node): Likewise. + * langhooks.h (lang_hooks_for_callgraph): Remove emit_associated_thunks. + * langhooks-def.h (LANG_HOOKS_CALLGRAPH_EMIT_ASSOCIATED_THUNKS): Remove. + (LANG_HOOKS_CALLGRAPH_INITIALIZER): Update. + * i386.c (x86_output_mi_thunk): Make output prettier. + +2009-11-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/42183 + * tree-nrv.c (tree_nrv): Bail out if the RESULT_DECL has its + address taken. Merge the addressable state of the NRV + variable and the result instead of copying it. + +2009-11-28 Jakub Jelinek <jakub@redhat.com> + + * matrix-reorg.c (analyze_matrix_allocation_site): Remove unused + malloc_fname variable. + (check_allocation_function): Remove unused gsi and bb_level_0 + variables. + (transform_access_sites): Remove unused d_type_size and d_type_size_k + variables. + * omega.c (resurrect_subs): Remove unused n variable. + (omega_solve_geq): Remove unused neweqns variable. + * lto-streamer-in.c (lto_read_tree): Remove unused end_marker variable. + * tree-inline.c (declare_return_variable): Remove USE_P argument, + return use instead of var. + (remap_decl, remap_block): Remove unused fn variable. + (expand_call_inline): Remove unused retvar variable, adjust + declare_return_variable caller. + (optimize_inline_calls): Remove unused prev_fn variable. + * tree-vect-slp.c (vect_analyze_slp_instance): Remove unused ncopies + variable. + (vect_create_mask_and_perm): Remove unused group_size and dr_chain_size + variables. + * tree-ssa-loop-niter.c (split_to_var_and_offset): Handle MINUS_EXPR + properly. + * tree-vect-loop.c (vect_analyze_loop_form): Remove unused backedge + variable. + (vect_create_epilog_for_reduction): Remove unused bytesize variable. + * omp-low.c (workshare_safe_to_combine_p): Remove par_entry_bb + parameter. Remove unused par_stmt variable. + (determine_parallel_type): Adjust workshare_safe_to_combine_p caller. + (expand_omp_sections): Remove unused l1 variable. + (lower_omp_for): Remove unused ilist variable. + * tree-loop-distribution.c (mark_nodes_having_upstream_mem_writes): + Remove unused has_upstream_mem_write_p variable. + * recog.c (decode_asm_operands): Remove unused noperands variable. + * tree-ssa-alias.c (refs_may_alias_p_1): Remove unused size1 and + size2 variable. + * libgcov.c (__gcov_merge_delta): Remove unused last variable. + * tree-call-cdce.c (gen_conditions_for_pow_int_base): Remove unused + base_nm variable. + (gen_conditions_for_pow): Remove unused ec variable. + * tree-ssa-sccvn.c (vn_reference_lookup_3): Remove unused size + variable. + * ipa-struct-reorg.c (program_redefines_malloc_p): Remove unused + fndecl variable. + * tree-ssa-sink.c (statement_sink_location): Remove unused code + variable. + * regmove.c (copy_src_to_dest): Remove unused insn_uid and move_uid + variables. + * tree-complex.c (create_one_component_var): Remove unused inner_type + variable. + * calls.c (emit_call_1): Don't GEN_INT (struct_value_size) + unnecessarily when GEN_*CALL omits that argument. + * regrename.c (regrename_optimize): Remove unused regs_seen variable. + (build_def_use): Remove unused icode variable. + * ipa-pure-const.c (check_call): Remove unused callee and avail + variables. + * tree-dfa.c (add_referenced_var): Remove unused v_ann variable. + * tree-vect-patterns.c (vect_recog_pow_pattern): Remove unused type + variable. + (vect_pattern_recog): Remove unused stmt variable. + * sel-sched-ir.c (make_regions_from_the_rest): Remove unused + new_regions variable. + * postreload.c (reload_cse_simplify_operands): Remove unused mode + variable. + * tree-parloops.c (create_call_for_reduction_1): Remove unused + addr_type variable. + (create_parallel_loop): Remove unused res variable. + (gen_parallel_loop): Remove unused nloop variable. + * tree-vect-loop-manip.c (vect_loop_versioning): Likewise. + * value-prof.c (gimple_mod_subtract_transform, + gimple_stringops_transform): Remove unused value variable. + (gimple_stringops_values_to_profile): Remove unused fcode variable. + * tree-vrp.c (register_new_assert_for): Remove unused found variable. + (vrp_visit_switch_stmt): Remove unused n variable. + * tree-vect-stmts.c (vectorizable_conversion): Remove unused expr + variable. + (vectorizable_operation): Remove unused shift_p variable. + (vectorizable_store): Remove unused first_stmt_vinfo variable. + * tree-ssa-operands.c (add_stmt_operand): Remove unused v_ann variable. + * tree-vect-data-refs.c (vect_analyze_data_refs): Remove unused bb + variable. + (vect_permute_store_chain): Remove unused scalar_dest variable. + (vect_supportable_dr_alignment): Remove unused invariant_in_outerloop + variable. + * tree-ssa-threadupdate.c (thread_single_edge): Remove unused + local_info variable. + * tree-optimize.c (tree_rest_of_compilation): Remove unused node + variable. + * optabs.c (expand_binop): Remove unused equiv_value variable. + (emit_libcall_block): Remove unused prev variable. + (init_optabs): Remove unused int_mode variable. + * tree-ssa-structalias.c (scc_visit): Remove unused have_ref_node + variable. + (do_structure_copy): Remove unused lhsbase and rhsbase variables. + (find_func_aliases): Remove unused rhstype variable. + (ipa_pta_execute): Remove unused varid variable. + +2009-11-28 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + * config/avr/avr.h (ASM_OUTPUT_EXTERNAL): Add. + +2009-11-28 David Binderman <dcb314@hotmail.com> + + * ira-color.c (put_allocno_into_bucket): Remove set but not used + local variable hard_regs_num. + * ira-lives.c (process_single_reg_class_operands): Remove cover_class. + * loop-unswitch.c (unswitch_loop): Remove zero_bitmap. + * lower-subreg.c (decompose_multiword_subregs): Remove next. + +2009-11-27 Martin Jambor <mjambor@suse.cz> + + PR middle-end/42006 + * tree-sra.c (get_replaced_param_substitute): Call create_tmp_var + instead of create_tmp_var. Set DECL_GIMPLE_REG_P to one manually + for vector and complex types. + (get_adjustment_for_base): Describe return value in the comment. + +2009-11-27 Nick Clifton <nickc@redhat.com> + + * longlong.h (count_leading_zeros): Define macro for stormy16 target. + (COUNT_LEADING_ZEROS_0): Likewise. + * config/stormy16/stormy16-lib2.c: Arrange for separate + compilation of each function. + (__ffshi2): New function. + (__stormy16_count_leading_zeros): New function. + * config/stormy16/t-stormy16 (LIB2FUNCS_EXTRA): Use stub files to + compile each function into its own object file. + (stormy16-lib2-ashlsi3.c): New stub file. + (stormy16-lib2-ashrsi3.c): New stub file. + (stormy16-lib2-clzhi2.c): New stub file. + (stormy16-lib2-count-leading-zeros.c): New stub file. + (stormy16-lib2-ctzhi2.c): New stub file. + (stormy16-lib2-divsi3.c): New stub file. + (stormy16-lib2-ffshi2.c): New stub file. + (stormy16-lib2-lshrsi3.c): New stub file. + (stormy16-lib2-modsi3.c): New stub file. + (stormy16-lib2-parityhi2.c): New stub file. + (stormy16-lib2-popcounthi2.c): New stub file. + (stormy16-lib2-udivmodsi4.c): New stub file. + (stormy16-lib2-udivsi3.c): New stub file. + (stormy16-lib2-umodsi3.c): New stub file. + +2009-11-27 Richard Henderson <rth@redhat.com> + + * config/i386/sse.md (vec_interleave_highv16qi, + vec_interleave_lowv16qi, vec_interleave_highv8hi, + vec_interleave_lowv8hi, vec_interleave_highv4si, + vec_interleave_lowv4si, vec_interleave_highv2di, + vec_interleave_lowv2di, vec_interleave_highv4sf, + vec_interleave_lowv4sf, vec_interleave_highv2df, + vec_interleave_lowv2df): Remove expanders. + (sse_unpcklps, sse_unpckhps, sse2_unpckhpd_exp, sse2_unpcklpd_exp, + sse2_punpckhqdq, sse2_punpcklqdq, sse2_punpckhbw, sse2_punpcklbw, + sse2_punpckhwd, sse2_punpcklwd, sse2_punpckhdq, sse2_punpckldq): + Rename to their proper vec_interleave equivalent. Update all users + to the new name. + * config/i386/i386.c, config/i386/i386.md: Update all users. + +2009-11-27 Michael Matz <matz@suse.de> + + PR rtl-optimization/42084 + * cfgexpand.c (maybe_cleanup_end_of_block): Add new parameter, + use it to stop walking. + (expand_gimple_cond): Adjust call to above. + +2009-11-27 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + + PR target/41810 + * gthr-solaris.h (__gthread_mutex_destroy): Remove UNUSED. + [SUPPORTS_WEAK && GTHREAD_USE_WEAK] (__gthread_active_p): Use + __extension__ to allow cast from function pointer to object + pointer in C++. + * doc/install.texi (--enable-threads): Clarify use of Solaris threads. + +2009-11-27 Steven Bosscher <steven@gcc.gnu.org> + + * config/ia64/itanium1.md: Remove. + * config/ia64/ia64.md: Do not include it. + * config/ia64/ia64.c (ia64_handle_option): Remove "itanium", + "itanium1", and "merced" from the processor alias table. + (clocks, add_cycles): Remove global variables. + (ia64_sched_reorder2): Don't set/use them. + (ia64_dfa_new_cycle, ia64_h_i_d_extended, ia64_reorg): Likewise. + (bundling): Likewise. Remove extra pass for MMMUL/MMSHF. + +2009-11-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.c (last_scheduled_insn): New variable. + (s390_fpload_toreg, s390_z10_prevent_earlyload_conflicts): New + functions. + (s390_sched_reorder, s390_sched_variable_issue): New functions. + (TARGET_SCHED_VARIABLE_ISSUE, TARGET_SCHED_REORDER): Target hooks + defined. + +2009-11-27 Michael Matz <matz@suse.de> + + PR c++/41906 + * tree-eh.c (lower_catch): Stop after expanding a catch-all. + +2009-11-27 Richard Guenther <rguenther@suse.de> + + * timevar.def (TV_LOOP_MOVE_INVARIANTS, TV_LOOP_UNSWITCH, + TV_LOOP_UNROLL, TV_LOOP_DOLOOP): New timevars. + * loop-init.c (pass_rtl_move_loop_invariants): Use + TV_LOOP_MOVE_INVARIANTS. + (pass_rtl_unswitch): Use TV_LOOP_UNSWITCH. + (pass_rtl_unroll_and_peel): Use TV_LOOP_UNROLL. + (pass_rtl_doloop): Use TV_LOOP_DOLOOP. + +2009-11-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * emit-rtl.c (next_active_insn, prev_active_insn): Correct comment. + +2009-11-27 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.c (ix86_emit_restore_sse_regs_using_mov): Remove + unused insn variable. + * genemit.c (output_peephole2_scratches): Only declare and initialize + _regs_allocated if it will be ever used. + * cfgloopmanip.c (create_empty_if_region_on_edge): Remove unused + succ_bb variable. + (create_empty_loop_on_edge): Remove unused freq and cnt variables. + * unwind-c.c (PERSONALITY_FUNCTION): Remove unused action_record + variable. + + * opts.c (decode_options): If optimize is bigger than 255, + set it to 255. + +2009-11-26 Richard Henderson <rth@redhat.com> + + * config/i386/sse.md (mulv16qi3): Change back from an expander + to an insn-and-split. + (mulv4si): Mention AVX not XOP for AVX exception. + (*sse2_mulv4si3): Likewise. + (mulv2di3): Use vmulld not vpmacsdd for XOP expansion. Tidy. + +2009-11-26 Bernd Schmidt <bernd.schmidt@analog.com> + + * cfgexpand (n_stack_vars_conflict): New static variable. + (triangular_index): Reduce likelyhood of overflow by performing + the division before the multiplication. + (resize_stack_vars_conflict): Call fatal_error if overflow + occurred in triangular_index. Update n_stack_vars_conflict. + + PR rtl-opt/38582 + * regrename.c (struct du_chain): Remove member earlyclobber. + (scan_rtx_reg): Don't set it. Remove argument earlyclobber, + all callers changed. + (scan_rtx): Remove argument earlyclobber, all callers changed. + (hide_operands, restore_operands, record_out_operands): New functions, + broken out of build_def_use. + (build_def_use): Call them as necessary. + + * regrename.c (struct du_head): New members id, conflicts, + hard_conflicts and cannot_rename. + (enum scan_actions): Remove terminate_all_read and + terminate_overlapping_read; add mark_all_read. + (scan_actions_name): Likewise. + (du_head_p): New typedef. Define a vector type for it. + (id_to_chain): New static variable. + (note_sets, clear_dead_regs): Delete functions. + (free_chain_data): New function. + (merge_overlapping_regs): Simply walk the conflicts bitmap. + Remove argument B, all callers changed. + (regrename_optimize): Allocate id_to_chain. Ignore chains that have + the cannot_rename bit set. Update regno and nregs of a renamed chain. + Call free_chain_data when done. + (do_replace): Remove death notes when the renamed reg is set in the + last insn; add them if not. + (mark_conflict, note_sets_clobbers): New static function. + (fail_current_block, current_id, open_chains_set, live_hard_regs): New + static variables. + (scan_rtx_reg): Keep track of conflicts between chains, and between + chains and hard regs. Don't terminate chains when we find a read we + can't handle, mark it unrenameable instead. For terminate_write, + terminate chains that are written with an exact match or a superset + of registers. Set fail_current_block if multi-word lifetimes are too + complex to handle. + (scan_rtx_address): Use mark_all_read instead of terminate_all_read. + (build_def_use): Initialize current_id, live_chains and live_hard_regs; + free memory for them when done. + Rearrange the steps so that earlyclobbers are noted before reads + are processed. Add new steps to keep track of hard register lifetimes + outside insn operands. + +2009-11-26 Richard Guenther <rguenther@suse.de> + + * tree-ssa-dce.c (nr_walks): New variable. + (mark_aliased_reaching_defs_necessary): Adjust oracle cut-off. + (perform_tree_ssa_dce): Init nr_walks. + +2009-11-26 Michael Matz <matz@suse.de> + + PR tree-optimization/41905 + * tree-eh.c (lower_eh_constructs_2): Don't add assignments + below statements that can't fall thru. + +2009-11-26 Michael Matz <matz@suse.de> + + * builtins.c (expand_builtin_printf, expand_builtin_fprintf, + expand_builtin_sprintf): Remove. + (expand_builtin): Don't call them. + +2009-11-26 Richard Guenther <rguenther@suse.de> + + * tree-ssa-dce.c (perform_tree_ssa_dce): Allocate visited bitmap. + +2009-11-26 Nick Clifton <nickc@redhat.com> + + * config/rx/rx.c (rx_expand_epilogue): Add checks for sibcalls + being used incorrectly. + (rx_function_ok_for_sibcall): New function. Do not allow indirect + sibcalls, or sibcalls from interrupt functions. + (TARGET_FUNCTION_OK_FOR_SIBCALL): Define. + * config/rx/rx.md (sibcall): Convert to a define_expand. Check + for a MEM inside a MEM. + (sibcall_value): Likewise. + (sibcall_internal): New pattern containing old sibcall pattern. + (sibcall_value_internal): Likewise. + +2009-11-25 Richard Henderson <rth@redhat.com> + + * config/i386/i386-builtin-types.awk (DEF_VECTOR_TYPE): Allow an + optional 3rd argument to define the mode. + * config/i386/i386-builtin-types.def (UQI, UHI, USI, UDI): New. + (V2UDI, V4USI, V8UHI, V16UQI): New. + (V4SF_FTYPE_V4SF_V4SF_V4SI, V2UDI_FTYPE_V2UDI_V2UDI_V2UDI, + V4USI_FTYPE_V4USI_V4USI_V4USI, V8UHI_FTYPE_V8UHI_V8UHI_V8UHI, + V16UQI_FTYPE_V16UQI_V16UQI_V16UQI): New. + * config/i386/i386-modes.def: Rearrange for double-wide AVX. + * config/i386/i386-protos.h (ix86_expand_vec_extract_even_odd): New. + * config/i386/i386.c (IX86_BUILTIN_VEC_PERM_*): New. + (bdesc_args): Add the builtin definitions to match. + (ix86_expand_builtin): Expand them. + (ix86_builtin_vectorization_cost): Rename from + x86_builtin_vectorization_cost. + (ix86_vectorize_builtin_vec_perm, struct expand_vec_perm_d, + doublesize_vector_mode, expand_vselect, expand_vselect_vconcat, + expand_vec_perm_blend, expand_vec_perm_vpermil, + expand_vec_perm_pshufb, expand_vec_perm_1, + expand_vec_perm_pshuflw_pshufhw, expand_vec_perm_palignr, + expand_vec_perm_interleave2, expand_vec_perm_pshufb2, + expand_vec_perm_even_odd_1, expand_vec_perm_even_odd, + ix86_expand_vec_perm_builtin_1, extract_vec_perm_cst, + ix86_expand_vec_perm_builtin, ix86_vectorize_builtin_vec_perm_ok, + ix86_expand_vec_extract_even_odd, TARGET_VECTORIZE_BUILTIN_VEC_PERM, + TARGET_VECTORIZE_BUILTIN_VEC_PERM_OK): New. + * sse.md (SSEMODE_EO): New. + (vec_extract_even<mode>): Use SSEMODE_EO and + ix86_expand_vec_extract_even_odd. + (vec_extract_odd<mode>): Likewise. + (mulv16qi3, vec_pack_trunc_v8hi, vec_pack_trunc_v4si, + vec_pack_trunc_v2di): Use ix86_expand_vec_extract_even_odd. + +2009-11-25 Richard Henderson <rth@redhat.com> + + * target.h (targetm.vectorize.builtin_vec_perm_ok): New. + * target-def.h (TARGET_VECTORIZE_BUILTIN_VEC_PERM_OK): New. + * hooks.h, hooks.c (hook_bool_tree_tree_true): New. + * tree-vect-slp.c (vect_create_mask_and_perm): Don't create + the vector constant here... + (vect_transform_slp_perm_load): ... do it here instead. Validate + that the permutation vector is implementable by the target. + +2009-11-25 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/sysv4.opt (mregnames): Change Var to rs6000_regnames. + * config/rs6000/sysv4.h (TARGET_REGNAMES): Define. + + * print-rtl.c (print_rtx): When printing newline, append + print_rtx_head and indentation after the newline. + + PR target/42165 + * config/i386/i386.c (print_operand): For 32-byte memory use + YMMWORD in -masm=intel mode. Use TBYTE instead of XWORD. + * config/i386/i386.md (crc32modesuffix): Expand to nothing + in -masm=intel mode. + (sse4_2_crc32di): Print just crc32 instead of crc32q in + -masm=intel mode. + * config/i386/mmx.md (*mmx_pinsrw): Print correct size of + memory operand in -masm=intel mode. + * config/i386/sse.md (*avx_pinsr<ssevecsize>, *sse4_1_pinsrb, + *sse2_pinsrw): Likewise. + (sse_cvtss2siq, sse_cvtss2siq_2, sse_cvttss2siq): Don't print + q suffix in -masm=intel mode. + +2009-11-25 Eric Botcazou <ebotcazou@adacore.com> + + PR target/10127 + PR ada/20548 + PR middle-end/42004 + * dwarf2out.c (dwarf2out_args_size_adjust): Rename to... + (dwarf2out_stack_adjust): ...this. Do not adjust the arg size for + ACCUMULATE_OUTGOING_ARGS targets. Rename former version to... + (dwarf2out_notice_stack_adjust): ...this. Adjust for above renaming. + (dwarf2out_frame_debug_expr): Revert previous change and adjust for + above renaming. + (dwarf2out_frame_debug): Add ??? comment. Adjust for above renaming. + +2009-11-25 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/predicates.md (emms_operation): New predicate. + (vzeroupper_operation): Ditto. + (vzeroall_operation): Improve pattern recognition. + * config/i386/sse.md (avx_vzeroupper_rex64): Remove insn pattern. + (avx_vzeroupper): Change insn pattern to expander. + (*avx_vzeroupper): New insn pattern. Use vzeroupper_operation + predicate. + (*avx_vzeroall): Remove operands 1 and 2. + * config/i386/mmx.md (mmx_emms): Change insn pattern to expander. + (mmx_femms): Ditto. + (*mmx_emms): New insn pattern. Use emms_operation predicate. + (*mmx_femms): Ditto. + * config/i386/i386.c (enum ix86_builtins) + <IX86_BUILTIN_VZEROUPPER_REX64>: Remove. + (struct builtin_description) <CODE_FOR_avx_vzeroupper_rex64>: + Remove initailization. + <CODE_FOR_avx_vzeroupper>: Unconditionally initialize here. + +2009-11-25 Paul Brook <paul@codesourcery.com> + + * config/arm/arm.md (consttable_4): Handle (high ...). + +2009-11-25 Robert Nelson <robert.nelson@digikey.com> + Richard Earnshaw <rearnsha@arm.com> + + * arm.h (enum vfp_reg_type): Add VFP_NONE. + * arm.c (all_fpus): Use it for floating point units that aren't based + on the VFP architecture. + (aapcs_vfp_is_call_or_return_candidate): Make base_mode a pointer to + enum machine_mode. + +2009-11-25 H.J. Lu <hongjiu.lu@intel.com> + + * alias.c: Remove trailing white spaces. + * alloc-pool.c: Likewise. + * alloc-pool.h: Likewise. + * attribs.c: Likewise. + * auto-inc-dec.c: Likewise. + * basic-block.h: Likewise. + * bb-reorder.c: Likewise. + * bt-load.c: Likewise. + * builtins.c: Likewise. + * builtins.def: Likewise. + * c-common.c: Likewise. + * c-common.h: Likewise. + * c-cppbuiltin.c: Likewise. + * c-decl.c: Likewise. + * c-format.c: Likewise. + * c-lex.c: Likewise. + * c-omp.c: Likewise. + * c-opts.c: Likewise. + * c-parser.c: Likewise. + * c-pretty-print.c: Likewise. + * c-tree.h: Likewise. + * c-typeck.c: Likewise. + * caller-save.c: Likewise. + * calls.c: Likewise. + * cfg.c: Likewise. + * cfganal.c: Likewise. + * cfgexpand.c: Likewise. + * cfghooks.c: Likewise. + * cfghooks.h: Likewise. + * cfglayout.c: Likewise. + * cfgloop.c: Likewise. + * cfgloop.h: Likewise. + * cfgloopmanip.c: Likewise. + * cfgrtl.c: Likewise. + * cgraph.c: Likewise. + * cgraph.h: Likewise. + * cgraphbuild.c: Likewise. + * cgraphunit.c: Likewise. + * cif-code.def: Likewise. + * collect2.c: Likewise. + * combine.c: Likewise. + * convert.c: Likewise. + * coverage.c: Likewise. + * crtstuff.c: Likewise. + * cse.c: Likewise. + * cselib.c: Likewise. + * dbgcnt.c: Likewise. + * dbgcnt.def: Likewise. + * dbgcnt.h: Likewise. + * dbxout.c: Likewise. + * dce.c: Likewise. + * ddg.c: Likewise. + * ddg.h: Likewise. + * defaults.h: Likewise. + * df-byte-scan.c: Likewise. + * df-core.c: Likewise. + * df-problems.c: Likewise. + * df-scan.c: Likewise. + * df.h: Likewise. + * dfp.c: Likewise. + * diagnostic.c: Likewise. + * diagnostic.h: Likewise. + * dominance.c: Likewise. + * domwalk.c: Likewise. + * double-int.c: Likewise. + * double-int.h: Likewise. + * dse.c: Likewise. + * dwarf2asm.c: Likewise. + * dwarf2asm.h: Likewise. + * dwarf2out.c: Likewise. + * ebitmap.c: Likewise. + * ebitmap.h: Likewise. + * emit-rtl.c: Likewise. + * et-forest.c: Likewise. + * except.c: Likewise. + * except.h: Likewise. + * expmed.c: Likewise. + * expr.c: Likewise. + * expr.h: Likewise. + * final.c: Likewise. + * flags.h: Likewise. + * fold-const.c: Likewise. + * function.c: Likewise. + * function.h: Likewise. + * fwprop.c: Likewise. + * gcc.c: Likewise. + * gcov-dump.c: Likewise. + * gcov-io.c: Likewise. + * gcov-io.h: Likewise. + * gcov.c: Likewise. + * gcse.c: Likewise. + * genattr.c: Likewise. + * genattrtab.c: Likewise. + * genautomata.c: Likewise. + * genchecksum.c: Likewise. + * genconfig.c: Likewise. + * genflags.c: Likewise. + * gengtype-parse.c: Likewise. + * gengtype.c: Likewise. + * gengtype.h: Likewise. + * genmddeps.c: Likewise. + * genmodes.c: Likewise. + * genopinit.c: Likewise. + * genpreds.c: Likewise. + * gensupport.c: Likewise. + * ggc-common.c: Likewise. + * ggc-page.c: Likewise. + * ggc-zone.c: Likewise. + * ggc.h: Likewise. + * gimple-iterator.c: Likewise. + * gimple-low.c: Likewise. + * gimple-pretty-print.c: Likewise. + * gimple.c: Likewise. + * gimple.def: Likewise. + * gimple.h: Likewise. + * gimplify.c: Likewise. + * graphds.c: Likewise. + * graphite-clast-to-gimple.c: Likewise. + * gthr-nks.h: Likewise. + * gthr-posix.c: Likewise. + * gthr-posix.h: Likewise. + * gthr-posix95.h: Likewise. + * gthr-single.h: Likewise. + * gthr-tpf.h: Likewise. + * gthr-vxworks.h: Likewise. + * gthr.h: Likewise. + * haifa-sched.c: Likewise. + * hard-reg-set.h: Likewise. + * hooks.c: Likewise. + * hooks.h: Likewise. + * hosthooks.h: Likewise. + * hwint.h: Likewise. + * ifcvt.c: Likewise. + * incpath.c: Likewise. + * init-regs.c: Likewise. + * integrate.c: Likewise. + * ipa-cp.c: Likewise. + * ipa-inline.c: Likewise. + * ipa-prop.c: Likewise. + * ipa-pure-const.c: Likewise. + * ipa-reference.c: Likewise. + * ipa-struct-reorg.c: Likewise. + * ipa-struct-reorg.h: Likewise. + * ipa-type-escape.c: Likewise. + * ipa-type-escape.h: Likewise. + * ipa-utils.c: Likewise. + * ipa-utils.h: Likewise. + * ipa.c: Likewise. + * ira-build.c: Likewise. + * ira-color.c: Likewise. + * ira-conflicts.c: Likewise. + * ira-costs.c: Likewise. + * ira-emit.c: Likewise. + * ira-int.h: Likewise. + * ira-lives.c: Likewise. + * ira.c: Likewise. + * jump.c: Likewise. + * lambda-code.c: Likewise. + * lambda-mat.c: Likewise. + * lambda-trans.c: Likewise. + * lambda.h: Likewise. + * langhooks.c: Likewise. + * lcm.c: Likewise. + * libgcov.c: Likewise. + * lists.c: Likewise. + * loop-doloop.c: Likewise. + * loop-init.c: Likewise. + * loop-invariant.c: Likewise. + * loop-iv.c: Likewise. + * loop-unroll.c: Likewise. + * lower-subreg.c: Likewise. + * lto-cgraph.c: Likewise. + * lto-compress.c: Likewise. + * lto-opts.c: Likewise. + * lto-section-in.c: Likewise. + * lto-section-out.c: Likewise. + * lto-streamer-in.c: Likewise. + * lto-streamer-out.c: Likewise. + * lto-streamer.c: Likewise. + * lto-streamer.h: Likewise. + * lto-symtab.c: Likewise. + * lto-wpa-fixup.c: Likewise. + * matrix-reorg.c: Likewise. + * mcf.c: Likewise. + * mode-switching.c: Likewise. + * modulo-sched.c: Likewise. + * omega.c: Likewise. + * omega.h: Likewise. + * omp-low.c: Likewise. + * optabs.c: Likewise. + * optabs.h: Likewise. + * opts-common.c: Likewise. + * opts.c: Likewise. + * params.def: Likewise. + * params.h: Likewise. + * passes.c: Likewise. + * plugin.c: Likewise. + * postreload-gcse.c: Likewise. + * postreload.c: Likewise. + * predict.c: Likewise. + * predict.def: Likewise. + * pretty-print.c: Likewise. + * pretty-print.h: Likewise. + * print-rtl.c: Likewise. + * print-tree.c: Likewise. + * profile.c: Likewise. + * read-rtl.c: Likewise. + * real.c: Likewise. + * recog.c: Likewise. + * reg-stack.c: Likewise. + * regcprop.c: Likewise. + * reginfo.c: Likewise. + * regmove.c: Likewise. + * regrename.c: Likewise. + * regs.h: Likewise. + * regstat.c: Likewise. + * reload.c: Likewise. + * reload1.c: Likewise. + * resource.c: Likewise. + * rtl.c: Likewise. + * rtl.def: Likewise. + * rtl.h: Likewise. + * rtlanal.c: Likewise. + * sbitmap.c: Likewise. + * sched-deps.c: Likewise. + * sched-ebb.c: Likewise. + * sched-int.h: Likewise. + * sched-rgn.c: Likewise. + * sched-vis.c: Likewise. + * sdbout.c: Likewise. + * sel-sched-dump.c: Likewise. + * sel-sched-dump.h: Likewise. + * sel-sched-ir.c: Likewise. + * sel-sched-ir.h: Likewise. + * sel-sched.c: Likewise. + * sel-sched.h: Likewise. + * sese.c: Likewise. + * sese.h: Likewise. + * simplify-rtx.c: Likewise. + * stack-ptr-mod.c: Likewise. + * stmt.c: Likewise. + * stor-layout.c: Likewise. + * store-motion.c: Likewise. + * stringpool.c: Likewise. + * stub-objc.c: Likewise. + * sync-builtins.def: Likewise. + * target-def.h: Likewise. + * target.h: Likewise. + * targhooks.c: Likewise. + * targhooks.h: Likewise. + * timevar.c: Likewise. + * tlink.c: Likewise. + * toplev.c: Likewise. + * toplev.h: Likewise. + * tracer.c: Likewise. + * tree-affine.c: Likewise. + * tree-affine.h: Likewise. + * tree-browser.def: Likewise. + * tree-call-cdce.c: Likewise. + * tree-cfg.c: Likewise. + * tree-cfgcleanup.c: Likewise. + * tree-chrec.c: Likewise. + * tree-chrec.h: Likewise. + * tree-complex.c: Likewise. + * tree-data-ref.c: Likewise. + * tree-data-ref.h: Likewise. + * tree-dfa.c: Likewise. + * tree-dump.c: Likewise. + * tree-dump.h: Likewise. + * tree-eh.c: Likewise. + * tree-flow-inline.h: Likewise. + * tree-flow.h: Likewise. + * tree-if-conv.c: Likewise. + * tree-inline.c: Likewise. + * tree-into-ssa.c: Likewise. + * tree-loop-distribution.c: Likewise. + * tree-loop-linear.c: Likewise. + * tree-mudflap.c: Likewise. + * tree-nested.c: Likewise. + * tree-nomudflap.c: Likewise. + * tree-nrv.c: Likewise. + * tree-object-size.c: Likewise. + * tree-optimize.c: Likewise. + * tree-outof-ssa.c: Likewise. + * tree-parloops.c: Likewise. + * tree-pass.h: Likewise. + * tree-phinodes.c: Likewise. + * tree-predcom.c: Likewise. + * tree-pretty-print.c: Likewise. + * tree-profile.c: Likewise. + * tree-scalar-evolution.c: Likewise. + * tree-ssa-address.c: Likewise. + * tree-ssa-alias.c: Likewise. + * tree-ssa-ccp.c: Likewise. + * tree-ssa-coalesce.c: Likewise. + * tree-ssa-copy.c: Likewise. + * tree-ssa-copyrename.c: Likewise. + * tree-ssa-dce.c: Likewise. + * tree-ssa-dom.c: Likewise. + * tree-ssa-dse.c: Likewise. + * tree-ssa-forwprop.c: Likewise. + * tree-ssa-ifcombine.c: Likewise. + * tree-ssa-live.c: Likewise. + * tree-ssa-live.h: Likewise. + * tree-ssa-loop-ch.c: Likewise. + * tree-ssa-loop-im.c: Likewise. + * tree-ssa-loop-ivcanon.c: Likewise. + * tree-ssa-loop-ivopts.c: Likewise. + * tree-ssa-loop-manip.c: Likewise. + * tree-ssa-loop-niter.c: Likewise. + * tree-ssa-loop-prefetch.c: Likewise. + * tree-ssa-loop-unswitch.c: Likewise. + * tree-ssa-loop.c: Likewise. + * tree-ssa-math-opts.c: Likewise. + * tree-ssa-operands.c: Likewise. + * tree-ssa-operands.h: Likewise. + * tree-ssa-phiopt.c: Likewise. + * tree-ssa-phiprop.c: Likewise. + * tree-ssa-pre.c: Likewise. + * tree-ssa-propagate.c: Likewise. + * tree-ssa-reassoc.c: Likewise. + * tree-ssa-sccvn.c: Likewise. + * tree-ssa-sink.c: Likewise. + * tree-ssa-structalias.c: Likewise. + * tree-ssa-ter.c: Likewise. + * tree-ssa-threadedge.c: Likewise. + * tree-ssa-threadupdate.c: Likewise. + * tree-ssa-uncprop.c: Likewise. + * tree-ssa.c: Likewise. + * tree-ssanames.c: Likewise. + * tree-switch-conversion.c: Likewise. + * tree-tailcall.c: Likewise. + * tree-vect-data-refs.c: Likewise. + * tree-vect-generic.c: Likewise. + * tree-vect-loop-manip.c: Likewise. + * tree-vect-loop.c: Likewise. + * tree-vect-patterns.c: Likewise. + * tree-vect-slp.c: Likewise. + * tree-vect-stmts.c: Likewise. + * tree-vectorizer.c: Likewise. + * tree-vectorizer.h: Likewise. + * tree-vrp.c: Likewise. + * tree.c: Likewise. + * tree.def: Likewise. + * tree.h: Likewise. + * treestruct.def: Likewise. + * unwind-compat.c: Likewise. + * unwind-dw2-fde-glibc.c: Likewise. + * unwind-dw2.c: Likewise. + * value-prof.c: Likewise. + * value-prof.h: Likewise. + * var-tracking.c: Likewise. + * varasm.c: Likewise. + * varpool.c: Likewise. + * vec.c: Likewise. + * vec.h: Likewise. + * vmsdbgout.c: Likewise. + * web.c: Likewise. + * xcoffout.c: Likewise. + +2009-11-24 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa.c (output_call): Only use sr4 for long interspace calls if + call binds local and generating non PIC code. + (attr_length_call): Adjust length calculation for above. + +2009-11-25 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (plusminus_carry_mnemonic): New code attribute. + (add<mode>3_carry): Change operand order of plus RTX. + (*add<mode>3_carry): Ditto. + (*addsi3_carry_zext): Ditto. + (*add<dwi>3_doubleword): Update for changed operand order. + (*negti2_1 splitter): Ditto. + (*negdi2_1 splitter): Ditto. + (<plusminus_insn><mode>3_carry): Macroize expander from + {add,sub}<mode>3_carry patterns using plusminus code iterator. + (*<plusminus_insn><mode>3_carry): Macroize insn from + *{add,sub}<mode>3_carry patetrns using plusminus code iterator. + (neg<mode>2): Macroize expander from neg{qi,hi,si,di,ti}2 + patterns using SDWIM mode iterator. + (*neg<dwi>2_doubleword): New insn_and_split pattern. Macroize + pattern from *neg{di,ti}2_1 patterns and corresponding splitters + using DWIH mode iterator. + (*neg<mode>2_1): Macroize insn from neg{qi,hi,si,di}2_1 patterns + using SWI mode iterator. + (*neg<mode>2_cmpz): Ditto from neg{qi,hi,si,di}2_cmpz patterns. + (one_cmpl<mode>2): Macroize expander from one_cmpl{qi,hi,si,di}2 + patterns using SWIM mode iterator. + (*one_cmpl<mode>2_1): Macroize insn from one_cmpl{hi,si,di}2_1 + patterns using SWI248 mode iterator. + (*one_cmpl<mode>2_2): Macroize insn from one_cmpl{qi,hi,si,di}2_2 + patterns using SWI mode iterator. + (*one_cmpl<mode>2_2 splitter): Macroize splitter from + one_cmpl{qi,hi,si,di}2_2 splitter patterns using SWI mode iterator. + +2009-11-24 Michael Matz <matz@suse.de> + + * expr.c (set_storage_via_libcall): Fix build_call_expr call. + +2009-11-24 David Binderman <dcb314@hotmail.com> + + * expr.c (store_field): Remove set but not used local variable + width_mask. + (expand_expr_real_2): Remove treeop2. + * gcse.c (update_ld_motion_stores): Remove new_rtx. + * haifa-sched.c (max_issue): Remove points. + (sched_create_recovery_edges): Remove e. + * ira-costs.c (setup_allocno_cover_class_and_costs): Remove mode. + +2009-11-24 Nick Clifton <nickc@redhat.com> + + * config/v850/v850.c (function_arg): Fix handling of zero-length + function arguments. + +2009-11-24 Michael Matz <matz@suse.de> + + * tree.h (union tree_ann_d): Don't declare. + (tree_base): Remove ann field. + (struct var_ann_d): Declare forward. + (tree_result_decl, tree_parm_decl, tree_var_decl): Add ann field. + (DECL_VAR_ANN_PTR): New macro. + * tree-dfa.c (create_var_ann): Rewrite in terms of above macro, + accept only VAR, PARM or RESULT decls. + (create_tree_common_ann): Remove. + (remove_referenced_var): Use DECL_VAR_ANN_PTR. + * tree-eh.c (lookup_expr_eh_lp): Remove. + * tree-flow-inline.h (var_ann, get_var_ann): Rewrite in terms of + DECL_VAR_ANN_PTR. + (ann_type, tree_common_ann, get_tree_common_ann): Remove. + * tree-flow.h (enum tree_ann_type): Remove. + (struct tree_ann_common_d): Remove. + (struct var_ann_d): Remove common field. + (union tree_ann_d): Remove. + (tree_ann_t, tree_ann_common_t): Remove typedefs. + (tree_common_ann, get_tree_common_ann, ann_type, + create_tree_common_ann, lookup_expr_eh_lp): Don't declare. + * tree-ssa.c (delete_tree_ssa): Use DECL_VAR_ANN_PTR. + * tree.c (copy_node_stat): Use DECL_VAR_ANN_PTR. + * builtins.c (expand_builtin_memcpy): Use + currently_expanding_gimple_stmt instead of tree annotation. + (expand_builtin_memset_args): Ditto. + * cfgexpand.c (currently_expanding_gimple_stmt): Add global variable. + (expand_call_stmt): Don't set tree annotation. + (expand_gimple_basic_block): Set currently_expanding_gimple_stmt. + * expr.c (expand_expr_real): Don't call lookup_expr_eh_lp. + * gimple.h (currently_expanding_gimple_stmt): Declare. + +2009-11-24 Paolo Carlini <paolo.carlini@oracle.com> + + * dwarf2out.c (add_location_or_const_value_attribute): Remove + useless NOTE_VAR_LOCATION_STATUS call. + * cfgrtl.c (commit_one_edge_insertion): Remove useless loop, tidy. + +2009-11-24 Rafael Avila de Espindola <espindola@google.com> + + * lto-wrapper.c (lto_wrapper_exit): Don't try to delete files if + being called recursively. + +2009-11-24 Basile Starynkevitch <basile@starynkevitch.net> + + * Makefile.in (PLUGIN_HEADERS): Added files: cppdefault.h flags.h + $(MD5_H) params.def params.h prefix.h tree-inline.h. + +2009-11-24 Paul Brook <paul@codesourcery.com> + + * gcc/config/arm/arm.c (arm_compute_save_reg0_reg12_mask): Fix comment + typo. + +2009-11-24 Julian Brown <julian@codesourcery.com> + Paul Brook <paul@codesourcery.com> + + * config/arm/arm.c (TARGET_DWARF_REGISTER_SPAN): Define. + (arm_dwarf_register_span): New function. + (arm_dbx_register_number): Add VFPv3 dwarf numbering. + +2009-11-24 David Binderman <dcb314@hotmail.com> + + * cfgrtl.c (commit_one_edge_insertion): Remove set but not used + local variable bb_note. + * dominance.c (get_dominated_by): Likewise local var n. + (output_file_names): Likewise local var idx. + (add_location_or_const_value_attribute): Likewise local var status. + * dwarf2out.c (gen_variable_die): Likewise local var field. + * emit-rtl.c (no_line_numbers): Remove. + (init_emit_once): Remove line_numbers parameter. + * rtl.h (init_emit_once): Adjust prototype. + * toplev.c (backend_init): Adjust init_emit_once call. + +2009-11-24 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/42142 + * tree-ssa-dce.c (mark_aliased_reaching_defs_necessary_1): + Handle iv-dependent (non-)kills properly. + (mark_aliased_reaching_defs_necessary): Pass the basic-block + of the reference statement to mark_aliased_reaching_defs_necessary_1. + +2009-11-24 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/42154 + * tree-sra.c (struct access): Added comments. + (sra_modify_expr): Build references to the old aggregate with + build_ref_for_offset instead of reusing access->expr. + (load_assign_lhs_subreplacements): Likewise. + +2009-11-24 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (add<mode>3_carry): Change insn pattern + to expander. + (sub<mode>3_carry): Ditto. + (x86_mov<mode>cc_0_m1): Ditto. + (*add<mode>3_carry): New insn pattern. Use VOIDmode match_operator + for ix86_carry_flag_operator operator predicate. + (*sub<mode>3_carry): Ditto. + (*x86_mov<mode>cc_0_m1): Ditto. + (*addsi3_carry_zext): Use VOIDmode match_operator for + ix86_carry_flag_operator operator predicate. + (*subsi3_carry_zext): Ditto. + (*x86_mov<mode>cc_0_m1_s): Ditto. + (*x86_mov<mode>cc_0_m1_neg): Ditto. + * config/i386/predocates.md (ix86_carry_flag_operator): Do not + check operator sub-expressions for FLAGS_REG and const0_rtx. + * config/i386/i386.c (*ix86_gen_sub3_carry): Update prototype. + (ix86_expand_int_movcc): Update calls to gen_x86_mov{si,di}cc_0_m1. + (ix86_expand_int_addcc): Update calls to + gen_{add,sub}{qi,hi,si,di}3_carry. Do not set mode of compare_op. + (ix86_expand_strlensi_unroll_1): Update calls to ix86_gen_sub3_carry. + Do not set mode of compare operation. + +2009-11-23 Jan Hubicka <jh@suse.cz> + + PR middle-end/42151 + * ipa-inline.c (inline_transform): Avoid ICE when transform is called + twice. + +2009-11-23 Jan Hubicka <jh@suse.cz> + + * ipa-cp.c (ipcp_compute_node_scale): Work around completely + wrong profile updates. + * predict.c (counts_to_freqs): Be expected for ENTRY/EXIT block + having largest frequency. + * ira-live.c (ira_implicitly_set_insn_hard_regs): Silecne + used uninitalized warning. + * tree-optimize.c (execute_fixup_cfg): Rescale entry and exit block + frequencies. + +2009-11-23 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.md (*cmp_sadd_sidi): Use gen_lowpart instead + of gen_rtx_REG to generate operand 5. + (*cmp_ssub_sidi): Ditto. + +2009-11-23 Richard Henderson <rth@redhat.com> + + * config/i386/i386.c (avx_vpermilp_parallel): Fix sign compare + mismatch. + +2009-11-23 Paul Brook <paul@codesourcery.com> + + * config/arm/arm.c (arm_compute_save_reg0_reg12_mask): Add special + case for noreturn functions. + (arm_compute_save_reg_mask): Remove special noreturn handling. + +2009-11-23 Richard Guenther <rguenther@suse.de> + + * tree-dfa.c (get_ref_base_and_extent): Adjust maximum access + size for DECL bases. + +2009-11-22 Richard Henderson <rth@redhat.com> + + * i386.c (avx_vpermilp_parallel): New function. + * i386-protos.h: Declare it. + * predicates.md (avx_vpermilp_v8sf_operand, avx_vpermilp_v4df_operand, + avx_vpermilp_v4sf_operand, avx_vpermilp_v2df_operand): New. + * sse.md (AVXMODEFDP, AVXMODEFSP): New iterators. + (ssescalarnum, ssedoublesizemode): Add AVX modes. + (vpermilbits): Remove. + (avx_vpermil<mode>): Change insns to expanders. + (*avx_vpermil<mode>): New. Use vec_select. + +2009-11-22 Richard Earnshaw <rearnsha@arm.com> + + * opts.c (decode_options): Don't enable flag_schedule_insns + when optimizing for size. + * doc/invoke.texi: Document change. + +2009-11-22 Uros Bizjak <ubizjak@gmail.com> + + PR target/42113 + * config/alpha/alpha.md (*cmp_sadd_si): Change mode + of scratch register to SImode. + (*cmp_sadd_sidi): Ditto. + (*cmp_ssub_si): Ditto. + (*cmp_ssub_sidi): Ditto. + +2009-11-21 Ian Lance Taylor <iant@google.com> + + * Makefile.in (HOST_LIBS): Move higher in file. + (LINKER, LINKER_FLAGS): If ENABLE_BUILD_WITH_CXX, but $(HOST_LIBS) + is not empty, set to $(CC) and $(CFLAGS). + +2009-11-22 Martin Jambor <mjambor@suse.cz> + + * tree-cfg.c (verify_types_in_gimple_reference): Error out on + V_C_E of an SSA_NAME or an invariant if lvalue is required. + (verify_gimple_call): Verify LHS also with with + verify_types_in_gimple_reference. + +2009-11-21 Martin Jambor <mjambor@suse.cz> + + PR middle-end/42025 + * tree-sra.c (access_precludes_ipa_sra_p): New function. + (splice_param_accesses): Check all accesses by calling + access_precludes_ipa_sra_p. + (sra_ipa_modify_expr): Rename argument erite to dont_convert and do + not convert types if it is true. + (sra_ipa_modify_assign): Convert types in case of mismatch. + +2009-11-21 Kaushik Phatak <kaushik.phatak@kpitcummins.com> + + * config/sh/sh.md (cmpeqsi_t-1): Use logical_operand predicate + for operand 1. + +2009-11-21 Adam Nemet <adambnemet@gmail.com> + + * config/mips/mips-protos.h (mulsidi3_gen_fn): New typedef. + (mips_mulsidi3_gen_fn): Declare new function. + * config/mips/mips.c (mips_mulsidi3_gen_fn): New function. + * config/mips/mips.md (<u>mulsidi3): Change condition to use + mips_mulsidi3_gen_fn. Use mips_mulsidi3_gen_fn to generate the insn. + (<u>mulsidi3_64bit): Don't match for ISA_HAS_DMUL3. + (mulsidi3_64bit_dmul): New define_insn. + +2009-11-21 Ben Elliston <bje@au.ibm.com> + + * gengtype-lex.l: Enable noinput flex option. + (YY_NO_INPUT): Remove define. + +2009-11-21 Alexandre Oliva <aoliva@redhat.com> + + * tree-ssa.c (find_released_ssa_name): Handle NULL wi. + (insert_debug_temp_for_var_def): Handle degenerate PHI nodes. + (insert_debug_temps_for_defs): Handle PHI nodes. + * tree-ssa-dom.c (degenerate_phi_result): Don't crash on released + SSA names. + +2009-11-21 Alexandre Oliva <aoliva@redhat.com> + + * tree-ssa-pre.c (remove_dead_inserted_code): Don't release_defs + after remove_phi_node. + +2009-11-21 Alexandre Oliva <aoliva@redhat.com> + + PR tree-optimization/42078 + * gimple.h (gimple_replace_lhs): New declaration. + * gimple.c (gimple_replace_lhs): New function. + * tree-ssa-math-opts.c (execute_cse_reciprocals): Call it before + modifying the call. + +2009-11-20 Sebastian Pop <sebastian.pop@amd.com> + + * config/i386/sse.md (*xop_pmacsdql_mem): Don't call reg_mentioned_p. + (xop_mulv2div2di3_low): Same. + (*xop_pmacsdqh_mem): Same. + +2009-11-20 Richard Henderson <rth@redhat.com> + + * config/i386/i386-builtin-types.awk: New file. + * config/i386/i386-builtin-types.def: New file. + * config/i386/t-i386: Use them to build i386-builtin-types.inc. + * config/i386/i386.c: Include it. + (ix86_builtin_type_tab, ix86_get_builtin_type): New. + (ix86_builtin_func_type_tab, ix86_get_builtin_func_type): New. + (struct builtin_isa): Remove GTY marker. Replace tree type with + ix86_builtin_func_type; add set_and_not_built_p. + (def_builtin): Change type parameter to tcode; use + ix86_get_builtin_func_type; update all callers. Accept zero mask + to mean the builtin is unconditionally available. + (ix86_add_new_builtins): Use set_and_not_built_p instead of type + being set to NULL. + (enum ix86_special_builtin_type, enum ix86_builtin_type): Remove. + Update some users to rationalized enumeration codes from new include. + (enum multi_arg_type): Remove. Replace all enumeration values + with defines to new ix86_builtin_func_type. + (ix86_init_mmx_sse_builtins): Don't build any types here. Defer + all type resolution to def_builtin. + (ix86_init_builtin_types): Split out from ... + (ix86_init_builtins): ... here. Use ix86_get_builtin_func_type. + +2009-11-20 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR target/41787 + * config/rs6000/rs6000.c (struct machine_function): Revert + 2009-10-23 change to set VRSAVE to non-0 if we use VSX. + (rs6000_expand_to_rtl_hook): Ditto. + (rs6000_check_vector_mode): Ditto. + (compute_vrsave_mask): Ditto. + +2009-11-20 Paul Brook <paul@codesourcery.com> + + * doc/invoke.texi: Document ARM -mcpu=cortex-a5. + * config/arm/arm-cores.def: Add cortex-a5. + * config/arm/bpabi.h (BE8_LINK_SPEC): Add mcpu=cortex-a5. + * config/arm/arm-tune.md: Regenerate. + +2009-11-20 Olga Golovanevsky <olga@il.ibm.com> + + PR middle-end/39960 + * ipa-struct-reorg.c (find_pos_in_stmt): New parameter. + (ref_pos): New field in structure. + (insert_new_var_in_stmt): New function. + + +2009-11-20 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + + * config.gcc (alpha*-dec-osf[45]*): Set use_gcc_stdint. + * config/alpha/osf.h (SIG_ATOMIC_TYPE): Define. + (INT8_TYPE, INT16_TYPE, INT32_TYPE, INT64_TYPE): Define. + (UINT8_TYPE, UINT16_TYPE, UINT32_TYPE, UINT64_TYPE): Define. + (INT_LEAST8_TYPE, INT_LEAST16_TYPE, INT_LEAST32_TYPE, + INT_LEAST64_TYPE): Define. + (UINT_LEAST8_TYPE, UINT_LEAST16_TYPE, UINT_LEAST32_TYPE, + UINT_LEAST64_TYPE): Define. + (INT_FAST8_TYPE, INT_FAST16_TYPE, INT_FAST32_TYPE, + INT_FAST64_TYPE): Define. + (UINT_FAST8_TYPE, UINT_FAST16_TYPE, UINT_FAST32_TYPE, + UINT_FAST64_TYPE): Define. + (INTPTR_TYPE, UINTPTR_TYPE): Define. + +2009-11-20 Julian Brown <julian@codesourcery.com> + + * config/arm/arm.h (ASM_OUTPUT_REG_PUSH): Handle STATIC_CHAIN_REGNUM + specially for Thumb-1. + (ASM_OUTPUT_REG_POP): Likewise. + +2009-11-19 Jason Merrill <jason@redhat.com> + + * dwarf2out.c (get_context_die): Take TYPE_MAIN_VARIANT. + +2009-11-19 Basile Starynkevitch <basile@starynkevitch.net> + Rafael Avila de Espindola <espindola@google.com> + + * doc/plugins.texi (Plugin initialization): Added advices for + retrieving the version of GCC at plugin compilation and loading times. + +2009-11-19 Basile Starynkevitch <basile@starynkevitch.net> + + * plugin.c (FMT_FOR_PLUGIN_EVENT): added definition. + (dump_active_plugins): output to file everything. Use + internationalized dump & FMT_FOR_PLUGIN_EVENT. + +2009-11-19 Richard Guenther <rguenther@suse.de> + + * gimple.c (canonicalize_cond_expr_cond): Strip conversions + around truth-valued expressions. + * tree.c (free_lang_data): Untangle check for LTO frontend. + +2009-11-19 Jakub Jelinek <jakub@redhat.com> + + * tree.c (need_assembler_name_p): Use cgraph_get_node instead + of cgraph_node_for_decl. + * cgraph.h (cgraph_node_for_decl): Remove prototype. + * cgraph.c (cgraph_node_for_decl): Remove. + (cgraph_get_node): Just return NULL if !cgraph_hash. + +2009-11-19 Paul Brook <paul@codesourcery.com> + + * config.gcc: Add new ARM --with-fpu options. + * doc/invoke.texi: Docuent ARM -mfpu=fpv4-sp-d16. + * config/arm/arm.c (all_fpus): Add fpv4-sp-d16. + +2009-11-18 Richard Guenther <rguenther@suse.de> + + * gimple.h (union gimple_statement_d): Add gsmembase member. + (gimple_vuse_op): Use gsmembase for access. + (gimple_vdef_op): Likewise. + (gimple_vuse): Likewise. + (gimple_vdef): Likewise. + (gimple_vuse_ptr): Likewise. + (gimple_vdef_ptr): Likewise. + (gimple_set_vuse): Likewise. + (gimple_set_vdef): Likewise. + * gsstruct.def (GSS_WITH_MEM_OPS_BASE): Add. + +2009-11-18 Daniel Jacobowitz <dan@codesourcery.com> + + * doc/arm-neon-intrinsics.texi: Regenerated. + +2009-11-18 Daniel Jacobowitz <dan@codesourcery.com> + + * config/arm/neon-docgen.ml (analyze_shape_elt): Handle alternatives. + +2009-11-18 Paul Brook <paul@codesourcery.com> + Daniel Jacobowitz <dan@codesourcery.com> + + * config/arm/arm.c (FL_ARCH7EM, FL_FOR_ARCH7EM): Define. + (arm_arch7em): New variable. + (all_architectures): Add armv7e-m. + (arm_override_options): Set arm_arch7em. + * config/arm/arm.h (TARGET_DSP_MULTIPLY, TARGET_INT_SIMD): + Include arm_arch7em. + (arm_arch7em): Declare. + +2009-11-18 Richard Guenther <rguenther@suse.de> + + * lto-streamer-in.c (input_gimple_stmt): Assert that we find + a valid field decl if checking is enabled. + +2009-11-18 Martin Jambor <mjambor@suse.cz> + + * ipa-prop.h (struct ipa_param_call_note): New field lto_stmt_uid. + (lto_ipa_fixup_call_notes): Declare. + * ipa-prop.c (ipa_note_param_call): Store gimple uid. + (update_call_notes_after_inlining): Copy call stmt uid to the new + edge. + (ipa_write_param_call_note): New function. + (ipa_read_param_call_note): New function + (ipa_write_node_info): Write also param call notes. Removed a bogus + comment, reformatted to fit 80 columns. + (ipa_read_node_info): Read also param call notes. Removed a bogus + comment. Remove ipa_edge_args_vector growth. + (lto_ipa_fixup_call_notes): New function. + * ipa-cp.c (pass_ipa_cp): Add stmt_fixup hook. + * ipa-inline.c (cgraph_mark_inline_edge): Perform indirect + inlining regardless of flag_wpa. + (cgraph_decide_inlining_of_small_functions): Likewise. + (cgraph_decide_inlining): Likewise. + (inline_read_summary): Likewise. + +2009-11-18 Jan Hubicka <jh@suse.cz> + + * predict.c (compute_function_frequency): Export. + * predict.h (compute_function_frequency): Declare. + * tree-optimize.c (execute_fixup_cfg): Rescale frequencies. + +2009-11-18 Martin Jambor <mjambor@suse.cz> + + * passes.c (ipa_write_summaries): Call renumber_gimple_stmt_uids + on all nodes we write summaries for. + +2009-11-18 Shujing Zhao <pearly.zhao@oracle.com> + + PR middle-end/22201 + * params.def (PARAM_INLINE_UNIT_GROWTH, PARAM_IPCP_UNIT_GROWTH) + (PARAM_EARLY_INLINING_INSNS, PARAM_IRA_MAX_LOOPS_NUM) + (PARAM_IRA_MAX_CONFLICT_TABLE_SIZE) + (PARAM_LOOP_INVARIANT_MAX_BBS_IN_LOOP) + (PARAM_MIN_INSN_TO_PREFETCH_RATIO) + (PARAM_PREFETCH_MIN_INSN_TO_MEM_RATIO) + (PARAM_IPA_SRA_PTR_GROWTH_FACTOR): Uppercase the first letter of the + description string. + +2009-11-18 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (loc_list_from_tree): Don't call rtl_for_decl_location + unnecessarily. + (rtl_for_decl_location): Try harder to get a rtl for TREE_STATIC vars. + + PR c++/3187 + * cgraph.h (struct cgraph_node): Add same_body and same_body_alias + fields. + (cgraph_same_body_alias, cgraph_remove_same_body_alias): New + prototypes. + * cgraphunit.c (cgraph_expand_function, cgraph_emit_thunks, + cgraph_materialize_all_clones): Handle same_body aliases. + * cgraph.c (cgraph_allocate_node): New function. + (cgraph_create_node): Use it. + (cgraph_node_for_decl, cgraph_node, cgraph_get_node, + cgraph_node_for_asm, cgraph_remove_node): Handle same_body aliases. + (cgraph_same_body_alias, cgraph_remove_same_body_alias): New + functions. + * lto-cgraph.c (lto_output_node): Stream out same_body aliases. + (input_node): Stream in same_body aliases. + * lto-symtab.c (lto_cgraph_replace_node): Clear node pointers + for same_body aliases. + (lto_symtab_merge_cgraph_nodes_1): Handle same_body aliases. + +2009-11-18 Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk> + + PR other/39888 + * config/darwin.h: Use the extension stub libraries to access + current libgcc_s features. + +2009-11-18 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41926 + * tree-vect-loop.c (vect_loop_kill_debug_uses): New. + (vect_transform_loop): Call it. + +2009-11-18 Alexandre Oliva <aoliva@redhat.com> + + * tree-ssa.c (insert_debug_temp_for_var_def): Fix handling of + released SSA names. + +2009-11-18 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41888 + PR debug/41886 + * graphite-scop-detection.c (stmt_simple_for_scop_p): Debug stmts + are ok. + * graphite-sese-to-poly.c (graphite_stmt_p): Likewise. + (try_generate_gimple_bb): Skip debug stmts when finding data refs. + * sese.c (sese_build_liveouts_bb): Skip debug stmts. + (sese_bad_liveouts_use): New. + (sese_reset_debug_liveouts_bb): New. + (sese_build_liveouts): Use it. + (rename_variables_in_stmt): Reset debug stmts rather than creating + new vars for them. + (expand_scalar_variable_stmt): Likewise. + +2009-11-18 Alexandre Oliva <aoliva@redhat.com> + + * df-scan.c (df_ref_create): Don't mark BB as dirty on debug insns. + (df_ref_remove): Likewise. + +2009-11-17 Jan Hubicka <jh@suse.cz> + + * ipa-struct-reorg.c (update_cgraph_with_malloc_call): Fix profile + info. + +2009-11-17 Eric Botcazou <ebotcazou@adacore.com> + + * toplev.c (process_options): Remove dead code. + * doc/invoke.texi (-frename-registers): Mention -fpeel-loops. + +2009-11-17 Rafael Avila de Espindola <espindola@google.com> + + * lto-symtab.c (lto_symtab_resolve_symbols): Always initialize the + nodes. + +2009-11-17 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + PR tree-optimization/41857 + * tree-ssa-address.c (move_hint_to_base): Use void pointer to + TYPE's address space instead of pointer to TYPE. + +2009-11-17 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * reload.c (find_reloads_address): Fix typo. + +2009-11-17 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * config/spu/spu.c (get_pic_reg): Use LAST_ARG_REGNUM as PIC + registers in leaf functions if possible. + +2009-11-17 Maxim Kuvyrkov <maxim@codesourcery.com> + + * config/m68k/m68k-devices.def: Add MCF5441x family. + +2009-11-17 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_update_edges_for_call_stmt_node): Do not access + removed node. + * cgraphunit.c (verify_cgraph_node): Verify frequencies for match. + +2009-11-17 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/predicates.md (x86_64_szext_general_operand): Do not + nest ior expressions. + (x86_64_szext_nonmemory_operand): Ditto. + (call_insn_operand): Ditto. + +2009-11-16 Alexandre Oliva <aoliva@redhat.com> + + * stmt.c (expand_asm_stmt): Get locus from stmt. + +2009-11-16 Alexandre Oliva <aoliva@redhat.com> + + * tree-cfg.c (gimple_redirect_edge_and_branch) <case GIMPLE_ASM>: + Create the decl label for the new dest block on demand. Require + a fallthrough edge if no asm labels were redirected. + +2009-11-16 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (cbranchsi4): Use nonimmediate_operand for + operand 1 predicate. + (cstoresi4): Ditto for operand 2. + (cbranch<mode>4): Macroize expander from cbranch{qi,hi,si,di,ti}4 + patterns using SDWIM mode iterator. + (cstore<mode>4): Macroize expander from cstore{qi,hi,si,di}4 patterns + using SWIM mode iterator. + (cmpdi_1): Rename from cmpdi_1_rex64. + (cmp<mode>_1): Macroize expander from cmp{si,di}_1 patterns using + SWI48 mode iterator. + (*cmp<mode>_1): Macroize insn from *cmp{qi,hi,si,di}_1_insn patterns + using SWI mode iterator. + (*cmp<mode>_ccno_1): Ditto from *cmp{qi,hi,si,di}_ccno_1. + (*cmp<mode>_minus_1): Ditto from *cmp{qi,hi,si,di}_minus_1. + (*cmpqi_ext_3_insn): Make private. + (*cmpqi_ext_3_insn_rex64): Make private. + (cmpstrnsi): Update for renamed cmpdi_1_rex64. + * config/i386/predicates.md (cmpsi_operand): Remove. + +2009-11-16 Paul Brook <paul@codesourcery.com> + + * doc/invoke.texi: Document ARM VFPv4 based FPUs. + * config/arm/arm.c (all_fpus): Add VFPv4 entries. + +2009-11-14 Jan Hubicka <jh@suse.cz> + + * cgraphbuild.c (compute_call_stmt_bb_frequency): Use proper + ENTRY_BLOCK_PTR. + * cgraph.c (cgraph_clone_edge): Avoid freq_scale 0 to completely + zero out all callees. + * cgraphunit.c (verify_cgraph_node): Verify cgraph nodes for + frequency and count match. + * ipa-inline.c (update_noncloned_frequencies): New function. + (cgraph_clone_inlined_nodes): Use it. + * tree-inline.c (copy_bb): Fix frequency scaling; output + diagnostic on frequency mismatches to dump file. + (initialize_cfun): Do not scale frequency; fix count scaling; + initialize entry and exit block frequencies; copy profile info. + (copy_cfg_body): Use frequency_scale as argument; fix count scaling. + (copy_body): Use frequency_scale as argument. + (expand_call_inline): Compute frequency scale and output diagnostic + to dump file. + (delete_unreachable_blocks_update_callgrah): Remove checking that + has to be done after edge redirection. + (tree_function_versioning): Update initialize_cfun and copy_body call. + +2009-11-14 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_release_function_body): Update use of + ipa_transforms_to_apply. + (cgraph_remove_node): Remove ipa_transforms_to_apply. + * cgraph.h (struct cgraph_node): Add ipa_transforms_to_apply. + * cgraphunit.c (save_inline_function_body): Clear ipa_transforms for + copied body. + (cgraph_materialize_clone): Remove original if dead. + * lto-streamer-in.c (lto_read_body): Remove FIXME and + ipa_transforms_to_apply hack. + * function.h (struct function): Add ipa_transforms_to_apply. + * ipa.c (cgraph_remove_unreachable_nodes): Handle dead clone originals. + * tree-inline.c (copy_bb): Update sanity check. + (initialize_cfun): Do not copy ipa_transforms_to_apply. + (expand_call_inline): remove dead clone originals. + (tree_function_versioning): Merge transformation queues. + * passes.c (add_ipa_transform_pass): Remove. + (execute_one_ipa_transform_pass): Update ipa_transforms_to_apply + tracking. + (execute_all_ipa_transforms): Update. + (execute_one_pass): Update. + +2009-11-14 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + PR target/21078, 21080 + * config/avr/avr.c (avr_return_addr_rtx): New function for + builtin_return_address. + (expand_prologue): Calculate stack usage. + (avr_asm_function_end_prologue): Output stack size and offset label. + * config/avr/avr.h (RETURN_ADDR_RTX): Replace. + (machine_function): Add stack_usage. + * config/avr/avr-protos.h (avr_return_addr_rtx): New function. + +2009-11-14 Anatoly Sokolov <aesok@post.ru> + + * config/iq2000/iq2000.c (iq2000_function_value): Make static, add + new 'outgoing' argument. + (iq2000_libcall_value, iq2000_function_value_regno_p): New functions. + (TARGET_FUNCTION_VALUE, TARGET_LIBCALL_VALUE): Declare. + * config/iq2000/iq2000.h (FUNCTION_VALUE_REGNO_P): Redefine, use + iq2000_function_value_regno_p. + (FUNCTION_VALUE, LIBCALL_VALUE): Remove. + * config/iq2000/iq2000-protos.h (iq2000_function_value_regno_p): + Declare. + +2009-11-14 Richard Earnshaw <rearnsha@arm.com> + + PR target/42031 + * arm.md (adddi_sesidi_di): Place tied contraint first. + (adddi_zesidi_di, subdi_di_zesidi, subdi_di_sesidi): Likewise + (subdi_zesidi_di, subdi_sesidi_di): Likewise. + (mulsi3_compare0, mulsi_compare0_scratch): Likewise. + (mulsi3addsi, mulsi3addsi_compare0): Likewise. + (mulsi3addsi_compare0_scratch, smulsi3_highpart_nov6): Likewise. + (umulsi3_highpart_nov6, anddi_zesidi_di, anddi_sesdi_di): Likewise. + (anddi_notdi_di, iordi_sesidi_di, xordi_sesidi_di): Likewise. + (andsi_iorsi3_notsi, arm_ashldi3_1bit, arm_ashrdi3_1_bit): Likewise. + (arm_lshrdi3_1bit, one_cmpldi2): Likewise. + +2009-11-14 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/predicates.md (call_register_no_elim_operand): + New predicate. Reject stack register as valid call operand + for 32bit targets. + (call_insn_operand): Use call_register_no_elim_operand. + +2009-11-13 Richard Henderson <rth@redhat.com> + + * function.c (stack_protect_prologue): Don't bypass expand_expr + for stack_protect_guard and guard_decl. + (stack_protect_epilogue): Likewise. + +2009-11-13 Jan Hubicka <jh@suse.cz> + + * ipa.c (function_and_variable_visibility): Clear COMDAT on functions + when to PUBLIC is set. + +2009-11-13 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/42029 + * gimplify.c (gimplify_omp_atomic): Set DECL_GIMPLE_REG_P on + tmp_load if needed. + +2009-11-13 Uros Bizjak <ubizjak@gmail.com> + + PR target/41900 + * config/i386/i386.md (*call_pop_1, *call_1, *call_value_pop_1, + *call_value_1): Use "lsm" as operand 1 constraint. + * config/i386/predicates.md (call_insn_operand): Depend on + index_register_operand to avoid %esp register. + +2009-11-13 Uros Bizjak <ubizjak@gmail.com> + + Revert: + 2009-11-03 Uros Bizjak <ubizjak@gmail.com> + + PR target/41900 + * config/i386/i386.h (ix86_arch_indices) <X86_ARCH_CALL_ESP>: New. + (TARGET_CALL_ESP): New define. + * config/i386/i386.c (initial_ix86_tune_features): Initialize + X86_ARCH_CALL_ESP. + * config/i386/i386.md (*call_pop_1_esp, *call_1_esp, + *call_value_pop_1_esp, *call_value_1_esp): Rename from *call_pop_1, + *call_1, *call_value_pop_1 and *call_value_1. Depend on + TARGET_CALL_ESP. + (*call_pop_1, *call_1, *call_value_pop_1, *call_value_1): + New patterns, use "lsm" as operand 1 constraint. + * config/i386/predicates.md (call_insn_operand): Depend on + index_register_operand for !TARGET_CALL_ESP to avoid %esp register. + +2009-11-13 Jason Merrill <jason@redhat.com> + + PR debug/26965 + * dwarf2out.c (gen_variable_die): Don't worry about DECL_COMDAT. + Don't emit a second declaration at any scope. + +2009-11-13 Andrey Belevantsev <abel@ispras.ru> + + PR rtl-optimization/41697 + * sel-sched-ir.c (fallthru_bb_of_jump): Bail out when a block with + a conditional jump has a single successor. + +2009-11-13 Andrey Belevantsev <abel@ispras.ru> + + * sched-deps.c (init_deps): New parameter lazy_reg_last. Don't + allocate reg_last when in case lazy_reg_last is true. + (init_deps_reg_last): New. + (free_deps): When max_reg is 0, this context is already freed. + * sched-int.h (init_deps_reg_last): Export. + (init_deps): Update prototype. + * sched-ebb.c (schedule_ebb): Update the call to init_deps. + * sched-rgn.c (sched_rgn_compute_dependencies): Likewise. + * ddg.c (build_intra_loop_deps): Likewise. + * sel-sched-ir.c (copy_deps_context, create_deps_context, + reset_deps_context, deps_init_id): Likewise. + (init_first_time_insn_data): Lazy allocate INSN_DEPS_CONTEXT. + (free_data_for_scheduled_insn): New, break down from ... + (free_first_time_insn_data): ... here. + (has_dependence_p): Allocate reg_last now, when it is needed. + (extend_insn_data): When maximal LUID is big enough, allocate + per-insn data in smaller chunks. + * sel-sched-ir.h (free_data_for_scheduled_insn): Export. + * sel-sched.c (update_seqnos_and_stage): Free INSN_DEPS_CONTEXT + in scheduled insn. + +2009-11-13 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (call_value): Fix comment. + (sibcall_value): Ditto. + +2009-11-13 Eric Botcazou <ebotcazou@adacore.com> + + * config/i386/linux-unwind.h (x86_frob_update_context): New function. + (MD_FROB_UPDATE_CONTEXT): Define. + +2009-11-12 Eric Botcazou <ebotcazou@adacore.com> + Laurent GUERBY <laurent@guerby.net> + + * config/sparc/linux-unwind.h (sparc64_fallback_frame_state): Tidy. + Do not schedule an %sp restore. Compensate for RETURN_ADDR_OFFSET. + (sparc_fallback_frame_state): Tidy. Compensate for RETURN_ADDR_OFFSET. + +2009-11-12 Jan Hubicka <jh@suse.cz> + + * ipa.c (function_and_variable_visibility): Fix my accidentail commit + and clear DECL_COMMON on localized declarations. + +2009-11-12 Bernd Schmidt <bernd.schmidt@analog.com> + + PR rtl-opt/38582 + * regrename.c (struct du_head): New structure; some elements moved + from... + (struct du_chain): ... this one. + (open_chains, closed_chains): Now of type struct du_head *. + (do_replace): Accept du_head argument, not du_chain. All callers + changed. Modified code to match new data structures. + (build_def_use): Return a list of du_head structures. Modified code + to match new data structures. + (dump_def_use_chain): Accept du_head argument, not du_chain. All + callers changed. Modified code to match new data structures. + (merge_overlapping_regs): Accept du_head argument, not du_chain. All + callers changed. Modified code to match new data structures. + (scan_rtx_reg): Change type of this_regno and this_nregs to unsigned. + Allocate a du_head structure as well as a du_chain when creating a + new chain. Modified other code to match new data structures. + +2009-11-12 Jan Hubicka <jh@suse.cz> + + * cgraph.h (varpool_node_name): Declare. + * cgraphunit.c (process_function_and_variable_attributes): Set + force_output flag on used variables. + * ipa.c (function_and_variable_visibility): Dump externally visible + and needed variables. + * varpool.c (varpool_node_name): Export. + (decide_is_variable_needed): Check COMDAT for externally visible vars; + ignore needed flag. + +2009-11-12 Uros Bizjak <ubizjak@gmail.com> + + PR middle-end/41930 + * simplify-rtx.c (simplify_replace_fn_rtx) <case 'e'>: Skip + processing if XEXP (x, i) is NULL. + +2009-11-12 Jan Hubicka <jh@suse.cz> + + * ipa.c (function_and_variable_visibility): Verify that WEAK || COMMON + imply PUBLIC || EXTERNAL. + +2009-11-11 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + PR middle-end/41440 + * cfgexpand.c (expand_gimple_basic_block): Append NOP to a fallthru, + single successor block, ending with jump created by RTL expander. + +2009-11-11 Jan Hubicka <jh@suse.cz> + + PR middle-end/41729 + * ipa.c (function_and_variable_visibility): Do not privatize COMDAT + and WEAK variables at -fwhole-program. + + PR middle-end/41735 + * ipa.c (whole_program_function_and_variable_visility): COMDAT + functions/variables are not needed even if they are externally visible. + +2009-11-11 Jan Hubicka <jh@suse.cz> + + (patch by Richard Guenther) + * lto-streamer-out.c (output_function): Output head of argument list + earlier. + * lto-streamer-in.c (input_function): Re-map arguments into merged + declaration. + +2009-11-11 Jan Hubicka <jh@suse.cz> + + * lto-cgraph.c: Include gcov-io.h + (output_profile_summary): New function. + (output_cgraph): Use it. + (input_profile_summary): New function. + (input_cgraph): Use it. + * coverage.c (build_ctr_info_value): Use varpool; initalize + DECL_ASSEMBLER_NAME. + (create_coverage): Likewise. + * tree-profile.c (tree_init_ic_make_global_vars): Likewise. + (tree_init_edge_profiler): Likewise. + * Makefile.in (lto-cgraph.o): Add dependency on gcov-io.h. + +2009-11-11 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/cygming.h (HANDLE_PRAGMA_PUSH_POP_MACRO): Removed. + * c-pragma.c (def_pragma_macro_value): Likewise. + (def_pragma_macro): Likewise. + (pushed_macro_table): Likewise. + (HANDLE_PRAGMA_PUSH_POP_MACRO): Remove guarded code. + * doc/tm.texi (HANDLE_PRAGMA_PUSH_POP_MACRO): Removed. + +2009-11-11 Basile Starynkevitch <basile@starynkevitch.net> + + * doc/plugins.texi (Registering custom attributes): section + renamed as (Registering custom attributes or pragmas). + Mentions custom attributes & pragmas, and c_register_pragma, with + a small example. + * doc/cpp.texi (Pragmas): Mentions that plugins can provide their + pragmas. + * doc/extend.texi (Function Attributes): Mentions that plugin can + provide their attributes. + +2009-11-11 Jon Beniston <jon@beniston.com> + + * config.gcc: Add lm32 elf and uclinux targets. + * config/lm32: New directory. + * config/lm32/lm32.c: New file. + * config/lm32/lm32.h: New file. + * config/lm32/lm32.md: New file. + * config/lm32/lm32.opt: New file. + * config/lm32/lm32-protos.h: New file. + * config/lm32/constraints.md: New file. + * config/lm32/predicates.md: New file. + * config/lm32/sfp-machine.h: New file. + * config/lm32/t-fprules-softfp: New file. + * config/lm32/uclinux-elf.h: New file. + * doc/invoke.texi: Document lm32 options. + * doc/contrib.texi: Document lm32 porter. + * doc/install.texi: Document lm32 targets. + +2009-11-11 Martin Jambor <mjambor@suse.cz> + + PR lto/41932 + * ipa-prop.c (ipa_update_after_lto_read): Call + ipa_check_create_node_params and ipa_check_create_edge_args. Also + call ipa_initialize_node_params instead of ipa_populate_param_decls. + +2009-11-11 Daniel Jacobowitz <dan@codesourcery.com> + + * config/arm/arm.c (neon_vdup_constant, neon_make_constant): New. + (neon_expand_vector_init): Use them. Also handle non-constant + vectors with identical elements and vectors with only one + non-constant element. + (arm_print_operand): Handle 'y' modifier. + * config/arm/arm-protos.h (neon_make_constant): Declare. + * config/arm/neon.md (neon_vdup_n<mode>): Split into two + patterns. Use VX instead of VDQW for the first one. Allow + a VFP alternative and V32 modes for the second one. + * config/arm/neon.ml (shape_elt): Add Alternatives. + (ops): Use Alternatives for vdup lane instructions. + * config/arm/neon-testgen.ml (analyze_shape): Handle Alternatives. + * config/arm/vec-common.md (mov<mode>): Use neon_make_constant. + +2009-11-11 Daniel Jacobowitz <dan@codesourcery.com> + + * config/arm/neon.md (*neon_mov<mode>): Reject two non-register + operands. + (movti, mov<mode>): Call force_reg on one operand if required. + * config/arm/vec-common.md (mov<mode>): Likewise. + +2009-11-11 Daniel Jacobowitz <dan@codesourcery.com> + + * config/arm/arm.c (arm_override_options): Enable scheduling for + Thumb-2. + +2009-11-10 Eric Botcazou <ebotcazou@adacore.com> + + PR target/10127 + PR ada/20548 + * expr.h (anti_adjust_stack_and_probe): Declare. + * explow.c (anti_adjust_stack_and_probe): Make global, add ADJUST_BACK + parameter and rewrite head comment. + (allocate_dynamic_stack_space): Adjust call to above function. + * function.c (expand_function_end): Handle STACK_CHECK_MOVING_SP. + + * tree.h (dwarf2out_args_size): Delete. + * dwarf2out.c (dwarf2out_args_size): Make static and move around. + (dwarf2out_args_size_adjust): Delete prototype and move around. + (dwarf2out_frame_debug_expr): Do not record arg size adjustments for + ACCUMULATE_OUTGOING_ARGS targets. + +2009-11-10 Eric Botcazou <ebotcazou@adacore.com> + + * config/sparc/sparc.c (print_operand) <')'>: Test for a non-null + DECL_SIZE of DECL_RESULT before evaluating it. + +2009-11-10 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + PR tree-optimization/41987 + * fold-const.c (const_binop): Avoid using fold_buildN(). + +2009-11-10 Martin Jambor <mjambor@suse.cz> + + * tree-pass.h (struct ipa_opt_pass_d): Added stmt_fixup field. + (execute_all_ipa_stmt_fixups): Declare. + * ipa-cp.c (pass_ipa_cp): Added stmt_fixup value. + * ipa-inline.c (pass_ipa_inline): Likewise. + * ipa-pure-const.c (pass_ipa_pure_cons): Likewise. + * ipa-reference.c (pass_ipa_reference): Likewise. + * ipa.c (pass_ipa_whole_program_visibility): Likewise. + * lto-streamer-out.c (pass_ipa_lto_gimple_out): Likewise. + (pass_ipa_lto_finish_out): Likewise. + * lto-wpa-fixup.c (pass_ipa_lto_wpa_fixup): Likewise. + * passes.c (execute_ipa_stmt_fixups): New function. + (execute_all_ipa_stmt_fixups): New function. + * lto-streamer-in.c (input_function): Call execute_all_ipa_stmt_fixups. + +2009-11-10 Eric Botcazou <ebotcazou@adacore.com> + + PR ada/20548 + * explow.c (probe_stack_range): Fix typo. + * config/sparc/sparc.md (probe_stack): New expander. + +2009-11-09 Dave Korn <dave.korn.cygwin@gmail.com> + + * config/i386/cygwin.h (LINK_SPEC): Add -tsaware flag if !mno-cygwin. + +2009-11-09 Jason Merrill <jason@redhat.com> + + * gdbinit.in (pgq): New function for printing gimple sequence. + +2009-11-09 Paul Brook <paul@codesourcery.com> + Daniel Jacobowitz <dan@codesourcery.com> + Sandra Loosemore <sandra@codesourcery.com> + + * doc/extend.texi (Half-Precision): Update wording to reflect + that there are now multiple -mfpu options that enable fp16 + hardware support. + * doc/invoke.texi: Update list of ARM -mfpu= options. + * config.gcc: Update ARM --with-fpu option list. + * config/arm/arm.c (all_fpus): Add vfpv3-fp16, vfpv3-d16-fp16, + vfpv3xd and vfpv3xd-fp16. + (use_vfp_abi): New function. + (aapcs_vfp_is_call_or_return_candidate): Avoid double precision regs + when undesirable. + (aapcs_vfp_is_return_candidate, aapcs_vfp_is_call_candidate, + aapcs_vfp_allocate_return_reg): Use use_vfp_abi. + (arm_rtx_costs_1, arm_size_rtx_costs, arm_fastmul_rtx_costs, + arm_9e_rtx_costs): Only expect double-precision operations if the FPU + provides them. + (coproc_secondary_reload_class): Reload HFmode via GENERAL_REGS if no + NEON. + (arm_print_operand): Handle 'p' modifier. + (arm_hard_regno_mode_ok): : Allow HFmode in VFP registers if + TARGET_FP16. + * config/arm/arm.h (TARGET_VFP_SINGLE, TARGET_VFP_DOUBLE): Define. + (TARGET_FP16): Define. + * config/arm/vfp.md: Disable double-precision patterns if the FPU + does not provide them. + (arm_movdi_vfp, thumb2_movdi_vfp): Use fcpys to move + double-precision values on a single-precision FPU. + (movdf_vfp, thumb2_movdf_vfp): Likewise. Use "Dy" for + double-precision constants. + (movhf_vfp_neon): New pattern (was movhf_vfp). + (movhf_vfp): Remove NEON instructions. + * config/arm/constraints.md: Add new "Dy" constraint for + double-precision constants. Update description of "Dv". + * config/arm/arm.md: Disable double-precision patterns if the FPU + does not provide them + +2009-11-09 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.c (print_operand) <case 'D'>: Fix formatting. + (print_operand) <case 'Y'>: Likewise. Fix a pasto in operand lossage + diagnostics. + +2009-11-08 H.J. Lu <hongjiu.lu@intel.com> + + * collect2.c (main): Search PLUGIN_LD for plugin linker. + + * configure.ac (--with-plugin-ld): New. Default to ld. + * configure: Regenerated. + * config.in: Likewise. + + * exec-tool.in (ORIGINAL_PLUGIN_LD_FOR_TARGET): New. + (collect-ld): Use ORIGINAL_PLUGIN_LD_FOR_TARGET for -plugin. + +2009-11-08 Jonathan Gray <jsg@openbsd.org> + + * config/openbsd-stdint.h: Change to reflect what + c_common_nodes_and_builtins expects. + +2009-11-08 Paolo Carlini <paolo.carlini@oracle.com> + + * builtins.c (apply_args_reg_offset): Remove commented out delaration. + +2009-11-08 Jakub Jelinek <jakub@redhat.com> + + PR target/41985 + * config/i386/i386.c (get_some_local_dynamic_name): Don't assert + function contains at least one local dynamic name. + (print_operand) <case '&'>: Instead output operand lossage diagnostics + here if that happens. + +2009-11-08 Zbigniew Chamski <zbigniew.chamski@gmail.com> + Joern Rennecke <amylaar@spamcop.net> + + * cfgrtl.c (pass_free_cfg): Add pass name. + * cgraphbuild.c (pass_build_cgraph_edges): Likewise. + (pass_rebuild_cgraph_edges, pass_remove_cgraph_callee_edges): Likewise. + * dce.c (pass_ud_rtl_dce, pass_fast_rtl_dce): Change pass name. + * df-core.c (pass_df_initialize_no_opt): Likewise. + * except.c (pass_rtl_eh): Likewise. + * function.c (pass_init_function, pass_leaf_regs): Likewise. + * gcse.c (pass_rtl_pre): Change pass name. + * passes.c (pass_postreload): Add pass name. + (make_pass_instance): Don't use duplicate-tracking logic for + names starting with '*'. + (next_pass_1): Assert that pass has a name. + (register_one_dump_file): If there is an space in the name, + skip past it. + * predict.c (pass_strip_predict_hints): Add pass name. + * reg-stack.c (pass_stack_regs): Likewise. + * stack-ptr-mod.c (pass_stack_ptr_mod): Likewise. + * tree-cfg.c (pass_warn_function_return, + pass_warn_function_noreturn): Add pass name. + * tree-dfa.c (pass_referenced_vars): Likewise. + * tree-optimize.c (pass_cleanup_cfg_post_optimizing): + Fix whitespace before comment. + (pass_fixup_cfg): Add pass name, fix whitespace before comment. + (pass_init_datastructures): Add pass name. + * tree-ssa-loop.c (pass_record_bounds): Likewise. + * tree-ssa.c (pass_early_warn_uninitialized, + pass_late_warn_uninitialized): Likewise. + * tree.c (pass_ipa_free_lang_data): Likewise. + * doc/passes.texi (pass manager): Document how to disambiguate + pass names. + +2009-11-08 Paolo Bonzini <bonzini@gnu.org> + + * df-problems.c: Fix documentation for forward simulation of LR. + (df_simulate_one_insn_forwards): Use df_simulate_find_defs. + (df_simulate_finalize_forwards): Remove. + * df.h (df_simulate_finalize_forwards): Remove. + +2009-11-08 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (build_succ_graph): Properly make + variables escape if they are stored to anything. + +2009-11-08 Richard Guenther <rguenther@suse.de> + + PR rtl-optimization/41928 + * loop-invariant.c (free_loop_data): If we didn't allocate + loop data do not try to free it. + +2009-11-07 Jason Merrill <jason@redhat.com> + + * tree.c (reconstruct_complex_type): Preserve attributes. + +2009-11-07 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (build_succ_graph): Feed stores + to anything only to variables that can take pointers. + (get_constraint_for_ssa_var): Properly exclude full + variables from expanding. + (first_vi_for_offset): Avoid overflow in arithmetic. + (first_or_preceding_vi_for_offset): Likewise. + (count_num_arguments): Fix implementation. + (gate_ipa_pta): Do not run when not optimizing. + +2009-11-07 David Binderman <dcb314@hotmail.com> + + * builtins.c (apply_args_size, expand_builtin_mathfn, expand_powi, + expand_builtin_expect, maybe_emit_sprintf_chk_warning): Remove some + set but not used variables. + (apply_args_reg_offset): Comment out as unused. + * calls.c (flags_from_decl_or_type): Likewise. + * genautomata.c (check_regexp_units_distribution): Likewise. + +2009-11-07 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/sse.md (xop_pmacsww, xop_pmacssww, xop_pmacsdd, + xop_pmacssdd, xop_pmacssdql, xop_pmacssdqh, xop_pmacsdql, + *xop_pmacsdql_mem, xop_pmacsdqh, *xop_pmacsdqh_mem, xop_pmacsswd, + xop_pmacswd, xop_pmadcsswd, xop_pmadcswd, xop_pcmov_<mode>, + xop_pcmov_<mode>256, xop_pperm, xop_pperm_pack_v2di_v4si, + xop_pperm_pack_v4si_v8hi, xop_pperm_pack_v8hi_v16qi): Compress + operand alternatives. + +2009-11-06 Michael Matz <matz@suse.de> + + PR middle-end/41963 + * tree-ssa-math-opts.c (execute_cse_reciprocals): Check all uses + of a potential reciprocal to really be reciprocals. + +2009-11-06 Jakub Jelinek <jakub@redhat.com> + + * config/i386/x86intrin.h: Include fma4intrin.h, xopintrin.h and + lwpintrin.h after immintrin.h. + * config/i386/fma4intrin.h (__v8sf, __v4df, __m256, __m256d): Remove + typedefs. + + PR middle-end/41935 + * c-common.c (fold_offsetof_1) <case ARRAY_REF>: Don't crash for VLAs + or non-constant index, allow index one past the last element and + allow exceeding array bound in arrays that might be used as flexible + array members. + +2009-11-05 Richard Henderson <rth@redhat.com> + + * config/i386/ia32intrin.h: Protect CRC32 builtins with __SSE4_2__. + +2009-11-05 Paul Brook <paul@codesourcery.com> + + * config/arm/arm.c (arm_fp_model, arm_fpu_arch, arm_fpu_tune): Remove. + (arm_fpu_desc): New. + (all_fpus): Add FPU details. + (fp_model_for_fpu): Remove. + (arm_override_options): Set and use arm_fpu_desc and arm_fpu_attr. + (arm_output_epilogue, arm_save_coproc_regs): Use TARGET_FPA_EMU2. + (arm_file_start): Use arm_fpu_desc. + * config/arm/arm.h (TARGET_FPA, TARGET_MAVERICK, TARGET_VFP, + TARGET_VFPD32, TARGET_VFP3, TARGET_NEON_FP16, TARGET_NEON): Use + arm_fpu_desc. + (TARGET_FPA_EMU2): Define. + (arm_fp_model, fputype, arm_fpu_tune): Remove. + (vfp_reg_type, arm_fpu_desc): New. + * config/arm/arm.md (attr fpu): Simplify. + * config/arm/fpa.md (movxf_fpa): Use TARGET_FPA_EMU2. + * config/arm/linux-elf.h (FPUTYPE_DEFAULT): Use string value. + * config/arm/bpabi.h (FPUTYPE_DEFAULT): Use string value. + * config/arm/netbsd-elf.h (FPUTYPE_DEFAULT): Use string value. + * config/arm/vxworks.h (FPUTYPE_DEFAULT): Use string value. + +2009-11-05 Michael Matz <matz@suse.de> + + * config/i386/i386.c (ix86_builtin_reciprocal): Remove dependency + on TARGET_RECIP. + * doc/invoke.texi (-mrecip): Clarify that we don't need -mrecip + for 1/sqrtf. + +2009-11-04 Jason Merrill <jason@redhat.com> + + PR c++/36912 + * varasm.c (initializer_constant_valid_p): A PLUS_EXPR + or MINUS_EXPR of REAL_TYPE is not a valid constant initializer. + (output_constant): Avoid crash after error. + +2009-11-05 Martin Jambor <mjambor@suse.cz> + + * tree-sra.c (struct access): Changed comment of next_sibling field. + (analyze_modified_params): Loop over accesses of a group rather than + over all with the ame base, pass a common bitmap to + walk_aliased_vdefs. + (unmodified_by_ref_scalar_representative): Build link lists of + accesses of a group. + (splice_param_accesses): Likewise. + +2009-11-04 Kenneth Zadeck <zadeck@naturalbridge.com> + + * df-scan.c (df-uses-record): Add case zero_extract of mem. + +2009-11-04 Eric Botcazou <ebotcazou@adacore.com> + + PR target/10127 + PR ada/20548 + * config/i386/i386.md (probe_stack): New expander. + (logical operation peepholes): Do not split stack checking probes. + +2009-11-04 Harsha Jagasia <harsha.jagasia@amd.com> + Dwarakanath Rajagopal <dwarak.rajagopal@amd.com> + + * doc/invoke.texi (-mlwp): Add documentation. + * doc/extend.texi (x86 intrinsics): Add LWP intrinsics. + * config.gcc (i[34567]86-*-*): Include lwpintrin.h. + (x86_64-*-*): Ditto. + * config/i386/lwpintrin.h: New file, provide x86 compiler + intrinisics for LWP. + * config/i386/cpuid.h (bit_LWP): Define LWP bit. + * config/i386/x86intrin.h: Add LWP check and lwpintrin.h. + * config/i386/i386-c.c (ix86_target_macros_internal): Check + ISA_FLAG for LWP. + * config/i386/i386.h (TARGET_LWP): New macro for LWP. + * config/i386/i386.opt (-mlwp): New switch for LWP support. + * config/i386/i386.c (OPTION_MASK_ISA_LWP_SET): New. + (OPTION_MASK_ISA_LWP_UNSET): New. + (ix86_handle_option): Handle -mlwp. + (isa_opts): Handle -mlwp. + (enum pta_flags): Add PTA_LWP. + (override_options): Add LWP support. + (IX86_BUILTIN_LLWPCB16): New for LWP intrinsic. + (IX86_BUILTIN_LLWPCB32): Ditto. + (IX86_BUILTIN_LLWPCB64): Ditto. + (IX86_BUILTIN_SLWPCB16): Ditto. + (IX86_BUILTIN_SLWPCB32): Ditto. + (IX86_BUILTIN_SLWPCB64): Ditto. + (IX86_BUILTIN_LWPVAL16): Ditto. + (IX86_BUILTIN_LWPVAL32): Ditto. + (IX86_BUILTIN_LWPVAL64): Ditto. + (IX86_BUILTIN_LWPINS16): Ditto. + (IX86_BUILTIN_LWPINS32): Ditto. + (IX86_BUILTIN_LWPINS64): Ditto. + (enum ix86_special_builtin_type): Add LWP intrinsic support. + (builtin_description): Ditto. + (ix86_init_mmx_sse_builtins): Ditto. + (ix86_expand_special_args_builtin): Ditto. + * config/i386/i386.md (UNSPEC_LLWP_INTRINSIC): Add new UNSPEC for + LWP support. + (UNSPEC_SLWP_INTRINSIC): Ditto. + (UNSPECV_LWPVAL_INTRINSIC): Ditto. + (UNSPECV_LWPINS_INTRINSIC): Ditto. + (lwp_llwpcbhi1): New lwp pattern. + (lwp_llwpcbsi1): Ditto. + (lwp_llwpcbdi1): Ditto. + (lwp_slwpcbhi1): Ditto. + (lwp_slwpcbsi1): Ditto. + (lwp_slwpcbdi1): Ditto. + (lwp_lwpvalhi3): Ditto. + (lwp_lwpvalsi3): Ditto. + (lwp_lwpvaldi3): Ditto. + (lwp_lwpinshi3): Ditto. + (lwp_lwpinssi3): Ditto. + (lwp_lwpinsdi3): Ditto. + +2009-11-04 Andrew Pinski <andrew_pinski@playstation.sony.com> + Trevor Smigiel <Trevor_Smigiel@playstation.sony.com> + + PR rtl-opt/41833 + * simplify-rtx.c (simplify_binary_operation_1): Simplify vec_select of + a vec_duplicate. + +2009-11-04 Richard Guenther <rguenther@suse.de> + Rafael Avila de Espindola <espindola@google.com> + + * gcc.c (process_command): Handle arguments name@offset. + +2009-11-04 Harsha Jagasia <harsha.jagasia@amd.com> + Dwarakanath Rajagopal <dwarak.rajagopal@amd.com> + + * config.gcc (i[34567]86-*-*): Include xopintrin.h. + (x86_64-*-*): Ditto. + * config/i386/xopintrin.h: New file, provide common x86 compiler + intrinisics for XOP. + * config/i386/cpuid.h (bit_XOP): Define XOP bit. + * config/i386/x86intrin.h: Add XOP check and xopintrin.h. + * config/i386/i386-c.c(ix86_target_macros_internal): Check + ISA_FLAG for XOP. + * config/i386/i386.h(TARGET_XOP): New macro for XOP. + * config/i386/i386.opt (-mxop): New switch for XOP support. + * config/i386/i386.md (UNSPEC_XOP_UNSIGNED_CMP) + (UNSPEC_XOP_TRUEFALSE) + (UNSPEC_XOP_PERMUTE) + (UNSPEC_FRCZ): Add new UNSPEC for XOP support. + (PPERM_*): New constants for vpperm instruction. + (xop_pcmov_<mode>): Add XOP conditional mov instructions. + * config/i386/i386.c (OPTION_MASK_ISA_XOP_SET): New. + (OPTION_MASK_ISA_XOP_UNSET): New. + (OPTION_MASK_ISA_XOP_UNSET): Change definition to depend on XOP. + (ix86_handle_option): Handle -mxop. + (isa_opts): Handle -mxop. + (enum pta_flags): Add PTA_XOP. + (override_options): Add XOP support. + (print_operand): Add code for XOP compare instructions. + (ix86_expand_sse_movcc): Extend for XOP conditional move instruction. + (ix86_expand_int_vcond): Extend for XOP compare instruction. + + (IX86_BUILTIN_VPCMOV): New for XOP intrinsic. + (IX86_BUILTIN_VPCMOV_V2DI): Ditto. + (IX86_BUILTIN_VPCMOV_V4SI): Ditto. + (IX86_BUILTIN_VPCMOV_V8HI): Ditto. + (IX86_BUILTIN_VPCMOV_V16QI): Ditto. + (IX86_BUILTIN_VPCMOV_V4SF): Ditto. + (IX86_BUILTIN_VPCMOV_V2DF): Ditto. + + (IX86_BUILTIN_VPCMOV256): Ditto. + (IX86_BUILTIN_VPCMOV_V4DI256): Ditto. + (IX86_BUILTIN_VPCMOV_V8SI256): Ditto. + (IX86_BUILTIN_VPCMOV_V16HI256): Ditto. + (IX86_BUILTIN_VPCMOV_V32QI256): Ditto. + (IX86_BUILTIN_VPCMOV_V8SF256): Ditto. + (IX86_BUILTIN_VPCMOV_V4DF256): Ditto. + + (IX86_BUILTIN_VPPERM): Ditto. + + (IX86_BUILTIN_VPMACSSWW): Ditto. + (IX86_BUILTIN_VPMACSWW): Ditto. + (IX86_BUILTIN_VPMACSSWD): Ditto. + (IX86_BUILTIN_VPMACSWD): Ditto. + (IX86_BUILTIN_VPMACSSDD): Ditto. + (IX86_BUILTIN_VPMACSDD): Ditto. + (IX86_BUILTIN_VPMACSSDQL): Ditto. + (IX86_BUILTIN_VPMACSSDQH): Ditto. + (IX86_BUILTIN_VPMACSDQL): Ditto. + (IX86_BUILTIN_VPMACSDQH): Ditto. + (IX86_BUILTIN_VPMADCSSWD): Ditto. + (IX86_BUILTIN_VPMADCSWD): Ditto. + + (IX86_BUILTIN_VPHADDBW): Ditto. + (IX86_BUILTIN_VPHADDBD): Ditto. + (IX86_BUILTIN_VPHADDBQ): Ditto. + (IX86_BUILTIN_VPHADDWD): Ditto. + (IX86_BUILTIN_VPHADDWQ): Ditto. + (IX86_BUILTIN_VPHADDDQ): Ditto. + (IX86_BUILTIN_VPHADDUBW): Ditto. + (IX86_BUILTIN_VPHADDUBD): Ditto. + (IX86_BUILTIN_VPHADDUBQ): Ditto. + (IX86_BUILTIN_VPHADDUWD): Ditto. + (IX86_BUILTIN_VPHADDUWQ): Ditto. + (IX86_BUILTIN_VPHADDUDQ): Ditto. + (IX86_BUILTIN_VPHSUBBW): Ditto. + (IX86_BUILTIN_VPHSUBWD): Ditto. + (IX86_BUILTIN_VPHSUBDQ): Ditto. + + (IX86_BUILTIN_VPROTB): Ditto. + (IX86_BUILTIN_VPROTW): Ditto. + (IX86_BUILTIN_VPROTD): Ditto. + (IX86_BUILTIN_VPROTQ): Ditto. + (IX86_BUILTIN_VPROTB_IMM): Ditto. + (IX86_BUILTIN_VPROTW_IMM): Ditto. + (IX86_BUILTIN_VPROTD_IMM): Ditto. + (IX86_BUILTIN_VPROTQ_IMM): Ditto. + + (IX86_BUILTIN_VPSHLB): Ditto. + (IX86_BUILTIN_VPSHLW): Ditto. + (IX86_BUILTIN_VPSHLD): Ditto. + (IX86_BUILTIN_VPSHLQ): Ditto. + (IX86_BUILTIN_VPSHAB): Ditto. + (IX86_BUILTIN_VPSHAW): Ditto. + (IX86_BUILTIN_VPSHAD): Ditto. + (IX86_BUILTIN_VPSHAQ): Ditto. + + (IX86_BUILTIN_VFRCZSS): Ditto. + (IX86_BUILTIN_VFRCZSD): Ditto. + (IX86_BUILTIN_VFRCZPS): Ditto. + (IX86_BUILTIN_VFRCZPD): Ditto. + (IX86_BUILTIN_VFRCZPS256): Ditto. + (IX86_BUILTIN_VFRCZPD256): Ditto. + + (IX86_BUILTIN_VPCOMEQUB): Ditto. + (IX86_BUILTIN_VPCOMNEUB): Ditto. + (IX86_BUILTIN_VPCOMLTUB): Ditto. + (IX86_BUILTIN_VPCOMLEUB): Ditto. + (IX86_BUILTIN_VPCOMGTUB): Ditto. + (IX86_BUILTIN_VPCOMGEUB): Ditto. + (IX86_BUILTIN_VPCOMFALSEUB): Ditto. + (IX86_BUILTIN_VPCOMTRUEUB): Ditto. + + (IX86_BUILTIN_VPCOMEQUW): Ditto. + (IX86_BUILTIN_VPCOMNEUW): Ditto. + (IX86_BUILTIN_VPCOMLTUW): Ditto. + (IX86_BUILTIN_VPCOMLEUW): Ditto. + (IX86_BUILTIN_VPCOMGTUW): Ditto. + (IX86_BUILTIN_VPCOMGEUW): Ditto. + (IX86_BUILTIN_VPCOMFALSEUW): Ditto. + (IX86_BUILTIN_VPCOMTRUEUW): Ditto. + + (IX86_BUILTIN_VPCOMEQUD): Ditto. + (IX86_BUILTIN_VPCOMNEUD): Ditto. + (IX86_BUILTIN_VPCOMLTUD): Ditto. + (IX86_BUILTIN_VPCOMLEUD): Ditto. + (IX86_BUILTIN_VPCOMGTUD): Ditto. + (IX86_BUILTIN_VPCOMGEUD): Ditto. + (IX86_BUILTIN_VPCOMFALSEUD): Ditto. + (IX86_BUILTIN_VPCOMTRUEUD): Ditto. + + (IX86_BUILTIN_VPCOMEQUQ): Ditto. + (IX86_BUILTIN_VPCOMNEUQ): Ditto. + (IX86_BUILTIN_VPCOMLTUQ): Ditto. + (IX86_BUILTIN_VPCOMLEUQ): Ditto. + (IX86_BUILTIN_VPCOMGTUQ): Ditto. + (IX86_BUILTIN_VPCOMGEUQ): Ditto. + (IX86_BUILTIN_VPCOMFALSEUQ): Ditto. + (IX86_BUILTIN_VPCOMTRUEUQ): Ditto. + + (IX86_BUILTIN_VPCOMEQB): Ditto. + (IX86_BUILTIN_VPCOMNEB): Ditto. + (IX86_BUILTIN_VPCOMLTB): Ditto. + (IX86_BUILTIN_VPCOMLEB): Ditto. + (IX86_BUILTIN_VPCOMGTB): Ditto. + (IX86_BUILTIN_VPCOMGEB): Ditto. + (IX86_BUILTIN_VPCOMFALSEB): Ditto. + (IX86_BUILTIN_VPCOMTRUEB): Ditto. + + (IX86_BUILTIN_VPCOMEQW): Ditto. + (IX86_BUILTIN_VPCOMNEW): Ditto. + (IX86_BUILTIN_VPCOMLTW): Ditto. + (IX86_BUILTIN_VPCOMLEW): Ditto. + (IX86_BUILTIN_VPCOMGTW): Ditto. + (IX86_BUILTIN_VPCOMGEW): Ditto. + (IX86_BUILTIN_VPCOMFALSEW): Ditto. + (IX86_BUILTIN_VPCOMTRUEW): Ditto. + + (IX86_BUILTIN_VPCOMEQD): Ditto. + (IX86_BUILTIN_VPCOMNED): Ditto. + (IX86_BUILTIN_VPCOMLTD): Ditto. + (IX86_BUILTIN_VPCOMLED): Ditto. + (IX86_BUILTIN_VPCOMGTD): Ditto. + (IX86_BUILTIN_VPCOMGED): Ditto. + (IX86_BUILTIN_VPCOMFALSED): Ditto. + (IX86_BUILTIN_VPCOMTRUED): Ditto. + + (IX86_BUILTIN_VPCOMEQQ): Ditto. + (IX86_BUILTIN_VPCOMNEQ): Ditto. + (IX86_BUILTIN_VPCOMLTQ): Ditto. + (IX86_BUILTIN_VPCOMLEQ): Ditto. + (IX86_BUILTIN_VPCOMGTQ): Ditto. + (IX86_BUILTIN_VPCOMGEQ): Ditto. + (IX86_BUILTIN_VPCOMFALSEQ): Ditto. + (IX86_BUILTIN_VPCOMTRUEQ): Ditto. + + (enum multi_arg_type): New enum for describing the various XOP + intrinsic argument types. + (bdesc_multi_arg): New table for XOP intrinsics. + (ix86_init_mmx_sse_builtins): Add XOP intrinsic support. + (ix86_expand_multi_arg_builtin): New function for creating XOP + intrinsics. + + * config/i386/sse.md (sserotatemax): New mode attribute for XOP. + (xop_pmacsww): Ditto. + (xop_pmacssww): Ditto. + (xop_pmacsdd): Ditto. + (xop_pmacssdd): Ditto. + (xop_pmacssdql): Ditto. + (xop_pmacssdqh): Ditto. + (xop_pmacsdql): Ditto. + (xop_pmacsdql_mem): Ditto. + (xop_mulv2div2di3_low): Ditto. + (xop_pmacsdqh): Ditto. + (xop_pmacsdqh_mem): Ditto. + (xop_mulv2div2di3_high): Ditto. + (xop_pmacsswd): Ditto. + (xop_pmacswd): Ditto. + (xop_pmadcsswd): Ditto. + (xop_pmadcswd): Ditto. + (xop_pcmov_<mode>): Ditto. + (xop_pcmov_<mode>256): Ditto. + (xop_phaddbw): Ditto. + (xop_phaddbd): Ditto. + (xop_phaddbq): Ditto. + (xop_phaddwd): Ditto. + (xop_phaddwq): Ditto. + (xop_phadddq): Ditto. + (xop_phaddubw): Ditto. + (xop_phaddubd): Ditto. + (xop_phaddubq): Ditto. + (xop_phadduwd): Ditto. + (xop_phadduwq): Ditto. + (xop_phaddudq): Ditto. + (xop_phsubbw): Ditto. + (xop_phsubwd): Ditto. + (xop_phsubdq): Ditto. + (xop_pperm): Ditto. + (rotl<mode>3): Ditto. + (rotr<mode>3): Ditto. + (xop_rotl<mode>3): Ditto. + (xop_rotr<mode>3): Ditto. + (vrotr<mode>3): Ditto. + (vrotl<mode>3): Ditto. + (xop_vrotl<mode>3): Ditto. + (vlshr<mode>3): Ditto. + (vashr<mode>3): Ditto. + (vashl<mode>3 + (xop_ashl<mode>3): Ditto. + (xop_lshl<mode>3): Ditto. + (ashlv16qi3): Ditto. + (lshlv16qi3): Ditto. + (ashrv16qi3): Ditto. + (ashrv2di3): Ditto. + (xop_frcz<mode>2): Ditto. + (xop_vmfrcz<mode>2): Ditto. + (xop_frcz<mode>2256): Ditto. + (xop_maskcmp<mode>3): Ditto. + (xop_maskcmp_uns<mode>3): Ditto. + (xop_maskcmp_uns2<mode>3): Ditto. + (xop_pcom_tf<mode>3): Ditto. + + * doc/invoke.texi (-mxop): Add documentation. + * doc/extend.texi (x86 intrinsics): Add XOP intrinsics. + +2009-11-03 Mark Mitchell <mark@codesourcery.com> + + PR driver/11810 + * gcc.c (SWITCHES_NEED_SPACES): Define to "o". + * config/alpha/osf.h (SWITCHES_NEED_SPACES): Remove here. + * config/mips/iris.h (SWITCHES_NEED_SPACES): Remove here. + +2009-11-04 Richard Earnshaw <rearnsha@arm.com> + + PR target/40835 + * arm.md (peephole2 patterns for move and compare): New. + +2009-11-04 Nick Clifton <nickc@redhat.com> + + * defaults.h (CONSTANT_ADDRESS_P): Provide a default definition. + Make sure that it does not allow CONST_DOUBLEs. + * doc/tm.texi (CONSTANT_ADDRESS_P): Update description. + * config/avr/avr.h (CONSTANT_ADDRESS_P): Delete. + * config/bfin/bfin.h (CONSTANT_ADDRESS_P): Delete. + * config/cris/cris.h (CONSTANT_ADDRESS_P): Delete. + * config/fr30/fr30.h (CONSTANT_ADDRESS_P): Delete. + * config/frv/frv.h (CONSTANT_ADDRESS_P): Delete. + * config/m32c/m32c.h (CONSTANT_ADDRESS_P): Delete. + * config/m68hc11/m68hc11.h (CONSTANT_ADDRESS_P): Delete. + * config/mep/mep.h (CONSTANT_ADDRESS_P): Delete. + * config/mn10300/mn10300.h (CONSTANT_ADDRESS_P): Delete. + * config/moxie/moxie.h (CONSTANT_ADDRESS_P): Delete. + * config/pdp11/pdp11.h (CONSTANT_ADDRESS_P): Delete. + * config/picochip/picochip.h (CONSTANT_ADDRESS_P): Delete. + * config/score/score.h (CONSTANT_ADDRESS_P): Delete. + * config/stormy16/stormy16.h (CONSTANT_ADDRESS_P): Delete. + +2009-11-04 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41919 + * tree-vrp.c (test_for_singularity): Properly compare values. + +2009-11-04 Revital Eres <eres@il.ibm.com> + + * tree-vect-data-refs.c (vect_enhance_data_refs_alignment): + Consider peeling for alignment only for stores and remove + redundant assignment. + +2009-11-04 Maxim Kuvyrkov <maxim@codesourcery.com> + + PR target/41302 + * config/m68k/m68k.c (m68k_reg_present_p): New static function. + (m68k_ok_for_sibcall_p): Handle different result return locations. + +2009-11-04 Richard Guenther <rguenther@suse.de> + + * c-opts.c (c_common_post_options): Move LTO option processing + code ... + * opts.c (decode_options): ... here. + +2009-11-04 Jakub Jelinek <jakub@redhat.com> + + * c-common.c (fold_offsetof_1): Use %wd instead of + HOST_WIDE_INT_PRINT_DEC. + +2009-11-04 Maciej W. Rozycki <macro@linux-mips.org> + + * config/vax/linux.h (TARGET_OS_CPP_BUILTINS): Don't define + __pic__ or __PIC__. + +2009-11-04 Maciej W. Rozycki <macro@linux-mips.org> + + * config.gcc (vax-*-linux*): Keep the original contents of + tmake_file while adding vax/t-linux. + +2009-11-03 Eric Botcazou <ebotcazou@adacore.com> + + PR target/10127 + PR ada/20548 + * expr.h (STACK_CHECK_PROBE_INTERVAL): Delete. + (STACK_CHECK_PROBE_INTERVAL_EXP): New macro. + (STACK_CHECK_MOVING_SP): Likewise. + * system.h (STACK_CHECK_PROBE_INTERVAL): Poison it. + * doc/tm.texi (Stack Checking): Delete STACK_CHECK_PROBE_INTERVAL. + Document STACK_CHECK_PROBE_INTERVAL_EXP and STACK_CHECK_MOVING_SP. + * doc/md.texi (Standard Pattern Names): Tweak entry of CHECK_STACK. + Document PROBE_STACK. + * explow.c (anti_adjust_stack_and_probe): New function. + (allocate_dynamic_stack_space): Do not directly allocate space if + STACK_CHECK_MOVING_SP, instead invoke above function. + (emit_stack_probe): Handle probe_stack insn. + (PROBE_INTERVAL): New macro. + (STACK_GROW_OPTAB): Likewise. + (STACK_GROW_OFF): Likewise. + (probe_stack_range): Use Pmode and memory_address consistently. Fix + loop condition in the small constant case. Rewrite in the general + case to be immune to wraparounds. Make sure the address of probes + is valid. Try to use [base + disp] addressing mode if possible. + * ira.c (setup_eliminable_regset): Set frame_pointer_needed if stack + checking is enabled and STACK_CHECK_MOVING_SP. + * rtlanal.c (may_trap_p_1) <MEM>: If stack checking is enabled, + return 1 for volatile references to the stack pointer. + * tree.c (build_common_builtin_nodes): Do not set ECF_NOTHROW on + __builtin_alloca if stack checking is enabled. + * unwind-dw2.c (uw_identify_context): Take into account whether the + context is that of a signal frame or not. + * config/i386/linux.h (STACK_CHECK_MOVING_SP): Define to 1. + * config/i386/linux64.h (STACK_CHECK_MOVING_SP): Likewise. + +2009-11-03 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/41917 + * rtlanal.c (num_sign_bit_copies1) <case UMOD>: If sign bit of second + operand isn't known to be 0, return 1. + +2009-11-03 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.md: Fix typos. + +2009-11-03 Richard Sandiford <rdsandiford@googlemail.com> + + * doc/invoke.texi: Fix typo. + +2009-11-03 Paul Brook <paul@codesourcery.com> + + * config/arm/neon.ml (vectype): Add T_floatSF. + (string_of_vectype): Ditto. + * config/arm/neon-gen.ml (signed_ctype): Add T_floatSF. + (deftypes): Use float for float32_t. + * config/arm/arm_neon.h: Regenerate. + +2009-11-03 Nick Clifton <nickc@redhat.com> + Kevin Buettner <kevinb@redhat.com> + + * config/rx/predicates.md (rx_store_multiple_vector): Reverse + order of expected registers. + (rx_load_multiple_vector): Likewise. + (rx_rtsd_vector): Likewise. + * config/rx/rx.c (rx_cpu_type): New variable. + (rx_print_operand): Fix bug printing 64-bit constant values. + (rx_emit_stack_pushm): Reverse order of pushed registers. + (gen_rx_store_vector): Likewise. + (is_fast_interrupt_func): Only accept "fast_interrupt" as the + attribute name. + (is_exception_func): Rename to is_interrupt_func and only accept + "interrupt" as the attribute name. + (rx_get_stack_layout): Use new function name. + (rx_func_attr_inlinable): Likewise. + (rx_attribute_table): Remove "exception". + (rx_expand_prologue): If necessary push the accumulator register + in the prologue of interrupt functions. + (rx_expand_epilogue): If necessary pop the accumulator. + (rx_builtins): Add RX_BUILTIN_MVTIPL. + (rx_expand_builtin_stz): Remove. + (rx_expand_builtin_mvtipl): New function. + (rx_init_builtins): Handle RX_BUILTIN_MVTIPL. + (rx_expand_builtin): Likewise. + (rx_enable_fpu): New variable. + (rx_handle_option): Handle -fpu, -nofpu, -mcpu and -patch. + * config/rx/rx.h (TARGET_CPU_CPP_BUILTINS): Assert machine based + on rx_cpu_type. Define __RX_FPU_INSNS__ if FPU insns are allowed. + (enum rx_cpu_types): Define. + (ASM_SPEC): Pass -m32bit-doubles on to assembler. + (INCOMING_FRAME_SP_OFFSET): Define. + (ARG_POINTER_CFA_OFFSET): Define. + (FRAME_POINTER_CFA_OFFSET): Define. + (OVERRIDE_OPTIONS): Enable fast math if RX FPU insns are enabled. + (ALLOW_RX_FPU_INSNS): Define. + * config/rx/rx.md: Test ALLOW_RX_FPU_INSNS instead of + fast_math_flags_set_p. + (UNSPEC_BUILTIN_MVTIPL): Define. + (revl): Rename to bswapsi2. + (bswaphi2): New pattern. + (mvtachi): Mark as volatile because it uses a register unknown to GCC. + (mvtaclo): Likewise. + (racw): Likewise. + (mvtc): Remove clobber of cc0. + (mvtcp): Delete. + (opecp): Delete. + * config/rx/rx.opt (mieee): Remove. + (fpu): Add. + (nofpu): Add. + (mcpu=): Add. + (patch=): Add. + (msave-acc-in-interrupts): Add. + * config/rx/t-rx (MULTILIB_OPTIONS): Change default to 64bit doubles. + (MULTILIB_DIRS): Likewise. + (MULTILIB_MATCHES): Treat -fpu as an alias for -m32bit-doubles. + * doc/extend.texi: Remove description of "exception" function + attribute. + * doc/invoke.texi: Document -fpu, -nofpu, -mcpu=, -patch= and + -msave-acc-in-interrupts options. + +2009-11-03 Richard Guenther <rguenther@suse.de> + + * c-common.c (fold_offsetof_1): Use HOST_WIDE_INT_PRINT_DEC. + +2009-11-03 Dodji Seketeli <dodji@redhat.com> + + PR c++/38699 + * c-common.c (fold_offsetof_1): Issue errors when the member + designator of the offsetof expression is not legitimate. + +2009-11-03 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (*call_value_1_rex64_ms_sysv): Use register + names instead of numerical constants. + (sse_prologue_save): Ditto. + (*sse_prologue_save_insn): Ditto. + +2009-11-03 Uros Bizjak <ubizjak@gmail.com> + + PR target/41900 + * config/i386/i386.h (ix86_arch_indices) <X86_ARCH_CALL_ESP>: New. + (TARGET_CALL_ESP): New define. + * config/i386/i386.c (initial_ix86_tune_features): Initialize + X86_ARCH_CALL_ESP. + * config/i386/i386.md (*call_pop_1_esp, *call_1_esp, + *call_value_pop_1_esp, *call_value_1_esp): Rename from *call_pop_1, + *call_1, *call_value_pop_1 and *call_value_1. Depend on + TARGET_CALL_ESP. + (*call_pop_1, *call_1, *call_value_pop_1, *call_value_1): + New patterns, use "lsm" as operand 1 constraint. + * config/i386/predicates.md (call_insn_operand): Depend on + index_register_operand for !TARGET_CALL_ESP to avoid %esp register. + +2009-11-02 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + PR tree-optimization/41857 + * tree-flow.h (rewrite_use_address): Add BASE_HINT argument. + * tree-ssa-loop-ivopts.c (rewrite_use_address): Pass base hint + to create_mem_ref. + * tree-ssa-address.c (move_hint_to_base): New function. + (most_expensive_mult_to_index): Add TYPE argument. Use mode and + address space associated with TYPE. + (addr_to_parts): Add TYPE and BASE_HINT arguments. Pass TYPE to + most_expensive_mult_to_index. Call move_hint_to_base. + (create_mem_ref): Add BASE_HINT argument. Pass BASE_HINT and + TYPE to addr_to_parts. + +2009-11-02 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/41750 + * tree-sra.c (analyze_modified_params): Loop over all + representatives of components of a parameter. + +2009-11-02 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/41841 + * ipa-struct-reorg.c (build_data_structure): Don't attempt to look at + local variables of not yet materialized clones. + + PR debug/41893 + * cfgexpand.c (expand_debug_expr): Don't attempt to create DECL_RTL + for a VOIDmode variable. + + PR c++/41774 + * c-pragma.c (visstack): Change into vector of ints rather than + enum symbol_visibility. + (push_visibility): Add kind argument, push default_visibility together + with kind. + (pop_visibility): Add kind argument, return true if successful, fail + if visibility stack is empty or if stack top is of different kind. + (handle_pragma_visibility): Don't check length of visstack, instead + call pop_visibility and issue diagnostics if it failed. Pass 0 + as last argument to push_visibility and pop_visibility. + * c-pragma.h (push_visibility): Add kind argument. + (pop_visibility): Likewise. Return bool instead of void. + +2009-11-01 Eric Botcazou <ebotcazou@adacore.com> + + * tree.def (TARGET_MEM_REF): Update comment. + * alias.c (get_alias_set): Retrieve the original memory reference for + a TARGET_MEM_REF before proceeding. + +2009-10-31 Anatoly Sokolov <aesok@post.ru> + + * config/frv/frv.c (frv_function_value, frv_libcall_value, + frv_function_value_regno_p): New functions. + (TARGET_FUNCTION_VALUE, TARGET_LIBCALL_VALUE): Declare. + * config/frv/frv.h (FUNCTION_VALUE, LIBCALL_VALUE): Remove. + (FUNCTION_VALUE_REGNO_P): Redefine, use frv_function_value_regno_p. + * config/frv/frv-protos.h (frv_function_value_regno_p): Declare. + +2009-10-31 Anatoly Sokolov <aesok@post.ru> + + * config/mn10300/mn10300.c (mn10300_function_value): Make static, add + new 'outgoing' argument. + (mn10300_libcall_value, mn10300_function_value_regno_p): New functions. + (TARGET_FUNCTION_VALUE, TARGET_LIBCALL_VALUE): Declare. + * config/mn10300/mn10300.h (FUNCTION_VALUE, FUNCTION_OUTGOING_VALUE, + LIBCALL_VALUE): Remove. + (FUNCTION_VALUE_REGNO_P): Redefine, use mn10300_function_value_regno_p. + * config/mn10300/mn10300-protos.h (mn10300_function_value): Remove. + (mh10300_function_value_regno_p): Declare. + +2009-10-31 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/cortex-a9.md: New - integer pipeline description. + +2009-10-31 Eric Botcazou <ebotcazou@adacore.com> + + * tree-ssa-sccvn.c (vn_reference_lookup_3): Bail out instead of + aborting if the sizes of the two references don't match. + +2009-10-31 Toon Moene <toon@moene.org> + + * ipa-inline.c (cgraph_decide_inlining): + Include reason for not inlining called-once functions in dump file. + +2009-10-30 Daniel Gutson <dgutson@codesourcery.com> + + * config/arm/linux-eabi.h (LINK_SPEC): BE8_LINK_SPEC added. + * config/arm/bpapi.h (BE8_LINK_SPEC): New define. + (LINK_SPEC): BE_LINK_SPEC added. + +2009-10-30 Richard Guenther <rguenther@suse.de> + + PR lto/41858 + * lto-streamer.h (struct lto_file_decl_data): Remove fd member. + +2009-10-30 Nathan Sidwell <nathan@codesourcery.com> + + * target-def.h (TARGET_ASM_TTYPE): Correct typo of TARGET_ARM_TTYPE. + * config/arm/unwind-arm.c (__gnu_Unwind_Backtrace): Remove unused + label. + +2009-10-30 Martin Jambor <mjambor@suse.cz> + + * tree-sra.c (build_ref_for_offset_1): Remove a comment. + +2009-10-30 H.J. Lu <hongjiu.lu@intel.com> + + PR target/40838 + * cfgexpand.c (expand_stack_alignment): Call update_stack_boundary + first. Move assert on stack_alignment_estimated just before + setting stack_realign_needed. + (gimple_expand_cfg): Initialize stack_alignment_estimated to 0. + Don't call update_stack_boundary. + + * config/i386/i386.c (ix86_minimum_incoming_stack_boundary): New. + (verride_options): Don't check ix86_force_align_arg_pointer here. + (ix86_function_ok_for_sibcall): Use it. + (ix86_update_stack_boundary): Likewise. + + * config/i386/i386.h (STACK_REALIGN_DEFAULT): Update comments. + +2009-10-30 Richard Earnshaw <rearnsha@arm.com> + + * arm.md (QHSI): New mode iterator. + (movqi): If generating for thumb, then truncate any immediate to + 8 bits. + * thumb2.md (thumb2_movsi_shortim and peephole2 generator): Replace + with... + (thumb2_mov<mode>_shortim and peephole2 generator): ... iterator based + version. + +2009-10-29 Cary Coutant <ccoutant@google.com> + + PR debug/41700 + * dwarf2out.c (dwarf2_debug_hooks): Add entries for new hook (two + locations in the source). + (store_vcall_insn): New function. + (lookup_vcall_insn): New function. + (dwarf2out_virtual_call_token): Use store_vcall_insn. + (dwarf2out_copy_call_info): New function. + (dwarf2out_virtual_call): Use lookup_vcall_insn. + * emit-rtl.c (try_split): Call copy_call_info debug hook. + * debug.h (struct gcc_debug_hooks): Add copy_call_info hook. + * debug.c (do_nothing_debug_hooks): Add dummy entry for new hook. + (debug_nothing_rtx_rtx): New dummy hook. + * dbxout.c (dbx_debug_hooks): Add dummy entry for new hook. + (xcoff_debug_hooks): Likewise. + * sdbout.c (sdb_debug_hooks): Likewise. + * vmsdbgout.c (vmsdbg_debug_hooks): Likewise. + +2009-10-29 David Daney <ddaney@caviumnetworks.com> + + * doc/invoke.texi (mmcount-ra-address): Document new command line + option. + * config/mips/mips.opt (mmcount-ra-address): New option. + * config/mips/mips-protos.h (mips_function_profiler): Declare new + function. + * config/mips/mips.c (struct mips_frame_info): Add ra_fp_offset + member. + (mips_for_each_saved_gpr_and_fpr): Set ra_fp_offset. + (mips_function_profiler): Moved from FUNCTION_PROFILER, and + rewritten. + * config/mips/mips.h (FUNCTION_PROFILER): Body of macro moved to + mips_function_profiler. + +2009-10-29 Steve Ellcey <sje@cup.hp.com> + + PR middle-end/37565 + PR target/38018 + * doc/tm.texi (OVERRIDE_OPTIONS): Update. + (TARGET_OVERRIDE_OPTIONS_AFTER_CHANGE): New. + * optc-gen.awk (cl_target_option_restore): Include call to + targetm.override_options_after_change. + * target-def.h (TARGET_OVERRIDE_OPTIONS_AFTER_CHANGE): New. + * target.h (override_options_after_change): New. + * c-common.c (parse_optimize_options): Call + targetm.override_options_after_change. + * config/ia64/ia64.c (TARGET_OVERRIDE_OPTIONS_AFTER_CHANGE): New. + (ia64_override_options_after_change): New. + (ia64_override_options) Add call to above. + +2009-10-29 Michael Matz <matz@suse.de> + + * tree-ssa-math-opts.c (execute_convert_to_rsqrt): Remove. + (gate_convert_to_rsqrt): Ditto. + (pass_convert_to_rsqrt): Ditto. + * tree-pass.h (pass_convert_to_rsqrt): Don't declare. + * passes.c (init_optimization_passes): Don't add pass_convert_to_rsqrt + to pass list. + + * config/i386/i386.c (ix86_emit_swdivsf): Change evaluation order. + +2009-10-29 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (find_best_start): Fix type of remainder to be + unsigned. + +2009-10-29 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/41775 + * tree-sra.c (build_ref_for_offset): Unshare *expr if not NULL. + (generate_subtree_copies): Do not unshare agg. + (load_assign_lhs_subreplacements): Do not unshare rhs. + (sra_modify_assign): Do not unshare exprs. + (propagate_subacesses_accross_link): Renamed to + propagate_subaccesses_across_link. + +2009-10-29 Richard Earnshaw <rearnsha@arm.com> + + * arm.c (count_insns_for_constant): Rework to support counting for + thumb2 immediates as well. + (find_best_start): Split out from arm_gen_constant. + (arm_gen_constant): Rework to support XOR with immediate. + +2009-10-29 Chao-ying Fu <fu@mips.com> + + * config/mips/mips.c (mips_emit_unary, mips_force_unary): New + functions. + (mips_expand_synci_loop): Use the length rtx to control the + synci loop from the begin rtx that points to the first byte of + the cache line. + +2009-10-28 Rafael Avila de Espindola <espindola@google.com> + + * doc/invoke.texi: Rename -use-linker-plugin -fuse-linker-plugin. + +2009-10-28 Rafael Avila de Espindola <espindola@google.com> + + * dbxout.c (dbxout_common_check): Accept non public trees. + * dwarf2out.c (fortran_common): Accept non public trees. + +2009-10-28 Rafael Avila de Espindola <espindola@google.com> + + * common.opt (fuse-linker-plugin): New option. + * gcc.c (LINK_COMMAND_SPEC, main): Rename use-linker-plugin to + fuse-linker-plugin. + * opts.c (common_handle_option): Ignore OPT_fuse_linker_plugin. + +2009-10-28 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/39715 + * config/arm/arm.md (cstoresi4): Use gen_cstoresi_ltu_thumb1. + (gen_cstoresi_ltu_thumb1): New splitter. + +2009-10-28 Richard Guenther <rguenther@suse.de> + + PR lto/41808 + PR lto/41839 + * tree-ssa.c (useless_type_conversion_p): Do not treat + conversions to pointers to incomplete types as useless. + * gimple.c (gimple_types_compatible_p): Compare struct tags, + not typedef names. + +2009-10-28 Jakub Jelinek <jakub@redhat.com> + + * var-tracking.c (emit_note_insn_var_location): Don't call the second + vt_expand_loc unnecessarily when location is not a register nor + memory. + + PR middle-end/41837 + * ipa-struct-reorg.c (find_field_in_struct_1): Return NULL if + fields don't have DECL_NAME. + + PR debug/41801 + * builtins.c (get_builtin_sync_mem): Expand loc in ptr_mode, + call convert_memory_address on addr. + + PR target/41762 + * config/i386/i386.c (ix86_pic_register_p): Don't call + rtx_equal_for_cselib_p for VALUEs discarded as useless. + +2009-10-28 Richard Sandiford <rdsandiford@googlemail.com> + + * var-tracking.c (emit_note_insn_var_location): Get the mode of + a variable part from its REG, MEM or VALUE. + +2009-10-28 Richard Guenther <rguenther@suse.de> + + * gimple.c (gimple_get_alias_set): Fix comment typo. + +2009-10-28 Richard Guenther <rguenther@suse.de> + + * tree.c (free_lang_data_in_type): Do not call get_alias_set. + (free_lang_data): Unconditionally compute alias sets for all + standard integer types. Bail out if gate bailed out previously. + Do not reset the types_compatible_p langhook. + (gate_free_lang_data): Remove. + (struct pass_ipa_free_lang_data): Enable unconditionally. + * gimple.c (gimple_get_alias_set): Use the same alias-set for + all pointer types. + +2009-10-28 Richard Guenther <rguenther@suse.de> + + PR middle-end/41855 + * tree-ssa-alias.c (refs_may_alias_p_1): Deal with CONST_DECLs + (ref_maybe_used_by_call_p_1): Fix bcopy handling. + (call_may_clobber_ref_p_1): Likewise. + * tree-ssa-structalias.c (find_func_aliases): Likewise. + * alias.c (nonoverlapping_memrefs_p): Deal with CONST_DECLs. + +2009-10-28 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/41812 + + Revert: + 2009-06-27 Paolo Bonzini <bonzini@gnu.org> + + * df-problems.c (df_md_scratch): New. + (df_md_alloc, df_md_free): Allocate/free it. + (df_md_local_compute): Only include live registers in init. + (df_md_transfer_function): Prune the in-set computed by + the confluence function, and the gen-set too. + +2009-10-28 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/39715 + * combine.c (simplify_comparison): Use extensions to + widen comparisons. Try an ANDing first. + +2009-10-28 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/40741 + * config/arm/arm.c (thumb1_rtx_costs): IOR or XOR with + a small constant is cheap. + * config/arm/arm.md (andsi3, iorsi3): Try to place the result of + force_reg on the LHS. + (xorsi3): Likewise, and split the XOR if the constant is complex + and not in Thumb mode. + +2009-10-28 Paolo Bonzini <bonzini@gnu.org> + + * expmed.c (emit_store_flag): Check costs before + transforming to the opposite representation. + +2009-10-28 Paolo Bonzini <bonzini@gnu.org> + + * config/sh/sh.md (cbranchfp4_media): Remove hack extending + cstore result to DImode. + +2009-10-28 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.md (stuff_delay_slot): Move const_int pattern + inside the unspec vector. + +2009-10-27 Richard Henderson <rth@redhat.com> + + * cgraphunit.c (cgraph_optimize): Maintain timevar stack properly. + +2009-10-27 Richard Henderson <rth@redhat.com> + + PR c++/41819 + * tree-eh.c (eh_region_may_contain_throw_map): Rename from + eh_region_may_contain_throw; update users. + (eh_region_may_contain_throw): New function. + (lower_catch): Check flag_exceptions before creating exception region. + (lower_eh_filter, lower_eh_must_not_throw): Likewise. + (lower_cleanup): Tidy existing flag_exceptions check to match. + +2009-10-27 Kai Tietz <kai.tietz@onevision.com> + + PR/41799 + * config/i386/mingw32.h (CHECK_EXECUTE_STACK_ENABLED): New macro. + * config/i386/mingw.opt: Add fset-stack-executable. + * config/i386/i386.c (ix86_trampoline_init): Make call to + emit_library_call conditional, if CHECK_EXECUTE_STACK_ENABLED is + defined and its value is not zero. + * doc/invoke.texi + +2009-10-27 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (find_func_aliases): In IPA mode + handle calls to externally visible functions like in regular mode. + (create_variable_info_for): Do not create function infos here. + (have_alias_info): Remove write-only variable. + (solve_constraints): New function split out from common code + in compute_points_to_sets and ipa_pta_execute. + (compute_points_to_sets): Adjust. + (ipa_pta_execute): Likewise. Handle clones and externally visible + functions like in non-IPA mode. + +2009-10-27 Jakub Jelinek <jakub@redhat.com> + + PR c/41842 + * c-typeck.c (convert_arguments): Return -1 if any of the arguments is + error_mark_node. + +2009-10-27 Richard Guenther <rguenther@suse.de> + + * tree-complex.c (expand_complex_div_wide): Check for + INTEGER_CST, not TREE_CONSTANT on comparison folding result. + +2009-10-27 Revital Eres <eres@il.ibm.com> + + PR tree-optimization/40648 + * tree-vect-data-refs.c (vect_enhance_data_refs_alignment): + Change decision of when to peel for alignment. + +2009-10-27 Richard Guenther <rguenther@suse.de> + + PR lto/41821 + * gimple.c (gimple_types_compatible_p): Handle OFFSET_TYPE. + +2009-10-27 Aldy Hernandez <aldyh@redhat.com> + + PR bootstrap/41451 + * fold-const.c (fold_binary_loc): Do not call + protected_set_expr_location. + +2009-10-27 Wei Guozhi <carrot@google.com> + + PR target/41705 + * target.h (have_conditional_execution): Add a new target hook + function. + * target-def.h (TARGET_HAVE_CONDITIONAL_EXECUTION): Likewise. + * targhooks.h (default_have_conditional_execution): Likewise. + * targhooks.c (default_have_conditional_execution): Likewise. + * doc/tm.texi (TARGET_HAVE_CONDITIONAL_EXECUTION): Document it. + * config/arm/arm.c (TARGET_HAVE_CONDITIONAL_EXECUTION): Define it. + (arm_have_conditional_execution): New function. + * ifcvt.c (noce_process_if_block, find_if_header, + cond_exec_find_if_block, dead_or_predicable): Change the usage of + macro HAVE_conditional_execution to a target hook call. + * recog.c (peephole2_optimize): Likewise. + * sched-rgn.c (add_branch_dependences): Likewise. + * final.c (asm_insn_count, final_scan_insn): Likewise. + * bb-reorder.c (HAVE_conditional_execution): Remove it. + +2009-10-26 Ben Elliston <bje@au.ibm.com> + Michael Meissner <meissner@linux.vnet.ibm.com> + Ulrich Weigand <uweigand@de.ibm.com> + + * config.gcc (spu-*-elf*): Add spu_cache.h to extra_headers. + * config/spu/spu_cache.h: New file. + + * config/spu/cachemgr.c: New file. + * config/spu/cache.S: New file. + + * config/spu/spu.h (ASM_OUTPUT_SYMBOL_REF): Define. + (ADDR_SPACE_EA): Define. + (TARGET_ADDR_SPACE_KEYWORDS): Define. + * config/spu/spu.c (EAmode): New macro. + (TARGET_ADDR_SPACE_POINTER_MODE): Define. + (TARGET_ADDR_SPACE_ADDRESS_MODE): Likewise. + (TARGET_ADDR_SPACE_LEGITIMATE_ADDRESS_P): Likewise. + (TARGET_ADDR_SPACE_LEGITIMIZE_ADDRESS): Likewise. + (TARGET_ADDR_SPACE_SUBSET_P): Likewise. + (TARGET_ADDR_SPACE_CONVERT): Likewise. + (TARGET_ASM_SELECT_SECTION): Likewise. + (TARGET_ASM_UNIQUE_SECTION): Likewise. + (TARGET_ASM_UNALIGNED_SI_OP): Likewise. + (TARGET_ASM_ALIGNED_DI_OP): Likewise. + (ea_symbol_ref): New function. + (spu_legitimate_constant_p): Handle __ea qualified addresses. + (spu_addr_space_legitimate_address_p): New function. + (spu_addr_space_legitimize_address): Likewise. + (cache_fetch): New global. + (cache_fetch_dirty): Likewise. + (ea_alias_set): Likewise. + (ea_load_store): New function. + (ea_load_store_inline): Likewise. + (expand_ea_mem): Likewise. + (spu_expand_mov): Handle __ea qualified memory references. + (spu_addr_space_pointer_mode): New function. + (spu_addr_space_address_mode): Likewise. + (spu_addr_space_subset_p): Likewise. + (spu_addr_space_convert): Likewise. + (spu_section_type_flags): Handle "._ea" section. + (spu_select_section): New function. + (spu_unique_section): Likewise. + * config/spu/spu-c.c (spu_cpu_cpp_builtins): Support __EA32__ + and __EA64__ predefined macros. + * config/spu/spu-elf.h (LIB_SPEC): Handle -mcache-size= and + -matomic-updates switches. + + * config/spu/t-spu-elf (MULTILIB_OPTIONS): Define. + (EXTRA_MULTILIB_PARTS): Add libgcc_cachemgr.a, + libgcc_cachemgr_nonatomic.a, libgcc_cache8k.a, libgcc_cache16k.a, + libgcc_cache32k.a, libgcc_cache64k.a, libgcc_cache128k.a. + ($(T)cachemgr.o, $(T)cachemgr_nonatomic.o): New target. + ($(T)cache8k.o, $(T)cache16k.o, $(T)cache32k.o, $(T)cache64k.o, + $(T)cache128k.o): Likewise. + ($(T)libgcc_%.a): Likewise. + + * config/spu/spu.h (TARGET_DEFAULT): Add MASK_ADDRESS_SPACE_CONVERSION. + * config/spu/spu.opt (-mea32/-mea64): Add switches. + (-maddress-space-conversion): Likewise. + (-mcache-size=): Likewise. + (-matomic-updates): Likewise. + * doc/invoke.texi (-mea32/-mea64): Document. + (-maddress-space-conversion): Likewise. + (-mcache-size=): Likewise. + (-matomic-updates): Likewise. + +2009-10-26 Ben Elliston <bje@au.ibm.com> + Michael Meissner <meissner@linux.vnet.ibm.com> + Ulrich Weigand <uweigand@de.ibm.com> + + * doc/tm.texi (TARGET_ADDR_SPACE_KEYWORDS): Document. + + * c-common.c (c_common_reswords): If TARGET_ADDR_SPACE_KEYWORDS is + defined, add the named address space keywords. + (c_addr_space_name): New function. + (complete_array_type): Preserve named address space. + (handle_mode_attribute): Use targetm.addr_space.valid_pointer_mode + instead of targetm.valid_pointer_mode. + + * c-common.h (enum rid): Add RID_ADDR_SPACE_0 .. RID_ADDR_SPACE_15, + RID_FIRST_ADDR_SPACE and RID_LAST_ADDR_SPACE. + (ADDR_SPACE_KEYWORD): New macro. + (c_addr_space_name): Add prototype. + + * c-tree.h (struct c_declspecs): Add address_space member. + (declspecs_add_addrspace): Add prototype. + + * c-pretty-print.c (pp_c_type_qualifier_list): Handle address spaces. + + * c-parser.c (c_parse_init): Add assertion. + (typedef enum c_id_kind): Add C_ID_ADDRSPACE. + (c_lex_one_token): Handle address space keywords. + (c_token_starts_typename): Likewise. + (c_token_starts_declspecs): Likewise. + (c_parser_declspecs): Likewise. + (c_parser_postfix_expression_after_paren_type): Diagnose compound + literal within function qualified with named address space. + + * c-decl.c (diagnose_mismatched_decls): Diagnose conflicting named + address space qualifiers. + (shadow_tag_warned): Warn about useless address space qualifiers. + (quals_from_declspecs): Handle address space qualifiers. + (grokdeclarator): Likewise. + (build_null_declspecs): Likewise. + (declspecs_add_addrspace): New function. + + * c-typeck.c (addr_space_superset): New function. + (qualify_type): Handle named address spaces. + (composite_type): Likewise. + (common_pointer_type): Likewise. + (comp_target_types): Likewise. + (build_conditional_expr): Likewise. + (handle_warn_cast_qual): Likewise. + (build_c_cast): Likewise. + (convert_for_assignment): Likewise. + (build_binary_op): Likewise. + (pointer_diff): Handle named address spaces. Use intermediate + integer type of sufficient size if required. + +2009-10-26 Ben Elliston <bje@au.ibm.com> + Michael Meissner <meissner@linux.vnet.ibm.com> + Ulrich Weigand <uweigand@de.ibm.com> + + * doc/tm.texi (TARGET_ADDR_SPACE_POINTER_MODE): Document. + (TARGET_ADDR_SPACE_ADDRESS_MODE): Likewise. + (TARGET_ADDR_SPACE_VALID_POINTER_MODE): Likewise. + + * target.h (struct target_def): Add pointer_mode, address_mode, + and valid_pointer_mode to addr_space substructure. + * target-def.h (TARGET_ADDR_SPACE_POINTER_MODE): Define. + (TARGET_ADDR_SPACE_ADDRESS_MODE): Likewise. + (TARGET_ADDR_SPACE_VALID_POINTER_MODE): Likewise. + (TARGET_ADDR_SPACE_HOOKS): Add them. + * targhooks.c (target_default_pointer_address_modes_p): New function. + * target.h (target_default_pointer_address_modes_p): Add prototype. + * targhooks.c (default_addr_space_pointer_mode): New function. + (default_addr_space_address_mode): Likewise. + (default_addr_space_valid_pointer_mode): Likewise. + * targhooks.h (default_addr_space_pointer_mode): Add prototype. + (default_addr_space_address_mode): Likewise. + (default_addr_space_valid_pointer_mode): Likewise. + * output.h (default_valid_pointer_mode): Move to ... + * targhooks.h (default_valid_pointer_mode): ... here. + * varasm.c (default_valid_pointer_mode): Move to ... + * targhooks.c (default_valid_pointer_mode): ... here. + + * varasm.c (output_constant): Use targetm.addr_space.valid_pointer_mode + instead of targetm.valid_pointer_mode. + + * fold-const.c (fit_double_type): Use int_or_pointer_precision. + * tree.c (integer_pow2p): Likewise. + (tree_log2): Likewise. + (tree_floor_log2): Likewise. + (signed_or_unsigned_type_for): Support pointer type of different size. + (int_or_pointer_precision): New function. + * tree.h (int_or_pointer_precision): Add prototype. + * stor-layout.c (layout_type): Set TYPE_PRECISION for offset types. + * varasm.c (initializer_constant_valid_p): Use TYPE_PRECISION of + incoming pointer type instead of POINTER_SIZE. + + * tree.c (build_pointer_type): Use appropriate pointer mode + instead of ptr_mode. + (build_reference_type): Likewise. + * expr.c (store_expr): Likewise. + (expand_expr_addr_expr): Likewise. + * tree-vect-data-refs.c (vect_create_data_ref_ptr): Likewise. + * cfgexpand.c (expand_debug_expr): Likewise. + + * auto-inc-dec.c: Include "target.h". + (try_merge): Use appropriate address mode instead of Pmode. + (find_inc): Likewise. + * combine.c (find_split_point): Likewise. + * cselib.c (cselib_record_sets): Likewise. + * dse.c (replace_inc_dec): Likewise. + (canon_address): Likewise. + * var-tracking.c (replace_expr_with_values): Likewise. + (count_uses): Likewise. + (add_uses): Likewise. + (add_stores): Likewise. + * emit-rtl.c: Include "target.h". + (adjust_address_1): Use appropriate address mode instead of Pmode. + (offset_address): Likewise. + * explow.c (break_out_memory_refs): Likewise. + (memory_address_addr_space): Likewise. + (promote_mode): Likewise. + * expr.c (move_by_pieces): Likewise. + (emit_block_move_via_loop): Likewise. + (store_by_pieces): Likewise. + (store_by_pieces_1): Likewise. + (expand_assignment): Likewise. + (store_constructor): Likewise. + (expand_expr_addr_expr): Likewise. + (expand_expr_real_1): Likewise. + * cfgexpand.c (expand_debug_expr): Likewise. + * ifcvt.c (noce_try_cmove_arith): Likewise. + * regcprop.c (kill_autoinc_value): Likewise. + * regmove.c (try_auto_increment): Likewise. + * reload.c (find_reloads): Likewise. + (find_reloads_address): Likewise. + (find_reloads_address_1): Likewise. + * sched-deps.c: Include "target.h". + (sched_analyze_1): Use appropriate address mode instead of Pmode. + (sched_analyze_2): Likewise. + * sel-sched-dump.c: Include "target.h". + (debug_mem_addr_value): Use appropriate address mode instead of Pmode. + * stor-layout.c (layout_type): Likewise. + * tree-ssa-loop-ivopts.c (produce_memory_decl_rtl): Likewise. + (multiplier_allowed_in_address_p): Likewise. + (get_address_cost): Likewise. + * varasm.c (make_decl_rtl): Likewise. + + * expr.c (expand_assignment): Always convert offsets to appropriate + address mode. + (store_expr): Likewise. + (store_constructor): Likewise. + (expand_expr_real_1): Likewise. + + * reload.h (form_sum): Add MODE argument. + * reload.c (form_sum): Add MODE argument, use it instead of Pmode. + Update recursive calls. + (subst_indexed_address): Update calls to form_sum. + + * tree-flow.h (addr_for_mem_ref): Add ADDRSPACE argument. + * tree-ssa-address.c: Include "target.h". + (templates): Replace by ... + (mem_addr_template_list): ... this new vector. + (TEMPL_IDX): Handle address space numbers. + (gen_addr_rtx): Add address mode argument, use it instead of Pmode. + (addr_for_mem_ref): Add ADDRSPACE argument. Use per-address-space + instead of global cache. Update call to gen_addr_rtx. + (valid_mem_ref_p): Update call to addr_for_mem_ref. + * expr.c (expand_expr_real_1): Update call to addr_for_mem_ref. + + * rtl.h (convert_memory_address_addr_space): Add prototype. + (convert_memory_address): Define as macro. + * explow.c (convert_memory_address): Rename to ... + (convert_memory_address_addr_space): ... this. Add ADDRSPACE argument. + Use appropriate pointer and address modes instead of ptr_mode / Pmode. + Update recursive calls. + (memory_address_addr_space): Call convert_memory_address_addr_space. + * expmed.c (make_tree): Likewise. + * expr.c (expand_assignment): Likewise. + (expand_expr_addr_expr_1): Likewise. Also, add ADDRSPACE argument. + (expand_expr_addr_expr): Likewise. Also, update call. + + * alias.c (find_base_value): Guard pointer size optimizations. + (find_base_term): Likewise. + * rtlanal.c (nonzero_bits1): Likewise. + (num_sign_bit_copies1): Likewise. + * simplify-rtx.c (simplify_unary_operation_1): Likewise. + + * Makefile.in (tree-ssa-address.o): Add $(TARGET_H) dependency. + (emit-rtl.o): Likewise. + (auto-inc-dec.o): Likewise. + (sched-deps.o): Likewise. + +2009-10-26 Ben Elliston <bje@au.ibm.com> + Michael Meissner <meissner@linux.vnet.ibm.com> + Ulrich Weigand <uweigand@de.ibm.com> + + * doc/extend.texi (Named Address Spaces): New section. + * coretypes.h (addr_space_t): New type. + (ADDR_SPACE_GENERIC): New define. + (ADDR_SPACE_GENERIC_P): New macro. + + * doc/tm.texi (Named Address Spaces): New section. + (TARGET_ADDR_SPACE_LEGITIMATE_ADDRESS_P): Document. + (TARGET_ADDR_SPACE_LEGITIMIZE_ADDRESS): Document. + (TARGET_ADDR_SPACE_SUBSET_P): Document. + (TARGET_ADDR_SPACE_CONVERT): Document. + * target.h (struct gcc_target): Add addr_space substructure. + * target-def.h (TARGET_ADDR_SPACE_LEGITIMATE_ADDRESS_P): Define. + (TARGET_ADDR_SPACE_LEGITIMIZE_ADDRESS): Likewise. + (TARGET_ADDR_SPACE_SUBSET_P): Likewise. + (TARGET_ADDR_SPACE_CONVERT): Likewise. + (TARGET_ADDR_SPACE_HOOKS): Likewise. + (TARGET_INITIALIZER): Initialize addr_space hooks. + * targhooks.c (default_addr_space_legitimate_address_p): New function. + (default_addr_space_legitimize_address): Likewise. + (default_addr_space_subset_p): Likewise. + (default_addr_space_convert): Likewise. + * targhooks.h (default_addr_space_legitimate_address_p): Add prototype. + (default_addr_space_legitimize_address): Likewise. + (default_addr_space_subset_p): Likewise. + (default_addr_space_convert): Likewise. + + * doc/rtl.texi (MEM_ADDR_SPACE): Document. + * rtl.h (mem_attrs): Add ADDRSPACE memory attribute. + (MEM_ADDR_SPACE): New macro. + * emit-rtl.c (get_mem_attrs): Add ADDRSPACE argument and set + address space memory attribute. + (mem_attrs_htab_hash): Handle address space memory attribute. + (mem_attrs_htab_eq): Likewise. + (set_mem_attributes_minus_bitpos): Likewise. + (set_mem_alias_set): Likewise. + (set_mem_align): Likewise. + (set_mem_expr): Likewise. + (set_mem_offset): Likewise. + (set_mem_size): Likewise. + (adjust_address_1): Likewise. + (offset_address): Likewise. + (widen_memoy_address): Likewise. + (get_spill_slot_decl): Likewise. + (set_mem_attrs_for_spill): Likewise. + (set_mem_addr_space): New function. + * emit-rtl.h (set_mem_addr_space): Add prototype. + * print-rtl.c (print_rtx): Print address space memory attribute. + * expr.c (expand_assignment): Set address space memory attribute + of generated MEM RTXes as appropriate. + (expand_expr_real_1): Likewise. + * cfgexpand.c (expand_debug_expr): Likewise. + * tree-ssa-loop-ivopts.c (produce_memory_decl_rtl): Likewise. + + * tree.h (struct tree_base): Add address_space bitfield. Reduce + size of "spare" bitfield. + (TYPE_ADDR_SPACE): New macro. + (ENCODE_QUAL_ADDR_SPACE): Likewise. + (DECODE_QUAL_ADDR_SPACE): Likewise. + (CLEAR_QUAL_ADDR_SPACE): Likewise. + (KEEP_QUAL_ADDR_SPACE): Likewise. + (TYPE_QUALS): Encode type address space. + (TYPE_QUALS_NO_ADDR_SPACE): New macro. + * tree.c (set_type_quals): Set type address space. + (build_array_type): Inherit array address space from element type. + * print-tree.c (print_node_brief): Print type address space. + (print_node): Likewise. + * tree-pretty-print.c (dump_generic_node): Likewise. + + * explow.c (memory_address): Rename to ... + (memory_address_addr_space): ... this. Add ADDRSPACE argument. + Use address-space aware variants of memory address routines. + * recog.c (memory_address_p): Rename to ... + (memory_address_addr_space_p): ... this. Add ADDSPACE argument. + Use address-space aware variants of memory address routines. + (offsettable_address_p): Rename to ... + (offsettable_address_addr_space_p): ... this. Add ADDRSPACE argument. + Use address-space aware variants of memory address routines. + * reload.c (strict_memory_address_p): Rename to ... + (strict_memory_address_addr_space_p): ... this. Add ADDSPACE argument. + Use address-space aware variants of memory address routines. + (maybe_memory_address_p): Rename to ... + (maybe_memory_address_addr_space_p): ... this. Add ADDSPACE argument. + Use address-space aware variants of memory address routines. + * expr.h (memory_address_addr_space): Add prototype. + (memory_address): Define as macro. + * recog.h (memory_address_addr_space_p): Add prototype. + (memory_address_p): Define as macro. + (offsettable_address_addr_space_p): Add prototype. + (offsettable_address_p): Define as macro. + (strict_memory_address_addr_space_p): Add prototype. + (strict_memory_address_p): Define as macro. + + * combine.c (find_split_point): Use address-space aware variants + of memory address routines. + * emit-rtl.c (operand_subword): Likewise. + (change_address_1): Likewise. + (adjust_address_1): Likewise. + (offset_address): Likewise. + * expr.c (emit_move_insn): Likewise. + (expand_assignment): Likewise. + (expand_expr_real_1): Likewise. + * recog.c (verify_changes): Likewise. + (general_operand): Likewise. + (offsettable_memref_p): Likewise. + (offsettable_nonstrict_memref_p): Likewise. + (constrain_operands): Likewise. + * reload.c (get_secondary_mem): Likewise. + (find_reloads_toplev): Likewise. + (find_reloads_address): Likewise. + (find_reloads_subreg_address): Likewise. + * reload1.c (reload): Likewise. + * rtlhooks.c (gen_lowpart_if_possible): Likewise. + * rtl.h (address_cost): Add ADDRSPACE argument. + * rtlanal.c (address_cost): Add ADDRSPACE argument. Use address-space + aware variant of memory address routines. + * loop-invariant.c (create_new_invariant): Update address_cost call. + * tree-ssa-loop-ivopts.c (computation_cost): Likewise. + * fwprop.c (should_replace_address): Add ADDRSPACE argument. + Use address-space aware variant of memory address routines. + (propagate_rtx_1): Update call to should_replace_address. + * tree-flow.h (multiplier_allowed_in_address_p): Add ADDRSPACE + argument. + * tree-ssa-loop-ivopts.c (multiplier_allowed_in_address_p): Add + ADDRSPACE argument. Use per-address-space instead of global cache. + Use address-space aware variant of memory address routines. + (get_address_cost): Likewise. + (get_computation_cost_at): Update calls. + * tree-ssa-address.c (valid_mem_ref_p): Add ADDRSPACE argument. + Use address-space aware variant of memory address routines. + (create_mem_ref_raw): Update call to valid_mem_ref_p. + (most_expensive_mult_to_index): Update call to + multiplier_allowed_in_address_p. + + * dwarf2out.c (modified_type_die): Output DW_AT_address_class + attribute to indicate named address spaces. + + * varasm.c (get_variable_section): DECLs in named address spaces + cannot be "common". + + * reload.c (find_reloads_address): Do not use LEGITIMIZE_RELOAD_ADDRESS + for addresses in a non-generic address space. + + * expr.c (emit_block_move_hints): Do not use libcalls for + memory in non-generic address spaces. + (clear_storage_hints): Likewise. + (expand_assignment): Likewise. + + * fold-const.c (operand_equal_p): Expressions refering to different + address spaces are not equivalent. + + * rtl.c (rtx_equal_p_cb): MEMs refering to different address + spaces are not equivalent. + (rtx_equal_p): Likewise. + * cse.c (exp_equiv_p): Likewise. + * jump.c (rtx_renumbered_equal_p): Likewise. + * reload.c (operands_match_p): Likewise. + + * alias.c (nonoverlapping_memrefs_p): MEMs refering to different + address spaces may alias. + (true_dependence): Likewise. + (canon_true_dependence): Likewise. + (write_dependence_p): Likewise. + + * dse.c (canon_address): Handle named address spaces. + * ifcvt.c (noce_try_cmove_arith): Likewise. + + * tree.def (ADDR_SPACE_CONVERT_EXPR): New tree code. + * expr.c (expand_expr_real_2): Expand ADDR_SPACE_CONVERT_EXPR. + * convert.c (convert_to_pointer): Generate ADDR_SPACE_CONVERT_EXPR + to handle conversions between different address spaces. + * fold-const.c (fold_convert_loc): Likewise. + (fold_unary_loc): Handle ADDR_SPACE_CONVERT_EXPR. + * tree-pretty-print.c (dump_generic_node): Likewise. + * gimple-pretty-print.c (dump_unary_rhs): Likewise. + * tree-cfg.c (verify_gimple_assign_unary): Likewise. + * tree-inline.c (estimate_operator_cost): Likewise. + * tree-ssa.c (useless_type_conversion_p): Conversions between pointers + to different address spaces are not useless. + +2009-10-26 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/41345 + * cfgcleanup.c (trivially_empty_bb_p): New function. + (try_optimize_bb): Use it instead of checking BB_HEAD == BB_END. + + PR debug/41828 + * dwarf2out.c (add_pubname, add_pubtype, generic_parameter_die, + add_name_and_src_coords_attributes, gen_namespace_die, + dwarf2out_set_name): Handle dwarf2_name returning NULL. + +2009-10-26 Nick Clifton <nickc@redhat.com> + + * config.gcc: Add support for RX target. + * config/rx: New directory. + * config/rx/constraints.md: New file. + * config/rx/predicates.md: New file. + * config/rx/rx.c: New file. + * config/rx/rx.h: New file. + * config/rx/rx.md: New file. + * config/rx/rx.opt: New file. + * config/rx/rx-protos.h: New file. + * config/rx/t-rx: New file. + * doc/extend.texi: Document RX function attributes. + * doc/invoke.texi: Document RX specific command line options. + * doc/contrib.texi: Document RX contribution. + * doc/md.texi: Document RX constraints. + * doc/install.texi: Document RX support. + +2009-10-26 Michael Matz <matz@suse.de> + + PR tree-optimization/41783 + * tree-ssa-alias.c (get_continuation_for_phi): Export, add a special + case for simple diamonds. + * tree-ssa-alias.h (get_continuation_for_phi): Declare. + * tree-ssa-pre.c (translate_vuse_through_block): Add same_valid + argument, use alias oracle to skip some vdefs. + (phi_translate_1): Change call to above, don't allocate new + value ids if they can stay the same. + (compute_avail): Allow vuse walking when looking up references. + +2009-10-26 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41826 + * tree-ssa-structalias.c (get_constraint_for_ptr_offset): Avoid + access to re-allocated vector fields. + +2009-10-26 Richard Guenther <rguenther@suse.de> + + * graphite-sese-to-poly.c (check_poly_representation): Fix + compile without checking. + +2009-10-26 Janus Weil <janus@gcc.gnu.org> + + PR fortran/41714 + * gimple.h (tree_annotate_all_with_location): Remove prototype. + * gimplify.c (tree_should_carry_location_p, + tree_annotate_one_with_location,tree_annotate_all_with_location): + Remove obsolete functions. + +2009-10-25 Kaz Kojima <kkojima@gcc.gnu.org> + + PR target/41813 + * config/sh/sh.md (stuff_delay_slot): Don't set T_REG in pattern. + +2009-10-25 Richard Guenther <rguenther@suse.de> + + * lto-streamer-in.c (unpack_ts_decl_common_value_fields): + Stream DECL_RESTRICTED_P. + * lto-streamer-out.c (pack_ts_decl_common_value_fields): Likewise. + +2009-10-25 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.c (mips_restore_gp_from_cprestore_slot): Emit + a note when expanding to nothing. + +2009-10-25 Richard Guenther <rguenther@suse.de> + + PR middle-end/41814 + * tree.c (find_decls_types_r): Deal with Java overloading + BINFO_VIRTUALS for its own purpose. + +2009-10-24 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/predicates.md (hilo_operand): New predicate. + * config/mips/mips.md (<u>mulsidi3_64bit): Change it to a + define_insn. Correct !ISA_HAS_EXT_INS length from 24 to 28. Move + splitter part from here ...: + (<u>mulsidi3_64bit splitter for !ISA_HAS_EXT_INS): ... to here. Swap + op0 and op4 to match the DINS case. + (<u>mulsidi3_64bit splitter for ISA_HAS_EXT_INS): New splitter. + +2009-10-24 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + PR middle-end/19154 + * avr.md (QIDI): Add new mode iterator. + (sbrx_branch<mode>): Create new zero extract bit, test and jump + patterns for all QI thru DI modes combinations. + (sbrx_and_branch<mode>): Create new and based bit test and jump + patterns for QI thru SI modes. + avr.c (avr_out_sbxx_branch): Use only bit number. + +2009-10-24 Jan Hubicka <jh@suse.cz> + + * ipa-reference.c (check_call): Noreturn notrhow calls do not write + to memory. + (analyze_function): When analyzing noreturn nothrow call, do not + compute written stats; free bitmaps of vars early if possible. + (generate_summary): Only update bitmaps if computed. + (propagate): Only dump bitmaps if computed. + (ipa_reference_read_summary): Fix pasto. + +2009-10-24 Eric Botcazou <ebotcazou@adacore.com> + + * tree-ssa-alias.c (nonaliasing_component_refs_p): Rename into... + (aliasing_component_refs_p): ...this. Return true if there is no + common base and the base access types have the same alias set. + (indirect_ref_may_alias_decl_p): Adjust for above renaming. + (indirect_refs_may_alias_p): Likewise. + +2009-10-23 Joseph Myers <joseph@codesourcery.com> + + PR c/40033 + * c-typeck.c (c_finish_stmt_expr): Do not wrap error_mark_node in + a C_MAYBE_CONST_EXPR. + +2009-10-23 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR target/41787 + * config/rs6000/rs6000.c (struct machine_function): Add + vsx_or_altivec_used_p to record if vector types are used. + (rs6000_expand_to_rtl_hook): Rename from + rs6000_alloc_sdmode_stack_slot. If VSX, check to see if there are + any vector operations, so if there are, we can set VRSAVE to + non-zero when only floating point vector registers are used. + (TARGET_EXPAND_TO_RTL_HOOK): Use rs6000_expand_to_rtl_hook. + (rs6000_check_vector_mode): Inner function to check if vector + types are used in the code. + (compute_vrsave_mask): If VSX, make sure VRSAVE is non-zero if + vector instructions are used. + + * config/rs6000/rs6000.h (HARD_REGNO_CALL_PART_CLOBBERED): + Indicate that VSX registers which overlap floating point + registers, can't be used across a call, since the ABI only states + the scalar part of the register will be saved and restored. + +2009-10-23 Joseph Myers <joseph@codesourcery.com> + + PR c/41673 + * alias.c (get_alias_set): Call langhook before returning 0 for + types with structural equality. + * c-common.c (c_common_get_alias_set): Use alias set of element + type for arrays with structural comparison. + +2009-10-23 Richard Guenther <rguenther@suse.de> + + PR middle-end/41805 + * cfgexpand.c (expand_call_stmt): Use gimple_has_side_effects and + gimple_call_nothrow_p. + +2009-10-23 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41778 + * tree-ssa-pre.c (do_regular_insertion): Only insert if a + redundancy along a path in the CFG we want to optimize for speed + is going to be removed. + (execute_pre): Do partial-PRE only if the function is to be + optimized for speed. + (gate_pre): Do not turn off all of PRE when not optimizing a + function for speed. + +2009-10-23 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * builtins.c (fold_builtin_cabs): Use validate_arg(). + (fold_builtin_cexp): Fix if-logic. + (fold_builtin_1): Check subtype for BUILT_IN_CIMAG. + +2009-10-22 Jeff Law <law@redhat.com> + + * ira-lives.c (process_single_reg_class_operands): Update the + hard reg costs for all the hard registers desired by the + single reg class operand. + +2009-10-22 Richard Sandiford <rdsandiford@googlemail.com> + + * simplify-rtx.c (simplify_replace_fn_rtx): Add a fallback case + for rtxes that aren't handled specially. + +2009-10-22 Richard Sandiford <rdsandiford@googlemail.com> + + * rtl.h (shallow_copy_rtvec): Declare. + * rtl.c (shallow_copy_rtvec): New function. + * cselib.c (cselib_subst_to_values): Use it. Only modify an + rtx field if the subrtx has changed. + +2009-10-22 Anatoly Sokolov <aesok@post.ru> + + * config/m32c/m32c.c (m32c_function_value_regno_p): New function. + (m32c_function_value): Make static, add new 'outgoing' argument. + (m32c_libcall_value): Make static, add new 'fun' argument. + (TARGET_FUNCTION_VALUE, TARGET_LIBCALL_VALUE): Declare. + * config/m32c/m32c.h (FUNCTION_VALUE, LIBCALL_VALUE): Remove. + (FUNCTION_VALUE_REGNO_P): Redefine, use m32c_function_value_regno_p. + * config/m32c/m32c-protos.h (m32c_function_value_regno_p): Declare. + (m32c_function_value, m32c_libcall_value): Delete declaration. + +2009-10-22 Diego Novillo <dnovillo@google.com> + + * Makefile.in (PLUGIN_HEADERS): Add output.h and IPA_UTILS_H. + +2009-10-22 Razya Ladelsky <razya@il.ibm.com> + + * tree-cfg.c (gimple_duplicate_sese_tail): Fix typos/indentation/white + space. + +2009-10-22 Richard Guenther <rguenther@suse.de> + + * lto-streamer.h (lto_symtab_merge_cgraph_nodes): Declare. + * lto-symtab.c (struct lto_symtab_entry_def): Add node member. + (lto_symtab_merge): Do not merge cgraph nodes here. + (lto_symtab_resolve_can_prevail_p): Simplify. + (lto_symtab_resolve_symbols): Store cgraph node. + (lto_symtab_merge_decls_1): Simplify. Do not drop non-prevailing + functions from the symtab. + (lto_symtab_merge_cgraph_nodes_1): New function. + (lto_symtab_merge_cgraph_nodes): Likewise. + +2009-10-22 Richard Guenther <rguenther@suse.de> + + PR lto/41791 + * lto-streamer-out.c (lto_output_location): Stream the + system header flag. + * lto-streamer-in.c (lto_input_location): Likewise. + +2009-10-22 Razya Ladelsky <razya@il.ibm.com> + + * cfgloopmanip.c (duplicate_subloops): Export. + * tree-parloops.c (loop_parallel_p): Dump if loop is innermost. + (transform_to_exit_first_loop): Duplicate bbs starting from + header up to loop->latch instead of exit->src. + Initialize control variable to the correct number of iterations. + (gather_scalar_reductions): Do not register double reductions. + (parallelize_loops): Dump which loop is tested. + Indicate whether the parallelized loop is inner or not. + Remove the innermost-loop requirement. + * cfgloop.h (duplicate_subloops): Export. + * tree-cfg.c (add_phi_args_after_redirect): New function. + (gimple_duplicate_sese_tail): Remove the no-subloops constraint. + Call duplicate_subloops. + Update number of iterations at the exit condition. + Don't redirect nexits always to the loop exit. + Redirect copied edges from latch to the loop exit. + +2009-10-22 Jan Hubicka <jh@suse.cz> + + * ipa-cp.c (ipcp_read_summary): Remove now invalid FIXME and + flag_ltrans check. + * ipa-inline.c (cgraph_mark_inline_edge, + cgraph_decide_inlining_of_small_function, + cgraph_decide_inlining, inline_read_summary): Disable indirect + inlining for WPA for time being. + + PR tree-optimize/40556 + * ipa-inline.c (cgraph_early_inlining): Fix iterations condition. + +2009-10-22 Richard Guenther <rguenther@suse.de> + + * lto-streamer.h (lto_symtab_clear_resolution): Remove. + * lto-symtab.c (lto_symtab_clear_resolution): Likewise. + +2009-10-22 Jan Hubicka <jh@suse.cz> + + PR lto/41730 + * ipa-reference.c (has_proper_scope_for_analysis): Add fixme about + global vars. + (check_call): Handle only indirect calls. + (propagate_bits): Update comment. + (write_node_summary_p): Turn bogus check to assert. + (ipa_reference_write_summary): Stream calls_read_all properly. + (ipa_reference_read_summary): Stream in calls_read_all properly. + (read_write_all_from_decl): New function. + (propagate): Handle OVERWRITABLE nodes and external calls here. + * ipa-pre-const.c (check_call): In IPA mode handle indirect + calls only. + (analyze_function): Do not check visibility here. + (add_new_function): We summary OVERWRITABLE too. + (generate_summary): Stream OVERWRITABLE nodes too. + (propagate): Handle external calls and OVERWRITABLE nodes here. + (local_pure_const): Check visibility here. + +2009-10-22 Jan Hubicka <jh@suse.cz> + + * ipa-cp.c (ipcp_write_summary, ipcp_read_summary): New functions. + (pass_ipa_cp): Register them. + (ipcp_init_stage): Analyze all functions for whopr/lto. + (ipcp_propagate_stage): Skip external calls. + (ipcp_iterate_stage): Call ipa_update_after_lto_read if needed. + * ipa-reference.c (write_node_summary_p): Fix thinko about + availability. + * cgraphunit.c (ipa_passes): When in lto, ne er produce new summaries; + when in ltrans, skip executing of ipa passes since everything + should've been done. + * ipa-inline.c (cgraph_decide_inlining): Remove FIXMEs. + (inline_generate_summary): Likewise. + (inline_read_summary): New function. + (inline_write_summary): New function. + (pass_ipa_inline): Register new hooks. + * ipa-prop.c: Inlcude lto-streamer.h + (ipa_edge_args_vector): Update declaration. + (ipa_count_arguments, ipa_compute_jump_functions, + ipa_free_edge_args_substructures): Move ipa_edge_args_vector into ggc. + (ipa_write_jump_function, ipa_read_jump_function, ipa_write_node_info, + ipa_read_node_info): New static functions. + (ipa_prop_write_jump_functions, ipa_prop_read_jump_functions): Update. + (duplicate_array): Use xmalloc. + (duplicate_ggc_array): New. + (ipa_edge_duplication_hook): Use it. + (ipa_update_after_lto_read): New function. + * ipa-prop.h (ipa_prop_write_jump_functions, + ipa_prop_read_jump_functions): Declare. + (ipa_pass_through_data, ipa_ancestor_jf_data, ipa_member_ptr_cst, + jump_func_value, ipa_member_ptr_cst, ipa_edge_args): Add GTY markers. + (ipa_edge_args_vector): Move into GGC. + (ipa_check_create_edge_args): Update. + (ipa_update_after_lto_read): New. + * passes.c (ipa_write_summaries_1): When in wpa, do not write + summaries. + (ipa_read_summaries): When in ltrans, so not read summaries. + * lto-streamer.c (lto_get_section_name): Add + LTO_section_jump_functions. + * lto-streamer.h (LTO_section_jump_functions): New section. + (produce_asm): Declare. + * lto-cgraph.c (output_cgraph): Output edges in reverse order. + * lto-streamer-out.c (produce_asm): Export. + * lto-streamer-in.c: Include tree-pass.h + (input_function): Free dominance info when done. + (lto_read_body): Push ipa_inline in ltrans stage. + * gengtype.c (open_base_files): Add ipa-prop.h into includes. + * Makefile.in (GTFILES): Add ipa-prop.h + +2009-10-22 Matthias Klose <doko@ubuntu.com> + + * doc/install.texi: Document --enable-browser-plugin. + +2009-10-21 Vladimir Makarov <vmakarov@redhat.com> + + * doc/invoke.texi (fira-loop-pressure): Update default value. + * opts.c (decode_options): Remove default value setting for + flag_ira_loop_pressure. + * config/ia64/ia64.c (ia64_override_options): Set + flag_ira_loop_pressure up for -O3. + * config/rs6000/rs6000.c (rs6000_override_options): Ditto. + +2009-10-21 Sebastian Pop <sebastian.pop@amd.com> + + PR tree-optimization/41497 + * tree-scalar-evolution.c (analyze_evolution_in_loop): Return + chrec_dont_know if the evolution function returned by follow_ssa_edge + is constant in the analyzed loop and is not compatible with the + initial value before the loop. + * tree-chrec.h (no_evolution_in_loop_p): Call STRIP_NOPS. + +2009-10-21 Joseph Myers <joseph@codesourcery.com> + + * config/sh/sh.c (nonpic_symbol_mentioned_p): Allow UNSPEC_TPOFF. + +2009-10-21 Jakub Jelinek <jakub@redhat.com> + + PR other/25507 + * doc/invoke.texi: Document -print-multi-os-directory. + +2009-10-21 Jack Howarth <howarth@bromo.med.uc.edu> + + PR c++/41313 + * gcc/config/darwin10.h: Use default_emit_unwind_label. + * gcc/config/darwin.c: Disable -freorder-blocks-and-partition + when darwin_emit_unwind_label is used. + +2009-10-21 Eric Botcazou <ebotcazou@adacore.com> + + * tree-vect-stmts.c (exist_non_indexing_operands_for_use_p): Tweak + order of checks. + +2009-10-20 Richard Henderson <rth@redhat.com> + + * tree-eh.c (lower_try_finally_copy): Do lower_eh_constructs_1 + before emit_post_landing_pad. + +2009-10-20 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.c (mips_binary_cost): Add new argument speed. + Use when calling rtx_costs. + (mips_rtx_costs): Fix formatting. Use argument speed rather than the + global optimize_size. Pass speed to mips_binary_cost. + +2009-10-20 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/rs6000.c (def_builtin): Set TREE_READONLY instead + of TREE_CONSTANT. + +2009-10-20 Richard Sandiford <rdsandiford@googlemail.com> + + * rtl.h (simplify_replace_fn_rtx): Declare. + (wrap_constant, unwrap_constant): Delete. + * cfgexpand.c (unwrap_constant, wrap_constant): Delete. + (expand_debug_expr): Don't call wrap_constant. + * combine.c (rtx_subst_pair): Only define for AUTO_INC_DEC. + (auto_adjust_pair): Fold into... + (propagate_for_debug_subst): ...here. Only define for AUTO_INC_DEC. + Just return a new value. + (propagate_for_debug): Use simplify_replace_fn_rtx for AUTO_INC_DEC, + otherwise use simplify_replace_rtx. + * cselib.c (wrap_constant): Reinstate old definition. + (cselib_expand_value_rtx_1): Don't wrap constants. + * gcse.c (try_replace_reg): Don't use copy_rtx in the call to + simplify_replace_rtx. + (bypass_block): Fix formatting in calls to simplify_replace_rtx. + * reload1.c (reload): Skip all uses for an insn before adjusting it. + Use simplify_replace_rtx. + * simplify-rtx.c (simplify_replace_fn_rtx): New function, + adapted from... + (simplify_replace_rtx): ...here. Turn into a wrapper for + simplify_replace_fn_rtx. + (simplify_unary_operation): Don't unwrap CONSTs. + * var-tracking.c (check_wrap_constant): Delete. + (vt_expand_loc_callback): Don't call it. + (vt_expand_loc): Likewise. + +2009-10-20 Pascal Obry <obry@adacore.com> + Eric Botcazou <ebotcazou@adacore.com> + + * config/i386/cygming.h (DWARF_FRAME_REGNUM): Add enclosing parens. + +2009-10-20 Michael Matz <matz@suse.de> + + * loop-invariant.c (create_new_invariant): Use different magic number. + +2009-10-20 Richard Earnshaw <rearnsha@arm.com> + + PR target/39247 + * arm.c (arm_override_options): Forcibly disable hot/cold block + partitioning. + +2009-10-20 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41739 + * haifa-sched.c (try_ready): Skip debug deps updating speculation + status. + +2009-10-20 Richard Guenther <rguenther@suse.de> + + * ggc-page.c: Include cfgloop.h. + (struct max_alignment): Drop long double, add void *. + (extra_order_size_table): Add low non-power-of-two multiples + of MAX_ALIGNMENT. Drop small type-based entries, add + tree_type, cgraph_node and loop. + * alloc-pool.c (struct allocation_object_def): Drop long double + aligning element. + +2009-10-20 Jakub Jelinek <jakub@redhat.com> + + PR debug/41340 + * loop-invariant.c (calculate_loop_reg_pressure): Don't count regs + referenced just in DEBUG_INSNs. + +2009-10-20 Richard Guenther <rguenther@suse.de> + + PR lto/41761 + * gimple.c (gimple_register_type): Make sure we register + the types main variant first. + +2009-10-20 Richard Guenther <rguenther@suse.de> + + * gimple.c (gimple_types_compatible_p): Simplify. Move + cheap checks before hashtable queries. Add checks for + TYPE_NONALIASED_COMPONENT and DECL_NONADDRESSABLE_P. + +2009-10-20 Eric Botcazou <ebotcazou@adacore.com> + + * tree-sra.c (build_ref_for_offset_1) <RECORD_TYPE>: Skip fields + without size or with size that can't be represented as a host integer. + +2009-10-20 Alexandre Oliva <aoliva@redhat.com> + + * tree-ssa-dce.c (eliminate_unnecessary_stmts): Don't regard + the removal of a debug stmt as a significant change. + +2009-10-20 Wolfgang Gellerich <gellerich@de.ibm.com> + + * config/s390/s390.md: Added agen condition to operand + forwarding bypasses. Added bypass for early address generation + use of int results. Updated comments. + +2009-10-20 Stefan Dösinger <stefan@codeweavers.com> + + * config/i386/i386.c: Remove signal.h #include. + +2009-10-20 Jie Zhang <jie.zhang@analog.com> + + * simplify-rtx.c (simplify_const_unary_operation): Handle SS_ABS. + * doc/rtl.texi: Document ss_abs. + +2009-10-19 Jakub Jelinek <jakub@redhat.com> + + * c-common.c (c_parse_error): Handle CPP_UTF8STRING. + * c-lex.c (c_lex_with_flags): Likewise. Test C_LEX_STRING_NO_JOIN + instead of C_LEX_RAW_STRINGS. + (lex_string): Handle CPP_UTF8STRING. + * c-parser.c (c_parser_postfix_expression): Likewise. + * c-pragma.h (C_LEX_RAW_STRINGS): Rename to ... + (C_LEX_STRING_NO_JOIN): ... this. + +2009-10-19 Anatoly Sokolov <aesok@post.ru> + + * config/cris/cris.c (cris_function_value, cris_libcall_value, + cris_function_value_regno_p): New functions. + (cris_promote_function_mode): Update comment. + (TARGET_FUNCTION_VALUE, TARGET_LIBCALL_VALUE): Declare. + * config/cris/cris.h (FUNCTION_VALUE, LIBCALL_VALUE): Remove. + (FUNCTION_VALUE_REGNO_P): Redefine, use cris_function_value_regno_p. + * config/cris/cris-protos.h (cris_function_value_regno_p): Declare. + +2009-10-19 Jakub Jelinek <jakub@redhat.com> + + * unwind-dw2.c (execute_stack_op): Fix operand order for + DW_OP_le, DW_OP_ge, DW_OP_lt and DW_OP_gt. + +2009-10-19 Eric Botcazou <ebotcazou@adacore.com> + + * gimple-low.c (struct lower_data): Add cannot_fallthru field. + (lower_stmt) <GIMPLE_BIND>: Add comment. + <GIMPLE_COND, GIMPLE_GOTO, GIMPLE_SWITCH>: Set cannot_fallthru to true + and return. + <GIMPLE_RETURN>: Remove the statement if cannot_fallthru is set. + Otherwise lower it and set cannot_fallthru to true. + <GIMPLE_TRY>: Update cannot_fallthru for GIMPLE_TRY_FINALLY and return. + <GIMPLE_CATCH, GIMPLE_EH_FILTER>: Set cannot_fallthru to false. + <GIMPLE_CALL>: Set cannot_fallthru to false for BUILT_IN_SETJMP and + to true for a noreturn call. Do not remove statements. + <GIMPLE_OMP_PARALLEL, GIMPLE_OMP_TASK>: Set cannot_fallthru to false. + Set cannot_fallthru to false on function exit. + (gimple_stmt_may_fallthru) <GIMPLE_SWITCH>: Really return false. + <GIMPLE_ASSIGN>: Remove. + +2009-10-19 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.c (s390_z10_optimize_cmp): Don't touch FP compares. + +2009-10-19 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.c (s390_z10_optimize_cmp): Use + next/prev_active_insn to skip DEBUG_INSNs as well. + +2009-10-19 Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (output_move_neon): Use DImode in call to + adjust_address. + +2009-10-19 Matthias Klose <doko@ubuntu.com> + + PR target/40134 + * config.gcc (arm*-*-linux-*eabi): Use config/t-slibgcc-libgcc. + +2009-10-19 Jakub Jelinek <jakub@redhat.com> + + * cfgexpand.c (expand_debug_expr): Fail if bitpos < 0 for non-MEM op0. + +2009-10-17 Andy Hutchinson <hutchinsonandy@gcc.gnu.org> + + PR middle-end/41738 + * optabs.c (expand_binop): Make mode of shift count expression mode + of shift count not target. + Remove indent nit. + +2009-10-17 Eric Botcazou <ebotcazou@adacore.com> + + * tree-nested.c (convert_nonlocal_reference_stmt) <GIMPLE_COND>: New + case. Force using values to replace references within the statement. + (convert_local_reference_stmt): Likewise. + +2009-10-17 Eric Botcazou <ebotcazou@adacore.com> + + * gimple-low.c (lower_stmt) <GIMPLE_CALL>: If the call is noreturn, + remove a subsequent GOTO or RETURN statement. + +2009-10-17 Andy Hutchinson <hutchinsonandy@aim.com> + + * config/avr.md (*movqi): Add zero as equally preferable constraint + as general register. + (*movhi): Ditto. + +2009-10-17 Eric Botcazou <ebotcazou@adacore.com> + + * print-tree.c (print_node): Fix string for DECL_STRUCT_FUNCTION. + +2009-10-17 Richard Guenther <rguenther@suse.de> + + * lto-streamer-in.c (lto_input_location): Try to reuse previous maps. + +2009-10-17 Richard Guenther <rguenther@suse.de> + + * lto-streamer-in.c (input_gimple_stmt): Fixup FIELD_DECL + operands in COMPONENT_REFs. + +2009-10-17 Anatoly Sokolov <aesok@post.ru> + + * targhooks.c (default_libcall_value): Don't use LIBCALL_VALUE macro + if not defined. Change type of second argument to const_rtx. + (default_function_value): Call gcc_unreachable if FUNCTION_VALUE + macro not defined. + * targhooks.h (default_libcall_value): Update prototype. + * target.h (struct gcc_target): Change type of second argument of + libcall_value to const_rtx. + * config/arm/arm.c (arm_libcall_value): Change type of second argument + to const_rtx. + (arm_libcall_uses_aapcs_base): Change type of argument to const_rtx. + * doc/tm.texi (TARGET_LIBCALL_VALUE): Revise documentation. + +2009-10-17 Jakub Jelinek <jakub@redhat.com> + + PR debug/40521 + * debug.h (struct gcc_debug_hooks): Add assembly_start hook. + * cgraphunit.c (cgraph_optimize): Call it. + * dwarf2out.c (dwarf2out_init): Move .cfi_sections printing into... + (dwarf2out_assembly_start): ... here. New hook. + (dwarf2out_debug_hooks): Add dwarf2out_assembly_start. + * debug.c (do_nothing_debug_hooks): Do nothing for assembly_start + hook. + * dbxout.c (dbx_debug_hooks, xcoff_debug_hooks): Likewise. + * sdbout.c (sdb_debug_hooks): Likewise. + * vmsdbgout.c (vmsdbg_debug_hooks): Add vmsdbgout_assembly_start. + (vmsdbgout_assembly_start): New hook. + +2009-10-17 Alexandre Oliva <aoliva@redhat.com> + + * rtl.h (RTL_LOCATION): Fix typo. + +2009-10-17 Alexandre Oliva <aoliva@redhat.com> + + * print-rtl.c (print_rtx): Print locators in asm_operands + and asm_input. + +2009-10-17 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41535 + * sched-deps.c (depl_on_debug_p): New. + (attach_dep_link): Reject debug deps before nondebug deps. + (add_to_deps_list): Insert debug deps after nondebug deps. + (sd_lists_empty_p): Stop at first nonempty list. Disregard debug + deps. + (sd_add_dep): Do not reject debug deps. + (add_insn_mem_dependence): Don't count debug deps. + (remove_from_deps): Likewise. + (sched_analyze_2): Set up mem deps on debug insns. + (sched_analyze_insn): Record reg uses for deps on debug insns. + * haifa-sched.c (schedule_insn): Reset deferred debug insn. Don't + try_ready nondebug insn after debug insn. + * ddg.c (create_ddg_dep_from_intra_loop_link, + create_ddg_dep_no_link): Don't reject debug deps. + +2009-10-16 Richard Guenther <rguenther@suse.de> + + * lto-symtab.c (merge_incomplete_and_complete_type): Remove. + (maybe_merge_incomplete_and_complete_type): Likewise. + (lto_symtab_merge): Do not call them. Do not warn for + complete vs. incomplete compatible types. + (lto_symtab_merge_decls_2): Simplify. + * gimple.c (gimple_force_type_merge): Remove. + (gimple_types_compatible_p): Make it static. + * gimple.h (gimple_force_type_merge): Remove. + (gimple_types_compatible_p): Likewise. + +2009-10-16 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (mem_loc_descriptor) <case ZERO_EXTRACT>: Cast + DWARF2_ADDR_SIZE to int to avoid signed vs. unsigned warnings. + +2009-10-16 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41728 + * tree-ssa-dom.c (optimize_stmt): Mark the stmt modified + if fold_stmt did anything. + +2009-10-16 Richard Guenther <rguenther@suse.de> + + PR lto/41715 + * lto-streamer-in.c (lto_input_tree_ref): Revert last change. + (maybe_fixup_handled_component): New function. + (input_gimple_stmt): Fixup mismatched decl replacements. + +2009-10-16 Richard Guenther <rguenther@suse.de> + + PR lto/41713 + * lto-streamer-out.c (lto_output_tree_ref): Handle DEBUG_EXPR_DECL + the same as VAR_DECL. + +2009-10-16 Richard Guenther <rguenther@suse.de> + + * gimple.c (iterative_hash_gimple_type): For integer types + also hash their minimum and maximum values and the string flag. + For array types hash their domain and the string flag. + +2009-10-16 Richard Guenther <rguenther@suse.de> + + * gimple.c (gimple_types_compatible_p): Restrict completing + types to record or unions. Simplify completion. + Do not merge records or unions with different + TYPE_STRUCTURAL_EQUALITY_P tag. + (iterative_hash_gimple_type): Restrict non-recursing into + pointer targets for records and unions. + +2009-10-15 Jakub Jelinek <jakub@redhat.com> + + PR debug/41717 + * cfgexpand.c (expand_debug_expr): Handle CONJ_EXPR. + * dwarf2out.c (mem_loc_descriptor): Don't handle + POST_INT/POST_DEC/POST_MODIFY like SUBREG. For SUBREG + punt if it is not lowpart subreg or if inner mode isn't + MODE_INT. + +2009-10-16 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.c (s390_z10_optimize_cmp): Skip notes when + investigating previous or next insns. + +2009-10-16 Eric Botcazou <ebotcazou@adacore.com> + + * tree-sra.c (build_ref_for_offset_1): Update comment. + +2009-10-16 Wolfgang Gellerich <gellerich@de.ibm.com> + + * config/s390/s390.md (atype): Added missing values. + +2009-10-15 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + PR target/41702 + * pa.md (casesi): Use sign extended index in call to gen_casesi64p. + (casesi64p): Update pattern to reflect above. + +2009-10-15 Steve Ellcey <sje@cup.hp.com> + + PR rtl-optimization/41697 + * sel-sched-ir.h (_eligible_successor_edge_p): Check successor count. + +2009-10-15 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR target/23983 + * config/rs6000/predicates.md: Update copyright year. + * config/rs6000/altivec.md: Ditto. + + * config/rs6000/t-rs6000 (TM_H): Add rs6000-builtin.def. + (MD_INCLUDES): Add a2.md. + + * config/rs6000/rs6000.c (rs6000_builtin_decls): Change + RS6000_BUILTIN_COUNT to MAX_RS6000_BUILTINS. + (builtin_classify): New static vector to classify various builtins + to get the tree attributes correct. + (def_builtin): Set the attributes of builtins based on what the + builtin does (i.e. memory operation, floating point, saturation + need special attributes, others are pure functions). + + * config/rs6000/rs6000.h (enum rs6000_btc): New enum to classify + the builtins. + (enum rs6000_builtins): Include rs6000-builtin.def to define the + builtins. Change the end marker to MAX_RS6000_BUILTINS from + RS6000_BUILTIN_COUNT. + (rs6000_builtin_decls): Change RS6000_BUILTIN_COUNT to + MAX_RS6000_BUILTINS. + + * config/rs6000/rs6000-builtin.def: New file that combines the + builtin enumeration name and attributes. + +2009-10-15 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/linux.h (ASM_SPEC): Add --32. + +2009-10-15 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (dwarf_tag_name): Handle DW_TAG_rvalue_reference_type + and DW_TAG_template_alias. + (dwarf_attr_name): Handle DW_AT_main_subprogram, + DW_AT_data_bit_offset, DW_AT_const_expr, DW_AT_enum_class, + DW_AT_linkage_name, DW_AT_GNU_guarded_by, DW_AT_GNU_pt_guarded_by, + DW_AT_GNU_guarded, DW_AT_GNU_pt_guarded, DW_AT_GNU_locks_excluded, + DW_AT_GNU_exclusive_locks_required, DW_AT_GNU_shared_locks_required + and DW_AT_GNU_odr_signature. + (dwarf_form_name): Handle DW_FORM_sec_offset, DW_FORM_exprloc, + DW_FORM_flag_present and DW_FORM_ref_sig8. + (output_signature): Only print name on the first byte. + (output_die): Likewise for dw_val_class_data8. + +2009-10-15 Alexander Monakov <amonakov@ispras.ru> + + * doc/invoke.texi: Clarify that most optimizations are not enabled + without -O. + +2009-10-15 Richard Guenther <rguenther@suse.de> + + PR lto/41668 + * gimple.c (compare_type_names_p): Handle anonymous names + differently based on new mode argument. + (gimple_types_compatible_p): For structs also compare the tags. + (iterative_hash_type_name): Rename to ... + (iterative_hash_name): ... this. Hash all names. + (iterative_hash_gimple_type): Fix hashing the struct tag of + pointer targets. Hash field decl names. + +2009-10-15 Richard Guenther <rguenther@suse.de> + + PR lto/41669 + * gimple.c (gimple_get_alias_set): Avoid recursing on + invalid type topology. + +2009-10-15 Andrew Pinski <andrew_pinski@playstation.sony.com> + + * config/spu/spu.c (get_branch_target): Use extract_asm_operands. + +2009-10-15 Richard Guenther <rguenther@suse.de> + + * tree.c (free_lang_data_in_decl): Free DECL_FCONTEXT. + +2009-10-15 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/option-defaults.h (OPTION_DEFAULT_SPECS): Don't + add --with-tune{,-32,-64} configured default for -mtune if explicit + -mcpu is used. + +2009-10-14 Daniel Gutson <dgutson@codesourcery.com> + + * config/arm/neon.md (neon_vshll_n<mode>): Checking Bounds fixed. + +2009-10-14 DJ Delorie <dj@redhat.com> + + * config/h8300/h8300.c (F): New. + (Fpa): New. + (h8300_emit_stack_adjustment): Call them. + (push): Likewise. + (h8300_push_pop): Likewise. + (h8300_expand_prologue): Likewise. + * config/h8300/h8300.h (DWARF2_DEBUGGING_INFO): Define. + (MUST_USE_SJLJ_EXCEPTIONS): Define. + (INCOMING_RETURN_ADDR_RTX): Define. + (INCOMING_FRAME_SP_OFFSET): Define. + (DWARF_CIE_DATA_ALIGNMENT): Define. + +2009-10-14 Jakub Jelinek <jakub@redhat.com> + + * stor-layout.c (place_field): Don't emit -Wpadded warnings for + fields in builtin structs. + (finalize_record_size): Likewise. + +2009-10-14 Richard Guenther <rguenther@suse.de> + + * gimple.c (gtc_ob): New global. + (struct type_pair_d): Replace pointers with type UIDs. + (type_pair_hash): Adjust. + (type_pair_eq): Likewise. + (lookup_type_pair): Likewise. Allocate from an obstack. + (gimple_force_type_merge): Adjust. + (gimple_types_compatible_p): Likewise. + (free_gimple_type_tables): Free the obstack. + +2009-10-14 Jakub Jelinek <jakub@redhat.com> + + * tree-parloops.c (separate_decls_in_region_debug_bind): Drop debug + stmts setting DEBUG_EXPR_DECLs. + + * cfgexpand.c (expand_debug_expr): Ignore zero-length bitfields. + Don't crash if mode1 is VOIDmode. + +2009-09-26 Vladimir Makarov <vmakarov@redhat.com> + + * params.def (PARAM_IRA_LOOP_RESERVED_REGS): New. + * params.h (IRA_LOOP_RESERVED_REGS): New. + * tree-pass.h (pass_subregs_of_mode_init, + pass_subregs_of_mode_finish): Remove. + * passes.c (pass_subregs_of_mode_init, + pass_subregs_of_mode_finish): Remove. + (pass_reginfo_init): Move before loop optimizations. + * config/i386/i386.h (STACK_REG_COVER_CLASS): Define. + * common.opt (fira-loop-pressure): New. + * toplev.h (flag_ira_loop_pressure): New. + * rtl.h (init_subregs_of_mode, finish_subregs_of_mode): New externals. + * reginfo.c (init_subregs_of_mode, finish_subregs_of_mode): + Make external and void type functions. + (gate_subregs_of_mode_init, pass_subregs_of_mode_init, + pass_subregs_of_mode_finish): Remove. + * ira-costs.c (init_costs): Call init_subregs_of_mode. + * regmove.c: Include ira.h. + (regmove_optimize): Call ira_set_pseudo_classes after IRA based + register pressure calculation in loops. + * loop-invariant.c: Include REGS_H and ira.h. + (struct loop_data): New members max_reg_pressure, regs_ref, and + regs_live. + (struct invariant): New member orig_regno. + (curr_loop): New variable. + (find_exits): Initialize regs_ref and regs_live. + (create_new_invariant): Initialize orig_regno. + (get_cover_class_and_nregs): New. + (get_inv_cost): Make aregs_needed an array. Use regs_needed as an + array. Add code for flag_ira_loop_pressure. + (gain_for_invariant): Make new_regs an array. Add code for + flag_ira_loop_pressure. + (best_gain_for_invariant): Ditto. + (set_move_mark): New parameter gain. Use it for debugging output. + (find_invariants_to_move): Make regs_needed and new_regs an array. + Add code for flag_ira_loop_pressure. + (move_invariant_reg): Set up orig_regno. + (move_invariants): Set up reg classes for pseudos for + flag_ira_loop_pressure. + (free_loop_data): Clear regs_ref and regs_live. + (curr_regs_live, curr_reg_pressure, regs_set, n_regs_set, + get_regno_cover_class, change_pressure, mark_regno_live, + mark_regno_death, mark_reg_store, mark_reg_clobber, + mark_reg_death, mark_ref_regs, calculate_loop_reg_pressure): New. + (move_loop_invariants): Calculate pressure. Initialize curr_loop. + * ira.c (ira): Call ira_set_pseudo_classes after IRA based + register pressure calculation in loops if new regs were added. + Call finish_subregs_of_mode. + * opts.c (decode_options): Set up flag_ira_loop_pressure. + * Makefile.in (loop-invariant.o): Add ira.h. + (regmove.o): Ditto. + * doc/invoke.texi (-fira-loop-pressure, ira-loop-reserved-regs): + Describe. + * doc/tm.texi (STACK_REG_COVER_CLASS): Describe. + +2009-10-14 Richard Guenther <rguenther@suse.de> + + * lto-symtab.c (lto_symtab_compatible): Fold in ... + (lto_symtab_merge): ... here. Rewrite both to take the + prevailing and a to-be-merged entry and to queue diagnostics properly. + (lto_symtab_resolve_replaceable_p): New predicate for + symbol resolution. + (lto_symtab_resolve_can_prevail_p): Likewise. + (lto_symtab_resolve_symbols): Rewrite. Fold in code that + handles merging commons by choosing the largest decl. Fold + in code that gives ODR errors. + (lto_symtab_merge_decls_2): Simplify a lot. Emit queued + diagnostics here. + (lto_symtab_merge_decls_1): Re-structure. Deal with the + case of no prevailing decl here. Diagnose mismatches + in object types here. Drop all but the prevailing decls. + (lto_symtab_prevailing_decl): Return the single prevailing decl. + * lto-streamer-in.c (lto_input_tree_ref): Deal with + VIEW_CONVERT_EXPRs in decl slots. Unshare the tree in this case. + +2009-10-14 Richard Guenther <rguenther@suse.de> + + PR lto/41521 + * lto-streamer-in.c (input_bb): Replace debug stmts with + nops instead of dropping them. + +2009-10-14 Nick Clifton <nickc@redhat.com> + + * gcc/doc/extended.texi: Replace the dash character with @minus{} + in situations where it is being used as a minus symbol. + * gcc/doc/tm.texi: Likewise. + * gcc/doc/md.texi: Likewise. + +2009-10-14 Jakub Jelinek <jakub@redhat.com> + + PR preprocessor/41543 + * input.h (BUILTINS_LOCATION): Change to 1 from 2. + Assert BUILTINS_LOCATION < RESERVED_LOCATION_COUNT. + * tree.c: Include intl.h. + (expand_location): Handle BUILTINS_LOCATION. + * Makefile.in (tree.o): Depend on intl.h. + + PR debug/41695 + * dwarf2out.c (dwarf2out_var_location): Always clear + last_postcall_label when changing last_label. + +2009-10-14 Pascal Obry <obry@adacore.com> + + * gcc.c (DEFAULT_SWITCH_CURTAILS_COMPILATION): Add -E. + (process_command): Handle -E as done with -c and -S. Do not add + the target executable suffix to the output file when -E is used. + (main): Adjust error message accordingly. + +2009-10-14 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41343 + PR debug/41447 + PR debug/41264 + PR debug/41338 + * tree.c (tree_node_structure_for_code): DEBUG_EXPR_DECL uses + decl with rtl. + (tree_code_size): Likewise. + +2009-10-13 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * builtins.c (fold_builtin_1): Support complex "arc" functions. + * real.h (HAVE_mpc_arc): Define. + +2009-10-14 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (TARGET_BUILTIN_DECL): Define. + (struct builtin_description): Add fndecl field. + (bdesc): Remove const qualifier. Update initializer. + (sh_media_init_builtins): Remove const qualifier for d. Record + the result of add_builtin_function to the fndecl field. + (sh_builtin_decl): New. + (sh_media_builtin_decl): New. + +2009-10-14 Hans-Peter Nilsson <hp@axis.com> + + PR target/38948 + * config/cris/cris.h (SECONDARY_RELOAD_CLASS): Handle reload + requests between special registers. + +2009-10-13 Eric Botcazou <ebotcazou@adacore.com> + + * dwarf2out.c (mem_loc_descriptor): Accept UNGT as well. + +2009-10-13 Richard Henderson <rth@redhat.com> + + PR tree-optimization/41377 + * tree-eh.c (unsplit_eh): Propagate degenerate PHIs. + (cleanup_empty_eh_merge_phis): New change_region parameter; + pass it on to redirect_eh_edge_1. Update callers. + (cleanup_empty_eh_unsplit): Don't require an existing EH label + at the destination block. + +2009-10-13 Basile Starynkevitch <basile@starynkevitch.net> + + * passes.c (register_pass): Replaced gcc_unreachable by + fatal_error on failure. Mentions plugins in comments & messages. + +2009-10-13 Jakub Jelinek <jakub@redhat.com> + + PR target/41693 + * rtl.h (DEBUG_EXPR_TREE_DECL): Define. + * sched-vis.c (print_value): Use it. + * cselib.c (cselib_hash_rtx): Likewise. + * print-rtl.c (print_rtx): Likewise. + * cfgexpand.c (expand_debug_rtx): Likewise. + * var-tracking.c (vt_expand_loc_callback): Likewise. + +2009-10-13 Richard Guenther <rguenther@suse.de> + + PR lto/41565 + * opts.c (handle_option): Split out code to handle setting + the options flag var ... + (set_option): ... here. + * opts.h (set_option): Declare. + * lto-opts.c (register_user_option_p): Include -fexceptions + and all position independent code variants. + (handle_common_option): Remove. + (lto_reissue_options): Use set_option. + +2009-10-13 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/41661 + * ipa-prop.c (compute_complex_pass_through): Allow only operations + that are tcc_comparisons or do not change the type in any + un-usleless way. + * ipa-cp.c (ipcp_lattice_from_jfunc): Request boolean type when + folding tcc_comparison operations. + +2009-10-13 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.c (s390_encode_section_info): Handle BLKmode + properly. + +2009-10-12 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41343 + PR debug/41447 + PR debug/41264 + PR debug/41338 + * tree.def (DEBUG_EXPR_DECL): New. + * rtl.def (DEBUG_EXPR): New. + * gengtype.c (adjust_field_rtx_def): Handle it. + * tree-ssa.c (propagate_var_def_into_debug_stmts): Rename to... + (insert_debug_temp_for_var_def): ... this. Drop support for + moving. Take iterator for def stmt; insert debug stmt before it. + Scan early for use count and kind in debug stmts. + (propagate_defs_into_debug_stmts): Rename to... + (insert_debug_temps_for_defs): ... this. Likewise. + * tree.h (DEBUG_TEMP_UID): New. + * tree.c (next_debug_decl_uid): New. + (make_node_stat): Count debug decls separately. + (copy_node_stat): Likewise. + * cfgexpand.c (expand_debug_expr): Handle DEBUG_EXPR_DECL. + * var-tracking.c (dv_is_decl_p): Recognize it. + (VALUE_RECURSED_INTO): Apply to DEBUG_EXPRs too. + (track_expr_p): Track expanded DEBUG_EXPR_DECLs. + (vt_expand_loc_callback): Expand DEBUG_EXPRs. + (emit_note_insn_var_location): Don't emit notes for DEBUG_EXPR_DECLs. + * cselib.c (rtx_equal_for_cselib_p): Handle DEBUG_EXPR. + (cselib_hash_rtx): Likewise. + (cselib_expand_value_rtx_1): Use callback for DEBUG_EXPR. + * tree-ssa-operands.c (get_expr_operands): Skip DEBUG_EXPR_DECLs in + debug bind stmts. + * emit-rtl.c (verify_rtx_sharing): Handle DEBUG_EXPR and VALUE. + (copy_rtx_if_shared_1, reset_used_flags, set_used_flags): Likewise. + * rtl.c (copy_rtx): Likewise. + (rtx_equal_p_cb, rtx_equal_p): Handle DEBUG_EXPR. + * print-rtl.c (print_rtx): Likewise. + * sched-vis.c (print_value): Likewise. + (print_insn): Handle DEBUG_EXPR_DECL. + * tree-dump.c (dequeue_and_dump): Likewise. + * tree-pretty-print.c (dump_decl_name, dump_generic_node): Likewise. + * gimple-iterator (gsi_replace): Check for same lhs. + (gsi_remove): Insert debug temps. + * tree-ssa-loop-im.c (rewrite_reciprocal): Replace with same lhs. + (move_computations_stmt): Drop explicit propagation into debug stmts. + (rewrite_bittest): Likewise. Use gsi_remove for propagation. + * tree-ssa-reassoc.c (rewrite_expr_tree, linearize_expr): Likewise. + * tree-ssa-sink.c (statement_sink_location): Likewise. + * tree-ssa-forwprop (forward_propagate_addr_expr): Likewise. + * tree-ssanames.c (release_ssa_name): Adjust for rename. + * tree-flow.h: Likewise. + * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Don't mark + debug temps without values. + (eliminate_unnecessary_stmts): Don't discard just-inserted + debug stmts. + +2009-10-12 Hans-Peter Nilsson <hp@axis.com> + + PR target/26515 + * config/cris/cris.md (andu): Check that operand 1 is one of the + general registers. Fix typo in head comment. + +2009-10-12 Stefan Dösinger <stefan@codeweavers.com> + + * config/i386/i386.md (vswapmov): New. + * config/i386/i386.c (ix86_handle_fndecl_attribute): New. + (ix86_function_ms_hook_prologue): New. + (ix86_expand_prologue): Handle ms_hook_prologue attribute. + * configure.ac: Test for swap suffix support in as. + * configure: Rebuild. + +2009-10-12 Jakub Jelinek <jakub@redhat.com> + + PR target/41680 + * config/i386/i386.md (split after *testqi_ext_3_rex64): Only narrow + paradoxical subregs to prevent partial register stalls if the inner + mode is integer mode. + +2009-10-12 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (*setcc_<mode>_2): Remove insn pattern. + +2009-10-12 Dodji Seketeli <dodji@redhat.com> + + PR c++/41570 + * gcc/dwarf2out.c (template_parameter_pack_die, + gen_formal_parameter_pack_die): Use add_name_and_src_coords_attributes. + +2009-10-12 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41616 + * tree-into-ssa.c (insert_phi_nodes_for): Build debug bind stmts + on updates too. + (maybe_register_def): Likewise. Take stmt iterator. + (rewrite_update_stmt): Take stmt iterator and pass it on. + (rewrite_update_enter_block): Pass stmt iterator. + +2009-10-11 Andrew Pinski <andrew_pinski@playstation.sony.com> + + * config/spu/spu.c (TARGET_BUILTIN_DECL): Define. + (spu_builtin_decl): New function. + +2009-10-12 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (SWIM): New mode iterator. + (mov<mode>cc): Macroize expander from mov{qi,hi,si,di}cc patterns + using SWIM mode iterator. + (x86_mov<mode>cc_0_m1): Macroize insn from x86_mov{si,di}cc_0_m1 + patterns using SWI48 mode iterator. + (*x86_mov<mode>cc_0_m1_se): Macroize insn from + *x86_mov{si,di}cc_0_m1_se patterns using SWI48 mode iterator. + (*x86_mov<mode>cc_0_m1_neg): New insn pattern. + (*mov<mode>cc_noc): Macroize insn from *mov{hi,si,di}cc_noc + patterns using SWI248 mode iterator. + * config/i386/i386.c (ix86_expand_int_movcc): Update the call to + gen_x86_movdicc_0_m1_rex64 for renamed function + +2009-10-11 Jose Ruiz <ruiz@adacore.com> + Eric Botcazou <ebotcazou@adacore.com> + + PR target/33743 + * config/sparc/sol2.h (MD_UNWIND_SUPPORT): Define. + * config/sparc/sol2-unwind.h: New file. + +2009-10-11 Olivier Hainque <hainque@adacore.com> + Eric Botcazou <ebotcazou@adacore.com> + + PR target/33743 + * config/i386/sol2.h (MD_UNWIND_SUPPORT): Define. + * config/i386/sol2-unwind.h: New file. + +2009-10-11 H.J. Lu <hongjiu.lu@intel.com> + + PR target/41665 + * config/i386/i386.md (addsi_1_zext): Get the proper second + operand for lea. + +2009-10-11 Richard Sandiford <rdsandiford@googlemail.com> + + * simplify-rtx.c (simplify_replace_rtx): Use rtx_equal_p for + all OLD_RTXes, not just REGs. Use copy_rtx to create the + replacement value. + +2009-10-11 Richard Guenther <rguenther@suse.de> + + * gimple.c (iterative_hash_type_name): Do not handle special + anonymous names. + +2009-10-11 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (*setcc_di_1): New insn_and_split pattern. + (*setcc_si_1_and): Ditto. + (*setcc_si_1_movzbl): Ditto. + (*setcc_<mode>_2): Ditto. + (*setcc_qi): Rename from *setcc_1. + (*setcc_qi_slp): Rename from *setcc_2. + + (*zero_extendqihi2_movzbw_and splitter): Use ix86_expand_clear. + (*zero_extendqisi2_movzbw_and splitter): Ditto. + + * config/i386/i386.c (ix86_expand_clear): Remove reload_completed from + "if" condition, there is already assert with reload_completed present. + +2009-10-11 Gerald Pfeifer <gerald@pfeifer.com> + + * plugin.c (try_init_one_plugin): Improve constness of variable err. + +2009-10-10 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (Final install): Refer to + http://gcc.gnu.org/bugs/ for bug reporting. + +2009-10-10 Peter Bergner <bergner@vnet.ibm.com> + + * configure.ac: Add test for dci instruction. + * configure: Regenerate. + * config.in: Likewise. + * config.gcc: Handle --with-cpu=476 and --with-cpu=476fp. + * doc/invoke.texi: Add cpu_type 476 and 476fp. + (-mmulhw): Add 476 to description. + (-mdlmzb): Likewise. + * config/rs6000/t-fprules (MULTILIB_MATCHES_FLOAT): Include -mcpu=476. + * config/rs6000/rs6000.c (processor_costs): Add ppc476_cost. + (processor_target_table): Add 476 and 476fp entries. + (rs6000_override_options): Use ppc476_cost for PROCESSOR_PPC476. + (rs6000_issue_rate): Add CPU_PPC476. + * config/rs6000/rs6000.h (ASM_CPU_476_SPEC): Define. + (ASM_CPU_SPEC): Pass %(asm_cpu_476) for -mcpu=476 and -mcpu=476fp. + (processor_type): Add PROCESSOR_PPC476. + (EXTRA_SPECS): Add asm_cpu_476 string. + * config/rs6000/rs6000.md (define_attr "type"): Add isel attribute. + (define_attr "cpu"): Add ppc476. + Include 476.md. + Update comments for 476. + (isel_signed, isel_unsigned): Change to use "isel" type attribute. + * config/rs6000/vxworks.h (CPP_SPEC): Handle 464 and 476. + Update copyright year. + * config/rs6000/476.md: New file. + * config/rs6000/40x.md: Add description for "isel" attribute. + Update copyright year. + * config/rs6000/440.md: Likewise. + * config/rs6000/603.md: Likewise. + * config/rs6000/6xx.md: Likewise. + * config/rs6000/7450.md: Likewise. + * config/rs6000/7xx.md: Likewise. + * config/rs6000/8540.md: Likewise. + * config/rs6000/cell.md: Likewise. + * config/rs6000/e300c2c3.md: Likewise. + * config/rs6000/e500mc.md: Likewise. + * config/rs6000/mpc.md: Likewise. + * config/rs6000/power4.md: Likewise. + * config/rs6000/power5.md: Likewise. + * config/rs6000/power6.md: Likewise. + * config/rs6000/power7.md: Likewise. + * config/rs6000/rios1.md: Likewise. + * config/rs6000/rios2.md: Likewise. + * config/rs6000/rs64.md: Likewise. + +2009-10-10 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41654 + * tree-ssa-ifcombine.c (ifcombine_ifandif): Properly canonicalize + a cond expr before calling gimple_cond_set_condition_from_tree. + (ifcombine_iforif): Likewise. + +2009-10-09 Ian Lance Taylor <iant@google.com> + + * configure.ac: Use AC_SEARCH_LIBS to find dlopen. + * configure: Rebuild. + +2009-10-09 Neil Vachharajani <nvachhar@google.com> + + * doc/cpp.texi (Other Directives): Do not list #ident and #sccs as + deprecated. + +2009-10-09 Richard Guenther <rguenther@suse.de> + + PR lto/41638 + * target-def.h (TARGET_BUILTIN_DECL): Define. + (TARGET_INITIALIZER): Add TARGET_BUILTIN_DECL. + * target.h (struct gcc_target): Add builtin_decl target hook. + * doc/tm.texi (TARGET_BUILTIN_DECL): Document. + * lto-streamer-in.c (lto_get_builtin_tree): Fix handling of + target builtins. + * lto-streamer-out.c (lto_output_tree_pointers): Use sorry, + not gcc_unreachable. + (lto_output_builtin_tree): Sorry if the target does not support + streaming target builtins. + * config/rs6000/rs6000.c (TARGET_BUILTIN_DECL): Define. + (rs6000_builtin_decl): New function. + * config/i386/i386.c (TARGET_BUILTIN_DECL): Define. + (ix86_builtin_decl): New function. + +2009-10-09 Jakub Jelinek <jakub@redhat.com> + + PR preprocessor/41445 + * c-ppoutput.c (do_line_change): New function. + (cb_line_change): Use it. + (scan_translation_unit): Call do_line_change if + avoid_paste or PREV_WHITE and token location is on a different line + than print.src_line. + + PR debug/40521 + * dwarf2out.c (dwarf2out_init): Test whether + HAVE_GAS_CFI_SECTIONS_DIRECTIVE is non-zero instead of checking + it is defined. + + PR rtl-optimization/41646 + * calls.c (expand_call): For BLKmode types returned in registers + avoid likely spilled hard regs in copy_blkmode_from_reg generated + insns. + +2009-10-09 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41634 + * tree-ssa-dom.c (remove_local_expressions_from_table): Assert + we remove the correct elements. + (optimize_stmt): Make sure to update stmt operands before + optimizing redundancies. + +2009-10-09 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.md ("prefetch"): Remove stcmh for prefetching. + +2009-10-09 Richard Guenther <rguenther@suse.de> + + PR driver/41637 + * lto-wrapper.c (ltrans_output_file, flto_out, args_name): New + globals. + (lto_wrapper_exit): New function. + (fatal): Use it. + (fatal_perror): Likewise. + (fork_execute): Use global args_name, do not free it. + (run_gcc): Use global ltrans_output_file, flto_out, do not free them. + * lto-streamer.h: Remove duplicate prototypes. + +2009-10-09 Richard Guenther <rguenther@suse.de> + + * cgraph.c (cgraph_create_edge): Check for NULL call_stmt + before calling stmt_can_throw_external. + +2009-10-09 Eric Botcazou <ebotcazou@adacore.com> + + PR tree-optimization/40071 + * tree-vect-data-refs.c (vect_create_data_ref_ptr): Build a ref-all + pointer if the original data reference doesn't conflict with the + created vector data reference. Fix long line. + +2009-10-09 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (any_div): New code iterator. + (u): Handle div and udiv. + (sgnprefix): Ditto. + (<u>divqi3): Macroize insn from {,u}divqi3 using any_div + code iterator. + (lfloor<MODEF:mode><SWI48:mode>2): Macroize insn from + lfloor<mode>{si,di}2 patterns using SWI48 mode iterator. + (lceil<MODEF:mode><SWI48:mode>2): Macroize insn from + lceil<mode>{si,di}2 patterns using SWI48 mode iterator. + +2009-10-08 Joseph Myers <joseph@codesourcery.com> + + * gcc.c (main): Remove trailing "." from diagnostics. + +2009-10-08 Cary Coutant <ccoutant@google.com> + + Add support for debugging with ICF (Identical Code Folding). + * calls.c (debug.h): New #include. + (emit_call_1): Call virtual_call_token debug hook. + * common.opt (-fenable-icf-debug): New option. + * dwarf2out.c (dwarf2_debug_hooks): Add entries for new hooks (two + locations in the source). + (poc_label_num): New variable. + (dcall_entry, vcall_entry): New typedefs. + (dcall_table, vcall_table): New variables. + (struct vcall_insn): New type. + (vcall_insn_table): New variable. + (DEBUG_DCALL_SECTION, DEBUG_VCALL_SECTION): New macros. + (size_of_dcall_table): New function. + (output_dcall_table): New function. + (size_of_vcall_table): New function. + (output_vcall_table): New function. + (dwarf2out_direct_call): New function. + (vcall_insn_table_hash): New function. + (vcall_insn_table_eq): New function. + (dwarf2out_virtual_call_token): New function. + (dwarf2out_virtual_call): New function. + (dwarf2out_init): Allocate new tables and sections. + (prune_unused_types): Mark DIEs referenced from direct call table. + (dwarf2out_finish): Output direct and virtual call tables. + * final.c (final_scan_insn): Call direct_call and virtual_call + debug hooks. + * debug.h (struct gcc_debug_hooks): Add direct_call, + virtual_call_token, virtual_call hooks. + (debug_nothing_uid): New function. + * debug.c (do_nothing_debug_hooks): Add dummy entries for new hooks. + (debug_nothing_uid): New function. + * dbxout.c (dbx_debug_hooks): Add dummy entries for new hooks. + (xcoff_debug_hooks): Likewise. + * sdbout.c (sdb_debug_hooks): Likewise. + * vmsdbgout.c (vmsdbg_debug_hooks): Likewise. + * doc/invoke.texi (-fenable-icf-debug): New option. + +2009-10-08 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41353 + * regmove.c (regmove_backward_pass): Replace src with dst in the + debug insn, and check for dst before rather than after. + +2009-10-08 Janis Johnson <janis187@us.ibm.com> + + * config/rs6000/rs6000.c (rs6000_delegitimize_address): Remove. + (TARGET_DELEGITIMIZE_ADDRESS): Likewise. + +2009-10-08 Jan Hubicka <jh@suse.cz> + + PR middle-end/41626 + * cgraphbuild.c (record_reference): When parameter DATA is NULL, + do not mark cgraph nodes as needed. + (record_references_in_initializer): Add new only_vars parameter. + * cgraph.h (record_references_in_initializer): New parameter. + * varasm.c (assemble_variable): Update call. + * varpool.c (varpool_analyze_pending_decls): Always look for + referenced vars. + +2009-10-08 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.c (last_insn_address) Remove variable. + (expand_prologue): Don't initialise last_insn_address variable. + (final_prescan_insn): Don't output insn size. + * config/avr/avr.opt (msize): Remove switch. + * doc/invoke.texi (AVR Options): Remove documentation of -msize + switch. + +2009-10-08 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (label_tick_ebb_start): Fix comment. + (combine_instructions): Set label_tick and label_tick_ebb_start before + calling setup_incoming_promotions. Start them from 1. Increment + label_tick instead of deriving it from the BB index. Rather than + comparing ticks use the block from the previous iteration to decide + whether to start a new EBB. Remove empty lines before function. + +2009-10-08 Michael Matz <matz@suse.de> + + PR middle-end/41573 + * builtins.c (fold_builtin_isascii): Use fold_build2. + (fold_builtin_isdigit): Ditto. + * except.c (duplicate_eh_regions_1): Tolerate NULL labels. + * tree-cfg.c (struct rus_data, remove_useless_stmts_warn_notreached, + remove_useless_stmts_cond, remove_useless_stmts_tf, + remove_useless_stmts_tc, remove_useless_stmts_bind, + remove_useless_stmts_goto, remove_useless_stmts_label, + remove_useless_stmts_1, remove_useless_stmts, + pass_remove_useless_stmts): Remove. + * tree-pass.h (pass_remove_useless_stmts): Don't declare. + * passes.c (init_optimization_passes): Don't add + pass_remove_useless_stmts. + * tree-eh.c (lower_eh_constructs_2): Handle empty cleanups. + * tree.c (free_lang_data_in_decl): Don't clear DECL_INITIAL of + static constants. + * lto-symtab.c (lto_symtab_register_decl): Accepts DECL_INITIAL + for static constants. + * lto-streamer-out.c (output_gimple_stmt): Handle GIMPLE_NOP. + * lto-streamer-in.c (input_gimple_stmt): Handle GIMPLE_NOP. + +2009-10-08 Richard Guenther <rguenther@suse.de> + + * gimple.c (free_gimple_type_tables): New function. + * gimple.h (free_gimple_type_tables): Declare. + +2009-10-07 Mark Heffernan <meheff@google.com> + + * ipa-prop.c (ipa_print_node_params) Only print + names of named arguments. + +2009-10-08 Rafael Avila de Espindola <espindola@google.com> + + * gcc.c (LINK_COMMAND_SPEC): Pass libc with -pass-through if it is + being statically linked. + +2009-10-08 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + + * collect2.c (add_lto_object): Only define if OBJECT_FORMAT_NONE. + +2009-10-08 Jan Hubicka <jh@suse.cz> + + PR bootstrap/41620 + * ipa.c (cgraph_externally_visible_p, + function_and_variable_visibility, + whole_program_function_and_variable_visibility): Skip non-finalized + nodes. + +2009-10-08 Nick Clifton <nickc@redhat.com> + + * config/mn10300/mn10300.h (CONSTANT_ADDRESS_P): Do not allow + CONST_DOUBLEs. + +2009-10-08 Andreas Tobler <a.tobler@schweiz.org> + + PR bootstrap/37739 + * config.host: Use config/x-cflags-O1 for powerpc FreeBSD. + +2009-10-07 Joseph Myers <joseph@codesourcery.com> + + PR c/41182 + * c-common.c (c_fully_fold_internal): Strip nops from the result + of recursive calls to c_fully_fold_internal. + (c_wrap_maybe_const): New. + (c_save_expr): Use c_wrap_maybe_const. + * c-common.h (c_wrap_maybe_const): Declare. + * c-typeck.c (build_conditional_expr, c_finish_stmt_expr, + build_binary_op): Use c_wrap_maybe_const. + +2009-10-07 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * real.c: Fix comment to reflect actual exponent size. + +2009-10-08 Ben Elliston <bje@au.ibm.com> + + * config/rs6000/a2.md: Add FSF comment header. + +2009-10-07 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (any_extend): New code iterator. + (u, s): New code attributes. + (sgnprefix): Ditto. + (DWIH): Rewrite as code iterator for SI and DI modes. + (DWI): Rewrite as mode attribute. + (dwi): New mode attribute. + (di): Depend on SI mode and DI mode. + (doubleint_general_operand): Remove mode attribute. + + (*lea_1): Macroize insn from *lea_1_rex64 and *lea_1 patterns using + DWIH mode iterator. + + (*add<mode>3_doubleword): Use DWIH as the base mode iterator. + (*sub<mode>3_doubleword): Ditto. + + (mul<mode>3): Macroize expander from mul{hi,si,di}3 patterns + using SWIM248 mode iterator. + (*mul<mode>3_1): Macroize insn from mul{si,di}3_1 patterns + using SWI48 mode iterator. + (<u>mul<mode><dwi>3): Macroize expander from {,u}mul{sidi,diti}3 + patterns using DWIH mode iterator and any_extend code iterator. + (<u>mulqihi3): Macroize expander from {,u}mulqihi3 patterns + using any_extend code iterator. + (*<u>mul<mode><dwi>3_1): Macroize insn from {,u}mul{sidi,diti}3_1 + patterns using DWIH mode iterator and any_extend code iterator. + (*<u>mulqihi3_1): Macroize insn from {,u}mulqihi3_1 patterns + using any_extend code iterator. + (<s>mul<mode>3_highpart): Macroize expander from + {s,u}mul{si,di}3_highpart patterns using DWIH mode iterator + and any_extend code iterator. + (*<s>muldi3_highpart_1): Macroize insn from + *{s,u}muldi3_highpart_rex64 patterns using any_extend code iterator. + (*<s>mulsi3_highpart_1): Macroize insn from *{s,u}mulsi3_highpart_1 + patterns using any_extend code iterator. + (*<s>mulsi3_highpart_zext): Macroize insn from + *{s,u}mulsi3_highpart_zext patterns using any_extend code iterator. + +2009-10-07 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (tree_add_const_value_attribute_for_decl): Don't add + DW_AT_const_value if VAR_DIE already has DW_AT_abstract_origin + refering to a DIE with DW_AT_const_value. + +2009-10-07 Vladimir Makarov <vmakarov@redhat.com> + + PR middle-end/22072 + * ira-lives.c (check_and_make_def_conflict): Process all operands. + +2009-10-06 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_node_can_be_local): Handle externally visible nodes + correctly. + +2009-10-06 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (*lea_1_rex64, *lea_1, *lea_1_zext, + *lea_2_rex64): Move before *add<mode>_1 pattern. + +2009-10-07 Jan Hubicka <jh@suse.cz> + + * collect2.c (main): Add -fno-whole-program. + * gcc.c (set_collect_gcc_options): Do not remove whole program here. + +2009-10-07 Jan Hubicka <jh@suse.cz> + + * lto-symtab.c (lto_cgraph_replace_node): Assert that inline clones + has no address taken. + * cgraph.c (cgraph_mark_needed_node): Assert that inline clones are + never needed. + (cgraph_clone_node): Clear externally_visible flag for clones. + * cgraph.h (cgraph_only_called_directly_p, + cgraph_can_remove_if_no_direct_calls_p): New predicates. + * tree-pass.h (pass_ipa_whole_program_visibility): Declare. + * ipa-cp.c (ipcp_cloning_candidate_p): Use new predicate. + (ipcp_initialize_node_lattices, ipcp_estimate_growth, + ipcp_insert_stage): Likwise. + * cgraphunit.c (cgraph_decide_is_function_needed): Do not compute + externally_visible flag. + (verify_cgraph_node): Verify that inline clones look right. + (process_function_and_variable_attributes): Do not set + externally_visible flags. + (ipa_passes): Avoid executing small_ipa_passes at LTO stage; they've + been already run. + * lto-cgraph.c (lto_output_node): Assert that inline clones are not + boundaries. + * ipa-inline.c (cgraph_clone_inlined_nodes): Use new predicates; + clear externally_visible when turning into inline clones + (cgraph_mark_inline_edge): Use new predicates. + (cgraph_estimate_growth): Likewise. + (cgraph_decide_inlining): Likewise. + * ipa.c (cgraph_postorder): Likewise. + (cgraph_remove_unreachable_nodes): Likewise; sanity check + that inline clones are not needed. + (cgraph_externally_visible_p): New predicate. + (function_and_variable_visibility): Add whole_program parameter; + always set externally_visible flag; handle COMDAT function + privatization. + (local_function_and_variable_visibility): New function. + (gate_whole_program_function_and_variable_visibility): New function. + (whole_program_function_and_variable_visibility): New function. + (pass_ipa_whole_program_visibility): New function. + * passes.c (init_optimization_passes): Add whole program visibility + pass. + (do_per_function_toporder, function_called_by_processed_nodes_p): Do + not care about needed/reachable flags. + * varpool.c: Include flags.h + (decide_is_variable_needed): When doing LTO assume whole-program mode. + (varpool_finalize_decl): When we are in LTO read-back, all variables + are analyzed. + (varpool_analyze_pending_decls): Skip analyzis of analyzed vars. + +2009-10-07 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/tpf.h (TARGET_DEFAULT): Remove MASK_HARD_FLOAT and + add MASK_HARD_DFP. + +2009-10-07 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config.gcc: Don't include the makefile fragments intended for + libgcc. + * config/s390/fixdfdi.h: File removed. + * config/s390/libgcc-glibc.ver: File removed. + * config/s390/s390.h: Remove the fixdfdi.h hack. + * config/s390/t-crtstuff: File moved to libgcc dir. + * config/s390/t-linux: Likewise. + * config/s390/t-tpf: libgcc specific parts removed. + * config/s390/t-linux64: Likewise. + +2009-10-06 Jerry Quinn <jlquinn@optonline.net> + + * Makefile.in (lto-wrapper): Use COMPILER and ALL_COMPILERFLAGS. + (lto-compress.o): Likewise. + +2009-10-07 Danny Smith <dannysmith@users.sourceforge.net> + + PR target/41512 + * config/i386/winnt.c (i386_pe_determine_dllexport_p): Don't propagate + dllexport to class members here. + (i386_pe_determine_dllimport_p): Only check static class data for + definition. + (i386_pe_encode_section_info): Don't recheck DECL_DLLIMPORT_P. + * config/i386/winnt-cxx.c (i386_pe_type_dllimport_p): Only check + functions for vague linkage. + (i386_pe_type_dllexport_p): Fix formatting. + (maybe_add_dllexport) New function. + (i386_pe_adjust_class_at_definition): Use it to propagate dllexport + to class members. + +2009-10-07 Ben Elliston <bje@au.ibm.com> + + * config/rs6000/a2.md: Remove duplicated lines. + +2009-10-07 Ben Elliston <bje@au.ibm.com> + + * config.gcc (powerpc*-*-*): Handle a2. + * config/rs6000/rs6000.md (cpu): Add ppca2. Include "a2.md". + * config/rs6000/a2.md: New file. + * config/rs6000/rs6000.opt (mno-update): New. + (mupdate): Return to using a mask, not a var. + * config/rs6000/rs6000.h (ASM_CPU_SPEC): Add support for a2. + (enum processor_type): Add PROCESSOR_PPCA2. + * config/rs6000/rs6000.c (ppca2_cost): New costs. + (rs6000_override_options): Add "a2" to processor_target_table. + Update rs6000_always_hint logic. Correctly set rs6000_cost for a2. + * doc/invoke.texi (RS/6000 and PowerPC Options): Document -mcpu=a2. + +2009-10-06 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (float<SSEMODEI24:mode><X87MODEF:mode>2): + Use explicit gen_truncxfsf2 and gen_truncxfdf2 references to avoid + reference to nonexistent gen_truncxfxf2 function. + +2009-10-06 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (SWI48, SDWIM, DWI): New mode iterators. + (DWIH, g, di, doubleint_general_operand): New mode attributes. + (general_operand): Handle TI mode. + (add<mode>3): Macroize expander from add{qi,hi,si,di,ti}3 patterns + using SDWIM mode iterator. + (*add<mode>3_doubleword): New insn_and_split pattern. Macroize + pattern from *add{di,ti}3_1 patterns and corresponding splitters + using DWI mode iterator. + (add<mode>3_carry): Macroize insn from add{qi,hi,si,di}3_carry + patterns using SWI mode iterator. + (*add<mode>3_cc): Macroize insn from add{si,di}3_cc patterns + using SWI48 mode iterator. + (*add<mode>_1): Ditto from add{si,di}_1 patterns. + (*add<mode>_2): Ditto from add{si,di}_2 patterns. + (*add<mode>_3): Ditto from add{si,di}_3 patterns. + (*add<mode>_5): Ditto from add{si,di}_5 patterns. + (sub<mode>3): Macroize expander from sub{qi,hi,si,di,ti}3 patterns + using SDWIM mode iterator. + (*sub<mode>3_doubleword): New insn_and_split pattern. Macroize + pattern from *sub{di,ti}3_1 patterns and corresponding splitters + using DWI mode iterator. + (sub<mode>3_carry): Macroize insn from sub{qi,hi,si,di}3_carry + patterns using SWI mode iterator. + (*sub<mode>_1): Ditto from from sub{qi,hi,si,di}_1 patterns. + (*sub<mode>_2): Ditto from sub{qi,hi,si,di}_2 patterns. + (*sub<mode>_3): Ditto from sub{qi,hi,si,di}_3 patterns. + (<plusminus_insn>xf3): Macroize expander from addxf3 and subxf3 + patterns using plusminus code iterator. + (<plusminus_insn><mode>3): Macroize expander from add<mode>3 and + sub<mode>3 patterns using plusminus code iterator. + * config/i386/i386.c (override_options): Update the call to + gen_subdi_carry_rex64 for renamed function. + (ix86_expand_int_addcc): Update calls to gen_subdi3_carry_rex64 + and gen_adddi3_carry_rex64 for renamed functions. Use indirect + calls to instruction expanders. + +2009-10-06 Martin Jambor <mjambor@suse.cz> + + PR bootstrap/41395 + * opts.c (decode_options): Run IPA-SRA at -O2. + +2009-10-06 Richard Guenther <rguenther@suse.de> + + * lto-symtab.c (lto_symtab_entry_hash): Hash strings, not pointers. + +2009-10-06 Tobias Burnus <burnus@net-b.de> + + PR lto/41591 + * doc/invoke.texi (-flto,-fwhole-program): Make clear that the + -flto and -fwhole-program flags can be combined. + +2009-10-06 Ryan Mansfield <rmansfield@qnx.com> + + PR driver/41217 + * gcc.c (process_command): Check that -o argument was specified. + +2009-10-06 Jerry Quinn <jlquinn@optonline.net> + + * gimple.c (gimple_type_hash): Use CONST_CAST_TREE to fix compilation. + +2009-10-05 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * c.opt (Wjump-misses-init): Fix typo to enable for ObjC. + * doc/invoke.texi (Warning Options): Annotate allowed languages + for -Wunsuffixed-float-constants. + +2009-10-05 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (modified_type_die): Don't add DW_AT_name to + DW_TAG_{const,volatile}_type if its DW_AT_type already has the + same name and isn't the main variant. + + PR debug/41558 + * dwarf2out.c (loc_by_reference): Removed. + (dw_loc_list_1): New function. + (dw_loc_list): Remove toplev argument, add want_address argument. + Don't look at decl_by_reference_p at all. Use dw_loc_list_1. + (loc_list_from_tree) <case VAR_DECL>: Pass want_address rather than + want_address == 2 to dw_loc_list. For successful dw_loc_list + set have_address to 1 only if want_address is not 0. + +2009-10-05 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips-protos.h (mips_trampoline_code_size): Declare. + * config/mips/mips.h (TRAMPOLINE_SIZE): Redefine as the size of + a code block followed by two pointers. + (TRAMPOLINE_ALIGNMENT): Define to 64 for 32-bit targets too. + * config/mips/mips.c (MIPS_LOAD_PTR): New macro. + (MIPS_MOVE): Likewise. + (MIPS_LUI): Likewise. + (MIPS_JR): Likewise. + (MIPS_BAL): Likewise. + (MIPS_NOP): Likewise. + (mips_asm_trampoline_template): Delete. + (mips_trampoline_code_size): New function. + (mips_trampoline_init): Add shorter sequences for all cases + except Pmode == DImoe && !TARGET_USE_PIC_FN_ADDR_REG. + Calculate the opcodes directly, rather than copying from a template. + Only flush the code part of the trampoline. + (TARGET_ASM_TRAMPOLINE_TEMPLATE): Delete. + +2009-10-05 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.h (DWARF_FRAME_RETURN_COLUMN): Replace + GP_REG_FIRST + 31 with RETURN_ADDR_REGNUM. + (INCOMING_RETURN_ADDR_RTX): Likewise. + (FUNCTION_PROFILER): Likewise. Replace GP_REG_FIRST + 1 + with AT_REGNUM. + * config/mips/sdemtk.h (FUNCTION_PROFILER): Replace GP_REG_FIRST + 31 + with RETURN_ADDR_REGNUM. + (MIPS_SAVE_REG_FOR_PROFILING_P): Likewise. + * config/mips/mips.c (mips16_build_call_stub): Replace + GP_REG_FIRST + 31 with RETURN_ADDR_REGNUM, GP_REG_FIRST + 1 + with AT_REGNUM and 31 with RETURN_ADDR_REGNUM. + (mips_print_operand_punctuation): Likewise. + (mips_frame_set): Likewise. + (mips16e_output_save_restore): Likewise. + (mips_cfun_might_clobber_call_saved_reg_p): Likewise. + (mips_save_reg_p): Likewise. + (mips_return_addr): Likewise. + (mips_set_return_address): Likewise. + (mips_direct_save_slot_move_p): Likewise. + (mips_output_function_prologue): Likewise. + (mips_restore_reg): Likewise. + (mips_expand_epilogue): Likewise. + (mips_epilogue_uses): Likewise. + * config/mips/mips.md (RETURN_ADD_REGNUM): Define. + (*mov<mode>_ra): Use it instead of a hard-coded 31. + (clear_hazard_<mode>): Likewise. + (call_internal): Likewise. + (call_internal_direct): Likewise. + (call_direct_split): Likewise. + (call_value_internal): Likewise. + (call_value_split): Likewise. + (call_value_internal_direct): Likewise. + (call_value_direct_split): Likewise. + (call_value_multiple_internal): Likewise. + (call_value_multiple_split): Likewise. + +2009-10-05 Eric Botcazou <ebotcazou@adacore.com> + Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/41511 + * combine.c (record_value_for_reg): Pass explicit values as argument + to get_last_value_validate. + (get_last_value_validate): Document INSN parameter. + For non-readonly MEMs, assume they might have been modified if INSN + was in another basic block. + (get_last_value): Minor reformatting. + +2009-10-05 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR tree-opt/40992 + * final.c (asm_str_count): Split out from asm_insn_count. + * rtl.h (asm_str_count): New prototype. + * tree-inline (estimate_num_insns) <case GIMPLE_ASM>: Call + asm_str_count. + +2009-10-05 Sriraman Tallam <tmsriram@google.com> + + * doc/plugins.texi: Change plugin_pass to register_pass_info. + +2009-10-05 Basile Starynkevitch <basile@starynkevitch.net> + Rafael Espindola <espindola@google.com> + + * gengtype.c (write_types): Moved call to write_func_for_structure + into seperate loops. + +2009-10-05 Richard Guenther <rguenther@suse.de> + + PR lto/41281 + * lto-cgraph.c (output_cgraph): Output toplevel asms. + (input_cgraph_1): Input toplevel asms. + +2009-10-05 Richard Guenther <rguenther@suse.de> + + PR lto/40902 + * lto-symtab.c (lto_compatible_attributes_p): Remove. + (external_aggregate_decl_p): Likewise. + (lto_symtab_compatible): Re-structure. Remove dead code. + For variables ignore toplevel qualifiers when comparing types. + Issue warnings, not errors for mismatched user-alignment. + +2009-10-05 Richard Guenther <rguenther@suse.de> + + PR lto/41552 + PR lto/41487 + * lto-symtab.c (struct lto_symtab_base_def): Remove. + (struct lto_symtab_identifier_def): Likewise. + (struct lto_symtab_decl_def): Likewise. + (struct lto_symtab_entry_def): New. + (lto_symtab_identifier_t): Rename to ... + (lto_symtab_entry_t): ... this. + (lto_symtab_decls): Remove. + (lto_symtab_base_hash): Rename to ... + (lto_symtab_entry_hash): ... this. + (lto_symtab_base_eq): Rename to ... + (lto_symtab_entry_eq): ... this. + (lto_symtab_base_marked_p): Rename to ... + (lto_symtab_entry_marked_p): ... this. + (lto_symtab_identifier_marked_p): Remove. + (lto_symtab_decl_marked_p): Likewise. + (lto_symtab_maybe_init_hash_tables): Rename to ... + (lto_symtab_maybe_init_hash_table): ... this. + (lto_symtab_set_resolution_and_file_data): Remove. + (lto_symtab_register_decl): New function. + (lto_symtab_get_identifier): Remove. + (lto_symtab_get): New function. + (lto_symtab_get_resolution): Adjust. + (lto_symtab_get_identifier_decl): Remove. + (lto_symtab_set_identifier_decl): Likewise. + (lto_symtab_merge_decl): Rename to ... + (lto_symtab_merge): ... this. Rewrite. + (lto_symtab_merge_var): Remove. + (lto_symtab_merge_fn): Likewise. + (lto_symtab_prevailing_decl): Adjust. + (lto_cgraph_replace_node): New function. + (lto_symtab_merge_decls_2): Likewise. + (lto_symtab_merge_decls_1): Likewise. + (lto_symtab_fixup_var_decls): Likewise. + (lto_symtab_resolve_symbols): Likewise. + (lto_symtab_merge_decls): Likewise. + (lto_symtab_prevailing_decl): Adjust. + (lto_symtab_get_symtab_def): Remove. + (lto_symtab_get_file_data): Likewise. + (lto_symtab_clear_resolution): Adjust. + (lto_symtab_clear_resolution): Likewise. + * lto-cgraph.c (input_edge): Do not merge cgraph nodes here. + (input_cgraph_1): Likewise. + * lto-streamer-in.c (get_resolution): Do not provide fake + symbol resolutions here. + (deferred_global_decls): Remove. + (lto_register_deferred_decls_in_symtab): Likewise. + (lto_register_var_decl_in_symtab): Change signature, register + variable via lto_symtab_register_decl. + (lto_register_function_decl_in_symtab): Likewise. + (lto_read_tree): Adjust. + * lto-streamer.h (lto_register_deferred_decls_in_symtab): Remove. + (lto_symtab_merge_var): Likewise. + (lto_symtab_merge_fn): Likewise. + (lto_symtab_register_decl): Declare. + (lto_symtab_merge_decls): Likewise. + +2009-10-05 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/23821 + * tree-vrp.c (vrp_finalize): Do not perform copy propagation. + * tree-ssa-dom.c (cprop_operand): Do not propagate copies into + simple IV increments. + +2009-10-05 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (arm_override_options): Really initialize + flag_dwarf2_cfi_asm to 0. + +2009-10-05 Doug Kwan <dougkwan@google.com> + + PR rtl-optimization/41574 + * combine.c (distribute_and_simplify_rtx): Quit if RTX mode is + floating point and we are not doing unsafe math optimizations. + +2009-10-03 Simon Baldwin <simonb@google.com> + Cary Coutant <ccoutant@google.com> + Rafael Espindola <espindola@google.com> + Richard Guenther <rguenther@suse.de> + Jan Hubicka <jh@suse.cz> + Doug Kwan <dougkwan@google.com> + H.J. Lu <hongjiu.lu@intel.com> + Bill Maddox <maddox@google.com> + Ryan Mansfield <rmansfield@qnx.com> + Diego Novillo <dnovillo@google.com> + Ollie Wild <aaw@google.com> + Kenneth Zadeck <zadeck@naturalbridge.com> + + * lto-cgraph.c: New file. + * lto-compress.c: New file. + * lto-compress.h: New file. + * lto-opts.c: New file. + * lto-section-in.c: New file. + * lto-section-out.c: New file. + * lto-streamer-in.c: New file. + * lto-streamer-out.c: New file. + * lto-streamer.c: New file. + * lto-streamer.h: New file. + * lto-symtab.c: New file. + * lto-wpa-fixup.c: New file. + * lto-wrapper.c: New file. + +2009-10-03 Simon Baldwin <baldwin@google.com> + Ben Elliston <bje@au.ibm.com> + Rafael Espindola <espindola@google.com> + Nathan Froyd <froydnj@codesourcery.com> + Jan Hubicka <jh@suse.cz> + Doug Kwan <dougkwan@google.com> + Diego Novillo <dnovillo@google.com> + Kenneth Zadeck <zadeck@naturalbridge.com> + + * Makefile.in (enable_lto): New. + (site.exp): If @enable_lto@ is set to 'yes' define ENABLE_LTO. + (LINKER_PLUGIN_API_H): Define. + (LTO_SYMTAB_H): Define. + (LTO_STREAMER_H): Define. + (TREE_VECTORIZER_H): Define. + (INCLUDES): Add LIBELFINC. + (OBJS-common): Add lto-cgraph.o, lto-streamer-in.o, + lto-streamer-out.o, lto-section-in.o, lto-section-out.o, lto-symtab.o, + lto-opts.o, lto-streamer.o, lto-wpa-fixup.o, lto-compress.o. + (MOSTLYCLEANFILES): Add lto-wrapper$(exeext) + (native): Add lto-wrapper$(exeext) + (lto-compress.o, lto-cgraph.o, lto-streamer-in.o, + lto-streamer-out.o, lto-section-in.o, lto-section-out.o, + lto-symtab.o, lto-opts.o, lto-streamer.o, lto-wpa-fixup.o): New rules. + (gimple.o): Add dependency on LTO_HEADER_H and LTO_SECTION_OUT_H. + (varasm.o): Add dependency on tree-iterator.h. + (cgraph.o): Add dependency on cif-code.def. + (ipa-reference.o): Add dependency on LTO_STREAMER_H. + (ipa-pure-const.o): Likewise. + (GTFILES): Add lto-symtab.c. + (install-lto-wrapper): New. + * configure.ac: If 'lto' is in enable_languages, define ENABLE_LTO + and enable_lto. If LIBELFLIBS is set, define HAVE_libelf. + * config.in: Regenerate. + +2009-10-03 Rafael Espindola <espindola@google.com> + Diego Novillo <dnovillo@google.com> + + * cgraphunit.c (ipa_passes): Prevent lto1 from calling + ipa_write_summaries. + Call execute_ipa_summary_passes for all_regular_ipa_passes and + all_lto_gen_passes. + (cgraph_optimize): Make extern. + +2009-10-03 Nathan Froyd <froydnj@codesourcery.com> + Kenneth Zadeck <zadeck@naturalbridge.com> + + * toplev.c (in_lto_p): Declare. + * collect2.c (scan_prog_file): Read all the output when reading + information for LTO. + (enum lto_mode_d): Declare. + +2009-10-03 Richard Guenther <rguenther@suse.de> + Diego Novillo <dnovillo@google.com> + + * gimple.c: Include target.h and alias.h. + (gimple_types): Declare. + (type_hash_cache): Declare. + (gimple_alloc_stat): Make extern. + (gimple_build_eh_must_not_throw): Call + gimple_eh_must_not_throw_set_fndecl. + (struct type_pair_d): Declare. + (type_pair_t): Declare. + (type_pair_hash): New. + (type_pair_eq): New. + (lookup_type_pair): New. + (gimple_force_type_merge): New. + (compare_type_names_p): New. + (compare_field_offset): New. + (gimple_types_compatible_p): New. + (struct sccs): Declare. + (next_dfs_num): Declare. + (iterative_hash_gimple_type): New. + (visit): New. + (iterative_hash_type_name): New. + (iterative_hash_gimple_type): New. + (gimple_type_hash): New. + (gimple_type_eq): New. + (gimple_register_type): New. + (print_gimple_types_stats): New. + (gimple_signed_or_unsigned_type): New. + (gimple_unsigned_type): New. + (gimple_signed_type): New. + (gimple_get_alias_set): New. + (gimple_decl_printable_name): Do not use DMGL_TYPES. + * gimple.h (gimple_alloc, gimple_alloc_stat): Declare. + (gimple_force_type_merge): Declare. + (gimple_types_compatible_p): Declare. + (gimple_register_type): Declare. + (print_gimple_types_stats): Declare. + (gimple_unsigned_type): Declare. + (gimple_signed_type): Declare. + (gimple_get_alias_set): Declare. + (gimple_eh_must_not_throw_set_fndecl): New. + +2009-10-03 Jan Hubicka <jh@suse.cz> + Kenneth Zadeck <zadeck@naturalbridge.com> + + * ipa-pure-const.c: Include lto-streamer.h. + (register_hooks): Factor out of ... + (generate_summary): ... here. + (pure_const_write_summary): New. + (pure_const_read_summary): New. + (pass_ipa_pure_const): Add pure_const_write_summary and + pure_const_read_summary. + * ipa-reference.c: Include lto-streamer.h. + (add_new_function): New. + (remove_node_data): New. + (duplicate_node_data): New. + (ipa_init): Guard against multiple calls. + Move hook setup from analyze_function. + (write_node_summary_p): New. + (ipa_reference_write_summary): New. + (ipa_reference_read_summary): New. + (pass_ipa_reference): Add ipa_reference_write_summary and + ipa_reference_read_summary. + * cgraph.h (cgraph_local_info): Add field lto_file_data. + (struct cgraph_edge): Add fields lto_stmt_uid and + call_stmt_cannot_inline_p. + (cgraph_optimize): Declare. + (cgraph_decide_is_function_needed): Declare. + (reset_inline_failed): Declare. + (enum LTO_cgraph_tags): Declare. + (LTO_cgraph_tag_names): Declare. + (LCC_NOT_FOUND): Define. + +2009-10-03 Doug Kwan <dougkwan@google.com> + Rafael Espindola <espindola@google.com> + Jan Hubicka <jh@suse.cz> + Diego Novillo <dnovillo@google.com> + Kenneth Zadeck <zadeck@naturalbridge.com> + + * passes.c (all_regular_ipa_passes): New. + (all_ipa_passes): Rename to all_small_ipa_passes. + (init_optimization_passes): Init all_regular_ipa_passes. + * tree-pass.h (all_regular_ipa_passes): New. + (all_ipa_passes): Rename to all_small_ipa_passes. + * passes.c (all_lto_gen_passes): New. + (init_optimization_passes): Initialize all_lto_gen_passes. + (execute_ipa_summary_passes): Make non-static. + (ipa_write_summaries_1): New. + (ipa_write_summaries_2): New. + (ipa_write_summaries): New. + (ipa_write_summaries_of_cgraph_node_set): New. + (ipa_read_summaries_1): New. + (ipa_read_summaries): New. + (execute_ipa_pass_list): Call cgraph_process_new_functions. + (execute_regular_ipa_pass_list): Remove. + (init_optimization_passes): Schedule + pass_rebuild_cgraph_edges and pass_early_inline outside + of pass_all_early_optimizations. Document reason. + (pass_ipa_lto_gimple_out, pass_ipa_lto_wpa_fixup, + pass_ipa_lto_finish_out): New pass. + (pass_ipa_summary_passes): Start and stop timers if the pass has them. + (execute_all_ipa_transforms): New. + (execute_one_pass): Don't call execute_one_ipa_transform_pass. + (dump_properties, debug_properties): New. + * tree-optimize.c (gate_all_early_local_passes): Return + false if we are in lto1. + (tree_rest_of_compilation): Call execute_all_ipa_transforms. + * tree-pass.h (execute_all_ipa_transforms): Declare. + (pass_ipa_function_and_variable_visibility): Declare. + (pass_ipa_early_inline): Declare. + (pass_ipa_lto_gimple_out): Declare. + (pass_ipa_lto_wpa_fixup): Declare. + (pass_ipa_lto_finish_out): Declare. + (all_small_ipa_passes, all_regular_ipa_passes, + all_lto_gen_passes): Declare. + (execute_ipa_summary_passes): Declare. + (execute_all_ipa_transforms): Declare. + (ipa_write_summaries): Declare + (ipa_write_summaries_of_cgraph_node_set): Declare. + (ipa_read_summaries): Declare. + +2009-10-03 Doug Kwan <dougkwan@google.com> + Ollie Wild <aaw@google.com> + + * ipa-prop.c (ipa_propagate_indirect_call_infos): Do nothing in WPA. + + * collect2.c (LTO_MODE_NONE, LTO_MODE_LTO, LTO_MODE_WPA): New enums. + (lto_mode): New variable. + (maybe_run_lto_and_relink): Handle the -fwpa option. + (main): Handle the -fwpa option. + (maybe_unlink_list): New function. + * gcc.c (link_lto_options): Replace -flto with -fwpa. + * common.opt (flto): New flag. + * toplev.c (flag_generate_lto): Declare. + +2009-10-03 Simon Baldwin <simonb@google.com> + + * common.opt (flto-compression-level): New flag. + + * opts.c: Include lto-opts.h. + (handle_option): Call lto_register_user_option for each + valid option handled. + (decode_options): Clear registered options before the options + handling loop. + +2009-10-03 Cary Coutant <ccoutant@google.com> + + * collect2.c (is_elf): New function. + (scan_prog_file): Require LTO object to be in ELF format. + +2009-10-03 Rafael Espindola <espindola@google.com> + + * gcc.c (LINK_COMMAND_SPEC): Use the -pass-through option to pass + libgcc to the linker. + + * ipa-cp.c (cgraph_gate_cp): Return false if LTRANS is running. + + * collect2.c (maybe_run_lto_and_relink): Execute lto-wrapper. + (collect_execute): Add flags argument. Pass flags to pex_run. Update + all callers. + * collect2.h (collect_execute): Add flags argument. + * tlink.c (tlink_execute): Update call to collect_execute. + * gcc.c (main): Set the COLLECT_LTO_WRAPPER environment variable. + (use_linker_plugin): New. + (use_linker_plugin_spec_function): New. + (LINK_COMMAND_SPEC): Pass plugin options to the linker. + (linker_plugin_file_spec): New. + (lto_wrapper_spec): New. + (lto_gcc_spec): New. + (static_specs): Add linker_plugin_file, lto_wrapper and lto_gcc. + (static_spec_functions): Add use-linker-plugin. + (process_command): Handle -use-linker-plugin. + (main): Use lto_wrapper_spec instead of lto_wrapper. Set + linker_plugin_file_spec and lto_gcc_spec. + (use_linker_plugin_spec_function): New. + +2009-10-03 Richard Guenther <rguenther@suse.de> + + PR lto/41547 + PR lto/41548 + * tree.h (is_lang_specific): Include LANG_TYPE. + * tree.c (find_decls_types_r): Manually add interesting parts + of TYPE_FIELDS. Walk BINFO_VIRTUALS. Do not walk TYPE_METHODS. + + * gimple.c (type_pair_hash): Make symmetric. + (type_pair_eq): Likewise. + (lookup_type_pair): Increase initial hashtable size. + (gimple_force_type_merge): Rely on type-pair symmetry. + (visit): Remove excessive checking code. + (iterative_hash_type_name): Do not hash TYPE_NAME of anonymous unions. + (gimple_register_type): Remove getenv calls, shrink initial + hashtable size. + + PR middle-end/41502 + * cgraphunit.c (ipa_passes): Do not remove bodies of extern + inline functions if not generating lto output. + + PR lto/41379 + * toplev.c (finalize): In WPA mode remove the asm file. + +2009-10-03 Doug Kwan <dougkwan@google.com> + + * ipa-inline.c (cgraph_mark_inline): Check + edge->call_stmt_cannot_inline_p instead of calling + gimple_call_cannot_inline_p. + (cgraph_decide_inlining): Do nothing in WPA and LTRANS. + (cgraph_gate_ipa_early_inlining): Return false if in_lto_p is set. + (inline_generate_summary): Do nothing in LTRANS. + * cgraph.c (initialize_inline_failed): Make sure e->call_stmt + exists before calling gimple_call_cannot_inline_p. + (cgraph_create_edge): Set edge->call_stmt_cannot_inline_p. + (cgraph_clone_edge): Add argument STMT_UID. Modify all callers. + Update new_edge->lto_stmt_uid. + * cgraphbuild.c (reset_inline_failed): New. + + * common.opt (fwpa): New flag. + (fltrans): New option. + * gcc.c (gcc_lto_option_t): New type. + (current_lto_option): New variable. + (lto_single_spec_function): Remove and is replaced by .. + (lto_option_spec_function): New function. + (LINK_COMMAND_SPEC): Use link_lto_option spec instead of just + passing the -flto flag. + (cc1_options): Separate non-LTO related parts into .. + (cc1_non_lto_options): Non-LTO related options shared by all FEs. + (lto1_options): New spec for lto FE. + (link_lto_options): New spec for handling LTO flags in linker. + (invoke_lto_single): Re-format to fit in 80 column. Replace + lto-single with lto-option. + (static_specs): Add cc1_non_lto_options, lto1_options and + link_lto_options. + (static_spec_function): Replace lto-single with lto-option. + (process_command): Handle -flto, -fwpa and -fltran by setting + current_lto_option and not passing it to subprocess unconditionally. + +2009-10-03 Bill Maddox <maddox@google.com> + + Add `gcc' driver support for link-time code generation (LTO). + + * collect2.c (enum pass): Add new literal PASS_LTOINFO. + (lto_flag, lto_objects, lto_o_file): New variables. + (struct lto_object, struct lto_object_list): New structures. + (collect_exit, handler): Remove LTO temporary output file on exit. + (add_lto_object): New function. + (maybe_run_lto_and_relink): New function. Perform link time code + generation and relinking for object files containing LTO information. + (main): Invoke maybe_run_lto_and_relink(). + (dump_argv): New function. For debugging, currently disabled. + (scan_prog_file): Add LTO information pass. + * gcc.c (LINK_COMMAND_SPEC): Pass `-flto' switch to linker, i.e., + collect2. + * toplev.c (compile_file): Emit assembler directive to create + the `gnu_lto_v1' marker symbol when compiling with `-flto'. + +2009-10-03 Diego Novillo <dnovillo@google.com> + + * c.opt: Add LTO to warn_abi and warn_psabi. + + * tree.c (fld_worklist_push): Rename from PUSH. Convert to static + inline function. Ignore language-specific nodes. Update all users. + (find_decls_types_r): Do not traverse the subtrees of + language-specific nodes. Do not traverse DECL_INITIAL for TYPE_DECLs. + * tree.h (is_lang_specific): New. + * langhooks.h (struct lang_hooks_for_decls): Remove + may_need_assembler_name_p. Update all users. + + * c-common.c (set_builtin_user_assembler_name): Move ... + * builtins.c (set_builtin_user_assembler_name): ... here. + (is_builtin_name): Add comment + (is_builtin_fn): New. + * except.c (output_ttype): Only call + lookup_type_for_runtime if TYPE is not a runtime type. + + * passes.c (register_pass): Call position_pass on + all_small_ipa_passes, all_regular_ipa_passes and all_lto_gen_passes. + * timevar.def (TV_IPA_LTO_GIMPLE_IO): Define. + (TV_IPA_LTO_DECL_IO): Define. + (TV_IPA_LTO_CGRAPH_IO): Define. + (TV_LTO): Define. + (TV_WHOPR_WPA): Define. + (TV_WHOPR_WPA_IO): Define. + (TV_WHOPR_LTRANS): Define. + (TV_WHOPR_WPA_FIXUP): Define. + (TV_WHOPR_WPA_LTRANS_EXEC): Define. + * tree-cfg.c (tree_node_can_be_shared): Make extern. + * tree-flow.h (tree_node_can_be_shared): Declare. + * tree-inline.c (tree_can_inline_p): Check that E has a + statement associated with it. + * tree.c (free_lang_data_in_binf): Factor out of ... + (free_lang_data_in_type): ... here. + Call RECORD_OR_UNION_TYPE_P. + (need_assembler_name_p): Ignore DECL if it does not have TREE_PUBLIC + set. Call lang_hooks.decls.may_need_assembler_name_p if set. + (free_lang_data_in_decl): Do not clear DECL_CONTEXT for CONST_DECLs. + (free_lang_data): Set debug_info_level to DINFO_LEVEL_NONE. Set + write_symbols to NO_DEBUG. Set debug_hooks to do_nothing_debug_hooks. + (gate_free_lang_data): Return true if flag_generate_lto is set. + (walk_tree_1): Call RECORD_OR_UNION_TYPE_P. + * c-common.h (set_builtin_user_assembler_name): Move ... + * tree.h (set_builtin_user_assembler_name): ... here. + + * common.opt (flto-report): New flag. + * opts.c (complain_wrong_lang): Do not complain if running lto1. + * collect2.c (scan_prog_file): Send the error output of + 'nm' to HOST_BIT_BUCKET. + +2009-10-03 Ollie Wild <aaw@google.com> + + * langhooks-def.h (lhd_begin_section): New function declaration. + (lhd_write_section): New function declaration. + (lhd_end_section): New function declaration. + (LANG_HOOKS_BEGIN_SECTION): New macro. + (LANG_HOOKS_WRITE_SECTION_DATA): New macro. + (LANG_HOOKS_END_SECTION): New macro. + (LANG_HOOKS_LTO): New macro. + (LANG_HOOKS_INITIALIZER): Add LANG_HOOKS_LTO. + * langhooks.c (output.h): Add include. + (saved_section): New static variable. + (lhd_begin_section): New function. + (lhd_write_section_data): New function. + (lhd_end_section): New function. + * langhooks.h (struct lang_hooks_for_lto): New structure. + (struct lang_hooks): Add member lto. + * Makefile.in (langhooks.o): Add dependency on output.h. + + * c-opts.c (c_common_post_options): Handle -flto and -fwhopr. + +2009-10-03 Richard Guenther <rguenther@suse.de> + + * config/rs6000/rs6000.c (rs6000_output_function_epilogue): + Handle LTO. + +2009-10-03 Simon Baldwin <simonb@google.com> + Richard Guenther <rguenther@suse.de> + Janis Johnson <janis187@us.ibm.com> + Doug Kwan <dougkwan@google.com> + Diego Novillo <dnovillo@google.com> + Ramana Radhakrishnan <ramana.r@gmail.com> + Ollie Wild <aaw@google.com> + + * doc/install.texi: Add documentation for libelf and --enable-lto. + * doc/invoke.texi: Document -fwpa, -flto, -fwhopr, -fltrans, + -flto-report, -flto-compression-level and -use-linker-plugin. + * doc/sourcebuild.texi: Document use of zlib. Document lto-plugin. + Add section for LTO Testing. + +2009-10-02 Cary Coutant <ccoutant@google.com> + + Add support for comdat type sections for DWARF v4. + Merge from dwarf4 branch. + + * dwarf2out.c (DWARF_TYPE_SIGNATURE_SIZE): New constant. + (dw_die_ref): Define vector type. + (enum dw_val_class): Add dw_val_class_data8. + (struct dw_val_struct): Add v.val_data8. + (comdat_type_node_ref): New type. + (struct die_struct): Move die_symbol into a union; add new field + die_type_node. Change all uses. + (comdat_type_node): New type. + (skeleton_chain_node): New type. + (DWARF_COMDAT_TYPE_UNIT_HEADER_SIZE): New constant. + (comdat_type_list): New variable. + (dwarf_tag_name): Add DW_TAG_type_unit. + (dwarf_attr_name): Add DW_AT_signature. + (add_AT_data8): New function. + (replace_child): New function. + (move_all_children): New function. + (print_signature): New function. + (print_die): Print signature information; add dw_val_class_data8. + (attr_checksum): Support dw_val_class_data8. + (CHECKSUM_STRING): Redefine for DWARF-4 to include trailing NULL byte. + (CHECKSUM_SLEB128, CHECKSUM_ULEB128): New macros. + (checksum_sleb128, checksum_uleb128): New functions. + (checksum_die_context): New function. + (loc_checksum_ordered): New function. + (attr_checksum_ordered): New function. + (struct checksum_attributes): New structure. + (collect_checksum_attributes): New function. + (die_checksum_ordered): New function. + (generate_type_signature): New function. + (same_dw_val_p): Add dw_val_class_data8. + (is_symbol_die): Use new is_declaration_die function. + (is_declaration_die): New function. + (should_move_die_to_comdat): New function. + (clone_die): New function. + (clone_tree): New function. + (clone_as_declaration): New function. + (copy_declaration_context): New function. + (generate_skeleton_ancestor_tree): New function. + (generate_skeleton_bottom_up): New function. + (generate_skeleton): New function. + (remove_child_or_replace_with_skeleton): New function. + (break_out_comdat_types): New function. + (struct decl_table_entry): New type. + (htab_decl_hash): New function. + (htab_decl_eq): New function. + (htab_decl_del): New function. + (copy_ancestor_tree): New function. + (copy_decls_walk): New function. + (copy_decls_for_unworthy_types): New function. + (build_abbrev_table): Don't assert on missing die_symbol when doing + comdat type sections. + (size_of_die): Use DW_FORM_sig8 for external references. Add + dw_val_class_data8. + (unmark_dies): Don't assert for unmarked dies when doing comdat + type sections. + (value_format): Support DW_FORM_sig8 and dw_val_class_data8. + (output_signature): New function. + (output_die): Likewise. + (output_compilation_unit_header): Mark output as DWARF version 3 + even if generating DWARF 4. + (output_comdat_type_unit): New function. + (output_line_info): Mark output as DWARF version 3 even if generating + DWARF 4. + (dwarf2out_start_source_file): Don't do eliminate_dwarf2_dups with + DWARF-4. + (dwarf2out_end_source_file): Likewise. + (prune_unused_types_walk_attribs): Don't follow references into + comdat type sections. + (prune_unused_types_mark): When generating type units, do not mark + children of non-defining declarations of types; do mark children of + type entries. + (prune_unused_types): Process comdat type sections. + (htab_ct_hash): New function. + (htab_ct_eq): New function. + (dwarf2out_finish): Move types to comdat sections when using DWARF-4. + Add a pointer to the line table from type unit entries so + DW_AT_decl_file has meaning. + * varasm.c (default_elf_asm_named_section): Use identifier name as + comdat key instead of lang hook. + +2009-10-02 Neil Vachharajani <nvachhar@google.com> + + * gcov-io.c (gcov_open): Open files read-only when MODE < 0. + +2009-10-02 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (SWIM248): New mode iterator. + (divmod<mode>4) Macroize expander from divmoddi4, divmodsi4 and + divmodhi4 patterns using SWIM248 macro. + (*divmod<mode>4): Macroize insn_and_split pattern from + *divmoddi4_cltd_rex64, *divmodsi4_cltd and divmodhi4 insn patterns + and their corresponding splitters usign SWIM248 macro. Split SImode + insn to generate cltd and DImode insn to generate cqto instead of + move+shift when optimizing for size or TARGET_USE_CLTD is in effect. + (*divmoddi4_nocltd_rex64, *divmodsi4_nocltd): Remove insn patterns. + (*divmod<mode>4_noext): Macroize insn from *divmoddi_noext_rex64 and + *divmodsi_noext patterns using SWIM248 macro. + (udivmod<mode>4): Macroize expander from udivmoddi4, udivmodsi4 and + udivmodhi4 patterns using SWIM248 macro. + (*udivmod<mode>4): Macroize insn_and_split pattern from + *udivmoddi4, udivmodsi4 and udivmodhi4 patterns and their + corresponding splitters using SWIM248 macro. + (*udivmod<mode>4_noext): Macroize insn from *udivmoddi4_noext, + *udivmodsi4_noext and *udivmodhi_noext patterns using SWIM248 macro. + +2009-10-02 Eric Botcazou <ebotcazou@adacore.com> + + * stor-layout.c (layout_type) <ARRAY_TYPE>: Make sure that an array + of zero-sized element is zero-sized regardless of its extent. + +2009-10-02 Jakub Jelinek <jakub@redhat.com> + + PR debug/40521 + * configure.ac (HAVE_GAS_CFI_SECTIONS_DIRECTIVE): New test. + * configure: Regenerated. + * config.in: Regenerated. + * dwarf2out.c (dwarf2out_do_cfi_asm): Return false if + !HAVE_GAS_CFI_SECTIONS_DIRECTIVE and not emitting .eh_frame. + (dwarf2out_init): If HAVE_GAS_CFI_SECTIONS_DIRECTIVE and + not emitting .eh_frame, emit .cfi_sections .debug_frame + directive. + + PR debug/41404 + PR debug/41353 + * cfgexpand.c (expand_debug_expr) <case STRING_CST>: Don't create + CONST_STRING if STRING_CST contains embedded '\0's or doesn't end + with '\0'. + (expand_debug_expr) <case VAR_DECL>: For TREE_STATIC !DECL_EXTERNAL + vars use DECL_RTL with resetting it back to NULL afterwards. + * dwarf2out.c (same_dw_val_p): For dw_val_class_addr compare with + rtx_equal_p instead of asserting it is a SYMBOL_REF. + (value_format): For dw_val_class_addr only use DW_FORM_addr if + the attribute type allows it, otherwise use DW_FORM_dataN. + (mem_loc_descriptor): Handle CONST_STRING. + (add_const_value_attribute): Handle CONST_STRING using add_AT_addr. + Handle MEM with CONST_STRING address using add_AT_string. + (rtl_for_decl_init): Return MEM with CONST_STRING address instead of + CONST_STRING for const arrays initialized with a string literal. + (resolve_one_addr, resolve_addr_in_expr, resolve_addr): New functions. + (dwarf2out_finish): Call resolve_addr. + +2009-10-02 Andreas Schwab <schwab@linux-m68k.org> + Maxim Kuvyrkov <maxim@codesourcery.com> + + * config/m68k/lb1sf68.asm (PICCALL): Use variable sized branch. + +2009-10-02 Nick Clifton <nickc@redhat.com> + + * config/mn10300/mn10300.h (USER_LABEL_PREFIX): Define. + (ASM_OUTPUT_LABELREF): Use asm_fprintf and %U. + +2009-10-01 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_clone_node): Add redirect_callers parameter. + (cgraph_create_virtual_clone): Just pass redirect_callers + around. + * cgraph.h (cgraph_clone_node): Update prototype. + * ipa-pure-const.c (self_recursive_p): New function. + (propagate): Use it. + * ipa-inline.c (cgraph_clone_inlined_nodes, + cgraph_decide_recursive_inlining): Update. + +2009-10-01 David Daney <ddaney@caviumnetworks.com> + + * gcc/config/mips/mips.c (mips_process_sync_loop) Emit syncw + instructions for TARGET_OCTEON. + +2009-10-01 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (arm_override_options): Turn off + flag_dwarf2_cfi_asm for AAPCS variants. + +2009-10-01 Martin Jambor <mjambor@suse.cz> + + PR middle-end/12392 + * tree-sra.c (convert_callers): Do not call + compute_inline_parameters on one caller more than once. + +2009-10-01 Nick Clifton <nickc@redhat.com> + + * config/vax/netbsd-elf.h (NETBSD_CC1_AND_CC1PLUS_SPEC): Define as + an empty string if not already defined. + +2009-10-01 Martin Jambor <mjambor@suse.cz> + + PR bootstrap/41395 + * tree-sra.c (is_va_list_type): New function. + (find_var_candidates): Call is_va_list_type. + (find_param_candidates): Check that the type or the type pointed + to are not va_list types. + +2009-10-01 Martin Jambor <mjambor@suse.cz> + + PR c++/41503 + * cp/pt.c (function_parameter_expanded_from_pack_p): Return false if + DECL_ARTIFICIAL (param_decl) is true. + +2009-09-30 Gabriel Dos Reis <gdr@cs.tamu.edu> + + * tree.h (tree_decl_common::lang_flag_8): New. + * c-common.c (c_common_reswords): Include "constexpr" as C++0x + keyword. + * c-common.h (RID_CONSTEXPR): New. + +2009-09-30 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_gimplify_va_arg_1): + Use ref-all pointers. + (alpha_gimplify_va_arg): Ditto. + +2009-09-30 Jakub Jelinek <jakub@redhat.com> + + PR target/41279 + * cfgloopanal.c (num_loop_insns): Don't increment ninsns for each bb + before insn counting loop now that BB_END (bb) is counted. Ensure + the return value isn't zero. + +2009-09-30 Nick Clifton <nickc@redhat.com> + + * config.gcc (sh-symbianelf): Replace definition of extra_objs + with separate definitions of c_target_objs and cxx_target_objs. + * config/sh/t-sh: Add rules to build symbian-cxx.o, symbian-c.o + and symbian-base.o. + * config/sh/sh.c (TARGET_CXX_INPUT_EXPORT_CLASS): Use + sh_symbian_import_export_class. + * config/sh/sh-protos.h: Fix names of exported symbian functions. + * config/sh/symbian.c: Delete, moving code into... + * config/sh/symbian-base.c: ... here + * config/sh/symbian-c.c: ... and here + * config/sh/symbian-cxx.c: ... and here. + +2009-09-30 Uros Bizjak <ubizjak@gmail.com> + + PR target/22093 + * config/alpha/alpha.md (unaligned_storehi_be): Force operand + of plus RTX into register. + +2009-09-30 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/install.texi: Linguistic and markup fixes. + (Configuration) <--disable-cpp>: Remove description. + <--enable-maintainer-mode>: Autotools files are affected, too. + <--with-sysroot>: Improve description. + (Building): Bump required GNU make version. + +2009-09-29 Harsha Jagasia <harsha.jagasia@amd.com> + + * config.gcc (i[34567]86-*-*): Include fma4intrin.h. + (x86_64-*-*): Ditto. + + * config/i386/fma4intrin.h: New file, provide common x86 compiler + intrinisics for FMA4. + * config/i386/cpuid.h (bit_FMA4): Define FMA4 bit. + * config/i386/x86intrin.h: Fix typo to SSE4A instead of SSE4a. + Add FMA4 check and fma4intrin.h. + * config/i386/i386-c.c(ix86_target_macros_internal): Check + ISA_FLAG for FMA4. + * config/i386/i386.h(TARGET_FMA4): New macro for FMA4. + * config/i386/i386.md (UNSPEC_FMA4_INTRINSIC): Add new UNSPEC + constant for FMA4 support. + (UNSPEC_FMA4_FMADDSUB): Ditto. + (UNSPEC_FMA4_FMSUBADD): Ditto. + * config/i386/i386.opt (-mfma4): New switch for FMA4 support. + * config/i386/i386-protos.h (ix86_fma4_valid_op_p): Add declaration. + (ix86_expand_fma4_multiple_memory): Ditto. + * config/i386/i386.c (OPTION_MASK_ISA_FMA4_SET): New. + (OPTION_MASK_ISA_FMA4_UNSET): New. + (OPTION_MASK_ISA_SSE4A_UNSET): Change definition to depend on FMA4. + (OPTION_MASK_ISA_AVX_UNSET): Change definition to depend on FMA4. + (ix86_handle_option): Handle -mfma4. + (isa_opts): Handle -mfma4. + (enum pta_flags): Add PTA_FMA4. + (override_options): Add FMA4 support. + (IX86_BUILTIN_VFMADDSS): New for FMA4 intrinsic. + (IX86_BUILTIN_VFMADDSD): Ditto. + (IX86_BUILTIN_VFMADDPS): Ditto. + (IX86_BUILTIN_VFMADDPD): Ditto. + (IX86_BUILTIN_VFMSUBSS): Ditto. + (IX86_BUILTIN_VFMSUBSD): Ditto. + (IX86_BUILTIN_VFMSUBPS): Ditto. + (IX86_BUILTIN_VFMSUBPD): Ditto. + (IX86_BUILTIN_VFMADDSUBPS): Ditto. + (IX86_BUILTIN_VFMADDSUBPD): Ditto. + (IX86_BUILTIN_VFMSUBADDPS): Ditto. + (IX86_BUILTIN_VFMSUBADDPD): Ditto. + (IX86_BUILTIN_VFNMADDSS): Ditto. + (IX86_BUILTIN_VFNMADDSD): Ditto. + (IX86_BUILTIN_VFNMADDPS): Ditto. + (IX86_BUILTIN_VFNMADDPD): Ditto. + (IX86_BUILTIN_VFNMSUBSS): Ditto. + (IX86_BUILTIN_VFNMSUBSD): Ditto. + (IX86_BUILTIN_VFNMSUBPS): Ditto. + (IX86_BUILTIN_VFNMSUBPD): Ditto. + (IX86_BUILTIN_VFMADDPS256): Ditto. + (IX86_BUILTIN_VFMADDPD256): Ditto. + (IX86_BUILTIN_VFMSUBPS256): Ditto. + (IX86_BUILTIN_VFMSUBPD256): Ditto. + (IX86_BUILTIN_VFMADDSUBPS256): Ditto. + (IX86_BUILTIN_VFMADDSUBPD256): Ditto. + (IX86_BUILTIN_VFMSUBADDPS256): Ditto. + (IX86_BUILTIN_VFMSUBADDPD256): Ditto. + (IX86_BUILTIN_VFNMADDPS256): Ditto. + (IX86_BUILTIN_VFNMADDPD256): Ditto. + (IX86_BUILTIN_VFNMSUBPS256): Ditto. + (IX86_BUILTIN_VFNMSUBPD256): Ditto. + (enum multi_arg_type): New enum for describing the various FMA4 + intrinsic argument types. + (bdesc_multi_arg): New table for FMA4 intrinsics. + (ix86_init_mmx_sse_builtins): Add FMA4 intrinsic support. + (ix86_expand_multi_arg_builtin): New function for creating FMA4 + intrinsics. + (ix86_expand_builtin): Add FMA4 intrinsic support. + (ix86_fma4_valid_op_p): New function to validate FMA4 3 and 4 + operand instructions. + (ix86_expand_fma4_multiple_memory): New function to split the + second memory reference from FMA4 instructions. + * config/i386/sse.md (ssemodesuffixf4): New mode attribute for FMA4. + (ssemodesuffixf2s): Ditto. + (fma4_fmadd<mode>4): Add FMA4 floating point multiply/add + instructions. + (fma4_fmsub<mode>4): Ditto. + (fma4_fnmadd<mode>4): Ditto. + (fma4_fnmsub<mode>4): Ditto. + (fma4_vmfmadd<mode>4): Ditto. + (fma4_vmfmsub<mode>4): Ditto. + (fma4_vmfnmadd<mode>4): Ditto. + (fma4_vmfnmsub<mode>4): Ditto. + (fma4_fmadd<mode>4256): Ditto. + (fma4_fmsub<mode>4256): Ditto. + (fma4_fnmadd<mode>4256): Ditto. + (fma4_fnmsub<mode>4256): Ditto. + (fma4_fmaddsubv8sf4): Ditto. + (fma4_fmaddsubv4sf4): Ditto. + (fma4_fmaddsubv4df4): Ditto. + (fma4_fmaddsubv2df4): Ditto. + (fma4_fmsubaddv8sf4): Ditto. + (fma4_fmsubaddv4sf4): Ditto. + (fma4_fmsubaddv4df4): Ditto. + (fma4_fmsubaddv2df4): Ditto. + (fma4i_fmadd<mode>4): Add FMA4 floating point multiply/add + instructions for intrinsics. + (fma4i_fmsub<mode>4): Ditto. + (fma4i_fnmadd<mode>4): Ditto. + (fma4i_fnmsub<mode>4): Ditto. + (fma4i_vmfmadd<mode>4): Ditto. + (fma4i_vmfmsub<mode>4): Ditto. + (fma4i_vmfnmadd<mode>4): Ditto. + (fma4i_vmfnmsub<mode>4): Ditto. + (fma4i_fmadd<mode>4256): Ditto. + (fma4i_fmsub<mode>4256): Ditto. + (fma4i_fnmadd<mode>4256): Ditto. + (fma4i_fnmsub<mode>4256): Ditto. + (fma4i_fmaddsubv8sf4): Ditto. + (fma4i_fmaddsubv4sf4): Ditto. + (fma4i_fmaddsubv4df4): Ditto. + (fma4i_fmaddsubv2df4): Ditto. + (fma4i_fmsubaddv8sf4): Ditto. + (fma4i_fmsubaddv4sf4): Ditto. + (fma4i_fmsubaddv4df4): Ditto. + (fma4i_fmsubaddv2df4): Ditto. + + * doc/invoke.texi (-mfma4): Add documentation. + * doc/extend.texi (x86 intrinsics): Add FMA4 intrinsics. + +2009-09-29 Richard Henderson <rth@redhat.com> + + * tree-eh.c (unsplit_eh): Do not unsplit if there's already + an edge to the new destination block. + +2009-09-29 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + PR target/41393 + * pa.c (hppa_profile_hook): Use + make_reg_eh_region_note_nothrow_nononlocal to add REG_EH_REGION note. + +2009-09-29 Steve Ellcey <sje@cup.hp.com> + Alexander Monakov <amonakov@ispras.ru> + + PR target/41365 + * config/ia64/predicates.md (not_postinc_destination_operand): New. + (not_postinc_memory_operand): New. + (not_postinc_move_operand): New. + * config/ia64/ia64.md (*cmovdi_internal): Disallow autoincrement. + (*cmovsi_internal): Ditto. + +2009-09-29 Pat Haugen <pthaugen@us.ibm.com> + + * config/rs6000/rs6000.c (rs6000_issue_rate): Don't artificially + restrict issue_rate in first pass when scheduling for register + pressure. + +2009-09-29 Basile Starynkevitch <basile@starynkevitch.net> + Rafael Avila de Espindola <espindola@google.com> + + * gengtype.c (plugin_output): New. + (get_output_file_with_visibility): Return plugin_output for plugins. + (main): Parse and use the -P option. + * gty.texi: Update the command line format. + +2009-09-29 Jakub Jelinek <jakub@redhat.com> + + PR debug/41438 + * dwarf2out.c (const_ok_for_output_1, const_ok_for_output): New + functions. + (mem_loc_descriptor, loc_descriptor, add_const_value_attribute): Bail + out if !const_ok_for_output. + + PR debug/41474 + * dwarf2out.c (mem_loc_descriptor) <case CONCAT, case CONCATN, + case VAR_LOCATION>: Remove gcc_unreachable (). + +2009-09-29 Harsha Jagasia <harsha.jagasia@amd.com> + + * config.gcc (i[34567]86-*-*): Remove mmintrin-common.h. + (x86_64-*-*): Ditto. + * config/i386/smmintrin.h: Move instructions in mmintrin-common.h + back to smmintrin.h. + * config/i386/cpuid.h (bit_SSE5): Remove SSE5 bit. + * config/i386/x86intrin.h: Remove SSE5. + * config/i386/mmintrin-common.h: Delete file. + * doc/extend.texi (x86 intrinsics): Remove SSE5 flags and builtins. + +2009-09-29 Richard Guenther <rguenther@suse.de> + + * alias.c (ao_ref_from_mem): Properly deal with off decl accesses + resulting from stack temporaries on STRICT_ALIGNMENT targets. + +2009-09-29 Nick Clifton <nickc@redhat.com> + + * function.c (current_function_name): If there is no current + function just return "<none>". + +2009-09-28 Sriraman Tallam <tmsriram@google.com> + + * tree-pass.h (register_pass_info): New structure. + (pass_positioning_ops): Move enum from gcc-plugin.h. + (register_pass): New function. + * gcc-plugin.h (plugin_pass): Delete structure. + (pass_positioning_ops): Delete enum. + * plugin.c (regsiter_pass): Delete function. + (position_pass): Delete function. + (added_pass_nodes): Delete variable. + (prev_added_pass_nodes): Delete variable. + (pass_list_node): Delete structure. + * passes.c (make_pass_instance): New function. + (next_pass_1): Change to call make_pass_instance. + (pass_list_node): Move structure from gcc-plugin.h. + (added_pass_nodes): Move variable from plugin.c. + (prev_added_pass_nodes): Move variable from plugin.c. + (position_pass): New function. + (register_pass): New function. + +2009-09-28 Easwaran Raman <eraman@google.com> + + * ifcvt.c (noce_try_abs): Recognize pattern and call + expand_one_cmpl_abs_nojump. + * optabs.c (expand_one_cmpl_abs_nojump): New function. + * optabs.h (expand_one_cmpl_abs_nojump): Declare. + +2009-09-28 Ian Lance Taylor <iant@google.com> + + PR middle-end/40500 + * c-opts.c (c_common_handle_option): Don't set + warn_jump_misses_init for -Wall. + * doc/invoke.texi (Warning Options): Update documentation. + +2009-09-28 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * Makefile.in ($(out_object_file)): Depend on + gt-$(basename $(notdir $(out_file))).h. + +2009-09-28 Richard Henderson <rth@redhat.com> + + * except.h (struct eh_region_d): Add use_cxa_end_cleanup. + * except.c (gen_eh_region): Set it. + (duplicate_eh_regions_1): Copy it. + * tree-eh.c (lower_resx): Use it to determine which function + to call to resume. + + * langhooks.h (struct lang_hooks): Add eh_use_cxa_end_cleanup. + * langhooks-def.h (LANG_HOOKS_EH_USE_CXA_END_CLEANUP): New. + * builtins.def (BUILT_IN_CXA_END_CLEANUP): New. + * tree.c (build_common_builtin_nodes): Remove parameter. Build + BUILT_IN_CXA_END_CLEANUP if necessary. + + * c-common.c (c_define_builtins): Update call to + build_common_builtin_nodes. + +2009-09-28 Andrew Pinski <andrew_pinski@playstation.sony.com> + + * spu.c (get_branch_target): Return NULL for ASM_OPERANDS patterns. + +2009-09-28 Michael Matz <matz@suse.de> + + * builtins.c (interclass_mathfn_icode): New helper. + (expand_builtin_interclass_mathfn): Use it here, and split folding + into ... + (fold_builtin_interclass_mathfn): ... this new folder. + (build_call_nofold_loc): New static helper. + (build_call_nofold): New wrapper macro for above. + (expand_builtin_int_roundingfn): Use it instead of build_call_expr. + (expand_builtin_pow): Ditto. + (expand_builtin_memset_args): Ditto. + (expand_builtin_printf): Ditto. + (expand_builtin_fprintf): Ditto. + (expand_builtin_sprintf): Ditto. + (expand_builtin_memory_chk): Ditto. + (expand_builtin_mempcpy_args): Ditto and don't call folders. + (expand_builtin_stpcpy): Ditto. + (expand_builtin_strcmp): Ditto. + (expand_builtin_strncmp): Ditto. + (expand_builtin_strcpy): Remove FNDECL and MODE arguments. + (expand_builtin_strcpy_args): Don't call folders. + (expand_builtin_memcmp): Ditto. + (expand_builtin_strncpy): Ditto, and use target. + (expand_builtin_memcpy): Ditto. + (expand_builtin_strstr, expand_builtin_strchr, expand_builtin_strrchr, + expand_builtin_strpbrk, expand_builtin_memmove, + expand_builtin_memmove_args, expand_builtin_bcopy, + expand_builtin_memchr, expand_builtin_strcat, expand_builtin_strncat, + expand_builtin_strspn, expand_builtin_strcspn, + expand_builtin_fputs): Remove these. + (expand_builtin): Don't call the above, change calls to other + expanders that changed prototype. + (fold_builtin_stpcpy): New folder split out from expand_builtin_stpcpy. + (fold_builtin_1 <ISFINITE, ISINF, ISNORMAL>): Call + fold_builtin_interclass_mathfn. + (fold_builtin_2 <STPCPY>): Call fold_builtin_stpcpy. + (fold_builtin_strcat): Add folding split from expand_builtin_strcat. + + * fold-const.c (fold_binary_loc <NE_EXPR>): Add !exp != 0 -> !exp. + * passes.c (init_optimization_passes): Move pass_fold_builtins + after last phiopt pass. + * tree-inline.c (fold_marked_statements): When folding builtins + iterate over all instruction potentially generated. + * tree-ssa-ccp.c (gimplify_and_update_call_from_tree): Declare + earlier. + (fold_gimple_call): Use it to always fold calls (into potentially + multiple instructions). + * tree-ssa-dom.c (optimize_stmt): Resolve __builtin_constant_p + calls into zero at this time. + * tree-ssa-propagate.c (substitute_and_fold): Ignore multiple + statements generated by builtin folding. + +2009-09-28 Nick Clifton <nickc@redhat.com> + + * config/m32r/m32r.c (m32r_is_insn): Return false for debugging insns. + +2009-09-28 Duncan Sands <baldrick@free.fr> + + * gcc-plugin.h (PLUGIN_REGISTER_GGC_CACHES): New event. + * plugin.c (plugin_event_name): Add PLUGIN_REGISTER_GGC_CACHES. + (register_callback): Dispatch it. + (invoke_plugin_callbacks): Incorporate in sanity check. + * ggc.h (ggc_register_cache_tab): Add declaration. + * ggc-common.c (ggc_register_root_tab): Simplify. + (const_ggc_cache_tab_t): New typedef. + (extra_cache_vec): New vector of dynamically added cache tables. + (ggc_register_cache_tab): New function. + (ggc_scan_cache_tab): New function. + (ggc_mark_roots): Simplify dynamic roots. Handle dynamic caches. + * doc/plugins.texi: Document PLUGIN_REGISTER_GGC_CACHES. + +2009-09-27 Richard Henderson <rth@redhat.com> + + * tree-ssa-ccp.c (optimize_stack_restore): Relax the conditions under + which we remove __builtin_stack_restore. + +2009-09-27 Bernd Schmidt <bernd.schmidt@analog.com> + + * loop-iv.c (iv_analyze_op): Use function_invariant_p, not CONSTANT_P, + to test for GRD_INVARIANT. + (simple_rhs_p): Anything that's function_invariant_p is fine. + +2009-09-27 Rafael Avila de Espindola <espindola@google.com> + + * gengtype.c (main): Use plunge_files instead of plugin_output. + +2009-09-27 Basile Starynkevitch <basile@starynkevitch.net> + Rafael Avila de Espindola <espindola@google.com> + + * gengtype.c (write_root, write_roots): Add a emit_pch argument. + Don't print pch related info if it is false. + (main): Don't print pch info in plugin mode. + +2009-09-27 Eric Botcazou <ebotcazou@adacore.com> + + * dwarf2out.c (enum dw_val_class): Replace dw_val_class_long_long + with dw_val_class_const_double. + (struct dw_val_struct): Replace val_long_long with val_double and + adjust for above change. + (output_loc_operands): Likewise. + (add_AT_long_long): Rename into... + (add_AT_double): ...this. + (print_die): Replace dw_val_class_long_long with + dw_val_class_const_double and adjust. + (attr_checksum): Likewise. + (same_dw_val_p): Likewise. + (size_of_die): Likewise. + (value_format): Likewise. + (output_die): Likewise. + (loc_descriptor) <CONST_DOUBLE>: Likewise. + (add_const_value_attribute) <CONST_DOUBLE>: Call add_AT_double + instead of add_AT_long_long. + (add_bound_info) <INTEGER_CST>: Generate the bound as an unsigned + value with the precision of its type. + +2009-09-27 Andreas Schwab <schwab@linux-m68k.org> + + PR c/41476 + * c-typeck.c (build_conditional_expr): Use the readonly and + volatile flags of the operand types, not of the operands itself. + +2009-09-27 Peter O'Gorman <pogma@thewrittenword.com> + + * collect2.c (main): Look for -brtl before adding libraries. + +2009-09-27 Jonathan Gray <jsg@openbsd.org> + + * config.gcc: Update OpenBSD targets. + * config/openbsd-stdint.h: New file. + * config/openbsd-libpthread.h: New file. + * config/openbsd.h: Update and break out LIB_SPEC definition. + * config/alpha/openbsd.h: Overhaul to reflect ELF migration. + * config/i386/openbsdelf.h: Correct types. + * config/m68k/openbsd.h: Likewise. + * config/mips/openbsd.h: Likewise. + * config/vax/openbsd.h: Likewise. + +2009-09-27 Eric Botcazou <ebotcazou@adacore.com> + + * fold-const.c (maybe_lvalue_p): Return false for M(IN|AX)_EXPR. + (extract_muldiv_1) <MINUS_EXPR>: Swap operands if necessary. + * stor-layout.c (layout_type) <ARRAY_TYPE>: Do not take the maximum + of the length and zero. + +2009-09-27 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * Makefile.in (TOPLEV_H): Use $(INPUT_H) not input.h. + (FLAGS_H): Add options.h $(REAL_H). + (SEL_SCHED_IR_H): Add $(BITMAP_H) vecprim.h $(CFGLOOP_H). + (TREE_VECTORIZER_H): New. + (EBITMAP_H): Renamed from EBIMAP_H. + (c-decl.o, c-objc-common.o, c-pretty-print.o, attribs.o, c-omp.o) + (gtype-desc.o, ggc-common.o, ggc-page.o, ggc-zone.o, langhooks.o) + (tree.o, tree-ssa-structalias.o, tree-ssa-ter.o, tree-ssanames.o) + (tree-phinodes.o, tree-ssa-loop.o, tree-ssa-math-opts.o) + (gimple-low.o, omp-low.o, sese.o, graphite-blocking.o) + (graphite-clast-to-gimple.o, graphite-dependences.o) + (graphite-interchange.o, graphite-poly.o, graphite-scop-detection.o) + (graphite-sese-to-poly.o, tree-vect-loop.o, tree-vect-loop-manip.o) + (tree-vect-patterns.o, tree-vect-slp.o, tree-vect-stmts.o) + (tree-vect-data-refs.o, tree-vectorizer.o, gimple.o, tree-mudflap.o) + (targhooks.o, stmt.o, emit-rtl.o, ipa.o, matrix-reorg.o, ipa-inline.o) + (gcse.o, tree-ssa-ccp.o, df-byte-scan.o, vec.o, caller-save.o) + (ira-build.o, ira-costs.o, ira-color.o, ira-emit.o, ira.o) + (haifa-sched.o, sched-rgn.o, sel-sched.o, sel-sched-dump.o) + (sel-sched-ir.o, final.o, $(out_object_file)): Dependencies + updated and fixed as per above changes and per + check_makefile_deps.sh output. + + PR bootstrap/40928 + * configure.ac: Use $LIBS for '-ldl', not $LDFLAGS. + * configure: Regenerate. + +2009-09-26 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * doc/install.texi: Update minimum MPC version to 0.7. + +2009-09-26 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (Binaries): Remove reference to the binary + distribution CD-ROM from the FSF. + +2009-09-26 Michael Matz <matz@suse.de> + + PR lto/40758 + PR middle-end/41470 + * tree-ssa-coalesce.c (coalesce_ssa_name): Add only SSA names + that are mentioned in the body. + +2009-09-26 Michael Matz <matz@suse.de> + + PR tree-optimization/41454 + * tree-ssa-dom (stmts_to_rescan): Remove variable. + (tree_ssa_dominator_optimize): Don't allocate and free it. + (dom_opt_leave_block): Don't iterate over it. + (eliminate_redundant_computations): Don't return a value. + (cprop_operand, cprop_into_stmt): Ditto. + (optimize_stmt): Don't defer updating stmts. + +2009-09-25 Dodji Seketeli <dodji@redhat.com> + + * dwarf2out.c (dwarf_tag_name, gen_generic_params_dies, + generic_parameter_die, template_parameter_pack_die, + gen_formal_parameter_die, gen_subprogram_die): Adjust after + renaming DW_TAG_formal_parameter_pack and + DW_TAG_template_parameter_pack into DW_TAG_GNU_formal_parameter_pack + and DW_TAG_GNU_template_parameter_pack. + +2009-09-25 Anatoly Sokolov <aesok@post.ru> + + * config/v850/v850.h (FUNCTION_VALUE): Remove. + * config/v850/v850.c (v850_function_value): New function. + (TARGET_FUNCTION_VALUE): Define. + +2009-09-25 Jakub Jelinek <jakub@redhat.com> + + * tree-vect-stmts.c (vectorizable_call): Call + mark_symbols_for_renaming after vect_finish_stmt_generation. + + * dwarf2out.c (tls_mem_loc_descriptor): Pass 1 instead of 2 + to loc_descriptor_from_tree. + (add_location_or_const_value_attribute): Pass 0 instead of 2 + for decl_by_reference_p decls. + +2009-09-25 Richard Guenther <rguenther@suse.de> + + PR middle-end/41463 + * tree-dfa.c (get_ref_base_and_extent): Fix issue with trailing + arrays again. + +2009-09-25 Ben Elliston <bje@au.ibm.com> + + * doc/invoke.texi (RS/6000 and PowerPC Options): Add missing comma + after `power7'. + +2009-09-25 Alan Modra <amodra@bigpond.net.au> + + * config/rs6000/rs6000.md (load_toc_v4_PIC_3c): Correct POWER + form of instruction. + +2009-09-24 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + PR middle-end/41435 + * fold-const.c (const_binop): Handle complex int division. + * tree-complex.c (expand_complex_div_straight, + expand_complex_div_wide): Update comments. + +2009-09-24 DJ Delorie <dj@redhat.com> + + PR target/41456 + * config/m32c/m32c.h (REG_CLASS_CONTENTS): Add R13. + (reg_class): Likewise. + (REG_CLASS_NAMES): Likewise. + * config/m32c/m32c.c (m32c_reg_class_from_constraint): Likewise. + (m32c_override_options): Disable -fivopts for M32C. + +2009-09-24 Michael Meissner <meissner@linux.vnet.ibm.com> + + * config/rs6000/predicates.md (indexed_or_indirect_operand): + Delete VSX load/store with update support. + * config/rs6000/rs6000.c (rs6000_legitimate_address_p): Ditto. + * config/rs6000/vsx.md (vsx_mov<mode>): Ditto. + (vsx_movti): Ditto. + (VSX_U): Delete. + (VSbit): Ditto. + (VStype_load_update): Ditto. + (VStype_store_update): Ditto. + (vsx_load<VSX_U:mode>_update_<P:mptrsize>): Ditto. + (vsx_store<VSX_U:mode>_update_<P:mptrsize>): Ditto. + + * config/rs6000/rs6000.h (enum rs6000_builtins): Delete VSX + load/store with update builtins. + +2009-09-24 Kai Tietz <kai.tietz@onevision.com> + + * libgcc2.c (L_trampoline): Prototype for getpagesize + and mprotect in WINNT case. + +2009-09-24 Anatoly Sokolov <aesok@post.ru> + + * config/rs6000/rs6000.h (FUNCTION_VALUE): Remove macro. + * config/rs6000/rs6000-protos.h (rs6000_function_value): Remove. + * config/rs6000/rs6000.c (rs6000_function_value): Make static, add + 'outgoing' argument. + (TARGET_FUNCTION_VALUE): Define. + +2009-09-24 Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk> + + * config/darwin.h (DWARF2_DEBUGGING_INFO): Define as 1. + +2009-09-24 Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk> + + PR bootstrap/41405 + * common.opt: Initialize dwarf_strict to -1. + * toplev.c (process_options): Catch unset dwarf_strict + and set to 0 for all targets not overriding. + * config/darwin.c (darwin_override_options): Catch unset + dwarf_strict and override to 1. + +2009-09-24 Jeff Law <law@redhat.com> + + * tree-into-ssa.c (rewrite_into_ssa): Free interesting_blocks. + +2009-09-24 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/36143 + PR tree-optimization/38747 + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Only + create VIEW_CONVERT_EXPRs for TBAA compatible accesses. + +2009-09-24 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/41457 + * dwarf2out.c (add_const_value_attribute): For HIGH and CONST_FIXED, + return false instead of gcc_unreachable (). For CONST return the + value returned by recursive call instead of always returning true. + (tree_add_const_value_attribute): Return the value returned by + add_const_value_attribute instead of always returning true if rtl + is non-NULL. + +2009-09-23 Justin Seyster <jrseys@gmail.com> + + * Makefile.in (PLUGIN_HEADERS): Include real.h. + +2009-09-24 Jakub Jelinek <jakub@redhat.com> + + * cgraphunit.c (cgraph_lower_function): Revert last change. + * targhooks.c (default_static_chain): Use !DECL_STATIC_CHAIN + instead of DECL_NO_STATIC_CHAIN. + * tree-cfg.c (verify_gimple_call): Likewise. + * tree-nested.c (get_chain_decl, get_chain_field, + convert_tramp_reference_op, convert_gimple_call): Likewise. + (convert_all_function_calls): Likewise. Always set or clear + DECL_STATIC_CHAIN initially, for !n->outer clear it. + (lower_nested_functions): Remove DECL_NO_STATIC_CHAIN checking code. + * c-parser.c (c_parser_declaration_or_fndef): Set DECL_STATIC_CHAIN + if nested. + * print-tree.c (print_node): Handle DECL_STATIC_CHAIN instead of + DECL_NO_STATIC_CHAIN. + * config/i386/i386.c (ix86_static_chain): Use !DECL_STATIC_CHAIN + instead of DECL_NO_STATIC_CHAIN. + (ix86_function_regparm, find_drap_reg): Likewise. Don't test + decl_function_context. + * varasm.c (initializer_constant_valid_p): Likewise. + * tree.h (DECL_NO_STATIC_CHAIN): Renamed to ... + (DECL_STATIC_CHAIN): ... this. + * config/moxie/moxie.c (moxie_static_chain): Use !DECL_STATIC_CHAIN + instead of DECL_NO_STATIC_CHAIN. + +2009-09-23 Basile Starynkevitch <basile@starynkevitch.net> + Rafael Avila de Espindola <espindola@google.com> + + * gengtype.c (nb_plugin_files): Make it unsigned to match + num_gt_files. Adjust other variables to avoid warnings. + (main): Allocate an all zero lang_bitmap before each plugin file name + to match regular file names. + +2009-09-23 Richard Henderson <rth@redhat.com> + + * doc/tm.texi (STATIC_CHAIN, STATIC_CHAIN_INCOMING): Remove. + (TARGET_STATIC_CHAIN): Mention that this hook must be used for + static chain passed in memory. + * system.h (STATIC_CHAIN, STATIC_CHAIN_INCOMING): Poison. + * targhooks.c (default_static_chain): Don't handle STATIC_CHAIN, + STATIC_CHAIN_INCOMING. Issue a sorry if there's no + STATIC_CHAIN_REGNUM defined. + + * config/picochip/picochip-protos.h: s/class/klass/. + * config/picochip/picochip.c (TARGET_STATIC_CHAIN): New. + (picochip_static_chain): New. + * config/picochip/picochip.h (STATIC_CHAIN): Remove. + (STATIC_CHAIN_INCOMING): Remove. + + * config/xtensa/xtensa.c (TARGET_STATIC_CHAIN): New. + (xtensa_static_chain): New. + * config/xtensa/xtensa.h (STATIC_CHAIN): Remove. + (STATIC_CHAIN_INCOMING): Remove. + +2009-09-23 Anatoly Sokolov <aesok@post.ru> + + * config/pa/pa.h (FUNCTION_VALUE): Remove macro. + * config/pa/pa-protos.h (function_value): Remove. + * config/pa/pa.c (pa_function_value): Rename from function_value. + Make static, add 'outgoing' argument. + (TARGET_FUNCTION_VALUE): Define. + +2009-09-23 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.c (avr_regs_to_save): Use current_function_is_leaf + instead of cfun->machine->is_leaf. + * config/avr/avr.h (machine_function): Remove is_leaf field. + +2009-09-23 Jakub Jelinek <jakub@redhat.com> + + PR debug/41439 + * dwarf2out.c (address_of_int_loc_descriptor): Don't emit + DW_OP_piece after DW_OP_stack_value, adjust size calculations + for it, when DW_OP_stack_value and DW_OP_implicit_value has + the same size, prefer DW_OP_stack_value. + (loc_descriptor, loc_list_for_address_of_addr_expr_of_indirect_ref, + loc_list_from_tree): Don't emit DW_OP_piece after DW_OP_stack_value. + +2009-09-23 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41353 + * var-tracking.c (add_with_sets): Sort MO_VAL_LOC last among uses. + +2009-09-23 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41248 + * cfgexpand.c (convert_debug_memory_address): New. + (expand_debug_expr): Convert base address and offset to the same + mode. Use it to convert addresses to other modes. Accept + ptr_mode addresses. + +2009-09-23 Dodji Seketeli <dodji@redhat.com> + + PR debug/41065 + * function.h (types_used_by_vars_hash): Declare new hash table. + (types_used_by_vars_eq, types_used_by_var_decl_insert): Declare + equality and hash function for the hash table. + (types_used_by_cur_var_decl): Declare a new global chained list. + (types_used_by_var_decl_insert): Declare new function. + * function.c (types_used_by_vars_hash): Define the hashtable ... + (types_used_by_vars_eq, types_used_by_vars_do_hash): ... as well as + its equality and hash functions. + (hash_types_used_by_vars_entry): New hash helper. + (types_used_by_cur_var_decl): Define the global chained list. + (used_types_insert): Update the list of types used by the global + variable being parsed. + (types_used_by_var_decl_insert): Define new function. + * c-common.h (record_types_used_by_current_var_decl): Declare ... + * c-common.c (record_types_used_by_current_var_decl): ... new + function. + * c-decl.c (finish_decl): Record the types used by the global + variable declaration we've just parsed. + * dwarf2out.c (premark_used_types): Insert a new line between + comment and function. + (premark_used_types_helper): Fix comment. + (premark_types_used_by_global_vars_helper, + premark_types_used_by_global_vars): New functions. + (prune_unused_types): Do not prune types used by global variables. + +2009-09-23 Richard Guenther <rguenther@suse.de> + + * alias.c (ao_ref_from_mem): Correct for negative MEM_OFFSET + produced for bigendian targets with promoted subregs. + +2009-09-23 Richard Guenther <rguenther@suse.de> + + * value-prof.c (gimple_ic): Purge old EH edges only after building + the new ones. + +2009-09-23 Nick Clifton <nickc@redhat.com> + + * config/arc/arc.c (arc_trampoline_init): Fix typo. + +2009-09-23 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/41405 + * doc/invoke.texi: Document -gstrict-dwarf and -gno-strict-dwarf. + + PR bootstrap/41436 + * cgraphunit.c (cgraph_lower_function): Set DECL_NO_STATIC_CHAIN + on non-nested functions. + +2009-09-23 Jakub Jelinek <jakub@redhat.com> + Jan Hubicka <jh@suse.cz> + + * dwarf2out.c (loc_list_plus_const): Only define if + DWARF2_DEBUGGING_INFO. + (address_of_int_loc_descriptor): Likewise. + + PR debug/41411 + * dwarf2out.c (mem_loc_descriptor): Handle HIGH. + +2009-09-23 Uros Bizjak <ubizjak@gmail.com> + + PR c/39779 + * c-typeck.c (build_binary_op) <short_shift>: Check that integer + constant is more than zero. + +2009-09-23 Alan Modra <amodra@bigpond.net.au> + + PR target/40473 + * config/rs6000/rs6000.c (rs6000_output_function_prologue): Don't + call final to emit non-scheduled prologue, instead insert at entry. + +2009-09-22 Loren J. Rittle <ljrittle@acm.org> + Joseph S. Myers <joseph@codesourcery.com> + + * doc/install.texi (*-*-freebsd*): Add proper format codes. + +2009-09-22 Basile Starynkevitch <basile@starynkevitch.net> + Rafael Avila de Espindola <espindola@google.com> + + * gengtype.c (is_file_equal): New function. + (close_output_files): Use is_file_equal. Free of->buf. + +2009-09-22 Basile Starynkevitch <basile@starynkevitch.net> + Rafael Avila de Espindola <espindola@google.com> + + * gengtype.c (write_types, write_local): Add the output_header + argument. Update all callers. + +2009-09-22 Dodji Seketeli <dodji@redhat.com> + + * dwarf2out.c (template_parameter_pack_die, + gen_formal_parameter_pack_die ): New functions. + (make_ith_pack_parameter_name): Remove this function. + (dwarf_tag_name): Support printing DW_TAG_template_parameter_pack and + DW_TAG_formal_parameter_pack. + (gen_generic_params_dies): Represent each template parameter pack + by a DW_TAG_template_parameter_pack DIE. Argument pack elements are + represented by usual DW_TAG_template_*_parameter DIEs that are + children of the DW_TAG_template_parameter_pack element DIE. + (generic_parameter_die): This doesn't deal with parameter pack + names anymore. Don't generate DW_AT_name for some DIEs, e.g. children + of parameter pack DIEs. + (gen_formal_parameter_die): Add a flag to not emit DW_AT_name + in certain cases, e.g. for pack elements. + (gen_formal_types_die, gen_decl_die): Adjust usage of + gen_formal_parameter_die. + (gen_subprogram_die): Represent each function parameter pack by a + DW_TAG_formal_parameter_pack DIE. Arguments of of the pack are + represented by usual DW_TAG_formal_parameter DIEs that are children + of the DW_TAG_formal_parameter_pack DIE. Remove references to + ____builtin_va_alist decls as no part of the compiler uses those + anymore. + * langhooks.h (struct lang_hooks_for_decls): Add + function_parm_expanded_from_pack_p, get_generic_function_decl + and function_parameter_pack_p hooks. Fix comment for + get_innermost_generic_parms hook. + * langhooks-def.h (LANG_HOOKS_FUNCTION_PARAMETER_PACK_P, + LANG_HOOKS_FUNCTION_PARM_EXPANDED_FROM_PACK_P ): Declare new hook + macros and use them to initialize lang_hook. + +2009-09-22 Richard Henderson <rth@redhat.com> + + * system.h (TRAMPOLINE_TEMPLATE, INITIALIZE_TRAMPOLINE): Poison. + (TRAMPOLINE_ADJUST_ADDRESS): Poison. + * target-def.h (TARGET_ASM_TRAMPOLINE_TEMPLATE): Don't conditionalize + on TRAMPOLINE_TEMPLATE. + (TARGET_TRAMPOLINE_ADJUST_ADDRESS): Don't conditionalize on + TRAMPOLINE_ADJUST_ADDRESS. + * targhooks.c (default_asm_trampoline_template): Remove. + (default_trampoline_adjust_address): Remove. + (default_trampoline_init): Don't handle INITIALIZE_TRAMPOLINE. + * targhooks.h: Update decls. + +2009-09-22 Dave Korn <dave.korn.cygwin@gmail.com> + + * config/i386/cygming.h (TARGET_USE_JCR_SECTION): Enable. + * config/i386/cygwin.h (LIBGCJ_SONAME): Define. + * config/i386/mingw32.h (LIBGCJ_SONAME): Likewise. + +2009-09-22 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41295 + * reload1.c (reload): Reset debug insns with pseudos without + equivalences. + +2009-09-22 Janis Johnson <janis187@us.ibm.com> + + * config/i386/i386.c (ix86_scalar_mode_supported_p): Don't return + unconditional true for decimal float modes. + * config/rs6000/rs6000.c (rs6000_scalar_mode_supported_p): Ditto. + * config/s390/s390.c (s390_scalar_mode_supported_p): Ditto. + +2009-09-22 Loren J. Rittle <ljrittle@acm.org> + + * unwind-dw2-fde-glibc.c: Define and use USE_PT_GNU_EH_FRAME. + Enable a new case for __FreeBSD__ >= 7. + * crtstuff.c: Define USE_PT_GNU_EH_FRAME for __FreeBSD__ >= 7. + * config/t-freebsd: Define LIB2ADDEH and LIB2ADDEHDEP. + * config/freebsd-spec.h: Conditionally define LINK_EH_SPEC + and USE_LD_AS_NEEDED. + + * doc/install.texi (*-*-freebsd*): Update target information. + +2009-09-22 Richard Guenther <rguenther@suse.de> + + PR middle-end/41395 + * tree-dfa.c (get_ref_base_and_extent): Handle trailing + arrays really properly. + +2009-09-22 Richard Henderson <rth@redhat.com> + + PR target/41246 + * target.h (struct gcc_target): Add asm_out.trampoline_template, + calls.static_chain, calls.trampoline_init, + calls.trampoline_adjust_address. + * target-def.h (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_STATIC_CHAIN, TARGET_TRAMPOLINE_INIT): New. + (TARGET_TRAMPOLINE_ADJUST_ADDRESS): New. + * builtins.c (expand_builtin_setjmp_receiver): Use + targetm.calls.static_chain; only clobber registers. + (expand_builtin_init_trampoline): Use targetm.calls.trampoline_init; + set up memory attributes properly for the trampoline block. + (expand_builtin_adjust_trampoline): Use + targetm.calls.trampoline_adjust_address. + * calls.c (prepare_call_address): Add fndecl argument. Use + targetm.calls.static_chain. + * df-scan.c (df_need_static_chain_reg): Remove. + (df_get_entry_block_def_set): Use targetm.calls.static_chain; + consolodate static chain handling. + * doc/tm.texi: Document new hooks. + * emit-rtl.c (static_chain_rtx, static_chain_incoming_rtx): Remove. + (init_emit_regs): Don't initialize them. + * expr.h (prepare_call_address): Update decl. + * final.c (profile_function): Use targetm.calls.static_chain. + * function.c (expand_function_start): Likewise. + * rtl.h (static_chain_rtx, static_chain_incoming_rtx): Remove. + * stmt.c (expand_nl_goto_receiver): Use targetm.calls.static_chain; + only clobber registers. + * targhooks.c (default_static_chain): New. + (default_asm_trampoline_template, default_trampoline_init): New. + (default_trampoline_adjust_address): New. + * targhooks.h: Declare them. + * varasm.c (assemble_trampoline_template): Use + targetm.asm_out.trampoline_template. Make the memory block const + and set its size. + + * config/alpha/alpha.c (alpha_trampoline_init): Rename from + alpha_initialize_trampoline. Make static. Merge VMS parameter + differences into the TARGET_ABI_OPEN_VMS code block. + (TARGET_TRAMPOLINE_INIT): New. + * config/alpha/alpha.h (TRAMPOLINE_TEMPLATE): Remove. + (TRAMPOLINE_SECTION, INITIALIZE_TRAMPOLINE): Remove. + * config/alpha/vms.h (TRAMPOLINE_SIZE, TRAMPOLINE_ALIGNMENT): Remove. + (INITIALIZE_TRAMPOLINE): Remove. + + * config/arc/arc.h (TRAMPOLINE_ALIGNMENT): New. + (TRAMPOLINE_TEMPLATE): Merge with ... + (INITIALIZE_TRAMPOLINE): ... this and move ... + * config/arc/arc.c (arc_trampoline_init): ... here. + (TARGET_TRAMPOLINE_INIT): New. + + * config/arm/arm.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT, TARGET_TRAMPOLINE_ADJUST_ADDRESS): New. + (arm_asm_trampoline_template): New. + (arm_trampoline_init, arm_trampoline_adjust_address): New. + * config/arm/arm.h (TRAMPOLINE_TEMPLATE, ARM_TRAMPOLINE_TEMPLATE, + THUMB2_TRAMPOLINE_TEMPLATE, THUMB1_TRAMPOLINE_TEMPLATE): Move all + code to arm_asm_trampoline_template. + (TRAMPOLINE_ADJUST_ADDRESS): Move code to + arm_trampoline_adjust_address. + (INITIALIZE_TRAMPOLINE): Move code to arm_trampoline_init; + adjust for target hook parameters. + + * config/avr/avr.h (TRAMPOLINE_TEMPLATE, INITIALIZE_TRAMPOLINE): + Remove. + + * config/bfin/bfin-protos.h (initialize_trampoline): Remove. + * config/bfin/bfin.c (bfin_asm_trampoline_template): New. + (bfin_trampoline_init): Rename from initialize_trampoline; + make static; update for target hook parameters. + (TARGET_ASM_TRAMPOLINE_TEMPLATE, TARGET_TRAMPOLINE_INIT): New. + * config/bfin/bfin.h (TRAMPOLINE_TEMPLATE): Move code to + bfin_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Remove. + + * config/cris/cris.c (TARGET_ASM_TRAMPOLINE_TEMPLATE, + TARGET_TRAMPOLINE_INIT, cris_asm_trampoline_template, + cris_trampoline_init): New. + * config/cris/cris.h (TRAMPOLINE_TEMPLATE): Move code to + cris_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to cris_trampoline_init; + adjust for target hook parameters. + + * config/crx/crx.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/fr30/fr30.c (TARGET_ASM_TRAMPOLINE_TEMPLATE, + TARGET_TRAMPOLINE_INIT, fr30_asm_trampoline_template, + fr30_trampoline_init): New. + * config/fr30/fr30.h (TRAMPOLINE_TEMPLATE): Move code to + fr30_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to fr30_trampoline_init; + adjust for target hook parameters. + + * config/frv/frv.c (TARGET_TRAMPOLINE_INIT): New. + (frv_trampoline_init): Rename from frv_initialize_trampoline; + make static, adjust arguments for TARGET_TRAMPOLINE_INIT hook. + * config/frv/frv.h (INITIALIZE_TRAMPOLINE): Remove. + * config/frv/frv-protos.h (frv_initialize_trampoline): Remove. + + * config/h8300/h8300.c (h8300_trampoline_init): New. + (TARGET_TRAMPOLINE_INIT): New. + * config/h8300/h8300.h (INITIALIZE_TRAMPOLINE): Move code + to h8300_trampoline_init and adjust for hook parameters. + + * config/ia64/ia64-protos.h (ia64_initialize_trampoline): Remove. + * config/ia64/ia64.c (TARGET_TRAMPOLINE_INIT): New. + (ia64_trampoline_init): Rename from ia64_initialize_trampoline; + make static; adjust for hook parameters. + * config/ia64/ia64.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/iq2000/iq2000.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT): New. + (iq2000_asm_trampoline_template, iq2000_trampoline_init): New. + * config/iq2000/iq2000.h (TRAMPOLINE_TEMPLATE): Move code to + iq2000_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to iq2000_trampoline_init. + (TRAMPOLINE_CODE_SIZE): New. + (TRAMPOLINE_SIZE): Use it. + (TRAMPOLINE_ALIGNMENT): Follow Pmode. + + * config/m32c/m32c-protos.h (m32c_initialize_trampoline): Remove. + * config/m32c/m32c.c (TARGET_TRAMPOLINE_INIT): New. + (m32c_trampoline_init): Rename from m32c_initialize_trampoline; + adjust for hook parameters. + * config/m32c/m32c.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/m32r/m32r.c (TARGET_TRAMPOLINE_INIT): New. + (m32r_trampoline_init): New. + * config/m32r/m32r.h (INITIALIZE_TRAMPOLINE): Move code to + m32r_trampoline_init. + + * config/m68hc11/m68hc11.c (TARGET_TRAMPOLINE_INIT): New. + (m68hc11_trampoline_init): Rename from m68hc11_initialize_trampoline; + make static; update for hook parameters. + * config/m68hc11/m68hc11-protos.h: Update. + * config/m68hc11/m68hc11.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/mcore/mcore.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT): New. + (mcore_function_value): Fix typo. + (mcore_asm_trampoline_template, mcore_trampoline_init): New. + * config/mcore/mcore.h (TRAMPOLINE_TEMPLATE): Move code + to mcore_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to mcore_trampoline_init. + + * config/mep/mep.h (INITIALIZE_TRAMPOLINE): Remove. + * config/mep/mep.c (TARGET_TRAMPOLINE_INIT): New. + (mep_trampoline_init): Rename from mep_init_trampoline; make static; + update for hook parameters. + * config/mep/mep-protos.h (mep_init_trampoline): Remove. + + * config/mips/mips.c (TARGET_ASM_TRAMPOLINE_TEMPLATE, + mips_asm_trampoline_template, TARGET_TRAMPOLINE_INIT, + mips_trampoline_init): New. + * config/mips/mips.h (TRAMPOLINE_TEMPLATE): Move code to + mips_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to mips_trampoline_init; + update for hook parameters. + + * gcc/config/mmix/mmix.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT): New. + (mmix_trampoline_size): Remove. + (mmix_asm_trampoline_template): Rename from mmix_trampoline_template; + make static. Remove out-of-date tetra vs octa comment. + (mmix_trampoline_init): Rename from mmix_initialize_trampoline; + make static; update for hook parameters. + * config/mmix/mmix.h (TRAMPOLINE_TEMPLATE): Remove. + (INITIALIZE_TRAMPOLINE): Remove. + (TRAMPOLINE_SIZE): Use a constant instead of mmix_trampoline_size. + (TRAMPOLINE_ALIGNMENT): New. + * gcc/config/mmix/mmix-protos.h: Update. + + * config/mn10300/mn10300.c (TARGET_ASM_TRAMPOLINE_TEMPLATE, + mn10300_asm_trampoline_template, TARGET_TRAMPOLINE_INIT, + mn10300_trampoline_init): New. + * config/mn10300/mn10300.h (TRAMPOLINE_TEMPLATE): Move code to + mn10300_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to mn10300_trampoline_init. + + * config/moxie/moxie.c (moxie_static_chain, + moxie_asm_trampoline_template, moxie_trampoline_init, + TARGET_STATIC_CHAIN, TARGET_ASM_TRAMPOLINE_TEMPLATE, + TARGET_TRAMPOLINE_INIT): New. + * config/moxie/moxie.h (INITIALIZE_TRAMPOLINE): Move code to + moxie_trampoline_init. + (TRAMPOLINE_TEMPLATE): Move code to moxie_asm_trampoline_template. + (STATIC_CHAIN, STATIC_CHAIN_INCOMING): Remove. + + * gcc/config/pa/pa.c (TARGET_ASM_TRAMPOLINE_TEMPLATE, + pa_asm_trampoline_template, TARGET_TRAMPOLINE_INIT, + pa_trampoline_init, TARGET_TRAMPOLINE_ADJUST_ADDRESS, + pa_trampoline_adjust_address): New. + * config/pa/pa.h (TRAMPOLINE_TEMPLATE): Move code to + pa_asm_trampoline_template. + (TRAMPOLINE_ALIGNMENT): New. + (TRAMPOLINE_CODE_SIZE): Move to pa.c. + (INITIALIZE_TRAMPOLINE): Move code to pa_trampoline_init; + adjust for hook parameters. + (TRAMPOLINE_ADJUST_ADDRESS): Move code to pa_trampoline_adjust_address. + + * config/pdp11/pdp11.c (pdp11_trampoline_init): New. + (TARGET_TRAMPOLINE_INIT): New. + * config/pdp11/pdp11.h (TRAMPOLINE_TEMPLATE): Remove. + (INITIALIZE_TRAMPOLINE): Move code to pdp11_trampoline_init. + + * config/picochip/picochip.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/rs6000/rs6000-protos.h (rs6000_initialize_trampoline): Remove. + * config/rs6000/rs6000.c (TARGET_TRAMPOLINE_INIT): New. + (rs6000_trampoline_init): Rename from rs6000_initialize_trampoline; + make static; adjust parameters for the hook. + * config/rs6000/rs6000.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/s390/s390.c (s390_asm_trampoline_template): Rename from + s390_trampoline_template; make static. + (s390_trampoline_init): Rename from s390_initialize_trampoline; + make static; adjust for target hook. + (TARGET_ASM_TRAMPOLINE_TEMPLATE, TARGET_TRAMPOLINE_INIT): New. + * config/s390/s390-protos.h: Remove trampoline decls. + * config/s390/s390.h (INITIALIZE_TRAMPOLINE): Remove. + (TRAMPOLINE_TEMPLATE): Remove. + (TRAMPOLINE_ALIGNMENT): New. + + * config/score/score-protos.h (score_initialize_trampoline): Remove. + * config/score/score.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT): New. + (score_asm_trampoline_template): New. + (score_trampoline_init): Rename from score_initialize_trampoline; + make static; adjust for hook parameters. + * config/score/score.h (TRAMPOLINE_TEMPLATE): Move code to + score[37]_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Remove. + * config/score/score3.c (score3_asm_trampoline_template): New. + (score3_trampoline_init): Rename from score3_initialize_trampoline; + adjust for target hook. + * config/score/score7.c (score7_asm_trampoline_template): New. + (score7_trampoline_init): Rename from score7_initialize_trampoline; + adjust for target hook. + * config/score/score3.h, config/score/score7.h: Update. + + * config/sh/sh-protos.h (sh_initialize_trampoline): Remove. + * config/sh/sh.c (TARGET_TRAMPOLINE_INIT): New. + (TARGET_TRAMPOLINE_ADJUST_ADDRESS): New. + (sh_trampoline_init): Rename from sh_initialize_trampoline; + make static; adjust for target hook parameters. + (sh_trampoline_adjust_address): New. + * config/sh/sh.h (INITIALIZE_TRAMPOLINE): New. + (TRAMPOLINE_ADJUST_ADDRESS): Move code to sh_trampoline_adjust_address. + + * config/sparc/sparc.c (TARGET_TRAMPOLINE_INIT): New. + (sparc32_initialize_trampoline): Rename from + sparc_initialize_trampoline; make static; replace tramp parameter + with m_tramp and update memory accesses. + (sparc64_initialize_trampoline): Similarly. + (sparc_trampoline_init): New. + * config/sparc/sparc-protos.h: Remove trampoline decls. + * config/sparc/sparc.h (INITIALIZE_TRAMPOLINE): Remove. + * config/sparc/sparc.md (nonlocal_goto): Don't use static_chain_rtx. + + * config/spu/spu.c (TARGET_TRAMPOLINE_INIT): New. + (array_to_constant): Make ARR parameter const. + (spu_trampoline_init): Rename from spu_initialize_trampoline; + make static; update for hook parameters. + * config/spu/spu-protos.h: Update decls. + * config/spu/spu.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/stormy16/stormy16.c (xstormy16_trampoline_init): Rename + from xstormy16_initialize_trampoline; make static; update for + hook parameters. + (TARGET_TRAMPOLINE_INIT): New. + * config/stormy16/stormy16.h (INITIALIZE_TRAMPOLINE): Remove. + + * config/v850/v850.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT): New. + (v850_can_eliminate): Make static. + (v850_asm_trampoline_template, v850_trampoline_init): New. + * config/v850/v850.h (TRAMPOLINE_TEMPLATE): Move code to + v850_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to v850_trampoline_init + and adjust for target hook parameters. + + * config/vax/vax.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT): New. + (vax_asm_trampoline_template, vax_trampoline_init): New. + * config/vax/vax.h (TRAMPOLINE_TEMPLATE): Move code to + vax_asm_trampoline_template. + (INITIALIZE_TRAMPOLINE): Move code to vax_trampoline_init. + + * config/xtensa/xtensa.c (TARGET_ASM_TRAMPOLINE_TEMPLATE): New. + (TARGET_TRAMPOLINE_INIT): New. + (xtensa_asm_trampoline_template): Rename from + xtensa_trampoline_template; make static. + (xtensa_trampoline_init): Rename from xtensa_initialize_trampoline; + make static; update for hook parameters. + * config/xtensa/xtensa-protos.h: Remove trampoline decls. + * config/xtensa/xtensa.h (TRAMPOLINE_TEMPLATE): Remove. + (INITIALIZE_TRAMPOLINE): Remove. + + * config/i386/i386.c (ix86_function_regparm): Do not issue an + error for nested functions with regparm=3. + (ix86_compute_frame_layout): Adjust frame pointer offset for + ix86_static_chain_on_stack. + (ix86_expand_prologue): Handle ix86_static_chain_on_stack. + (ix86_emit_restore_reg_using_pop): Increment ix86_cfa_state->offset, + don't reset to UNITS_PER_WORD. + (ix86_emit_leave): Adjust ix86_cfa_state. + (ix86_expand_epilogue): Handle ix86_static_chain_on_stack. + (ix86_static_chain): New. + (ix86_trampoline_init): Rename from x86_initialize_trampoline; + make static; update for target hook parameters; use ix86_static_chain. + (TARGET_STATIC_CHAIN, TARGET_TRAMPOLINE_INIT): New. + * config/i386/i386.h (STATIC_CHAIN_REGNUM): Remove. + (INITIALIZE_TRAMPOLINE): Remove. + (TRAMPOLINE_SIZE): Use 24 for 64-bit. + (struct machine_function): Use BOOL_BITFIELD; rearrange bitfields + to the end. Add static_chain_on_stack. + (ix86_static_chain_on_stack): New. + + * config/m68k/m68k.c (TARGET_TRAMPOLINE_INIT): New. + (m68k_output_mi_thunk): Don't use static_chain_rtx. + (m68k_trampoline_init): New. + * config/m68k/m68k.h (INITIALIZE_TRAMPOLINE): Move code to + m68k_trampoline_init and adjust for hook parameters. + * config/m68k/netbsd-elf.h (TRAMPOLINE_TEMPLATE): Remove. + (TRAMPOLINE_SIZE, INITIALIZE_TRAMPOLINE): Remove. + +2009-09-22 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/rs6000.c (bdesc_2arg): Fix CODE_FOR_vector_gt* codes + for __builtin_altivec_vcmpgt{sb,uh,sh,uw}. + + * reload1.c (reload): Call wrap_constant when substituting + reg for equiv inside of DEBUG_INSNs. + + PR bootstrap/41405 + * dwarf2out.c (base_type_die, record_type_tag, gen_subprogram_die, + add_call_src_coords_attributes, add_high_low_attributes, + gen_compile_unit_die, gen_type_die_with_usage force_decl_die, + gen_decl_die, dwarf2out_imported_module_or_decl_1, dwarf2out_finish, + dwarf2out_imported_module_or_decl): Avoid using DWARF3 additions + when -gdwarf-2 -gstrict-dwarf. + (loc_list_from_tree): Likewise. Avoid using DWARF4 additions when + -gdwarf-[23] -gstrict-dwarf. + (address_of_int_loc_descriptor, loc_descriptor, + loc_list_for_address_of_addr_expr_of_indirect_ref): Avoid using + DWARF4 additions when -gdwarf-[23] -gstrict-dwarf. + * common.opt (gno-strict-dwarf, gstrict-dwarf): New options. + +2009-09-22 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41428 + * tree-ssa-ccp.c (ccp_fold_stmt): New function. + (ccp_finalize): Pass it to substitute_and_fold. + +2009-09-22 Richard Guenther <rguenther@suse.de> + + * tree-ssa-propagate.h (ssa_prop_fold_stmt_fn): Declare. + (substitute_and_fold): Adjust prototype. + * tree-vrp.c (vrp_evaluate_conditional): Make static. + (simplify_stmt_using_ranges): Likewise. + (fold_predicate_in): Move here from tree-ssa-propagate.c. + (vrp_fold_stmt): New function. + (vrp_finalize): Pass it to substitute_and_fold. + * tree-flow.h (vrp_evaluate_conditional): Remove. + (simplify_stmt_using_ranges): Likewise. + * tree-ssa-ccp.c (ccp_finalize): Adjust call to substitute_and_fold. + * tree-ssa-copy.c (fini_copy_prop): Likewise. + * tree-ssa-propagate.c (struct prop_stats_d): Rename num_pred_folded + member. + (fold_predicate_in): Move to tree-vrp.c. + (substitute_and_fold): Use the callback instead of calling into + tree-vrp.c functions directly. + +2009-09-22 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (address_of_int_loc_descriptor): Avoid signed/unsigned + comparison warning on rs6000. + + PR middle-end/41429 + * tree-cfg.c (remove_useless_stmts_tc): Call gsi_next (gsi) even for + GIMPLE_EH_MUST_NOT_THROW cleanup. + (verify_types_in_gimple_stmt): Handle GIMPLE_EH_MUST_NOT_THROW. + +2009-09-22 Jack Howarth <howarth@bromo.med.uc.edu> + + PR middle-end/41260 + * gcc/config.gcc: Use darwin9.h and darwin10.h on darwin10 and later. + * gcc/config/darwin10.h: Add file to pass -no_compact_unwind on + LIB_SPEC for darwin10 and later since it always uses the unwinder in + libSystem which is derived from the gcc 4.2.1 unwinder. + +2009-09-22 Dave Korn <dave.korn.cygwin@gmail.com> + + PR middle-end/41357 + * varasm.c (default_encode_section_info): Copy TLS model into + sym_ref flags regardless of backend support for TLS, for all + model types except TLS_MODEL_EMULATED. + +2009-09-22 Dave Korn <dave.korn.cygwin@gmail.com> + + PR bootstrap/41404 + * dwarf2out.c (mem_loc_descriptor): Punt on CONST_STRING until + we can handle it correctly. + +2009-09-21 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (os2): Remove section. + +2009-09-21 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/standards.texi (Objective-C): Adjust two URLs. + +2009-09-21 Giuseppe Scrivano <gscrivano@gnu.org> + + * tree-tailcall.c (process_assignment): Don't check if a + multiplication or an addition are already present. + (find_tail_calls): Combine multiple additions and multiplications. + (adjust_accumulator_values): Emit accumulators. + +2009-09-21 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/i386.c (ix86_expand_epilogue): Adjust offset for + xmm register restore. + +2009-09-21 Jan Hubicka <jh@suse.cz> + + * dwarf2out.c (decl_loc_table_eq): Allow decl_loc_table to be NULL. + (dwarf2out_abstract_function): NULLify decl_loc_table at begginig and + restore at the end. + +2009-09-21 Eric Botcazou <ebotcazou@adacore.com> + + * stor-layout.c (layout_type): Remove obsolete code. + +2009-09-20 H.J. Lu <hongjiu.lu@intel.com> + + PR middle-end/41395 + * opts.c (decode_options): Don't turn on flag_ipa_sra for opt2. + +2009-09-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + PR middle-end/30789 + * builtins.c (do_mpc_arg2): Accept DO_NONFINITE parameter. + (do_mpc_ckconv): Accept FORCE_CONVERT parameter. + (fold_builtin_2, do_mpc_arg1): Update accordingly. + * fold-const.c (const_binop): Likewise. + * real.h (do_mpc_arg2): Update prototype. + +2009-09-20 Jan Hubicka <jh@suse.cz> + + * dwarf2out.c (add_const_value_attribute): Return true if successful. + (add_location_or_const_value_attribute): Rewrite using + loc_list_from_tree. + (tree_add_const_value_attribute): Return true if successful. + (tree_add_const_value_attribute_for_decl): Likewise. + + * dwarf2out.c (address_of_int_loc_descriptor): Break out from ... + (loc_descriptor): ... here; + (loc_list_for_address_of_addr_expr_of_indirect_ref): New function. + (cst_pool_loc_descr): Break out from ...; do not reffer constant + pool items that was not marked for output. + (loc_list_from_tree): ... here; handle special cases of ADDR_EXPR; + (loc_list_for_address_of_addr_expr_of_indirect_ref): New function. + (loc_list_for_address_of_addr_expr_of_indirect_ref): New function. + handle ALIGN_INDIRECT_REF, MISALIGNED_INDIRECT_REF, REALPART_EXPR, + IMAGPART_EXPR; handle address of INTEGER_CST; improve handling of + CONSTRUCTOR; handle REAL_CST, STRING_CST, COMPLEX_CST; use + DW_OP_stack_value to get address of items that are not available + as addresses. + (dw_loc_list): Handle single element lists correctly. + +2009-09-20 Kai Tietz <kai.tietz@onevision.com> + Pascal Obry <obry@adacore.com> + + * unwind-dw2-fde.c (classify_object_over_fdes): + Cast the constant 1 to _Unwind_Ptr. + (add_fdes): Likewise. + (linear_search_fdes): Likewise. + +2009-09-20 Eric Botcazou <ebotcazou@adacore.com> + + * stor-layout.c (set_sizetype): Avoid useless type copy. + +2009-09-20 Richard Sandiford <rdsandiford@googlemail.com> + + * configure.ac (gcc_cv_ld_mips_personality_relaxation): New + feature check. + (HAVE_LD_PERSONALITY_RELAXATION): New macro definition. + * configure, config.in: Regenerate. + * dwarf2asm.c (eh_data_format_name): Handle DW_EH_PE_indirect | + DW_EH_PE_absptr. + * config/mips/mips.h (TARGET_WRITABLE_EH_FRAME): New macro. + (ASM_PREFERRED_EH_DATA_FORMAT): Define. Use MIPS_EH_INDIRECT + for global data if the output could be used in a shared library. + * config/mips/mips.c (mips_override_options): Set flag_dwarf2_cfi_asm + to 0 if TARGET_WRITABLE_EH_FRAME. + +2009-09-20 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/39886 + * combine.c (update_cfg_for_uncondjump): Set EDGE_FALLTHRU + just when insn is equal to BB_END (bb). + +2009-09-19 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.opt (mrelax-pic-calls): New option. + * config/mips/mips.c (mips_strip_unspec_address): Move it up in + the file. + (mips_unspec_call): Change "unspec_call" expander into this. + (mips_strip_unspec_call): New function. + (mips_got_load): Call mips_unspec_call instead of + gen_unspec_call<mode>. + (mips16_build_call_stub): Fix comment for fp_code. Adjust call to + MIPS_CALL. + (mips_cfg_in_reorg): New function. + (mips16_lay_out_constants): Use it to decide whether to call + CFG-aware insn splitting. + (r10k_insert_cache_barriers): Move CFG set-up code from here to + mips_reorg. Move DF set-up code from here ... + (mips_df_reorg): ... to here. Call r10k_insert_cache_barriers + from here. + (mips_reorg): Call mips_df_reorg instead of + r10k_insert_cache_barriers. Move CFG set-up code here from + r10k_insert_cache_barriers. + (mips_call_expr_from_insn): New function. + (mips_pic_call_symbol_from_set): Likewise. + (mips_find_pic_call_symbol): Likewise. + (mips_annotate_pic_call_expr): Likewise. + (mips_get_pic_call_symbol): Likewise. + (mips_annotate_pic_calls): Likewise. + (mips_override_options): Disable -mrelax-pic-calls unless PIC + calls are used. + (mips_set_mips16_mode): Disable -mrelax-pic-calls for MIPS16. + * config/mips/mips-protos.h (mips_get_pic_call_symbol): Declare it. + * config/mips/mips.h (MIPS_CALL): Use it to print the .reloc + directive. + * config/mips/mips.md (UNSPEC_CALL_ATTR): New unspec. + (unspec_call<mode>): Remove it. + (sibcall_internal, sibcall_value_internal, + sibcall_value_multiple_internal, call_internal, call_split, + call_value_internal, call_value_split, + call_value_multiple_internal, call_value_multiple_split): Pass + SIZE_OPNO to MIPS_CALL. + (call_internal_direct, call_direct_split, + call_value_internal_direct, call_value_direct_split): Pass -1 as + SIZE_OPNO to MIPS_CALL. + * configure.ac <mips*-*-*>: Add test for .reloc R_MIPS_JALR. + * configure: Regenerate. + * doc/invoke.texi (Option Summary): Add -mrelax-pic-calls + and -mno-relax-pic-calls. + (MIPS Options): Document -mrelax-pic-calls and -mno-relax-pic-calls. + +2009-09-19 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + PR bootstrap/35619 + * Makefile.in (stmp-fixinc): Ensure `include-fixed' is created + in the directory this rule is called from, rather than the + toplevel 'gcc' directory, to fix in-tree build. + +2009-09-19 Chris Demetriou <cgd@google.com> + + PR preprocessor/28435: + * c-opts.c (c_common_handle_option): For -MD and -MMD, indicate + to cpplib that the preprocessor output is needed. + +2009-09-19 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/rs6000.md (*save_gpregs_<mode>, *save_fpregs_<mode>, + *restore_gpregs_<mode>, *return_and_restore_gpregs_<mode>, + *return_and_restore_fpregs_<mode>, + *return_and_restore_fpregs_aix_<mode>): Remove 'z' operand modifier. + + PR bootstrap/41397 + * dwarf2out.c (mem_loc_descriptor) <case SUBREG>: Recurse + instead of assuming it has always a REG inside of it. + +2009-09-18 Gerald Pfeifer <gerald@pfeifer.com> + + * config/freebsd.h: Update comment on types. + (WINT_TYPE): Define. + +2009-09-18 Jason Merrill <jason@redhat.com> + + * c.opt: Add -fno-deduce-init-list. + +2009-09-18 Neil Vachharajani <nvachhar@google.com> + + * value-prof.c (interesting_stringop_to_profile_p): Added output + argument to indicate which parameter is the size parameter. + * value-prof.c (gimple_stringop_fixed_value): Use + INTERESTING_STRINGOP_TO_PROFILE_P to find size argument. + * value-prof.c (gimple_stringops_transform): Update call sites to + INTERESTING_STRINGOP_TO_PROFILE_P to reflect parameter change. + +2009-09-18 Uros Bizjak <ubizjak@gmail.com> + + PR target/38288 + From David Binderman <dcb314@hotmail.com>: + * gcc/config/i386/i386.c (ix86_function_regparm): Remove useless + local variable f. Remove stale comments. + (ix86_compute_frame_layout): Remove useless local variable total_size. + Remove #if 0'd code. + (legitimate_address_p): Remove useless local variables + reason_rtx and reason. + (ix86_split_copysign_const): Remove useless local variable op1. + (scale_counter): Remove useless local variable piece_size_mask. + +2009-09-18 Jakub Jelinek <jakub@redhat.com> + + * stmt.c (expand_asm_operands): Set REG_ATTRS on the temporary from + output decl. + +2009-09-17 Michael Haubenwallner <michael.haubenwallner@salomon.at> + + PR target/40913 + * config/pa/t-hpux-shlib: Set soname in libgcc_s.sl. + +2009-09-17 Jakub Jelinek <jakub@redhat.com> + + * c-decl.c (finish_struct): Adjust DECL_SOURCE_LOCATION of + TYPE_STUB_DECL. + +2009-09-17 Alexandre Oliva <aoliva@redhat.com> + + * dwarf2out.c (loc_descriptor): Emit DW_OP_stack_value and + DW_OP_implicit_value even without dwarf_version 4. + +2009-09-17 Jan Hubicka <jh@suse.cz> + + * dwarf2out.c: Include tree-pass.h and gimple.h. + (loc_list_plus_const): New function. + (loc_descriptor_from_tree_1): Rename to ... + (loc_descriptor_from_tree): ... remove original. + (loc_list_from_tree): New function. + (add_AT_location_description): Accept location list. + (tls_mem_loc_descriptor): Update call of loc_descriptor_from_tree. + (concatn_mem_loc_descriptor): Remove. + (mem_loc_descriptor): Handle CONCAT/CONCATN and VAR_LOCATION by + returning NULL. + (secname_for_decl): Move up. + (hidden_reference_p): New function; break out from ... + (loc_by_refernece): ... here; move up. + (dw_loc_list): New function. + (single_element_loc_list): New function. + (single_element_loc_list_p): New function. + (add_loc_descr_to_each): New function. + (add_loc_list): New function. + (loc_descr_from_tree): Make wraper of loc_list_from_tree. + (loc_list_from_tree): Reroganized from loc_descr_from_tree; + add diagnostics why expansion failed. + (add_location_or_const_value_attribute): Support location lists. + (add_bound_info): Likewise. + (descr_info_loc): Update call of loc_descriptor_from_tree. + (gen_variable_die): Work on location lists. + * final.c (pass_final): Add dump file. + * Makefile.in (dwarf2out.o): Add new dependencies. + +2009-09-17 Janis Johnson <janis187@us.ibm.com> + + PR c/41049 + * real.c decimal_from_integer, decimal_integer_string): New. + (real_from_integer): Use them as special case for decimal float. + * config/dfp-bit.c (_si_to_sd, _usi_to_sd): Use default rounding. + (_di_to_sd, _di_to_dd, _di_to_td, _udi_to_sd, _udi_to_dd, _udi_to_td): + Do not append zero after the decimal point in string to convert. + +2009-09-17 Alexander Monakov <amonakov@ispras.ru> + + * graphite-sese-to-poly.c (pdr_add_data_dimensions): Add bounds only + for ARRAY_REFs. Use array_ref_{low,up}_bound to determine bounds. + +2009-09-17 Martin Jambor <mjambor@suse.cz> + + * common.opt (fipa-sra): New switch. + * opts.c (decode_options): Turn flag_ipa_sra on for opt2. + * timevar.def (TV_IPA_SRA): New timevar. + * params.def (ipa-sra-ptr-growth-factor): New parameter. + * doc/invoke.texi: Document -fipa-sra and ipa-sra-ptr-growth-factor. + * tree-sra.c: Include cgraph.c. + (enum sra_mode): Added SRA_MODE_EARLY_IPA. + (struct access): Added fields stmt, grp_maybe_modified, grp_scalar_ptr + and grp_not_necessarilly_dereferenced. + (func_param_count): New variable. + (encountered_apply_args): New variable. + (bb_dereferences): New variable. + (final_bbs): New variable. + (no_accesses_representant): New variable. + (no_accesses_p): New function. + (dump_access): Dump the new fields. + (sra_initialize): Set encountered_apply_args to false. + (get_ssa_base_param): New function. + (mark_parm_dereference): New function. + (create_access): Caring for INIDRECT_REFs and different handling of + varialble length accesses in early IPA SRA. Store the stmt - a new + parameter - to the new access. + (build_access_from_expr_1): New parameter stmt, passed to + create_access. Handle INDIRECT_REFs. + (build_access_from_expr): Pass the current statement to + build_access_from_expr_1. + (disqualify_ops_if_throwing_stmt): Trigger only in intraprocedural + passes. + (build_accesses_from_assign): Pass the current statement to + build_access_from_expr_1. Do not create assign links in IPA-SRA. + (scan_function): Call handle_ssa_defs on phi nodes. Set bits in + final_bbs when necessary. Check for calls to __builtin_apply_args. + Fixup EH info if anythng was changed. + (is_unused_scalar_param): New function. + (ptr_parm_has_direct_uses): New function. + (find_param_candidates): New function. + (mark_maybe_modified): New function. + (analyze_modified_params): New function. + (propagate_dereference_distances): New function. + (dump_dereferences_table): New function. + (analyze_caller_dereference_legality): New function. + (unmodified_by_ref_scalar_representative): New function. + (splice_param_accesses): New function. + (decide_one_param_reduction): New function. + (enum ipa_splicing_result): New type. + (splice_all_param_accesses): New function. + (get_param_index): New function. + (turn_representatives_into_adjustments): New function. + (analyze_all_param_acesses): New function. + (get_replaced_param_substitute): New function. + (get_adjustment_for_base): New function. + (replace_removed_params_ssa_names): New function. + (sra_ipa_reset_debug_stmts): New function. + (sra_ipa_modify_expr): New function. + (sra_ipa_modify_assign): New function. + (convert_callers): New function. + (modify_function): New function. + (ipa_sra_preliminary_function_checks): New function. + (ipa_early_sra): New function. + (ipa_early_sra_gate): New function. + (pass_early_ipa_sra): New variable. + * Makefile.in (tree-sra.o): Add cgraph.h to dependencies. + +2009-09-17 Michael Matz <matz@suse.de> + + PR middle-end/41347 + * tree.c (build_type_attribute_qual_variant): Export. + * tree.h (build_type_attribute_qual_variant): Declare. + * tree-inline.c (remap_type_1): Use it to build variants with + the original qualifiers and attributes. + +2009-09-17 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * cfglayout.c (fixup_reorder_chain): Accept conditional jumps + without a fallthrough edge. + +2009-09-16 DJ Delorie <dj@redhat.com> + + * config/m32c/m32c.c (m32c_emit_epilogue): Check for R8C or M16C + chip and ignore the "fast_interrupt" attribute if so. + +2009-09-16 Richard Henderson <rth@redhat.com> + + PR middle-end/41360 + * cfgbuild.c (find_bb_boundaries): Really re-instate 2009-09-02 + barrier fix. + +2009-09-16 Richard Henderson <rth@redhat.com> + + PR target/41246 + * tree-cfg.c (verify_gimple_call): Validate that gimple_call_chain + is set only if DECL_NO_STATIC_CHAIN is unset. + * tree-nested.c (iter_nestinfo_start, iter_nestinfo_next): New. + (FOR_EACH_NEST_INFO): New. + (walk_all_functions): Use it. + (finalize_nesting_tree): Likewise. + (unnest_nesting_tree): Likewise. + (free_nesting_tree): Use iter_nestinfo_start, iter_nestinfo_next. + (get_chain_decl, get_chain_field): Reset DECL_NO_STATIC_CHAIN. + (convert_gimple_call): Early out if gimple_call_chain already set. + (convert_all_function_calls): Iterate until no new functions + require a static chain. + (finalize_nesting_tree_1): Assert DECL_NO_STATIC_CHAIN is unset + when building a trampoline. Use dump_function_to_file instead + of dump_function. + (lower_nested_functions): Open dump_file. Validate that decls + that have DECL_NO_STATIC_CHAIN from the front end don't have that + bit reset by this pass. + +2009-09-16 Michael Matz <matz@suse.de> + + PR fortran/41212 + * tree.h (struct tree_decl_common): Add decl_restricted_flag, + shorten decl_common_unused. + (DECL_RESTRICTED_P): New accessor. + * tree-ssa-alias.c (ptr_deref_may_alias_decl_p): Use it + to disambiguate marked decls and restrict pointers. + +2009-09-16 Richard Henderson <rth@redhat.com> + + PR middle-end/41360 + * cfgbuild.c (find_bb_boundaries): Re-instate 2009-09-02 barrier fix. + +2009-09-16 Jakub Jelinek <jakub@redhat.com> + + * integrate.c (set_block_abstract_flags): Call + set_decl_abstract_flags also on BLOCK_NONLOCALIZED_VARs. + +2009-09-16 Richard Guenther <rguenther@suse.de> + + PR middle-end/34011 + * tree-flow-inline.h (may_be_aliased): Compute readonly variables + as non-aliased. + +2009-09-16 DJ Delorie <dj@redhat.com> + Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (output_stack_adjust): Add new argument frame_p. + (sh_expand_prologue): Update calls to output_stack_adjust. + (sh_expand_epilogue): Likewise. + +2009-09-15 Adam Nemet <anemet@caviumnetworks.com> + + PR bootstrap/41349 + * reorg.c (redundant_insn): Don't count notes or DEBUG_INSNs when + trying to limit the extent of searches in the insn stream. + +2009-09-15 Nathan Froyd <froydnj@codesourcery.com> + Jakub Jelinek <jakub@redhat.com> + + PR target/41175 + PR target/40677 + * config/rs6000/rs6000.c (no_global_regs_above): Fix precedence + problem. + (SAVRES_NOINLINE_GPRS_SAVES_LR, SAVRES_NOINLINE_FPRS_SAVES_LR, + SAVRES_NOINLINE_FPRS_DOESNT_RESTORE_LR): New strategy bits. + (rs6000_savres_strategy): Always save FP registers inline if the + target doesn't support hardware double-precision. Set the above + bits in return value when needed. + (rs6000_savres_routine_sym): Fix computation for cache selector. + Mark the generated symbol as a function. Rename exitp argument to + lr. Move code for determining the name of the symbol... + (rs6000_savres_routine_name): ...here. New function. Add cases for + getting the names right on AIX and 64-bit Linux. + (savres_routine_name): New variable. + (rs6000_make_savres_rtx): Rename exitp argument to lr. Don't assert + lr isn't set when savep. Use r12 resp. r1 instead of r11 depending + on what the target routine uses as a base register. If savep && lr + describe saving of r0 into memory slot. + (rs6000_emit_prologue): Correct use of call_used_regs. Fix out of + line calls for AIX ABI. + (rs6000_output_function_prologue): Use rs6000_savres_routine_name to + determine FP save/restore functions. + (rs6000_emit_stack_reset): Handle savres if sp_offset != 0 and + frame_reg_rtx != sp_reg_rtx. Use gen_add3_insn instead of + gen_addsi3. + (rs6000_emit_epilogue): Adjust computation of restore_lr. + Duplicate restoration of LR and execute the appropriate one + depending on whether GPRs are being restored inline. Set r11 from + offsetted frame_reg_rtx instead of sp_reg_rtx; if frame_reg_rtx is + r11, adjust sp_offset. Use gen_add3_insn instead of gen_addsi3. + Fix out of line calls for AIX ABI. + * config/rs6000/rs6000.md (*return_and_restore_fpregs_aix_<mode>): + New insn. + * config/rs6000/spe.md (*save_gpregs_spe): Use explicit match for + register 11. + (*restore_gpregs_spe): Likewise. + (*return_and_restore_gpregs_spe): Likewise. + * config/rs6000/linux64.h (SAVE_FP_SUFFIX, RESTORE_FP_SUFFIX): + Define to empty string unconditionally. + * config/rs6000/sysv4.h (SAVE_FP_SUFFIX, RESTORE_FP_SUFFIX): + Define to empty string unconditionally. + (GP_SAVE_INLINE, FP_SAVE_INLINE): Handle TARGET_64BIT the same as + !TARGET_64BIT. + +2009-09-15 Jan Hubicka <jh@suse.cz> + + * doc/invoke.texi (inline-insns-auto): Drop from 60 to 50. + * params.def (inline-insns-auto): Likewise. + +2009-09-15 Martin Jambor <mjambor@suse.cz> + + * ipa-inline.c (estimate_function_body_sizes): Dump info about + individual statements only at TDF_DETAILS dump level. Format + source for 80 characters per line. + +2009-09-15 Christian Bruel <christian.bruel@st.com> + + * regrename.c (do_replace): Update REG_DEAD notes. + +2009-09-15 Revital Eres <eres@il.ibm.com> + + * doc/tm.texi (TARGET_SUPPORT_VECTOR_MISALIGNMENT): Document. + * targhooks.c (default_builtin_support_vector_misalignment): + New builtin function. + * targhooks.h (default_builtin_support_vector_misalignment): + Declare. + * target.h (builtin_support_vector_misalignment): + New field in struct gcc_target. + * tree-vect-data-refs.c (vect_supportable_dr_alignment): Call + new builtin function. + * target-def.h (TARGET_SUPPORT_VECTOR_MISALIGNMENT): + Define. + * config/rs6000/rs6000.c + (rs6000_builtin_support_vector_misalignment): New function. + (TARGET_SUPPORT_VECTOR_MISALIGNMENT): Define. + +2009-09-15 Jie Zhang <jie.zhang@analog.com> + + * config/bfin/bfin.c (length_for_loop): Use NONDEBUG_INSN_P + instead of INSN_P. + (bfin_optimize_loop): Likewise. + (bfin_gen_bundles): Likewise. + (workaround_speculation): Likewise. + (find_load): Return NULL_RTX for debug_insn. + +2009-09-15 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.md (smaxsf3): Disable for IEEE mode. + (sminsf3): Ditto. + +2009-09-14 DJ Delorie <dj@redhat.com> + + * config/mep/mep.h (JUMP_TABLES_IN_TEXT_SECTION): Define. + * config/mep/mep.c (mep_emit_cbranch): Don't use BEQZ/BNEI in + VLIW mode. + +2009-09-14 Richard Henderson <rth@redhat.com> + Jakub Jelinek <jakub@redhat.com> + + * builtins.c (expand_builtin_synchronize): Use gimple_build_asm_vec. + * cfgbuild.c (make_edges): Handle asm goto. + * cfglayout.c (fixup_reorder_chain): Likewise. + * cfgrtl.c (patch_jump_insn): Likewise. + * gimple-pretty-print.c (dump_gimple_asm): Likewise. + * gimple.c (gimple_build_asm_1): Add and use nlabels parameter. + (gimple_build_asm_vec): Add and use labels parameter. + (gimple_build_asm): Remove. + (walk_gimple_asm): Walk labels too. + * gimple.def (GIMPLE_ASM): Update docs. + * gimple.h: Update decls. + (struct gimple_statement_asm): Change nc to use unsigned char; + add nl member. + (gimple_asm_nlabels): New. + (gimple_asm_label_op, gimple_asm_set_label_op): New. + * gimplify.c (gimplify_asm_expr): Copy labels from ASM_EXPR + into gimple_build_asm_vec. + * jump.c (mark_jump_label_asm): New. + (mark_jump_label): Use it. + (redirect_jump_1): Handle asm goto. + (invert_jump_1): Soft fail if X is null. + * recog.c (extract_asm_operands): New. + (asm_noperands): Use it; handle asm labels. + (decode_asm_operands): Use extract_asm_operands. + (asm_operand_ok): Properly handle empty string. + * reg-stack.c (get_asm_operands_in_out): Rename from + get_asm_operand_n_inputs; use extract_asm_operands; return both + inputs and outputs by reference; update all callers. + * rtl.def (ASM_OPERANDS): Add label vector as operand 6. + * rtl.h (ASM_OPERANDS_LABEL_VEC): New. + (ASM_OPERANDS_LABEL_LENGTH, ASM_OPERANDS_LABEL): New. + (ASM_OPERANDS_SOURCE_LOCATION): Renumber. + (extract_asm_operands): Declare. + * stmt.c (expand_asm_operands): Add and use labels parameter. + (check_unique_operand_names): Likewise. + (resolve_asm_operand_names, resolve_operand_name_1): Likewise. + (expand_asm_stmt): Handle asm labels. + * tree-cfg.c (make_gimple_asm_edges): New. + (make_edges): Use it. + (cleanup_dead_labels): Handle asm labels. + (is_ctrl_altering_stmt): Likewise. + (gimple_redirect_edge_and_branch): Likewise. + * tree.def (ASM_EXPR): Add 5th operand. + * tree.h (ASM_LABELS): New. + (resolve_asm_operand_names): Update decl. + + * c-parser.c (c_parser_asm_statement): Parse asm goto. + (c_parser_asm_goto_operands): New. + * c-tree.h (build_asm_expr): Update decl. + * c-typeck.c (build_asm_expr): Add and use labels parameter. + * doc/extend.texi: Document asm goto. + +2009-09-14 Richard Henderson <rth@redhat.com> + + * except.h: Update declarations. + (struct pointer_map_t): Forward declare. + (ERT_UNKNOWN, ERT_THROW, ERT_CATCH): Remove. + (struct eh_landing_pad_d, eh_landing_pad): New. + (struct eh_catch_d, eh_catch): New. + (struct eh_region_d): Remove next_region_sharing_label, aka, + label, tree_label, landing_pad, post_landing_pad, resume, + may_contain_throw. Rename region_number to index. Remove + u.eh_catch, u.eh_throw. Rename u.eh_try.eh_catch to first_catch. + Add u.must_not_throw, landing_pads, exc_ptr_reg, filter_reg. + (VEC(eh_landing_pad,gc)): New. + (struct eh_status): Remove last_region_number. Add lp_array, + throw_stmt_table, ttype_data, ehspec_data. + (ehr_next, FOR_ALL_EH_REGION_AT): New. + (FOR_ALL_EH_REGION_FN, FOR_ALL_EH_REGION): New. + * except.c (lang_protect_cleanup_actions): Return tree. + (struct ehl_map_entry): Remove. + (init_eh_for_function): Push zero entries for region and lp_array. + (gen_eh_region): Add to region_array immediately. + (gen_eh_region_catch): Operate on eh_catch objects. + (gen_eh_landing_pad): New. + (get_eh_region_may_contain_throw, get_eh_region_tree_label): Remove. + (get_eh_region_no_tree_label, set_eh_region_tree_label): Remove. + (get_eh_region_from_number, get_eh_region_from_number_fn): New. + (get_eh_landing_pad_from_number_fn): New. + (get_eh_landing_pad_from_number): New. + (get_eh_region_from_lp_number_fn): New. + (get_eh_region_from_lp_number): New. + (expand_resx_stmt, note_eh_region_may_contain_throw): Remove. + (get_exception_pointer, get_exception_filter): Remove. + (collect_eh_region_array, can_be_reached_by_runtime): Remove. + (current_function_has_exception_handlers): Simplify. + (bring_to_root, eh_region_replaceable_by_p): Remove. + (replace_region, hash_type_list, hash_eh_region): Remove. + (eh_regions_equal_p, merge_peers, remove_unreachable_regions): Remove. + (label_to_region_map, num_eh_regions): Remove. + (get_next_region_sharing_label, must_not_throw_labels): Remove. + (find_exception_handler_labels): Remove. + (duplicate_eh_regions_0, find_prev_try): Remove. + (struct duplicate_eh_regions_data): New. + (duplicate_eh_regions_1): Rewrite. + (duplicate_eh_regions): Return a pointer map instead of an + integer offset. + (copy_eh_region_1, copy_eh_region, push_reachable_handler): Remove. + (redirect_eh_edge_to_label): Remove. + (eh_region_outermost): Rewrite using eh_region pointers + instead of integers. + (add_ttypes_entry): Update for ttype_data move to eh_status. + (add_ehspec_entry): Rewrite with VEC instead of varray. + (assign_filter_values): Likewise. Export. + (build_post_landing_pads, connect_post_landing_pads): Remove. + (dw2_build_landing_pads): Rewrite to use lp_array. + (struct sjlj_lp_info, sjlj_find_directly_reachable_regions): Remove. + (sjlj_assign_call_site_values): Rewrite to use lp_array. + (sjlj_emit_dispatch_table, sjlj_build_landing_pads): Likewise. + (sjlj_mark_call_sites): Update for landing pad numbers. + (finish_eh_generation): Rewrite. + (gate_handle_eh): Do nothing for no eh tree. + (pass_rtl_eh): Move up near finish_eh_generation. + (remove_eh_landing_pad): New. + (remove_eh_handler): Export. + (remove_eh_region, remove_eh_handler_and_replace): Remove. + (for_each_eh_label): Rewrite to use lp_array. + (make_reg_eh_region_note): New. + (make_reg_eh_region_note_nothrow_nononlocal): New. + (insn_could_throw_p): New. + (copy_reg_eh_region_note_forward): New. + (copy_reg_eh_region_note_backward): New. + (check_handled, add_reachable_handler): Remove. + (reachable_next_level, foreach_reachable_handler): Remove. + (arh_to_landing_pad, arh_to_label, reachable_handlers): Remove. + (get_eh_region_and_lp_from_rtx): New. + (get_eh_region_from_rtx): New. + (can_throw_internal_1, can_throw_external_1): Remove. + (can_throw_internal): Use get_eh_region_from_rtx. + (can_throw_external): Use get_eh_region_and_lp_from_rtx. + (insn_nothrow_p, can_nonlocal_goto): New. + (expand_builtin_eh_common, expand_builtin_eh_pointer): New. + (expand_builtin_eh_filter, expand_builtin_eh_copy_values): New. + (add_action_record): Use VEC not varray. + (collect_one_action_chain): Update for eh_region changes. + (convert_to_eh_region_ranges): Make static. Use VEC not varray. + Use get_eh_region_and_lp_from_rtx. + (gate_convert_to_eh_region_ranges): New. + (pass_convert_to_eh_region_ranges): Use it. + (push_uleb128, push_sleb128): Use VEC not varray. + (output_one_function_exception_table): Likewise. + (dump_eh_tree): Update for eh_region changes. + (verify_eh_tree): Likewise. + (verify_eh_region, default_init_unwind_resume_libfunc): Remove. + * tree-eh.c: Include target.h. + (add_stmt_to_eh_lp_fn): Rename from add_stmt_to_eh_region_fn. + Don't disallow GIMPLE_RESX; adjust argument check. + (add_stmt_to_eh_lp): Rename from add_stmt_to_eh_region. + (record_stmt_eh_region): Update for landing pad numbers; + generate a landing pad if necessary. + (remove_stmt_from_eh_lp): Rename from remove_stmt_from_eh_region. + (remove_stmt_from_eh_lp_fn): Similarly. + (lookup_stmt_eh_lp_fn): Rename from lookup_stmt_eh_region_fn. + Update for lp numbers; don't special case missing throw_stmt_table. + (lookup_expr_eh_lp): Similarly. + (lookup_stmt_eh_lp): Rename from lookup_stmt_eh_region. + (eh_seq, eh_region_may_contain_throw): New. + (struct leh_state): Add ehp_region. + (struct leh_tf_state): Remove eh_label. + (emit_post_landing_pad): New. + (emit_resx, emit_eh_dispatch): New. + (note_eh_region_may_contain_throw): New. + (frob_into_branch_around): Take eh_region not eh label; + emit eh code into eh_seq. + (honor_protect_cleanup_actions): Early exit for no actions. Don't + handle EXC_PTR_EXPR, FILTER_EXPR. Use gimple_build_eh_must_not_throw, + lower_eh_must_not_throw. Emit code to eh_seq. + (lower_try_finally_nofallthru): Emit eh code to eh_seq. + (lower_try_finally_onedest): Likewise. + (lower_try_finally_copy): Likewise. + (lower_try_finally_switch): Likewise. + (lower_try_finally): Initialize ehp_region. + (lower_catch): Update for eh_catch objects. + (lower_eh_filter): Don't handle must_not_throw. + (lower_eh_must_not_throw): New. + (lower_cleanup): Don't set eh_label. + (lower_eh_constructs_2): Resolve eh builtins. + Handle GIMPLE_EH_MUST_NOT_THROW. + (lower_eh_constructs): Initialize eh_region_may_contain_throw. + Add eh_seq to the end of the function body. + (make_eh_dispatch_edges): New. + (make_eh_edge): Remove. + (make_eh_edges): Simplify for landing pads. + (redirect_eh_edge_1): New. + (redirect_eh_edge): Use it. + (redirect_eh_dispatch_edge): New. + (stmt_could_throw_p): Use a switch. Allow RESX. + (stmt_can_throw_external): Use lookup_stmt_eh_lp. + (stmt_can_throw_internal): Likewise. + (maybe_clean_eh_stmt_fn, maybe_clean_eh_stmt): New. + (maybe_clean_or_replace_eh_stmt): Update for landing pads. + (maybe_duplicate_eh_stmt_fn, maybe_duplicate_eh_stmt): New. + (gate_refactor_eh): New. + (pass_refactor_eh): Use it. + (lower_resx, execute_lower_resx, pass_lower_resx): New. + (lower_eh_dispatch, execute_lower_eh_dispatch): New. + (gate_lower_ehcontrol, pass_lower_eh_dispatch): New. + (remove_unreachable_handlers): Rename from + tree_remove_unreachable_handlers; rewrite for landing pads; + call remove_eh_handler directly. + (remove_unreachable_handlers_no_lp): New. + (unsplit_eh, unsplit_all_eh): New. + (tree_empty_eh_handler_p, all_phis_safe_to_merge): Remove. + (cleanup_empty_eh_merge_phis, cleanup_empty_eh_move_lp): New. + (cleanup_empty_eh_unsplit): New. + (cleanup_empty_eh): Rewrite. + (cleanup_all_empty_eh): New. + (execute_cleanup_eh): Rename from cleanup_eh. Remove unreachable + handlers first. Use unsplit_all_eh, cleanup_all_empty_eh. + (gate_cleanup_eh): New. + (pass_cleanup_eh): Use it. + (verify_eh_edges): Move later in file. Expect one EH edge. + (verify_eh_dispatch_edge): New. + + * Makefile.in (FUNCTION_H): Use vecprim.h, not varray.h. + (gtype-desc.o): Add TARGET_H. + (tree.o): Use EXCEPT_H, not except.h. + (cfgbuild.o): Add EXPR_H. + (GTFILES): Add vecprim.h. + * builtins.c (expand_builtin): Handle BUILT_IN_EH_POINTER, + BUILT_IN_EH_FILTER, BUILT_IN_EH_COPY_VALUES. + * builtins.def (BUILT_IN_UNWIND_RESUME, BUILT_IN_EH_POINTER, + BUILT_IN_EH_FILTER, BUILT_IN_EH_COPY_VALUES): New. + * calls.c (emit_call_1): Use make_reg_eh_region_note. + * cfgbuild.c (control_flow_insn_p): Use can_nonlocal_goto; tidy + calls to can_throw_internal. + (rtl_make_eh_edge): Use get_eh_landing_pad_from_rtx. + (make_edges): Don't handle RESX; use can_nonlocal_goto. + * cfgexpand.c (expand_gimple_stmt_1): Don't handle RESX. + (expand_gimple_stmt): Use make_reg_eh_region_note. + (expand_debug_expr): Don't handle EXC_PTR_EXPR and FILTER_EXPR. + (gimple_expand_cfg): Don't call convert_from_eh_region_ranges, + or find_exception_handler_labels. + * cfgrtl.c (rtl_verify_flow_info_1): Don't handle RESX. Assert + there is exacly one EH edge. Use can_nonlocal_goto and + can_throw_internal. + * cgraphunit.c (update_call_expr): Use maybe_clean_eh_stmt_fn. + (cgraph_materialize_all_clones): Use maybe_clean_or_replace_eh_stmt. + * combine.c (can_combine_p, try_combine): Use insn_nothrow_p. + * cse.c (count_reg_usage, insn_live_p): Use insn_could_throw_p. + * dce.c (deletable_insn_p_1): Don't test may_trap_p. + (deletable_insn_p): Use insn_nothrow_p; reorder nonjump insn test. + * dse.c (scan_insn): Use insn_could_throw_p. + * emit-rtl.c (try_split): Use copy_reg_eh_region_note_backward. + * expr.c (expand_expr_real): Use make_reg_eh_region_note. + (expand_expr_real_1): Don't handle RESX, EXC_PTR, or FILTER_EXPR. + * fold-const.c (tree_expr_nonnegative_warnv_p): Don't handle + EXC_PTR_EXPR or FILTER_EXPR. + (tree_expr_nonzero_warnv_p): Likewise. + * function.h: Include vecprim.h, not varray.h + (struct rtl_eh): Remove filter, exc_ptr, built_landing_pad members; + move ttype_data and ehspec_data members to struct eh_status; change + action_record_data member to a VEC. + * gcse.c (hash_scan_set): Use can_throw_internal. + * gengtype.c (open_base_files): Add target.h to gtype-desc.c. + * gimple-iterator.c (gsi_replace): Use maybe_clean_or_replace_eh_stmt. + * gimple-low.c (lower_stmt): Handle GIMPLE_EH_MUST_NOT_THROW. + (block_may_fallthru): Don't handle RESX_EXPR. + * gimple-pretty-print.c (dump_gimple_label): Dump EH_LANDING_PAD_NR. + (dump_gimple_eh_must_not_throw, dump_gimple_eh_dispatch): New. + (dump_gimple_stmt): Dump landing pad information with TDF_EH; + handle GIMPLE_EH_MUST_NOT_THROW, GIMPLE_EH_DISPATCH. + * gimple.c (gss_for_code): Handle GIMPLE_EH_MUST_NOT_THROW, + GIMPLE_EH_DISPATCH, GIMPLE_RESX. + (gimple_size): Likewise. + (gimple_build_eh_dispatch, gimple_build_eh_must_not_throw): New. + (gimple_build_resx): Use gimple_build_with_ops. + (DEFTREECODE): Don't handle EXC_PTR_EXPR, FILTER_EXPR. + (is_gimple_val): Likewise. + (is_gimple_stmt): Remove RESX_EXPR. + * gimple.def (GIMPLE_EH_MUST_NOT_THROW, GIMPLE_EH_DISPATCH): New. + (GIMPLE_RESX): Reorder with other EH constructs. + * gimple.h (struct gimple_statement_eh_mnt): New. + (struct gimple_statement_eh_ctrl): Rename from gimple_statement_resx. + (gimple_eh_filter_must_not_throw): Remove. + (gimple_eh_filter_set_must_not_throw): Remove. + (gimple_eh_must_not_throw_fndecl): New. + (gimple_eh_dispatch_region, gimple_eh_dispatch_set_region): New. + (is_gimple_resx): New. + * gimplify.c (gimplify_expr): Don't handle EXC_PTR_EXPR, RESX_EXPR. + Don't copy EH_FILTER_MUST_NOT_THROW. + * gsstruct.def (GSS_EH_MNT, GSS_EHCONTROL): New. + * ipa-inline.c (estimate_function_body_sizes): Don't try to + handle must_not_throw_labels specially. + * ipa-pure-const.c (check_call): Update debug statement for LP. + * ipa-type-escape.c (check_operand): Don't handle EXC_PTR or FILTER. + * ipa-utils.c (get_base_var): Likewise. + * libfunc.h (LTI_unwind_resume, unwind_resume_libfunc): Remove. + * lower-subreg.c (move_eh_region_note): Remove. + (resolve_simple_move): Use copy_reg_eh_region_note_forward. + * omp-low.c (new_omp_context): Update for eh_lp_nr. + (create_task_copyfn): Likewise. + (maybe_catch_exception): Use gimple_build_eh_filter. + * optabs.c (emit_libcall_block): Update test for no-nonlocal-goto + REG_EH_REGION. Use make_reg_eh_region_note_nothrow_nononlocal. + * passes.c (init_optimization_passes): Add pass_lower_eh_dispatch + and pass_lower_resx. + * print-tree.c (print_node): Dump EH_LANDING_PAD_NR. + * recog.c (peephole2_optimize): Use copy_reg_eh_region_note_backward, + can_throw_internal, can_nonlocal_goto. + * reload1.c (fixup_eh_region_note): Use insn_could_throw_p, + copy_reg_eh_region_note_forward. + (emit_input_reload_insns): Use copy_reg_eh_region_note_forward. + (emit_output_reload_insns): Likewise. + (copy_eh_notes): Remove. + * rtl.def (RESX): Remove. + * rtl.h: Update declarations. + * sese.c (graphite_copy_stmts_from_block): Use maybe_duplicate_eh_stmt. + * tree-cfg.c (make_edges): Handle GIMPLE_EH_DISPATCH. + (update_eh_label): Remove. + (cleanup_dead_labels_eh): New. + (cleanup_deal_labels): Use it instead of update_eh_label. + (gimple_merge_blocks): Update landing pad data structure when + removing a landing pad label. + (remove_useless_stmts_tc): Remove gimple_eh_filter_must_not_throw + test; handle GIMPLE_EH_MUST_NOT_THROW. + (is_ctrl_altering_stmt): Handle GIMPLE_EH_DISPATCH. + (verify_gimple_assign_single): Don't handle EXC_PTR or FILTER_EXPR. + (verify_types_in_gimple_stmt): Handle GIMPLE_EH_DISPATCH. + (verify_stmt): Likewise. Verify landing pads. + (gimple_redirect_edge_and_branch): Handle GIMPLE_EH_DISPATCH. + (gimple_duplicate_bb): Use maybe_duplicate_eh_stmt. + (struct move_stmt_d): Add eh_map. + (move_stmt_eh_region_nr, move_stmt_eh_region_tree_nr): New. + (move_stmt_r): Remap eh region numbers in builtin calls, + resx and eh_dispatch. + (move_block_to_fn): Remove eh_offset parameter. Use + maybe_duplicate_eh_stmt_fn. + (find_outermost_region_in_block): Operate on eh_region pointers + instead of region numbers. + (move_sese_region_to_fn): Expect eh_map instead of eh_offset from + duplicate_eh_regions. + * tree-cfgcleanup.c (tree_forwarder_block_p): Move entry block edge + test earlier. Disallow EH landing pads. + * tree-cfa.c (create_tree_common_ann): Don't set ann->rn. + * tree-flow.h: Update declarations. + (struct tree_ann_common_d): Replace rn with lp_nr. + * tree-inline.c (copy_tree_body_r): Don't handle RESX_EXPR. + (remap_eh_region_nr, remap_eh_region_tree_nr): New. + (remap_gimple_stmt): Remap eh region numbers in builtin calls, + resx and eh_dispatch. + (copy_bb): Use maybe_duplicate_eh_stmt_fn. + (copy_edges_for_bb): Use make_eh_dispatch_edges. + (copy_cfg_body): Expect eh_map instead of eh_region_offset + from duplicate_eh_regions. + (estimate_num_insns): Don't handle EXC_PTR_EXPR or FILTER_EXPR; + update RESX; handle EH_DISPATCH. + (expand_call_inline): Set eh_lp_nr, not eh_region. + (maybe_inline_call_in_expr): Likewise. + * tree-inline.h (struct copy_body_data): Replace eh_region with + eh_lp_nr, eh_region_offset with eh_map. + * tree-optimize.c (execute_fixup_cfg): Use maybe_clean_eh_stmt. + * tree-pass.h (pass_lower_eh_dispatch, pass_lower_resx): New. + * tree-pretty-print.c (dump_generic_node): Don't handle + EXC_PTR_EXPR, FILTER_EXPR, RESX_EXPR. + * tree-sra.c (scan_function): Use maybe_clean_eh_stmt. + * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Don't handle + EXC_PTR_EXPR, FILTER_EXPR. + * tree-ssa-operands.c (get_expr_operands): Likewise. + * tree-ssa-propagate.c (valid_gimple_rhs_p): Likewise. + * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Likewise. + (ao_ref_init_from_vn_reference): Likewise. + * tree-ssa-sink.c (statement_sink_location): Likewise. + * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Likewise. + (mark_virtual_phi_result_for_renaming): Export. Tidy. + * tree-ssa-pre.c (get_or_alloc_expr_for): Don't handle + EXC_PTR_EXPR, FILTER_EXPR. + (is_exception_related): Remove. + (compute_avail): Don't call it. + * tree-ssa-structalias.c: Remove VEC definitions for int and unsigned. + * tree.c (find_decls_types_in_eh_region): Update for eh_region changes. + (find_decls_types_in_node): Use FOR_ALL_EH_REGION_FN. + (build_common_builtin_nodes): Add enable_cxa_end_cleanup parameter. + Build EH builtins. + (build_resx): Remove. + * tree.def (EXC_PTR_EXPR, FILTER_EXPR, RESX_EXPR): Remove. + * tree.h: Update declarations. + (EH_FILTER_MUST_NOT_THROW): Remove. + (struct tree_label_decl): Add eh_landing_pad_nr. + (EH_LANDING_PAD_NR): New. + * value-prof.c (gimple_ic): Tidy variable names. Update for + landing pad numbers. + (gimple_stringop_fixed_value): Tidy variable names. Assert + that neither call stmt can throw. + * vecprim.h (uchar): New. + (VEC(uchar,heap), VEC(uchar,gc)): New. + + * c-common.c (c_define_builtins): Update call to + build_common_builtin_nodes. + * c-parser.c (c_parse_file): Don't call + default_init_unwind_resume_libfunc. + +2009-09-14 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips-protos.h (mips_cfun_has_cprestore_slot_p): Declare. + (mips_cprestore_address_p): Likewise. + (mips_save_gp_to_cprestore_slot): Likewise. + (mips_restore_gp): Rename to... + (mips_restore_gp_from_cprestore_slot): ...this. + (mips_must_initialize_gp_p): Declare. + (mips_emit_save_slot_move): Likewise. + (mips_output_load_label): Return nothing. + (mips_eh_uses): Declare. + * config/mips/mips.h (TARGET_SPLIT_CALLS): Require epilogue_completed. + (TARGET_CPRESTORE_DIRECTIVE): New macro. + (TARGET_ABSOLUTE_JUMPS): Likewise. + (EH_USES): Likewise. + (FIRST_PSEUDO_REGISTER): Update comment. + (MIPS_ABSOLUTE_JUMP): New macro, extracted from... + (MIPS_CALL): ...here. + (REGISTER_NAMES): Add $cprestore. + * config/mips/mips.c (machine_function): Remove has_gp_insn_p. + Add load_label_length, has_inflexible_gp_insn_p, + has_flexible_gp_insn_p, must_initialize_gp_p and + must_restore_gp_when_clobbered_p. + (mips_expand_call): Don't generate split instructions here. + (mips_split_call): Update the call to mips_restore_gp after + the above name change. + (mips16_cfun_returns_in_fpr_p): Move earlier in file. + (mips_find_gp_ref): New function. + (mips_insn_has_inflexible_gp_ref_p): Likewise. + (mips_cfun_has_inflexible_gp_ref_p): Likewise. + (mips_insn_has_flexible_gp_ref_p): Likewise. + (mips_cfun_has_flexible_gp_ref_p): Likewise. + (mips_function_has_gp_insn): Delete. + (mips_global_pointer): Drop the df_regs_ever_live_p check. + Use the new functions above. Only return INVALID_REGNUM + for TARGET_ABSOLUTE_JUMPS. + (mips_must_initialize_gp_p): New function. + (mips_get_cprestore_base_and_offset): New function, extracted from... + (mips_cprestore_slot): ...here. Take a bool parameter. + (mips_cfun_has_cprestore_slot_p): New function. + (mips_cprestore_address_p): Likewise. + (mips_save_gp_to_cprestore_slot): Likewise. + (mips_restore_gp): Rename to... + (mips_restore_gp_from_cprestore_slot): ...this. Assert + epilogue_completed. Update the call to mips_cprestore_slot. + Test cfun->machine->must_restore_gp_when_clobbered_p. + (mips_direct_save_slot_move_p): New function. + (mips_emit_save_slot_move): Likewise. + (mips_output_cplocal): Test mips_must_initialize_gp_p () instead + of cfun->machine->global_pointer. + (mips_output_function_prologue): Check mips_must_initialize_gp_p (). + (mips_save_reg): Use mips_emit_save_slot_move. + (mips_expand_prologue): Set must_initialize_gp_p. + Use mips_cfun_has_cprestore_slot_p. Use gen_potential_cprestore + for all cprestore saves. Emit a use_cprestore instruction after + setting up the cprestore slot. + (mips_restore_reg): Use mips_emit_save_slot_move. + (mips_process_load_label): New function. + (mips_load_label_length): Likewise. + (mips_output_load_label): Don't return asm: output it here instead. + Use mips_process_load_label. + (mips_adjust_insn_length): Adjust the length of branch instructions + that have length MAX_PIC_BRANCH_LENGTH. + (mips_output_conditional_branch): Update the call to + mips_output_load_label. Assume the branch target is OPERANDS[0] + rather than OPERANDS[1]. Use MIPS_ABSOLUTE_JUMP for absolute jumps. + (mips_output_order_conditional_branch): Swap the meaning of + OPERANDS[0] and OPERANDS[1]. + (mips_variable_issue): Don't count ghost instructions. + (mips_expand_ghost_gp_insns): New function. + (mips_reorg): Rerun mips_reorg_process_insns if it returns true. + (mips_output_mi_thunk): Set must_initialize_gp_p. + (mips_eh_uses): New function. + * config/mips/predicates.md (cprestore_save_slot_operand) + (cprestore_load_slot_operand): New predicates. + * config/mips/mips.md (UNSPEC_POTENTIAL_CPRESTORE): New unspec. + (UNSPEC_MOVE_GP): Likewise. + (UNSPEC_CPRESTORE, UNSPEC_RESTORE_GP, UNSPEC_EH_RETURN) + (UNSPEC_CONSTTABLE_INT, UNSPEC_CONSTTABLE_FLOAT): Bump to make room. + (CPRESTORE_SLOT_REGNUM): New register. + (MAX_PIC_BRANCH_LENGTH): New constant. + (jal_macro): Use MIPS_ABSOLUTE_JUMPS. + (length): Use MAX_PIC_BRANCH_LENGTH as a placeholder for PIC long + branches. Fix commentary. + (loadgp_newabi_<mode>): Change from unspec_volatile to unspec. + Only split if mips_must_initialize_gp_p; expand to nothing otherwise. + Change type to "ghost". + (loadgp_absolute_<mode>): Likewise. + (loadgp_rtp_<mode>): Likewise. + (copygp_mips16): Likewise. + (loadgp_blockage): Remove redundant mode attribute. + (potential_cprestore): New instruction. + (cprestore): Turn into an unspec set. + (use_cprestore): New instruction. + (*branch_fp): Swap operands 0 and 1. Remove redundant mode attribute. + (*branch_fp_inverted): Likewise. + (*branch_order<mode>): Likewise. + (*branch_order<mode>_inverted): Likewise. + (*branch_equality<mode>): Likewise. + (*branch_equality<mode>_inverted): Likewise. + (*branch_bit<bbv><mode>): Likewise. + (*branch_bit<bbv><mode>_inverted): Likewise. + (*branch_equality<mode>_mips16): Remove redundant mode. + (jump): Turn into a define_expand. + (*jump_absolute): New instruction. + (*jump_pic): Likewise. + (*jump_mips16): Rename previously-unnamed pattern. Remove + redundant mode attribute. + (restore_gp): Split on epilogue_completed rather than + reload_completed. Change type to "ghost". + (move_gp<mode>): New instruction. + * config/mips/mips-dsp.md (mips_bposge): Swap operands 0 and 1. + Remove redundant mode attribute. + * config/mips/mips-ps-3d.md (bc1any4t): Likewise. + (bc1any4f, bc1any2t, bc1any2f): Likewise. + (*branch_upper_lower, *branch_upper_lower_inverted): Likewise. + +2009-09-14 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR target/41210 + * config/rs6000/rs6000.c (rs6000_function_value): V2DF and V2DI + are returned in the same register (vs34 or v2) that Altivec vector + types are returned in. + (rs6000_libcall_value): Ditto. + + PR target/41331 + * config/rs6000/rs6000.c (rs6000_emit_move): Use gen_add3_insn + instead of explicit addsi3/adddi3 calls. + (rs6000_split_multireg_move): Ditto. + (rs6000_emit_allocate_stack): Ditto. + (rs6000_emit_prologue): Ditto. + (rs6000_output_mi_thunk): Ditto. + + * config/rs6000/rs6000.md (bswapdi*): Don't assume the pointer + size is 64 bits if we can use 64-bit registers. + +2009-09-14 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.c (bfin_longcall_p): Don't use short calls for weak + symbols. + + From Jie Zhang <jie.zhang@analog.com>: + * config/bfin/bfin.c (bfin_expand_prologue): Ask do_link to + save FP and RETS with saveall attribute. + (bfin_expand_epilogue): Ask do_unlink to restore FP and RETS + with saveall attribute. + + * config/bfin/bfin.c (bfin_expand_builtin, + case BFIN_BUILTIN_MULT_1X32X32): Force constants to registers for the + operands. + + From Jie Zhang <jie.zhang@analog.com>: + * config/bfin/bfin.c (bfin_expand_builtin): Initialize icodes + before use in two places. + * config/bfin/bfin.md (AREG): Define mode iterator. + (reload_in, reload_out): Use mode iterator AREG. + +2009-09-14 Richard Guenther <rguenther@suse.de> + + PR middle-end/41350 + * dwarf2out.c (dwarf2out_begin_prologue): Adjust non-CFI asm + EH personality path. + +2009-09-13 Richard Guenther <rguenther@suse.de> + Rafael Avila de Espindola <espindola@google.com> + + * langhooks-def.h (LANG_HOOKS_EH_RUNTIME_TYPE): Define. + (LANG_HOOKS_EH_PERSONALITY): Likewise. + (LANG_HOOKS_INITIALIZER): Adjust. + (lhd_pass_through_t): Declare. + * langhooks.h (struct lang_hooks): Add eh_runtime_type and + eh_personality. + * langhooks.c (lhd_pass_through_t): New function. + * dwarf2out.c (output_call_frame_info, dwarf2out_do_cfi_startproc, + dwarf2out_begin_prologue): Use personality from current_function_decl. + * expr.h (get_personality_function): Declare. + * expr.c (get_personality_function): New function. + (build_personality_function): Likewise. + * libfuncs.h (libfunc_index): Remove LTI_eh_personality. + (eh_personality_libfunc): Remove. + * optabs.c (build_libfunc_function): New function split out from ... + (init_one_libfunc): ... here. + * tree.h (DECL_FUNCTION_PERSONALITY): New. + (tree_function_decl): Add personality. + (lhd_gcc_personality): Declare. + (build_personality_function): Likewise. + * tree.c (gcc_eh_personality_decl): New. + (lhd_gcc_personality): New function. + * except.h (lang_eh_runtime_type): Remove. + (enum eh_personality_kind): New. + (build_personality_function): Declare. + (function_needs_eh_personality): Declare. + * except.c (lang_eh_runtime_type): Remove. + (function_needs_eh_personality): New function. + (add_type_for_runtime): Call lang_hooks.type_for_runtime instead. + (sjlj_emit_function_enter, output_function_exception_table): + Use personality from current_function_decl. + * tree-eh.c (lower_eh_constructs): Set DECL_FUNCTION_PERSONALITY. + * tree-inline.c (tree_can_inline_p): Do not inline across different + EH personalities. + (expand_call_inline): Likewise. Adjust the callers EH personality. + (tree_function_versioning): Copy DECL_FUNCTION_PERSONALITY. + * cgraph.c (cgraph_add_new_function): Set DECL_FUNCTION_PERSONALITY. + * Makefile.in (cgraph.o): Add $(EXCEPT_H) dependency. + (c-parser.o): Likewise + * c-tree.h (c_eh_initialized_p): Remove. + (c_maybe_initialize_eh): Likewise. + * c-decl.c (finish_decl): Don't call c_maybe_initialize_eh. + (finish_decl): Don't call c_maybe_initialize_eh. + (c_eh_initialized_p): Remove. + (c_maybe_initialize_eh): Likewise. + * c-parser.c (c_parser_omp_construct): Likewise. + (c_parse_file): Initialize exception handling. + +2009-09-13 Kai Tietz <kai.tietz@onevision.com> + + * config.gcc (tm_file): Remove i386/biarch32.h + for i?86-w64-mingw* case. + (i?86-*-mingw* andx86_64-*-mingw*): Add multilib + support. + * config.host: Set for x64 mingw the option + use_long_long_for_widest_fast_int to yes. + +2009-09-13 Eric Botcazou <ebotcazou@adacore.com> + + * tree.h (DECL_IGNORED_P): Document further effect for FUNCTION_DECL. + * dbxout.c (dbxout_function_end): Do not test DECL_IGNORED_P. + (dbxout_begin_function): Likewise. + * final.c (dwarf2_debug_info_emitted_p): New predicate. + (final_start_function): Do not emit debug info if DECL_IGNORED_P is + set on the function. + (final_end_function): Likewise. + (final_scan_insn): Likewise. + (rest_of_handle_final): Likewise. + * varasm.c (assemble_start_function): Likewise. + * config/rs6000/xcoff.h (ASM_DECLARE_FUNCTION_NAME): Likewise. + +2009-09-12 Jason Merrill <jason@redhat.com> + + * dbgcnt.c (dbg_cnt_process_single_pair): constify. + * opts.c (common_handle_option): constify. + +2009-09-12 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (avr): Remove obsolete reference site. + +2009-09-12 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (Binaries): Adjust AIX link. + +2009-09-12 Akim Demaille <demaille@gostai.com> + + * doc/invoke.texi (-fstrict-aliasing): Correct two examples. + Use an imperative sentence. + +2009-09-11 Richard Henderson <rth@redhat.com> + + * gsstruct.def (DEFGSSTRUCT): Remove printable-name argument; add + structure-name and has-tree-operands arguments; update all entries. + * gimple.def (DEFGSCODE): Replace 3rd argument with GSS_symbol; + update all entries. + * gimple.c (gimple_ops_offset_): Use HAS_TREE_OP argument. + (gsstruct_code_size): New. + (gss_for_code_): New. + (gss_for_code): Remove. + (gimple_size): Rewrite using gsstruct_code_size. + (gimple_statement_structure): Move to gimple.h. + * gimple.h (gimple_ops_offset_, gss_for_code_): Declare. + (gss_for_code, gimple_statement_structure): New. + (gimple_ops): Use new arrays; tidy. + +2009-09-11 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * config/pa/predicates.md (symbolic_operand): Require a CONST symbolic + operand to be a PLUS expression. + * config/pa/pa.c (pa_secondary_reload): Likewise. + +2009-09-11 Jakub Jelinek <jakub@redhat.com> + + * combine.c (propagate_for_debug_subst): Call wrap_constant on top. + + * print-rtl.c (print_rtx): Use JUMP_LABEL (in_rtx) instead of + XEXP (in_rtx, 8). + +2009-09-11 Bernd Schmidt <bernd.schmidt@analog.com> + + From Jie Zhang <jie.zhang@analog.com>: + * doc/extend.texi (node Function Attributes): Document l2 + function attribute. + (node Blackfin Variable Attributes): Document l2 variable attributes. + +2009-09-11 Loren J. Rittle <ljrittle@acm.org> + + * config.gcc (*-*-freebsd*): Enable default_use_cxa_atexit + to match the system compiler's configuration at inflection point. + Add comment to remark a remaining difference with system compiler. + + * configure.ac (*-*-freebsd*): Enable check for __stack_chk_fail. + * configure: Regenerate. + +2009-09-11 Bernd Schmidt <bernd.schmidt@analog.com> + + From Jie Zhang <jie.zhang@analog.com>: + * config/bfin/bfin.c (bfin_expand_call): Handle L2 functions. + (bfin_handle_l2_attribute): New. + (bfin_attribute_table): Add l2 attribute. + +2009-09-11 Michael Matz <matz@suse.de> + + PR middle-end/41275 + * tree-inline.c (remap_decls): Don't put DECL_EXTERNAL decls + on the local_decls list. + +2009-09-11 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41276 + PR debug/41307 + * cselib.c (cselib_expand_value_rtx_cb): Document callback + interface. + (cselib_expand_value_rtx_1): Use callback for SUBREGs. Adjust + for VALUEs, to implement the documented interface. + * var-tracking.c (vt_expand_loc_callback): Handle SUBREGs. + Adjust for VALUEs and anything else, to implement the + documented interface. + +2009-09-10 Nathan Froyd <froydnj@codesourcery.com> + + * config/rs6000/rs6000.h (DATA_ALIGNMENT): Check that we are dealing + with actual SPE/paired vector modes before using 64-bit alignment. + Check that TYPE is a REAL_TYPE for TARGET_E500_DOUBLE. + +2009-09-10 DJ Delorie <dj@redhat.com> + + * config/mep/mep.md (eh_epilogue): Defer until after epilogue is + emitted. + + * config/mep/mep.h (LEGITIMATE_CONSTANT_P): New. + * config/mep/mep.c (mep_legitimate_constant_p): New. + * config/mep/mep-protos.h: Prototype it. + +2009-09-10 Richard Henderson <rth@redhat.com> + + * print-rtl.c (print_rtx): Fix JUMP_LABEL index. + +2009-09-10 Jason Merrill <jason@redhat.com> + + * tree.c (chain_index): New fn. + * tree.h: Declare it. + +2009-09-10 Rainer Orth <ro@CeBiTec.Uni-Bielefeld.DE> + + * config/sol2-c.c (cmn_err_length_specs): Initialize + scalar_identity_flag. + +2009-09-10 Richard Henderson <rth@redhat.com> + + * tree.h (struct tree_decl_common): Move align member earlier; + move label_decl_uid member ... + (struct tree_label_decl): ... here. + (LABEL_DECL_UID): Update to match. + + * tree-cfg.c (dump_function_to_file): Dump eh tree with TDF_EH, + not TDF_DETAILS. + + * tree-cfg.c (gimple_redirect_edge_and_branch): Do + gimple_try_redirect_by_replacing_jump test after no-op and EH tests. + + * tree-cfg.c (split_edge_bb_loc): Don't disallow placement at + dest_prev if the edge is complex. + + * tree-cfg.c (is_ctrl_stmt): Use a switch. + + * tree-cfg.c (gimple_can_merge_blocks_p): Move label and + loop latch tests earlier. + + * gimple-iterator.c (gimple_find_edge_insert_loc): Insert + before GIMPLE_RETURN, not after its predecessor; insert + before GIMPLE_RESX. + + * gimple-iterator.c (gimple_find_edge_insert_loc): Use + gimple_seq_empty_p to test for no PHI nodes. + * tree-cfg.c (split_critical_edges): Likewise. + + * c-common.h (c_dialect_cxx, c_dialect_objc): Boolify. + +2009-09-10 Hariharan Sandanagobalane <hariharan@picochip.com> + + * final.c (shorten_branches) : Ignore DEBUG_INSN_P instructions + introduced by the VTA branch merge. + +2009-09-10 Uros Bizjak <ubizjak@gmail.com> + + * ira-conflicts.c: Use fputs or putc instead of fprintf + where appropriate. + * cfg.c: Ditto. + * toplev.c: Ditto. + * tree-switch-conversion.c: Ditto. + +2009-09-10 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.c : Ignore DEBUG_INSN_P instructions + introduced by the VTA branch merge. + +2009-09-10 Uros Bizjak <ubizjak@gmail.com> + + Revert: + 2009-09-09 Uros Bizjak <ubizjak@gmail.com> + + PR rtl-optimization/39779 + * expr.c (convert_modes): Return when mode == oldmode after + CONST_INTs are processed. + +2009-09-10 Nick Clifton <nickc@redhat.com> + + * config/mep/mep.c (mep_encode_section_info): Copy weakness + attribute and referring decl when creating renamed symbol. + +2009-09-10 Richard Guenther <rguenther@suse.de> + + PR middle-end/41257 + * cgraphunit.c (cgraph_emit_thunks): Emit thunks only for + reachable nodes. + (cgraph_finalize_compilation_unit): Compute reachability + before emitting thunks. Properly process aliases before + possibly removing unreachable nodes. + +2009-09-10 Richard Guenther <rguenther@suse.de> + + PR middle-end/41254 + * tree.c (struct free_lang_data_d): Add worklist member. + (find_decls_types_r): Push onto the worklist instead of recursing. + Handle TREE_BINFOs properly. + (find_decls_types): New function wrapped around find_decls_types_r + to process the worklist. + (find_decls_types_in_eh_region): Use it. + (find_decls_types_in_node): Likewise. + (find_decls_types_in_var): Likewise. + (free_lang_data_in_cgraph): Likewise. Free the worklist. + * tree.h (RECORD_OR_UNION_TYPE_P): New. + (AGGREGATE_TYPE_P): Adjust. + +2009-09-09 Jason Merrill <jason@redhat.com> + + * configure.ac: Check glibc version even if we have an in-tree + assembler. + +2009-09-09 Anthony Green <green@moxielogic.com> + + * config/moxie/moxie.md (*movsi, *movhi, *movqi): Use xor to load + the constant 0 when appropriate. + * config/moxie/constraints.md: Add constraint O. + + * config/moxie/moxie.c (moxie_setup_incoming_varargs): Adjust + to pass up to 6 32-bit argument values in registers. + (moxie_function_arg): Ditto. + (moxie_arg_partial_bytes): Ditto. + * config/moxie/moxie.h (FUNCTION_ARG_ADVANCE): Ditto. + (REG_PARM_STACK_SPACE): Ditto. + (FUNCTION_ARG_REGNO_P): Ditto. + + * config/moxie/moxie.c (moxie_expand_prologue): Use dec + instruction to allocate stack space. + +2009-09-09 Segher Boessenkool <segher@kernel.crashing.org> + + * config/rs6000/rs6000.md (bswapdi2_64bit): Fix + unnecessarily stringent constraints. Fix address + calculation in the splitters. + +2009-09-09 Uros Bizjak <ubizjak@gmail.com> + + PR rtl-optimization/39779 + * expr.c (convert_modes): Return when mode == oldmode after + CONST_INTs are processed. + +2009-09-09 Kai Tietz <kai.tietz@onevision.com> + + PR/41315 + * config/i386.c (ix86_can_use_return_insn_p): Check for padding0, too. + (ix86_expand_prologue): Take frame.padding0 into logic of + to_allocate checks. + (ix86_expand_epilogue): Likewise. + +2009-09-09 Jakub Jelinek <jakub@redhat.com> + + * config/t-slibgcc-elf-ver (SHLIB_MAKE_SOLINK, SHLIB_INSTALL_SOLINK): + New variables. + (SHLIB_LINK, SHLIB_INSTALL): Use them. + * config/t-slibgcc-libgcc: New file. + * config.gcc (powerpc*-*-linux*, powerpc*-*-gnu*): Use it. + +2009-09-09 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/41089 + * tree-sra.c (find_var_candidates): Do not consider va_lists in + early SRA. + +2009-09-09 Richard Henderson <rth@redhat.com> + + * gimple.h (CASE_GIMPLE_OMP): New. + (is_gimple_omp): Use it. + * tree-cfg.c (is_ctrl_altering_stmt): Likewise. + (verify_gimple_debug): Likewise. + +2009-09-09 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41101 + * tree-ssa-pre.c (maximal_set): Remove. + (compute_antic_aux): Treat the maximal set as implicitly all ones. + Defer all blocks we didn't visit at least one successor. + (add_to_exp_gen): Do not add to the maximal set. + (make_values_for_phi): Likewise. + (compute_avail): Likewise. + (init_pre): Do not allocate the maximal set. + (execute_pre): Do not dump it. + +2009-09-09 Martin Jambor <mjambor@suse.cz> + + * tree-cfg.c (verify_gimple_phi): Check that gimple_phi_result is + an SSA_NAME rather than a is_gimple_variable. + +2009-09-09 Richard Guenther <rguenther@suse.de> + + PR middle-end/41317 + * tree-ssa-ccp.c (maybe_fold_offset_to_component_ref): Remove + code dealing with plain pointer bases. + (maybe_fold_offset_to_reference): Likewise. + (maybe_fold_stmt_addition): Adjust. + +2009-09-09 Richard Guenther <rguenther@suse.de> + + * tree.c (free_lang_data_in_type): Do not free the type variant + chains. + (free_lang_data): Merge char_type_node with its properly signed + variant. + (pass_ipa_free): Collect after freeing language specific data. + +2009-09-09 Michael Matz <matz@suse.de> + + PR middle-end/41268 + * cfgexpand.c (expand_gimple_stmt_1): Use an int for storing + SUBREG_PROMOTED_UNSIGNED_P, instead of a bool. + * rtl.h (struct rtx, SUBREG_PROMOTED_UNSIGNED_P): Update comments + to reflect reality. + +2009-09-08 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (conversions[]): Add "ml" pattern. + +2009-09-04 Jason Merrill <jason@redhat.com> + + * tree.c (tree_find_value): Remove. + * tree.h: Remove prototype. + * varasm.c (assemble_external): Use value_member instead. + +2009-09-08 Alexandre Oliva <aoliva@redhat.com> + + * toplev.c (process_options): Choose default debugging type when + gtoggle enables debug info and type is unset. + +2009-09-08 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41276 + PR debug/41307 + * cselib.c (cselib_expand_value_rtx_1): Don't return copy of + invalid subreg. + +2009-09-08 Alexandre Oliva <aoliva@redhat.com> + + * configure: Rebuilt with modified libtool.m4. + +2009-09-08 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41229 + PR debug/41291 + PR debug/41300 + * tree-ssa.c (execute_update_addresses_taken): Update debug insns. + +2009-09-08 Alexandre Oliva <aoliva@redhat.com> + + * tree-ssa-loop-ivopts.c (get_phi_with_result): Remove. + (remove_statement): Likewise. + (rewrite_use_nonlinear_expr): Adjust. + (remove_unused_ivs): Collect SSA NAMEs to remove and call... + * tree-ssa.c (release_defs_bitset): ... this. New. + * tree-flow.h (release_defs_bitset): Declare. + +2009-09-08 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41232 + * tree-ssa-phiopt.c (minmax_replacement): Skip debug stmts + in the middle block. + +2009-09-08 Kai Tietz <kai.tietz@onevision.com> + + * tree-ssa-reassoc.c (find_operand_rank): Cast pointer + via intptr_t to long type. + (insert_operand_rank): Cast long type via intptr_t to + pointer type. + * genattrtab.c (RTL_HASH): Use intptr_t to cast from + pointer to scalar. + * c-pretty-print.c (pp_c_tree_decl_identifier): Cast + from pointer to unsigned via uintptr_t. + + * configure.ac (GCC_STDINT_TYPES): Initialize intptr_t, + uintptr_t, HAVE_INTTYPES_H, HAVE_STDINT_H, HAVE_UINTPTR_T, + and HAVE_INTPTR_T. + * configure: Regenerated. + * config.in: Regenerated + * system.h (stdint.h): Add include. + (inttypes.h): Likewise. + * Makefile.in (aclocal): Add config/stdint.m4. + * aclocal.m4: Regenerated. + +2009-09-08 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.c (np_check_regno, np_after_branch): New static + variables. + (note_np_check_stores): New function. + (harmless_null_pointer_p): New function. + (trapping_loads_p): New args NP_REG and AFTER_NP_BRANCH. Callers + changed. Take into account whether we're in the shadow of a condjump + that tested NP_REG for NULL. + Lose all code that tested for SEQUENCEs. + (workaround_speculation): Avoid inserting NOPs for loads that are + either always executed or a NULL pointer. + +2009-09-08 Jan Hubicka <jh@suse.cz> + + * doc/invoke.texi (early-inlining-insns): Reduce from 12 to 8. + * params.def (early-inlining-insns): Likewise. + +2009-09-08 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/41239 + * sched-int.h (struct deps): Add last_function_call_may_noreturn field. + * sched-rgn.c (deps_join): Join also last_function_call_may_noreturn + lists. + * sched-deps.c (sched_analyze_insn): Prevent moving trapping insns + across calls, as the calls might not always return normally. + (call_may_noreturn_p): New function. + (deps_analyze_insn): Update last_function_call_may_noreturn list. + (init_deps): Initialize it. + (remove_from_deps): Also remove calls from + last_function_call_may_noreturn list. + +2009-09-07 Richard Henderson <rth@redhat.com> + + * tree-ssa-sccvn.c (vn_reference_lookup_3): Don't assume there are + more VR->OPERANDS than LHS operands. Free LHS before returning. + +2009-09-07 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.md (UNSPEC_VOLATILE_STALL): New constant. + (attr "addrtype"): New member "spreg". + Use it if mem_spfp_address_operand is true for the address. + (attr "type"): New entry "stall". + (cpu_unit "load"): New. + (insn_reservations "load32", "loadp", "loadi"): Add reservation of + "load". + (insn_reservation "loadsp"): New. + (insn_reservation "load_stall1"): New. + (insn_reservation "load_stall3"): New. + (stall): New insn. + * config/bfin/predicates.md (const1_operand, const3_operand): New. + (mem_p_address_operand): Exclude stack and frame pointer based + addresses. + (mem_spfp_address_operand): New; match them here. + * config/bfin/bfin.c (add_sched_insns_for_speculation): New function. + (bfin_reorg): Call it if scheduling insns. + (bfin_gen_bundles): Remove dummy insns created by + add_sched_insns_for_speculation. + + From Jie Zhang <jie.zhang@analog.com>: + * config/bfin/bfin-protos.h (enum bfin_cpu_type, bfin_cpu_type, + bfin_si_revision, bfin_workarounds): Move these ... + * config/bfin/bfin.h: ... here. + + From Mike Frysinger <michael.frysinger@analog.com> + * config/bfin/bfin-protos.h (bfin_cpu_type): Add BFIN_CPU_BF542M, + BFIN_CPU_BF544M, BFIN_CPU_BF547M, BFIN_CPU_BF548M, and BFIN_CPU_BF549M. + * config/bfin/bfin.c (bfin_cpus[]): Add 0.3 for bf542m, bf544m, + bf547m, bf548m, and bf549m. + * config/bfin/bfin.h (TARGET_CPU_CPP_BUILTINS): Define __ADSPBF542M__ + for BFIN_CPU_BF542M, __ADSPBF544M__ for BFIN_CPU_BF544M, + __ADSPBF547M__ for BFIN_CPU_BF547M, __ADSPBF548M__ for + BFIN_CPU_BF548M, and __ADSPBF549M__ for BFIN_CPU_BF549M. + * config/bfin/t-bfin-elf (MULTILIB_MATCHES): Select bf532-none for + bf542m-none, bf544m-none, bf547m-none, bf548m-none, and bf549m-none. + * config/bfin/t-bfin-linux (MULTILIB_MATCHES): Likewise. + * config/bfin/t-bfin-uclinux (MULTILIB_MATCHES): Likewise. + * doc/invoke.texi (Blackfin Options): Document that -mcpu now accepts + bf542m, bf544m, bf547m, bf548m, and bf549m. + + From Jie Zhang <jie.zhang@analog.com>: + * config/bfin/predicates.md (p_register_operand): New predicate. + (dp_register_operand): New predicate. + * config/bfin/bfin-protos.h (WA_05000074): Define. + (ENABLE_WA_05000074): Define. + * config/bfin/bfin.c (bfin_cpus[]): Add WA_05000074 for all cpus. + (bfin_gen_bundles): Put dsp32shiftimm instruction in slot[0]. + * config/bfin/bfin.md (define_attr type): Add dsp32shiftimm. + (define_attr addrtype): Allow load/store register to be P register. + (define_attr storereg): New. + (define_cpu_unit anomaly_05000074): New. + (define_insn_reservation dsp32shiftimm): New. + (define_insn_reservation dsp32shiftimm_anomaly_05000074): New. + (define_insn_reservation loadp): Cannot use slot2. + (define_insn_reservation loadsp): Cannot use slot2. + (define_insn_reservation storep): Cannot use slot2. Does not + apply when working around 05000074. + (define_insn_reservation storep_anomaly_05000074): New. + (define_insn_reservation storei): Does not apply when working + around 05000074. + (define_insn_reservation storei_anomaly_05000074): New. + (define_attr length): Add dsp32shiftimm case. + (define_insn movsi_insn32, movsi_insv, ashlsi3_insn, ashrsi3, + ror_one, rol_one, lshrsi3, lshrpdi3, ashrpdi3, movhiv2hi_low, + movhiv2hi_high, composev2hi, packv2hi, movv2hi_hi, + ssashiftv2hi3, ssashifthi3, ssashiftsi3, lshiftv2hi3, lshifthi3): + Set type as dsp32shiftimm for dsp32shiftimm alternatives. + +2009-09-07 Martin Jambor <mjambor@suse.cz> + + PR middle-end/41282 + * tree-sra.c (create_artificial_child_access): Return NULL if + build_ref_for_offset fails. + (propagate_subacesses_accross_link): Allow build_ref_for_offset + and create_artificial_child_access to fail. + +2009-09-06 Dmitry Gorbachev <d.g.gorbachev@gmail.com> + + PR c++/41214 + * unwind-dw2.c (uw_init_context_1): Mark noinline. + * config/ia64/unwind-ia64.c (uw_init_context_1): Likewise. + * config/xtensa/unwind-dw2-xtensa.c (uw_init_context_1): Likewise. + +2009-09-07 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.c (bfin_optimize_loop): When creating a new basic + block, ensure it has an exit edge. Emit a barrier after a jump. + +2009-09-07 Nick Clifton <nickc@redhat.com> + + * gcc.c (this_is_linker_script): New variable. Like + this_is_library_file but for the %T constructor. + (end_going_arg): If this_is_linker_script is set then locate the + script and insert a --script switch before it + (do_spec_2): Initialise this_is_linker_script. + (do_spec_1): Likewise. Handle %T construct. + (eval_spec_function): Preserve this_is_linker_script. + * doc/invoke.texi: Document %T construct in spec files. + * config/m32c/m32c.h (LIB_SPEC): Use it. + +2009-09-07 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * rtl.h (PREFETCH_SCHEDULE_BARRIER_P): New macro. + * sched-deps.c (sched_analyze_2): Make prefetches a hard barrier + when volatile flag is set. + * doc/rtl.texi (PREFETCH_SCHEDULE_BARRIER_P): Add documentation pieces. + +2009-09-06 Eric Botcazou <ebotcazou@adacore.com> + + PR bootstrap/41241 + * combine-stack-adj.c (try_apply_stack_adjustment): Handle stores. + (combine_stack_adjustments_for_block): Allow insns between stack + adjustments and stores with corresponding pre-(dec|inc)rement or + pre-modify operation. + +2009-09-06 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/41241 + * combine-stack-adj.c (struct csa_memlist): Rename to... + (struct csa_reflist): ... this. Rename mem field to ref. + (free_csa_memlist): Rename to... + (free_csa_reflist): ... this. + (record_one_stack_memref): Rename to... + (record_one_stack_ref): ... this. Handle also REG_P. + (try_apply_stack_adjustment): Handle also REG_P. + (struct record_stack_memrefs_data): Rename to... + (struct record_stack_refs_data): ... this. Rename memlist field to + reflist. + (record_stack_memrefs): Rename to... + (record_stack_refs): ... this. For DEBUG_INSNs keep traversing + subexpressions instead of failing when a MEM contains SP references. + For SP itself in DEBUG_INSNs queue it also onto reflist chain. + (combine_stack_adjustments_for_block): Adjust for mem to ref renaming. + +2009-09-06 Richard Guenther <rguenther@suse.de> + + PR middle-end/41144 + * tree.c (build_array_type): Do not record types marked + with structural equality in the canonical type hashtable. + +2009-09-06 Richard Guenther <rguenther@suse.de> + + PR middle-end/41261 + * tree-ssa-alias.c (refs_may_alias_p_1): Bail out for function decls. + +2009-09-05 Richard Guenther <rguenther@suse.de> + + PR middle-end/41181 + * tree-ssa-ccp.c (maybe_fold_stmt_addition): Use the correct type. + +2009-09-05 Richard Guenther <rguenther@suse.de> + + PR debug/41273 + * tree-ssa-operands.c (get_tmr_operands): Pass through opf_no_vops. + +2009-09-05 Richard Guenther <rguenther@suse.de> + + PR middle-end/41271 + * tree-ssa.c (useless_type_conversion_p): Drop qualifiers + before comparing function argument types. + +2009-09-05 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> + + PR target/41024 + * config/i386/mingw-w64.h (ASM_SPEC): Pass -v instead of -V to + the assembler. + +2009-09-04 Uros Bizjak <ubizjak@gmail.com> + + Revert: + 2009-08-18 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_output_mi_thunk_osf): Allocate insn + locators before emit_insn is called. + +2009-09-04 Vladimir Makarov <vmakarov@redhat.com> + + PR bootstrap/41241 + * ira.c (update_equiv_reg): Revert my previous patch for the PR. + * reginfo.c (resize_reg_info): Call allocate_reg_info if necessary. + (reginfo_init): Don't call allocate_reg_info. + +2009-09-04 Uros Bizjak <ubizjak@gmail.com> + + PR target/41262 + * config/alpha/alpha.c (alpha_does_function_need_gp): Use + NONDEBUG_INSN_P instead of INSN_P. + +2009-09-04 Alexandre Oliva <aoliva@redhat.com> + + PR debug/41225 + * tree-vect-stmts.c (vect_stmt_relevant_p): Skip debug uses. + +2009-09-04 Alexandre Oliva <aoliva@redhat.com> + + PR target/41252 + * config/arm/vfp.md (*cmpdf_split_vfp): Fix src mode in the second + pattern of the split. + +2009-09-04 Alexandre Oliva <aoliva@redhat.com> + + * toplev.c (process_options): Move setter of flag_var_tracking + before other tests that depend on it. Move down setter of + flag_rename_registers. Don't enable var-tracking-assignments + by default if selective scheduling is enabled. Warn if both + are enabled. + +2009-09-04 Alexandre Oliva <aoliva@redhat.com> + + * var-tracking.c (dv_is_decl_p): Adjust NULL behavior to match + comment. Use switch statement to catch overlaps between rtx + and tree codes. Accept FUNCTION_DECLs in addition to those in... + (IS_DECL_CODE): ... here. Remove. + (check_value_is_not_decl): Remove. + (dv_from_decl, dv_from_value): Check after conversion. + +2009-09-04 Richard Guenther <rguenther@suse.de> + + PR middle-end/41257 + * (cgraph_finalize_compilation_unit): Move finalizing aliases + after emitting tunks. Move emitting thunks and ctors from ... + (cgraph_optimize): ... here. Remove redundant + cgraph_analyze_functions. + * varasm.c (find_decl_and_mark_needed): Remove no longer + necessary check. + (finish_aliases_1): Adjust check for thunk aliases. + +2009-09-04 Daniel Gutson <dgutson@codesourcery.com> + + * config/arm/arm.md (ctzsi2): Added braces + to avoid warning that broke booststrap. + +2009-09-04 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/41112 + * tree-sra.c (build_ref_for_offset_1): Signal that we cannot + handle variable-bounded arrays. + (expr_with_var_bounded_array_refs_p): New function. + (analyze_access_subtree): Call expr_with_var_bounded_array_refs_p. + +2009-09-04 Wolfgang Gellerich <gellerich@de.ibm.com> + + * config/s390/2097.md: Removed two incorrect bypasses. + (z10_fsimpdf): Fixed latency. + (z10_fhex): New insn_reservation. + (z10_floaddf): Fixed latency. + (z10_floadsf): Fixed latency. + (z10_ftrunctf): Fixed latency. + (z10_ftruncdf): Fixed latency. + * config/s390/s390.c (z10_cost): Fixed values. + (s390_adjust_priority): Added z10 path. + * config/s390/s390.md (type): Added fhex. + (*mov<mode>_64dfp): Updated type attribute. + (*mov<mode>_64): Updated type attribute. + (*mov<mode>_31): Updated type attribute. + (*mov<mode>"): Likewise. + * config/s390/2084.md (x_fsimpdf): Updated condition. + +2009-09-04 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/s390.md ("*fmadd<mode>", "*fmsub<mode>"): Enable mem + RTXs in the predicate for operand 1. + +2009-09-03 Daniel Gutson <dgutson@codesourcery.com> + + * config/arm/arm.md (UNSPEC_RBIT): New constant. + (rbitsi2): New insn. + (ctzsi2): New expand. + * config/arm/arm.h (CTZ_DEFINED_VALUE_AT_ZERO): New macro. + +2009-09-03 Martin Jambor <mjambor@suse.cz> + + * tree-sra.c (duplicate_expr_for_different_base): Removed. + (create_artificial_child_access): Use build_ref_for_offset instead + of duplicate_expr_for_different_base. + (propagate_subacesses_accross_link): Likewise. + +2009-09-03 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.c (USEFUL_INSN_P): Use NONDEBUG_INSN_P instead + of INSN_P. + (mips16e_collect_argument_saves): Skip debug instructions. + (mips_74k_agen_init): Use CALL_P || JUMP_P instead of !NONJUMP_INSN_P. + (mips16_lay_out_constants): Use USEFUL_INSN_P instead of INSN_P. + (r10k_insert_cache_barriers): Likewise. + (mips_reorg_process_insns): Likewise. + +2009-09-03 Vladimir Makarov <vmakarov@redhat.com> + + PR bootstrap/41241 + * ira.c (update_equiv_reg): Remove check on class likely spill. + +2009-09-03 Jakub Jelinek <jakub@redhat.com> + + PR debug/41236 + * dwarf2out.c (loc_descriptor): Don't use SUBREG_REG macro on + SIGN_EXTEND or ZERO_EXTEND. Don't assume there is a REG inside of + it or SUBREG. + + PR debug/41238 + * function.c (assign_parm_find_stack_rtl): Don't set mem attributes on + the stack slot if it is passed by invisible reference. + * var-tracking.c (vt_add_function_parameters): Handle arguments passed + by invisible reference. + +2009-09-03 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/linux.h (TARGET_SUPPORTS_SYNC_CALLS): Define to 1. + * config/bfin/uclinux.h (TARGET_SUPPORTS_SYNC_CALLS): Define to 1. + * config/bfin/bfin.h (TARGET_SUPPORTS_SYNC_CALLS): Provide default of + 0. + * config/bfin/sync.md: New file. + * config/bfin/bfin.md: Include it. + (UNSPEC_ATOMIC): New. + (UNSPEC_ONES): Provide a unique number. + + From Jie Zhang <jie.zhang@analog.com>: + * config/bfin/bfin.c (ret_regs): New. + (must_save_fp_p): Don't return true because of frame_pointer_needed. + (must_save_rets_p): New. + (n_regs_saved_by_prologue): Use must_save_rets_p instead of + current_function_is_leaf. + (do_link): Likewise. + (do_unlink): Likewise. + (expand_interrupt_handler_prologue): Use ret_regs array. + (expand_interrupt_handler_epilogue): Use ret_regs array and + pass return register to gen_return_internal. + (bfin_expand_epilogue): Pass return register to + gen_return_internal. + (bfin_expand_call): Explicitly clobber RETS. + * config/bfin/bfin.h (FUNCTION_RETURN_REGISTERS): Define. + * config/bfin/bfin.md (call_symbol_fdpic, call_value_symbol_fdpic, + call_insn_fdpic, call_value_insn_fdpic, call_symbol, + call_value_symbol, call_insn, call_value_insn): Explicitly clobber + RETS. + (return_internal): Take a reg rtx rather than the register number. + +2009-09-03 H.J. Lu <hongjiu.lu@intel.com> + + * tree-parloops.c (parallelize_loops): Cast to HOST_WIDE_INT + when comparing against estimated_loop_iterations_int return. + +2009-09-03 Richard Guenther <rguenther@suse.de> + + * dwarf2out.c (dwarf2out_do_cfi_asm): Remove check of + eh_personality_libfunc. + +2009-09-03 Razya Ladelsky <razya@il.ibm.com> + + * tree-parloops.c (separate_decls_in_region): Add space. + +2009-09-03 Razya Ladelsky <razya@il.ibm.com> + + * tree-parloops.c (separate_decls_in_region): Change the condition + checking if there are reductions in the loop. + +2009-09-03 Razya Ladelsky <razya@il.ibm.com> + + PR tree-optimization/38275 + * tree-parloops.c (parallelize_loops): Replace profitability condition + for expected number of iterations. + +2009-09-03 Alexandre Oliva <aoliva@redhat.com> + + * doc/invoke.texi (BUILD_CONFIG): Document --with-build-config. + (bootstrap-debug): Explain conditions in which it becomes default. + (bootstrap-debug-big): Rather than duplicate bootstrap-debug, + make it add to it. + +2009-09-03 Namhyung Kim <namhyung@gmail.com> + + * doc/invoke.texi (Optimize Options): Move + -finline-small-functions to the -O2 list. + +2009-09-03 Alexandre Oliva <aoliva@redhat.com> + + * toplev.c (process_options): Enable var-tracking-assignments + by default if var-tracking is enabled. + +2009-09-02 David Daney <ddaney@caviumnetworks.com> + + * cfgbuild.c (find_bb_boundaries): Split blocks containing a + barrier. + * emit-rtl.c (prev_nonnote_insn_bb): New function. + * rtl.h (prev_nonnote_insn_bb): Declare it. + +2009-09-03 Diego Novillo <dnovillo@google.com> + + * cgraph.c (cgraph_node_for_decl): New. + * cgraph.h (cgraph_node_for_decl): Declare. + * tree.c (host_integerp): Return 0 if T is NULL. + +2009-09-03 Diego Novillo <dnovillo@google.com> + + * tree.h (struct alias_pair): Move from varasm.c. + (alias_pairs): Likewise. + (TYPE_MAXVAL): Define. + (TYPE_MINVAL): Define. + (iterative_hash_host_wide_int): Declare. + (remove_unreachable_alias_pairs): Declare. + * tree-pass.h (pass_ipa_free_lang_data): Declare. + * diagnostic.c (default_diagnostic_starter): Make extern. + (default_diagnostic_finalizer): Make extern. + * diagnostic.h (default_diagnostic_starter): Declare. + (default_diagnostic_finalizer): Declare. + (default_tree_printer): Declare. + * toplev.c (default_tree_printer): Make extern. + +2009-09-03 Richard Guenther <rguenther@suse.de> + Diego Novillo <dnovillo@google.com> + + * cgraph.c (cgraph_add_new_function): Remove gimplification. + * cgraphunit.c (cgraph_expand_function): Do not emit + associated thunks from here. + (cgraph_emit_thunks): New. + (cgraph_optimize): Call it. + Return if any IPA pass finds an error. + * varasm.c (finish_aliases_1): Ignore errorneous aliases used + by thunks. + +2009-09-03 Simon Baldwin <simonb@google.com> + Rafael Espindola <espindola@google.com> + Richard Guenther <rguenther@suse.de> + Doug Kwan <dougkwan@google.com> + Diego Novillo <dnovillo@google.com> + + * tree.c: Include tree-pass.h, langhooks-def.h, + diagnostic.h, cgraph.h, timevar.h, except.h and debug.h. + (free_lang_data_in_type): New. + (need_assembler_name_p): New. + (free_lang_data_in_block): New. + (free_lang_data_in_decl): New. + (struct free_lang_data_d): New. + (add_tree_to_fld_list): New. + (find_decls_types_r): New. + (get_eh_types_for_runtime): New. + (find_decls_types_in_eh_region): New. + (find_decls_types_in_node): New. + (find_decls_types_in_var): New. + (free_lang_data_in_cgraph): New. + (free_lang_data): New. + (gate_free_lang_data): New. + (pass_ipa_free_lang_data): New. + +2009-09-03 Diego Novillo <dnovillo@google.com> + + * timevar.def (TV_IPA_FREE_LANG_DATA): Define. + * langhooks.h (struct lang_hooks): Add field free_lang_data. + (lang_hooks): Remove const qualifier. + * ipa.c (cgraph_remove_unreachable_nodes): Call + remove_unreachable_alias_pairs. + * except.c (add_type_for_runtime): Check if TYPE has + already been converted. + (lookup_type_for_runtime): Likewise. + (check_handled): Handle converted types. + * varasm.c (remove_unreachable_alias_pairs): New. + * gimple.c: Include demangle.h. + (gimple_decl_printable_name): New. + (gimple_fold_obj_type_ref): New. + * gimple.h (gimple_decl_printable_name): Declare. + (gimple_fold_obj_type_ref): Declare. + * passes.c (init_optimization_passes): Add pass + pass_ipa_free_lang_data. + * langhooks-def.h (LANG_HOOKS_FREE_LANG_DATA): Define. + (LANG_HOOKS_INITIALIZER): Add LANG_HOOKS_FREE_LANG_DATA. + +2009-09-03 Diego Novillo <dnovillo@google.com> + + * c-lang.c (lang_hooks): Remove const qualifier. + +2009-09-02 Loren James Rittle <ljrittle@acm.org> + + * doc/install.texi (*-*-freebsd*): Update target information. + +2009-09-02 Anatoly Sokolov <aesok@post.ru> + + * hard-reg-set.h (call_fixed_regs): Remove. + * reginfo.c (call_fixed_regs): Remove. + (init_reg_sets_1): Remove initialization of call_fixed_regs. + (globalize_reg): Don't use call_fixed_regs. + * caller-save.c (init_caller_save): Use call_fixed_reg_set instead of + call_fixed_regs. + +2009-09-01 Michael Matz <matz@suse.de> + + * expr.h (emit_storent_insn, expand_expr_real_1, + expand_expr_real_2): Declare. + * expr.c (emit_storent_insn, expand_expr_real_1, + expand_expr_real_2): Export. + (store_expr): Setting and evaluating dont_return_target is useless. + (expand_expr_real_1, <case GOTO_EXPR, RETURN_EXPR, SWITCH_EXPR, + LABEL_EXPR and ASM_EXPR>): Move to gcc_unreachable. + * except.c (expand_resx_expr): Rename to ... + (expand_resx_stmt): ... this. Rewrite to take gimple statement. + * except.h (expand_resx_stmt): Declare. + * stmt.c: Add include gimple.h + (expand_asm_expr): Rename to ... + (expand_asm_stmt): ... this. Rewrite to take gimple statement. + (expand_case): Rewrite to take gimple statement. + * tree.h (expand_asm_stmt): Declare. + (expand_case): Change prototype. + * Makefile.in (stmt.o): Depend on gimple.h. + * builtins.c (expand_builtin_synchronize): Build gimple asm + statement, not an ASM_EXPR. + * cfgexpand.c (gimple_cond_pred_to_tree, set_expr_location_r, + gimple_to_tree, release_stmt_tree): Remove. + (expand_gimple_cond): Don't call gimple_cond_pred_to_tree or + ggc_free, but hold comparison code and operands separately. + Call jumpif_1 and jumpifnot_1 instead of jumpif and jumpifnot. + (expand_call_stmt, expand_gimple_stmt_1, + expand_gimple_stmt): New helpers. + (expand_gimple_tailcall): Don't call gimple_to_tree, expand_expr_stmt, + release_stmt_tree. Call expand_gimple_stmt instead. + (expand_gimple_basic_block): Ditto. + + * calls.c (emit_call_1): Don't look at EH regions here, make + fntree parameter useless. + (expand_call): New local rettype for TREE_TYPE(exp), use it + throughout. Remove local p, use addr instead. + Don't look at EH regions here. + +2009-09-02 Vladimir Makarov <vmakarov@redhat.com> + + * doc/invoke.texi (-fsched-pressure): Document it. + (-fsched-reg-pressure-heuristic): Remove it. + + * reload.c (ira.h): Include. + (find_reloads): Add choosing reload on number of small spilled + classes. + + * haifa-sched.c (ira.h): Include. + (sched_pressure_p, sched_regno_cover_class, curr_reg_pressure, + saved_reg_pressure, curr_reg_live, saved_reg_live, + region_ref_regs): New variables. + (sched_init_region_reg_pressure_info, mark_regno_birth_or_death, + initiate_reg_pressure_info, setup_ref_regs, + initiate_bb_reg_pressure_info, save_reg_pressure, + restore_reg_pressure, dying_use_p, print_curr_reg_pressure): New + functions. + (setup_insn_reg_pressure_info): New function. + (rank_for_schedule): Add pressure checking and insn issue time. + Remove comparison of insn reg weights. + (ready_sort): Set insn reg pressure info. + (update_register_pressure, setup_insn_max_reg_pressure, + update_reg_and_insn_max_reg_pressure, + sched_setup_bb_reg_pressure_info): New functions. + (schedule_insn): Add code for printing and updating reg pressure info. + (find_set_reg_weight, find_insn_reg_weight): Remove. + (ok_for_early_queue_removal): Do nothing if pressure_only_p. + (debug_ready_list): Print reg pressure info. + (schedule_block): Ditto. Check insn issue time. + (sched_init): Set up sched_pressure_p. Allocate and set up some + reg pressure related info. + (sched_finish): Free some reg pressure related info. + (fix_tick_ready): Make insn always ready if pressure_p. + (init_h_i_d): Don't call find_insn_reg_weight. + (haifa_finish_h_i_d): Free insn reg pressure info. + + * ira-int.h (ira_hard_regno_cover_class, ira_reg_class_nregs, + ira_memory_move_cost, ira_class_hard_regs, + ira_class_hard_regs_num, ira_no_alloc_regs, + ira_available_class_regs, ira_reg_class_cover_size, + ira_reg_class_cover, ira_class_translate): Move to ira.h. + + * ira-lives.c (single_reg_class): Check mode to find how many + registers are necessary for operand. + (ira_implicitly_set_insn_hard_regs): New. + + * common.opt (fsched-pressure): New options. + (fsched-reg-pressure-heuristic): Remove. + + * ira.c (setup_eliminable_regset): Rename to + ira_setup_eliminable_regset. Make it external. + (expand_reg_info): Pass cover class to setup_reg_classes. + (ira): Call resize_reg_info instead of allocate_reg_info. + + * sched-deps.c: Include ira.h. + (implicit_reg_pending_clobbers, implicit_reg_pending_uses): New. + (create_insn_reg_use, create_insn_reg_set, setup_insn_reg_uses, + reg_pressure_info, insn_use_p, mark_insn_pseudo_birth, + mark_insn_hard_regno_birth, mark_insn_reg_birth, + mark_pseudo_death, mark_hard_regno_death, mark_reg_death, + mark_insn_reg_store, mark_insn_reg_clobber, + setup_insn_reg_pressure_info): New. + (sched_analyze_1): Update implicit_reg_pending_uses. + (sched_analyze_insn): Find implicit sets, uses, clobbers of regs. + Use them to create dependencies. Set insn reg uses and pressure + info. Process reg_pending_uses in one place. + (free_deps): Free implicit sets. + (remove_from_deps): Remove implicit sets if necessary. Check + implicit sets when clearing reg_last_in_use. + (init_deps_global): Clear implicit_reg_pending_clobbers and + implicit_reg_pending_uses. + + * ira.h (ira_hard_regno_cover_class, ira_reg_class_nregs, + ira_memory_move_cost, ira_class_hard_regs, + ira_class_hard_regs_num, ira_no_alloc_regs, + ira_available_class_regs, ira_reg_class_cover_size, + ira_reg_class_cover, ira_class_translate): Move from ira-int.h. + (ira_setup_eliminable_regset, ira_set_pseudo_classes, + ira_implicitly_set_insn_hard_regs): New prototypes. + + * ira-costs.c (pseudo_classes_defined_p, allocno_p, + cost_elements_num): New variables. + (allocno_costs, total_costs): Rename to costs and + total_allocno_costs. + (COSTS_OF_ALLOCNO): Rename to COSTS. + (allocno_pref): Rename to pref. + (allocno_pref_buffer): Rename to pref_buffer. + (common_classes): Rename to regno_cover_class. + (COST_INDEX): New. + (record_reg_classes): Set allocno attributes only if allocno_p. + (record_address_regs): Ditto. Use COST_INDEX instead of ALLOCNO_NUM. + (scan_one_insn): Use COST_INDEX and COSTS instead of ALLOCNO_NUM + and COSTS_OF_ALLOCNO. + (print_costs): Rename to print_allocno_costs. + (print_pseudo_costs): New. + (process_bb_node_for_costs): Split into 2 functions with new + function process_bb_for_costs. Pass BB to process_bb_for_costs. + (find_allocno_class_costs): Rename to find_costs_and_classes. Add + new parameter dump_file. Use cost_elements_num instead of + ira_allocnos_num. Make one iteration if preferred classes were + already calculated for scheduler. Make 2 versions of code + depending on allocno_p. + (setup_allocno_cover_class_and_costs): Check allocno_p. Use + regno_cover_class and COSTS instead of common_classes and + COSTS_OF_ALLOCNO. + (init_costs, finish_costs): New. + (ira_costs): Set up allocno_p and cost_elements_num. Call + init_costs and finish_costs. + (ira_set_pseudo_classes): New. + + * rtl.h (allocate_reg_info): Remove. + (resize_reg_info): Change return type. + (reg_cover_class): New. + (setup_reg_classes): Add new parameter. + + * sched-int.h (struct deps_reg): New member implicit_sets. + (sched_pressure_p, sched_regno_cover_class): New external definitions. + (INCREASE_BITS): New macro. + (struct reg_pressure_data, struct reg_use_data): New. + (struct _haifa_insn_data): Remove reg_weight. Add members + reg_pressure, reg_use_list, reg_set_list, and + reg_pressure_excess_cost_change. + (struct deps): New member implicit_sets. + (pressure_p): New variable. + (COVER_CLASS_BITS, INCREASE_BITS): New macros. + (struct reg_pressure_data, struct reg_use_data): New. + (INSN_REG_WEIGHT): Remove. + (INSN_REG_PRESSURE, INSN_MAX_REG_PRESSURE, INSN_REG_USE_LIST, + INSN_REG_SET_LIST, INSN_REG_PRESSURE_EXCESS_COST_CHANGE): New macros. + (sched_init_region_reg_pressure_info, + sched_setup_bb_reg_pressure_info): New prototypes. + + * reginfo.c (struct reg_pref): New member coverclass. + (reg_cover_class): New function. + (reginfo_init, pass_reginfo_init): Move after free_reg_info. + (reg_info_size): New variable. + (allocate_reg_info): Make static. Setup reg_info_size. + (resize_reg_info): Use reg_info_size. Return flag of resizing. + (setup_reg_classes): Add a new parameter. Setup cover class too. + + * Makefile.in (reload.o, haifa-sched.o, sched-deps.o): Add ira.h to + the dependencies. + + * sched-rgn.c (deps_join): Set up implicit_sets. + (schedule_region): Set up region and basic blocks pressure + relative info. + + * passes.c (init_optimization_passes): Move + pass_subregs_of_mode_init before pass_sched. + +2009-09-02 Martin Jambor <mjambor@suse.cz> + + * tree-sra.c (struct access): New field grp_hint. + (dump_access): Dump grp_hint. + (sort_and_splice_var_accesses): Set grp_hint if a group is read + multiple times. + (analyze_access_subtree): Only scalarize accesses with grp_hint set or + those which have been specifically read and somehow written to. + (propagate_subacesses_accross_link): Set grp_hint of right child and + also possibly of the left child. + +2009-09-02 Jakub Jelinek <jakub@redhat.com> + + * tree-object-size.c (addr_object_size): Always use object_size_type + 0 or 2 when determining the pointer pointed object size. + +2009-09-02 Richard Guenther <rguenther@suse.de> + + Revert + 2009-08-31 Richard Guenther <rguenther@suse.de> + + * builtins.c (fold_builtin_memory_op): Use the alias oracle + to query if the memory regions for memmove overlap. + * tree-ssa-alias.c (ptr_deref_may_alias_decl_p): Relax the + asserts on pointers, instead deal with odd trees. + (ptr_derefs_may_alias_p): Likewise. + (refs_may_alias_p_1): Constructor bases also never alias. + +2009-08-01 Christian Bruel <christian.bruel@st.com> + + Revert: + 2009-07-31 Christian Bruel <christian.bruel@st.com> + * gcc/config.gcc (sh*-*-elf): test with_libgloss. + +2009-09-01 Alexandre Oliva <aoliva@redhat.com> + + * doc/invoke.texi (-fvar-tracking-assignments): New. + (-fvar-tracking-assignments-toggle): New. + (-fdump-final-insns=file): Mark filename as optional. + (--param min-nondebug-insn-uid): New. + (-gdwarf-@{version}): Mention version 4. + * opts.c (common_handle_option): Accept it. + * tree-vrp.c (find_assert_locations_1): Skip debug stmts. + * regrename.c (regrename_optimize): Drop last. Don't count debug + insns as uses. Don't reject change because of debug insn. + (do_replace): Reject DEBUG_INSN as chain starter. Take base_regno + from the chain starter, and check for inexact matches in DEBUG_INSNS. + (scan_rtx_reg): Accept inexact matches in DEBUG_INSNs. + (build_def_use): Simplify and fix the marking of DEBUG_INSNs. + * sched-ebb.c (schedule_ebbs): Skip boundary debug insns. + * fwprop.c (forward_propagate_and_simplify): ...into debug insns. + * doc/gimple.texi (is_gimple_debug): New. + (gimple_debug_bind_p): New. + (is_gimple_call, gimple_assign_cast_p): End sentence with period. + * doc/install.texi (bootstrap-debug): More details. + (bootstrap-debug-big, bootstrap-debug-lean): Document. + (bootstrap-debug-lib): More details. + (bootstrap-debug-ckovw): Update. + (bootstrap-time): New. + * tree-into-ssa.c (mark_def_sites): Skip debug stmts. + (insert_phi_nodes_for): Insert debug stmts. + (rewrite_stmt): Take iterator. Insert debug stmts. + (rewrite_enter_block): Adjust. + (maybe_replace_use_in_debug_stmt): New. + (rewrite_update_stmt): Use it. + (mark_use_interesting): Return early for debug stmts. + * tree-ssa-loop-im.c (rewrite_bittest): Propagate DEFs into debug + stmts before replacing stmt. + (move_computations_stmt): Likewise. + * ira-conflicts.c (add_copies): Skip debug insns. + * regstat.c (regstat_init_n_sets_and_refs): Discount debug insns. + (regstat_bb_compute_ri): Skip debug insns. + * tree-ssa-threadupdate.c (redirection_block_p): Skip debug stmts. + * tree-ssa-loop-manip.c (find_uses_to_rename_stmt, + check_loop_closed_ssa_stmt): Skip debug stmts. + * tree-tailcall.c (find_tail_calls): Likewise. + * tree-ssa-loop-ch.c (should_duplicate_loop_header_p): Likewise. + * tree.h (MAY_HAVE_DEBUG_STMTS): New. + (build_var_debug_value_stat): Declare. + (build_var_debug_value): Define. + (target_for_debug_bind): Declare. + * reload.c (find_equiv_reg): Skip debug insns. + * rtlanal.c (reg_used_between_p): Skip debug insns. + (side_effects_p): Likewise. + (canonicalize_condition): Likewise. + * ddg.c (create_ddg_dep_from_intra_loop_link): Check that non-debug + insns never depend on debug insns. + (create_ddg_dep_no_link): Likewise. + (add_cross_iteration_register_deps): Use ANTI_DEP for debug insns. + Don't add inter-loop dependencies for debug insns. + (build_intra_loop_deps): Likewise. + (create_ddg): Count debug insns. + * ddg.h (struct ddg::num_debug): New. + (num_backargs): Pair up with previous int field. + * diagnostic.c (diagnostic_report_diagnostic): Skip notes on + -fcompare-debug-second. + * final.c (get_attr_length_1): Skip debug insns. + (rest_of_clean-state): Don't dump CFA_RESTORE_STATE. + * gcc.c (invoke_as): Call compare-debug-dump-opt. + (driver_self_specs): Map -fdump-final-insns to + -fdump-final-insns=.. + (get_local_tick): New. + (compare_debug_dump_opt_spec_function): Test for . argument and + compute output name. Compute temp output spec without flag name. + Compute -frandom-seed. + (OPT): Undef after use. + * cfgloopanal.c (num_loop_insns): Skip debug insns. + (average_num_loop_insns): Likewise. + * params.h (MIN_NONDEBUG_INSN_UID): New. + * gimple.def (GIMPLE_DEBUG): New. + * ipa-reference.c (scan_stmt_for_static_refs): Skip debug stmts. + * auto-inc-dec.c (merge_in_block): Skip debug insns. + (merge_in_block): Fix whitespace. + * toplev.c (flag_var_tracking): Update comment. + (flag_var_tracking_assignments): New. + (flag_var_tracking_assignments_toggle): New. + (process_options): Don't open final insns dump file if we're not + going to write to it. Compute defaults for var_tracking. + * df-scan.c (df_insn_rescan_debug_internal): New. + (df_uses_record): Handle debug insns. + * haifa-sched.c (ready): Initialize n_debug. + (contributes_to_priority): Skip debug insns. + (dep_list_size): New. + (priority): Use it. + (rank_for_schedule): Likewise. Schedule debug insns as soon as + they're ready. Disregard previous debug insns to make decisions. + (queue_insn): Never queue debug insns. + (ready_add, ready_remove_first, ready_remove): Count debug insns. + (schedule_insn): Don't reject debug insns because of issue rate. + (get_ebb_head_tail, no_real_insns_p): Skip boundary debug insns. + (queue_to_ready): Skip and discount debug insns. + (choose_ready): Let debug insns through. + (schedule_block): Check boundary debug insns. Discount debug + insns, schedule them early. Adjust whitespace. + (set_priorities): Check for boundary debug insns. + (add_jump_dependencies): Use dep_list_size. + (prev_non_location_insn): New. + (check_cfg): Use it. + * tree-ssa-loop-ivopts.c (find-interesting_users): Skip debug + stmts. + (remove_unused_ivs): Reset debug stmts. + * modulo-sched.c (const_iteration_count): Skip debug insns. + (res_MII): Discount debug insns. + (loop_single_full_bb_p): Skip debug insns. + (sms_schedule): Likewise. + (sms_schedule_by_order): Likewise. + (ps_has_conflicts): Likewise. + * caller-save.c (refmarker_fn): New. + (save_call_clobbered_regs): Replace regs with saved mem in + debug insns. + (mark_referenced_regs): Take pointer, mark and arg. Adjust. + Call refmarker_fn mark for hardregnos. + (mark_reg_as_referenced): New. + (replace_reg_with_saved_mem): New. + * ipa-pure-const.c (check_stmt): Skip debug stmts. + * cse.c (cse_insn): Canonicalize debug insns. Skip them when + searching back. + (cse_extended_basic_block): Skip debug insns. + (count_reg_usage): Likewise. + (is_dead_reg): New, split out of... + (set_live_p): ... here. + (insn_live_p): Use it for debug insns. + * tree-stdarg.c (check_all_va_list_escapes): Skip debug stmts. + (execute_optimize_stdarg): Likewise. + * tree-ssa-dom.c (propagate_rhs_into_lhs): Likewise. + * tree-ssa-propagate.c (substitute_and_fold): Don't regard + changes in debug stmts as changes. + * sel-sched.c (moving_insn_creates_bookkeeping_block_p): New. + (moveup_expr): Don't move across debug insns. Don't move + debug insn if it would create a bookkeeping block. + (moveup_expr_cached): Don't use cache for debug insns that + are heads of blocks. + (compute_av_set_inside_bb): Skip debug insns. + (sel_rank_for_schedule): Schedule debug insns first. Remove + dead code. + (block_valid_for_bookkeeping_p); Support lax searches. + (create_block_for_bookkeeping): Adjust block numbers when + encountering debug-only blocks. + (find_place_for_bookkeeping): Deal with debug-only blocks. + (generate_bookkeeping_insn): Accept no place to insert. + (remove_temp_moveop_nops): New argument full_tidying. + (prepare_place_to_insert): Deal with debug insns. + (advance_state_on_fence): Debug insns don't start cycles. + (update_boundaries): Take fence as argument. Deal with + debug insns. + (schedule_expr_on_boundary): No full_tidying on debug insns. + (fill_insns): Deal with debug insns. + (track_scheduled_insns_and_blocks): Don't count debug insns. + (need_nop_to_preserve_insn_bb): New, split out of... + (remove_insn_from_stream): ... this. + (fur_orig_expr_not_found): Skip debug insns. + * rtl.def (VALUE): Move up. + (DEBUG_INSN): New. + * tree-ssa-sink.c (all_immediate_uses_same_place): Skip debug stmts. + (nearest_common_dominator_of_uses): Take debug_stmts argument. + Set it if debug stmts are found. + (statement_sink_location): Skip debug stmts. Propagate + moving defs into debug stmts. + * ifcvt.c (first_active_insn): Skip debug insns. + (last_active_insns): Likewise. + (cond_exec_process_insns): Likewise. + (noce_process_if_block): Likewise. + (check_cond_move_block): Likewise. + (cond_move_convert_if_block): Likewise. + (block_jumps_and_fallthru_p): Likewise. + (dead_or_predicable): Likewise. + * dwarf2out.c (debug_str_hash_forced): New. + (find_AT_string): Add comment. + (gen_label_for_indirect_string): New. + (get_debug_string_label): New. + (AT_string_form): Use it. + (mem_loc_descriptor): Handle non-TLS symbols. Handle MINUS , DIV, + MOD, AND, IOR, XOR, NOT, ABS, NEG, and CONST_STRING. Accept but + discard COMPARE, IF_THEN_ELSE, ROTATE, ROTATERT, TRUNCATE and + several operations that cannot be represented with DWARF opcodes. + (loc_descriptor): Ignore SIGN_EXTEND and ZERO_EXTEND. Require + dwarf_version 4 for DW_OP_implicit_value and DW_OP_stack_value. + (dwarf2out_var_location): Take during-call mark into account. + (output_indirect_string): Update comment. Output if there are + label and references. + (prune_indirect_string): New. + (prune_unused_types): Call it if debug_str_hash_forced. + More in dwarf2out.c, from Jakub Jelinek <jakub@redhat.com>: + (dw_long_long_const): Remove. + (struct dw_val_struct): Change val_long_long type to rtx. + (print_die, attr_checksum, same_dw_val_p, loc_descriptor): Adjust for + val_long_long change to CONST_DOUBLE rtx from a long hi/lo pair. + (output_die): Likewise. Use HOST_BITS_PER_WIDE_INT size of each + component instead of HOST_BITS_PER_LONG. + (output_loc_operands): Likewise. For const8* assert + HOST_BITS_PER_WIDE_INT rather than HOST_BITS_PER_LONG is >= 64. + (output_loc_operands_raw): For const8* assert HOST_BITS_PER_WIDE_INT + rather than HOST_BITS_PER_LONG is >= 64. + (add_AT_long_long): Remove val_hi and val_lo arguments, add + val_const_double. + (size_of_die): Use HOST_BITS_PER_WIDE_INT size multiplier instead of + HOST_BITS_PER_LONG for dw_val_class_long_long. + (add_const_value_attribute): Adjust add_AT_long_long caller. Don't + handle TLS SYMBOL_REFs. If CONST wraps a constant, tail recurse. + (dwarf_stack_op_name): Handle DW_OP_implicit_value and + DW_OP_stack_value. + (size_of_loc_descr, output_loc_operands, output_loc_operands_raw): + Handle DW_OP_implicit_value. + (extract_int): Move prototype earlier. + (mem_loc_descriptor): For SUBREG punt if inner + mode size is wider than DWARF2_ADDR_SIZE. Handle SIGN_EXTEND + and ZERO_EXTEND by DW_OP_shl and DW_OP_shr{a,}. Handle + EQ, NE, GT, GE, LT, LE, GTU, GEU, LTU, LEU, SMIN, SMAX, UMIN, + UMAX, SIGN_EXTRACT, ZERO_EXTRACT. + (loc_descriptor): Compare mode size with DWARF2_ADDR_SIZE + instead of Pmode size. + (loc_descriptor): Add MODE argument. Handle CONST_INT, CONST_DOUBLE, + CONST_VECTOR, CONST, LABEL_REF and SYMBOL_REF if mode != VOIDmode, + attempt to handle other expressions. Don't handle TLS SYMBOL_REFs. + (concat_loc_descriptor, concatn_loc_descriptor, + loc_descriptor_from_tree_1): Adjust loc_descriptor callers. + (add_location_or_const_value_attribute): Likewise. For single + location loc_lists attempt to use add_const_value_attribute + for constant decls. Add DW_AT_const_value even if + NOTE_VAR_LOCATION is VAR_LOCATION with CONSTANT_P or CONST_STRING + in its expression. + * cfgbuild.c (inside_basic_block_p): Handle debug insns. + (control_flow_insn_p): Likewise. + * tree-parloops.c (eliminate_local_variables_stmt): Handle debug stmt. + (separate_decls_in_region_debug_bind): New. + (separate_decls_in_region): Process debug bind stmts afterwards. + * recog.c (verify_changes): Handle debug insns. + (extract_insn): Likewise. + (peephole2_optimize): Skip debug insns. + * dse.c (scan_insn): Skip debug insns. + * sel-sched-ir.c (return_nop_to_pool): Take full_tidying argument. + Pass it on. + (setup_id_for_insn): Handle debug insns. + (maybe_tidy_empty_bb): Adjust whitespace. + (tidy_control_flow): Skip debug insns. + (sel_remove_insn): Adjust for debug insns. + (sel_estimate_number_of_insns): Skip debug insns. + (create_insn_rtx_from_pattern): Handle debug insns. + (create_copy_of_insn_rtx): Likewise. + * sel-sched-.h (sel_bb_end): Declare. + (sel_bb_empty_or_nop_p): New. + (get_all_loop_exits): Use it. + (_eligible_successor_edge_p): Likewise. + (return_nop_to_pool): Adjust. + * tree-eh.c (tre_empty_eh_handler_p): Skip debug stmts. + * ira-lives.c (process_bb_node_lives): Skip debug insns. + * gimple-pretty-print.c (dump_gimple_debug): New. + (dump_gimple_stmt): Use it. + (dump_bb_header): Skip gimple debug stmts. + * regmove.c (optimize_reg_copy_1): Discount debug insns. + (fixup_match_2): Likewise. + (regmove_backward_pass): Likewise. Simplify combined + replacement. Handle debug insns. + * function.c (instantiate_virtual_regs): Handle debug insns. + * function.h (struct emit_status): Add x_cur_debug_insn_uid. + * print-rtl.h: Include cselib.h. + (print_rtx): Print VALUEs. Split out and recurse for VAR_LOCATIONs. + * df.h (df_inns_rescan_debug_internal): Declare. + * gcse.c (alloc_hash_table): Estimate n_insns. + (cprop_insn): Don't regard debug insns as changes. + (bypass_conditional_jumps): Skip debug insns. + (one_pre_gcse_pass): Adjust. + (one_code_hoisting_pass): Likewise. + (compute_ld_motion_mems): Skip debug insns. + (one_cprop_pass): Adjust. + * tree-if-conv.c (tree_if_convert_stmt): Reset debug stmts. + (if_convertible_stmt_p): Handle debug stmts. + * init-regs.c (initialize_uninitialized_regs): Skip debug insns. + * tree-vect-loop.c (vect_is_simple_reduction): Skip debug stmts. + * ira-build.c (create_bb_allocnos): Skip debug insns. + * tree-flow-inline.h (has_zero_uses): Discount debug stmts. + (has_single_use): Likewise. + (single_imm_use): Likewise. + (num_imm_uses): Likewise. + * tree-ssa-phiopt.c (empty_block_p): Skip debug stmts. + * tree-ssa-coalesce.c (build_ssa_conflict_graph): Skip debug stmts. + (create_outofssa_var_map): Likewise. + * lower-subreg.c (adjust_decomposed_uses): New. + (resolve_debug): New. + (decompose_multiword_subregs): Use it. + * tree-dfa.c (find_referenced_vars): Skip debug stmts. + * emit-rtl.c: Include params.h. + (cur_debug_insn_uid): Define. + (set_new_first_and_last_insn): Set cur_debug_insn_uid too. + (copy_rtx_if_shared_1): Handle debug insns. + (reset_used_flags): Likewise. + (set_used_flags): LIkewise. + (get_max_insn_count): New. + (next_nondebug_insn): New. + (prev_nondebug_insn): New. + (make_debug_insn_raw): New. + (emit_insn_before_noloc): Handle debug insns. + (emit_jump_insn_before_noloc): Likewise. + (emit_call_insn_before_noloc): Likewise. + (emit_debug_insn_before_noloc): New. + (emit_insn_after_noloc): Handle debug insns. + (emit_jump_insn_after_noloc): Likewise. + (emit_call_insn_after_noloc): Likewise. + (emit_debug_insn_after_noloc): Likewise. + (emit_insn_after): Take loc from earlier non-debug insn. + (emit_jump_insn_after): Likewise. + (emit_call_insn_after): Likewise. + (emit_debug_insn_after_setloc): New. + (emit_debug_insn_after): New. + (emit_insn_before): Take loc from later non-debug insn. + (emit_jump_insn_before): Likewise. + (emit_call_insn_before): Likewise. + (emit_debug_insn_before_setloc): New. + (emit_debug_insn_before): New. + (emit_insn): Handle debug insns. + (emit_debug_insn): New. + (emit_jump_insn): Handle debug insns. + (emit_call_insn): Likewise. + (emit): Likewise. + (init_emit): Take min-nondebug-insn-uid into account. + Initialize cur_debug_insn_uid. + (emit_copy_of_insn_after): Handle debug insns. + * cfgexpand.c (gimple_assign_rhs_to_tree): Do not overwrite + location of single rhs in place. + (maybe_dump_rtl_for_gimple_stmt): Dump lineno. + (floor_sdiv_adjust): New. + (cell_sdiv_adjust): New. + (cell_udiv_adjust): New. + (round_sdiv_adjust): New. + (round_udiv_adjust): New. + (wrap_constant): Moved from cselib. + (unwrap_constant): New. + (expand_debug_expr): New. + (expand_debug_locations): New. + (expand_gimple_basic_block): Drop hiding redeclaration. Expand + debug bind stmts. + (gimple_expand_cfg): Expand debug locations. + * cselib.c: Include tree-pass.h. + (struct expand_value_data): New. + (cselib_record_sets_hook): New. + (PRESERVED_VALUE_P, LONG_TERM_PRESERVED_VALUE_P): New. + (cselib_clear_table): Move, and implemnet in terms of... + (cselib_reset_table_with_next_value): ... this. + (cselib_get_next_unknown_value): New. + (discard_useless_locs): Don't discard preserved values. + (cselib_preserve_value): New. + (cselib_preserved_value_p): New. + (cselib_preserve_definitely): New. + (cselib_clear_preserve): New. + (cselib_preserve_only_values): New. + (new_cselib_val): Take rtx argument. Dump it in details. + (cselib_lookup_mem): Adjust. + (expand_loc): Take regs_active in struct. Adjust. Silence + dumps unless details are requested. + (cselib_expand_value_rtx_cb): New. + (cselib_expand_value_rtx): Rename and reimplment in terms of... + (cselib_expand_value_rtx_1): ... this. Adjust. Silence dumps + without details. Copy more subregs. Try to resolve values + using a callback. Wrap constants. + (cselib_subst_to_values): Adjust. + (cselib_log_lookup): New. + (cselib_lookup): Call it. + (cselib_invalidate_regno): Don't count preserved values as useless. + (cselib_invalidate_mem): Likewise. + (cselib_record_set): Likewise. + (struct set): Renamed to cselib_set, moved to cselib.h. + (cselib_record_sets): Adjust. Call hook. + (cselib_process_insn): Reset table when it would be cleared. + (dump_cselib_val): New. + (dump_cselib_table): New. + * tree-cfgcleanup.c (tree_forwarded_block_p): Skip debug stmts. + (remove_forwarder_block): Support moving debug stmts. + * cselib.h (cselib_record_sets_hook): Declare. + (cselib_expand_callback): New type. + (cselib_expand_value_rtx_cb): Declare. + (cselib_reset_table_with_next_value): Declare. + (cselib_get_next_unknown_value): Declare. + (cselib_preserve_value): Declare. + (cselib_preserved_value_p): Declare. + (cselib_preserve_only_values): Declare. + (dump_cselib_table): Declare. + * cfgcleanup.c (flow_find_cross_jump): Skip debug insns. + (try_crossjump_to_edge): Likewise. + (delete_unreachable_blocks): Remove dominant GIMPLE blocks after + dominated blocks when debug stmts are present. + * simplify-rtx.c (delegitimize_mem_from_attrs): New. + * tree-ssa-live.c (remove_unused_locals): Skip debug stmts. + (set_var_live_on_entry): Likewise. + * loop-invariant.c (find_invariants_bb): Skip debug insns. + * cfglayout.c (curr_location, last_location): Make static. + (set_curr_insn_source_location): Don't avoid bouncing. + (get_curr_insn_source_location): New. + (get_curr_insn_block): New. + (duplicate_insn_chain): Handle debug insns. + * tree-ssa-forwprop.c (forward_propagate_addr_expr): Propagate + into debug stmts. + * common.opt (fcompare-debug): Move to sort order. + (fdump-unnumbered-links): Likewise. + (fvar-tracking-assignments): New. + (fvar-tracking-assignments-toggle): New. + * tree-ssa-dce.c (mark_stmt_necessary): Don't mark blocks + because of debug stmts. + (mark_stmt_if_obviously_necessary): Mark debug stmts. + (eliminate_unnecessary_stmts): Walk dominated blocks before + dominators. + * tree-ssa-ter.c (find_replaceable_in_bb): Skip debug stmts. + * ira.c (memref_used_between_p): Skip debug insns. + (update_equiv_regs): Likewise. + * sched-deps.c (sd_lists_size): Accept empty list. + (sd_init_insn): Mark debug insns. + (sd_finish_insn): Unmark them. + (sd_add_dep): Reject non-debug deps on debug insns. + (fixup_sched_groups): Give debug insns group treatment. + Skip debug insns. + (sched_analyze_reg): Don't mark debug insns for sched before call. + (sched_analyze_2): Handle debug insns. + (sched_analyze_insn): Compute next non-debug insn. Handle debug + insns. + (deps_analyze_insn): Handle debug insns. + (deps_start_bb): Skip debug insns. + (init_deps): Initialize last_debug_insn. + * tree-ssa.c (target_for_debug_bind): New. + (find_released_ssa_name): New. + (propagate_var_def_into_debug_stmts): New. + (propagate_defs_into_debug_stmts): New. + (verify_ssa): Skip debug bind stmts without values. + (warn_uninialized_vars): Skip debug stmts. + * target-def.h (TARGET_DELEGITIMIZE_ADDRESS): Set default. + * rtl.c (rtx_equal_p_cb): Handle VALUEs. + (rtx_equal_p): Likewise. + * ira-costs.c (scan_one_insn): Skip debug insns. + (process_bb_node_for_hard_reg_moves): Likewise. + * rtl.h (DEBUG_INSN_P): New. + (NONDEBUG_INSN_P): New. + (MAY_HAVE_DEBUG_INSNS): New. + (INSN_P): Accept debug insns. + (RTX_FRAME_RELATED_P): Likewise. + (INSN_DELETED_P): Likewise + (PAT_VAR_LOCATION_DECL): New. + (PAT_VAR_LOCATION_LOC): New. + (PAT_VAR_OCATION_STATUS): New. + (NOTE_VAR_LOCATION_DECL): Reimplement. + (NOTE_VAR_LOCATION_LOC): Likewise. + (NOTE_VAR_LOCATION_STATUS): Likewise. + (INSN_VAR_LOCATION): New. + (INSN_VAR_LOCATION_DECL): New. + (INSN_VAR_LOCATION_LOC): New. + (INSN_VAR_LOCATION_STATUS): New. + (gen_rtx_UNKNOWN_VAR_LOC): New. + (VAR_LOC_UNKNOWN_P): New. + (NOTE_DURING_CALL_P): New. + (SCHED_GROUP_P): Accept debug insns. + (emit_debug_insn_before): Declare. + (emit_debug_insn_before_noloc): Declare. + (emit_debug_insn_beore_setloc): Declare. + (emit_debug_insn_after): Declare. + (emit_debug_insn_after_noloc): Declare. + (emit_debug_insn_after_setloc): Declare. + (emit_debug_insn): Declare. + (make_debug_insn_raw): Declare. + (prev_nondebug_insn): Declare. + (next_nondebug_insn): Declare. + (delegitimize_mem_from_attrs): Declare. + (get_max_insn_count): Declare. + (wrap_constant): Declare. + (unwrap_constant): Declare. + (get_curr_insn_source_location): Declare. + (get_curr_insn_block): Declare. + * tree-inline.c (insert_debug_decl_map): New. + (processing_debug_stmt): New. + (remap_decl): Don't create new mappings in debug stmts. + (remap_gimple_op_r): Don't add references in debug stmts. + (copy_tree_body_r): Likewise. + (remap_gimple_stmt): Handle debug bind stmts. + (copy_bb): Skip debug stmts. + (copy_edges_for_bb): Likewise. + (copy_debug_stmt): New. + (copy_debug_stmts): New. + (copy_body): Copy debug stmts at the end. + (insert_init_debug_bind): New. + (insert_init_stmt): Take id. Skip and emit debug stmts. + (setup_one_parameter): Remap variable earlier, register debug mapping. + (estimate_num_insns): Skip debug stmts. + (expand_call_inline): Preserve debug_map. + (optimize_inline_calls): Check for no debug_stmts left-overs. + (unsave_expr_now): Preserve debug_map. + (copy_gimple_seq_and_replace_locals): Likewise. + (tree_function_versioning): Check for no debug_stmts left-overs. + Init and destroy debug_map as needed. Split edges unconditionally. + (build_duplicate_type): Init and destroy debug_map as needed. + * tree-inline.h: Include gimple.h instead of pointer-set.h. + (struct copy_body_data): Add debug_stmts and debug_map. + * sched-int.h (struct ready_list): Add n_debug. + (struct deps): Add last_debug_insn. + (DEBUG_INSN_SCHED_P): New. + (BOUNDARY_DEBUG_INSN_P): New. + (SCHEDULE_DEBUG_INSN_P): New. + (sd_iterator_cond): Accept empty list. + * combine.c (create_log_links): Skip debug insns. + (combine_instructions): Likewise. + (cleanup_auto_inc_dec): New. From Jakub Jelinek: Make sure the + return value is always unshared. + (struct rtx_subst_pair): New. + (auto_adjust_pair): New. + (propagate_for_debug_subst): New. + (propagate_for_debug): New. + (try_combine): Skip debug insns. Propagate removed defs into + debug insns. + (next_nonnote_nondebug_insn): New. + (distribute_notes): Use it. Skip debug insns. + (distribute_links): Skip debug insns. + * tree-outof-ssa.c (set_location_for_edge): Likewise. + * resource.c (mark_target_live_regs): Likewise. + * var-tracking.c: Include cselib.h and target.h. + (enum micro_operation_type): Add MO_VAL_USE, MO_VAL_LOC, and + MO_VAL_SET. + (micro_operation_type_name): New. + (enum emit_note_where): Add EMIT_NOTE_AFTER_CALL_INSN. + (struct micro_operation_def): Update comments. + (decl_or_value): New type. Use instead of decls. + (struct emit_note_data_def): Add vars. + (struct attrs_def): Use decl_or_value. + (struct variable_tracking_info_def): Add permp, flooded. + (struct location_chain_def): Update comment. + (struct variable_part_def): Use decl_or_value. + (struct variable_def): Make var_part a variable length array. + (valvar_pool): New. + (scratch_regs): New. + (cselib_hook_called): New. + (dv_is_decl_p): New. + (dv_is_value_p): New. + (dv_as_decl): New. + (dv_as_value): New. + (dv_as_opaque): New. + (dv_onepart_p): New. + (dv_pool): New. + (IS_DECL_CODE): New. + (check_value_is_not_decl): New. + (dv_from_decl): New. + (dv_from_value): New. + (dv_htab_hash): New. + (variable_htab_hash): Use it. + (variable_htab_eq): Support values. + (variable_htab_free): Free from the right pool. + (attrs_list_member, attrs_list_insert): Use decl_or_value. + (attrs_list_union): Adjust. + (attrs_list_mpdv_union): New. + (tie_break_pointers): New. + (canon_value_cmp): New. + (unshare_variable): Return possibly-modified slot. + (vars_copy_1): Adjust. + (var_reg_decl_set): Adjust. Split out of... + (var_reg_set): ... this. + (get_init_value): Adjust. + (var_reg_delete_and_set): Adjust. + (var_reg_delete): Adjust. + (var_regno_delete): Adjust. + (var_mem_decl_set): Split out of... + (var_mem_set): ... this. + (var_mem_delete_and_set): Adjust. + (var_mem_delete): Adjust. + (val_store): New. + (val_reset): New. + (val_resolve): New. + (variable_union): Adjust. Speed up merge of 1-part vars. + (variable_canonicalize): Use unshared slot. + (VALUED_RECURSED_INTO): New. + (find_loc_in_1pdv): New. + (struct dfset_merge): New. + (insert_into_intersection): New. + (intersect_loc_chains): New. + (loc_cmp): New. + (canonicalize_loc_order_check): New. + (canonicalize_values_mark): New. + (canonicalize_values_star): New. + (variable_merge_over_cur): New. + (variable_merge_over_src): New. + (dataflow_set_merge): New. + (dataflow_set_equiv_regs): New. + (remove_duplicate_values): New. + (struct dfset_post_merge): New. + (variable_post_merge_new_vals): New. + (variable_post_merge_perm_vals): New. + (dataflow_post_merge_adjust): New. + (find_mem_expr_in_1pdv): New. + (dataflow_set_preserve_mem_locs): New. + (dataflow_set_remove_mem_locs): New. + (dataflow_set_clear_at_call): New. + (onepart_variable_different_p): New. + (variable_different_p): Use it. + (dataflow_set_different_1): Adjust. Make detailed dump more verbose. + (track_expr_p): Add need_rtl parameter. Don't generate rtl + if not needed. + (track_loc_p): Pass it true. + (struct count_use_info): New. + (find_use_val): New. + (replace_expr_with_values): New. + (log_op_type): New. + (use_type): New, partially split out of... + (count_uses): ... this. Count new micro-ops. + (count_uses_1): Adjust. + (count_stores): Adjust. + (count_with_sets): New. + (VAL_NEEDS_RESOLUTION): New. + (VAL_HOLDS_TRACK_EXPR): New. + (VAL_EXPR_IS_COPIED): New. + (VAL_EXPR_IS_CLOBBERED): New. + (add_uses): Adjust. Generate new micro-ops. + (add_uses_1): Adjust. + (add_stores): Generate new micro-ops. + (add_with_sets): New. + (find_src_status): Adjust. + (find_src_set_src): Adjust. + (compute_bb_dataflow): Use dataflow_set_clear_at_call. + Handle new micro-ops. Canonicalize value equivalances. + (vt_find_locations): Compute total size of hash tables for + dumping. Perform merge for var-tracking-assignments. Don't + disregard single-block loops. + (dump_attrs_list): Handle decl_or_value. + (dump_variable): Take variable. Deal with decl_or_value. + (dump_variable_slot): New. + (dump_vars): Use it. + (dump_dataflow_sets): Adjust. + (set_slot_part): New, extended to support one-part variables + after splitting out of... + (set_variable_part): ... this. + (clobber_slot_part): New, split out of... + (clobber_variable_part): ... this. + (delete_slot_part): New, split out of... + (delete_variable_part): .... this. + (check_wrap_constant): New. + (vt_expand_loc_callback): New. + (vt_expand_loc): New. + (emit_note_insn_var_location): Adjust. Handle values. Handle + EMIT_NOTE_AFTER_CALL_INSN. + (emit_notes_for_differences_1): Adjust. Handle values. + (emit_notes_for_differences_2): Likewise. + (emit_notes_for_differences): Adjust. + (emit_notes_in_bb): Take pointer to set. Emit AFTER_CALL_INSN notes. + Adjust. Handle new micro-ops. + (vt_add_function_parameters): Adjust. Create and bind values. + (vt_initialize): Adjust. Initialize scratch_regs and + valvar_pool, flooded and perm.. Initialize and use cselib. Log + operations. Move some code to count_with_sets and add_with_sets. + (delete_debug_insns): New. + (vt_debug_insns_local): New. + (vt_finalize): Release permp, valvar_pool, scratch_regs. Finish + cselib. + (var_tracking_main): If var-tracking-assignments is enabled + but var-tracking isn't, delete debug insns and leave. Likewise + if we exceed limits or fail the stack adjustments tests, and + after all var-tracking processing. + More in var-tracking, from Jakub Jelinek <jakub@redhat.com>: + (dataflow_set): Add traversed_vars. + (value_chain, const_value_chain): New typedefs. + (value_chain_pool, value_chains): New variables. + (value_chain_htab_hash, value_chain_htab_eq, add_value_chain, + add_value_chains, add_cselib_value_chains, remove_value_chain, + remove_value_chains, remove_cselib_value_chains): New functions. + (shared_hash_find_slot_unshare_1, shared_hash_find_slot_1, + shared_hash_find_slot_noinsert_1, shared_hash_find_1): New + static inlines. + (shared_hash_find_slot_unshare, shared_hash_find_slot, + shared_hash_find_slot_noinsert, shared_hash_find): Update. + (dst_can_be_shared): New variable. + (unshare_variable): Unshare set->vars if shared, use shared_hash_*. + Clear dst_can_be_shared. If set->traversed_vars is non-NULL and + different from set->vars, look up slot again instead of using the + passed in slot. + (dataflow_set_init): Initialize traversed_vars. + (variable_union): Use shared_hash_*. Use initially NO_INSERT + lookup if set->vars is shared. Don't keep slot cleared before + calling unshare_variable. Unshare set->vars if needed. Adjust + unshare_variable callers. Clear dst_can_be_shared if needed. + Even ->refcount == 1 vars must be unshared if set->vars is shared + and var needs to be modified. + (dataflow_set_union): Set traversed_vars during canonicalization. + (VALUE_CHANGED, DECL_CHANGED): Define. + (set_dv_changed, dv_changed_p): New static inlines. + (track_expr_p): Clear DECL_CHANGED. + (dump_dataflow_sets): Set it. + (variable_was_changed): Call set_dv_changed. + (emit_note_insn_var_location): Likewise. + (changed_variables_stack): New variable. + (check_changed_vars_1, check_changed_vars_2): New functions. + (emit_notes_for_changes): Do nothing if changed_variables is + empty. Traverse changed_variables with check_changed_vars_1, + call check_changed_vars_2 on each changed_variables_stack entry. + (emit_notes_in_bb): Add SET argument. Just clear it at the + beginning, use it instead of local &set, don't destroy it at the end. + (vt_emit_notes): Call dataflow_set_clear early on all + VTI(bb)->out sets, never use them, instead use emit_notes_in_bb + computed set, dataflow_set_clear also VTI(bb)->in when we are + done with the basic block. Initialize changed_variables_stack, + free it afterwards. If ENABLE_CHECKING verify that after noting + differences to an empty set value_chains hash table is empty. + (vt_initialize): Initialize value_chains and value_chain_pool. + (vt_finalize): Delete value_chains htab, free value_chain_pool. + (variable_tracking_main): Call dump_dataflow_sets before calling + vt_emit_notes, not after it. + * tree-flow.h (propagate_defs_into_debug_stmts): Declare. + (propagate_var_def_into_debug_stmts): Declare. + * df-problems.c (df_lr_bb_local_compute): Skip debug insns. + (df_set_note): Reject debug insns. + (df_whole_mw_reg_dead_p): Take added_notes_p argument. Don't + add notes to debug insns. + (df_note_bb_compute): Adjust. Likewise. + (df_simulate_uses): Skip debug insns. + (df_simulate_initialize_backwards): Likewise. + * reg-stack.c (subst_stack_regs_in_debug_insn): New. + (subst_stack_regs_pat): Reject debug insns. + (convert_regs_1): Handle debug insns. + * Makefile.in (TREE_INLINE_H): Take pointer-set.h from GIMPLE_H. + (print-rtl.o): Depend on cselib.h. + (cselib.o): Depend on TREE_PASS_H. + (var-tracking.o): Depend on cselib.h and TARGET_H. + * sched-rgn.c (rgn_estimate_number_of_insns): Discount debug insns. + (init_ready_list): Skip boundary debug insns. + (add_branch_dependences): Skip debug insns. + (free_block_dependencies): Check for blocks with only debug insns. + (compute_priorities): Likewise. + * gimple.c (gss_for_code): Handle GIMPLE_DEBUG. + (gimple_build_with_ops_stat): Take subcode as unsigned. Adjust + all callers. + (gimple_build_debug_bind_stat): New. + (empty_body_p): Skip debug stmts. + (gimple_has_side_effects): Likewise. + (gimple_rhs_has_side_effects): Likewise. + * gimple.h (enum gimple_debug_subcode, GIMPLE_DEBUG_BIND): New. + (gimple_build_debug_bind_stat): Declare. + (gimple_build_debug_bind): Define. + (is_gimple_debug): New. + (gimple_debug_bind_p): New. + (gimple_debug_bind_get_var): New. + (gimple_debug_bind_get_value): New. + (gimple_debug_bind_get_value_ptr): New. + (gimple_debug_bind_set_var): New. + (gimple_debug_bind_set_value): New. + (GIMPLE_DEBUG_BIND_NOVALUE): New internal temporary macro. + (gimple_debug_bind_reset_value): New. + (gimple_debug_bind_has_value_p): New. + (gsi_next_nondebug): New. + (gsi_prev_nondebug): New. + (gsi_start_nondebug_bb): New. + (gsi_last_nondebug_bb): New. + * sched-vis.c (print_pattern): Handle VAR_LOCATION. + (print_insn): Handle DEBUG_INSN. + * tree-cfg.c (remove_bb): Walk stmts backwards. Let loc + of first insn prevail. + (first_stmt): Skip debug stmts. + (first_non_label_stmt): Likewise. + (last_stmt): Likewise. + (has_zero_uses_1): New. + (single_imm_use_1): New. + (verify_gimple_debug): New. + (verify_types_in_gimple_stmt): Handle debug stmts. + (verify_stmt): Likewise. + (debug_loop_num): Skip debug stmts. + (remove_edge_and_dominated_blocks): Remove dominators last. + * tree-ssa-reasssoc.c (rewrite_expr_tree): Propagate into debug stmts. + (linearize_expr): Likewise. + * config/i386/i386.c (ix86_delegitimize_address): Call + default implementation. + * config/ia64/ia64.c (ia64_safe_itanium_class): Handle debug insns. + (group_barrier_needed): Skip debug insns. + (emit_insn_group_barriers): Likewise. + (emit_all_insn_group_barriers): Likewise. + (ia64_variable_issue): Handle debug insns. + (ia64_dfa_new_cycle): Likewise. + (final_emit_insn_group_barriers): Skip debug insns. + (ia64_dwarf2out_def_steady_cfa): Take frame argument. Don't + def cfa without frame. + (process_set): Likewise. + (process_for_unwind_directive): Pass frame on. + * config/rs6000/rs6000.c (TARGET_DELEGITIMIZE_ADDRESS): Define. + (rs6000_delegitimize_address): New. + (rs6000_debug_adjust_cost): Handle debug insns. + (is_microcoded_insn): Likewise. + (is_cracked_insn): Likewise. + (is_nonpipeline_insn): Likewise. + (insn_must_be_first_in_group): Likewise. + (insn_must_be_last_in_group): Likewise. + (force_new_group): Likewise. + * cfgrtl.c (rtl_split_block): Emit INSN_DELETED note if block + contains only debug insns. + (rtl_merge_blocks): Skip debug insns. + (purge_dead_edges): Likewise. + (rtl_block_ends_with_call_p): Skip debug insns. + * dce.c (deletable_insn_p): Handle VAR_LOCATION. + (mark_reg_dependencies): Skip debug insns. + * params.def (PARAM_MIN_NONDEBUG_INSN_UID): New. + * tree-ssanames.c (release_ssa_name): Propagate def into debug stmts. + * tree-ssa-threadedge.c + (record_temporary_equivalences_from_stmts): Skip debug stmts. + * regcprop.c (replace_oldest_value_addr): Skip debug insns. + (replace_oldest_value_mem): Use ALL_REGS for debug insns. + (copyprop_hardreg_forward_1): Handle debug insns. + * reload1.c (reload): Skip debug insns. Replace unassigned + pseudos in debug insns with their equivalences. + (eliminate_regs_in_insn): Skip debug insns. + (emit_input_reload_insns): Skip debug insns at first, adjust + them later. + * tree-ssa-operands.c (add_virtual_operand): Reject debug stmts. + (get_indirect_ref_operands): Pass opf_no_vops on. + (get_expr_operands): Likewise. Skip debug stmts. + (parse_ssa_operands): Scan debug insns with opf_no_vops. + +2009-09-01 Richard Henderson <rth@redhat.com> + + * tree-ssa-ccp.c (ccp_initialize): Make sure to simulate + stmt_ends_pp_p statements at least once. + * tree-vrp.c (vrp_initialize): Likewise. + (vrp_visit_stmt): Be prepared for non-interesting stmts. + +2009-09-01 Dodji Seketeli <dodji@redhat.com> + + PR bootstrap/41205 + Fix AIX bootstrap after PR debug/30161 + * dwarf2out.c (make_ith_pack_parameter_name): Don't used strnlen + that is a GNU extension. + (tmpl_value_parm_die_table): Move the definition of this global + outside #ifdef DWARF2_DEBUGGING_INFO region. + +2009-09-01 Richard Guenther <rguenther@suse.de> + + * tree.c (tree_expr_size): New function. + * tree.h (tree_expr_size): Declare. + * rtlanal.c (rtx_addr_can_trap_p_1): Adjust comment. + * builtins.c (fold_builtin_memory_op): Use tree_expr_size. + * langhooks.c (lhd_expr_size): Remove. + * langhooks.h (struct lang_hooks): Remove expr_size. + * explow.c (expr_size): Use tree_expr_size. + (int_expr_size): Likewise. + * langhooks-def.h (lhd_expr_size): Remove. + (LANG_HOOKS_EXPR_SIZE): Likewise. + (LANG_HOOKS_INITIALIZER): Adjust. + +2009-09-01 Richard Guenther <rguenther@suse.de> + + * tree-flow.h (mark_addressable): Move declaration ... + * tree.h (mark_addressable): ... here. + * stmt.c (expand_asm_operands): Use mark_addressable, not + lang_hooks.mark_addressable. + * langhooks-def.h (LANG_HOOKS_INITIALIZER): Remove + LANG_HOOKS_MARK_ADDRESSABLE. + * langhooks.h (struct lang_hooks): Remove mark_addressable langhook. + * c-objc-common.h (LANG_HOOKS_MARK_ADDRESSABLE): Remove. + +2009-08-31 Chris Demetriou <cgd@google.com> + + * config/i386/i386.c (ix86_vectorize_builtin_conversion): Never + vectorize if not TARGET_SSE2. + +2009-08-31 DJ Delorie <dj@redhat.com> + + * config/mep/mep.h (FUNCTION_ARG_REGNO_P): Exclude coprocessor + registers if no coprocessor is enabled. + +2009-08-31 Dodji Seketeli <dodji@redhat.com> + + PR debug/30161 + * cgraph.h (cgraph_get_node): Declare ... + * cgraph.c (cgraph_get_node): ... new function. + * dwarf2out.c (gen_generic_params_dies, + generic_parameter_die, tree_add_const_value_attribute_for_decl, + make_ith_pack_parameter_name, + append_entry_to_tmpl_value_parm_die_table, + gen_remaining_tmpl_value_param_die_attribute): New functions. + (gen_subprogram_die): Generate debug info for template parameters + if debug info level is higher than DINFO_LEVEL_TERSE. + Use tree_add_const_value_attribute_for_decl instead of + tree_add_const_value_attribute. + (gen_const_die): Use tree_add_const_value_attribute_for_decl + instead of tree_add_const_value_attribute. + (gen_struct_or_union_type_die): Generate debug + info for template parameters if debug info level is higher than + DINFO_LEVEL_TERSE. + (tree_add_const_value_attribute): Handle integral and pointer + constants. Update comment. + (dwarf_tag_name): Support DW_TAG_GNU_template_template_param. + (dwarf_attr_name): Support DW_AT_GNU_template_name. + (reference_to_unused): Fix thinko. Remove redundant predicates from + tests. + (tree_add_const_value_attribute): Make this work for constant + expressions only. + tree_add_const_value_attribute_for_decl is to be used for variable + DECLs now. + (add_location_or_const_value_attribute): Use + tree_add_const_value_attribute_for_decl now. + (dwarf2out_finish): Emit the DW_AT_const_value attribute of + DW_TAG_template_value_param DIEs after function DIEs have been + emitted. + * langhooks.h (lang_hooks_for_types): Add + get_argument_pack_elems. + (lang_hooks_for_decls): Add generic_generic_parameter_decl_p. + (lang_hooks): Added get_innermost_generic_parms, + get_innermost_generic_args. + * langhooks-def.h (LANG_HOOKS_GET_INNERMOST_GENERIC_PARMS, + LANG_HOOKS_GET_INNERMOST_GENERIC_ARGS, + LANG_HOOKS_GET_ARGUMENT_PACK_ELEMS, + LANG_HOOKS_GENERIC_GENERIC_PARAMETER_DECL_P): New language hooks. + +2009-08-31 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (machine_function): Add frame_locked flag. Set + it once we start generating the prologue or epilogue. + (mep_call_saves_register): If the frame is locked, re-use + cached values. + (mep_assign_save_slots): New, broken out from mep_expand_prologue. + (mep_expand_prologue): Call it. + (mep_expand_epilogue): Likewise. + (mep_start_function): Use the same logic as mep_expand_prologue. + (mep_pass_by_reference): Make logic more readable. + (mep_return_in_memory): Zero-sized objects are passed in memory. + (mep_reorg_noframe): Make sure we have accurate REG_DEAD notes. + +2009-08-31 Richard Guenther <rguenther@suse.de> + + * builtins.c (fold_builtin_memory_op): Use the alias oracle + to query if the memory regions for memmove overlap. + * tree-ssa-alias.c (ptr_deref_may_alias_decl_p): Relax the + asserts on pointers, instead deal with odd trees. + (ptr_derefs_may_alias_p): Likewise. + (refs_may_alias_p_1): Constructor bases also never alias. + +2009-08-31 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (Final install): Adjust reference on where to + order printed manuals. + +2009-08-30 Olivier Hainque <hainque@adacore.com> + + * dwarf2out.c (switch_to_frame_table_section): Move + definition prior to first use. + +2009-08-30 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41186 + * tree-ssa-alias.c (ptr_deref_may_alias_ref_p): Remove. + (ao_ref_init_from_ptr_and_size): New function. + (ref_maybe_used_by_call_p_1): Be more precise tracking + used ranges for builtin functions. + (ref_maybe_used_by_call_p): Adjust. + (call_may_clobber_ref_p_1): Be more precise tracking clobbered + ranges for builtin functions. + * tree-ssa-alias.h (ao_ref_init_from_ptr_and_size): Declare. + +2009-08-30 Alan Modra <amodra@bigpond.net.au> + + PR target/41081 + * fwprop.c (get_reg_use_in): Delete. + (free_load_extend): New function. + (forward_propagate_subreg): Use it. + +2009-08-29 Kaz Kojima <kkojima@gcc.gnu.org> + + * config.gcc (sh*-*-elf): Add superh stuff only for sh*-superh-elf. + +2009-08-29 Kai Tietz<kai.tietz@onevision.com> + + PR/41184 + * config/i386.c (ix86_expand_epilogue): Correct stack adjustment for + padding. + +2009-08-29 Douglas B Rupp <rupp@gnat.com> + + * crtstuff.c (__do_global_dtors_aux): Use atexit if no + fini or fini_array section. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (graphite_legal_transform_bb): Call + pbb_remove_duplicate_pdrs. + * graphite-poly.c (can_collapse_pdr): Removed. + (pdr_find_duplicate): Removed. + (can_collapse_pdrs): New. + (pbb_remove_duplicate_pdrs): New. + (new_poly_dr): Do not look for duplicates. + * graphite-poly.h (struct poly_bb): New field pdr_duplicates_removed. + (PBB_PDR_DUPLICATES_REMOVED): New. + (pbb_remove_duplicate_pdrs): Declared. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-interchange.c (pbb_interchange_profitable_p): Adjust + the strides by multiplying by PDR_NB_REFS. + * graphite-poly.c (can_collapse_pdr): New. + (pdr_find_duplicate): New. + (new_poly_dr): Call pdr_find_duplicate. Collapse duplicate PDRs. + Initialize PDR_NB_REFS. + * graphite-poly.h (struct poly_dr): Add field nb_refs. + (PDR_NB_REFS): New. + (new_poly_dr): Number of subscripts is a graphite_dim_t. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/40965 + * graphite-poly.c (apply_poly_transforms): Remove legality test before + any transform. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (pddr_original_scattering): Return NULL + for read-read dependence relations. + * graphite-poly.h (enum poly_dr_type): Fix comment. + (pdr_read_p): New. + (pdr_write_p): New. + (pdr_may_write_p): New. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-poly.h (enum POLY_DR_TYPE): Renamed poly_dr_type. + (struct poly_dr): Same. + (new_poly_dr): Same. + * graphite-poly.c (new_poly_dr): Same. + * graphite-dependences.c (dot_deps): Disable call to system. + +2009-08-28 Cary Coutant <ccoutant@google.com> + + PR debug/41063 + * dwarf2out.c (gen_type_die_with_usage): Use proper context for + struct/union/enum types local to a function. + +2009-08-28 Konrad Trifunovic <konrad.trifunovic@gmail.com> + Sebastian Pop <sebastian.pop@amd.com> + + * graphite-blocking.c (pbb_strip_mine_loop_depth): Renamed + pbb_strip_mine_time_depth. Changed the implementation so that + transformation is expressed as a transformation on + time (scatttering) dimensions. Also, ensures that the 2d+1 + scheduling format is preserved. + (pbb_strip_mine_profitable_p): Profitability is based on the + iteration number of a given time (scattering) dimension, + and not on a original loop depth dimension. + (pbb_strip_mine): Call pbb_number_of_iterations_at_time. + (pbb_do_strip_mine): Call psct_dynamic_dim. + * graphite-poly.c (pbb_number_of_iterations_at_time): New. + * graphite-poly.h (pbb_number_of_iterations_at_time): Declared. + (pbb_nb_dynamic_scattering_transform): New. + (psct_dynamic_dim): New. + +2009-08-28 Konrad Trifunovic <konrad.trifunovic@gmail.com> + + * graphite-ppl.c (ppl_max_for_le): Renamed ppl_max_for_le_pointset. + * graphite-ppl.h (ppl_max_for_le): Renamed ppl_max_for_le_pointset. + * graphite-poly.c (pbb_number_of_iterations): Rename ppl_max_for_le. + * graphite-interchange.c (build_linearized_memory_access): Same. + (memory_stride_in_loop): Same. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (pddr_original_scattering): New. + (graphite_legal_transform_dr): Call pddr_original_scattering. + (dot_deps_1): New. + (dot_deps): New. + * graphite-dependences.h (dot_deps): Declared. + * graphite-poly.c (new_poly_dr): Initialize PDR_ID. + (print_pdr): Print PDR_ID. + * graphite-poly.h (struct poly_dr): Add field id. + (PDR_ID): New. + (pbb_index): New. + * graphite-scop-detection.c (dot_all_scops_1): Cleanup comment. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (graphite_carried_dependence_level_k): Do + not delete the original dependence relation. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (new_poly_dr_pair): Renamed new_poly_ddr. + (eq_poly_dr_pair_p): Renamed eq_poly_ddr_p. + (hash_poly_dr_pair_p): Renamed hash_poly_ddr_p. + (free_poly_ddr): New. + (pddr_is_empty): New. + (dependence_polyhedron_1): Now returns a poly_ddr_p. + (dependence_polyhedron): Same. Remove useless gcc_assert. + Remove fprintfs. + (graphite_legal_transform_dr): Call pddr_is_empty and free_poly_ddr. + (graphite_carried_dependence_level_k): Call pddr_is_empty. + * graphite-dependences.h (enum poly_dependence_kind): New. + (poly_dr_pair): Renamed poly_ddr. Added a field kind. + (PDRP_SOURCE): Renamed PDDR_SOURCE. + (PDRP_SINK): Renamed PDDR_SINK. + (PDRP_DDP): Renamed PDDR_DDP. + (PDDR_KIND): New. + (free_poly_ddr): Declared. + * graphite-poly.c (new_scop): Use the new hash function names. + * graphite-poly.h (struct scop): Renamed field original_pdr_pairs + into original_pddrs. + (SCOP_ORIGINAL_PDR_PAIRS): Renamed SCOP_ORIGINAL_PDDRS. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * cfgloopmanip.c (create_empty_loop_on_edge): Generate upper + bounds with LT_EXPR to make niter analysis more precise on code + generated by Graphite. + +2009-08-28 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (graphite_legal_transform_dr): Fix formatting. + (graphite_legal_transform_bb): Same. + (poly_drs_may_alias_p): Same. + +2009-08-28 Richard Guenther <rguenther@suse.de> + + * tree.def: Remove note about obsolete TYPE_NONCOPIED_PARTS. + +2009-08-28 Jan Beulich <jbeulich@novell.com> + + * config/i386/netware.c: Include langhooks.h. + (i386_nlm_encode_section_info): Simplify. + (netware_override_options): Delete. + * config/i386/netware.h (netware_override_options): Delete + declaration. + (OVERRIDE_OPTIONS): Delete definition. + (SUBTARGET_OVERRIDE_OPTIONS): Define. + (ASM_COMMENT_START): Define. + * config/i386/nwld.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Define. + +2009-08-28 Jan Beulich <jbeulich@novell.com> + + * configure.ac: For in-tree ld, do a plain version check to + determine whether comdat groups are supported. + * configure: Regenerate. + +2009-08-28 Olivier Hainque <hainque@adacore.com> + + * collect2.c (DO_COLLECT_EXPORT_LIST): New internal macro, + always defined. Reflect definition or absence of such for + COLLECT_EXPORT_LIST. Readability helper. + (scanfilter): New enum, to help control what symbols + are to be considered or ignored by scan_prog_file. + (enum pass): Rename as "scanpass", moved together with scanfilter + prior to scan_prog_file's prototype. + (scan_prog_file): Accept and honor scanpass and scanfilter arguments. + Group prototype with the scanpass/scanfilter definitions, factorize + head comments for the several implementations at the prototype. + (main): Reorganize the first pass link control to let AIX + drag only the needed frame tables in executables. Prevent + frame tables collection during the scan aimed at static ctors. + Pre-link and scan for frame tables later to compensate. + * doc/tm.texi (ASM_OUTPUT_DWARF_TABLE_REF): New macro. + A C statement to issue assembly directives that create a reference + to the given DWARF table identifier label from the current function + section. + * dwarf2out.c (switch_to_eh_frame_section): Add a BACK argument + to differentiate first time section entry. Only emit a .data + tables start identifier label the first time around. + (switch_to_frame_table_section): New function. Helper for + output_call_frame_info to switch possibly BACK into the eh_frame + or the debug_frame section depending on FOR_EH. + (output_call_frame_info): Use helper to first enter the proper + frame section. + (output_fde): Use ASM_OUTPUT_DWARF_TABLE_REF when defined to + emit a link to the frame table start label from each function + section. + * config/rs6000/rs6000.c (rs6000_aix_asm_output_dwarf_table_ref): + New function. Implementation of ASM_OUTPUT_DWARF_TABLE_REF. + * config/rs6000/rs6000-protos.h: Declare it. + * config/rs6000/aix.h (ASM_OUTPUT_DWARF_TABLE_REF): Define. + +2009-08-27 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (split_branches): Check the result of + next_active_insn. + +2009-08-27 Steve Ellcey <sje@cup.hp.com> + + * config/ia64/hpux.h (LIB_SPEC): Add -lrt for when + using -pthread -fopenmp + +2009-08-27 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/service.texi (service directory): Update URL. + +2009-08-27 Uros Bizjak <ubizjak@gmail.com> + + PR rtl-optimization/40861 + * simplify-rtx.c (simplify_subreg): Do not call simplify_gen_subreg to + extract word from a multi-word subreg for negative byte positions. + +2009-08-27 Tristan Gingold <gingold@adacore.com> + Douglas B Rupp <rupp@gnat.com> + + * config/ia64/ia64.c (ia64_attribute_table): Add "common_object" entry. + (SECTION_VMS_OVERLAY): Define. + (ia64_vms_common_object_attribute): Added. Handle the "common_object" + attribute. + (ia64_vms_elf_asm_named_section): Added. Generate .section pseudo-op + for common_object. + (ia64_vms_output_aligned_decl_common): Added. Generate pseudo-op for + common_object declarations. + (ia64_section_type_flags): Set section flag for common_object. + * config/ia64/ia64-protos.h + (ia64_vms_output_aligned_decl_common): Declare. + (ia64_vms_elf_asm_named_section): Declare. + +2009-08-27 Michael Matz <matz@suse.de> + + * expr.c (expand_expr_real_2): New function taking exploded + unary or binary expression, split out from ... + (expand_expr_real_1): ... here. Move over all unary/binary + switch parts to above function, in particular these codes: + PAREN_EXPR, NOP_EXPR, CONVERT_EXPR, POINTER_PLUS_EXPR, PLUS_EXPR, + MINUS_EXPR, MULT_EXPR, TRUNC_DIV_EXPR, FLOOR_DIV_EXPR, CEIL_DIV_EXPR, + ROUND_DIV_EXPR, EXACT_DIV_EXPR, RDIV_EXPR, TRUNC_MOD_EXPR, + FLOOR_MOD_EXPR, CEIL_MOD_EXPR, ROUND_MOD_EXPR, FIXED_CONVERT_EXPR, + FIX_TRUNC_EXPR, FLOAT_EXPR, NEGATE_EXPR, ABS_EXPR, MAX_EXPR, MIN_EXPR, + BIT_NOT_EXPR, TRUTH_AND_EXPR, BIT_AND_EXPR, TRUTH_OR_EXPR, + BIT_IOR_EXPR, TRUTH_XOR_EXPR, BIT_XOR_EXPR, LROTATE_EXPR, RROTATE_EXPR, + LSHIFT_EXPR, RSHIFT_EXPR, LT_EXPR, LE_EXPR, GT_EXPR, GE_EXPR, EQ_EXPR, + NE_EXPR, UNORDERED_EXPR, ORDERED_EXPR, UNLT_EXPR, UNLE_EXPR, UNGT_EXPR, + UNGE_EXPR, UNEQ_EXPR, LTGT_EXPR, TRUTH_NOT_EXPR, COMPLEX_EXPR, + WIDEN_SUM_EXPR, REDUC_MAX_EXPR, REDUC_MIN_EXPR, REDUC_PLUS_EXPR, + VEC_EXTRACT_EVEN_EXPR, VEC_EXTRACT_ODD_EXPR, VEC_INTERLEAVE_HIGH_EXPR, + VEC_INTERLEAVE_LOW_EXPR, VEC_LSHIFT_EXPR, VEC_RSHIFT_EXPR, + VEC_UNPACK_HI_EXPR, VEC_UNPACK_LO_EXPR, VEC_UNPACK_FLOAT_HI_EXPR, + VEC_UNPACK_FLOAT_LO_EXPR, VEC_WIDEN_MULT_HI_EXPR, + VEC_WIDEN_MULT_LO_EXPR, VEC_PACK_TRUNC_EXPR, VEC_PACK_SAT_EXPR, + VEC_PACK_FIX_TRUNC_EXPR. + (<case PAREN_EXPR>): Call set_mem_attributes() with type, not the + full expression. + +2009-08-27 Richard Guenther <rguenther@suse.de> + + * gengtype.c (main): Handle uint64_t. + * ipa-utils.c (get_base_var): Indent properly. + * tree-ssa-live.c (debug_scope_block): New function. + * tree-flow.h (debug_scope_block): Declare. + * tree-ssa-copy.c (replace_exp_1): Add vertical space. + * basic-block.h (enum profile_status): Rename to + enum profile_status_d. + (x_profile_status): Adjust type. + +2009-08-27 Dodji Seketeli <dodji@redhat.com> + + PR debug/41170 + * dwarf2out.c (get_context_die): Declare this static function. + (gen_type_die_with_usage): Make sure a DIE is a generated for + the context of a typedef. + +2009-08-26 Anatoly Sokolov <aesok@post.ru> + + * doc/invoke.texi (AVR Options): Remove documentation of -minit-stack + switch. + +2009-08-26 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips-protos.h (mips_output_sync): Declare. + (mips_sync_loop_insns): Likewise. + (mips_output_sync_loop): Replace first two parameters with an rtx. + * config/mips/mips.c (mips_multi_member): New structure. + (mips_multi_members): New variable. + (mips_multi_start): New function. + (mips_multi_add): Likewise. + (mips_multi_add_insn): Likewise. + (mips_multi_add_label): Likewise. + (mips_multi_last_index): Likewise. + (mips_multi_copy_insn): Likewise. + (mips_multi_set_operand): Likewise. + (mips_multi_write): Likewise. + (mips_print_operand_punctuation): Remove '%|' and '%-'. + (mips_init_print_operand_punct): Update accordingly. + (mips_start_ll_sc_sync_block): New function. + (mips_end_ll_sc_sync_block): Likewise. + (mips_output_sync): Likewise. + (mips_sync_insn1_template): Likewise. + (mips_sync_insn2_template): Likewise. + (mips_get_sync_operand): Likewise. + (mips_process_sync_loop): Likewise. + (mips_output_sync_loop): Use mips_process_sync_loop. + (mips_sync_loop_insns): New function. + * config/mips/mips.h (MIPS_COMPARE_AND_SWAP): Delete. + (MIPS_COMPARE_AND_SWAP_12): Likewise. + (MIPS_COMPARE_AND_SWAP_12_ZERO_OP): Likewise. + (MIPS_COMPARE_AND_SWAP_12_NONZERO_OP): Likewise. + (MIPS_SYNC_OP, MIPS_SYNC_OP_12): Likewise. + (MIPS_SYNC_OP_12_AND, MIPS_SYNC_OP_12_XOR): Likewise. + (MIPS_SYNC_OLD_OP_12): Likewise. + (MIPS_SYNC_OLD_OP_12_AND, MIPS_SYNC_OLD_OP_12_XOR): Likewise. + (MIPS_SYNC_NEW_OP_12): Likewise. + (MIPS_SYNC_NEW_OP_12_AND, MIPS_SYNC_NEW_OP_12_XOR): Likewise. + (MIPS_SYNC_OLD_OP, MIPS_SYNC_NEW_OP): Likewise. + (MIPS_SYNC_NAND, MIPS_SYNC_OLD_NAND, MIPS_SYNC_NEW_NAND): Likewise. + (MIPS_SYNC_EXCHANGE, MIPS_SYNC_EXCHANGE_12): Likewise. + (MIPS_SYNC_EXCHANGE_12_ZERO_OP): Likewise. + (MIPS_SYNC_EXCHANGE_12_NONZER_OP): Likewise. + * config/mips/mips.md (sync_mem): New attribute. + (sync_oldval, sync_newval, sync_inclusive_mask): Likewise. + (sync_exclusive_mask, sync_required_oldval): Likewise. + (sync_insn1_op2, sync_insn1, sync_insn2): Likewise. + (sync_release_barrier): Likewise. + (length): Handle sync loops. + (sync): Use mips_output_sync. + * config/mips/sync.md (*memory_barrier): Use mips_output_sync. + (sync_compare_and_swap<mode>): Set the new sync_* attributes + and use mips_output_sync_loop. + (compare_and_swap_12, sync_add<mode>, sync_<optab>_12): Likewise. + (sync_old_<optab>_12, sync_new_<optab>_12, sync_nand_12): Likewise. + (sync_old_nand_12, sync_new_nand_12, sync_sub<mode>): Likewise. + (sync_old_add<mode>, sync_old_sub<mode>): Likewise. + (sync_new_add<mode>, sync_new_sub<mode>): Likewise. + (sync_<optab><mode>, sync_old_<optab><mode>): Likewise. + (sync_new_<optab><mode>, sync_nand<mode>): Likewise. + (sync_old_nand<mode>, sync_new_nand<mode>): Likewise. + (sync_lock_test_and_set<mode>, test_and_set_12): Likewise. + +2009-08-26 Richard Guenther <rguenther@suse.de> + + PR middle-end/41163 + * gimplify.c (gimplify_addr_expr): Canonicalize ADDR_EXPRs if + the types to not match. + * tree-cfg.c (verify_gimple_assign_single): Adjust ADDR_EXPR + verification. + * tree-ssa.c (useless_type_conversion_p): Conversions to + pointers to unprototyped functions are useless. + +2009-08-26 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (create_variable_info_for): Remove strange + whole-program condition, prepare to be called for non-globals. + (intra_create_variable_infos): For restrict qualified DECL_BY_REFERENCE + params build a representative with known type and track its fields. + +2009-08-26 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/sync.md: Update comment about unpredictable LL/SC lock + clearing by a taken branch. + (sync_<fetchop_name><mode>): Split when epilogue_completed is set, + effectively after bbro pass. + (sync_nand<mode>): Ditto. + (sync_old_<fetchop_name><mode>): Ditto. + (sync_old_nand<mode>): Ditto. + (sync_new_<fetchop_name><mode>): Dito. + (sync_new_nand<mode>): Ditto. + (sync_compare_and_swap<mode>_1): Ditto. + (*sync_compare_and_swap<mode>): Ditto. + (sync_lock_test_and_set<mode>_1): Ditto. + ("sync_lock_test_and_set<mode>): Ditto. + +2009-08-25 Douglas B Rupp <rupp@gnat.com> + + * hwint.h (HOST_LONG_FORMAT): New macro + * bitmap.c, c-decl.c, mips-tfile.c, print-rtl.c, print-tree.c: + Use HOST_PTR_PRINTF. + * system.h (HOST_PTR_PRINTF): Resurrect old macro + * doc/hostconfig.texi (HOST_LONG_FORMAT): Document. + (HOST_PTR_PRINTF): Document. + +2009-08-25 Jan Hubicka <jh@suse.cz> + + * config/i386/bmmintrin.h: Replace by #error. + + Revert: + Michael Meissner <michael.meissner@amd.com> + Dwarakanath Rajagopal <dwarak.rajagopal@amd.com> + Tony Linthicum <tony.linthicum@amd.com> + + * config/i386/i386.h (TARGET_SSE5): New macro for SSE5. + (TARGET_ROUND): New macro for the round/ptest instructions which + are shared between SSE4.1 and SSE5. + (OPTION_MASK_ISA_ROUND): Ditto. + (OPTION_ISA_ROUND): Ditto. + (TARGET_FUSED_MADD): New macro for -mfused-madd swtich. + (TARGET_CPU_CPP_BUILTINS): Add SSE5 support. + + * config/i386/i386.opt (-msse5): New switch for SSE5 support. + (-mfused-madd): New switch to give users control over whether the + compiler optimizes to use the multiply/add SSE5 instructions. + + * config/i386/i386.c (enum pta_flags): Add PTA_SSE5. + (ix86_handle_option): Turn off 3dnow if -msse5. + (override_options): Add SSE5 support. + (print_operand): %Y prints comparison codes for SSE5 com/pcom + instructions. + (ix86_expand_sse_movcc): Add SSE5 support. + (ix86_expand_sse5_unpack): New function to use pperm to unpack a + vector type to the next largest size. + (ix86_expand_sse5_pack): New function to use pperm to pack a + vector type to the next smallest size. + (IX86_BUILTIN_FMADDSS): New for SSE5 intrinsic. + (IX86_BUILTIN_FMADDSD): Ditto. + (IX86_BUILTIN_FMADDPS): Ditto. + (IX86_BUILTIN_FMADDPD): Ditto. + (IX86_BUILTIN_FMSUBSS): Ditto. + (IX86_BUILTIN_FMSUBSD): Ditto. + (IX86_BUILTIN_FMSUBPS): Ditto. + (IX86_BUILTIN_FMSUBPD): Ditto. + (IX86_BUILTIN_FNMADDSS): Ditto. + (IX86_BUILTIN_FNMADDSD): Ditto. + (IX86_BUILTIN_FNMADDPS): Ditto. + (IX86_BUILTIN_FNMADDPD): Ditto. + (IX86_BUILTIN_FNMSUBSS): Ditto. + (IX86_BUILTIN_FNMSUBSD): Ditto. + (IX86_BUILTIN_FNMSUBPS): Ditto. + (IX86_BUILTIN_FNMSUBPD): Ditto. + (IX86_BUILTIN_PCMOV_V2DI): Ditto. + (IX86_BUILTIN_PCMOV_V4SI): Ditto. + (IX86_BUILTIN_PCMOV_V8HI): Ditto. + (IX86_BUILTIN_PCMOV_V16QI): Ditto. + (IX86_BUILTIN_PCMOV_V4SF): Ditto. + (IX86_BUILTIN_PCMOV_V2DF): Ditto. + (IX86_BUILTIN_PPERM): Ditto. + (IX86_BUILTIN_PERMPS): Ditto. + (IX86_BUILTIN_PERMPD): Ditto. + (IX86_BUILTIN_PMACSSWW): Ditto. + (IX86_BUILTIN_PMACSWW): Ditto. + (IX86_BUILTIN_PMACSSWD): Ditto. + (IX86_BUILTIN_PMACSWD): Ditto. + (IX86_BUILTIN_PMACSSDD): Ditto. + (IX86_BUILTIN_PMACSDD): Ditto. + (IX86_BUILTIN_PMACSSDQL): Ditto. + (IX86_BUILTIN_PMACSSDQH): Ditto. + (IX86_BUILTIN_PMACSDQL): Ditto. + (IX86_BUILTIN_PMACSDQH): Ditto. + (IX86_BUILTIN_PMADCSSWD): Ditto. + (IX86_BUILTIN_PMADCSWD): Ditto. + (IX86_BUILTIN_PHADDBW): Ditto. + (IX86_BUILTIN_PHADDBD): Ditto. + (IX86_BUILTIN_PHADDBQ): Ditto. + (IX86_BUILTIN_PHADDWD): Ditto. + (IX86_BUILTIN_PHADDWQ): Ditto. + (IX86_BUILTIN_PHADDDQ): Ditto. + (IX86_BUILTIN_PHADDUBW): Ditto. + (IX86_BUILTIN_PHADDUBD): Ditto. + (IX86_BUILTIN_PHADDUBQ): Ditto. + (IX86_BUILTIN_PHADDUWD): Ditto. + (IX86_BUILTIN_PHADDUWQ): Ditto. + (IX86_BUILTIN_PHADDUDQ): Ditto. + (IX86_BUILTIN_PHSUBBW): Ditto. + (IX86_BUILTIN_PHSUBWD): Ditto. + (IX86_BUILTIN_PHSUBDQ): Ditto. + (IX86_BUILTIN_PROTB): Ditto. + (IX86_BUILTIN_PROTW): Ditto. + (IX86_BUILTIN_PROTD): Ditto. + (IX86_BUILTIN_PROTQ): Ditto. + (IX86_BUILTIN_PROTB_IMM): Ditto. + (IX86_BUILTIN_PROTW_IMM): Ditto. + (IX86_BUILTIN_PROTD_IMM): Ditto. + (IX86_BUILTIN_PROTQ_IMM): Ditto. + (IX86_BUILTIN_PSHLB): Ditto. + (IX86_BUILTIN_PSHLW): Ditto. + (IX86_BUILTIN_PSHLD): Ditto. + (IX86_BUILTIN_PSHLQ): Ditto. + (IX86_BUILTIN_PSHAB): Ditto. + (IX86_BUILTIN_PSHAW): Ditto. + (IX86_BUILTIN_PSHAD): Ditto. + (IX86_BUILTIN_PSHAQ): Ditto. + (IX86_BUILTIN_FRCZSS): Ditto. + (IX86_BUILTIN_FRCZSD): Ditto. + (IX86_BUILTIN_FRCZPS): Ditto. + (IX86_BUILTIN_FRCZPD): Ditto. + (IX86_BUILTIN_CVTPH2PS): Ditto. + (IX86_BUILTIN_CVTPS2PH): Ditto. + (IX86_BUILTIN_COMEQSS): Ditto. + (IX86_BUILTIN_COMNESS): Ditto. + (IX86_BUILTIN_COMLTSS): Ditto. + (IX86_BUILTIN_COMLESS): Ditto. + (IX86_BUILTIN_COMGTSS): Ditto. + (IX86_BUILTIN_COMGESS): Ditto. + (IX86_BUILTIN_COMUEQSS): Ditto. + (IX86_BUILTIN_COMUNESS): Ditto. + (IX86_BUILTIN_COMULTSS): Ditto. + (IX86_BUILTIN_COMULESS): Ditto. + (IX86_BUILTIN_COMUGTSS): Ditto. + (IX86_BUILTIN_COMUGESS): Ditto. + (IX86_BUILTIN_COMORDSS): Ditto. + (IX86_BUILTIN_COMUNORDSS): Ditto. + (IX86_BUILTIN_COMFALSESS): Ditto. + (IX86_BUILTIN_COMTRUESS): Ditto. + (IX86_BUILTIN_COMEQSD): Ditto. + (IX86_BUILTIN_COMNESD): Ditto. + (IX86_BUILTIN_COMLTSD): Ditto. + (IX86_BUILTIN_COMLESD): Ditto. + (IX86_BUILTIN_COMGTSD): Ditto. + (IX86_BUILTIN_COMGESD): Ditto. + (IX86_BUILTIN_COMUEQSD): Ditto. + (IX86_BUILTIN_COMUNESD): Ditto. + (IX86_BUILTIN_COMULTSD): Ditto. + (IX86_BUILTIN_COMULESD): Ditto. + (IX86_BUILTIN_COMUGTSD): Ditto. + (IX86_BUILTIN_COMUGESD): Ditto. + (IX86_BUILTIN_COMORDSD): Ditto. + (IX86_BUILTIN_COMUNORDSD): Ditto. + (IX86_BUILTIN_COMFALSESD): Ditto. + (IX86_BUILTIN_COMTRUESD): Ditto. + (IX86_BUILTIN_COMEQPS): Ditto. + (IX86_BUILTIN_COMNEPS): Ditto. + (IX86_BUILTIN_COMLTPS): Ditto. + (IX86_BUILTIN_COMLEPS): Ditto. + (IX86_BUILTIN_COMGTPS): Ditto. + (IX86_BUILTIN_COMGEPS): Ditto. + (IX86_BUILTIN_COMUEQPS): Ditto. + (IX86_BUILTIN_COMUNEPS): Ditto. + (IX86_BUILTIN_COMULTPS): Ditto. + (IX86_BUILTIN_COMULEPS): Ditto. + (IX86_BUILTIN_COMUGTPS): Ditto. + (IX86_BUILTIN_COMUGEPS): Ditto. + (IX86_BUILTIN_COMORDPS): Ditto. + (IX86_BUILTIN_COMUNORDPS): Ditto. + (IX86_BUILTIN_COMFALSEPS): Ditto. + (IX86_BUILTIN_COMTRUEPS): Ditto. + (IX86_BUILTIN_COMEQPD): Ditto. + (IX86_BUILTIN_COMNEPD): Ditto. + (IX86_BUILTIN_COMLTPD): Ditto. + (IX86_BUILTIN_COMLEPD): Ditto. + (IX86_BUILTIN_COMGTPD): Ditto. + (IX86_BUILTIN_COMGEPD): Ditto. + (IX86_BUILTIN_COMUEQPD): Ditto. + (IX86_BUILTIN_COMUNEPD): Ditto. + (IX86_BUILTIN_COMULTPD): Ditto. + (IX86_BUILTIN_COMULEPD): Ditto. + (IX86_BUILTIN_COMUGTPD): Ditto. + (IX86_BUILTIN_COMUGEPD): Ditto. + (IX86_BUILTIN_COMORDPD): Ditto. + (IX86_BUILTIN_COMUNORDPD): Ditto. + (IX86_BUILTIN_COMFALSEPD): Ditto. + (IX86_BUILTIN_COMTRUEPD): Ditto. + (IX86_BUILTIN_PCOMEQUB): Ditto. + (IX86_BUILTIN_PCOMNEUB): Ditto. + (IX86_BUILTIN_PCOMLTUB): Ditto. + (IX86_BUILTIN_PCOMLEUB): Ditto. + (IX86_BUILTIN_PCOMGTUB): Ditto. + (IX86_BUILTIN_PCOMGEUB): Ditto. + (IX86_BUILTIN_PCOMFALSEUB): Ditto. + (IX86_BUILTIN_PCOMTRUEUB): Ditto. + (IX86_BUILTIN_PCOMEQUW): Ditto. + (IX86_BUILTIN_PCOMNEUW): Ditto. + (IX86_BUILTIN_PCOMLTUW): Ditto. + (IX86_BUILTIN_PCOMLEUW): Ditto. + (IX86_BUILTIN_PCOMGTUW): Ditto. + (IX86_BUILTIN_PCOMGEUW): Ditto. + (IX86_BUILTIN_PCOMFALSEUW): Ditto. + (IX86_BUILTIN_PCOMTRUEUW): Ditto. + (IX86_BUILTIN_PCOMEQUD): Ditto. + (IX86_BUILTIN_PCOMNEUD): Ditto. + (IX86_BUILTIN_PCOMLTUD): Ditto. + (IX86_BUILTIN_PCOMLEUD): Ditto. + (IX86_BUILTIN_PCOMGTUD): Ditto. + (IX86_BUILTIN_PCOMGEUD): Ditto. + (IX86_BUILTIN_PCOMFALSEUD): Ditto. + (IX86_BUILTIN_PCOMTRUEUD): Ditto. + (IX86_BUILTIN_PCOMEQUQ): Ditto. + (IX86_BUILTIN_PCOMNEUQ): Ditto. + (IX86_BUILTIN_PCOMLTUQ): Ditto. + (IX86_BUILTIN_PCOMLEUQ): Ditto. + (IX86_BUILTIN_PCOMGTUQ): Ditto. + (IX86_BUILTIN_PCOMGEUQ): Ditto. + (IX86_BUILTIN_PCOMFALSEUQ): Ditto. + (IX86_BUILTIN_PCOMTRUEUQ): Ditto. + (IX86_BUILTIN_PCOMEQB): Ditto. + (IX86_BUILTIN_PCOMNEB): Ditto. + (IX86_BUILTIN_PCOMLTB): Ditto. + (IX86_BUILTIN_PCOMLEB): Ditto. + (IX86_BUILTIN_PCOMGTB): Ditto. + (IX86_BUILTIN_PCOMGEB): Ditto. + (IX86_BUILTIN_PCOMFALSEB): Ditto. + (IX86_BUILTIN_PCOMTRUEB): Ditto. + (IX86_BUILTIN_PCOMEQW): Ditto. + (IX86_BUILTIN_PCOMNEW): Ditto. + (IX86_BUILTIN_PCOMLTW): Ditto. + (IX86_BUILTIN_PCOMLEW): Ditto. + (IX86_BUILTIN_PCOMGTW): Ditto. + (IX86_BUILTIN_PCOMGEW): Ditto. + (IX86_BUILTIN_PCOMFALSEW): Ditto. + (IX86_BUILTIN_PCOMTRUEW): Ditto. + (IX86_BUILTIN_PCOMEQD): Ditto. + (IX86_BUILTIN_PCOMNED): Ditto. + (IX86_BUILTIN_PCOMLTD): Ditto. + (IX86_BUILTIN_PCOMLED): Ditto. + (IX86_BUILTIN_PCOMGTD): Ditto. + (IX86_BUILTIN_PCOMGED): Ditto. + (IX86_BUILTIN_PCOMFALSED): Ditto. + (IX86_BUILTIN_PCOMTRUED): Ditto. + (IX86_BUILTIN_PCOMEQQ): Ditto. + (IX86_BUILTIN_PCOMNEQ): Ditto. + (IX86_BUILTIN_PCOMLTQ): Ditto. + (IX86_BUILTIN_PCOMLEQ): Ditto. + (IX86_BUILTIN_PCOMGTQ): Ditto. + (IX86_BUILTIN_PCOMGEQ): Ditto. + (IX86_BUILTIN_PCOMFALSEQ): Ditto. + (IX86_BUILTIN_PCOMTRUEQ): Ditto. + (enum multi_arg_type): New enum for describing the various SSE5 + intrinsic argument types. + (bdesc_multi_arg): New table for SSE5 intrinsics. + (ix86_init_mmx_sse_builtins): Add SSE5 intrinsic support. + (ix86_expand_multi_arg_builtin): New function for creating SSE5 + intrinsics. + (ix86_expand_builtin): Add SSE5 intrinsic support. + (ix86_sse5_valid_op_p): New function to validate SSE5 3 and 4 + operand instructions. + (ix86_expand_sse5_multiple_memory): New function to split the + second memory reference from SSE5 instructions. + (type_has_variadic_args_p): Delete in favor of stdarg_p. + (ix86_return_pops_args): Use stdarg_p to determine if the function + has variable arguments. + (ix86_setup_incoming_varargs): Ditto. + (x86_this_parameter): Ditto. + + * config/i386/i386-protos.h (ix86_expand_sse5_unpack): Add + declaration. + (ix86_expand_sse5_pack): Ditto. + (ix86_sse5_valid_op_p): Ditto. + (ix86_expand_sse5_multiple_memory): Ditto. + + * config/i386/i386.md (UNSPEC_SSE5_INTRINSIC): Add new UNSPEC + constant for SSE5 support. + (UNSPEC_SSE5_UNSIGNED_CMP): Ditto. + (UNSPEC_SSE5_TRUEFALSE): Ditto. + (UNSPEC_SSE5_PERMUTE): Ditto. + (UNSPEC_SSE5_ASHIFT): Ditto. + (UNSPEC_SSE5_LSHIFT): Ditto. + (UNSPEC_FRCZ): Ditto. + (UNSPEC_CVTPH2PS): Ditto. + (UNSPEC_CVTPS2PH): Ditto. + (PCOM_FALSE): Add new constant for true/false SSE5 comparisons. + (PCOM_TRUE): Ditto. + (COM_FALSE_S): Ditto. + (COM_FALSE_P): Ditto. + (COM_TRUE_S): Ditto. + (COM_TRUE_P): Ditto. + (type attribute): Add ssemuladd, sseiadd1, ssecvt1, sse4arg types. + (unit attribute): Add support for ssemuladd, ssecvt1, sseiadd1 sse4arg + types. + (memory attribute): Ditto. + (sse4_1_round<mode>2): Use TARGET_ROUND instead of TARGET_SSE4_1. + Use SSE4_1_ROUND_* constants instead of hard coded numbers. + (rint<mode>2): Use TARGET_ROUND instead of TARGET_SSE4_1. + (floor<mode>2): Ditto. + (ceil<mode>2): Ditto. + (btrunc<mode>2): Ditto. + (nearbyintdf2): Ditto. + (nearbyintsf2): Ditto. + (sse_setccsf): Disable if SSE5. + (sse_setccdf): Ditto. + (sse5_setcc<mode>): New support for SSE5 conditional move. + (sse5_pcmov_<mode>): Ditto. + + * config/i386/sse.md (SSEMODE1248): New mode iterator for SSE5. + (SSEMODEF4): Ditto. + (SSEMODEF2P): Ditto. + (ssemodesuffixf4): New mode attribute for SSE5. + (ssemodesuffixf2s): Ditto. + (ssemodesuffixf2c): Ditto. + (sserotatemax): Ditto. + (ssescalarmode): Ditto. + (sse_maskcmpv4sf3): Disable if SSE5. + (sse_maskcmpv2df3): Ditto. + (sse_vmmaskcmpv4sf3): Ditto. + (sse5_fmadd<mode>4): Add SSE5 floating point multiply/add instructions. + (sse5_vmfmadd<mode>4): Ditto. + (sse5_fmsub<mode>4): Ditto. + (sse5_vmfmsub<mode>4): Ditto. + (sse5_fnmadd<mode>4): Ditto. + (sse5_vmfnmadd<mode>4): Ditto. + (sse5_fnmsub<mode>4): Ditto. + (sse5_vmfnmsub<mode>4): Ditto. + (sse5i_fmadd<mode>4): Ditto. + (sse5i_fmsub<mode>4): Ditto. + (sse5i_fnmadd<mode>4): Ditto. + (sse5i_fnmsub<mode>4): Ditto. + (sse5i_vmfmadd<mode>4): Ditto. + (sse5i_vmfmsub<mode>4): Ditto. + (sse5i_vmfnmadd<mode>4): Ditto. + (sse5i_vmfnmsub<mode>4): Ditto. + (mulv16qi3): Add SSE5 support. + (mulv4si3): Ditto. + (sse5_mulv4si3): New insn for 32-bit multiply support on SSE5. + (sse2_mulv4si3): Disable if SSE5. + (sse4_1_roundpd): Use TARGET_ROUND instead of TARGET_SSE4_1. + (sse4_1_roundps): Ditto. + (sse4_1_roundsd): Ditto. + (sse4_1_roundss): Ditto. + (sse_maskcmpv4sf3): Disable if SSE5 so the SSE5 instruction will + be generated. + (sse_maskcmpsf3): Ditto. + (sse_vmmaskcmpv4sf3): Ditto. + (sse2_maskcmpv2df3): Ditto. + (sse2_maskcmpdf3): Ditto. + (sse2_vmmaskcmpv2df3): Ditto. + (sse2_eq<mode>3): Ditto. + (sse2_gt<mode>3): Ditto. + (sse5_pcmov_<mode>): Add SSE5 support. + (vec_unpacku_hi_v16qi): Ditto. + (vec_unpacks_hi_v16qi): Ditto. + (vec_unpacku_lo_v16qi): Ditto. + (vec_unpacks_lo_v16qi): Ditto. + (vec_unpacku_hi_v8hi): Ditto. + (vec_unpacks_hi_v8hi): Ditto. + (vec_unpacku_lo_v8hi): Ditto. + (vec_unpacks_lo_v8hi): Ditto. + (vec_unpacku_hi_v4si): Ditto. + (vec_unpacks_hi_v4si): Ditto. + (vec_unpacku_lo_v4si): Ditto. + (vec_unpacks_lo_v4si): Ditto. + (sse5_pmacsww): New SSE5 intrinsic insn. + (sse5_pmacssww): Ditto. + (sse5_pmacsdd): Ditto. + (sse5_pmacssdd): Ditto. + (sse5_pmacssdql): Ditto. + (sse5_pmacssdqh): Ditto. + (sse5_pmacsdqh): Ditto. + (sse5_pmacsswd): Ditto. + (sse5_pmacswd): Ditto. + (sse5_pmadcsswd): Ditto. + (sse5_pmadcswd): Ditto. + (sse5_pcmov_<move>): Conditional move support on SSE5. + (sse5_phaddbw): New SSE5 intrinsic insn. + (sse5_phaddbd): Ditto. + (sse5_phaddbq): Ditto. + (sse5_phaddwd): Ditto. + (sse5_phaddwq): Ditto. + (sse5_phadddq): Ditto. + (sse5_phaddubw): Ditto. + (sse5_phaddubd): Ditto. + (sse5_phaddubq): Ditto. + (sse5_phadduwd): Ditto. + (sse5_phadduwq): Ditto. + (sse5_phaddudq): Ditto. + (sse5_phsubbw): Ditto. + (sse5_phsubwd): Ditto. + (sse5_phsubdq): Ditto. + (sse5_pperm): Ditto. + (sse5_pperm_sign_v16qi_v8hi): New insns for pack/unpack with SSE5. + (sse5_pperm_zero_v16qi_v8hi): Ditto. + (sse5_pperm_sign_v8hi_v4si): Ditto. + (sse5_pperm_zero_v8hi_v4si): Ditto. + (sse5_pperm_sign_v4si_v2di): Ditto. + (sse5_pperm_sign_v4si_v2di): Ditto. + (sse5_pperm_pack_v2di_v4si): Ditto. + (sse5_pperm_pack_v4si_v8hi): Ditto. + (sse5_pperm_pack_v8hi_v16qi): Ditto. + (sse5_perm<mode>): New SSE5 intrinsic insn. + (rotl<mode>3): Ditto. + (sse5_rotl<mode>3): Ditto. + (sse5_ashl<mode>3): Ditto. + (sse5_lshl<mode>3): Ditto. + (sse5_frcz<mode>2): Ditto. + (sse5s_frcz<mode>2): Ditto. + (sse5_cvtph2ps): Ditto. + (sse5_cvtps2ph): Ditto. + (sse5_vmmaskcmp<mode>3): Ditto. + (sse5_com_tf<mode>3): Ditto. + (sse5_maskcmp<mode>3): Ditto. + (sse5_maskcmp_uns<mode>3): Ditto. + (sse5_maskcmp_uns2<mode>3): Ditto. + (sse5_pcom_tf<mode>3): Ditto. + + * config/i386/predicates.md (sse5_comparison_float_operator): + New predicate to match the comparison operators supported by + the SSE5 com instruction. + (ix86_comparison_int_operator): New predicate to match just the + signed int comparisons. + (ix86_comparison_uns_operator): New predicate to match just the + unsigned int comparisons. + + * doc/invoke.texi (-msse5): Add documentation. + (-mfused-madd): Ditto. + + * doc/extend.texi (x86 intrinsics): Document new SSE5 intrinsics. + + * config.gcc (i[34567]86-*-*): Include bmmintrin.h and + mmintrin-common.h. + (x86_64-*-*): Ditto. + + * config/i386/cpuid.h (bit_SSE5): Define SSE5 bit. + + * config/i386/bmmintrin.h: New file, provide common x86 compiler + intrinisics for SSE5. + + * config/i386/smmintrin.h: Move instructions shared with SSE5 to + mmintrin-common.h. + + * config/i386/mmintrin-common.h: New file, to contain common + instructions between SSE4.1 and SSE5. + + * config/i386/netware.c (gen_stdcall_or_fastcall_decoration): Use + FOREACH_FUNCTION_ARGS to iterate over the argument list. + (gen_regparm_prefix): Ditto. + + * config/i386/winnt.c (gen_stdcall_or_fastcall_suffix): Use + FOREACH_FUNCTION_ARGS to iterate over the argument list. Use + prototype_p to determine if a function is prototyped. + +2009-08-25 Ville Voutilainen <ville.voutilainen@gmail.com> + + * c-common.c (c_common_reswords) add the alignof keyword, + with same RID as __alignof and __alignof__ + +2009-08-25 Anatoly Sokolov <aesok@post.ru> + + * hooks.h (hook_bool_const_int_const_int_true): Declare. + * hooks.c (hook_bool_const_int_const_int_true): New function. + * target.h (struct gcc_target): Add can_eliminate field. + * target-def.h (TARGET_CAN_ELIMINATE): Define. + (TARGET_INITIALIZER): Use TARGET_CAN_ELIMINATE. + * ira.c (setup_eliminable_regset): Use can_eliminate target hook. + * reload1.c (update_eliminables, init_elim_table): (Ditto.). + (elim_table): Revise comment. + * system.h (CAN_ELIMINATE): Poison. + * defaults.h (CAN_ELIMINATE): Remove. + * doc/tm.texi (CAN_ELIMINATE): Revise documentation. + + * config/alpha/vms.h (CAN_ELIMINATE): Remove macro. + * config/alpha/alpha.c (TARGET_CAN_ELIMINATE) [TARGET_ABI_OPEN_VMS]: + Define macro. + (alpha_vms_can_eliminate): Declare as static, change return type to + bool. + * config/alpha/alpha-protos.h (alpha_vms_can_eliminate): Remove. + + * config/arm/arm.h (CAN_ELIMINATE): Remove macro. + * config/arm/arm.c (TARGET_CAN_ELIMINATE): Define macro. + (arm_can_eliminate): New function. + + * config/avr/avr.h (CAN_ELIMINATE): Remove macro. + * config/avr/avr.c (TARGET_CAN_ELIMINATE): Define macro. + (avr_can_eliminate): Declare as static. + * config/avr/avr-protos.h (avr_can_eliminate): Remove. + + * config/bfin/bfin.h (CAN_ELIMINATE): Remove macro. + * config/bfin/bfin.c (TARGET_CAN_ELIMINATE): Define macro. + (bfin_can_eliminate): New function. + + * config/crx/crx.h (CAN_ELIMINATE): Remove macro. + * config/crx/crx.c (TARGET_CAN_ELIMINATE): Define macro. + (crx_can_eliminate): New function. + + * config/fr30/fr30.h (CAN_ELIMINATE): Remove macro. + * config/fr30/fr30.c (TARGET_CAN_ELIMINATE): Define macro. + (fr30_can_eliminate): New function. + + * config/frv/frv.h (CAN_ELIMINATE): Remove macro. + * config/frv/frv.c (TARGET_CAN_ELIMINATE): Define macro. + (frv_can_eliminate): New function. + + * config/h8300/h8300.h (CAN_ELIMINATE): Remove macro. + * config/h8300/h8300.c (TARGET_CAN_ELIMINATE): Define macro. + (h8300_can_eliminate): New function. + + * config/i386/i386.h (CAN_ELIMINATE): Remove macro. + * config/i386/i386.c (TARGET_CAN_ELIMINATE): Define macro. + (i386_can_eliminate): Declare as static, change return type to bool. + * config/i386/i386-protos.h (i386_can_eliminate): Remove. + + * config/ia64/ia64.h (CAN_ELIMINATE): Remove macro. + * config/ia64/ia64.c (TARGET_CAN_ELIMINATE): Define macro. + (ia64_can_eliminate): New function. + + * config/iq2000/iq2000.h (CAN_ELIMINATE): Remove macro. + * config/iq2000/iq2000.c (TARGET_CAN_ELIMINATE): Define macro. + (iq2000_can_eliminate): New function. + + * config/m32r/m32r.h (CAN_ELIMINATE): Remove macro. + * config/m32r/m32r.c (TARGET_CAN_ELIMINATE): Define macro. + (m32r_can_eliminate): New function. + + * config/m68hc11/m68hc11.h (CAN_ELIMINATE): Remove macro. + * config/m68hc11/m68hc11.c (TARGET_CAN_ELIMINATE): Define macro. + (m68hc11_can_eliminate): New function. + + * config/m68k/m68k.h (CAN_ELIMINATE): Remove macro. + * config/m68k/m68k.c (TARGET_CAN_ELIMINATE): Define macro. + (m68k_can_eliminate): New function. + + * config/mep/mep.h (CAN_ELIMINATE): Remove macro. + * config/mep/mep.c (TARGET_CAN_ELIMINATE): Define macro. + (mep_can_eliminate): New function. + + * config/mips/mips.h (CAN_ELIMINATE): Remove macro. + * config/mips/mips.c (TARGET_CAN_ELIMINATE): Define macro. + (mips_can_eliminate): New function. + + * config/rs6000/rs6000.h (CAN_ELIMINATE): Remove macro. + * config/rs6000/rs6000.c (TARGET_CAN_ELIMINATE): Define macro. + (rs6000_can_eliminate): New function. + + * config/s390/s390.h (CAN_ELIMINATE): Remove macro. + * config/s390/s390.c (TARGET_CAN_ELIMINATE): Define macro. + (s390_can_eliminate): Declare as static. + * config/s390/s390-protos.h (sparc_can_eliminate): Remove. + + * config/score/score.h (CAN_ELIMINATE): Remove macro. + * config/score/score.c (TARGET_CAN_ELIMINATE): Define macro. + (score_can_eliminate): New function. + + * config/sparc/sparc.h (CAN_ELIMINATE): Remove macro. + * config/sparc/sparc.c (TARGET_CAN_ELIMINATE): Define macro. + (sparc_can_eliminate): Declare as static. + * config/sparc/sparc-protos.h (sparc_can_eliminate): Remove. + + * config/stormy16/stormy16.h (CAN_ELIMINATE): Remove macro. + * config/stormy16/stormy16.c (TARGET_CAN_ELIMINATE): Define macro. + (xstormy16_can_eliminate): New function. + + * config/v850/v850.h (CAN_ELIMINATE): Remove macro. + * config/v850/v850.c (TARGET_CAN_ELIMINATE): Define macro. + (v850_can_eliminate): New function. + +2009-08-25 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.md (*cmpdf_ieee_ext[123]): Remove. + (*cmpdf_internal): Enable for all ALPHA_FPTM levels. + (*movdfcc_ext[1234]): Disable for IEEE mode. + +2009-08-25 Eric Botcazou <ebotcazou@adacore.com> + + * gimplify.c (prepare_gimple_addressable): New static function. + (gimplify_modify_expr_to_memcpy): Invoke it on the RHS before marking + it addressable. + (gimplify_addr_expr): Invoke it similarly on the operand instead of + manually fiddling with it. + +2009-08-25 Michael Matz <matz@suse.de> + + * expr.h (jumpifnot_1, jumpif_1, do_jump_1): Declare. + * dojump.c (do_jump_by_parts_greater): Take two operands instead of + full expression. + (do_jump_by_parts_equality, do_compare_and_jump): Ditto. + (jumpifnot_1, jumpif_1): New wrappers for do_jump_1. + (do_jump): Split out code for simple binary comparisons into ... + (do_jump_1): ... this, taking the individual operands and code. + Change callers to helper function above accordingly. + * expr.c (expand_expr_real_1): Use jumpifnot_1 for simple binary + comparisons. + +2009-08-25 Michael Matz <matz@suse.de> + + * expr.h (struct separate_ops, sepops): New type for passing + around an exploded simple expression. + * optabs.c (expand_widen_pattern_expr, expand_vec_shift_expr): + Use this structure instead of expression tree. + (get_vcond_icode, expand_vec_cond_expr_p): Don't take whole + expression, only its type. + (expand_vec_cond_expr): Take type and individual operands instead + of full expression. + * optabs.h (expand_widen_pattern_expr, expand_vec_cond_expr, + expand_vec_shift_expr): Change prototype accordingly. + * tree-vect-stmts.c (vectorizable_condition): Change call of + expand_vec_cond_expr_p to pass only type. + * expr.c (do_store_flags): Change prototype and implementation + to take an exploded expression. + (expand_expr_real_1): New local ops initialized with details + of the full expression. Use it instead of full + expression in calls to do_store_flags, expand_vec_cond_expr, + expand_widen_pattern_expr and expand_vec_shift_expr. + +2009-08-25 Michael Matz <matz@suse.de> + + * expr.c (expand_expr_real_1): New local treeop0, treeop1, + treeop2 initialized with first three operands of the full expression. + Substitute all TREE_OPERAND (exp, [012]) calls with them. + +2009-08-25 Kai Tietz <kai.tietz@onevision.com> + + * gcc/gthr-win32.h (__UNUSED_PARAM): Define, if not already present. + (__gthread_objc_condition_allocate): Mark arguments as unused. + (__gthread_objc_condition_deallocate): Likewise. + (__gthread_objc_condition_wait): Likewise. + (__gthread_objc_condition_broadcast): Likewise. + (__gthread_objc_condition_signal): Likewise. + (__gthread_objc_thread_detach): Cast via INT_PTR to pointer. + (__gthread_objc_thread_id): Likewise. + +2009-08-25 Janus Weil <janus@gcc.gnu.org> + + PR middle-end/41149 + * tree-pretty-print.c (print_call_name): Print the correct call name + for procedure pointer components. + +2009-08-24 Steve Ellcey <sje@cup.hp.com> + + * config/ia64/ia64.c (ia64_promote_function_mode): Call + default_promote_function_mode when not VMS. + +2009-08-24 Olivier Hainque <hainque@adacore.com> + + * convert.c (convert_to_integer): Don't assume an input pointer is + POINTER_SIZE wide. Fetch from the type instead. + +2009-08-24 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * configure.ac (AC_PREREQ): Bump to 2.64. + +2009-08-24 Rafael Avila de Espindola <espindola@google.com> + + * gcc.c (standard_exec_prefix_1,standard_exec_prefix_2): Remove. + (process_command): Don't search standard_exec_prefix_1 and + standard_exec_prefix_2. + +2009-08-24 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (output_return_instruction): Handle for + unified syntax. + +2009-08-24 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (arm_select_cc_mode): Handle subreg. + +2009-08-24 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/vfp.md (*arm_movdi_vfp): Mark as predicable. + (*arm_movdf_vfp): Likewise. + +2009-08-24 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/neon.md (vashl<mode>3): Rename from ashl<mode>3. + (vashr<mode>3): Rename from ashr<mode>3. + (vlshr<mode>3): Rename from lshr<mode>3. + +2009-08-24 Kai Tietz <kai.tietz@onevision.com> + + PR/40786 + * c-format.c (format_wanted_type): Add new member scalar_identity_flag. + (check_format_info_main): Use scalar_identify_flag. + (check_format_types): Check for scalar size identity if + scalar_identify_flag is set. + (printf_length_specs): Extend by new field. + (asm_fprintf_length_specs): Likewise. + (gcc_diag_length_specs): Likewise. + (scanf_length_specs): Likewise. + (strfmon_length_specs): Likewise. + (gcc_gfc_length_specs): Likewise. + * config/i386/msformat-c.c (ms_printf_length_specs): Likewise. + (ms_printf_flag_specs): Likewise. + * c-format.h (format_length_info): Add new member scalar_identity_flag. + +2009-08-23 Uros Bizjak <ubizjak@gmail.com> + + PR target/40718 + * config/i386/i386.c (*call_pop_1): Disable for sibling calls. + (*call_value_pop_1): Ditto. + (*sibcall_pop_1): New insn pattern. + (*sibcall_value_pop_1): Ditto. + +2009-08-23 Alan Modra <amodra@bigpond.net.au> + + PR target/41081 + * config/rs6000/rs6000.md (rotlsi3_64, ashlsi3_64, lshrsi3_64, + ashrsi3_64): New. + +2009-08-23 Alan Modra <amodra@bigpond.net.au> + + PR target/41081 + * fwprop.c (try_fwprop_subst): Allow multiple sets. + (get_reg_use_in): New function. + (forward_propagate_subreg): Propagate through subreg of zero_extend + or sign_extend. + +2009-08-22 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/t-sh (TARGET_LIBGCC2_CFLAGS): Define. + * config/sh/t-netbsd (TARGET_LIBGCC2_CFLAGS): Add -mieee. + +2009-08-22 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * configure.ac: Remove --with-datarootdir, --with-docdir, + --with-htmldir switches. No need to call AC_SUBST for + datarootdir, docdir, htmldir any more. + * configure: Regenerate. + * doc/install.texi (Configuration): Document --datarootdir, + --docdir, --htmldir, --pdfdir; update documentation for + --infodir, --mandir. + (Prerequisites): Bump Autoconf version to 2.64, Automake to 1.11, + M4 to 1.4.6. + + * aclocal.m4: Regenerate. + * config.in: Regenerate. + * configure: Regenerate. + +2009-08-21 Douglas B Rupp <rupp@gnat.com> + Olivier Hainque <hainque@adacore.com> + + * config/ia64/ia64.c: Include libfuncs.h. + (TARGET_PROMOTE_FUNCITON_MODE): Define target macro. + (ia64_expand_call): Use reg 25 on VMS. + (ia64_initialize_trampoline): Fix for VMS ABI. + (ia64_function_arg_offset): Always returns 0 when TARGET_ABI_OPEN_VMS. + (ia64_function_arg): Initialize reg 25 on VMS. + Fix OpenVMS ABI issues for varargs. + For OpenVMS, emit the Argument Information register set in the + incoming/sibcall case as well. + (ia64_arg_type): New function. + (ia64_function_arg_advance): Keep track of cum->words. + Fix OpenVMS ABI issues for varargs. + (ia64_function_value): On VMS, promote mode of non-aggregate types. + (ia64_override_options): Set flag_no_common on VMS. + (ia64_init_builtins): Disable FWRITE builtin. + (ia64_asm_output_external): Call DO_CRTL_NAMES. + (ia64_vms_init_libfuncs): Add decc$ routines. + (ia64_vms_valid_pointer_mode): New function. + (ia64_struct_value_rtx): Allways NULL_RTX on VMS. + (ia64_promote_function_mode): New function + * config/ia64/ia64.h (TARGET_ABI_OPEN_VMS): Define as 0 for default. + (LONG_DOUBLE_TYPE_SIZE): Force to 64 on VMS. + (LIBCGC2_LONG_DOUBLE_TYPE_SIZE): Likewise. + (INIT_CUMULATIVE_ARGS): Add atypes for VMS. + (INIT_CUMULATIVE_INCOMING_ARGS): Likewise. + (ASM_OUTPUT_DEF): Use ISDIGIT instead of isdigit. + Suppress trailing '#' if VALUE is numeric. + * config/ia64/vms.h (PROMOTE_FUNCTION_MODE): Remove, code moved to + ia64_promote_function_mode. + (TARGET_VALID_POINTER_MODE): Define. + +2009-08-21 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR target/40671 + * config/rs6000/rs6000.c (rs6000_override_options): Use + TARGET_64BIT instead of TARGET_POWERPC64 to set the size of pointers. + + PR target/41145 + * config/rs6000/rs6000.c (rs6000_handle_altivec_attribute): Fix + reporting of vector + decimal/boolean/complex error. + +2009-08-21 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/rs6000.c (rs6000_init_builtins): Fix type of + __vector double TYPE_DECL. + +2009-08-21 Richard Earnshaw <rearnsha@arm.com> + + * arm.h (MACHMODE): New define. Include insn-modes.h if available. + (CUMULATIVE_ARGS): Use MACHMODE for declaration of aapcs_vfp_mode. + * arm.c (aapcs_vfp_is_call_or_return_candidate): Change base_mode + to pointer to enum machine_mode. Update all callers as needed. + +2009-08-21 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.md (exception_receiver): Emit alternative + GP load sequence if flag_reorder_blocks_and_partition is set. + (*exception_receiver_2): Also enable when + flag_reorder_blocks_and_partition is set. + +2009-08-20 Matt Rice <ratmice@gmail.com> + Diego Novillo <dnovillo@google.com> + + * Makefile.in (PLUGIN_HEADERS): Include incpath.h and + tree-ssa-sccvn.h. + +2009-08-20 Richard Guenther <rguenther@suse.de> + + * c-objc-common.h (LANG_HOOKS_DUP_LANG_SPECIFIC_DECL): Do not define. + * c-tree.h (c_dup_lang_specific_decl): Remove. + (struct lang_decl, struct lang_type): Move definitions ... + * c-lang.h: ... here. New file. + * c-decl.c: Include c-lang.h. + (c_dup_lang_specific_decl): Remove. + * c-typeck.c: Include c-lang.h. + * Makefile.in (c-decl.o): Add c-lang.h dependency. + (c-typeck.o): Likewise. + * c-config-lang.in (gtfiles): Add c-lang.h. + * gengtype.c (get_output_file_with_visibility): Handle c-lang.h + like c-tree.h. + +2009-08-20 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_end_function): Do not clear + crtl->emit structure and free insn locators if cfun->is_thunk is true, + this is now handled in generic code. + +2009-08-20 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/s390.c (Z10_PREDICT_DISTANCE): New macro. + (s390_z10_fix_long_loop_prediction): New function. + (s390_z10_optimize_cmp): INSN walk moved to callee - s390_reorg. + (s390_reorg): Walk over the INSNs and invoke + s390_z10_fix_long_loop_prediction and s390_z10_optimize_cmp. + +2009-08-20 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/s390.md ("*brx_stage1_<GPR:mode>", "*brxg_64bit", + "*brx_64bit", "*brx_31bit"): New patterns. + * config/s390/s390.c ('E'): New output modifier. + +2009-08-20 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + Richard Earnshaw <richard.earnshaw@arm.com> + + * config/arm/arm.c (arm_emit_movpair): Handle CONST_INT. + * config/arm/arm.md (*arm_movtas_ze): New pattern for movt. + +2009-08-19 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa.md (reload_inhi, reload_outhi, reload_inqi, reload_outqi): New + patterns. + * pa.c (emit_move_sequence): Check if address of operand1 is valid + for mode mode of operand0 when doing secondary reload for SAR. + +2009-08-19 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/41123 + * expr.c (expand_expr_real_1) <normal_inner_ref>: Handle all kinds + of CONCAT, not just bitpos 0 bitsize size of the whole CONCAT. + +2009-08-19 Jason Merrill <jason@redhat.com> + + * doc/invoke.texi (C++ Dialect Options): Note change of minimum + supported template depth in C++0x. + +2009-08-19 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Don't call + free_after_compilation. + * config/score/score7.c (score7_output_mi_thunk): Likewise. + * config/score/score3.c (score3_output_mi_thunk): Likewise. + * config/ia64/ia64.c (ia64_output_mi_thunk): Likewise. + * config/mips/mips.c (mips_output_mi_thunk): Likewise. + * config/sh/sh.c (sh_output_mi_thunk): Likewise. + * config/m68k/m68k.c (m68k_output_mi_thunk): Likewise. + * config/sparc/sparc.c (sparc_output_mi_thunk): Likewise. + +2009-08-19 Ian Lance Taylor <iant@google.com> + + * doc/md.texi (Insn Canonicalizations): Correct canonicalization + of (plus (mult (neg B) C) A). + +2009-08-18 Michael Matz <matz@suse.de> + + * omp-low.c (optimize_omp_library_calls): Use types_compatible_p + instead of comparing TYPE_MAIN_VARIANT for equality. + * tree-vect-patterns.c (vect_recog_dot_prod_pattern, + vect_recog_widen_mult_pattern, vect_recog_widen_sum_pattern): Ditto. + * tree-vect-loop.c (vect_is_simple_reduction): Ditto. + * gimplify.c (goa_lhs_expr_p): Ditto and use + STRIP_USELESS_TYPE_CONVERSION. + +2009-08-18 Michael Matz <matz@suse.de> + + * tree-ssa-structalias.c (create_variable_info_for): Also mark + first field in a struct. + (intra_create_variable_infos): Don't deal with flag_argument_noalias. + +2009-08-18 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_output_mi_thunk_osf): Allocate insn + locators before emit_insn is called. Remove assert that + cfun->is_thunk. + (alpha_end_function): Clear crtl->emit structure and free insn + locators if cfun->is_thunk is true. + +2009-08-18 Jason Merrill <jason@redhat.com> + + * config/elfos.h (ASM_DECLARE_OBJECT_NAME): Use gnu_unique_object + type if available. + * configure.ac: Test for it. + * configure, config.in: Regenerate. + * doc/install.texi: Document --enable-gnu-unique-object. + +2009-08-18 Richard Guenther <rguenther@suse.de> + + PR middle-end/41094 + * builtins.c (fold_builtin_pow): Fold pow(pow(x,y),z) to + pow(x,y*z) only if x is nonnegative. + +2009-08-18 Jakub Jelinek <jakub@redhat.com> + + * bb-reorder.c (fix_up_fall_thru_edges): Only call invert_jump + on jumps. + + PR target/40971 + * config/rs6000/rs6000.c (rs6000_legitimize_address): For + [DT][FDI]mode ensure the offset isn't 4/8/12 bytes below 0x8000. + +2009-08-17 DJ Delorie <dj@redhat.com> + + * config/m32c/m32c.md (UNS_FSETB, UNS_FREIT): New. + * config/m32c/prologue.md (epilogue_freit): New. + (fset_b): New. + * config/m32c/m32c.c (m32c_function_needs_enter): Add prototype. + (bank_switch_p): Likewise. + (fast_interrupt_p): Likewise. + (interrupt_p): Likewise. + (m32c_conditional_register_usage): Round memregs size up. + (need_to_save): We only need to save $a0 when we use ENTER. + (interrupt_p): Check for fast_interrupt too. + (bank_switch_p): New. + (fast_interrupt_p): New. + (m32c_attribute_table): Add bank_switch and fast_interrupt. + (m32c_emit_prolog): Support bank switching and fast interrupts. + * doc/extend.texi (Function Attributes): Add bank_switch and + fast_interrupt. + +2009-08-17 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (vms_valid_pointer_mode): New function. + * config/alpha/vms.h (TARGET_VALID_POINTER_MODE): Define. + +2009-08-16 Douglas B Rupp <rupp@gnat.com> + + * doc/invoke.texi (Target options): Add new option list for IA-64/VMS. + (menu): Add IA-64/VMS Options. + (IA-64/VMS Options): Likewise. + +2009-08-16 Richard Sandiford <rdsandiford@googlemail.com> + + PR target/38599 + * config/mips/mips.md (*lwxs): Use :P for pointer values. + +2009-08-16 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips-protos.h (mips_push_asm_switch): New function. + (mips_pop_asm_switch): Likewise. + * config/mips/mips.c (set_noreorder, set_nomacro, set_noat): Replace + with... + (mips_noreorder, mips_nomacro, mips_noat): ...these new variables. + (mips_push_asm_switch_1, mips_pop_asm_switch_1): New functions. + (mips_push_asm_switch, mips_pop_asm_switch): Likewise. + (mips_print_operand_punctuation): Use them. Check mips_noreorder + instead of set_noreorder. + (mips_output_function_prologue): Use the new functions. + (mips_output_function_epilogue): Likewise. + (mips_need_noat_wrapper_p): New function, split out from... + (mips_final_prescan_insn, mips_final_postscan_insn): ...here. + Use mips_push_asm_switch and mips_pop_asm_switch. + * config/mips/mips.h (FUNCTION_PROFILER): Use mips_push_asm_switch + and mips_pop_asm_switch. + (ASM_OUTPUT_REG_POP): Likewise. + (DBR_OUTPUT_SEQEND): Remove boilerplate comment. + Use mips_pop_asm_switch. + (mips_asm_switch): New structure. + (set_noreorder, set_nomacro): Replace with... + (mips_noreorder, mips_nomacro, mips_noat): ...these new variables. + * config/mips/mips.md (fix_truncdfsi2_macro): Use mips_nomacro + instead of set_nomacro. + (fix_truncsfsi2_macro): Likewise. + (cprestore): Likewise. + (hazard): Use mips_noreorder instead of set_noreorder. + * config/mips/sdemtk.h (FUNCTION_PROFILER): As for mips.h. + +2009-08-16 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_end_function): Handle NULL_RTX returned + from prev_active_insn. + +2009-08-16 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.h (AVR_HAVE_8BIT_SP): New macros. + * config/avr/avr.c (avr_override_options): Initialize + avr_current_arch variable. + (avr_cpu_cpp_builtins): Define __AVR_HAVE_8BIT_SP__ or + __AVR_HAVE_16BIT_SP__ according to the device type. + (expand_prologue, output_movhi): Use AVR_HAVE_8BIT_SP instead of + TARGET_TINY_STACK. + (expand_epilogue): Use correct QI mode frame pointer for tiny stack. + Use AVR_HAVE_8BIT_SP instead of TARGET_TINY_STACK. + +2009-08-16 Dodji Seketeli <dodji@redhat.com> + + PR debug/37801 + * gcc/dwarf2out.c (gen_inlined_subroutine_die): Concentrate on + generating inlined subroutine die only. We shouldn't be + called for anything else. + (gen_block_die): Don't generate inline subroutine debug info for + abstract blocks. + +2009-08-15 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-poly.c (print_pbb): Print PBB index. + +2009-08-15 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/40981 + * graphite-interchange.c (ppl_max_for_le): Moved... + * graphite-poly.c (pbb_number_of_iterations): Call ppl_max_for_le. + * graphite-ppl.c (ppl_max_for_le): ... here. Correct the use of + ppl_Pointset_Powerset_C_Polyhedron_maximize. + * graphite-ppl.h (ppl_max_for_le): Declared. + +2009-08-14 Olatunji Ruwase <tjruwase@google.com> + + * doc/extend.texi (Symbol-Renaming Pragmas): redefine_extname is + supported on all platforms. + * target.h (struct gcc_target): Remove handle_pragma_redefine_extname. + * c-cppbuiltin.c: Remove use of targetm.handle_pragma_redefine_extname. + * c-pragma.c: Likewise. + * target-def.h (TARGET_INITIALIZER): Remove + TARGET_HANDLE_PRAGMA_REDEFINE_EXTNAME. + * config/sol2.h: Remove use of TARGET_HANDLE_PRAGMA_REDEFINE_EXTNAME. + +2009-08-14 Douglas B Rupp <rupp@gnat.com> + + * config/ia64/fde-vms.c: New file. + * config/ia64/fde-glibc.c (_Unwind_FindTableEntry): Add dummy arg. + * config/ia64/unwind-ia64.c (UNW_ accessors): Move to unwind-ia64.h + (MD_UNW_COMPATIBLE_PERSONALITY_P): Provide default. + (uw_frame_state_for): Only register a personality routine if it is + known to be compatible with our expectations. + (_Unwind_FindEnclosingFunction, uw_frame_state_for): + Declare unw_table_entry stack variable and + mod all calls to _Unwind_FindTableEntry to add arg. + * config/ia64/unwind-ia64.h (UNW_ accessors): Move here. + (_Unwind_FindTableEntry): Add arg to prototype. + +2009-08-14 Eric Botcazou <ebotcazou@adacore.com> + + * config/ia64/unwind-ia64.c (struct _Unwind_Context): Add new + field 'signal_pfs_loc'. + (uw_frame_state_for): Remove duplicate code dealing with leaf + procedures without unwind info. + If in the frame after unwinding through a signal handler, restore + the AR.PFS register instead of the CFM if AR.PFS has not been saved. + * config/ia64/linux-unwind.h (ia64_fallback_frame_state): Do not set + 'pfs_loc' to the AR.PFS location in the signal context; instead + set 'signal_pfs_loc'. + Manually generate the unwind info for the AR.PFS register. + (ABI_MARKER_OLD_LINUX_SIGTRAMP, ABI_MARKER_OLD_LINUX_INTERRUPT, + ABI_MARKER_LINUX_SIGTRAMP, ABI_MARKER_LINUX_INTERRUPT): Define. + (ia64_handle_unwabi): Test 'fs->unwabi' against them. + Do not set 'pfs_loc' to the AR.PFS location in the signal context; + instead set 'signal_pfs_loc'. + Remove code preventing the AR.PFS register from being restored + from the signal context. + +2009-08-14 Douglas B Rupp <rupp@gnat.com> + Tristan Gingold <gingold@adacore.com> + + * config.gcc (ia64-hp-*vms*): Insert ia64/t-ia64 in tmake_file. + * config/ia64/t-vms: New file. + * config/ia64/vms64.h: New file. + * config/ia64/vms.h: New file. + * config/ia64/vms-crtinit.asm: New file. + * config/ia64/vms_symvec_libgcc_s.opt: New file. + * config/ia64/vms-unwind.h: New file. + +2009-08-14 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_emit_conditional_move): Handle + TFmode compares. + +2009-08-14 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + PR middle-end/30789 + * builtins.c (do_mpc_arg2): Make extern, define for any MPC version. + Move declaration... + * real.h (do_mpc_arg2): ... here. + * fold-const.c (const_binop): Use MPC for complex MULT_EXPR + and RDIV_EXPR. + +2009-08-14 Rafael Avila de Espindola <espindola@google.com> + + * final.c (add_debug_prefix_map): Don't use GC memory for + old_prefix and new_prefix. + +2009-08-14 Richard Guenther <rguenther@suse.de> + + * ipa-prop.c (compute_complex_pass_through): If we cannot + compute a non-varying offset for IPA_JF_ANCESTOR punt. + +2009-08-14 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * c-lex.c (c_lex_with_flags): Increase size of local variable + to avoid memory clobber. + +2009-08-14 Paolo Bonzini <bonzini@gnu.org> + + PR target/40934 + * config/i386/i386.c (ix86_fp_comparison_strategy): + Only enable/disable sahf at function granularity. + +2009-08-14 Hans-Peter Nilsson <hp@axis.com> + + PR rtl-optimization/41064 + * reload1.c (reload_as_needed): Don't call extract_insn + for known invalid replacements after calling + validate_replace_rtx_group and verify_changes. + +2009-08-14 Uros Bizjak <ubizjak@gmail.com> + + PR target/41019 + * config/i386/sse.md (SSEMODE124C8): New mode iterator. + (vcond<SSEMODEF2P:mode>): Assert that operation is supported by + ix86_expand_fp_vcond. + (vcond<SSEMODE124C8:mode>): Use SSEMODE124C8 instead of SSEMODE124. + Assert that operation is supported by ix86_expand_int_vcond. + (vcondu<SSEMODE124C8:mode>): Ditto. + +2009-08-13 DJ Delorie <dj@redhat.com> + + * config/i386/djgpp-stdint.h: New. + * config.gcc (djgpp): Use it. + +2009-08-13 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (sh_override_options): When flag_exceptions or + flag_unwind_tables is on, turn flag_reorder_blocks_and_partition off. + +2009-08-13 Ghassan Shobaki <ghassan.shobaki@amd.com> + + * tree-ssa-loop-prefetch.c + (prune_ref_by_group_reuse): Enhance probabilistic analysis + for long-stride pruning. + (compute_miss_rate): New function to compute the probability + that two memory references access different cache lines. + +2009-08-13 Dave Korn <dave.korn.cygwin@gmail.com> + + * gcc/config/i386/cygwin.h (LINK_SPEC): Add --enable-auto-image-base. + +2009-08-13 Richard Guenther <rguenther@suse.de> + + PR middle-end/41047 + * tree-ssa-ccp.c (ccp_fold): When folding pointer additions + use the constant pointer type. + * gimplify.c (canonicalize_addr_expr): Canonicalize independent + of CV qualifiers on the target pointer type. + * tree-ssa.c (useless_type_conversion_p): Move incomplete pointer + conversion check before restrict check. + +2009-08-12 Kaz Kojima <kkojima@gcc.gnu.org> + + PR target/41029 + * config/sh/sh.md (reload_outdf__RnFRm+4): Fix thinko. + +2009-08-12 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (sh_promote_function_mode): Add ATTRIBUTE_UNUSED. + +2009-08-12 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41011 + * ipa-cp.c (ipcp_lattice_from_jfunc): Deal with failing fold + and reference constructing. + +2009-08-12 Xinliang David Li <davidxl@google.com> + + PR tree-optimization/41012 + * tree-flow.h : New external interface. + * gimple-low.c (check_call_arg): Change to public function. + Remove argument mismatch check in lowering. + * tree-inline.h (tree_can_inline_p): Interface change. + * tree-inline.c (tree_can_inline_p): Fold argument mismatch check + into this function. + * ipa-inline.c (cgraph_decide_inlining_of_small_functions): + Call change to tree_can_inline_p function. + (cgraph_decide_inlining_incrementally): Ditto. + +2009-08-12 Richard Sandiford <rdsandiford@googlemail.com> + + PR tree-optimization/41031 + * tree-outof-ssa.c (insert_value_copy_on_edge): Use promote_decl_mode + on the partition variable rather than promote_mode on the source + type. Assert that the partition variable's type has the same + mode as the source value's. + +2009-08-12 Paolo Bonzini <bonzini@gnu.org> + + * doc/tm.texi (TARGET_PROMOTE_FUNCTION_MODE): Add documentation + for for_return == 2. + * function.c (assign_parm_setup_reg): Use for_return == 2, improve + comments. + * calls.c (expand_call): Fix typo. + * explow.c (promote_decl_mode): Use for_return == 2 for RESULT_DECL + and PARM_DECL. + * stmt.c (expand_value_return): Use promote_function_mode to copy out + of pseudo. + * targhooks.c (default_promote_function_mode): Handle for_return == 2. + * config/cris/cris.c (cris_promote_function_mode): Likewise. + * config/mmix/mmix.c (mmix_promote_function_mode): Likewise. + * config/pa/pa.c (pa_promote_function_mode): Likewise. + +2009-08-12 Andrew Haley <aph@redhat.com> + + * config/arm/arm.c (arm_init_libfuncs): Add __sync_synchronize. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + PR bootstrap/40103 + * graphite.c: Remove pragma GCC diagnostic warning "-Wc++-compat". + +2009-08-12 Richard Guenther <rguenther@suse.de> + + * alias.c (get_alias_set): Honor TYPE_STRUCTURAL_EQUALITY_P. + * gimplify.c (gimplify_modify_expr): Do not use + lang_hooks.types_compatible_p. + * tree-ssa.c (useless_type_conversion_p): For aggregates + just return false if the canonical types differ. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/40980 + * sese.c (convert_for_phi_arg): New. + (add_guard_exit_phis): Use convert_for_phi_arg. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-sese-to-poly.c (pdr_add_data_dimensions): Dont add + unknown subscript upper bounds. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + Pranav Garg <pranav.garg2107@gmail.com> + + * graphite-interchange.c (gather_access_strides): Removed. + (ppl_max_for_le): New. + (build_linearized_memory_access): New. + (memory_stride_in_loop): New. + (pbb_interchange_profitable_p): Reimplemented. + * graphite-ppl.h (ppl_new_id_map): New. + (ppl_interchange): New. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-interchange.c (compute_subscript): Removed. + (compute_array_size_cstr): Removed. + (compute_array_size_poly): Removed. + (compute_array_size): Removed. + (gather_access_strides_poly): Removed. + (gather_access_strides): Empty. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (dependence_polyhedron_1): Replace + pdr_nb_subscripts with PDR_NB_SUBSCRIPTS. + (graphite_legal_transform_dr): Same. + (graphite_carried_dependence_level_k): Same. + * graphite-poly.c (new_poly_dr): Add a parameter nb_subscripts. + Initialize PDR_NB_SUBSCRIPTS. + (print_pdr_access_layout): Replace pdr_nb_subscripts with + PDR_NB_SUBSCRIPTS. + * graphite-poly.h (struct poly_dr): Add nb_subscripts field. + (PDR_NB_SUBSCRIPTS): New. + (pdr_nb_subscripts): Removed. + (pdr_dim): Simplified. + * graphite-sese-to-poly.c (build_poly_dr): Replace pdr_nb_subscripts + with PDR_NB_SUBSCRIPTS. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-interchange.c (compute_array_size): Remove use of + PDR_DATA_CONTAINER. + * graphite-poly.c (new_poly_dr): Remove argument data_container. + Do not initialize PDR_DATA_CONTAINER. + (print_pdr): Do not print PDR_DATA_CONTAINER. + * graphite-poly.h (struct poly_dr): Remove data_container field. + (PDR_DATA_CONTAINER): Removed. + * graphite-sese-to-poly.c (pdr_add_data_dimensions): Remove use of + PDR_DATA_CONTAINER. + (build_poly_dr): Same. + +2009-08-12 Konrad Trifunovic <konrad.trifunovic@gmail.com> + Sebastian Pop <sebastian.pop@amd.com> + + * graphite-dependences.c (graphite_legal_transform_dr): Work on a + copy of the dependence polyhedron. Free the temporary objects. + (graphite_carried_dependence_level_k): Free unused objects before + returning. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-blocking.c (scop_do_strip_mine): Call store_scattering. + Early return without analyzing the data dependences if no + transform has been done. Call restore_scattering if the transform + is not legal. + (graphite-interchange.c): Same. + * graphite-poly.c (print_scattering_function): Test for + PBB_TRANSFORMED. + (graphite_read_transforms): Initialize PBB_TRANSFORMED. + (apply_poly_transforms): Do not gcc_assert that + the transform is legal. + (new_poly_bb): Initialize PBB_TRANSFORMED, PBB_SAVED and PBB_ORIGINAL. + Do not initialize PBB_NB_SCATTERING_TRANSFORM, PBB_NB_LOCAL_VARIABLES, + PBB_TRANSFORMED_SCATTERING, and PBB_ORIGINAL_SCATTERING. + (free_poly_dr): Free PBB_TRANSFORMED, PBB_SAVED, and PBB_ORIGINAL. + * graphite-poly.h (struct poly_scattering): New. + (struct poly_bb): Add original, transformed, and saved fields. + Remove transformed_scattering, original_scattering, + nb_local_variables and nb_scattering_transform fields. + (PBB_ORIGINAL, PBB_TRANSFORMED, PBB_SAVED): New. + (poly_scattering_new): New. + (poly_scattering_free): New. + (poly_scattering_copy): New. + (store_scattering_pbb): New. + (store_scattering): New. + (restore_scattering_pbb): New. + (restore_scattering): New. + * graphite-sese-to-poly.c (build_pbb_scattering_polyhedrons): + Initialize PBB_TRANSFORMED and PBB_ORIGINAL. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-poly.c (print_pbb): Add parentheses in the pretty print. + (print_scop): Same. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * Makefile.in (graphite.o): Depends on PREDICT_H. + * graphite.c: Include predict.h. + (graphite_finalize): Call tree_estimate_probability. + * predict.c (predict_loops): Do not call scev_initialize and + scev_finalize. + (tree_estimate_probability_bb): New. + (tree_estimate_probability): Do not initialize loops: move that + code to the driver. Call tree_estimate_probability_bb. + (tree_estimate_probability_driver): New. + (pass_profile): Use tree_estimate_probability_driver. + * predict.h (tree_estimate_probability): Declared. + +2009-08-12 Sebastian Pop <sebastian.pop@amd.com> + + * graphite-clast-to-gimple.c (gloog): Add time to TV_GRAPHITE_CODE_GEN. + * graphite-dependences.c (graphite_legal_transform): Add time to + TV_GRAPHITE_DATA_DEPS. + (dependency_between_pbbs_p): Same. + * timevar.def (TV_GRAPHITE_DATA_DEPS, TV_GRAPHITE_CODE_GEN): New. + +2009-08-12 Andrey Belevantsev <abel@ispras.ru> + + PR rtl-optimization/41033 + * alias.c (nonoverlapping_component_refs_p): Punt when strict + aliasing is disabled. + +2009-08-11 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/predicates.md (qi_mask_operand, hi_mask_operand, + si_mask_operand, and_load_operand, low_bitmask_operand, + and_reg_operand, and_operand): New predicates. + * config/mips/constraints.md (Yb, Yh, Yw, Yz): New constraints. + * config/mips/mips.c (and_operands_ok): New function. + * config/mips/mips-protos.h (and_operands_ok): Declare it. + * config/mips/mips.md (move_type): Add ext_ins and logical. + (type): Handle them. + (and<mode>3): Use and_reg_operand as the second operand's predicate. + (*and<mode>3): Add alternatives for lbu, lhu, lwu, <d>ext and + shift_shift. Remove commutative constraint modifier. + (*and<mode>3_mips16): Add alternatives for lbu, lhu, lwu and + shift_shift. + (*clear_upper32_dext): Remove define_insn_and_split. + (*clear_upper32): Turn this define_insn_and_split ... + (splitter for ANDing register with 0xffff_ffff): .. into this. + +2009-08-11 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (try_widen_shift_mode): Factor out code to check if an + integer constant is a low-order bitmask from here ... + * rtlanal.c (low_bitmask_len): ... to here. + * rtl.h (low_bitmask_len): Declare. + +2009-08-11 Uros Bizjak <ubizjak@gmail.com> + + PR target/8603 + * config/alpha/alpha.md (addsi3): Remove expander. + (addsi3): Rename from *addsi3_internal insn pattern. + (subsi3): Remove expander. + (subsi3): Rename from *subsi3_internal insn pattern. + +2009-08-11 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (alpha_init_builtins): Nullify FWRITE and + FWRITE_UNLOCKED. + +2009-08-11 Vasiliy Fofanov <fofanov@adacore.com> + Eric Botcazou <botcazou@adacore.com> + Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (alpha_return_in_memory): On VMS, ensure + that records that fit in 64 bits are returned by immediate value, + as required by OpenVMS Calling Standard. + (function_value): Adjust for above modification. + (alpha_va_start) <TARGET_ABI_OPEN_VMS>: Use + virtual_incoming_args_rtx as base object, not next_arg. + * config/alpha/vms.h (DEFAULT_PCC_STRUCT_RETURN): Define as 0. + +2009-08-11 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * reload.c (find_reloads_subreg_address): Check the original + req_equiv_mem address to detect the case where an address is + not valid in the outer mode. + +2009-08-11 Richard Guenther <rguenther@suse.de> + + PR bootstrap/40788 + * builtins.c (gimplify_va_arg_expr): Do not call SET_EXPR_LOCATION. + +2009-08-10 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/vms.h (OPTIMIZATION_OPTIONS): Remove + (OVERRIDE_OPTIONS): Incorporate removed OPTIMIZATION_OPTIONS. + +2009-08-10 Olivier Hainque <hainqueu@adacore.com> + Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (alpha_sa_size): Force procedure type to + PT_STACK when frame_pointer_needed on OpenVMS. + (alpha_pv_save_size, alpha_using_fp): Remove. + (alpha_vms_can_eliminate): New function. Support for CAN_ELIMINATE + with proper processing for PT_NULL. + (alpha_vms_initial_elimination_offset): New function. Support for + INITIAL_ELIMINATION_OFFSET with proper processing for PT_NULL. + (alpha_sa_size): Force procedure type to PT_STACK when + frame_pointer_needed on OpenVMS. + * config/alpha/alpha-protos.h (alpha_pv_save_size): Remove prototype. + (alpha_using_fp): Likewise. + (alpha_vms_can_eliminate): Add prototype. + (alpha_vms_initial_elimination_offset): Likewise. + * config/alpha/vms.h (CAN_ELIMINATE, INITIAL_ELIMINATION_OFFSET): + Call alpha_vms_can_eliminate and alpha_vms_initial_elimination_offset. + +2009-08-10 Eric Botcazou <botcazou@adacore.com> + Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (common_object_handler): New function. + (vms_attribute_table): Declare a single attribute "common_object". + (vms_output_aligned_decl_common): New global function. + (SECTION_VMS_OVERLAY): Delete. + (SECTION_VMS_GLOBAL): Likewise. + (SECTION_VMS_INITIALIZE): Likewise. + (vms_asm_named_section): Remove support for above flags. + (vms_section_type_flags): Delete. + (TARGET_SECTION_TYPE_FLAGS): Likewise. + * config/alpha/alpha-protos.h (vms_output_aligned_decl_common): New. + * config/alpha/vms.h (ASM_OUTPUT_ALIGNED_COMMON): Delete. + (ASM_OUTPUT_ALIGNED_DECL_COMMON): New macro. + +2009-08-10 SUGIOKA Toshinobu <sugioka@itonet.co.jp> + + PR target/41015 + * longlong.h [__sh__] (udiv_qrnnd): Add T register to clobber list. + (sub_ddmmss): Likewise. + +2009-08-10 Andreas Tobler <a.tobler@schweiz.org> + + PR bootstrap/41018 + * config/rs6000/freebsd.h: Define SVR4_ASM_SPEC. Adjust copyright + year. + +2009-08-10 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + PR target/37053 + * reload1.c (reload_as_needed): Use cancel_changes to completely + undo a failed replacement attempt. + +2009-08-10 Richard Guenther <rguenther@suse.de> + + PR middle-end/41006 + * tree-ssa.c (useless_type_conversion_p_1): Fold into ... + (useless_type_conversion_p): ... here. Require pointer targets + to be compatible. + +2009-08-10 Dodji Seketeli <dodji@redhat.com> + + PR c++/40866 + * tree-inline.c (copy_statement_list): The resulting copy shouldn't + loose the original type of the statement list. + +2009-08-09 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c: Include libfuncs.h + (avms_asm_output_extern): New function. + (alpha_init_libfuncs): Init some decc libfuncs. + * config/alpha/alpha-protos.h (avms_asm_output_external): Declare. + * config/alpha/vms.h (ASM_OUTPUT_EXTERNAL): Define. + (DO_CRTL_NAMES): Define. + (LIB_SPEC): Remove. + * config/alpha/vms64.h (POINTERS_EXTEND_UNSIGNED): Remove undef. + (LONG_TYPE_SIZE): Define. + (TARGET_OS_CPP_BUILTINS): Define with __LONG_POINTERS=1 + (SUBTARGET_SWITCHES): Define malloc64 switch. + (TARGET_DEFAULT): Default MASK_MALLOC64 set. + (MASK_RETURN_ADDR): Define. + doc/invoke.texi (mmalloc64): Document switch. + +2009-08-09 Olivier Hainque <hainque@adacore.com> + Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (struct machine_function): New flag for VMS, + uses_condition_handler. + (alpha_expand_builtin_establish_vms_condition_handler): New expander. + (alpha_expand_builtin_revert_vms_condition_handler): New expander. + (enum alpha_builtin): New ALPHA_BUILTIN_REVERT_VMS_CONDITION_HANDLER + and ALPHA_BUILTIN_ESTABLISH_VMS_CONDITION_HANDLER values. + (code_for_builtin): New insn codes for the new alpha_builtins. + (alpha_init_builtins): Register the new functions as BUILT_IN_MD. + (alpha_sa_size): Account for uses_condition_handler. + (alpha_expand_prologue): Likewise. + (alpha_start_function): Likewise. + (alpha_expand_epilogue): Likewise. + * config/alpha/alpha-protos.h: Prototype the new alpha.c builtin + establish/revert expanders. + * config/alpha/alpha.h (DWARF_FRAME_REGNUM): Define. + * config/alpha/alpha.md (builtin_establish_vms_condition_handler): + New expander, resorting to the alpha.c associated function. + (builtin_revert_vms_condition_handler): Likewise. + * config/alpha/vms-gcc_shell_handler.c: New file. Implements + __gcc_shell_handler, the static VMS condition handler used as + an indirection wrapper to the current dynamically established + handler. + * config/alpha/vms-unwind.h: Complete rewrite. + * config/alpha/t-vms (LIB2FUNCS_EXTRA): Add vms-gcc_shell_handler.c + * config/alpha/vms.h (MD_UNWIND_SUPPORT): + +2009-08-09 Eric Botcazou <botcazou@adacore.com> + Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (alpha_links): Add 'target' field. + (alpha_need_linkage): Handle aliases. Return function symbol. + (alpha_use_linkage): Rename 'linkage' argument to 'func'. + Use ultimate alias target for the linkage name. + * config/alpha/alpha.md (movmemdi): Use the symbol returned + by alpha_need_linkage for the function symbol. + (setmemdi): Likewise. + +2009-08-09 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (TARGET_ASM_UNALIGNED_*_OP): Define if on VMS. + * config/alpha/vms.h (OBJECT_FORMAT_ELF): Define. + (ASM_WEAKEN_LABEL): Define. + (CRT_CALL_STATIC_FUNCTION): Define. + (STARTFILE_SPEC): Add crtbegin.o crtbeginS.o. + (ENDFILE_SPEC): Define. + (INIT_SECTION_ASM_OP): Define. + * config/alpha/vms-dwarf2eh.asm (__EH_FRAME_BEGIN__): Remove. + * config/alpha/t-vms (EXTRA_PARTS): Add crtbegin.o crtbeginS.o + crtend.o crtendS.o. + (MULTILIB_OSDIRNAMES): Define. + (shlib_version): Define. + (SHLIB_EXT): Define. + (SHLIB_OBJS): Define. + (SHLIB_NAME): Define. + (SHLIB_MULTILIB): Define. + (SHLIB_INSTALL): Define. + (SHLIB_SYMVEC): Define. + (SHLIB_SYMVECX2): Define. + (SHLIB_LINK): Define. + +2009-08-09 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (alpha_initialize_trampoline): + Initialize VMS trampoline IAW ABI for bounded procedure calls. + (alpha_start_function): Emit transfer address on nested functions + for VMS trampoline call. + * config/alpha/t-vms (LIB2FUNCS_EXTRA): Remove vms_tramp.asm + since no longer used. + * config/alpha/vms-tramp.asm: Remove. + * config/alpha/vms.h (TRAMPOLINE_TEMPLATE): Leave undefined + since now only data initialized at runtime. + +2009-08-09 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/vms.h (HANDLE_SYSV_PRAGMA): Define. + (LINK_GCC_C_SEQUENCE_SPEC): Define. + (MD_EXEC_PREFIX): Remove, no longer used. + (MD_STARTFILE_PREFIX): Likewise. + (INCLUDE_DEFAULTS): Likewise. + * config/alpha/t-vms: + (vms-dwarf2.o, vms-dwarf2eh.o): Use GCC_FOR_TARGET to compile. + +2009-08-09 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/41016 + * tree-ssa-ifcombine.c (get_name_for_bit_test): Fix tuplification bug. + (operand_precision): Remove. + (integral_operand_p): Likewise. + (recognize_single_bit_test): Adjust. + +2009-08-09 Richard Sandiford <rdsandiford@googlemail.com> + + * c-common.c (c_fully_fold_internal): Issue a warning if a binary + operation overflows. Likewise non-cast unary arithmetic. + If one arm of a conditional expression is always taken, + inhibit evaluation warnings for the other arm. Likewise inhibit + evaluation warnings for the second && or || operand if the first + operand is enough to determine the result. + * c-typeck.c (build_conditional_expr): Apply the same inhibition + rules here. + (build_binary_op): Prevent duplicate evaluation warnings. + +2009-08-09 Richard Sandiford <rdsandiford@googlemail.com> + + * tree-out-of-ssa.c (insert_value_copy_on_edge): If the source + and destination have different modes, Use promote_mode to + determine the signedness of the conversion. Assert that the + promoted source mode matches the destination mode. Don't pass + the destination and destination mode to expand_expr if the source + mode is different. Simplify conversion logic. + +2009-08-09 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/41008 + * tree-vect-loop.c (vect_is_simple_reduction): Get operands + from condition only in case it's a comparison. Adjust checks. + +2009-08-09 Bernd Schmidt <bernd.schmidt@analog.com> + + * tree-dfa.c (renumber_gimple_stmt_uids_in_blocks): New function. + * tree-flow.h (renumber_gimple_stmt_uids_in_blocks): Declare it. + * tree-ssa-loop-ivopts.c (comp_cost): Make COST an integer. + (enum iv_position): Add IP_AFTER_USE and IP_BEFORE_USE. + (dump_cand): Handle them. + (struct iv_cand): New members COST_STEP and AINC_USE. + (stmt_after_increment): Likewise. + (stmt_after_inc_pos): Renamed from stmt_after_ip_original_pos. All + callers changed. Use gimple_uid comparison instead of scanning. + (add_candidate_1): When looking for identical candidates, take + AINC_USE into account. Set it for new candidates. + (force_expr_to_var_cost): Cast target_spill_cost to int. + (get_address_cost): New arguments STMT_AFTER_INC and MAY_AUTOINC. + All callers changed. Check for availability of autoinc addressing + modes, both in general for a given mode, and in the specific use case. + (get_computation_cost_at): New argument CAN_AUTOINC. All callers + changed. + (get_computation_cost): Likewise. + (autoinc_possible_for_pair, set_autoinc_for_original_candidates, + add_autoinc_candidates): New static functions. + (add_candidate): Call add_autoinc_candidates for candidates based on + a USE_ADDRESS use. + (find_iv_candidates): Call set_autoinc_for_original_candidates. + (determine_use_iv_cost_address): If we have an autoinc candidate at + the matching use, verify autoinc is possible and subtract the cost + of the candidate's step from the cost. + (determine_iv_cost): Record the cost of the increment in the COST_STEP + member of the candidate. + (tree_ssa_iv_optimize_loop): Swap the calls to determine_iv_costs and + determine_use_iv_costs. Call renumber_gimple_stmt_uids_in_blocks. + +2009-08-09 Douglas B Rupp <rupp@gnat.com> + + * config.build (ia64-hp-*vms*): New target. + (alpha64-dec-*vms*,alpha*-dec-*vms*): Fix for config/vms and unify + with ia64-hp-*vms*. + * config.gcc (ia64-hp-*vms*): New target. + (alpha64-dec-*vms*,alpha*-dec-*vms*): Fix for config/vms and unify + with ia64-hp-*vms*. + * config.host (ia64-hp-*vms*): New target. + (alpha64-dec-*vms*,alpha*-dec-*vms*): Fix for config/vms and unify + with ia64-hp-*vms*. + +2009-08-08 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40991 + * tree-ssa-pre.c (eliminate): Delay purging EH edges. + +2009-08-08 Richard Sandiford <rdsandiford@googlemail.com> + + * combine.c (gen_lowpart_or_truncate): Exclude CONST_INTs from + mode check. Do truncations in an integer mode. + (force_to_mode): Handle subregs for all mode types. Only do + arithmetic simplifications on integer modes. + +2009-08-07 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40999 + * tree-ssa-ccp.c (get_symbol_constant_value): Handle CONST_DECLs. + (maybe_fold_reference): Lookup constant initializers. + (fold_gimple_assign): Likewise. + +2009-08-07 Richard Guenther <rguenther@suse.de> + + * tree-ssa.c (useless_type_conversion_p_1): Only for types + that require structural equality defer to the langhook. + +2009-08-07 Martin Jambor <mjambor@suse.cz> + + * ipa-prop.h (enum jump_func_type): New value IPA_JF_ANCESTOR, changed + comments. + (struct ipa_pass_through_data): New type. + (struct ipa_ancestor_jf_data): New type. + (union jump_func_value): Removed field formal_id, added fields + pass_through and ancestor. + (struct ipa_param_call_note): Changed type of formal_id to int from + unsigned. + * ipa-prop.c (ipa_print_node_jump_functions): Print pass through with + operations jump functions and ancestor jump functions. + (compute_complex_pass_through): New function. + (compute_scalar_jump_functions): Call compute_complex_pass_through, + reflect changes in the jump function strucutre. + (update_jump_functions_after_inlining): Ignore complex pass-through + and ancestor jump functions. + * ipa-cp.c (ipcp_lattice_from_jfunc): Added support for ancestor and + polynomial pass-through with operation jump functions. + +2009-08-07 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (output_fde): When doing hot/cold partitioning, use + fde->dw_fde_begin as begin label instead of hot/cold label. + Use LLSDAC label instead of LLSDA for second section lsda. + (dwarf2out_do_cfi_startproc): Add SECOND argument. Use LLSDAC + label instead of LLSDA if it is true. + (dwarf2out_begin_prologue, dwarf2out_switch_text_section): Adjust + callers. + * except.c (add_call_site, dw2_size_of_call_site_table): Add + SECTION argument. Use it as index into crtl->eh.call_site_record + array. + (dw2_output_call_site_table): Likewise. Add CS_FORMAT argument, + use it to determine how to print table entries instead of using + #ifdef HAVE_AS_LEB128. For SECTION > 0 use hot resp. cold + label instead of normal begin label as base. + (sjlj_assign_call_site_values): Adjust add_call_site caller. + (convert_to_eh_region_ranges): When doing hot/cold partitioning, + ensure no EH range spans between sections and that landing pads + are always in the corresponding section. + (sjlj_size_of_call_site_table, sjlj_output_call_site_table): Adjust + for crtl->eh.call_site_record being an array rather than scalar. + (output_one_function_exception_table): New function, copied + from output_function_exception_table. Adjust + dw2_size_of_call_site_table, dw2_output_call_site_table + callers. For SECOND section use *C suffixed labels. + (output_function_exception_table): Call + output_one_function_exception_table and, when doing hot/cold + partitioning, also another time for the second section. + * opts.c: Include except.h. + (decode_options): Allow -freorder-blocks-and-partition with + exceptions, unless SJLJ or TARGET_UNWIND_INFO. + * Makefile.in (opts.o): Depend on $(EXCEPT_H). + * function.h (struct rtl_eh): Change call_site_record from + scalar into array of 2 elements. + +2009-08-07 Martin Jambor <mjambor@suse.cz> + + * ipa-prop.c (count_formal_params_1): New function. + (ipa_get_vector_of_formal_parms): New function. + (get_vector_of_formal_parm_types): New function. + (ipa_modify_formal_parameters): New function. + (ipa_modify_call_arguments): New function. + (index_in_adjustments_multiple_times_p): New function. + (ipa_combine_adjustments): New function. + (ipa_dump_param_adjustments): New function. + * ipa-prop.h (struct ipa_parm_adjustment): New type. + (ipa_get_vector_of_formal_parms): Declare. + (ipa_modify_formal_parameters): Declare. + (ipa_modify_call_arguments): Declare. + (ipa_combine_adjustments): Declare. + (ipa_dump_param_adjustments): Declare. + (build_ref_for_offset): Declare. + * Makefile.in (tree-sra.o): Add ipa-prop.h to dependencies. + * tree-sra.c: Include ipa-prop.c. + (build_ref_for_offset): Make public. + +2009-08-06 Neil Vachharajani <nvachhar@gmail.com> + + * value-prof.c (init_pid_map): Replace xmalloc with XCNEWVEC. + +2009-08-06 Thomas Schwinge <tschwinge@gnu.org> + + * gcc/doc/extend.texi (__builtin_extract_return_address) + (__builtin_frob_return_address): Document. + +2009-08-06 Paul Brook <paul@codesourcery.com> + + * config/arm/lib1funcs.asm (ARM_DIV_BODY): Add Thumb-2 implementation. + (udivsi3, aeabi_uidivmod, divsi3, aeabi_idivmod): Only use Thumb-1 + implementation on ARMv6-M. + +2009-08-06 Richard Earnshaw <rearnsha@arm.com> + + * doc/extend.texi (pcs): Document new attribute for ARM. + +2009-08-06 Richard Earnshaw <rearnsha@arm.com> + + * arm.c (pcs_attribute_args): Comment out unsupported attribute + variants. + +2009-08-06 Richard Earnshaw <rearnsha@arm.com> + + * arm.c (arm_handle_pcs_attribute): Pass the entire name object to + warning (). + +2009-08-06 Richard Earnshaw <rearnsha@arm.com> + + * arm.c (arm_handle_pcs_attribute): Use %qE in warning. + +2009-08-06 Richard Earnshaw <rearnsha@arm.com> + + Merge ARM/hard_vfp_branch to trunk. + + 2009-08-04 Richard Earnshaw <rearnsha@arm.com> + + * arm.c (libcall_eq): New function. + (libcall_hash): New function. + (add_libcall): New function. + (arm_libcall_uses_aapcs_base): New function. + (arm_libcall_value): Use arm_libcall_uses_aapcs_base to check for + libcalls using the base PCS. + (arm_init_cumulative_args): Likewise. + + 2009-07-20 Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (arm_libcall_value, arm_init_cumulative_args): + Use base ABI for conversion libfuncs between HFmode and SFmode. + + 2009-05-12 Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (aapcs_vfp_sub_candidate): Use V2SImode and + V4SImode as representatives of all 64-bit and 128-bit vector + types. Allow vector types without vector modes. + (aapcs_vfp_is_call_or_return_candidate): Handle vector types + without vector modes like BLKmode. + (aapcs_vfp_allocate): Handle TImode for non-TARGET_NEON like + BLKmode. Avoid unsupported vector modes or TImode moves for + non-TARGET_NEON. + (aapcs_vfp_allocate_return_reg): Likewise. + (arm_vector_mode_supported_p): Only support V2SImode, V4HImode and + V8QImode if TARGET_NEON || TARGET_IWMMXT. + + 2009-05-12 Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (arm_handle_pcs_attribute): New. + (arm_get_pcs_model): Pass attribute arguments to + arm_pcs_from_attribute. + (arm_init_cumulative_args): Use base AAPCS for conversions from + floating-point types to DImode. + (arm_attribute_table): Add pcs attribute. + (arm_handle_pcs_attribute): New. + * config/arm/bpabi.h (DECLARE_LIBRARY_RENAMES): When renaming + conversions from floating-point types to DImode, also declare them + to use base AAPCS and declare functions they call to use base + AAPCS and their RTABI names. + + 2009-05-12 Joseph Myers <joseph@codesourcery.com> + + * doc/invoke.texi (-mfloat-abi=@var{name}): Remove statement about + -mfloat-abi=hard not being supported for VFP. + + 2009-05-11 Kazu Hirata <kazu@codesourcery.com> + + * config/sparc/sparc.c (sparc_emit_float_lib_cmp): Pass a libcall + SYMBOL_REF to hard_libcall_value. + + 2009-03-05 Joseph Myers <joseph@codesourcery.com> + Richard Earnshaw <rearnsha@arm.com> + + * config/arm/arm.c (aapcs_layout_arg): Once a co-processor argument + has been put on the stack, all remaining co-processory arguments for + that co-processor also go on the stack. + + 2009-03-05 Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (arm_return_in_memory): Handle returning + vectors of suitable size in registers also for AAPCS case. + + 2009-01-13 Richard Earnshaw <rearnsha@arm.com> + + * doc/tm.texi (TARGET_LIBCALL_VALUE): Add missing end statement. + + 2008-12-09 Richard Earnshaw <rearnsha@arm.com> + + ARM Hard-VFP calling convention + * target-def.h (TARGET_LIBCALL_VALUE): New hook. + * target.h (gcc_target): Add libcall_value to table of call hooks. + * targhooks.h (default_libcall_value): Default implementation. + * targhooks.c (default_libcall_value): Likewise. + * doc/tm.texi (TARGET_LIBCALL_VALUE): Document it. + * optabs.c (expand_unop): Use it. + * expr.h (hard_libcall_value): Pass the function RTX through. + * calls.c (emit_library_call_value_1): Update call to + hard_libcall_value. + * explow.c (hard_libcall_value): Use new target hook. + * config/arm/arm.c: Include cgraph.h + (TARGET_FUNCTION_VALUE): Override default hook. + (arm_pcs_default): New variable. + (arm_override_options): Don't fault hard calling convention with VFP. + Add support for AAPCS variants. + (arm_function_value): Make static. Handle AAPCS variants. + (arm_libcall_value): New function. + (arm_apply_result_size): Handle VFP registers in results. + (arm_return_in_memory): Rework all AAPCS variants; handle hard-vfp + conventions. + (pcs_attribute_args): New variable. + (arm_pcs_from_attribute): New function. + (arm_get_pcs_model): New function. + (aapcs_vfp_cum_init): New function. + (aapcs_vfp_sub_candidate): New function. + (aapcs_vfp_is_return_candidate): New function. + (aapcs_vfp_is_call_candidate): New function. + (aapcs_vfp_allocate): New function. + (aapcs_vfp_allocate_return_reg): New function. + (aapcs_vfp_advance): New function. + (aapcs_cp_arg_layout): New variable. + (aapcs_select_call_coproc): New function. + (aapcs_select_return_coproc): New function. + (aapcs_allocate_return_reg): New function. + (aapcs_libcall_value): New function. + (aapcs_layout_arg): New function. + (arm_init_cumulative_args): Initialize AAPCS args data. + (arm_function_arg): Handle AAPCS variants using new interface. + (arm_arg_parital_bytes): Likewise. + (arm_function_arg_advance): New function. + (arm_function_ok_for_sibcall): Ensure that sibling calls agree on + calling conventions. + (arm_setup_incoming_varargs): Handle new AAPCS args data. + * arm.h (NUM_VFP_ARG_REGS): Define. + (LIBCALL_VALUE): Update. + (FUNCTION_VALUE): Delete. + (FUNCTION_VALUE_REGNO_P): Add VFP regs. + (arm_pcs): New enum. + (CUMULATIVE_ARGS): New data to support AAPCS argument marshalling. + (FUNCTION_ARG_ADVANCE): Call arm_function_arg_advance. + (FUNCTION_ARG_REGNO_P): Add VFP regs. + * arm-protos.h (arm_function_arg_advance): Add. + (aapcs_libcall_value): Add. + (arm_function_value): Delete. + +2009-08-06 Uros Bizjak <ubizjak@gmail.com> + H.J. Lu <hongjiu.lu@intel.com> + + PR target/40957 + * config/i386/i386.c (standard_sse_mode_p): Remove. + (standard_sse_constant_p): Return 2 for integer mode + vector_all_ones_operand when SSE2 is enabled. + (standard_sse_constant_opcode)<case 2>: Always return [v]pcmpeqd. + (ix86_expand_vector_move): Do not check for negative values from + standard_sse_constant_p. + +2009-08-06 Richard Guenther <rguenther@suse.de> + + * tree-ssa.c (useless_type_conversion_p_1): Make function and + array type comparisons frontend independent. + * Makefile.in (tree-ssa.o): Add $(TARGET_H) dependency. + * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Always fill + out array reference lower bound and element size operands. + (ao_ref_init_from_vn_reference): Properly compute the offset + for ARRAY_RANGE_REF. + (vn_reference_fold_indirect): Fill out array reference lower + bound and element size operands. + * tree-ssa-pre.c (phi_translate_1): Fail if we have to translate + a non gimple valued reference operand which can happen for + array reference lower bound or element size. + (create_component_ref_by_pieces_1): Properly generate the + element size operand for array references. + +2009-08-06 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40964 + * tree.c (iterative_hash_host_wide_int): Export. + * tree.h (iterative_hash_host_wide_int): Declare. + * tree-ssa-structalias.c (heapvar_map): New struct. + (heapvar_map_eq): New function. + (heapvar_map_hash): Likewise. + (heapvar_lookup): Adjust. + (heapvar_insert): Likewise. + (make_constraint_from_heapvar): Allow multiple heap variables + per decl at different offsets. + (init_alias_heapvars): Adjust. + +2009-08-04 David Daney <ddaney@caviumnetworks.com> + + * config/mips/mips.h (TARGET_SYNC_AFTER_SC): New macro. + * mips_output_sync_loop (mips_output_sync_loop): Only emit + trailing sync if TARGET_SYNC_AFTER_SC. + +2009-08-05 David Daney <ddaney@caviumnetworks.com> + + * gcc/config/mips/sync.md (sync_compare_and_swap<mode>, + compare_and_swap_12, sync_add<mode>, sync_<optab>_12, + sync_old_<optab>_12, sync_new_<optab>_12, sync_nand_12, + sync_old_nand_12, sync_new_nand_12, sync_sub<mode>, + sync_old_add<mode>, sync_old_sub<mode>, sync_new_add<mode>, + sync_new_sub<mode>, sync_<optab><mode>, sync_old_<optab><mode>, + sync_new_<optab><mode>, sync_nand<mode>, sync_old_nand<mode>, + sync_new_nand<mode>, sync_lock_test_and_set<mode>, + test_and_set_12): Rewrite calls to mips_output_sync_loop. + * gcc/config/mips/mips-protos.h (mips_output_sync_loop): Make + the prototype declaration match the definition. + * gcc/config/mips/mips.c (mips_output_sync_loop): Emit sync + instructions explicitly. Add barrier_before and operands + parameters. + * gcc/config/mips/mips.h (MIPS_COMPARE_AND_SWAP, + MIPS_COMPARE_AND_SWAP_12, MIPS_SYNC_OP, MIPS_SYNC_OP_12, + MIPS_SYNC_OLD_OP_12, MIPS_SYNC_NEW_OP_12, MIPS_SYNC_OLD_OP, + MIPS_SYNC_NEW_OP, MIPS_SYNC_NAND, MIPS_SYNC_OLD_NAND, + MIPS_SYNC_NEW_NAND, MIPS_SYNC_EXCHANGE, + MIPS_SYNC_EXCHANGE_12): Remove sync instructions. + +2009-08-05 Andrew Pinski <pinskia@gmail.com> + + * tree-ssa-alias.c: Fix intervals to use [) syntax. + +2009-08-05 Uros Bizjak <ubizjak@gmail.com> + Mikulas Patocka <mikulas@artax.karlin.mff.cuni.cz> + + PR target/40906 + * config/i386/i386.c (ix86_split_long_move): Fix push of multi-part + source operand. + +2009-08-05 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/40924 + * dse.c (canon_address): Before calling cselib_expand_value_rtx + make sure canon_rtx (mem_address) isn't simpler than + canon_rtx (expanded_mem_address). + +2009-08-05 Li Feng <nemokingdom@gmail.com> + + * graphite-sese-to-poly.c (build_pbb_drs): Remove build alias set + for each poly_bb_p. + (build_scop_drs): Build alias set for each SCoP. + +2009-08-04 Sandra Loosemore <sandra@codesourcery.com> + + * doc/invoke.texi (MIPS Options): Document new 1004K -march options. + * config/mips/mips.c (mips_cpu_info_table): Add 1004K cores. + * config/mips/mips.h (MIPS_ISA_LEVEL_SPEC): Add pattern for 1004K. + (MIPS_ARCH_FLOAT_SPEC): Likewise. + (BASE_DRIVER_SELF_SPECS): Likewise. + +2009-08-04 Andrew Pinski <pinskia@gmail.com> + + * tree-ssa-alias.c: Fix some comment typos. + +2009-08-04 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/linux-atomic.asm (ATOMIC_BOOL_COMPARE_AND_SWAP, + ATOMIC_OP_AND_FETCH, ATOMIC_COMBOP_AND_FETCH): Define. + +2009-08-03 Janis Johnson <janis187@us.ibm.com> + + PR c/39902 + * simplify-rtx.c (simplify_binary_operation_1): Disable + simplifications for decimal float operations. + +2009-08-03 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40943 + * tree-ssa.c (warn_uninitialized_var): Even on LHS warn for + operand of INDIRECT_REF. + +2009-08-03 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_legitimate_constant_p): Reject CONST + constants referencing TLS symbols. + +2009-08-03 SUGIOKA Toshinobu <sugioka@itonet.co.jp> + + * config/sh/linux-atomic.asm (ATOMIC_COMPARE_AND_SWAP): Rename + __sync_compare_and_swap_* to __sync_val_compare_and_swap_*. + +2009-08-03 Richard Guenther <rguenther@suse.de> + + * tree.c (make_vector_type): Build a main variant first, + get the canonical one and then build the variant. + * tree-ssa.c (useless_type_conversion_p_1): Handle + fixed-point types. + (useless_type_conversion_p): Conversions to pointers to + incomplete record types are useless. + +2009-08-03 Richard Guenther <rguenther@suse.de> + + * tree-cfg.c (pass_warn_unused_result): Mark name that no dump + file will be created. + * omp-low.c (pass_diagnose_omp_blocks): Likewise. + * toplev.c (compile_file): Adjust comment. + +2009-08-03 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh-protos.h (sh_promote_function_mode): Remove. + * config/sh/sh.c (sh_promote_function_mode): Wrap long lines. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_ARGS): Remove. + (sh_promote_function_mode): Fix typo. + +2009-08-03 Andreas Krebbel <krebbel1@de.ibm.com> + + * explow.c (promote_mode): Mark TYPE and PUNSIGNEDP as possibly unused. + +2009-08-02 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa.c (pa_promote_function_mode): Remove ATTRIBUTE_UNUSED from + declaration arguments. + +2009-08-02 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.c (ix86_expand_fp_compare): Use const0_rtx instead + of GEN_INT (0x00) and const1_rtx instead of GEN_INT (0x01). + (ix86_split_ashl): Ditto. + (ix86_expand_vector_init_one_nonzero): Ditto. + (ix86_expand_vector_set): Ditto. + (ix86_expand_reduc_v4sf): Ditto. + +2009-08-02 Paolo Bonzini <bonzini@gnu.org> + + * explow.c (promote_function_mode): Remove assert. + * config/sh/sh.c (sh_promote_function_mode): Declare. + +2009-08-01 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * config/pa/pa.c (pa_promote_function_mode): Declare. + Change to static. Fix promote_mode call. + + * gthr-dce.h (CONST_CAST2): Define if not defined. + (__gthread_setspecific): Use CONST_CAST2 to fix warning. + + * config.gcc (hppa[12]*-*-hpux10*): Add stdint support. + +2009-08-01 Paolo Bonzini <bonzini@gnu.org> + + * expr.c (store_constructor): Use promote_decl_mode. Remove + now write-only variable unsignedp. + (expand_expr_real_1): Use promote_decl_mode. + * expr.h (promote_function_mode, promote_decl_mode): New. + (promote_mode): Remove last argument. + * function.c (assign_temp): Drop last argument of promote_mode. + (assign_parm_find_data_types): Use promote_function_mode. + (assign_parm_setup_reg): Likewise. + (expand_function_end): Use promote_function_mode. + * calls.c (initialize_argument_information): Use promote_function_mode. + (precompute_arguments): Use promote_mode instead of checking if + only PROMOTE_FUNCTION_MODE is defined. + (expand_call): When making sibcall decisions, use promote_function_mode. + Below, remove an if for targetm.calls.promote_function_return and + and use promote_function_mode. + (emit_library_call_value_1): Use promote_function_mode, fix bug + where promote_mode was passed FOR_CALL == 0 for a return value in an + assertion. + * cfgexpand.c (expand_one_register_var): Use promote_decl_mode. + * explow.c (promote_function_mode, promote_decl_mode): New. + (promote_mode): Keep only the FOR_CALL == 0 case. + * combine.c (setup_incoming_promotion): Remove test of + promote_function_args. Use promote_function_mode. + * stmt.c (expand_value_return): Use promote_decl_mode. + (expand_decl): Use promote_decl_mode. + + * expr.c (store_constructor): Use promote_decl_mode. Remove + now write-only variable unsignedp. + (expand_expr_real_1): Use promote_decl_mode. + * expr.h (promote_function_mode, promote_decl_mode): New. + (promote_mode): Remove last argument. + * function.c (assign_temp): Drop last argument of promote_mode. + (assign_parm_find_data_types): Use promote_function_mode. + (assign_parm_setup_reg): Likewise. + (expand_function_end): Use promote_function_mode. + * calls.c (initialize_argument_information): Use promote_function_mode. + (precompute_arguments): Use promote_mode instead of checking if + only PROMOTE_FUNCTION_MODE is defined. + (expand_call): When making sibcall decisions, use promote_function_mode. + Below, remove an if for targetm.calls.promote_function_return and + and use promote_function_mode. + (emit_library_call_value_1): Use promote_function_mode, fix bug + where promote_mode was passed FOR_CALL == 0 for a return value in an + assertion. + * cfgexpand.c (expand_one_register_var): Use promote_decl_mode. + * explow.c (promote_function_mode, promote_decl_mode): New. + (promote_mode): Keep only the FOR_CALL == 0 case. + * combine.c (setup_incoming_promotion): Remove test of + promote_function_args. Use promote_function_mode. + * stmt.c (expand_value_return): Use promote_decl_mode. + (expand_decl): Use promote_decl_mode. + + * explow.c (promote_function_mode): Just call the target hook. + * targhooks.c (default_promote_function_mode, + default_promote_function_mode_always_promote): New. + * targhooks.h (default_promote_function_mode, + default_promote_function_mode_always_promote): Declare. + * target.h (promote_function_args, promote_function_return): Remove. + (promote_function_mode): New. + * target-def.h (TARGET_PROMOTE_FUNCTION_ARGS, + TARGET_PROMOTE_FUNCTION_RETURN): Remove. + (TARGET_PROMOTE_FUNCTION_MODE): New. + (TARGET_CALLS): Adjust. + * system.h (TARGET_PROMOTE_FUNCTION_ARGS, + TARGET_PROMOTE_FUNCTION_RETURN, PROMOTE_FUNCTION_MODE): Poison. + + * config/s390/s390.h (PROMOTE_FUNCTION_MODE): Move... + * config/s390/s390.c (s390_promote_function_mode): ... here, + with pointer handling. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN): Remove. + + * config/sparc/sparc.h (PROMOTE_FUNCTION_MODE): Move... + * config/sparc/sparc.c (sparc_promote_function_mode): ... here, + with pointer handling. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN): Remove. + + * config/sh/sh-protos.h (sh_promote_function_mode): New. + * config/sh/sh.c (sh_promote_function_mode): New. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN): Remove. + + * config/cris/cris.h (PROMOTE_FUNCTION_MODE): Move... + * config/cris/cris.c (cris_promote_function_mode): ... here. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_ARGS): Remove. + + * config/mmix/mmix.h (PROMOTE_FUNCTION_MODE): Move... + * config/mmix/mmix.c (mmix_promote_function_mode): ... here. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_ARGS): Remove. + + * config/arm/arm.h (PROMOTE_FUNCTION_MODE): Move... + * config/arm/arm.c (arm_promote_function_mode): ... here, without + complex type handling. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN): Remove. + + * config/pa/pa.c (pa_promote_function_mode): New. + (TARGET_PROMOTE_FUNCTION_MODE): Define. + (TARGET_PROMOTE_FUNCTION_RETURN): Remove. + + * config/alpha/alpha.c (TARGET_PROMOTE_FUNCTION_ARGS, + TARGET_PROMOTE_FUNCTION_RETURN): Remove. + (TARGET_PROMOTE_FUNCTION_MODE): Define equivalently. + * config/xtensa/xtensa.c: Likewise. + * config/stormy16/stormy16.c: Likewise. + * config/iq2000/iq2000.c: Likewise. + * config/rs6000/rs6000.c: Likewise. + * config/picochip/picochip.c: Likewise. + * config/arc/arc.c: Likewise. + * config/mcore/mcore.c: Likewise. + * config/score/score.c: Likewise. + * config/mips/mips.c: Likewise. + * config/bfin/bfin.c: Likewise. + * config/ia64/ia64.c: Likewise (disabled though). + + * config/frv/frv.h: Remove pointless remark. + + * doc/tm.texi (PROMOTE_FUNCTION_MODE, + TARGET_PROMOTE_FUNCTION_ARGS, + TARGET_PROMOTE_FUNCTION_RETURN): Consolidate into... + (TARGET_PROMOTE_FUNCTION_MODE): ... this. + +2009-08-01 Sebastian Pop <sebastian.pop@amd.com> + + * doc/invoke.texi (-fgraphite-force-parallel): Renamed + -floop-parallelize-all. + * toplev.c (process_options): Rename flag_graphite_force_parallel to + flag_loop_parallelize_all. + * tree-ssa-loop.c (gate_graphite_transforms): Same. + * graphite.c (graphite_transform_loops): Same. + * common.opt: Same. + * graphite-poly.c (apply_poly_transforms): Same. + +2009-07-31 Richard Earnshaw <rearnsha@arm.com> + + PR tree-optimization/40914 + * ipa-prop.c (ipa_get_ptr_load_param): New argument use_delta, + if set, then check the delta field of the PMF record. + (ipa_get_stmt_member_ptr_load_param): Propagate new param use_delta. + (ipa_analyze_call_uses): Handle machines where the vbit for a PMF + call is stored in the delta. + +2009-07-31 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (*clear_upper32_dext): New pattern. + +2009-07-31 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/bsd.h (ASM_BYTE): New define. + * config/i386/darwin.h (ASM_BYTE): Rename from ASM_BYTE_OP. + * config/i386/att.h (ASM_BYTE): New define. Use ASM_BYTE instead of + .byte. Use fputs or putc instead of fprintf where appropriate. + * config/i386/i386-interix.h: Use ASM_BYTE instead of .byte. Use + fputs or putc instead of fprintf where appropriate. + * config/i386/i386elf.h: Ditto. + * config/i386/sysv4.h: Ditto. + + * config/i386/i386.c (TARGET_ASM_BYTE_OP): New define. + * config/i386/i386.md (x86_sahf_1): Use ASM_BYTE instead of .byte. + (*tls_global_dynamic_64): Ditto. + +2009-07-31 Christian Bruel <christian.bruel@st.com> + + * gcc/config.gcc (sh*-*-elf): test with_libgloss. + +2009-07-31 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (arm_arm_address_cost): Fix typo. + Remove dead code for MINUS. + +2009-07-31 Anthony Green <green@moxielogic.com> + + * config/moxie/moxie.c (moxie_expand_prologue): Use $r5 instead of + $r12 in prologue. + (moxie_expand_epilogue): Ditto for epilogue. + (moxie_setup_incoming_varargs): ABI change. Use 5 registers for + incoming arguments. + (moxie_function_arg): Ditto. + (moxie_pass_by_reference): Ditto. + (moxie_arg_partial_bytes): Ditto. + * config/moxie/moxie.h (CALL_USED_REGISTERS): Ditto. + (FUNCTION_ARG_ADVANCE) Ditto. + (REG_PARM_STACK_SPACE) Ditto. + (FUNCTION_ARG_REGNO_P) Dito. + + * config.gcc: Add moxie linux config support. + * gcc/config/moxie/uclinux.h: New file. + +2009-07-31 DJ Delorie <dj@redhat.com> + + * config/sh/sh.md (UNSPECV_SP_SWITCH_B): New. + (UNSPECV_SP_SWITCH_E): New. + (sp_switch_1): Change to an unspec. + (sp_switch_2): Change to an unspec. Don't use post-inc when we + replace $r15. + * config/sh/sh.c (sh_expand_prologue): Use the constant pool to + reference the new stack's address + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * Makefile.in (OBJS-common): Added dependence on graphite-blocking.o, + graphite-clast-to-gimple.o, graphite-dependences.o, + graphite-interchange.o, graphite-poly.o, graphite-ppl.o, + graphite-scop-detection.o, graphite-sese-to-poly.o, and sese.o. + (graphite-blocking.o, + graphite-clast-to-gimple.o, graphite-dependences.o, + graphite-interchange.o, graphite-poly.o, graphite-ppl.o, + graphite-scop-detection.o, graphite-sese-to-poly.o, and sese.o): New. + * cfgloop.c (alloc_loop): Set loop->can_be_parallel to false. + * cfgloop.h (struct loop): Add can_be_parallel field. + * common.opt (fgraphite-identity): Moved up. + (fgraphite-force-parallel): New flag. + * graphite.c: Rewrite. + * graphite.h: Rewrite. + * passes.c (init_optimization_passes): Schedule a pass of DCE and LIM + after Graphite. + * toplev.c (graphite_out_file): New file descriptor. + (graphite_in_file): New. + (process_options): flag_graphite_force_parallel cannot be used without + Graphite. + * tree-ssa-loop.c: Include toplev.h. + (gate_graphite_transforms): Enable flag_graphite for + flag_graphite_force_parallel. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * ChangeLog.graphite: New. + * graphite-blocking.c: New. + * graphite-clast-to-gimple.c: New. + * graphite-clast-to-gimple.h: New. + * graphite-dependences.c: New. + * graphite-dependences.h: New. + * graphite-interchange.c: New. + * graphite-poly.c: New. + * graphite-poly.h: New. + * graphite-ppl.c: New. + * graphite-ppl.h: New. + * graphite-scop-detection.c: New. + * graphite-scop-detection.h: New. + * graphite-sese-to-poly.c: New. + * graphite-sese-to-poly.h: New. + * sese.c: New. + * sese.h: New. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * tree-chrec.c (evolution_function_right_is_integer_cst): New. + * tree-chrec.h (evolution_function_right_is_integer_cst): Declared. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * tree-chrec.c (operator_is_linear): Handle BIT_NOT_EXPR. + (scev_is_linear_expression): Return false if the evolution is not + affine multivariate. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * tree-data-ref.c (graphite_find_data_references_in_stmt): New. + * tree-data-ref.h (graphite_find_data_references_in_stmt): Declared. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * tree-data-ref.c (debug_data_references): New. + (debug_data_reference): New. + * tree-data-ref.h (debug_data_references): Declared. + (debug_data_reference): Declared. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * tree-data-ref.c (stmt_simple_memref_p: Removed. + * tree-data-ref.h (scop_p): Removed. + (struct data_reference): Remove field scop. + (DR_SCOP): Removed. + (stmt_simple_memref_p): Removed. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * cfgloop.h (create_empty_loop_on_edge): Pass an extra argument. + * cfgloopmanip.c (create_empty_loop_on_edge): Leave the loop_latch + basic block empty. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * doc/invoke.texi (-fgraphite-force-parallel): Documented. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * doc/invoke.texi (-fgraphite-identity): Documented. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * tree-scalar-evolution.c: Fix comment. + (instantiate_scev_1): Return unknow from scev instantiation if the + result is not above instantiate_below. + +2009-07-30 Sebastian Pop <sebastian.pop@amd.com> + + * tree-scalar-evolution.c (compute_overall_effect_of_inner_loop): Not + static anymore. Instantiate the symbols that may have been introduced + by chrec_apply. + * tree-scalar-evolution.h (compute_overall_effect_of_inner_loop): + Declared. + +2009-07-30 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (mep_asm_init_sections): Add section flags and + .vliw directive to VLIW sections. + +2009-07-30 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * Makefile.in (AUTOCONF, ACLOCAL, ACLOCAL_AMFLAGS, aclocal_deps): + New variables. + ($(srcdir)/configure, $(srcdir)/aclocal.m4): New rules. + (AUTOHEADER): New variable. + ($(srcdir)/cstamp-h.in): Use it. + +2009-07-30 Michael Meissner <meissner@linux.vnet.ibm.com> + Pat Haugen <pthaugen@us.ibm.com> + Revital Eres <ERES@il.ibm.com> + + * config/rs6000/vector.md (VEC_F): Add VSX support. + (VEC_A): Ditto. + (VEC_N): Ditto. + (mov<mode>): Ditto. + (vector_load_<mode>): Ditto. + (vector_store_<mode>): Ditto. + (vector GPR move split): Ditto. + (vec_reload_and_plus_<mptrsize>): Ditto. + (vec_reload_and_reg_<mptrsize>): Ditto. + (add<mode>3): Ditto. + (sub<mode>3): Ditto. + (mul<mode>3): Ditto. + (neg<mode>2): Ditto. + (abs<mode>2): Ditto. + (smin<mode>3): Ditto. + (smax<mode>3): Ditto. + (vector_eq<mode>): Ditto. + (vector_gt<mode>): Ditto. + (vector_ge<mode>): Ditto. + (vector_gtu<mode>): Ditto. + (vector_select_<mode>_uns): Ditto. + (vector_eq_<mode>_p): Ditto. + (vector_gt_<mode>_p): Ditto. + (vector_ge_<mode>_p): Ditto. + (vector_gtu_<mode>_p): Ditto. + (cr6_test_for_zero): Ditto. + (cr6_test_for_zero_reverse): Ditto. + (cr6_test_for_lt): Ditto. + (cr6_test_for_lt_reverse): Ditto. + (xor<mode>3): Ditto. + (ior<mode>3): Ditto. + (and<mode>3): Ditto. + (one_cmpl<mode>2): Ditto. + (nor<mode>2): Ditto. + (andc<mode>2): Ditto. + (float<VEC_int<mode>2): Ditto. + (unsigned_float<VEC_int><mode>2): Ditto. + (fix_trunc<mode><VEC_int>2): Ditto. + (fixuns_trunc<mode><VEC_int>2): Ditto. + (vec_init<mode>): + (vec_set<mode>): Ditto. + (vec_extract<mode>): Ditto. + (vec_interleave_highv4sf): Ditto. + (vec_interleave_lowv4sf): Ditto. + (vec_realign_load_<mode>): Ditto. + (vec_shl_<mode>): Ditto. + (vec_shr_<mode>): Ditto. + (div<mode>3): New patterns for VSX. + (vec_interleave_highv2df): Ditto. + (vec_interleave_lowv2df): Ditto. + (vec_pack_trunc_v2df): Ditto. + (vec_pack_sfix_trunc_v2df): Ditto. + (vec_pack_ufix_trunc_v2df): Ditto. + (vec_unpacks_hi_v4sf): Ditto. + (vec_unpacks_lo_v4sf): Ditto. + (vec_unpacks_float_hi_v4si): Ditto. + (vec_unpacks_float_lo_v4si): Ditto. + (vec_unpacku_float_hi_v4si): Ditto. + (vec_unpacku_float_lo_v4si): Ditto. + (movmisalign<mode>): Ditto. + (vector_ceil<mode>2): New patterns for vectorizing math library. + (vector_floor<mode>2): Ditto. + (vector_btrunc<mode>2): Ditto. + (vector_copysign<mode>3): Ditto. + + * config/rs6000/predicates.md (easy_vector_constant_msb): New + predicate for setting the high bit in each word, used for copysign. + + * config/rs6000/ppc-asm.h (f19): Whitespace. + (f32-f63): Define if VSX. + (v0-v31): Define if Altivec. + (vs0-vs63): Define if VSX. + + * config/rs6000/t-rs6000 (MD_INCLUDES): Add power7.md and vsx.md. + + * config/rs6000/power7.md: New file, provide tuning parameters for + -mcpu=power7. + + * config/rs6000/rs6000-c.c (rs6000_macro_to_expand): Add VSX support. + (rs6000_cpu_cpp_builtins): Ditto. + (altivec_overloaded_builtins): Ditto. + (altivec_resolve_overloaded_builtin): Ditto. + + * config/rs6000/rs6000.opt (-mno-vectorize-builtins): Add new + debug switch to disable vectorizing simple math builtin + functions. + + * config/rs6000/rs6000.c (rs6000_builtin_vectorized_function): + Vectorize simple math builtin functions. + (TARGET_VECTORIZE_BUILTIN_VECTORIZED_FUNCTION): Define target + hook to vectorize math builtins. + (rs6000_override_options): Enable -mvsx on -mcpu=power7. + (rs6000_builtin_conversion): Add VSX/power7 support. + (rs6000_builtin_vec_perm): Ditto. + (vsplits_constant): Add support for loading up a vector constant + with just the high bit set in each part. + (rs6000_expand_vector_init): Add VSX/power7 support. + (rs6000_expand_vector_set): Ditto. + (rs6000_expand_vector_extract): Ditto. + (rs6000_emit_move): Ditto. + (bdesc_3arg): Ditto. + (bdesc_2arg): Ditto. + (bdesc_1arg): Ditto. + (rs6000_expand_ternop_builtin): Ditto. + (altivec_expand_builtin): Ditto. + (rs6000_expand_unop_builtin): Ditto. + (rs6000_init_builtins): Ditto. + (altivec_init_builtins): Ditto. + (builtin_function_type): Ditto. + (rs6000_common_init_builtins): Ditto. + (rs6000_handle_altivec_attribute); Ditto. + (rs6000_mangle_type): Ditto. + (rs6000_vector_mode_supported_p): Ditto. + (rs6000_mode_dependent_address): Altivec addresses with AND -16 + are mode dependent. + + * config/rs6000/vsx.md: New file for VSX support. + + * config/rs6000/rs6000.h (EASY_VECTOR_MSB): New macro for + identifing values with just the most significant bit set. + (enum rs6000_builtins): Add builtins for VSX. Add simple math + vectorized builtins. + + * config/rs6000/altivec.md (UNSPEC_VRFIP): Delete. + (UNSPEC_VRFIM): Delete. + (splitter for loading up vector with most significant bit): New + splitter for vectorizing copysign. + (altivec_vrfiz): Rename from altivec_fturncv4sf2. Add support for + vectorizing simple math functions. + (altivec_vrfip): Add support for vectorizing simple math functions. + (altivec_vrfim): Ditto. + (altivec_copysign_v4sf3): New insn for Altivec copysign support. + + * config/rs6000/rs6000.md (UNSPEC_BPERM): New constant. + (power7.md, vsx.md): Include for power7 support. + (copysigndf3): Use VSX instructions if -mvsx. + (negdf2_fpr): Ditto. + (absdf2_fpr): Ditto. + (nabsdf2_fpr): Ditto. + (adddf3_fpr): Ditto. + (subdf3_fpr): Ditto. + (muldf3_fpr): Ditto. + (divdf3_fpr): Ditto. + (fix_truncdfdi2_fpr): Ditto. + (cmpdf_internal1): Ditto. + (fred, fred_fpr): Convert into expander/insn to add VSX support. + (btruncdf2, btruncdf2_fpr): Ditto. + (ceildf2, ceildf2_fpr): Ditto. + (floordf2, floordf2_fpr): Ditto. + (floatdidf2, floatdidf2_fpr): Ditto. + (fmadddf4_fpr): Name insn. Use VSX instructions if -mvsx. + (fmsubdf4_fpr): Ditto. + (fnmadddf4_fpr_1): Ditto. + (fnmadddf4_fpr_2): Ditto. + (fnmsubdf4_fpr_1): Ditto. + (fnmsubdf4_fpr_2): Ditto. + (fixuns_truncdfdi2): Add expander for VSX support. + (fix_truncdfdi2): Ditto. + (fix_truncdfsi2): Ditto. + (ftruncdf2): Ditto. + (btruncsf2): Whitespace. + (movdf_hardfloat32): Add support for VSX registers. + (movdf_softfloat32): Ditto. + (movdf_hardfloat64): Ditto. + (movdf_hardfloat64_mfpgpr): Ditto. + (movdf_softfloat64): Ditto. + (movti splitters): Add check for vector registers supporting + TImode in the future. + (bpermd): Add power7 bpermd instruction. + + * config/rs6000/altivec.h (vec_div): Define if VSX. + (vec_mul): Ditto. + (vec_msub): Ditto. + (vec_nmadd): Ditto. + (vec_nearbyint): Ditto. + (vec_rint): Ditto. + (vec_sqrt): Ditto. + (all predicates): Use the generic builtin function, and not the V4SF + specific function so that the predicates will work with VSX's V2DF. + (vec_all_*): Ditto. + (vec_any_*): Ditto. + + * doc/extend.texi (PowerPC Altivec/VSX Built-in Functions): + Document new VSX functions and types. + + * doc/invoke.texi (PowerPc options): Document -mpopcntd, -mvsx + switches. + + * doc/md.texi (PowerPC constraints): Document "wd", "wf", "ws", + "wa", and "j" constraints. Modify "v" to talk about Altivec + instead of just vector. + +2009-07-30 Andrew MacLeod <amacleod@redhat.com> + + PR debug/26475 + * tree-into-ssa.c (insert_phi_nodes_for, rewrite_add_phi_arguments): Set + location for phi arguments. + (rewrite_update_phi_arguments): Find locations for reaching defs. + * tree-ssa-threadupdate.c (create_edge_and_update_destination_phis): + Add location to add_phi_arg calls. + * tree-loop-districbution.c (update_phis_for_loop_copy): Add locations. + * tree-ssa-loop-manip.c (create_iv, add_exit_phis_edge, + split_loop_exit_edge, tree_transform_and_unroll_loop): Add locations. + * tree-tailcall.c (add_successor_phi_arg, eliminate_tail_call, + create_tailcall_accumulator, tree_optimize_tail_calls_1): Add locations. + * tree.h (struct phi_arg_d): Add location_t to PHI arguments. + * tree-phinodes.c (make_phi_node): Initialize location. + (resize_phi_node): Initialize location to UNKNOWN_LOCATION. + (add_phi_arg): Add location parameter. + (remove_phi_arg_num): Move location when moving phi argument. + * omp-low.c (expand_parallel_call, expand_omp_for_static_chunk): Set + location. + * tree-vect-loop-manip.c (slpeel_update_phis_for_duplicate_loop, + slpeel_update_phi_nodes_for_guard1, + slpeel_update_phi_nodes_for_guard2, + slpeel_tree_duplicate_loop_to_edge_cfg, set_prologue_iterations, + vect_loop_versioning): Set locations. + * tree-parloops.c (create_phi_for_local_result, + transform_to_exit_first_loop, create_parallel_loop): Add locations. + * gimple-pretty-print.c (dump_gimple_phi): Dump lineno's if present. + * tree-vect-loop.c (get_initial_def_for_induction, + vect_create_epilog_for_reduction, vect_finalize_reduction): Add + locations. + * tree-flow-inline.h (gimple_phi_arg_location): New. Return locus. + (gimple_phi_arg_location_from_edge): New. Return locus from an edge. + (gimple_phi_arg_set_location): New. Set locus. + (gimple_phi_arg_has_location): New. Check for locus. + (redirect_edge_var_map_location): New. Return locus from var_map. + * tree-vect-data-refs.c (vect_setup_realignment): Set location. + * tree-ssa-phiopt.c (conditional_replacement): Set locus when + combining PHI arguments. + (cond_store_replacement): Set location. + * cfgexpand.c (gimple_assign_rhs_to_tree): Transfer locus if possible. + * grpahite.c (add_loop_exit_phis, add_guard_exit_phis, + scop_add_exit_phis_edge): Add locations. + * tree-cfgcleanup.c (remove_forwarder_block, + remove_forwarder_block_with_phi): Add locations. + * tree-ssa-pre.c (insert_into_preds_of_block): Add locations. + * tree-predcom.c (initialize_root_vars, initialize_root_vars_lm): Add + locations. + * tree-ssa-dce.c (forward_edge_to_pdom): Add locations. + * tree-ssa.c (redirect_edge_var_map_add, ssa_redirect_edge, + flush_pending_stmts): Add source location. + * lambda-code.c (perfect_nestify): Maintain location stack with argument + stack to preserve locations. + * tree-vect-stmts.c (vectorizable_load): Add location. + * tree-inline.c (copy_phis_for_bb): Copy locus. + (setup_one_parameter): Add call locus to inlined parameter stmts. + (initialize_inlined_parameters): Pass in call location as parameter + assignment locus. + (tree_function_versioning): Pass location to setup_one_parameter. + * tree-ssa-phiprop.c (phiprop_insert_phi): Set locations. + * tree-outof-ssa.c (struct _elim_graph): Add source_location vecs for + copy and edge lists. + (insert_partition_copy_on_edge, insert_value_copy_on_edge, + insert_rtx_to_part_on_edge, insert_part_to_rtx_on_edge): Provide a + locus parameter and override the stmt default if provided. + (new_elim_graph, clear_elim_graph, delete_elim_graph, + elim_graph_add_edge, elim_graph_remove_succ_edge, + FOR_EACH_ELIM_GRAPH_SUCC, FOR_EACH_ELIM_GRAPH_PRED, eliminate_build, + elim_forward, elim_unvisited_predecessor, elim_backward, elim_create, + eliminate_phi): Add locus info in elimination graph for each edge and + value copy. + (insert_backedge_copies): Copy locus if present. + * tree-flow.h (struct _edge_var_map): Add locus field. + * tree-switch_conversions.c (fix_phi_nodes): Add locations. + * tree-cfg.c (reinstall_phi_args, gimple_make_forwarder_block, + add_phi_args_after_copy_edge, gimple_lv_adjust_loop_header_phi): Add + locations. + * ipa-struct-reorg.c (make_edge_and_fix_phis_of_dest): Add locations. + +2009-07-30 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40570 + * ipa-inline.c (cgraph_decide_inlining): Watch out for dead single + use inlining loops. + +2009-07-30 Razya Ladelsky <razya@il.ibm.com> + + * ssa-loop-manip.c: Include langhooks.h. + (rewrite_phi_with_iv): New. + (rewrite_all_phi_nodes_with_iv): New. + (canonicalize_loop_ivs): Move here from tree-parloops.c. + Remove reduction_list argument. Use rewrite_all_phi_nodes_with_iv. + * tree-parloops.c (loop_parallel_p): Move out all conditions + except dependency check. + (canonicalize_loop_ivs): Move to tree-ssa-loop-manip.c. + (gen_parallel_loop): Call canonicalize_loop_ivs without + reduction_list argument. + (build_new_reduction): New. + (gather_scalar_reductions): New. + (try_get_loop_niter): New. + (try_create_reduction_list): New. + (parallleize_loops): Change the parallel conditions check. + * tree-flow.h (canonicalize_loop_ivs): Remove one argument. + * Makefile.in (tree-ssa-loop-manip.o): Add langhooks.h dependency. + +2009-07-30 Dave Korn <dave.korn.cygwin@gmail.com> + + * opt-functions.awk (opt_args): Allow argument to be enclosed in + curly braces. + * doc/options.texi (Option properties): Mention new quoting syntax. + +2009-07-29 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/alpha.c (alpha_start_function): + Handle VMS_DEBUG_MAIN_POINTER + * config/alpha/vms.h (VMS_DEBUG_MAIN_POINTER): Define new macro. + * doc/invoke.texi: Document -mdebug-main switch. + +2009-07-29 Richard Henderson <rth@redhat.com> + + * cgraph.c (cgraph_set_call_stmt_including_clones): Tidy. + (cgraph_create_edge_including_clones): Likewise. + * tree-inline.c (copy_bb): Operate on the correct edges + when updating the callgraph. + +2009-07-29 Douglas B Rupp <rupp@gnat.com> + + * config/alpha/vms-cc.c: Deleted. + * config/alpha/vms-ld.c: Deleted. + * config/alpha/t-vms64: Moved to config/vms + * config/alpha/vms-crt0-64.c: Moved to config/vms + * config/alpha/vms-crt0.c: Moved to config/vms + * config/alpha/vms-psxcrt0-64.c: Moved to config/vms + * config/alpha/vms-psxcrt0.c: Moved to config/vms + * config/alpha/xm-vms.h: Moved to config/vms + * config/alpha/x-vms: Moved to config/vms + * config/alpha/t-vms (vcrt0.o, pcrt0.o): Move rules to new file + config/vms/t-vms. + * config/vms/t-vms: Moved here from config/alpha. Alpha specific + parts removed. (STMP_FIXPROTO, STMP_FIXINC, LIMITS_H_TEST): Set. + (version): Set. + * config/vms/t-vms64: Moved here from config/alpha + * config/vms/vms-crt0-64.c: Moved here from config/alpha. + (argc,argv,envp): Enforce 32bit malloc'ing. + * config/vms/vms-psxcrt0-64.c: Likewise. + * config/vms/vms-crt0.c: Moved here from config/alpha. + * config/vms/vms-psxcrt0.c: Likewise. + * config/vms/vms-crtl-64.h: New file. + * config/vms/vms-crtl.h: New file. + * config/vms/vms.opt: New file. + * config/vms/xm-vms64.h: New file. + * config/vms/xm-vms.h: Moved here from config/alpha. + (STANARD_EXEC_PREFIX, STANDARD_STARTFILE_PREFIX, STANDARD_INCLUDE_DIR): + Set. + * config/vms/x-vms: Moved here from config/alpha. + (version, VMS_EXTRA_PARTS): Moved to t-vms. + (vms-ld.o, vms-cc.o): Removed. + (LN, LN_S, USE_COLLECT2, POD2MAN): Set. + +2009-07-29 Douglas B Rupp <rupp@gnat.com> + + * dwarf2out.c (add_name_and_src_coords_attributes): Push on the + correct stack (obvious VMS fix). + +2009-07-29 Douglas B Rupp <rupp@gnat.com> + + * dwarf2out.c (output_file_names): Output VMS style file name, size, + date, version info if VMS_DEBUGGING_INFO defined. + * vmsdgbout.c (vms_file_stats_name): New functon. VMS style file name, + size, date calculating code moved here. + +2009-07-29 Paul Brook <paul@codesourcery.com> + + * config/arm/lib1funcs.asm (clear_cache): Use ARM_FUNC_START and + do_push/do_pop. + +2009-07-29 Uros Bizjak <ubizjak@gmail.com> + + PR target/40577 + * config/alpha/alpha.c (alpha_expand_unaligned_store): Convert src + to DImode when generating insq_le insn. + +2009-07-28 Douglas B Rupp <rupp@gnat.com> + + * dwarf2out.c (DWARF2_INDIRECT_STRING_SUPPORT_MISSING_ON_TARGET): + New macro set for VMS_DEBUGGGING_INFO. + (AT_string_form): Use it. + +2009-07-28 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (vtext_section): New. + (vftext_section): New. + (ftext_section): New. + (mep_select_section): Add support for functions. + (mep_unique_section): Likewise. + (mep_asm_init_sections): Likewise. + (mep_encode_section_info): Remove it from here. + + * config/mep/mep.h (USE_SELECT_SECTION_FOR_FUNCTIONS): Define. + +2009-07-28 Paolo Bonzini <bonzinI@gnu.org> + + * tree.h (TREE_DEPRECATED): Document it is used for types too. + (TYPE_VECTOR_OPAQUE): Use default_def_flag + +2009-07-28 Douglas B Rupp <rupp@gnat.com> + + * dwarf2out.c (output_file_names): Test new macro + DWARF2_DIR_SHOULD_END_WITH_SEPARATOR. + (add_comp_dir_attribute): Likewise. + +2009-07-28 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/mingw-w64.h (LINK_SPEC): Add + separating space between commands. + +2009-07-28 Jan Hubicka <jh@suse.cz> + + PR tree-optimization/40759 + * tree-ssa-dce.c (mark_virtual_phi_result_for_renaming): Mark all uses + for renaming. + +2009-07-27 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (mep_expand_builtin_saveregs): Make sure 64-bit + types are dword-aligned. + (mep_expand_va_start): Likewise. + +2009-07-27 Olivier Hainque <hainque@adacore.com> + Douglas B Rupp <rupp@gnat.com> + + * convert.c (convert_to_pointer): Don't assume the target + pointer type is POINTER_SIZE long. Fetch its precision instead. + +2009-07-27 Douglas B Rupp <rupp@gnat.com> + + * system.h (fopen): Undefine if macro. + +2009-07-27 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (output_cfi_p): Removed. + (output_cfis): New function. + (output_fde): New function, split from output_call_frame_info. + (output_call_frame_info): Use it. + (dwarf2out_switch_text_section): Use output_cfis. + +2009-07-24 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/cygming.h (DWARF2_UNWIND_INFO): Error build when + TARGET_BI_ARCH is specified without enabling SJLJ. + * config/i386/mingw32.h (MD_UNWIND_SUPPORT): Define MD_UNWIND_SUPPORT, + if TARGET_64BIT and TARGET_BI_ARCH aren't defined. + +2009-07-26 Mikael Pettersson <mikpe@it.uu.se> + + * arm.md (negdi2): Use DImode if forcing a value into a register. + +2009-07-26 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/40801 + * tree-vect-stmts.c (vectorizable_call): Get previous copy + of vector operand from the previous copy of vector statement. + Pass the correct definition type value to + vect_get_vec_def_for_stmt_copy(). + +2009-07-25 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * collect2.c (scan_libraries): Use CONST_CAST2 to perform char ** to + const char ** conversion. + +2009-07-25 David Daney <ddaney@caviumnetworks.com> + + * system.h (gcc_assert): Invoke __builtin_unreachable() instead of + fancy_abort() if !ENABLE_ASSERT_CHECKING. + (gcc_unreachable): Invoke __builtin_unreachable() if + !ENABLE_ASSERT_CHECKING. + +2009-07-25 David Daney <ddaney@caviumnetworks.com> + + PR rtl-optimization/40445 + * emit-rtl.c (next_nonnote_insn_bb): New function. + * rtl.h (next_nonnote_insn_bb): Declare new function. + * cfgcleanup.c (try_optimize_cfg): Don't remove an empty block + with no successors that is the successor of the ENTRY_BLOCK. + Continue from the top after removing an empty fallthrough block. + * cfgrtl.c (get_last_bb_insn): Call next_nonnote_insn_bb instead + of next_nonnote_insn. + +2009-07-25 David Daney <ddaney@caviumnetworks.com> + + * cfgcleanup.c (old_insns_match_p): Handle the case of empty blocks. + +2009-07-25 Martin Jambor <mjambor@suse.cz> + + * c-common.c (c_common_attribute_table): New element for noclone. + (handle_noclone_attribute): New function. Forward-declare. + * tree-inline.c (tree_versionable_function_p): Check for noclone + attribute. + * doc/extend.texi (Labels as Values): Document need for noclone. + (Function Attributes): Document noclone attribute. + +2009-07-25 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/34999 + * dwarf2out.c (struct dw_fde_struct): Add dw_fde_switch_cfi + and dw_fde_switched_cold_to_hot fields. + (output_cfi_p): New function. + (output_call_frame_info): If fde->dw_fde_switched_sections, + output 2 FDEs instead of one with corrupted header. + (dwarf2out_do_cfi_startproc): New function. + (dwarf2out_begin_prologue): Use it. Initialize fde->dw_fde_switch_cfi + and fde->dw_fde_switched_cold_to_hot. + (dwarf2out_switch_text_section): Compute + fde->dw_fde_switched_cold_to_hot. Switch to new text section here. + If dwarf2out_do_cfi_asm, emit .cfi_endproc before it and call + dwarf2out_do_cfi_startproc plus emit again currently active CFI insns. + Otherwise, compute fde->dw_fde_switch_cfi. + +2009-07-24 Cary Coutant <ccoutant@google.com> + + * tree-cfg.c (assign_discriminator): Add explicit parentheses. + +2009-07-24 Cary Coutant <ccoutant@google.com> + + * cfghooks.c (split_block): Copy discriminator to new block. + * tree-cfg.c (assign_discriminator): Check location of last + instruction in block as well as first. + +2009-07-24 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/linux.c: Use fputs or putc instead of fprintf + where appropriate. + * config/i386/gas.h: Ditto. + * config/i386/x86-64.h: Ditto. + * config/i386/att.h: Ditto. + +2009-07-24 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * expmed.c (emit_store_flag): Use a recursive call to optimize the + xor case. + +2009-07-24 Martin Jambor <mjambor@suse.cz> + + * ipa-prop.h (struct ipa_node_params): New flag node_enqued. + (ipa_push_func_to_list_1): Declare. + (ipa_push_func_to_list): New function. + + * ipa-prop.c (ipa_push_func_to_list_1): New function. + (ipa_init_func_list): Call ipa_push_func_to_list_1. + (ipa_push_func_to_list): Removed. + (ipa_pop_func_from_list): Clear node_enqueued flag. + +2009-07-24 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/s390.c (override_options): Default + max-unrolled-insns to 100 for z10 tuning. + +2009-07-24 Tobias Grosser <grosser@fim.uni-passau.de> + + * Makefile.in (TREE_DATA_REF_H, tree-vrp.o, tree-cfg.o, tree-if-conv.o + tree-ssa-loop.o, tree-ssa-loop-niter.o, tree-ssa-loop-ivcanon.o, + tree-ssa-loop-prefetch.o, tree-predcom.o, tree-affine.o, + tree-scalar-evolution.o, tree-data-ref.o, tree-vect-loop.o, + tree-vect-data-refs.o, tree-loop-linear.o, tree-loop-distribution.o + tree-parloops.o, tree-pretty-printer.o, fold-const.o, tree-ssa-dce.o, + lambda-code.o, params.o): Cleanup use of SCEV_H and TREE_DATA_REF_H. + +2009-07-24 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/mingw-w64.h (STANDARD_INCLUDE_DIR): Remove and + use default set in mingw32.h header. + * config/i386/mingw32.h (STANDARD_INCLUDE_DIR): Use for 32-bit and + 64-bit /mingw/include path. + (STANDARD_STARTFILE_PREFIX_1): Use for 32-bit and 64-bit /mingw/lib + path. + +2009-07-23 Neil Vachharajani <nvachhar@google.com> + + PR rtl-optimization/40209 + * loop-iv.c (iv_analysis_loop_init): Call df_note_add_problem. + +2009-07-23 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.c: Use ASM_LONG instead of .long. Concatenate + ASM_LONG, LPREFIX, MCOUNT_NAME and PROFILE_COUNT_REGISTER strings + with the rest of string where appropriate. Use fputs or putc + instead of fprintf where appropriate. + +2009-07-22 Michael Meissner <meissner@linux.vnet.ibm.com> + Pat Haugen <pthaugen@us.ibm.com> + Revital Eres <ERES@il.ibm.com> + + * config/rs6000/vector.md: New file. Move most of the vector + expander support here from altivec.md to allow for the VSX vector + unit in the future. Add support for secondary_reload patterns. + Rewrite the patterns for vector comparison, and vector comparison + predicate instructions so that the RTL expresses the desired + behavior, instead of using unspec. + + * config/rs6000/constraints.md ("f" constraint): Use + rs6000_constraints to hold the precalculated register class. + ("d" constraint): Ditto. + ("wd" constraint): New constraint for VSX. + ("wf" constraint): Ditto. + ("ws" constraint): Ditto. + ("wa" constraint): Ditto. + ("wZ" constraint): Ditto. + ("j" constraint): Ditto. + + * config/rs6000/predicates.md (vsx_register_operand): New + predicate for VSX. + (vfloat_operand): New predicate for vector.md. + (vint_operand): Ditto. + (vlogical_operand): Ditto. + (easy_fp_constant): If VSX, 0.0 is an easy constant. + (easy_vector_constant): Add VSX support. + (altivec_indexed_or_indirect_operand): New predicate for + recognizing Altivec style memory references with AND -16. + + * config/rs6000/rs6000.c (rs6000_vector_reload): New static global + for vector secondary reload support. + (rs6000_vector_reg_class): Delete, replacing it with + rs6000_constraints. + (rs6000_vsx_reg_class): Ditto. + (rs6000_constraints): New array to hold the register classes of + each of the register constraints that can vary at runtime. + (builtin_mode_to_type): New static array for builtin function type + creation. + (builtin_hash_table): New static hash table for builtin function + type creation. + (TARGET_SECONDARY_RELOAD): Define target hook. + (TARGET_IRA_COVER_CLASSES): Ditto. + (rs6000_hard_regno_nregs_internal): If -mvsx, floating point + registers are 128 bits if VSX memory reference instructions are used. + (rs6000_hard_regno_mode_ok): For VSX, only check if the VSX memory + unit is being used. + (rs6000_debug_vector_unit): Move into rs6000_debug_reg_global. + (rs6000_debug_reg_global): Move -mdebug=reg statements here. + Print several of the scheduling related parameters. + (rs6000_init_hard_regno_mode_ok): Switch to putting constraints in + rs6000_constraints instead of rs6000_vector_reg_class. Move + -mdebug=reg code to rs6000_debug_reg_global. Add support for + -mvsx-align-128 debug switch. Drop testing float_p if VSX or + Altivec. Add VSX support. Setup for secondary reload support on + Altivec/VSX registers. + (rs6000_override_options): Make power7 set the scheduling groups + like the power5. Add support for new debug switches to override + the scheduling defaults. Temporarily disable -mcpu=power7 from + setting -mvsx. Add support for debug switches -malways-hint, + -msched-groups, and -malign-branch-targets. + (rs6000_buitlin_conversion): Add support for returning unsigned + vector conversion functions to fix regressions due to stricter + type checking. + (rs6000_builtin_mul_widen_even): Ditto. + (rs6000_builtin_mul_widen_odd): Ditto. + (rs6000_builtin_vec_perm): Ditto. + (rs6000_vec_const_move): On VSX, use xxlxor to clear register. + (rs6000_expand_vector_init): Initial VSX support for using xxlxor + to zero a register. + (rs6000_emit_move): Fixup invalid const symbol_ref+reg that is + generated upstream. + (bdesc_3arg): Add builtins for unsigned types. Add builtins for + VSX types for bit operations. Changes to accomidate vector.md. + (bdesc_2arg): Ditto. + (bdesc_1arg): Ditto. + (struct builtin_description_predicates): Rewrite predicate + handling so that RTL describes the operation, instead of passing + the instruction to be used as a string argument. + (bdesc_altivec_preds): Ditto. + (altivec_expand_predicate_builtin): Ditto. + (altivec_expand_builtin): Ditto. + (rs6000_expand_ternop_builtin): Use a switch instead of an if + statement for vsldoi support. + (altivec_expand_ld_builtin): Change to use new names from vector.md. + (altivec_expand_st_builtin): Ditto. + (paired_expand_builtin): Whitespace changes. + (rs6000_init_builtins): Add V2DF/V2DI types. Initialize the + builtin_mode_to_type table for secondary reload. Call + builtin_function_type to build random builtin functions. + (altivec_init_builtins): Change to use builtin_function_type to + create builtin function types dynamically as we need them. + (builtin_hash_function): New support for hashing the tree types + for builtin function as we need it, rather than trying to build + all of the trees that we need. Add initial preliminary VSX support. + (builtin_function_type): Ditto. + (builtin_function_eq): Ditto. + (builtin_hash_struct): Ditto. + (rs6000_init_builtins): Ditto. + (rs6000_common_init_builtins): Ditto. + (altivec_init_builtins): Ditto. + (rs6000_common_init_builtins): Ditto. + (enum reload_reg_type): New enum for simplifing reg classes. + (rs6000_reload_register_type): Simplify register classes into GPR, + Vector, and other registers. Altivec and VSX addresses in reload. + (rs6000_secondary_reload_inner): Ditto. + (rs6000_ira_cover_classes): New target hook, that returns the + appropriate cover classes, based on -mvsx being used or not. + (rs6000_secondary_reload_class): Add VSX support. + (get_vec_cmp_insn): Delete, rewrite vector conditionals. + (get_vsel_insn): Ditto. + (rs6000_emit_vector_compare): Rewrite vector conditional support + so that where we can, we use RTL operators, instead of blindly use + UNSPEC. + (rs6000_emit_vector_select): Ditto. + (rs6000_emit_vector_cond_expr): Ditto. + (rs6000_emit_minmax): Directly generate min/max under altivec, vsx. + (create_TOC_reference): Add -mdebug=addr support. + (emit_frame_save): VSX loads/stores need register indexed addressing. + + * config/rs6000/rs6000.md: Include vector.md. + + * config/rs6000/t-rs6000 (MD_INCLUDES): Add vector.md. + + * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Add + support for V2DI, V2DF in logical, permute, select operations. + + * config/rs6000/rs6000.opt (-mvsx-scalar-double): Add new debug + switch for vsx/power7. + (-mvsx-scalar-memory): Ditto. + (-mvsx-align-128): Ditto. + (-mallow-movmisalign): Ditto. + (-mallow-df-permute): Ditto. + (-msched-groups): Ditto. + (-malways-hint): Ditto. + (-malign-branch-targets): Ditto. + + * config/rs6000/rs6000.h (IRA_COVER_CLASSES): Delete, use target + hook instead. + (IRA_COVER_CLASSES_PRE_VSX): Cover classes if not -mvsx. + (IRA_COVER_CLASSES_VSX): Cover classes if -mvsx. + (rs6000_vector_reg_class): Delete. + (rs6000_vsx_reg_class): Ditto. + (enum rs6000_reg_class_enum): New enum for the constraints that + vary based on target switches. + (rs6000_constraints): New array to hold the register class for all + of the register constraints that vary based on the switches used. + (ALTIVEC_BUILTIN_*_UNS): Add unsigned builtin functions. + (enum rs6000_builtins): Add unsigned varients for the builtin + declarations returned by target hooks for expanding multiplies, + select, and permute operations. Add VSX builtins. + (enum rs6000_builtin_type_index): Add entries for VSX. + (V2DI_type_node): Ditto. + (V2DF_type_node): Ditto. + (unsigned_V2DI_type_node): Ditto. + (bool_long_type_node): Ditto. + (intDI_type_internal_node): Ditto. + (uintDI_type_internal_node): Ditto. + (double_type_internal_node): Ditto. + + * config/rs6000/altivec.md (whole file): Move all expanders to + vector.md from altivec.md. Rename insn matching functions to be + altivec_foo. + (UNSPEC_VCMP*): Delete, rewrite vector comparisons. + (altivec_vcmp*): Ditto. + (UNSPEC_VPERM_UNS): New, add for unsigned types using vperm. + (VM): New iterator for moves that includes the VSX types. + (altivec_vperm_<mode>): Add VSX types. Add unsigned types. + (altivec_vperm_<mode>_uns): New, for unsigned types. + (altivec_vsel_*): Rewrite vector comparisons and predicate builtins. + (altivec_eq<mode>): Ditto. + (altivec_gt<mode>): Ditto. + (altivec_gtu<mode>): Ditto. + (altivec_eqv4sf): Ditto. + (altivec_gev4sf): Ditto. + (altivec_gtv4sf): Ditto. + (altivec_vcmpbfp_p): Ditto. + +2009-07-23 Richard Earnshaw <rearnsha@arm.com> + + * arm.md (split for ior/xor with shift and zero-extend): Cast op3 to + unsigned HWI. + +2009-07-23 Uros Bizjak <ubizjak@gmail.com> + + PR target/40832 + * config/i386/i386.c (output_387_ffreep): Rewrite to use + ASM_SHORT instead of .word. + * config/i386/i386.md (*tls_global_dynamic_64): Use ASM_SHORT + instead of .word in asm template. + +2009-07-22 Vladimir Makarov <vmakarov@redhat.com> + + PR target/37488 + * ira-lives.c (bb_has_abnormal_call_pred): New function. + (process_bb_node_lives): Use it. + + * ira.c (setup_cover_and_important_classes): Don't setup + ira_important_class_nums. Add cover classes to the end of + important classes. + (cover_class_order, comp_reg_classes_func, reorder_important_classes): + New. + (find_reg_class_closure): Use reorder_important_classes. + + * config/i386/i386.h (IRA_COVER_CLASSES): Remove. + + * config/i386/i386.c (i386_ira_cover_classes): New function. + (TARGET_IRA_COVER_CLASSES): Redefine. + + * doc/tm.texi (TARGET_IRA_COVER_CLASSES): Add a comment about + importance of order of cover classes in the array. + +2009-07-22 Diego Novillo <dnovillo@google.com> + + * tree-pass.h (TDF_EH): Define. + * gimple-pretty-print.c (dump_gimple_stmt): If FLAGS + contains TDF_EH, print the EH region number holding GS. + * tree-dump.c (dump_options): Add "eh". + * doc/invoke.texi: Document it. + +2009-07-22 Doug Kwan <dougkwan@google.com> + + * config/arm/arm.md (subdi3) Copy non-reg values to DImode registers. + +2009-07-22 Michael Matz <matz@suse.de> + + PR tree-optimization/35229 + PR tree-optimization/39300 + + * tree-ssa-pre.c (includes): Include tree-scalar-evolution.h. + (inhibit_phi_insertion): New function. + (insert_into_preds_of_block): Call it for REFERENCEs. + (init_pre): Initialize and finalize scalar evolutions. + * Makefile.in (tree-ssa-pre.o): Depend on tree-scalar-evolution.h . + +2009-07-22 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/predicates.md (zero_extended_scalar_load_operand): + Use CONST_VECTOR_NUNITS to determine number of elements. + +2009-07-22 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/constraints.md (ZQ, ZR, ZS, ZT): New constraints. + (U, W): Constraints are now deprecated and will be removed if we + run out of letters. + * config/s390/s390.md (U, W): Replaced with ZQZR, ZSZT throughout + the file. + ("prefetch"): Add the stcmh instruction for prefetching. + * config/s390/s390.c (s390_symref_operand_p): Function moved. No + changes. + (s390_short_displacement): Return always true if compiling for + machines not providing the long displacement facility. + (s390_mem_constraint): Support the new constraint letter Z. + (s390_check_qrst_address): New function. + +2009-07-21 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (mep_legitimize_arg): Leave control registers + alone too. + +2009-07-21 Jason Merrill <jason@redhat.com> + + * c-common.c (max_tinst_depth): Increase default to 1024. + +2009-07-21 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/sse.md (vec_unpacku_float_hi_v4si): New expander. + (vec_unpacku_float_lo_v4si): Ditto. + +2009-07-21 Uros Bizjak <ubizjak@gmail.com> + + PR target/40811 + * config/i386/sse.md (sse2_cvtudq2ps): New expander. + (enum ix86_builtins): Add IX86_BUILTIN_CVTUDQ2PS. + (builtin_description): Add __builtin_ia32_cvtudq2ps. + (ix86_vectorize_builtin_conversion): Handle IX86_BUILTIN_CVTUDQ2PS. + +2009-07-21 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/40813 + * tree-inline.c (copy_bb): Regimplify RHS after last stmt, not before + it. + +2009-07-21 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (sh_gimplify_va_arg_expr): Wrap the result + with a NOP_EXPR if needed. + +2009-07-21 Paul Brook <paul@codesourcery.com> + + * tree-vectorizer.c (increase_alignment): Handle nested arrays. + Terminate debug dump with newline. + +2009-07-20 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa.c (compute_zdepwi_operands): Limit deposit length to 32 - lsb. + Cast "1" to unsigned HOST_WIDE_INT. + (compute_zdepdi_operands): Limit maximum length to 64 bits. Limit + deposit length to the maximum length - lsb. Extend length if + HOST_BITS_PER_WIDE_INT is 32. + +2009-07-20 Olatunji Ruwase <tjruwase@google.com> + + * cgraph.h (constant_pool_htab): New function. + (constant_descriptor_tree): Move from varasm.c. + * varasm.c (constant_pool_htab): New function. + (constant_descriptor_tree): Move to cgraph.h. + +2009-07-20 Olatunji Ruwase <tjruwase@google.com> + + * toplev.c: Invoke FINISH_UNIT callbacks before call to finalize(). + +2009-07-20 Shujing Zhao <pearly.zhao@oracle.com> + + * Makefile.in (TREE_INLINE_H, tree-inline.o, cgraph.o): Remove + $(VARRAY_H). + +2009-07-20 Xinliang David Li <davidxl@google.com> + + * dbgcnt.c (dbg_cnt_set_limit_by_name): Add length check. + +2009-07-20 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (move_type): Add arith. + (type): Handle arith. + (zero_extendsidi2): Rename this into ... + (*zero_extendsidi2): ... this. Don't match if ISA_HAS_EXT_INS. + (zero_extendsidi2): New expander. + (*zero_extendsidi2_dext): New pattern. + +2009-07-20 Nick Clifton <nickc@redhat.com> + + * config.gcc (mips64-*-*): Add definition of tm_defines in order + to set MIPS_ABI_DEFAULT. + * config/mips/vr.h (MIPS_ABI_DEFAULT): Remove definition. + +2009-07-20 Jakub Jelinek <jakub@redhat.com> + + * tree-object-size.c (addr_object_size): Handle unions with + array in it as last field of structs in __bos (, 1) as __bos (, 0). + + PR tree-optimization/40792 + * tree.c (build_function_type_skip_args): Remove bogus assert. + +2009-07-20 Jan Hubicka <jh@suse.cz> + Martin Jambor <mjambor@suse.cz> + + * cgraph.h (combined_args_to_skip): New field. + * cgraph.c (cgraph_create_virtual_clone): Properly handle + combined_args_to_skip and args_to_skip. + * tree-inline.c (update_clone_info): New function. + (tree_function_versioning): Call update_clone_info. + * cgraphunit.c (cgraph_materialize_clone): Dump materialized + functions. + (cgraph_materialize_all_clones): More extensive dumping, working + with combined_args_to_skip rather than args_to_skip. + +2009-07-20 Ira Rosen <irar@il.ibm.com> + + * tree-vectorizer.h (vectorizable_condition): Add parameters. + * tree-vect-loop.c (vect_is_simple_reduction): Support COND_EXPR. + (get_initial_def_for_reduction): Likewise. + (vectorizable_reduction): Skip the check of first operand in case + of COND_EXPR. Add check that it is outer loop vectorization if + nested cycle was detected. Call vectorizable_condition() for + COND_EXPR. If reduction epilogue cannot be created do not fail for + nested cycles (if it is not double reduction). Assert that there + is only one type in the loop in case of COND_EXPR. Call + vectorizable_condition() to vectorize COND_EXPR. + * tree-vect-stmts.c (vectorizable_condition): Update comment. + Add parameters. Allow nested cycles if called from + vectorizable_reduction(). Use reduction vector variable if provided. + (vect_analyze_stmt): Call vectorizable_reduction() before + vectorizable_condition(). + (vect_transform_stmt): Update call to vectorizable_condition(). + +2009-07-20 Christian Bruel <christian.bruel@st.com> + + * config/sh/sh.opt (-mfmovd): Resurrect and document. + * doc/invoke.texi (-mfmovd): Likewise. + * config/sh/sh.h (TARGET_FMOVD, MASK_FMOVD): Remove default setting. + +2009-07-20 Jan Hubicka <jh@suse.cz> + + * tree-ssa-dce.c (remove_dead_phis): Only look for abnormal PHIs + when handling SSA name. + +2009-07-19 Jan Hubicka <jh@suse.cz> + + PR tree-optimization/40676 + * tree-ssa-dce.c (eliminate_unnecessary_stmts): Do renaming on all + virtual PHIs in empty BBs. + +2009-07-18 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (make_compound_operation) <SUBREG>: If force_to_mode + re-expanded the compound use gen_lowpart instead to convert to the + desired mode. + +2009-07-18 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (try_widen_shift_mode): Add COUNT, OUTER_CODE and + OUTER_CONST arguments. + <LSHIFTRT>: Use them to allow widening if the bits shifted in from + the new wider mode will be masked off. + (simplify_shift_const_1): Adjust calls to try_widen_shift_mode. + +2009-07-18 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (try_widen_shift_mode) <LSHIFTRT>: Allow widening if the + high-order bits are zero. + +2009-07-18 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (simplify_shift_const_1): Split code to determine + shift_mode into ... + (try_widen_shift_mode): ... here. Allow widening for ASHIFTRT if the + new bits shifted in are identical to the old sign bit. + +2009-07-18 Richard Guenther <rguenther@suse.de> + + PR c/40787 + * gimplify.c (gimplify_call_expr): Reject code using results from + functions returning void. + +2009-07-18 Richard Sandiford <r.sandiford@uk.ibm.com> + + * doc/md.texi: Document the new PowerPC "es" constraint. + Document that "m" can include automodified addresses on this target, + and explain how %U must be used. Extend the "Q" and "Z" documentation + to suggest "es" as well as "m". + * config/rs6000/constraints.md (es): New memory constraint. + (Q, Z): Update strings to match new documentation. + +2009-07-18 Richard Sandiford <r.sandiford@uk.ibm.com> + + * config/rs6000/rs6000.c (rs6000_mode_dependent_address): Allow any + offset from virtual_stack_vars_rtx and arg_pointer_rtx. + * config/rs6000/predicates.md (volatile_mem_operand): Use + offsettable_nonstrict_memref_p. + * config/rs6000/rs6000.md (*floatsidf2_internal): Remove split check. + (*floatunssidf2_internal): Likewise. + (*fix_truncdfsi2_internal): Likewise. + (*fix_trunctfsi2_internal): Likewise. + +2009-07-17 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr-devices.c (avr_mcu_t): Add atmega8u2, atmega16u2 and + atmega32u2 devices. + * config/avr/t-avr (MULTILIB_MATCHES): (Ditto.). + +2009-07-17 Richard Guenther <rguenther@suse.de> + + PR c/40401 + * tree-pass.h (pass_diagnose_omp_blocks): Declare. + (pass_warn_unused_result): Likewise. + (TODO_set_props): Remove. + * omp-low.c (diagnose_omp_structured_block_errors): Change to + run as a pass. + (pass_diagnose_omp_blocks): Define. + * c-decl.c (pop_file_scope): Do not finalize the CU here. + (c_gimple_diagnostics_recursively): Remove. + (finish_function): Do not call it. + (c_write_global_declarations): Continue after errors. + Finalize the CU here. + * c-gimplify.c (c_genericize): Do not gimplify here. + * c-common.c (c_warn_unused_result): Move ... + * tree-cfg.c (do_warn_unused_result): ... here. + (run_warn_unused_result): New function. + (gate_warn_unused_result): New function. + (pass_warn_unused_result): New pass. + * c-common.h (c_warn_unused_result): Remove. + * flags.h (flag_warn_unused_result): Declare. + * c-opts.c (c_common_init_options): Enable flag_warn_unused_result. + * opts.c (flag_warn_unused_result): Initialize to false. + * toplev.c (compile_file): Add comment. + * omp-low.c (create_omp_child_function): Do not register + the function with the frontend. + (diagnose_omp_structured_block_errors): Prepare to be + called as optimization pass. + (gate_diagnose_omp_blocks): New function. + (pass_diagnose_omp_blocks): New pass. + * cgraph.h (cgraph_optimize): Remove. + (cgraph_analyze_function): Likewise. + * cgraph.c (cgraph_add_new_function): Gimplify C++ thunks. + * cgraphunit.c (cgraph_lower_function): Lower nested functions + before their parents here. + (cgraph_finalize_function): Not here. + (cgraph_analyze_function): Gimplify functions here. + (cgraph_finalize_compilation_unit): Continue after errors. + Optimize the callgraph from here. + (cgraph_optimize): Make static. + * langhooks.c (write_global_declarations): Finalize the CU. + * gimplify.c (gimplify_asm_expr): Do not emit ASMs with errors. + (gimplify_function_tree): Assert we gimplify only once. + Set PROP_gimple_any property. + * tree-nested.c (gimplify_all_functions): New function. + (lower_nested_functions): Gimplify all nested functions. + * gimple.h (diagnose_omp_structured_block_errors): Remove. + * passes.c (init_optimization_passes): Add pass_warn_unused_result + and pass_diagnose_omp_blocks after gimplification. Do not + set TODO_set_props on all_lowering_passes. + (execute_one_pass): Do not handle TODO_set_props. + * Makefile.in (cgraphunit.o): Add $(TREE_DUMP_H) dependency. + (gimplify.o): Add tree-pass.h dependency. + * tree-inline.c (copy_statement_list): Properly copy STATEMENT_LIST. + (copy_tree_body_r): Properly handle TARGET_EXPR like SAVE_EXPR. + (unsave_r): Likewise. + * c-omp.c (c_finish_omp_atomic): Set DECL_CONTEXT on the + temporary variable. + +2009-07-17 Sandra Loosemore <sandra@codesourcery.com> + + * doc/service.texi (Service): Restore previously removed link, + which isn't broken after all. + +2009-07-17 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40321 + * tree-ssa-pre.c (add_to_exp_gen): Also add names defined by + PHI nodes to the maximal set. + (make_values_for_phi): Add PHI arguments to the maximal set. + (execute_pre): Dump PHI_GEN and the maximal set. + +2009-07-17 Jakub Jelinek <jakub@redhat.com> + + PR c++/40780 + * gimplify.c (gimplify_conversion): Don't change non-conversions into + VIEW_CONVERT_EXPR. + +2009-07-16 Sandra Loosemore <sandra@codesourcery.com> + + * doc/extend.texi (Nested Functions): Replace broken link with + textual reference. + * doc/service.texi (Service): Remove broken link. + +2009-07-16 H.J. Lu <hongjiu.lu@intel.com> + + PR bootstrap/40781 + * builtins.c (expand_builtin_memcmp): Use loc instead of + EXPR_LOCATION (exp). + (expand_builtin_strncmp): Likewise. + +2009-07-17 Aldy Hernandez <aldyh@redhat.com> + Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR 40435 + * tree-complex.c, tree-loop-distribution.c, tree.c, tree.h, + builtins.c, fold-const.c, omp-low.c, cgraphunit.c, tree-ssa-ccp.c, + tree-ssa-dom.c, gimple-low.c, expr.c, tree-ssa-ifcombine.c, + c-decl.c, stor-layout.c, tree-if-conv.c, c-typeck.c, gimplify.c, + calls.c, tree-sra.c, tree-mudflap.c, tree-ssa-copy.c, + tree-ssa-forwprop.c, c-convert.c, c-omp.c, varasm.c, + tree-inline.c, c-common.c, c-common.h, gimple.c, + tree-switch-conversion.c, gimple.h, tree-cfg.c, c-parser.c, + convert.c: Add location argument to fold_{unary,binary,ternary}, + fold_build[123], build_call_expr, build_size_arg, + build_fold_addr_expr, build_call_array, non_lvalue, size_diffop, + fold_build1_initializer, fold_build2_initializer, + fold_build3_initializer, fold_build_call_array, + fold_build_call_array_initializer, fold_single_bit_test, + omit_one_operand, omit_two_operands, invert_truthvalue, + fold_truth_not_expr, build_fold_indirect_ref, fold_indirect_ref, + combine_comparisons, fold_builtin_*, fold_call_expr, + build_range_check, maybe_fold_offset_to_address, round_up, + round_down. + +2009-07-16 Jason Merrill <jason@redhat.com> + + PR libstdc++/37907 + * c-common.c (c_common_reswords): Add __is_standard_layout + and __is_trivial. + * c-common.h (enum rid): Add RID_IS_STD_LAYOUT and RID_IS_TRIVIAL. + * doc/implement-cxx.texi: New. + * doc/gcc.texi: Include it. + +2009-07-16 DJ Delorie <dj@redhat.com> + + * config/m32c/m32c.c (m32c_compare_redundant): Avoid removing + compares that may be indirectly affected by previous instructions. + +2009-07-16 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * builtins.c (do_mpc_arg2): New. + (fold_builtin_2): Fold builtin cpow. + * real.h (HAVE_mpc_pow): New. + +2009-07-16 Bingfeng Mei <bmei@broadcom.com> + + * modulo-sched.c (sms_schedule): stage_count <= 1 as correct + comparison to skip unprofitable schedule + +2009-07-16 Simon Baldwin <simonb@google.com> + + * gcc.c (option_map): New flag -no-canonical-prefixes. + * (display_help): Print help text for new flag. + * (process_command): Move options translation and language specifics + and handle new flag early. Use it to set a function pointer to a + prefix builder. Replace make_relative_prefix calls with calls to + the function pointed to. Ignore new flag in regular options handling. + * doc/invoke.texi (Overall Options): Documented -no-canonical-prefixes. + +2009-07-15 DJ Delorie <dj@redhat.com> + + * config/mep/mep.md (sibcall_internal): Change register to avoid + argument registers. + (sibcall_value_internal): Likewise. + +2009-07-15 Eric Botcazou <ebotcazou@adacore.com> + + PR rtl-optimization/40710 + * resource.c (mark_target_live_regs): Reset DF problem to LR. + +2009-07-15 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (*extenddi_truncate<mode>, + *extendsi_truncate<mode>): Change type attribute to move_type + with shift_shift. Split out code handling exts from here ... + (*extend<GPR:mode>_truncate<SHORT:mode>_exts): ... to this new + pattern. + (*extendhi_truncateqi): Change type attribute to move_type with + shift_shift. Split out code handling exts from here ... + (*extendhi_truncateqi_exts): ... to this new pattern. + +2009-07-15 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/sse.md (copysign<mode>3): Use "and-not" SSE instruction + instead of "and" with inverted sign bit mask value. Use + "nonimmediate_operand" for operand 1 and operand 2 predicate. + Allocate registers only for operand 4 and operand 5. + +2009-07-15 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40747 + * fold-const.c (fold_cond_expr_with_comparison): When folding + < and <= to MIN, make sure the MIN uses the same type as the + comparison's operands. + +2009-07-15 Richard Earnshaw <rearnsha@arm.com> + + * arm.md (ior_xor): New code iterator. + (split for ior/xor with shift and zero-extend): New split pattern. + * arm/predicates.md (subreg_lowpart_operator): New special predicate. + +2009-07-15 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (make_constraint_from_heapvar): Initialize + offset member. + +2009-07-15 Richard Guenther <rguenther@suse.de> + + PR middle-end/40753 + * alias.c (ao_ref_from_mem): Reject FUNCTION_DECL and LABEL_DECL bases. + +2009-07-15 Maxim Kuvyrkov <maxim@codesourcery.com> + + * config/m68k/linux-unwind.h (m68k_fallback_frame_state): Update to + handle 2.6.30 kernel. + +2009-07-15 DJ Delorie <dj@redhat.com> + + * config/mep/mep.md (sibcall_internal): Change register to allow + for 24-bit addresses. + (sibcall_value_internal): Likewise. + +2009-07-14 Ghassan Shobaki <ghassan.shobaki@amd.com> + + * doc/invoke.texi: Added descriptions of the scheduling heuristics + that are enabled/disabled by the flags introduced by a previous patch. + +2009-07-14 DJ Delorie <dj@redhat.com> + + * config/mep/mep.md (sibcall_internal): Include non-toggling + non-jmp case. + (sibcall_value_internal): Likewise. + +2009-07-14 Taras Glek <tglek@mozilla.com> + Rafael Espindola <espindola@google.com> + + * doc/sourcebuild.texi: Document install-plugin target. + * configure.ac: Added install-plugin target to language makefiles. + * configure: Regenerate. + * Makefile.in (install-plugin): Install more headers, + depend on lang.install-plugin. + +2009-07-15 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * tree-vrp.c (vrp_evaluate_conditional): Mark strings for + translation. + +2009-07-14 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (mep_vliw_jmp_match): New function. + * config/mep/mep-protos.h (mep_vliw_jmp_match): Prototype it. + * config/mep/mep.md (sibcall_internal): Change test from + mep_vliw_mode_match to mep_vliw_jmp_match. + (sibcall_value_internal): Likewise. + +2009-07-14 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/sse.md (copysign<mode>3): New expander. + * config/i386/i386-protos.h (ix86_build_signbit_mask): New prototype. + * config/i386/i386.c (ix86_build_signbit_mask): Make public. + Use ix86_build_const_vector. + (enum ix86_builtins): Add IX86_BUILTIN_CPYSGNPS and + IX86_BUILTIN_CPYSGNPD. + (builtin_description): Add __builtin_ia32_copysignps and + __builtin_ia32_copysignpd. + (ix86_builtin_vectorized_function): Handle BUILT_IN_COPYSIGN + and BUILT_IN_COPYSIGNF. + +2009-07-13 Jason Merrill <jason@redhat.com> + + * builtins.c (can_trust_pointer_alignment): New fn. + (get_pointer_alignment): Factor it out from here. + * tree.h: Declare it. + +2009-07-14 David Edelsohn <edelsohn@gnu.org> + + * config/rs6000/predicates.md (offsettable_mem_operand): Test + RTX_AUTOINC class. + +2009-07-14 Dodji Seketeli <dodji@redhat.com> + + PR debug/40705 + PR c++/403057 + * dwarf2.out.c (gen_type_die_with_usage): Added comment. + +2009-07-14 Richard Guenther <rguenther@suse.de> + Andrey Belevantsev <abel@ispras.ru> + + PR middle-end/40745 + * cfgexpand.c (partition_stack_vars): Do not bother to update + alias information when not optimizing. + +2009-07-14 Richard Guenther <rguenther@suse.de> + Andrey Belevantsev <abel@ispras.ru> + + * tree-ssa-alias.h (refs_may_alias_p_1): Declare. + (pt_solution_set): Likewise. + * tree-ssa-alias.c (refs_may_alias_p_1): Export. + * tree-ssa-structalias.c (pt_solution_set): New function. + * final.c (rest_of_clean_state): Free SSA data structures. + * print-rtl.c (print_decl_name): Remove. + (print_mem_expr): Implement in terms of print_generic_expr. + * alias.c (ao_ref_from_mem): New function. + (rtx_refs_may_alias_p): Likewise. + (true_dependence): Query alias-export info. + (canon_true_dependence): Likewise. + (write_dependence_p): Likewise. + * tree-dfa.c (get_ref_base_and_extent): For void types leave + size unknown. + * emit-rtl.c (component_ref_for_mem_expr): Remove. + (mem_expr_equal_p): Use operand_equal_p. + (set_mem_attributes_minus_bitpos): Do not use + component_ref_for_mem_expr. + * cfgexpand.c (add_partitioned_vars_to_ptset): New function. + (update_alias_info_with_stack_vars): Likewise. + (partition_stack_vars): Call update_alias_info_with_stack_vars. + * tree-ssa.c (delete_tree_ssa): Do not release SSA names + explicitly nor clear stmt operands. + Free the decl-to-pointer map. + * tree-optimize.c (execute_free_datastructures): Do not free + SSA data structures here. + * tree-flow.h (struct gimple_df): Add decls_to_pointers member. + * Makefile.in (emit-rtl.o): Add pointer-set.h dependency. + (alias.o): Add tree-ssa-alias.h, pointer-set.h and $(TREE_FLOW_H) + dependencies. + (print-rtl.o): Add $(DIAGNOSTIC_H) dependency. + +2009-07-13 DJ Delorie <dj@redhat.com> + + * config/mep/mep.h (CC1_SPEC): Tweak parameters to trigger + unrolling at the right iteration count. + + * config/mep/mep.c (mep_expand_prologue): Fix frame pointer + calculations. + +2009-07-13 Ghassan Shobaki <ghassan.shobaki@amd.com> + + * haifa-sched.c (rank_for_schedule): Introduced flags to + enable/disable individual scheduling heuristics. + * common.opt: Introduced flags to enable/disable individual + heuristics in the scheduler. + * doc/invoke.texi: Introduced flags to enable/disable individual + heuristics in the scheduler. + +2009-07-13 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/t-gthr-win32 (LIB2FUNCS_EXTRA): Remove file + config/i386/mingw-tls.c. + * config/i386/mingw-tls.c: Removed. + +2009-07-13 Ira Rosen <irar@il.ibm.com> + + * tree-vect-loop.c (get_initial_def_for_reduction): Ensure that the + checks access only relevant statements. + (vectorizable_reduction): Likewise. + +2009-07-12 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/cygming.h (TARGET_OS_CPP_BUILTINS): Define _X86_ + just for 32-bit case. + +2009-07-12 Jan Hubicka <jh@suse.cz> + + PR tree-optimization/40585 + * except.c (expand_resx_expr): When there already is resume + instruction, produce linked list. + (build_post_landing_pads): Assert that resume is empty. + (connect_post_landing_pads): Handle resume lists. + (dump_eh_tree): Dump resume list. + +2009-07-12 Ira Rosen <irar@il.ibm.com> + + * tree-parloops.c (loop_parallel_p): Call vect_is_simple_reduction + with additional argument. + * tree-vectorizer.h (enum vect_def_type): Add + vect_double_reduction_def. + (vect_is_simple_reduction): Add argument. + * tree-vect-loop.c (vect_determine_vectorization_factor): Fix + indentation. + (vect_analyze_scalar_cycles_1): Detect double reduction. Call + vect_is_simple_reduction with additional argument. + (vect_analyze_loop_operations): Handle exit phi nodes in case of + double reduction. + (reduction_code_for_scalar_code): Handle additional codes by + returning ERROR_MARK for them. Fix comment and indentation. + (vect_is_simple_reduction): Fix comment, add argument to specify + double reduction. Detect double reduction. + (get_initial_def_for_induction): Fix indentation. + (get_initial_def_for_reduction): Fix comment and indentation. + Handle double reduction. Create initial definitions that do not + require adjustment if ADJUSTMENT_DEF is NULL. Handle additional cases. + (vect_create_epilog_for_reduction): Fix comment, add argument to + handle double reduction. Use PLUS_EXPR in case of MINUS_EXPR in + epilogue result extraction. Create double reduction phi node and + replace relevant uses. + (vectorizable_reduction): Call vect_is_simple_reduction with + additional argument. Fix indentation. Update epilogue code treatment + according to the changes in reduction_code_for_scalar_code. Check + for double reduction. Call vect_create_epilog_for_reduction with + additional argument. + * tree-vect-stmts.c (process_use): Handle double reduction, update + documentation. + (vect_mark_stmts_to_be_vectorized): Handle double reduction. + (vect_get_vec_def_for_operand): Likewise. + +2009-07-12 Danny Smith <dansmister@gmail.com> + + * config/i386/winnt.c (i386_pe_determine_dllexport_p): Don't + dllexport if !TREE_PUBLIC. + (i386_pe_maybe_record_exported_symbol): Assert TREE_PUBLIC. + +2009-07-11 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.h (TARGET_CPU_CPP_BUILTINS): Redefine. + (avr_extra_arch_macro) Remove declatation. + * config/avr/avr.c (avr_cpu_cpp_builtins): New function. + (avr_extra_arch_macro) Declare as static. + * config/avr/avr-protos.h (avr_cpu_cpp_builtins): Dclare. + +2009-07-11 Jan Hubicka <jh@suse.cz> + + PR middle-end/48388 + * except.c (can_be_reached_by_runtime): Test for NULL aka bitmap. + +2009-07-11 Jakub Jelinek <jakub@redhat.com> + + PR debug/40713 + * dwarf2out.c (dw_fde_struct): Add in_std_section and + cold_in_std_section bits. + (dwarf2out_begin_prologue): Initialize them. + (dwarf2out_finish): Don't emit FDE range into .debug_ranges + if already covered by text_section or cold_text_section range. + + PR rtl-optimization/40667 + * defaults.h (MINIMUM_ALIGNMENT): Define if not defined. + * doc/tm.texi (MINIMUM_ALIGNMENT): Document it. + * config/i386/i386.h (MINIMUM_ALIGNMENT): Define. + * config/i386/i386.c (ix86_minimum_alignment): New function. + * config/i386/i386-protos.h (ix86_minimum_alignment): New prototype. + * cfgexpand.c (expand_one_var): Use MINIMIM_ALIGNMENT. + * emit-rtl.c (gen_reg_rtx): Likewise. + * function.c (assign_parms): Likewise. If nominal_type needs + bigger alignment than FUNCTION_ARG_BOUNDARY, use its alignment + rather than passed_type's alignment. + + PR target/40668 + * function.c (assign_parm_setup_stack): Adjust + MEM_OFFSET (data->stack_parm) if promoted_mode is different + from nominal_mode on big endian. + +2009-07-11 Paolo Bonzini <bonzini@gnu.org> + + * expmed.c (emit_store_flag_1): Fix choice of zero vs. sign extension. + +2009-07-10 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (mep_can_inline_p): Correct logic, and simplify. + +2009-07-10 Mark Mitchell <mark@codesourcery.com> + + * config/arm/thumb2.md (thumb2_cbz): Correct computation of length + attribute. + (thumb2_cbnz): Likewise. + +2009-07-10 David Daney <ddaney@caviumnetworks.com> + + PR target/39079 + * config.gcc (supported_defaults): Add synci. + (with_synci): Add validation. + (all_defaults): Add synci. + * config/mips/mips.md (clear_cache): Use TARGET_SYNCI instead of + ISA_HAS_SYNCI. + (synci): Same. + * config/mips/mips.opt (msynci): New option. + * config/mips/mips.c (mips_override_options): Warn on use of + -msynci for targets that do now support it. + * gcc/config/mips/mips.h (OPTION_DEFAULT_SPECS): Add a default for + msynci. + * gcc/doc/invoke.texi (-msynci): Document the new option. + * doc/install.texi (--with-synci): Document the new option. + +2009-07-10 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40496 + * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop): Create + the PHI result with a compatible type. + +2009-07-10 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR 25509 + PR 40614 + * c.opt (Wunused-result): New. + * doc/invoke.texi: Document it. + * c-common.c (c_warn_unused_result): Use it. + +2009-07-09 DJ Delorie <dj@redhat.com> + + * targhooks.c (default_target_can_inline_p): Rename from + default_target_option_can_inline_p. + * targhooks.h (default_target_can_inline_p): Likewise. + * target-def.h (TARGET_CAN_INLINE_P): Rename from + TARGET_OPTION_CAN_INLINE_P. + * config/i386/i386.c (TARGET_CAN_INLINE_P): Likewise. + * config/mep/mep.c (TARGET_CAN_INLINE_P): Likewise. + (mep_target_can_inline_p): Rename from + mep_target_option_can_inline_p. + + PR target/40626 + * config/mep/mep.h (FUNCTION_ARG_REGNO_P): Add coprocessor + registers used to pass vectors. + + * config/mep/mep.c (mep_option_can_inline_p): Remove error call. + +2009-07-09 Tom Tromey <tromey@redhat.com> + + * unwind-dw2-fde-darwin.c: Include dwarf2.h. + * config/mmix/mmix.c: Include dwarf2.h. + * config/rs6000/darwin-fallback.c: Include dwarf2.h. + * config/xtensa/unwind-dw2-xtensa.c: Include dwarf2.h. + * config/sh/sh.c: Include dwarf2.h. + * config/i386/i386.c: Include dwarf2.h. + * Makefile.in (DWARF2_H): Remove 'elf'. + * except.c: Include dwarf2.h. + * unwind-dw2.c: Include dwarf2.h. + * dwarf2out.c: Include dwarf2.h. + * unwind-dw2-fde-glibc.c: Include dwarf2.h. + * unwind-dw2-fde.c: Include dwarf2.h. + * dwarf2asm.c: Include dwarf2.h. + +2009-07-09 Maxim Kuvyrkov <maxim@codesourcery.com> + + * haifa-sched.c (insn_finishes_cycle_p): New static function. + (max_issue): Use it. + * sched-int.h (struct sched_info: insn_finishes_block_p): New + scheduler hook. + * sched-rgn.c (rgn_insn_finishes_block_p): Implement it. + (region_sched_info): Update. + * sched-ebb.c (ebb_sched_info): Update. + * modulo-sched.c (sms_sched_info): Update. + * sel-sched-ir.c (sched_sel_haifa_sched_info): Update. + +2009-07-09 Maxim Kuvyrkov <maxim@codesourcery.com> + + * varasm.c (build_constant_desc): Don't share RTL in pool entries. + +2009-07-09 Basile Starynkevitch <basile@starynkevitch.net> + + * plugin.c (try_init_one_plugin): passes RTLD_GLOBAL to dlopen. + +2009-07-09 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40692 + * fold-const.c (fold_cond_expr_with_comparison): Don't replace + arg1 with arg01 if arg1 is already INTEGER_CST. + +2009-07-08 Adam Nemet <anemet@caviumnetworks.com> + + * simplify-rtx.c (simplify_binary_operation_1) <AND>: + Transform (and (truncate)) into (truncate (and)). + +2009-07-08 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (make_extraction): Check TRULY_NOOP_TRUNCATION before + creating LHS paradoxical subregs. Fix surrounding returns to + use NULL_RTX rather than 0. + +2009-07-08 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (mep_option_can_inline_p): New. + (TARGET_OPTION_CAN_INLINE_P): Define. + +2009-07-08 Mark Wielaard <mjw@redhat.com> + + PR debug/40659 + * dwarf2out.c (add_data_member_location_attribute): When we have + only a constant offset don't emit a new location description using + DW_OP_plus_uconst, but just add the constant with add_AT_int, when + dwarf_version > 2. + +2009-07-08 Richard Henderson <rth@redhat.com> + + PR target/38900 + * config/i386/i386.h (CONDITIONAL_REGISTER_USAGE): Move to i386.c. + (enum reg_class): Add CLOBBERED_REGS. + (REG_CLASS_NAMES, REG_CLASS_CONTENTS): Likewise. + * config/i386/i386.c (ix86_conditional_register_usage): Moved + from CONDITIONAL_REGISTER_USAGE; build CLOBBERED_REGS for 64-bit. + (ix86_function_ok_for_sibcall): Tidy. Disallow MS->SYSV sibcalls. + (ix86_expand_call): Use sibcall_insn_operand when needed. Don't + force 64-bit sibcalls into R11. + * config/i386/constraints.md (U): New constraint. + * config/i386/i386.md (sibcall_1, sibcall_value_1): Use it. + (sibcall_1_rex64, sibcall_value_1_rex64): Likewise. + (sibcall_1_rex64_v, sibcall_value_1_rex64_v): Remove. + +2009-07-08 Shujing Zhao <pearly.zhao@oracle.com> + + * basic-block.h (dump_regset, debug_regset): Remove duplicate + prototypes. + * c-objc-common.h (c_initialize_diagnostics): Ditto. + * ebitmap.h (dump_ebitmap): Ditto. + * optabs.h (optab_libfunc): Ditto. + * tree.h (tree_expr_nonzero_warnv_p): Ditto. + * tree-flow.h (vect_can_force_dr_alignment_p, + get_vectype_for_scalar_type): Ditto. + (vectorize_loops): Move prototype to ... + * tree-vectorizer.h: ... here. Also, adjust comment. + (vect_set_verbosity_level): Remove duplicate prototype. + * tree-ssa-loop.c: Include tree-vectorizer.h. + * Makefile.in (tree-ssa-loop.o): Depend on tree-vectorizer.h. + +2009-07-08 Nick Clifton <nickc@redhat.com> + + * config/i386/unix.h (ASM_COMMENT_START): Add a space after the + forward slash. + +2009-07-08 DJ Delorie <dj@redhat.com> + + * config/mep/mep-ivc2.cpu (cpmovtocsar0_C3, cpmovtocsar1_C3, + cpmovtocc_C3, cpmovtocsar0_P0S_P1, cpmovtocsar1_P0S_P1, + cpmovtocc_P0S_P1): Mark volatile. Note which registers are + written to. + * config/mep/intrinsics.md: Regenerated. + * config/mep/mep.c (mep_interrupt_saved_reg): Save IVC2 control + registers when asm() or calls are detected. + +2009-07-08 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR c++/31246 + * gimplify.c (gimplify_expr): Propagate no_warning flag when + gimplifying. + * gimple (gimple_build_call_from_tree): Likewise. + * tree-cfg.c (remove_useless_stmts_warn_notreached): Check + no_warning flag before warning. + +2009-07-07 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * tree.c (set_expr_locus): Remove. + * tree.h (EXPR_LOCUS,SET_EXPR_LOCUS,set_expr_locus): Remove. + * c-typeck.c (c_finish_stmt_expr): Replace EXPR_LOCUS by + EXPR_LOCATION. + * gimplify.c (internal_get_tmp_var): Likewise. + (gimplify_call_expr): Likewise. + (gimplify_one_sizepos): Likewise. + +2009-07-07 Eric Botcazou <ebotcazou@adacore.com> + + PR debug/40666 + * dbxout.c (dbxout_symbol) <PARM_DECL>: Deal with parameters pointing + to variables for debugging purposes. + +2009-06-23 Mark Loeser <mark@halcy0n.com> + + PR build/40010 + * Makefile.in (gcc.pod): Depend on gcc-vers.texi. + +2009-07-07 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * pretty-print.c (pp_base_format): Remove %J. + * c-format.c (gcc_diag_char_table, gcc_tdiag_char_table, + gcc_cxxdiag_char_table): Likewise. + (init_dynamic_diag_info): Likewise. + +2009-07-07 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * pretty-print.c (pp_base_format): Remove %H. + * c-format.c (gcc_diag_char_table, gcc_tdiag_char_table, + gcc_cxxdiag_char_table): Likewise. + (init_dynamic_diag_info): Likewise. + * config/mep/mep.c (mep_select_section): Likewise. + +2009-07-07 Duncan Sands <baldrick@free.fr> + + * final.c (pass_clean_state): Give the pass a name. + * passes.c (pass_rest_of_compilation): Likewise. + * tree-optimize.c (pass_all_optimizations): Likewise. + +2009-07-07 H.J. Lu <hongjiu.lu@intel.com> + + * config/ia64/ia64.c (ia64_handle_model_attribute): Remove + an extra 'decl' for error_at. + +2009-07-07 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40669 + * tree-tailcall.c (adjust_return_value_with_ops, + create_tailcall_accumulator): Set DECL_GIMPLE_REG_P on the temporary + if it has complex or vector type. + +2009-07-07 Olivier Hainque <hainque@adacore.com> + + * config/alpha/t-osf4 (SHLIB_LINK): Do not hide the dummy weak + pthread symbols. + +2009-07-07 Basile Starynkevitch <basile@starynkevitch.net> + + * Makefile.in: added more lists of includes to PLUGIN_HEADERS. + +2009-07-07 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * cgraphunit.c: Replace %J by an explicit location. Update all calls. + * c-decl.c: Likewise. + * function.c: Likewise. + * varasm.c: Likewise. + * tree-ssa.c: Likewise. + * c-common.c: Likewise. + * tree-cfg.c: Likewise. + * config/spu/spu.c: Likewise. + * config/ia64/ia64.c: Likewise. + * config/v850/v850.c: Likewise. + +2009-07-06 DJ Delorie <dj@redhat.com> + + * config/mep/mep-core.cpu (fsft, ssarb): Mark as VOLATILE. + * config/mep/mep-ivc2.cpu (many): Add VOLATILE to more insns that make + unspecified accesses to control registers. + * config/mep/intrinsics.md: Regenerate. + * config/mep/intrinsics.h: Regenerate. + * config/mep/mep-intrin.h: Regenerate. + +2009-07-07 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * c-lex.c: Replace %H by an explicit location. Update all calls. + * c-common.c: Likewise. + * c-decl.c: Likewise. + * c-typeck.c: Likewise. + * fold-const.c: Likewise. + * gimplify.c: Likewise. + * stmt.c: Likewise. + * tree-cfg.c: Likewise. + * tree-ssa-loop-niter.c: Likewise. + * tree-vrp.c: Likewise. + * value-prof.c: Likewise. + +2009-07-06 Diego Novillo <dnovillo@google.com> + + * tree-dfa.c (dump_variable): Write DECL_INITIAL for VAR + if it has one. Handle cases where VAR does not have an + annotation or cfun is NULL. + +2009-07-06 Diego Novillo <dnovillo@google.com> + + * tree.c: Include debug.h. + (initialize_tree_contains_struct): New. + (init_ttree): Call it. + (tree_node_structure_for_code): Factor out of ... + (tree_node_structure): ... here. + * treestruct.def (TS_PHI_NODE): Remove. + (TS_GIMPLE_STATEMENT): Remove. + +2009-07-06 Diego Novillo <dnovillo@google.com> + + * tree-pretty-print.c (dump_generic_node): Protect against NULL op0. + (debug_tree_chain): Handle cycles. + +2009-07-06 Nick Clifton <nickc@redhat.com> + DJ Delorie <dj@redhat.com> + + * config.sh/lib1funcs.h (FMOVD_WORKS): Only define if + __FMOVD_ENABLED__ is defined. + * config/sh/sh.h + (TARGET_FMOVD): Provide a default definition. + (MASK_FMOVD): Likewise. + (TARGET_CPU_CPP_BUILTINS): Define + __FMOVD_ENABLED__ if TARGET_FMOVD is true. + * config/sh/sh.md (movdf_i4): For alternative 0 use either one or + two fmov instructions depending upon whether TARGET_FMOVD is enabled. + (split for DF load from memory into register): Also handle + MEMs which consist of REG+DISP addressing. + (split for DF store from register to memory): Likewise. + (movsf_ie): Always use single fp_mode. + * config/sh/sh.c (sh_override_options): Do not automatically + enable TARGET_MOVD for the SH2A when supporting doubles - leave + that to the -mfmovd command line switch. + (broken_move): Do not restrict fldi test to only the SH4 and SH4A. + (fldi_ok): Always allow. + * config/sh/sh.opt (mfmovd): Remove this switch. + * doc/invoke.texi (-mfmovd): Remove documentation of this switch. + +2009-07-06 J"orn Rennecke <joern.rennecke@arc.com> + Kaz Kojima <kkojima@gcc.gnu.org> + + PR rtl-optimization/30807 + * postreload.c (reload_combine): For every new use of REG_SUM, + record the use of BASE. + +2009-07-06 Jan Hubicka <jh@suse.cz> + + * params.def: Revert my accidental commit at 2009-06-30. + +2009-07-04 Ian Lance Taylor <iant@google.com> + + PR target/40636 + * config/i386/msformat-c.c (mingw_format_attributes): Declare as + EXPORTED_CONST. + (mingw_format_attribute_overrides): Likewise. + +2009-07-04 Jakub Jelinek <jakub@redhat.com> + + PR debug/40596 + * dwarf2out.c (based_loc_descr): For crtl->stack_realign_tried + don't check cfa.reg. Instead of cfa.indirect use + fde && fde->drap_reg != INVALID_REGNUM test. + +2009-07-04 Eric Botcazou <ebotcazou@adacore.com> + + * postreload.c (reload_combine): Replace CONST_REG with INDEX_REG. + +2009-07-03 Vladimir Makarov <vmakarov@redhat.com> + + PR target/40587 + * ira.c (build_insn_chain): Use DF_LR_OUT instead of df_get_live_out. + +2009-07-03 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40640 + * tree-switch-conversion.c (build_arrays): Perform arithmetic + in original type. + +2009-07-03 Jan Hubicka <jh@suse.cz> + + * ipa-inline.c (cgraph_decide_inlining_incrementally): When optimizing + for size, reduce amount of inlining. + +2009-07-03 Richard Guenther <rguenther@suse.de> + + PR middle-end/34163 + * tree-chrec.c (chrec_convert_1): Fold (T2)(t +- x) to (T2)t +- (T2)x + if t +- x is known to not overflow and the conversion widens the + operation. + * Makefile.in (tree-chrec.o): Add $(FLAGS_H) dependency. + +2009-07-03 Jan Hubicka <jh@suse.cz> + + * ipa-pure-const.c (analyze): Update loop optimizer init. + * tree-ssa-loop-iv-canon.c (empty_loop_p, remove_empty_loop, + try_remove_empty_loop, remove_empty_loops): Remove. + * tree-ssa-loop.c (tree_ssa_empty_loop, pass_empty_loop): Remove. + * tree-ssa-dce.c (find_obviously_necessary_stmts): Use finiteness info + to mark regular loops as neccesary. + (degenerate_phi_p): New function. + (propagate_necessity, remove_dead_phis): Use it. + (forward_edge_to_pdom): Likewise. + (eliminate_unnecessary_stmts): Take care to remove uses of results of + virtual PHI nodes that became unreachable. + (perform_tree_ssa_dce): Initialize/deinitialize loop optimizer. + * tree-flow.h (remove_empty_loops): Remove. + * passes.c (init_optimization_passes): Remove. + +2009-07-03 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (fix_trunc<mode>_fisttp_i387_1): Use + can_create_pseudo_p. + (*fix_trunc<mode>_i387_1): Ditto. + (*floathi<mode>2_1): Ditto. + (*float<SSEMODEI24:mode><X87MODEF:mode>2_1): Ditto. + (*fistdi2_1): Ditto. + (*fist<mode>2_1): Ditto. + (frndintxf2_floor): Ditto. + (*fist<mode>2_floor_1): Ditto. + (frndintxf2_ceil): Ditto. + (*fist<mode>2_ceil_1): Ditto. + (frndintxf2_trunc): Ditto. + (frndintxf2_mask_pm): Ditto. + (fxam<mode>2_i387_with_temp): Ditto. + * config/i386/sse.md (mulv16qi3): Ditto. + (*sse2_mulv4si3): Ditto. + (mulv2di3): Ditto. + (sse4_2_pcmpestr): Ditto. + (sse4_2_pcmpistr): Ditto. + +2009-07-03 Jan Hubicka <jh@suse.cz> + + * tree-ssa-dce.c (bb_contains_live_stmts): New bitmap. + (mark_stmt_necessary): Set it. + (mark_operand_necessary): Set it. + (mark_control_dependent_edges_necessary): Set it. + (mark_virtual_phi_result_for_renaming): New function. + (get_live_post_dom): New function. + (forward_edge_to_pdom): New function. + (remove_dead_stmt): Fix handling of control dependences. + (tree_dce_init): Init new bitmap. + (tree_dce_done): Free it. + +2009-07-02 Richard Guenther <rguenther@suse.de> + + PR bootstrap/40617 + * tree-ssa-structalias.c (new_var_info): Initialize + is_restrict_var. + +2009-07-02 Jan Hubicka <jh@suse.cz> + + * ipa-pure-const.c (check_op): Use PTA info to see if indirect_ref is + local. + +2009-07-02 Paolo Bonzini <bonzini@gnu.org> + + * expmed.c (emit_cstore, emit_store_flag_1): Accept target_mode + instead of recomputing it. Adjust calls. + (emit_store_flag): Adjust recursive calls. + +2009-07-02 Richard Guenther <rguenther@suse.de> + + * tree-ssa-live.c (remove_unused_locals): Do not remove + heap variables. + * tree-ssa-structalias.c (handle_lhs_call): Delay setting + of DECL_EXTERNAL for HEAP variables. + (compute_points_to_sets): Set DECL_EXTERNAL for escaped + HEAP variables. Do not adjust RESTRICT vars. + (find_what_var_points_to): Nobody cares if something + points to READONLY. + +2009-07-02 Ben Elliston <bje@au.ibm.com> + + * unwind-dw2-fde-glibc.c (_Unwind_IteratePhdrCallback): Move + pc_low and pc_high declarations to the top of the function. + +2009-07-01 DJ Delorie <dj@redhat.com> + + * config/mep/mep.c (mep_handle_option): Leave IVC2 control + registers as fixed. + (mep_interrupt_saved_reg): Save appropriate IVC2 control registers. + * config/mep/mep-ivc2.cpu: Add VOLATILE to insns that make + unspecified accesses to control registers. + * config/mep/intrinsics.md: Regenerate. + * config/mep/intrinsics.h: Regenerate. + * config/mep/mep-intrin.h: Regenerate. + +2009-07-01 Anthony Green <green@moxielogic.com> + + * config/moxie/moxie.c (moxie_expand_prologue): Use dec + instruction when possible. + (moxie_expand_prologue): Ditto. Also, save an instruction and + some complexity by popping off of $r12 instead of $sp. + * config/moxie/moxie.md (movsi_pop): Don't assume $sp. Take two + operands. + +2009-07-01 Richard Henderson <rth@redhat.com> + + PR bootstrap/40347 + * function.c (reposition_prologue_and_epilogue_notes): If epilogue + contained no insns, reposition note before last insn. + +2009-07-01 Richard Henderson <rth@redhat.com> + + PR debug/40431 + * dwarf2out.c (def_cfa_1): Revert 2009-06-11 change for + DW_CFA_def_cfa_offset and DW_CFA_def_cfa. + +2009-07-01 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR bootstrap/40558 + * config/rs6000/rs6000.c (print_operand): Undo change that breaks + darwin9 for printing reg addresses with %y. + +2009-07-01 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (force_to_mode): Handle TRUNCATE. Factor out + truncation from operands in binary operations. + +2009-07-01 Adam Nemet <anemet@caviumnetworks.com> + + Revert: + 2009-01-11 Adam Nemet <anemet@caviumnetworks.com> + * expmed.c (store_bit_field_1): Properly truncate the paradoxical + subreg of op0 to the original op0. + + * expmed.c (store_bit_field_1): Use a temporary as the destination + instead of a paradoxical subreg when we need to truncate the result. + +2009-07-01 DJ Delorie <dj@redhat.com> + + * config/mep/mep-ivc2.cpu (cmov, cmovc, cmovh): Add intrinsic + names to VLIW variants. + (ivc2rm, ivc2crn): Make data type consistent with non-VLIW variants. + * config/mep/intrinsics.md: Regenerate. + * config/mep/intrinsics.h: Regenerate. + * config/mep/mep-intrin.h: Regenerate. + +2009-07-01 Jakub Jelinek <jakub@redhat.com> + + PR debug/40462 + * jump.c (returnjump_p): Revert last patch. + * dwarf2out.c (dwarf2out_begin_epilogue): Handle SEQUENCEs. + +2009-07-01 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + PR target/40575 + * pa.md (casesi32p): Use jump table label to determine the offset + of the jump table. + (casesi64p): Likewise. + + * pa.c (forward_branch_p): Return bool type. Use instruction + addresses when available. Assert that INSN has a jump label. + (pa_adjust_insn_length): Don't call forward_branch_p if INSN doesn't + have a jump label. + +2009-07-01 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/19831 + * tree-ssa-dce.c (propagate_necessity): Calls to functions + that only act as barriers do not make any previous stores necessary. + * tree-ssa-structalias.c (handle_lhs_call): Delay making + HEAP variables global, do not add a constraint from nonlocal. + (find_func_aliases): Handle escapes through return statements. + (compute_points_to_sets): Make escaped HEAP variables global. + +2009-07-01 Paolo Bonzini <bonzini@gnu.org> + + PR bootstrap/40597 + * expmed.c (emit_store_flag): Perform a conversion if necessary, + after reducing a DImode cstore to SImode. + +2009-07-01 Paolo Bonzini <bonzini@gnu.org> + + * expr.c (expand_expr_real_1): Reinstate fallthrough to + TRUTH_ANDIF_EXPR if do_store_flag returns NULL. + +2009-07-01 Maciej W. Rozycki <macro@linux-mips.org> + + * config/vax/vax.h (TARGET_BSD_DIVMOD): New macro. Set to 1. + * config/vax/linux.h (TARGET_BSD_DIVMOD): New macro. Redefine the + to 0. + * config/vax/vax.c (vax_init_libfuncs): Only redefine udiv_optab + and umod_optab if TARGET_BSD_DIVMOD. + * config/vax/lib1funcs.asm: New file. + * config/vax/t-linux: New file. + * config.gcc (vax-*-linux*): Set tmake_file to vax/t-linux. + +2009-06-30 Jakub Jelinek <jakub@redhat.com> + + PR c++/40566 + * convert.c (convert_to_integer) <case COND_EXPR>: Don't convert + to type arguments that have void type. + + PR debug/40573 + * dwarf2out.c (gen_formal_parameter_die): Call + equate_decl_number_to_die if node is different from origin. + +2009-06-30 Anthony Green <green@moxielogic.com> + + Clean up moxie port for --enable-build-with-cxx. + * config/moxie/moxie.c (moxie_function_value): First two + parameters are const_tree, not tree. + * config/moxie/moxie.h (enum reg_class): Rename CC_REG to CC_REGS. + (REG_CLASS_NAMES): Ditto. + (REGNO_REG_CLASS): Ditto. + * config/moxie/moxie-protos.h (moxie_override_options): Declare. + (moxie_function_value): Fix constyness of arguments. + +2009-06-30 Eric Botcazou <ebotcazou@adacore.com> + + * cgraphunit.c (cgraph_finalize_compilation_unit): Call + finalize_size_functions before further processing. + * stor-layout.c: Include cgraph.h, tree-inline.h and tree-dump.h. + (variable_size): Call self_referential_size on size expressions + that contain a PLACEHOLDER_EXPR. + (size_functions): New static variable. + (copy_self_referential_tree_r): New static function. + (self_referential_size): Likewise. + (finalize_size_functions): New global function. + * tree.c: Include tree-inline.h. + (push_without_duplicates): New static function. + (find_placeholder_in_expr): New global function. + (substitute_in_expr) <tcc_declaration>: Return the replacement object + on equality. + <tcc_expression>: Likewise. + <tcc_vl_exp>: If the replacement object is a constant, try to inline + the call in the expression. + * tree.h (finalize_size_functions): Declare. + (find_placeholder_in_expr): Likewise. + (FIND_PLACEHOLDER_IN_EXPR): New macro. + (substitute_placeholder_in_expr): Update comment. + * tree-inline.c (remap_decl): Do not unshare trees if do_not_unshare + is true. + (copy_tree_body_r): Likewise. + (copy_tree_body): New static function. + (maybe_inline_call_in_expr): New global function. + * tree-inline.h (struct copy_body_data): Add do_not_unshare field. + (maybe_inline_call_in_expr): Declare. + * Makefile.in (tree.o): Depend on TREE_INLINE_H. + (stor-layout.o): Depend on CGRAPH_H, TREE_INLINE_H, TREE_DUMP_H and + GIMPLE_H. + +2009-06-30 Richard Guenther <rguenther@suse.de> + + * tree-ssa-dce.c (mark_all_reaching_defs_necessary_1): Always + continue walking. + (propagate_necessity): Do not mark reaching defs of stores + as necessary. + +2009-06-30 Jan Hubicka <jh@suse.cz> + + * cfgloopanal.c (check_irred): Move into ... + (mark_irreducible_loops): ... here; return true if ireducible + loops was found. + * ipa-pure-const.c: Include cfgloop.h and tree-scalar-evolution.h + (analyze_function): Try to prove loop finiteness. + * cfgloop.h (mark_irreducible_loops): Update prototype. + * Makefile.in (ipa-pure-const.o): Add dependency on SCEV and CFGLOOP. + +2009-06-30 Basile Starynkevitch <basile@starynkevitch.net> + + * Makefile.in (PLUGIN_HEADERS): added ggc, tree-dump, pretty-print. + +2009-06-30 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/40542 + * tree-vect-stmts.c (vect_analyze_stmt): Don't vectorize volatile + types. + +2009-06-30 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40582 + * tree-sra.c (build_ref_for_offset_1): Use types_compatible_p rather + than useless_type_conversion_p. + (generate_subtree_copies): Increment sra_stats.subtree_copies at a + proper place. + +2009-06-30 Martin Jambor <mjambor@suse.cz> + + PR middle-end/40554 + * tree-sra.c (sra_modify_expr): Add access->offset to start_offset. + +2009-06-30 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (walk_aliased_vdefs_1): Change interface to + use ao_ref references. + (walk_aliased_vdefs): Likewise. + * tree-ssa-alias.h (walk_aliased_vdefs): Adjust prototype. + * tree-ssa-dce.c (struct ref_data): Remove. + (mark_aliased_reaching_defs_necessary_1): Use the ao_ref argument. + (mark_aliased_reaching_defs_necessary): Adjust. + (mark_all_reaching_defs_necessary_1): Likewise. + +2009-06-30 Paolo Bonzini <bonzini@gnu.org> + + PR boostrap/40597 + * expmed.c (emit_cstore): New name of emit_store_flag_1. + (emit_store_flag_1): Extract from emit_store_flag, adjust + calls to (what now is) emit_cstore. + (emit_store_flag): Call emit_store_flag_1 and also use it + for what used to be recursive calls. + +2009-06-30 Wei Guozhi <carrot@google.com> + + PR/40416 + * tree-ssa-sink.c (statement_sink_location): Stop sinking expression + if the target bb post dominates from bb. + * config/i386/i386.c (memory_address_length): Check existence of base + register before using it. + +2009-06-30 Nick Clifton <nickc@redhat.com> + DJ Delorie <dj@redhat.com> + + * config.sh/lib1funcs.h (FMOVD_WORKS): Only define if + __FMOVD_ENABLED__ is defined. + * config/sh/sh.h + (TARGET_FMOVD): Provide a default definition. + (MASK_FMOVD): Likewise. + (TARGET_CPU_CPP_BUILTINS): Define + __FMOVD_ENABLED__ if TARGET_FMOVD is true. + * config/sh/sh.md (movdf_i4): For alternative 0 use either one or + two fmov instructions depending upon whether TARGET_FMOVD is + enabled. + (split for DF load from memory into register): Also handle + MEMs which consist of REG+DISP addressing. + (split for DF store from register to memory): Likewise. + * config/sh/sh.opt (mfmovd): Remove this switch. + * doc/invoke.texi (-mfmovd): Remove documentation of this switch. + * config/sh/sh.c (sh_override_options): Do not automatically + enable TARGET_MOVD for the SH2A when supporting doubles - leave + that to the -mfmovd command line switch. + + * config/sh/sh.c (broken_move): Do not restrict fldi test to only + the SH4 and SH4A. + (fldi_ok): Always allow. + * config/sh/sh.md (movsf_ie): Always use single fp_mode. + +2009-06-29 DJ Delorie <dj@redhat.com> + + * doc/install.texi (mep-x-elf): Correct chip's full name. + +2009-06-29 H.J. Lu <hongjiu.lu@intel.com> + + * doc/extend.texi: Fix typo. + +2009-06-29 Tom Tromey <tromey@redhat.com> + + * dwarf2.h: Remove. + * Makefile.in (DWARF2_H): New variable. + (except.o): Use it. + (dwarf2out.o): Likewise. + (dwarf2asm.o): Likewise. + * config/i386/t-i386: Use DWARF2_H. + * except.c: Include elf/dwarf2.h. + * unwind-dw2.c: Include elf/dwarf2.h. + * dwarf2out.c: Include elf/dwarf2.h. + (dw_loc_descr_struct) <dw_loc_opc>: Now a bitfield. + <dtprel>: New field. + (dwarf_stack_op_name): Don't handle INTERNAL_DW_OP_tls_addr. + (size_of_loc_descr): Likewise. + (output_loc_operands_raw): Likewise. + (output_loc_operands): Handle new dtprel field. + (loc_checksum): Update. + (loc_descriptor_from_tree_1) <VAR_DDECL>: Set dtprel field. + * unwind-dw2-fde-glibc.c: Include elf/dwarf2.h. + * unwind-dw2-fde.c: Include elf/dwarf2.h. + * dwarf2asm.c: Include elf/dwarf2.h. + * unwind-dw2-fde-darwin.c: Include elf/dwarf2.h. + * config/mmix/mmix.c: Include elf/dwarf2.h. + * config/rs6000/darwin-fallback.c: Include elf/dwarf2.h. + * config/xtensa/unwind-dw2-xtensa.c: Include elf/dwarf2.h. + * config/sh/sh.c: Include elf/dwarf2.h. + * config/i386/i386.c: Include elf/dwarf2.h. + +2009-06-29 DJ Delorie <dj@redhat.com> + + * config/mep/mep.h (CPP_SPEC): Remove __cop macro. + + * doc/extend.texi: Add MeP attributes and pragmas. + * doc/invoke.text: Add MeP Options. + * doc/contrib.texi: Add MeP contribution. + * doc/md.texi: Add MeP constraints. + * doc/install.texi: Add MeP target. + +2009-06-30 Anatoly Sokolov <aesok@post.ru> + + * target.h (struct gcc_target): Add frame_pointer_required field. + * target-def.h (TARGET_FRAME_POINTER_REQUIRED): New. + (TARGET_INITIALIZER): Use TARGET_FRAME_POINTER_REQUIRED. + * ira.c (setup_eliminable_regset): Use frame_pointer_required target + hook. + * reload1.c (update_eliminables): (Ditto.). + * gcc/system.h (FRAME_POINTER_REQUIRED): Poison. + * doc/tm.texi (FRAME_POINTER_REQUIRED): Revise documentation. + (INITIAL_FRAME_POINTER_OFFSET): (Ditto.). + + * config/arc/arc.h (FRAME_POINTER_REQUIRED): Remove macro. + + * config/arm/arm.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/arm/arm.c (TARGET_FRAME_POINTER_REQUIRED): Define. + (arm_frame_pointer_required): New function. + + * config/avr/avr.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/avr/avr.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + (avr_frame_pointer_required_p): Declare as static. + * config/avr/avr-protos.h (avr_frame_pointer_required_p): Remove. + + * config/bfin/bfin.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/bfin/bfin.c (TARGET_FRAME_POINTER_REQUIRED): Define. + (bfin_frame_pointer_required): Make as static, change return type + to bool. + * config/bfin/bfin-protos.h (bfin_frame_pointer_required): Remove. + + * config/cris/cris.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/cris/cris.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + (cris_frame_pointer_required): New function. + + * config/crx/crx.h (FRAME_POINTER_REQUIRED): Remove macro. + + * config/fr30/fr30.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/fr30/fr30.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + (fr30_frame_pointer_required): New function. + + * config/frv/frv.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/frv/frv.c (TARGET_FRAME_POINTER_REQUIRED): Define. + (frv_frame_pointer_required): Make as static, change return type + to bool. + * config/bfin/bfin-protos.h (frv_frame_pointer_required): Remove. + + * config/i386/i386.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/i386/i386.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + (ix86_frame_pointer_required): Make as static, change return type to + bool. + * config/i386/i386-protos.h (ix86_frame_pointer_required): Remove. + + * config/m32c/m32c.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/m32c/m32c.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + + * config/m32r/m32r.h (FRAME_POINTER_REQUIRED): Remove macro. + + * config/mcore/mcore.h (CAN_ELIMINATE): Remove macro. + + * config/mep/mep.h (FRAME_POINTER_REQUIRED): Remove macro. + + * config/mips/mips.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/mips/mips.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + (mips_frame_pointer_required): Make as static. + * config/mips/mips-protos.h (mips_frame_pointer_required): Remove. + + * config/mmix/mmix.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/mmix/mmix.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + (mmix_frame_pointer_required): Mew function. + + * config/moxie/moxie.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/moxie/moxie.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + + * config/pa/pa.h (FRAME_POINTER_REQUIRED): Remove macro. + + * config/score/score.h (FRAME_POINTER_REQUIRED): Remove macro. + + * config/sh/sh.h (CAN_ELIMINATE): Remove macro. + + * config/sparc/sparc.h (FRAME_POINTER_REQUIRED): Remove macro. + (CAN_ELIMINATE): Redefine. + * config/sparc/sparc.c (TARGET_FRAME_POINTER_REQUIRED): Define macro. + (sparc_frame_pointer_required): New function. + (sparc_can_eliminate): New function. + * config/sparc/sparc-protos.h (sparc_can_eliminate): Declare. + + * config/vax/vax.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/vax/vax.c (TARGET_FRAME_POINTER_REQUIRED): Define. + + * config/xtensa/xtensa.h (FRAME_POINTER_REQUIRED): Remove macro. + * config/xtensa/xtensa.c (TARGET_FRAME_POINTER_REQUIRED): Define. + (xtensa_frame_pointer_required): Make as static, change return type + to bool. + * config/xtensa/xtensa-protos.h (xtensa_frame_pointer_required): + Remove. + +2009-06-29 Olatunji Ruwase <tjruwase@google.com> + + * doc/plugins.texi: Document PLUGIN_START_UNIT. + * toplev.c (compile_file): Call PLUGIN_START_UNIT. + * gcc-plugin.h (PLUGIN_START_UNIT): Added new event. + * plugin.c (plugin_event_name): Added PLUGIN_START_UNIT. + (register_callback): Handle PLUGIN_START_UNIT. + (invoke_plugin_callbacks): Handle PLUGIN_START_UNIT. + +2009-06-29 Eric Botcazou <ebotcazou@adacore.com> + + * tree.c (process_call_operands): Propagate TREE_READONLY from the + operands. + (PROCESS_ARG): Do not clear TREE_READONLY if CONSTANT_CLASS_P. + (build3_stat): Propagate TREE_READONLY for COND_EXPR. + +2009-06-29 Daniel Jacobowitz <dan@codesourcery.com> + + * config/arm/arm.h (REGISTER_MOVE_COST): Increase VFP register + move cost. + +2009-06-29 Uros Bizjak <ubizjak@gmail.com> + + * doc/extend.texi (Additional Floating Types): __float128 is also + supported on i386 targets. + +2009-06-29 Richard Guenther <rguenther@suse.de> + + PR middle-end/14187 + * tree-ssa-alias.h (struct pt_solution): Add vars_contains_restrict + flag. + (pt_solutions_same_restrict_base): Declare. + * tree-ssa-structalias.c (struct variable_info): Add is_restrict_var + flag. + (new_var_info): Initialize is_global_var properly for SSA_NAMEs. + (make_constraint_from, make_copy_constraint): Move earlier. + (make_constraint_from_heapvar): New function. + (make_constraint_from_restrict): Likewise. + (handle_lhs_call): Use it. + (find_func_aliases): Use it to track conversions to restrict + qualified pointers. + (struct fieldoff): Add only_restrict_pointers flag. + (push_fields_onto_fieldstack): Initialize it. + (create_variable_info_for): Track global restrict qualified pointers. + (intra_create_variable_infos): Use make_constraint_from_heapvar. + Track restrict qualified pointer arguments. + (set_uids_in_ptset): Use varinfo is_global_var flag. + (find_what_var_points_to): Set the vars_contains_restrict flag. + Always create the points-to solution for sets including restrict tags. + (pt_solutions_same_restrict_base): New function. + * tree-ssa-alias.c (ptr_derefs_may_alias_p): For two restrict + qualified pointers use pt_solutions_same_restrict_base as + additional source for disambiguation. + +2009-06-29 Richard Guenther <rguenther@suse.de> + + PR middle-end/38212 + * alias.c (find_base_decl): Remove. + (get_deref_alias_set_1): Remove restrict handling. + * c-common.c (c_apply_type_quals_to_decl): Do not set + DECL_POINTER_ALIAS_SET. + * gimplify.c (find_single_pointer_decl_1): Remove. + (find_single_pointer_decl): Likewise. + (internal_get_tmp_var): Remove restrict handling. + (gimple_regimplify_operands): Likewise. + * omp-low.c (expand_omp_atomic_pipeline): Do not set + DECL_POINTER_ALIAS_SET. Use ref-all pointers. + * print-tree.c (print_node): Do not print DECL_POINTER_ALIAS_SET. + * tree.c (restrict_base_for_decl): Remove. + (init_ttree): Do not allocate it. + (make_node_stat): Do not set DECL_POINTER_ALIAS_SET. Set + LABEL_DECL_UID for label decls. + (copy_node_stat): Do not copy restrict information. + (decl_restrict_base_lookup): Remove. + (decl_restrict_base_insert): Likewise. + (print_restrict_base_statistics): Likewise. + (dump_tree_statistics): Do not call print_restrict_base_statistics. + * tree.h (DECL_POINTER_ALIAS_SET): Remove. + (DECL_POINTER_ALIAS_SET_KNOWN_P): Likewise. + (struct tree_decl_common): Rename pointer_alias_set to label_decl_uid. + (LABEL_DECL_UID): Adjust. + (DECL_BASED_ON_RESTRICT_P): Remove. + (DECL_GET_RESTRICT_BASE): Likewise. + (SET_DECL_RESTRICT_BASE): Likewise. + (struct tree_decl_with_vis): Remove based_on_restrict_p flag. + + * config/i386/i386.c (ix86_gimplify_va_arg): Use ref-all pointers + instead of DECL_POINTER_ALIAS_SET. + * config/rs6000/rs6000.c (rs6000_gimplify_va_arg): Likewise. + * config/s390/s390.c (s390_gimplify_va_arg): Likewise. + * config/spu/spu.c (spu_gimplify_va_arg_expr): Likewise. + +2009-06-29 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40579 + * tree-vrp.c (vrp_evaluate_conditional): Bail out early if + the IL to simplify has constants that overflowed. + +2009-06-28 Uros Bizjak <ubizjak@gmail.com> + + PR tree-optimization/40550 + * tree-vect-generic.c (expand_vector_operations_1): Compute in + vector_compute_type only when the size of vector_compute_type is + less than the size of type. + +2009-06-28 Eric Botcazou <ebotcazou@adacore.com> + + * fold-const.c (contains_label_1): Fix comments. + (contains_label_p): Do not walk trees multiple time. + +2009-06-28 Paolo Bonzini <bonzini@gnu.org> + + * config/i386/i386.h (enum ix86_fpcmp_strategy): New. + * config/i386/i386.md (cbranchxf4, cstorexf4, cbranch<MODEF>4, + cstore<MODEF>4, mov<X87MODEF>cc): Change predicate to + ix86_fp_comparison_operator. + (*fp_jcc_1_mixed, *fp_jcc_1_sse, *fp_jcc_1_387, *fp_jcc_2_mixed, + *fp_jcc_2_sse, *fp_jcc_2_387): Delete + (*fp_jcc_3_387, *fp_jcc_4_387, *fp_jcc_5_387, *fp_jcc_6_387, + *fp_jcc_7_387, *fp_jcc_8<MODEF>_387): Eliminate call to + !ix86_use_fcomi_compare, change ix86_fp_jump_nontrivial_p call + to !TARGET_CMOVE, change predicate to ix86_fp_comparison_operator. + (related splits): Change predicate to ix86_fp_comparison_operator. + * config/i386/predicates.md: Use ix86_trivial_fp_comparison_operator + instead of ix86_fp_comparison_codes. + (ix86_trivial_fp_comparison_operator, + ix86_fp_comparison_operator): New. + * config/i386/i386-protos.h (ix86_fp_comparison_strategy): New. + (ix86_expand_compare): Eliminate last two parameters. + (ix86_fp_jump_nontrivial_p): Kill. + * config/i386/i386.c (put_condition_code): Eliminate call to + ix86_fp_comparison_codes and subsequent assertion. + (ix86_fp_comparison_codes): Eliminate. + (ix86_fp_swap_condition): New. + (ix86_fp_comparison_arithmetics_cost, ix86_fp_comparison_fcomi_cost, + ix86_fp_comparison_sahf_cost, ix86_use_fcomi_compare): Consolidate + into ix86_fp_comparison_cost and ix86_fp_comparison_strategy. + (ix86_prepare_fp_compare_args): Use ix86_fp_comparison_strategy + and ix86_fp_swap_condition. + (ix86_expand_fp_compare): Eliminate code for second jump/bypass jump. + Use ix86_fp_comparison_strategy. + (ix86_expand_compare): Likewise. Eliminate last two arguments. + (ix86_fp_jump_nontrivial_p): Eliminate. + (ix86_expand_branch): Treat SFmode/DFmode/XFmode as simple. Adjust + call to ix86_expand_compare. + (ix86_split_fp_branch, ix86_expand_setcc, + ix86_expand_carry_flag_compare, ix86_expand_int_movcc, + ix86_expand_fp_movcc): Eliminate code for second jump/bypass jump. + +2009-06-28 Paolo Bonzini <bonzini@gnu.org> + + * config/arm/arm.c (arm_final_prescan_ins): Eliminate code + related to jump_clobbers. + * config/arm/arm.md (conds): Remove jump_clob case. + (addsi3_cbranch, addsi3_cbranch_scratch, subsi3_cbranch, two + splits): Change comparison_operator to arm_comparison_operator. + (*arm_buneq, *arm_bltgt, *arm_buneq_reversed, *arm_bltgt_reversed): + Eliminate. + +2009-06-28 Paolo Bonzini <bonzini@gnu.org> + + * dojump.c (do_compare_rtx_and_jump): Try swapping the + condition for floating point modes. + * expmed.c (emit_store_flag_1): Move here a bigger part + of emit_store_flag. + (emit_store_flag): Try swapping the condition for floating point + modes. + * optabs.c (emit_cmp_and_jump_insns): Cope with constant op0 better. + +2009-06-28 Paolo Bonzini <bonzini@gnu.org> + + * expr.c (expand_expr_real_1): Just use do_store_flag. + (do_store_flag): Drop support for TRUTH_NOT_EXPR. Use + emit_store_flag_force. + * expmed.c (emit_store_flag_force): Copy here trick + previously in expand_expr_real_1. Try reversing the comparison. + (emit_store_flag_1): Work if target is NULL. + (emit_store_flag): Work if target is NULL, using the result mode + from the comparison. Use split_comparison, restructure final part + to simplify conditionals. + +2009-06-28 Paolo Bonzini <bonzini@gnu.org> + + * builtins.c (expand_errno_check): Use do_compare_rtx_and_jump. + * dojump.c (do_jump): Change handling of floating-point + ops to use just do_compare_and_jump. + (split_comparison): New. + (do_compare_rtx_and_jump): Add here logic coming previously + in do_jump, using split_comparison. + +2009-06-27 H.J. Lu <hongjiu.lu@intel.com> + + PR target/40489 + * config/ia64/ia64.c (ia64_reorg): Check NULL insn. + +2009-06-27 Paolo Bonzini <bonzini@gnu.org> + + * tree-ssa-alias.c: Fix unintentional commit. + +2009-06-27 Paolo Bonzini <bonzini@gnu.org> + + * passes.c (execute_one_pass): Fix unintentional commit. + +2009-06-27 Paolo Bonzini <bonzini@gnu.org> + + * df-problems.c (df_set_seen, df_unset_seen): Delete. + (df_rd_local_compute, df_md_local_compute): Inline them. + + (df_md_scratch): New. + (df_md_alloc, df_md_free): Allocate/free it. + (df_md_local_compute): Only include live registers in init. + (df_md_transfer_function): Prune the in-set computed by + the confluence function, and the gen-set too. + +2009-06-27 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/26854 + * timevar.def: Remove TV_DF_RU, add TV_DF_MD. + * df-problems.c (df_rd_add_problem): Fix comment. + (df_md_set_bb_info, df_md_free_bb_info, df_md_alloc, + df_md_simulate_artificial_defs_at_top, + df_md_simulate_one_insn, df_md_bb_local_compute_process_def, + df_md_bb_local_compute, df_md_local_compute, df_md_reset, + df_md_transfer_function, df_md_init, df_md_confluence_0, + df_md_confluence_n, df_md_free, df_md_top_dump, df_md_bottom_dump, + problem_MD, df_md_add_problem): New. + * df.h (DF_MD, DF_MD_BB_INFO, struct df_md_bb_info, df_md, + df_md_get_bb_info): New. + (DF_LAST_PROBLEM_PLUS1): Adjust. + + * Makefile.in (fwprop.o): Include domwalk.h. + * fwprop.c: Include domwalk.h. + (reg_defs, reg_defs_stack): New. + (bitmap_only_bit_between): Remove. + (process_defs): New. + (process_uses): Use reg_defs and local_md instead of + bitmap_only_bit_between and local_rd. + (single_def_use_enter_block): New, from build_single_def_use_links. + (single_def_use_leave_block): New. + (build_single_def_use_links): Remove code moved to + single_def_use_enter_block, invoke domwalk. + (use_killed_between): Adjust comment. + +2009-06-27 Paolo Bonzini <bonzini@gnu.org> + + * bitmap.h (bitmap_ior_and_into): New. + * bitmap.c (bitmap_ior_and_into): New. + +2009-06-27 Paolo Bonzini <bonzini@gnu.org> + + * domwalk.h (struct dom_walk_data): Remove all callbacks except + before_dom_children_before_stmts and after_dom_children_after_stmts. + Rename the two remaining callbacks to just before_dom_children and + after_dom_children. Remove other GIMPLE statement walking bits. + * domwalk.c (walk_dominator_tree): Remove now unsupported features. + * graphite.c: Do not include domwalk.h. + * tree-into-ssa.c (interesting_blocks): New global. + (struct mark_def_sites_global_data): Remove it and names_to_rename. + (mark_def_sites, rewrite_stmt, rewrite_add_phi_arguments, + rewrite_update_stmt, rewrite_update_phi_arguments): Simplify + now that they're not domwalk callbacks. + (rewrite_initialize_block): Rename to... + (rewrite_enter_block): ... this, place after called functions. Test + interesting_blocks, call rewrite_stmt and rewrite_add_phi_arguments. + (rewrite_finalize_block): Rename to... + (rewrite_leave_block): ... this, place after called functions. + (rewrite_update_init_block): Rename to... + (rewrite_update_enter_block): ... this, place after called functions. + Test interesting_blocks, call rewrite_update_stmt and + rewrite_update_phi_arguments. + (rewrite_update_fini_block): Rename to... + (rewrite_leave_block): ... this, place after called functions. + (rewrite_blocks): Remove last argument, simplify initialization of + walk_data. + (mark_def_sites_initialize_block): Rename to... + (mark_def_sites_block): ... this, call mark_def_sites. + (mark_def_sites_blocks): Remove argument, simplify initialization of + walk_data. + (rewrite_into_ssa): Adjust for interesting_blocks_being a global. + (update_ssa): Likewise. + * tree-ssa-dom.c (optimize_stmt): Simplify now that it's not a domwalk + callback. + (tree_ssa_dominator_optimize): Simplify initialization of walk_data. + (dom_opt_initialize_block): Rename to... + (dom_opt_enter_block): ... this, place after called functions. Walk + statements here, inline propagate_to_outgoing_edges. + (dom_opt_finalize_block): Rename to... + (dom_opt_leave_block): ... this, place after called functions. + * tree-ssa-dse.c (dse_optimize_stmt): Simplify now that it's not a + domwalk callback. + (dse_enter_block, dse_record_phi): New. + (dse_record_phis): Delete. + (dse_finalize_block): Rename to... + (dse_leave_block): ... this. + (tree_ssa_dse): Simplify initialization of walk_data. + * tree-ssa-loop-im.c (determine_invariantness, move_computations): + Adjust initialization of walk_data. + * tree-ssa-loop-unswitch.c: Do not include domwalk.h. + * tree-ssa-loop-phiopt.c (get_non_trapping): + Adjust initialization of walk_data. + * tree-ssa-loop-threadedge.c: Do not include domwalk.h. + * tree-ssa-uncprop.c (uncprop_into_successor_phis): Simplify now that + it's not a domwalk callback. + (uncprop_initialize_block): Rename to... + (dse_enter_block): ... this, call uncprop_into_successor_phis. + (dse_finalize_block): Rename to... + (dse_leave_block): ... this. + (tree_ssa_uncprop): Simplify initialization of walk_data. + * Makefile.in: Adjust dependencies. + +2009-06-27 Richard Earnshaw <rearnsha@arm.com> + + * arm.md (casesi): Fix test for Thumb1. + (thumb1_casesi_internal_pic): Likewise. + (thumb1_casesi_dispatch): Likewise. + +2009-06-26 Daniel Gutson <dgutson@codesourcery.com> + + * config/arm/arm-cores.def: Added core cortex-m0. + * config/arm/arm-tune.md: Regenerated. + * doc/invoke.texi: Added entry for cpu ARM Cortex-M0. + +2009-06-26 DJ Delorie <dj@redhat.com> + + * config/mep/mep.opt (mfar): Remove -mfar as it doesn't do anything. + + * config/mep/mep.c (mep_bundle_insns): Account for the fact that + the scheduler doesn't tag jump insns. + +2009-06-26 H.J. Lu <hongjiu.lu@intel.com> + + * c-decl.c (merge_decls): Re-indent. + +2009-06-26 Janis Johnson <janis187@us.ibm.com> + + PR c/39902 + * tree.c (real_zerop, real_onep, real_twop, real_minus_onep): + Special-case decimal float constants. + +2009-06-26 Richard Henderson <rth@redhat.com> + + * function.h (struct function): Add cannot_be_copied_reason, + and cannot_be_copied_set. + * tree-inline.c (has_label_address_in_static_1): Rename from + inline_forbidden_p_2; don't set inline_forbidden_reason here. + (cannot_copy_type_1): Rename from inline_forbidden_p_op; likewise + don't set inline_forbidden_reason. + (copy_forbidden): New function, split out of inline_forbidden_p. + (inline_forbidden_p_stmt): Don't check for nonlocal labels here. + (inline_forbidden_p): Use copy_forbidden. + (tree_versionable_function_p): Likewise. + (inlinable_function_p): Merge into tree_inlinable_function_p. + (tree_function_versioning): Remap cfun->nonlocal_goto_save_area. + * ipa-cp.c (ipcp_versionable_function_p): New function. + (ipcp_cloning_candidate_p): Use it. + (ipcp_node_modifiable_p): Likewise. + +2009-06-26 Olatunji Ruwase <tjruwase@google.com> + + * builtins.c (expand_builtin_alloca): Handle builtin alloca + that is marked not to be inlined. Remove flag_mudflap use. + * tree-mudflap.c: Rename mf_xform_derefs to mf_xfrom_statements. + (mf_xform_statements): Mark builtin alloca calls as un-inlineable. + +2009-06-26 Steve Ellcey <sje@cup.hp.com> + + PR bootstrap/40338 + * config/pa/t-pa-hpux10 (TARGET_LIBGCC2_CFLAGS): Add -frandom-seed. + * config/pa/t-pa-hpux11 (TARGET_LIBGCC2_CFLAGS): Ditto. + +2009-06-26 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/mingw-tls.c (__mingwthr_key_dtor): Remove for none + shared libgcc. + (__mingwthr_remove_key_dtor): Likewise. + +2009-06-26 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (do_ds_constraint): Simplify escape handling. + +2009-06-26 Steven Bosscher <steven@gcc.gnu.org> + + PR middle-end/40525 + * ifcvt.c (dead_or_predicable): If predicating MERGE_BB fails, + try the non-cond_exec path also. + +2009-06-25 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + PR target/40468 + * pa.c (branch_to_delay_slot_p, branch_needs_nop_p): New functions. + (output_cbranch): Use new functions. + (output_lbranch, output_bb, output_bvb, output_dbra, output_movb): + Likewise. + +2009-06-25 Michael Meissner <meissner@linux.vnet.ibm.com> + Pat Haugen <pthaugen@us.ibm.com> + Revital Eres <ERES@il.ibm.com> + + * config/rs6000/rs6000.c (print_operand): Correct lossage message + for %c error. Add %x support to print VSX registers as a unified + register set, instead of separate float and altivec registers. + Switch to use VECTOR_MEM_ALTIVEC_P instead of TARGET_ALTIVEC for + %y case, and add support for VSX pre-modify addresses. + (output_toc): Add assert for CONST containing an integer constant + in the PLUS case. + (rs6000_adjust_cost): Add POWER7 support. + (insn_must_be_first_in_group): Ditto. + (insn_must_be_last_in_group): Ditto. + (rs6000_emit_popcount): Ditto. + (rs6000_vector_mode_supported_p): Ditto. + + * config/rs6000/rs6000-protos.h (rs6000_secondary_reload_class): + Change some of the functions called by macros to being called + through a pointer, so debug functions can be inserted if + -mdebug=addr or -mdebug=cost. + (rs6000_preferred_reload_class_ptr): Ditto. + (rs6000_secondary_reload_class_ptr): Ditto. + (rs6000_secondary_memory_needed_ptr): Ditto. + (rs6000_cannot_change_mode_class_ptr): Ditto. + (rs6000_secondary_reload_inner): Ditto. + (rs6000_legitimize_reload_address): Ditto. + (rs6000_legitimize_reload_address_ptr): Ditto. + (rs6000_mode_dependent_address): Ditto. + (rs6000_mode_dependent_address_ptr): Ditto. + + * config/rs6000/rs6000.c (reg_offset_addressing_ok_p): New + function to return true if the mode allows reg + integer + addresses. + (virtual_stack_registers_memory_p): New function to return true if + the address refers to a virtual stack register. + (rs6000_legitimate_offset_address_p): Move code to say whether a + mode supports reg+int addressing to reg_offset_addressing_ok_p and + call it. + (rs6000_legitimate_address_p): Add checks for modes that only can + do reg+reg addressing. Start adding VSX support. + (rs6000_legitimize_reload_address): Ditto. + (rs6000_legitimize_address): Ditto. + (rs6000_debug_legitimate_address_p): New debug functions for + -mdebug=addr and -mdebug=cost. + (rs6000_debug_rtx_costs): Ditto. + (rs6000_debug_address_costs): Ditto. + (rs6000_debug_adjust_cost): Ditto. + (rs6000_debug_legitimize_address): Ditto. + (rs6000_legitimize_reload_address_ptr): Point to call normal + function or debug function. Make functions called via pointer + static. + (rs6000_mode_dependent_address_ptr): Ditto. + (rs6000_secondary_reload_class_ptr): Ditto. + (rs6000_hard_regno_mode_ok): Add preliminary VSX support. + (rs6000_emit_move): Add -mdebug=addr support. Change an abort + into a friendlier error. + (rs6000_init_builtins): Add initial VSX support. + (rs6000_adjust_cost): Fix some spacing issues. + + * config/rs6000/rs6000.h (enum reg_class): Add VSX_REGS. + (REG_CLASS_NAMES): Ditto. + (REG_CLASS_CONTENTS): Ditto. + (PREFERRED_RELOAD_CLASS): Move from a macro to calling through a + pointer, to add -mdebug=addr support. + (CANNOT_CHANGE_MODE_CLASS): Ditto. + (SECONDARY_RELOAD_CLASS): Call through a pointer to add + -mdebug=addr support. + (LEGITIMIZE_RELOAD_ADDRESS): Ditto. + (GO_IF_MODE_DEPENDENT_ADDRESS): Ditto. + (enum rs6000_builtins): Add RS6000_BUILTIN_BSWAP_HI. + + * config/rs6000/rs6000.md (bswaphi*): Add support for swapping + 16-bit values. + (bswapsi*): Set attribute types for load/store. Add combiner + patterns to eliminate zero extend on 64-bit. + (bswapdi*): Add support for swapping 64-bit values. Use ldbrx and + stdbrx if the hardware supports those instructions. + +2009-06-25 Ian Lance Taylor <iant@google.com> + + * doc/invoke.texi (Option Summary): Mention -static-libstdc++. + (Link Options): Document -static-libstdc++. + +2009-06-25 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR target/38731 + * config/rs6000/rs6000.c (LOCAL_ALIGNMENT): Redefine to just use + DATA_ALIGNMENT instead. + +2009-06-25 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Disambiguate + indirect references against the callused/escaped solutions. + (call_may_clobber_ref_p_1): Likewise. + +2009-06-25 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40493 + * tree-sra.c (sra_modify_expr): Correct BIT_FIELD_REF argument numbers. + (enum unscalarized_data_handling): New type. + (handle_unscalarized_data_in_subtree): Return what has been done. + (load_assign_lhs_subreplacements): Handle left flushes differently. + (sra_modify_assign): Use unscalarized_data_handling, simplified + condition determining whether to remove the statement. + +2009-06-25 Basile Starynkevitch <basile@starynkevitch.net> + + * doc/plugins.texi (Building GCC plugins): Correct typo in Makefile + excerpt - @ should be doubled for texinfo. + +2009-06-24 Ian Lance Taylor <iant@google.com> + + * config/arc/arc.c: Include "df.h". + (arc_attribute_table): Make static. Move higher in file. + (arc_address_cost): Call SMALL_INT on INTVAL, not rtx. + (output_shift): Initialize n later to avoid warning. + * config/arm/arm.c (arm_attribute_table): Make static. Move + higher in file. + * config/avr/avr.c (avr_attribute_table): Make static. Move + higher in file. + (reg_class_tab): Change array type from int to enum reg_class. + (avr_jump_mode): Change GET_MODE to GET_CODE when checking for + LABEL_REF. + (out_tsthi, ashlhi3_out): Don't use AS2 with "or" or "and". + (lshrhi3_out): Likewise. + (class_likely_spilled_p): Change return type to bool. + (avr_rtx_costs): Use local code variable with enum type. + * config/avr/avr.md (movmemhi): Use add_reg_note. + (andhi3, andsi3): Don't use AS2 with "and". + (iorhi3, iorsi3): Don't use AS2 with "or". + * config/avr/avr-protos.h (class_likely_spilled_p): Update declaration. + * config/crx/crx.c: Include "df.h". + (crx_attribute_table): Make static. + * config/m32r/m32r.c: Include "df.h". + (m32r_attribute_table): Make static. Move higher in file. + (pop): Use add_reg_note. + (block_move_call): Change 0 to LCT_NORMAL in function call. + * config/m32r/m32r.md (movsi_insn): Remove unused local value. + * config/m32r/m32r.h (INITIALIZE_TRAMPOLINE): Likewise. + * config/m32r/m32r-protos.h (m32r_compute_function_type): Always + declare, not just when TREE_CODE is defined. + * config/m68hc11/m68hc11.c: Include "expr.h". + (m68hc11_attribute_table): Make static. Move higher in file. + (m68hc11_small_indexed_indirect_p): Change 0 to VOIDmode in + function call. + (m68hc11_register_indirect_p): Likewise. + (m68hc11_function_arg_padding): Change return type to enum + direction. + (emit_move_after_reload): Use add_reg_note. + (m68hc11_emit_logical): Change code parameter to enum rtx_code. + (m68hc11_split_logical): Likewise. + (m68hc11_rtx_costs): Add local code_and outer_code variables with + enum type. + * config/m68hc11/predicates.md (reg_or_some_mem_operand): Change 0 + to VOIDmode in function call. + * config/m68hc11/m68hc11-protos.h: Don't check TREE_CODE to see if + tree is defined. + (m68hc11_split_logical): Update declaration. + (m68hc11_function_arg_padding): Update declaration. + * config/mcore/mcore.c (regno_reg_class): Change form array of int + to array of enum reg_class. + (mcore_attribute_table): Make static. Move higher in file. + (mcore_rtx_costs): Add cast to enum type. + * config/mcore/mcore.h (regno_reg_class): Update declaration. + (GO_IF_LEGITIMATE_INDEX): Add cast to avoid warning. + * config/sh/sh.c (sh_attribute_table): Make static. Move higher + in file. + * config/sh/predicates.md (trapping_target_operand): Rename and to + and_expr. + * config/sparc/sparc.c (sparc_attribute_table): Make static. Move + higher in file. + * config/spu/spu.c (spu_attribute_table): Make static. Move + higher in file. + * config/v850/v850.c (v850_attribute_table): Make static. Move + higher in file. + (v850_rtx_costs): Use local code with enum type. + (expand_epilogue): Add cast. + * config/v850/v850-c.c (ghs_pragma_section): Initialize repeat. + +2009-06-23 Takashi YOSHII <yoshii.takashi@renesas.com> + + PR target/40515 + * doc/invoke.texi (SH Options): Document -m2a, -m2a-single, + -m2a-single-only and -m2a-nofpu. + * config/sh/sh.opt: Document m2a generates FPU code. + +2009-06-24 Anatoly Sokolov <aesok@post.ru> + + * defaults.h (CAN_ELIMINATE): Provide default. + * doc/tm.texi (CAN_ELIMINATE): Revise documentation. + * config/alpha/alpha.h (CAN_ELIMINATE): Delete. + * config/m32c/m32c.h (CAN_ELIMINATE): Delete. + * config/spu/spu.h (CAN_ELIMINATE): Delete. + * config/xtensa/xtensa.h (CAN_ELIMINATE): Delete. + * config/moxie/moxie.h (CAN_ELIMINATE): Delete. + * config/cris/cris.h (CAN_ELIMINATE): Delete. + * config/mn10300/mn10300.h (CAN_ELIMINATE): Delete. + * config/pa/pa64-linux.h (CAN_ELIMINATE): Delete. + * config/mmix/mmix.h (CAN_ELIMINATE): Delete. + +2009-06-24 DJ Delorie <dj@redhat.com> + + * mep-ext-cop.cpu: Fix copyright notice. + * mep-default: Fix copyright notice. + * mep-core: Fix copyright notice. + * mep: Fix copyright notice. + * mep-ivc2: Fix copyright notice. + * mep-c5: Fix copyright notice. + +2009-06-24 Denis Chertykov <chertykov@gmail.com> + + * doc/contrib.texi (Contributors): + +2009-06-24 Andreas Krebbel <krebbel1@de.ibm.com> + + PR middle-end/40501 + * tree-ssa-math-opts.c (execute_optimize_bswap): Convert the bswap + src and dst operands if necessary. + +2009-06-23 DJ Delorie <dj@redhat.com> + + Add MeP port. + * config.gcc: Add mep support. + * recog.c: Resurrect validate_replace_rtx_subexp(). + * recog.h: Likewise. + * config/mep/: Add new port: + * config/mep/constraints.md: New file. + * config/mep/default.h: New file. + * config/mep/intrinsics.h: New file. + * config/mep/intrinsics.md: New file. + * config/mep/ivc2-template.h: New file. + * config/mep/mep-c5.cpu: New file. + * config/mep/mep-core.cpu: New file. + * config/mep/mep-default.cpu: New file. + * config/mep/mep-ext-cop.cpu: New file. + * config/mep/mep-intrin.h: New file. + * config/mep/mep-ivc2.cpu: New file. + * config/mep/mep-lib1.asm: New file. + * config/mep/mep-lib2.c: New file. + * config/mep/mep-pragma.c: New file. + * config/mep/mep-protos.h: New file. + * config/mep/mep-tramp.c: New file. + * config/mep/mep.c: New file. + * config/mep/mep.cpu: New file. + * config/mep/mep.h: New file. + * config/mep/mep.md: New file. + * config/mep/mep.opt: New file. + * config/mep/predicates.md: New file. + * config/mep/t-mep: New file. + +2009-06-23 Ian Lance Taylor <iant@google.com> + + * configure.ac: Invoke AC_PROG_CXX. Separate C specific warnings + from loose_warn into c_loose_warn and from strict_warn into + c_strict_warn. Set and substitute warn_cxxflags. Check for + --enable-build-with-cxx. Set and substitute + ENABLE_BUILD_WITH_CXX. Set and substitute HOST_LIBS. + * Makefile.in (CXXFLAGS): New variable. + (C_LOOSE_WARN, C_STRICT_WARN): New variables. + (GCC_WARN_CFLAGS): Add $(C_LOOSE_WARN). Add $(C_STRICT_WARN) if + the default is the same as $(STRICT_WARN). + (GCC_WARN_CXXFLAGS, WARN_CXXFLAGS): New variables. + (CXX): New variable. + (COMPILER): New value if ENABLE_BUILD_WITH_CXX. + (COMPILER_FLAGS, LINKER, LINKER_FLAGS): Likewise. + (ALL_COMPILERFLAGS, ALL_LINKERFLAGS): Likewise. + (HOST_LIBS): New variable. + (GCC_CFLAGS): Add $(C_LOOSE_WARN). + (ALL_CXXFLAGS): New variable. + (LIBS, BACKENDLIBS): Add $(HOST_LIBS). + * doc/install.texi (Configuration): Document + --enable-build-with-cxx, --with-stage1-ldflags, + --with-stage1-libs, --with-boot-ldflags, --with-boot-libs. + * configure: Rebuild. + +2009-06-24 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (arm_override_options): Fix braces and formatting + from previous commit. + +2009-06-23 Ian Lance Taylor <iant@google.com> + + * Makefile.in ($(out_object_file)): Depend upon $(DF_H). + +2009-06-23 Ian Lance Taylor <iant@google.com> + + * reload.c (alternative_allows_const_pool_ref): Mark mem parameter + with ATTRIBUTE_UNUSED. + +2009-06-23 Michael Meissner <meissner@linux.vnet.ibm.com> + Pat Haugen <pthaugen@us.ibm.com> + Revital Eres <eres@il.ibm.com> + + * config.in (HAVE_AS_POPCNTD): Add default definition. + (HAVE_AS_LWSYNC): Ditto. + + * configure.ac (gcc_cv_as_powerpc_mfpgpr): Provide real binutils + release number. + (gcc_cv_as_powerpc_cmpb): Ditto. + (gcc_cv_as_powerpc_dfp): Ditto. + (gcc_cv_as_powerpc_vsx): Ditto. + (gcc_cv_as_powerpc_popcntd): Add feature test for assembler + supporting the popcntd/lwsync instructions. + (gcc_cv_as_powerpc_lwsync): Ditto. + * configure: Regenerate. + + * config/rs6000/aix53.h (ASM_CPU_SPEC): Add support for + -mcpu=native and -mcpu=power7. + * config/rs6000/aix61.h (ASM_CPU_SPEC): Ditto. + + * config/rs6000/linux64.opt (-mprofile-kernel): Move switch to be + a variable instead of a mask to reduce the number of mask bits. + * config/rs6000/sysv4.opt (-mbit-align): Ditto. + (-mbit-word): Ditto. + (-mregnames): Ditto. + * config/rs6000/rs6000.opt (-mupdate): Ditto. + (-mfused-madd): Ditto. + + * config/rs6000/rs6000.opt (-mpopcntd): New switch for non-VSX ISA + 2.06 instructions. + (-mvsx): New switch for VSX instructions. + (-misel): Move from a variable to a mask to allow it to be set by + -mcpu=. + + * config/rs6000/rs6000-protos.h (rs6000_hard_regno_nregs): Change + function declaration to an array declaration. + (rs6000_hard_regno_nregs): New external array declaration. + + * config/rs6000/t-rs6000 (MD_INCLUDES): Define, add all of the .md + files included by rs6000.md. + + * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Use + SET_PROFILE_KERNEL macro to reset the -mprofile-kernel switch. + + * config/rs6000/rs6000.c (rs6000_isel): Delete, -misel moved to be + a target mask. + (rs6000_debug_reg): New -mdebug= variables. + (rs6000_debug_addr): Ditto. + (rs6000_debug_cost): Ditto. + (rs6000_pmode): New variable to hold Pmode. + (rs6000_pointer_size): New variable to hold POINTER_SIZE. + (rs6000_class_max_nregs): New array to hold CLASS_MAX_NREGS + calculated at compiler start. + (rs6000_hard_regno_nregs): Change function to an array which holds + HARD_REGNO_NREGS calculated at compiler start. + (rs6000_explicit_options): Delete isel field. + (rs6000_vector_unit): New array to hold which vector unit + supports arithmetic options for a given type. + (rs6000_vector_mem): New array to hold which vector unit supports + memory reference operations for a given type. + (rs6000_vector_align): New array to given the alignment of each + vector type. + (power7_cost): New basic costs for power7. + (SET_PROFILE_KERNEL): New macro for resetting -mprofile-kernel. + (rs6000_hard_regno_nregs_internal): New function, moved from + HARD_REGNO_NREGS, to calculate the number of registers each hard + register takes for each type. + (rs6000_debug_reg_print): New function for -mdebug=reg support. + (rs6000_debug_vector_unit): New array, map rs6000_vector to string. + (+rs6000_init_hard_regno_mode_ok): New function, move calculation + of HARD_REGNO_NREGS, CLASS_MAX_NREGS, REGNO_REG_CLASS, and vector + unit information here so it is calculated once at compiler startup + time. + (rs6000_override_options): Make -misel a target mask. Add more + power7 target masks. Setup Pmode and POINTER_SIZE. Add initial + VSX support. Add support for -mdebug=reg, -mdebug=addr, and + -mdebug=cost. + (POWERPC_MASKS): Add MASK_POPCNTD, MASK_VSX, and MASK_ISEL. + (rs6000_handle_option): Move -misel from variable to target mask. + (rs6000_builtin_mask_for_load): Add VSX support. + (rs6000_conditional_register_usage): Ditto. + (USE_ALTIVEC_FOR_ARG_P): Ditto. + (function_arg_boundary): Ditto. + (rs6000_expand_builtin): Ditto. + (def_builtin): Make abort message a little friendlier. + (rs6000_emit_int_cmove): Add support for 64-bit isel. + + * config/rs6000/rs6000.h (ASM_CPU_POWER7_SPEC): Depend on the + assembler support the popcntd instruction instead of a vsx + instruction to enable power7 support. + (ASM_CPU_SPEC): Add support for -mcpu=native and -mcpu=power7. + (EXTRA_SPECS): Add ASM_CPU_NATIVE_SPEC to allow passing the right + option to the assembler if -mcpu=native. + (ASM_CPU_NATIVE_SPEC): Ditto. + (TARGET_POPCNTD): If assembler doesn't support popcntd, turn off + ISA 2.06 features. + (TARGET_LWSYNC_INSTRUCTION): Define whether it is safe to issue + the lwsync instruction. + (enum processor_type): Add PROCESSOR_POWER7. + (rs6000_debug_reg): New -mdebug= options. + (rs6000_debug_addr): Ditto. + (rs6000_debug_cost): Ditto. + (rs6000_isel): Delete. + (enum rs6000_vector): New enum to say what vector unit we have. + (VECTOR_UNIT_*): New macros to say which vector unit has + arithmetic operations for a given type. + (VECTOR_MEM_*): New macros to say which vector unit has memory + operations for a given type. + (TARGET_LDBRX): Whether the machine supports the ldbrx + instruction. + (TARGET_ISEL): Delete, -misel moved to be a mask. + (TARGET_ISEL64): New macro for 64-bit isel support. + (UNITS_PER_VSX_WORD): New macro. + (POINTER_SIZE): Move to be an external variable, rather than + calculating whether we are generating 32 ot 64-bit code. + (Pmode): Ditto. + (STACK_BOUNDARY): Add VSX support. + (LOCAL_ALIGNMENT): Ditto. + (SLOW_UNALIGNED_ACCESS): Ditto. + (VSX_REGNO_P): New macro for VSX support. + (VFLOAT_REGNO_P): Ditto. + (VINT_REGNO_P): Ditto. + (VLOGICAL_REGNO_P): Ditto. + (VSX_VECTOR_MODE): Ditto. + (VSX_SCALAR_MODE): Ditto. + (VSX_MODE): Ditto. + (VSX_MOVE_MODE): Ditto. + (VSX_REG_CLASS_P): Ditto. + (HARD_REGNO_NREGS): Instead of calling a function, use an array + lookup. + (UNITS_PER_SIMD_WORD): Add VSX support. + (MODES_TIEABLE_P): Ditto. + (STARTING_FRAME_OFFSET): Ditto. + (STACK_DYNAMIC_OFFSET): Ditto. + (EPILOGUE_USES): Ditto. + (REGNO_REG_CLASS): Move to array lookup. + (CLASS_MAX_NREGS): Ditto. + (rs6000_vector_reg_class): Add declaration. + (ADDITIONAL_REGISTER_NAMES): Add VSX names for the registers that + overlap with the floating point and Altivec registers. + + * config/rs6000/e500.h (CHECK_E500_OPTIONS): Disallow -mvsx. + + * config/rs6000/driver-rs6000.c (asm_names): New static array to + give the appropriate asm switches if -mcpu=native. + (host_detect_local_cpu): Add support for "asm". + (host_detect_local_cpu): Follow GNU code guidelines for name. + + * config/rs6000/sysv4.h (SUBTARGET_OVERRIDE_OPTIONS): Move + -mbit-word to a variable instead of being a target mask. + + * config/rs6000/sync.md (lwsync): If the assembler supports it, + emit the lwsync instruction instead of emitting the instruction as + an integer constant. + + * config/rs6000/spe.md (spe_fixuns_truncdfsi2): Rename from + fixuns_trundfsi2, move expander into rs6000.md. + + * config/rs6000/rs6000.md (cpu): Add power7. + (sel, *ptrsize): New mode attributes for 32/64-bit isel. + (logical predicate patterns): Change the single instruction + primitives that set CR0 to be fast_compare instead of compare. + (norsi*): Ditto. + (popcntwsi2): Add support for ISA 2.06 popcount instructions. + (popcntddi2): Ditto. + (popcount<mode>): Ditto. + (floating multiply/add insns): Name the floating point + multiply/add insns. + (isel_signed_<mode>): Add support for -misel on 64-bit systems. + (isel_unsigned_<mode>): Ditto. + (fixuns_trundfsi2): Move expander here from spe.md. + (smindi3): Define if we have -misel on 64-bit systems. + (smaxdi3): Ditto. + (umindi3): Ditto. + (umaxdi3): Ditto. + +2009-06-23 Anatoly Sokolov <aesok@post.ru> + + * config.gcc (avr-*-rtems*, avr-*-*): Set extra_gcc_objs and + extra_objs. + * config/avr/avr.c (avr_current_device): New variable. + (avr_arch_types, avr_mcu_types): Move to avr-deveces.c. + (avr_arch, mcu_type_s): Move to avr.h. + * config/avr/avr.h (base_arch_s). Add reserved2, arch_name and + default_data_section_start fields. + (avr_arch): Moved from avr.c. + (mcu_type_s): Moved from avr.c. Add short_sp, data_section_start and + library_name fields. + (avr_current_device, avr_mcu_types, avr_arch_types, + avr_device_to_arch, avr_device_to_data_start, + avr_device_to_startfiles, avr_device_to_devicelib): Declare. + (EXTRA_SPEC_FUNCTIONS): Define. + (LINK_SPEC): Remove device name to '-m ...' and '-Tdata ...' linker + options mapping. Use device_to_arch and device_to_data_start insted. + (STARTFILE_SPEC): Use device_to_startfile instead of crt_binutils. + (CRT_BINUTILS_SPECS, EXTRA_SPECS): Remove. + * config/avr/t-avr (driver-avr.o, avr-devices.o): New rules. + * config/avr/driver-avr.c: New file. + * config/avr/avr-devices.c: New file. + +2009-06-23 Jakub Jelinek <jakub@redhat.com> + + * var-tracking.c (unshare_variable): Force initialized to + be VAR_INIT_STATUS_INITIALIZED unless flag_var_tracking_uninit. + (set_variable_part): Likewise. + (struct variable_union_info): Remove pos_src field. + (vui_vec, vui_allocated): New variables. + (variable_union): Pass VAR_INIT_STATUS_UNKNOWN to unshare_variable + unconditionally. Avoid XCVECNEW/free for every sorting, for dst_l + == 1 use a simpler sorting algorithm. Compute pos field right + away, don't fill in pos_src. For dst_l == 2 avoid qsort. + Avoid quadratic comparison if !flag_var_tracking_uninit. + (variable_canonicalize): Pass VAR_INIT_STATUS_UNKNOWN to + unshare_variable unconditionally. + (dataflow_set_different_2): Removed. + (dataflow_set_different): Don't traverse second hash table. + (compute_bb_dataflow): Pass VAR_INIT_STATUS_UNINITIALIZED + unconditionally to var_reg_set or var_mem_set. + (emit_notes_in_bb): Likewise. + (delete_variable_part): Pass VAR_INIT_STATUS_UNKNOWN to + unshare_variable. + (emit_note_insn_var_location): Don't set initialized to + VAR_INIT_STATUS_INITIALIZED early. + (vt_finalize): Free vui_vec if needed, clear vui_vec and + vui_allocated. + * rtl.c (rtx_equal_p): Don't implement on top of rtx_equal_p_cb. + + * tree-object-size.c (addr_object_size): Instead of checking + for non-NULL TREE_CHAIN of the FIELD_DECL check that there + are no FIELD_DECLs following it. + +2009-06-23 Andreas Krebbel <krebbel1@de.ibm.com> + + * tree-ssa-math-opts.c (find_bswap): Increase the search depth in + order to match bswaps with signed source operands. + +2009-06-23 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE> + + * sdbout.c (sdbout_one_type): Fix braces in switch. + +2009-06-23 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (struct variable_info): Add is_global_var + member. + (var_anything, anything_tree, var_nothing, nothing_tree, var_readonly, + readonly_tree, var_escaped, escaped_tree, var_nonlocal, nonlocal_tree, + var_callused, callused_tree, var_storedanything, storedanything_tree, + var_integer, integer_tree): Remove global variables. + (new_var_info): Do not pass new id, append the new var to the + global variable vector. + (do_ds_constraint): Use is_global_var member of the variable-info. + (new_scalar_tmp_constraint_exp): Adjust. + (create_function_info_for): Likewise. + (create_variable_info_for): Likewise. + (find_what_var_points_to): Remove dead code. + (init_base_vars): Simplify. + (compute_points_to_sets): Adjust. + +2009-06-22 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (try_combine): Dump information about the insns we're + combining. + +2009-06-22 Adam Nemet <anemet@caviumnetworks.com> + + * combine.c (combine_simplify_rtx): Remove TRULY_NOOP_TRUNCATION + check when calling force_to_mode on TRUNCATE's operand. + +2009-06-22 Ian Lance Taylor <iant@google.com> + + * config/rs6000/rs6000.opt: Move msched-epilog before msched-prolog. + +2009-06-22 Steven Bosscher <steven@gcc.gnu.org> + + * config/arm/arm.md (prologue_use): Set length of fake insn to 0. + +2009-06-22 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/invoke.texi (Link Options): -nodefaultlibs and -nostdlib + override library linkage flags such as -static-libgcc or + -shared-libgcc. + +2009-06-22 Maxim Kuvyrkov <maxim@codesourcery.com> + + * config/m68k/m68k-devices.def: Add line for MCF5221x. + +2009-06-22 Ian Lance Taylor <iant@google.com> + + * config/linux.opt: Put mglibc ahead of muclibc. + + * c-decl.c (diagnose_mismatched_decls): Add -Wc++-compat warning + for duplicate decls. + +2009-06-22 Matthias Klose <doko@ubuntu.com> + + * Makefile.in (install-plugin): Remove extra `/' after $(DESTDIR). + +2009-06-22 Steven Bosscher <steven@gcc.gnu.org> + + PR objc/28050 + * c-parser.c (c_parser_objc_message_args): Return error_mark_node + instead of NULL if a parser error occurs. + +2009-06-22 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE> + + * dwarf2out.c (dwarf2_debug_hooks): Initialize + non-DWARF2_DEBUGGING_INFO version. + +2009-06-22 Kai Tietz <kai.tietz@onevision.com> + + * config.gcc (i[34567]86-*-mingw*, x86_64-*-mingw*): Add + i386/t-fprules-softfp and soft-fp/t-softfp to tmake_file. + + * config/i386/mingw32.h (LIBGCC2_HAS_TF_MODE): Define. + (LIBGCC2_TF_CEXT): Define. + (TF_SIZE): Define. + +2009-06-22 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + PR target/40463 + * config/arm/linux-eabi.h (CLEAR_INSN_CACHE): Fix definition. + +2009-06-22 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (arm_override_options): Disable + -mcaller-super-interworking and -mcallee-super-interworking. + * doc/invoke.texi (ARM Options): Document this. + +2009-06-22 Nathan Sidwell <nathan@codesourcery.com> + + * config/arm/arm.c (arm_print_operand): Deal with HIGH. + * config/arm/constraints.md (j): New constraint for movw operands. + (N): Remove thumb2 meaning. + * config/arm/arm.md (*arm_movw): Delete. + (*arm_movsi_insn): Use j constraint for movw instead of N constraint. + * config/arm/vfp.md (*arm_movsi_vfp, *thumb2_movsi_vfp): Likewise. + * config/arm/thumb2.md (*thumb2_movsi_insn): Likewise. + +2009-06-22 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40492 + * tree-sra.c (sra_modify_assign): Pass zero offsets to + build_ref_for_offset. + +2009-06-22 Shujing Zhao <pearly.zhao@oracle.com> + + * alias.c: Use REG_P, MEM_P, CONST_INT_P, LABEL_P, CALL_P, NOTE_P and + JUMP_TABLE_DATA_P predicates where applicable. + * auto-inc-dec.c: Ditto. + * builtins.c: Ditto. + * caller-save.c: Ditto. + * calls.c: Ditto. + * cfgcleanup.c: Ditto. + * cfglayout.c: Ditto. + * cfgrtl.c: Ditto. + * combine.c: Ditto. + * combine-stack-adj.c: Ditto. + * cse.c: Ditto. + * cselib.c: Ditto. + * dbxout.c: Ditto. + * df-scan.c: Ditto. + * dse.c: Ditto. + * dwarf2asm.c: Ditto. + * dwarf2out.c: Ditto. + * emit-rtl.c: Ditto. + * except.c: Ditto. + * explow.c: Ditto. + * expmed.c: Ditto. + * expr.c: Ditto. + * final.c: Ditto. + * function.c: Ditto. + * fwprop.c: Ditto. + * gcse.c: Ditto. + * genpreds.c: Ditto. + * genrecog.c: Ditto. + * ifcvt.c: Ditto. + * ira-costs.c: Ditto. + * ira-lives.c: Ditto. + * jump.c: Ditto. + * loop-iv.c: Ditto. + * lower-subreg.c: Ditto. + * modulo-sched.c: Ditto. + * optabs.c: Ditto. + * postreload.c: Ditto. + * print-rtl.c: Ditto. + * recog.c: Ditto. + * reginfo.c: Ditto. + * regmove.c: Ditto. + * reload1.c: Ditto. + * reload.c: Ditto. + * reorg.c: Ditto. + * rtlanal.c: Ditto. + * rtl.c: Ditto. + * sched-vis.c: Ditto. + * sdbout.c: Ditto. + * sel-sched-ir.c: Ditto. + * simplify-rtx.c: Ditto. + * targhooks.c: Ditto. + * var-tracking.c: Ditto. + * vmsdbgout.c: Ditto. + +2009-06-22 Matthias Klose <doko@ubuntu.com> + + * Makefile.in (install-plugin): Always use DESTDIR. + +2009-06-22 Olivier Hainque <hainque@adacore.com> + + * config/pa/pa.c (output_call): Don't optimize post call jumps + into return address adjustments if the call may throw. + +2009-06-21 Richard Earnshaw <rearnsha@arm.com> + + * arm.c (thumb1_output_casesi): New function. + * arm.h (CASE_VECTOR_PC_RELATIVE): Thumb-1 code is also relative if + optimizing for size or PIC. + (CASE_VECTOR_SHORTEN_MODE): Handle thumb-1. + * arm.md (UNSPEC_THUMB1_CASESI): New constant. + (casesi): Handle Thumb-1 when optimizing for size or PIC. + (thumb1_casesi_internal_pic): New expand rule. + (thumb1_casesi_dispatch): New pattern. + * aout.h (ASM_OUTPUT_ADDR_DIFF_ELT): Use shortened vectors for + thumb-1 mode. + * coff.h (JUMP_TABLES_IN_TEXT_SECTION): Thumb-1 jump tables are now + in the text seciton when PIC or optimizing for size. + * elf.h (JUMP_TABLES_IN_TEXT_SECTION): Likewise. + * lib1funcs.asm ([__ARM_EABI__]): Add an attribute describing stack + preservation properties of code. + (__gnu_thumb1_case_sqi, __gnu_thumb1_case_uqi): New functions. + (__gnu_thumb1_case_shi, __gnu_thumb1_case_uhi): New functions. + (__gnu_thumb1_case_si): New function. + * t-arm (LIB1ASMSRC): Define here. + (LIB1ASMFUNCS): Add some common functions. + * t-arm-elf (LIB1ASMSRC): Delete. + (LIB1ASMFUNCS): Append to existing set. + * t-pe (LIB1ASMSRC, LIB1ASMFUNCS): Likewise. + * t-strongarm-elf (LIB1ASMSRC, LIB1ASMFUNCS): Likewise. + * t-symbian (LIB1ASMFUNCS): Likewise. + * t-vxworks (LIB1ASMSRC, LIB1ASMFUNCS): Likewise. + * t-wince-pe (LIB1ASMSRC, LIB1ASMFUNCS): Likewise. + +2009-06-21 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38729 + * tree-ssa-loop-niter.c (find_loop_niter_by_eval): Restrict + to loops with a single exit if -fno-expensive-optimizations. + +2009-06-21 Jakub Jelinek <jakub@redhat.com> + + * var-tracking.c (struct shared_hash_def, shared_hash): New types. + (dataflow_set): Change vars type from htab_t to shared_hash. + (shared_hash_pool, empty_shared_hash): New variables. + (vars_clear): Removed. + (shared_hash_shared, shared_hash_htab, shared_hash_copy, + shared_hash_find_slot_unshare, shared_hash_find_slot, + shared_hash_find_slot_noinsert, shared_hash_find): New + static inlines. + (shared_hash_unshare, shared_hash_destroy): New functions. + (unshare_variable): Unshare set->vars if shared, use + shared_hash_htab. + (vars_copy): Use htab_traverse_noresize instead of htab_traverse. + (get_init_value, find_src_set_src, dump_dataflow_set, + clobber_variable_part, emit_notes_for_differences): Use + shared_hash_htab. + (dataflow_set_init): Remove second argument, set vars to + empty_shared_hash instead of creating a new htab. + (dataflow_set_clear): Call shared_hash_destroy and set vars + to empty_shared_hash instead of calling vars_clear. + (dataflow_set_copy): Don't call vars_copy, instead just share + the src htab with dst. + (variable_union): Use shared_hash_*, use initially NO_INSERT + lookup if set->vars is shared. Don't keep slot cleared before + calling unshare_variable. Unshare set->vars if needed. + Even ->refcount == 1 vars must be unshared if set->vars is shared + and var needs to be modified. + (variable_canonicalize): New function. + (dataflow_set_union): If dst->vars is empty, just share src->vars + with dst->vars and traverse with variable_canonicalize to canonicalize + and unshare what is needed. + (dataflow_set_different): If old_set and new_set use the same shared + htab, they aren't different. If number of htab elements is different, + htabs are different. Use shared_hash_*. + (dataflow_set_destroy): Call shared_hash_destroy instead of + htab_delete. + (compute_bb_dataflow, emit_notes_in_bb, vt_emit_notes): Don't pass + second argument to dataflow_set_init. + (vt_initialize): Likewise. Initialize shared_hash_pool and + empty_shared_hash, move bb in/out initialization afterwards. + Use variable_htab_free instead of NULL as changed_variables del hook. + (variable_was_changed): Change type of second argument to pointer to + dataflow_set. When inserting var into changed_variables, bump + refcount. Unshare set->vars if set is shared htab and slot needs to + be cleared. + (set_variable_part): Use shared_hash_*, use initially NO_INSERT + lookup if set->vars is shared. Unshare set->vars if needed. + Even ->refcount == 1 vars must be unshared if set->vars is shared + and var needs to be modified. Adjust variable_was_changed caller. + (delete_variable_part): Use shared_hash_*. Even ->refcount == 1 + vars must be unshared if set->vars is shared and var needs to be + modified. Adjust variable_was_changed caller. + (emit_note_insn_var_location): Don't pool_free var. + (emit_notes_for_differences_1): Initialize empty_var->refcount to 0 + instead of 1. + (vt_finalize): Call htab_delete on empty_shared_hash->htab and + free_alloc_pool on shared_hash_pool. + +2009-06-20 Anthony Green <green@moxielogic.com> + + * config/moxie/sfp-machine.h (__gcc_CMPtype, CMPtype): Define. + * config/moxie/moxie.h (LOAD_EXTEND_OP): Define. + +2009-06-20 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (find_func_aliases): For memset use + a constraint from NULL if we memset to zero. + * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Add builtins + we explicitly handle that do not read from memory. + (call_may_clobber_ref_p_1): Properly handle builtins that may + set errno. + +2009-06-20 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40495 + * tree-ssa-structalias.c (get_constraint_exp_for_temp): Remove. + (new_scalar_tmp_constraint_exp): New function. + (process_constraint): Do not create temporary decls. + (process_all_all_constraints): Likewise. + (handle_const_call): Likewise. + (create_function_info_for): Do not set decl. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * config/rs6000/rs6000.c (rs6000_explicit_options): Make static. + (rs6000_attribute_table): Make static; move before use. + +2009-06-19 Eric Botcazou <ebotcazou@adacore.com> + + * tree.c (substitute_in_expr) <COMPONENT_REF>: Tweak and reformat. + <tcc_vl_exp>: Call process_call_operands on the new CALL_EXPR. + Propagate the TREE_READONLY flag without overwriting it. + (substitute_placeholder_in_expr) <tcc_vl_exp>: Likewise. + Propagate the TREE_READONLY flag onto the result. + (process_call_operands): Move around. Use correct constant value. + +2009-06-19 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + PR target/40482 + * config/arm/arm.c (thumb_shiftable_const): Truncate val to 32 bits. + * config/arm/arm.md: Likewise. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * tree-cfg.c (gimple_redirect_edge_and_branch): Change ERROR_MARK + to GIMPLE_ERROR_MARK. + + * c-typeck.c (build_conditional_expr): Add op1_original_type and + op2_original_type parameters. Warn about using different enum types. + * c-parser.c (c_parser_conditional_expression): Pass original + types to build_conditional_expr. + * c-tree.h (build_conditional_expr): Update declaration. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * config/i386/i386.c (ix86_function_specific_save): Test that + fields match values, rather than testing the values are in a + certain range. + +2009-06-19 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (ptr_deref_may_alias_decl_p): Handle + ADDR_EXPR pointers. + (ptr_derefs_may_alias_p): Likewise. + (ptr_deref_may_alias_ref_p_1): New function. + (ptr_deref_may_alias_ref_p): Likewise. + (ref_maybe_used_by_call_p_1): Handle builtins that are not + covered by looking at the ESCAPED solution. + (call_may_clobber_ref_p_1): Likewise. + * tree-ssa-structalias.c (get_constraint_for_ptr_offset): + Handle NULL_TREE offset. Do not produce redundant constraints. + (process_all_all_constraints): New helper function. + (do_structure_copy): Use it. + (handle_lhs_call): Likewise. + (find_func_aliases): Handle some builtins with pointer arguments + and/or return values explicitly. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * varasm.c (const_rtx_hash_1): Remove const qualifier from shift. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * rtl.h (SUBREG_PROMOTED_UNSIGNED_P): Add cast to int. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * ggc-page.c (ggc_pch_write_object): Initialize emptyBytes. + * sdbout.c (sdb_debug_hooks): Initialize non-SDB_DEBUGGING_INFO + version. + + * c-decl.c (finish_decl): If -Wc++-compat, warn about + uninitialized const. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * dse.c (struct store_info): Rename bitmap field to bmap. Change + all uses. + + * c-decl.c (in_struct, struct_types): Remove. + (struct c_binding): Add in_struct field. + (c_binding_ptr): Define type, along with VEC. + (struct c_struct_parse_info): Define. + (struct_parse_info): New static variable. + (bind): Initialize in_struct field. + (start_struct): Remove enclosing_in_struct and + enclosing_struct_types parameters. Add + enclosing_struct_parse_info parameter. Change all callers. Set + struct_parse_info rather than in_struct and struct_types. + (grokfield): If -Wc++-compat and there is a symbol binding for the + field name, set the in_struct flag and push it on the + struct_parse_info->fields vector. + (warn_cxx_compat_finish_struct): New static function. + (finish_struct): Remove enclosing_in_struct and + enclosing_struct_types parameters. Add + enclosing_struct_parse_info parameter. Change all callers. Don't + set C_TYPE_DEFINED_IN_STRUCT here. Call + warn_cxx_compat_finish_struct. Free struct_parse_info and set to + parameter. Only push on struct_types if warn_cxx_compat. + (finish_enum): Only push on struct_types if warn_cxx_compat. + (declspecs_add_type): Add loc parameter. Change all callers. + Change all error calls to error_at. Pass loc, not input_location, + to pedwarn calls. Warn if -Wc++-compat and a typedef name is + defined in a struct. If -Wc++-compat and parsing a struct, record + that a typedef name was used. + * c-parser.c (c_parser_declspecs): Get location to pass to + declspecs_add_type. + (c_parser_struct_or_union_specifier): Update calls to start_struct + and finish_struct. + * c-tree.h (struct c_struct_parse_info): Declare. + (finish_struct, start_struct): Update declarations. + (declspecs_add_type): Update declaration. + +2009-06-19 Ian Lance Taylor <iant@google.com> + + * c-decl.c (grokdeclarator): If -Wc++-compat, warn about a global + variable with an anonymous type. + +2009-06-19 Uros Bizjak <ubizjak@gmail.com> + + * see.c: Remove for real. + +2009-06-19 Uros Bizjak <ubizjak@gmail.com> + + * optabs.h (enum optab_index): Add new OTI_significand. + (significand_optab): Define corresponding macro. + * optabs.c (init_optabs): Initialize significand_optab. + * genopinit.c (optabs): Implement significand_optab using + significand?f2 patterns. + * builtins.c (expand_builtin_mathfn): Handle + BUILT_IN_SIGNIFICAND{,F,L}. + (expand_builtin): Expand BUILT_IN_SIGNIFICAND{,F,L} using + expand_builtin_mathfn if flag_unsafe_math_optimizations is set. + + * config/i386/i386.md (significandxf2, significand<mode>2): New + expanders to implement significandf, significand and significandl + built-ins as inline x87 intrinsics. + +2009-06-18 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.c (avr_override_options): Remove setting value of + PARAM_INLINE_CALL_COST. + +2009-06-18 Richard Henderson <rth@redhat.com> + + PR 40488 + * tree-pass.h (TDF_ASMNAME): New. + * tree-dump.c (dump_options): Add asmname. + * doc/invoke.texi: Document it. + + * tree-pretty-print.c (maybe_dump_asm_name): Merge into... + (dump_decl_name): ...here. + (dump_function_name): New flags arg; mind TDF_ASMNAME. + (dump_generic_node): Update dump_function_name calls. + (print_call_name): New flags arg; update all dump calls. + * diagnostic.h (print_call_name): Update. + * gimple-pretty-print.c (dump_gimple_call): Update. + +2009-06-18 H.J. Lu <hongjiu.lu@intel.com> + + PR target/40470 + * config/i386/i386.h (CLASS_LIKELY_SPILLED_P): Add SSE_FIRST_REG. + +2009-06-18 Diego Novillo <dnovillo@google.com> + + * doc/plugins.texi: Document plugin_is_GPL_compatible. + * plugin.c (str_license): Declare. + (try_init_one_plugin): Assert that the symbol + 'plugin_is_GPL_compatible' exists. + +2009-06-18 Sergei Dyshel <sergeid@il.ibm.com> + + * see.c: Remove. + * Makefile.in (OBJS-common): Remove see.o. + (see.o): Remove. + * common.opt (fsee): Mark as preserved for backward compatibility. + * opts.c (common_handle_option): Add OPT_fsee to the backward + compatibility section. + * passes.c (init_optimization_passes, pass_see): Remove pass. + * timevar.def (TV_SEE): Remove. + * tree-pass.h (pass_see): Remove declaration. + * doc/invoke.texi (-fsee): Remove documentation. + +2009-06-18 Martin Jambor <mjambor@suse.cz> + + * tree-sra.c: Include statistics.h + (sra_stats): New variable. + (sra_initialize): Clear sra_stats. + (create_access_replacement): Increment sra_stats.replacements. + (get_access_replacement): Do not return twice. + (analyze_all_variable_accesses): Increment statistics counter by the + number of scalarized aggregates. + (generate_subtree_copies): Increment sra_stats.subtree_copies. + (sra_modify_expr): Increment sra_stats.exprs. + (load_assign_lhs_subreplacements): Increment sra_stats.subreplacements. + (sra_modify_assign): Increment sra_stats.exprs, + sra_stats.separate_lhs_rhs_handling and sra_stats.deleted. + (perform_intra_sra): Update statistics counters. + * Makefile.in (tree-sra.o): Add statistics.h to dependencies. + +2009-06-18 Sandra Loosemore <sandra@codesourcery.com> + + * config/arm/arm.c (TARGET_SCALAR_MODE_SUPPORTED_P): Redefine. + (arm_scalar_mode_supported_p): New function. + +2009-06-18 Paul Brook <paul@codesourcery.com> + Sandra Loosemore <sandra@codesourcery.com> + + * config/arm/sfp-machine.h (_FP_NANFRAC_H, _FP_NANSIGN_H): Define. + (__extendhfsf2, __truncsfhf2): Define. + * config/arm/fp16.c: New file. + * config/arm/t-bpabi (LIB2FUNCS_STATIC_EXTRA): Add fp16.c. + * config/arm/t-symbian (LIB2FUNCS_STATIC_EXTRA): Add fp16.c. + +2009-06-18 Sandra Loosemore <sandra@codesourcery.com> + + * doc/extend.texi (Half-Precision): New section. + * doc/invoke.texi (Option Summary): List -mfp16-format. + (ARM Options): List neon-fp16 as -mfpu value. Document -mfp16-format. + * config/arm/arm.opt (mfp16-format=): New. + * config/arm/arm.c: Include intl.h. + (TARGET_INVALID_PARAMETER_TYPE): Redefine. + (TARGET_INVALID_RETURN_TYPE): Redefine. + (TARGET_PROMOTED_TYPE): Redefine. + (TARGET_CONVERT_TO_TYPE): Redefine. + (arm_fp16_format): Define. + (all_fpus): Add entry for neon-fp16. + (fp_model_for_fpu): Likewise. + (struct fp16_format): Declare. + (all_fp16_formats): Define. + (arm_init_libfuncs): Add entries for HFmode conversions and arithmetic + functions. + (arm_override_options): Set arm_fp16_format. Call sorry for fp16 + and no ldrh. + (arm_legitimate_index_p): Treat HFmode like HImode. + (thumb1_legitimate_address_p): Make it recognize HFmode constants. + (coproc_secondary_reload_class): Special-case HFmode. + (arm_print_operand): Add 'z' specifier for vld1.16/vst1.16. + (arm_hard_regno_mode_ok): Allow HFmode values in VFP registers. + (arm_init_fp16_builtins): New. + (arm_init_builtins): Call it. + (arm_invalid_parameter_type): New. + (arm_invalid_return_type): New. + (arm_promoted_type): New. + (arm_convert_to_type). + (arm_file_start): Deal with neon-fp16 as fpu_name. Emit tag for fp16 + format. + (arm_emit_fp16_const): New function. + (arm_mangle_type): Mangle __fp16 as "Dh". + * config/arm/arm.h (TARGET_VFPD32): Make it know about + FPUTYPE_NEON_FP16. + (TARGET_NEON_FP16): New. + (TARGET_NEON): Make it know about FPUTYPE_NEON_FP16. + (enum fputype): Add FPUTYPE_NEON_FP16. + (enum arm_fp16_format_type): Declare. + (arm_fp16_format): Declare. + (LARGEST_EXPONENT_IS_NORMAL): Define. + * config/arm/arm-protos.h (arm_emit_fp16_const): Declare. + * config/arm/arm-modes.def (HFmode): Define. + * config/arm/vfp.md (*movhf_vfp): New. + (extendhfsf2): New. + (truncsfhf2): New. + * config/arm/arm.md (fpu): Add neon_fp16. + (floatsihf2, floatdihf2): New. + (fix_trunchfsi2, fix_trunchfdi2): New. + (truncdfhf2): New. + (extendhfdf2): New. + (movhf): New. + (*arm32_movhf): New. + (*thumb1_movhf): New. + (consttable_2): Add check for HFmode constants. + (consttable_4): Handle HFmode constants. + +2009-06-18 Uros Bizjak <ubizjak@gmail.com> + + * convert.c (convert_to_integer): Convert (int)logb() into ilogb(). + +2009-06-17 Olivier Hainque <hainque@adacore.com> + + * collect2.c (main): Use CONST_CAST2 to perform char ** to + const char ** conversion in AIX specific section. + +2009-06-17 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (ix86_special_builtin_type): Remove + UINT64_FTYPE_PINT. Add UINT64_FTYPE_PUNSIGNED. + (bdesc_special_args): Updated. + (ix86_init_mmx_sse_builtins): Likewise. + (ix86_expand_special_args_builtin): Likewise. + +2009-06-17 Richard Henderson <rth@redhat.com> + + * tree-pretty-print.c (maybe_dump_asm_name): New. + (dump_decl_name): Use it. + (PRINT_FUNCTION_NAME): Merge into... + (dump_function_name): ... here. Use maybe_dump_asm_name. + +2009-06-17 Cary Coutant <ccoutant@google.com> + + * dbxout.c (dbxout_source_line): Add is_stmt parameter. + Change caller. + * debug.c (struct gcc_debug_hooks): Change placeholder for + source_line hook. + (debug_nothing_int_charstar_int): Replaced by... + (debug_nothing_int_charstar_int_bool): ...this. + * debug.h (struct gcc_debug_hooks): Add is_stmt parameter to + source_line prototype. + (debug_nothing_int_charstar_int): Replaced by... + (debug_nothing_int_charstar_int_bool): ...this. + * defaults.h (SUPPORTS_DISCRIMINATOR): New constant. + * dwarf2out.c (dwarf2out_source_line): Add is_stmt parameter. + Output is_stmt operand when necessary. + * final.c (final_scan_insn): Pass is_stmt to source_line debug hook. + (notice_source_line): Add is_stmt parameter. + * sdbout.c (sdbout_source_line): Add is_stmt parameter. + * vmsdbgout.c (vmsdbgout_source_line): Add is_stmt parameter. + Change callers. + * xcoffout.c (xcoffout_source_line): Add is_stmt parameter. + * xcoffout.h (xcoffout_source_line): Add is_stmt parameter. + +2009-06-17 Ian Lance Taylor <iant@google.com> + + * expr.c (struct move_by_pieces_d): Rename from move_by_pieces. + Change all uses. + (struct store_by_pieces_d): Rename from store_by_pieces. Change + call uses. + +2009-06-17 Adam Nemet <anemet@caviumnetworks.com> + + * tree.h (STRIP_NOPS, STRIP_SIGN_NOPS, + STRIP_USELESS_TYPE_CONVERSION): Use tree_strip_nop_conversions, + tree_strip_sign_nop_conversions and + tree_ssa_strip_useless_type_conversions rather than stripping + the operations here. + (tree_strip_nop_conversions, tree_strip_sign_nop_conversions): + Declare them. + * gimple.h (tree_ssa_strip_useless_type_conversions): Declare it. + * tree-ssa.c (tree_ssa_strip_useless_type_conversions): New function. + * tree.c (tree_nop_conversion, tree_sign_nop_conversion, + tree_strip_nop_conversions, tree_strip_sign_nop_conversions): New + functions. + +2009-06-17 Michael Eager <eager@eagercon.com> + + * config/rs6000/constraints.md (register_constraint "d"): New. + * config/rs6000/dfp.md (movsd_store, extendsddd2, extendsdtd2, + truncddsd2, *negdd2_fpr, *absdd2_fpr, *nabsdd2_fpr, + *movdd_hardfloat32, *movdd_hardfloat64_mfpgpr, *movdd_hardfloat64, + *negtd2_fp, *abstd2_fpr, *nabstd2_fpr, *movtd_internal, extendddtd2, + trunctddd2, adddd3, addtd3, subdd3, subtd3, muldd3, multd3, divdd3, + divtd3, *cmpdd_internal1, *cmptd_internal1, floatditd2, ftruncdd2, + fixdddi2, ftrunctd2, fixtddi2): replace 'f' constraint with 'd' + * config/rs6000/ppu_intrinsics.h (__mffs, __mtfsf, __mtfsfi, __fabs, + __fnabs, __fmadd, __fmsub, __fnmadd, __fnmsub, __fsel, __frsqrte, + __fsqrt, __fmul, __fmuls, __frsp, __fcfid, __fctid, __fctidz, __fctiw, + __fctiwz): Same. + * config/rs6000/rs6000.md (*extendsfdf2_fpr, *truncdfsf2_fpr, + *fseldfsf4, *negdf2_fpr, *absdf2_fpr, *nabsdf2_fpr, *adddf3_fpr, + *subdf3_fpr, *muldf3_fpr, *divdf3_fpr, recipdf3, fred, sqrtdf2, + *fseldfdf4, *fselsfdf4, *floatsidf2_internal, *floatunssidf2_internal, + *fix_truncdfsi2_internal, fix_truncdfsi2_internal_gfxopt, + fix_truncdfsi2_mfpgpr, fctiwz, btruncdf2, ceildf2, floordf2, rounddf2, + stfiwx, floatdidf2, fix_truncdfdi2, floatdisf2_internal1, + *movdf_hardfloat32, *movdf_hardfloat64_mfpgpr, *movdf_hardfloat64, + *movtf_internal, *extenddftf2_internal, trunctfdf2_internal1, + trunctfdf2_internal2, trunctfsf2_fprs, fix_trunc_helper, + *fix_trunctfsi2_internal, negtf2_internal, *movdi_internal32, + *movdi_mfpgpr, *movdi_internal64, *movdf_update1, *movdf_update2, + *cmpdf_internal1, *cmptf_internal1, *cmptf_internal2): Same. + * doc/md.texi: Describe PowerPC 'd' constraint, update 'f' constraint. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * profile.c (total_num_never_executed): Don't define. + (compute_branch_probabilities): Don't count or print + num_never_executed. + (init_branch_prob): Don't set total_num_never_executed. + (end_branch_prob): Don't print total_num_never_executed. + +2009-06-17 David Daney <ddaney@caviumnetworks.com> + + * jump.c (cleanup_barriers): Handle case of no insns before a barrier. + +2009-06-17 David Edelsohn <edelsohn@gnu.org> + + * config/rs6000/dfp.md (nabsdd2_fpr): Correct mode. + (nabstd2_fpr): Same. + +2009-06-17 Steve Ellcey <sje@cup.hp.com> + + * expr.c (expand_assignment): Change complex type check. + +2009-06-17 Basile Starynkevitch <basile@starynkevitch.net> + + * doc/plugins.texi (Building GCC plugins): Added new section. + +2009-06-17 Ian Lance Taylor <iant@google.com> + + * c-pch.c (get_ident): Don't set size of templ array. + (pch_init): Don't set size of partial_pch array. + + * c-typeck.c (digest_init): If -Wc++-compat, warn about using a + string constant to intialize an array whose size is the length of + the string. + +2009-06-17 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40389 + * tree-ssa-structalias.c (handle_rhs_call): Restrict NRV case + to addressable types. + * gimple.c (walk_stmt_load_store_addr_ops): Likewise. + +2009-06-17 Richard Guenther <rguenther@suse.de> + + PR middle-end/40460 + * tree-chrec.h (build_polynomial_chrec): If we cannot determine + if there is no evolution of left in the loop bail out. + * tree-chrec.c (chrec_fold_multiply_poly_poly): CSE one + chrec_fold_multiply. + +2009-06-16 J"orn Rennecke <joern.rennecke@arc.com> + Janis Johnson <janis187@us.ibm.com> + + PR target/39254 + * config/rs6000/rs6000.c (rs6000_emit_move): Don't emit a USE + for the symbol ref of a constant that is the source of a move + - nor for any other not-obvious-label-ref constants. + +2009-06-16 Olatunji Ruwase <tjruwase@google.com> + + * plugin.c (position_pass): Skip newly inserted pass during list + traversal to avoid repeated insertion. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * vec.h (VEC_stack_alloc): Define different version if + GATHER_STATISTICS is defined, to accept and ignore MEM_STAT. + (DEF_VEC_ALLOC_FUNC_P_STACK): Remove MEM_STAT_DECL. + (DEF_VEC_ALLOC_FUNC_O_STACK): Likewise. + (DEF_VEC_ALLOC_FUNC_I_STACK): Likewise. + +2009-06-16 H.J. Lu <hongjiu.lu@intel.com> + + * config.gcc (extra_headers): Add ia32intrin.h for x86. + + * config/i386/i386.c (ix86_builtins): Add IX86_BUILTIN_BSRSI, + IX86_BUILTIN_BSRDI. IX86_BUILTIN_RDPMC, IX86_BUILTIN_RDTSC. + IX86_BUILTIN_RDTSCP. IX86_BUILTIN_ROLQI, IX86_BUILTIN_ROLHI, + IX86_BUILTIN_RORQI and IX86_BUILTIN_RORHI. + (ix86_special_builtin_type): Add UINT64_FTYPE_VOID, + UINT64_FTYPE_PINT, INT_FTYPE_INT, UINT64_FTYPE_INT, + INT64_FTYPE_INT64, UINT16_FTYPE_UINT16_INT and UINT8_FTYPE_UINT8_INT. + (bdesc_special_args): Add __builtin_ia32_rdtsc and + __builtin_ia32_rdtscp. + (bdesc_args): Add __builtin_ia32_bsrsi, __builtin_ia32_bsrdi, + __builtin_ia32_rolqi, __builtin_ia32_rolhi, __builtin_ia32_rorqi + and __builtin_ia32_rorhi. + (ix86_init_mmx_sse_builtins): Handle UINT64_FTYPE_VOID, + UINT64_FTYPE_PINT, INT_FTYPE_INT, UINT64_FTYPE_INT, + INT64_FTYPE_INT64, UINT16_FTYPE_UINT16_INT and UINT8_FTYPE_UINT8_INT. + (ix86_expand_args_builtin): Likewise. + (ix86_expand_special_args_builtin): Likewise. + + * config/i386/i386.md (UNSPECV_RDTSCP): New. + (UNSPECV_RDTSC): Likewise. + (UNSPECV_RDPMC): Likewise. + (*bsr): Renamed to ... + (bsr): This + (*bsr_rex64): Renamed to ... + (bsr_rex64): This. + (rdpmc): New. + (*rdpmc): Likewise. + (*rdpmc_rex64): Likewise. + (rdtsc): Likewise. + (*rdtsc): Likewise. + (*rdtsc_rex64): Likewise. + (rdtscp): Likewise. + (*rdtscp): Likewise. + (*rdtscp_rex64): Likewise. + + * config/i386/ia32intrin.h: New. + + * config/i386/x86intrin.h: Include <ia32intrin.h>. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * ira-build.c (copy_info_to_removed_store_destinations): + Initialize parent_a. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * c-decl.c (grokdeclarator): Change size_varies to bool. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * sel-sched.c: Make forward declarations of move_op_hooks and + fur_hooks explicitly extern. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * df-problems.c (df_byte_lr_alloc): Don't set problem_data to itself. + * vec.c (vec_gc_o_reserve_1): Don't set alloc to itself. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * resource.c (mark_referenced_resources): Change + include_delayed_effects parameter to bool. Change all callers. + (mark_end_of_function_resources): Likewise. + * reorg.c (insn_references_resource_p): Likewise. + (insn_sets_resource_p): Likewise. + * resource.h (mark_referenced_resources): Update declaration. + (mark_end_of_function_resources): Update declaration. + +2009-06-16 David Edelsohn <edelsohn@gnu.org> + + * config/rs6000/aix.h (LIBSTDCXX_STATIC): Remove -lstdc++. + +2009-06-16 David Edelsohn <edelsohn@gnu.org> + + * doc/install.texi (*-*-aix): Update explanation of XLC bootstrap. + GCC can bootstrap on AIX with GNU Binutils 2.20. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * Makefile.in (tree-vect-stmts.o): Depend upon $(TOPLEV_H). + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * toplev.h (floor_log2): If GCC_VERSION >= 3004, declare as static + inline, not extern inline. + (exact_log2): Likewise. + * toplev.c (floor_log2): Only define if GCC_VERSION < 3004. Don't + test CLZ_HWI. + (exact_log2): Likewise, but don't test CTZ_HWI. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * bitmap.c (bitmap_clear): Don't declare as inline. + * gimple.c (gimplify_assign): Likewise. + * tree-ssa-sccvn.c (vn_nary_op_compute_hash): Likewise. + * haifa-sched.c (insn_cost): Don't declare with HAIFA_INLINE. + (sched_scan_info): Remove duplicate definition. + +2009-06-16 Ian Lance Taylor <iant@google.com> + + * c-common.c (skip_evaluation): Don't define. + (c_inhibit_evaluation_warnings): Define global variable. + (overflow_warning): Check c_inhibit_evaluation_warnings rather + than skip_evaluation. + (convert_and_check, warn_for_div_by_zero): Likewise. + * c-common.h (skip_evaluation): Don't declare. + (c_inhibit_evaluation_warnings): Declare. + * c-parser.c (c_parser_typeof_specifier): Set + c_inhibit_evaluation_warnings rather than skip_evaluation. + (c_parser_conditional_expression): Likewise. + (c_parser_binary_expression): Likewise. + (c_parser_sizeof_expression): Likewise. + (c_parser_alignof_expression): Likewise. + * c-typeck.c (build_indirect_ref): Check + c_inhibit_evaluation_warnings rather than skip_evaluation. + (build_conditional_expr, build_binary_op): Likewise. + +2009-06-16 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (is_escape_site): Remove. + * tree-ssa-alias.h (enum escape_type): Remove. + (is_escape_site): Likewise. + * tree-ssa-structalias.c (find_func_aliases): Handle escapes + via casts and asms without deferring to is_escape_site. + +2009-06-16 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40446 + * expr.c (expand_expr_real_1) <case VIEW_CONVERT_EXPR>: Don't + use gen_lowpart if op0 has complex mode. + +2009-06-16 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (do_ds_constraint): Stores in global + variables add them to ESCAPED. + (find_func_aliases): Do not make all indirectly stored values escaped. + +2009-06-16 Rafael Avila de Espindola <espindola@google.com> + + * config/i386/winnt.c (i386_pe_encode_section_info): Update call to + make_decl_one_only. + +2009-06-16 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40432 + * tree-sra.c (sra_modify_assign): When creating VIEW_CONVERT_EXPR, + check whether we need to force gimple register operand. + +2009-06-16 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40413 + * tree-sra.c (load_assign_lhs_subreplacements): Pass offset to + build_ref_for_offset. + (propagate_subacesses_accross_link): Fix a typo in a comment. + +2009-06-16 Ira Rosen <irar@il.ibm.com> + + * tree-parloops.c (loop_parallel_p): Call vect_is_simple_reduction + with additional parameter. + * tree-vectorizer.h (enum vect_def_type): Add new value + vect_nested_cycle. + (enum vect_relevant): Add comments. + (vect_is_simple_reduction): Add new argument. + * tree-vect-loop.c (vect_analyze_scalar_cycles_1): Add comments. + Detect nested cycles. + (vect_is_simple_reduction): Update documentation, add an argument to + distinguish inner-loop reduction from nested cycle, detect nested + cycles, fix printings and indentation, don't swap operands in case + of nested cycle. + (get_initial_def_for_reduction): Handle subtraction. + (vect_create_epilog_for_reduction): Add new argument to specify + reduction variable. + (vect_finalize_reduction): Handle subtraction, fix comments. + (vectorizable_reduction): Handle nested cycles. In case of nested + cycle keep track of the reduction variable position. Call + vect_is_simple_reduction with additional parameter. Use original + statement code in reduction epilogue for nested cycle. Call + vect_create_epilog_for_reduction with additional parameter. + * tree-vect-patterns.c (vect_recog_dot_prod_pattern): Assert + inner-loop vectorization. + (vect_recog_widen_sum_pattern): Likewise. + * tree-vect-stmts.c (process_use): Distinguish between nested cycles + and reductions. + (vect_mark_stmts_to_be_vectorized): Likewise. + (vect_get_vec_def_for_operand): Handle nested cycles. + +2009-06-16 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/invoke.texi (Debugging Options): Fix option index entries + for -fdump-statistics, -frandom-seed add entries for + -fdump-tree-original, -fdump-tree-optimized, -frandom-seed. + (FRV Options): Fix entries for -mTLS, -mtls. + (HPPA Options): Fix entries for -mgnu-ld, -mhp-ld. + (i386 and x86-64 Options): Fix entry for -mno-red-zone. + (M68hc1x Options): Fix @itemx for -mnominmax. + (MCore Options): Fix entry for -mno-lsim. + (MMIX Options): Fix entry for -mabi=mmixware. + (PDP-11 Options): Fix entry for -mbcopy-builtin. + +2009-06-16 Basile Starynkevitch <basile@starynkevitch.net> + + * doc/plugins.texi (Interacting with the GCC Garbage Collector): + Mention the plugin mode of gengtype. + * doc/gty.texi (Source Files Containing Type Information): Likewise. + * gengtype.c: Updated copyright. + (plugin_files, nb_plugin_files) Added new static variables. + (measure_input_list) Care about plugin_files. + (write_rtx_next): Added early return in plugin mode. + (create_file): Updated copyright year in generated file. Added + asserts. + (oprintf): Added early return if NULL outf. + (get_output_file_with_visibility): Care of plugin_files. + (get_output_file_name): May return null. + (write_local): Added early return. + (put_mangled_filename): Ditto. + (finish_root_table): Added check for base_files. + (write_roots): Care about null when plugins. + (main): Added plugin mode. + +2009-06-15 Ian Lance Taylor <iant@google.com> + + * df-problems.c (df_simulate_one_insn_forwards): Fix braces in switch. + * gcov.c (read_count_file): Add braces around variables declared + before label. + + * c.opt (Wjump-misses-init): New warning. + * c-opts.c (c_common_handle_option): Set warn_jump_misses_init for + -Wall and -Wc++-compat if not already set. + (c_common_post_options): Clear warn_jump_misses_init if it was not + set. + * c-decl.c (struct c_binding): Change type field to a union with + new label field. Make it the first field in the struct. Update + references to type to use u.type instead. + (struct c_spot_bindings): Define. + (struct c_goto_bindings): Define. + (c_goto_bindings_p): Define, along with VECs. + (struct c_label_vars): Define. + (struct c_scope): Add has_label_bindings field. + (bind_label, set_spot_bindings): New static functions. + (decl_jump_unsafe, update_spot_bindings): New static functions. + (update_label_decls): New static function. + (pop_scope): Call update_label_decls. Don't call c_end_vm_scope. + Update binding u.label field to shadowed field. + (c_binding_start_stmt_expr): New function. + (c_binding_end_stmt_expr): New function. + (pushdecl): Don't call c_begin_vm_scope. + (make_label): Add defining and p_label_vars parameters. Change + all callers. + (lookup_label): Correct test for whether a label has not yet been + defined. Call bind_label rather than bind. + (warn_about_goto): New static function. + (lookup_label_for_goto): New function. + (declare_label): Call bind_label rather than bind. + (check_earlier_gotos): New static function. + (define_label): Don't give errors about jumping into statement + expressions or scopes of variably modified types. Call + set_spot_bindings and check_earlier_gotos. Call bind_label + instead of bind. Don't set label_context_stack_se or + label_context_stack_vm. + (c_get_switch_bindings): New function. + (c_release_switch_bindings): New function. + (c_check_switch_jump_warnings): New function. + (start_function): Don't set label_context_stack_se or + label_context_stack_vm. + (finish_function): Likewise. + * c-typeck.c (label_context_stack_se): Don't define. + (label_context_stack_vm): Don't define. + (c_finish_goto_label): Call lookup_label_for_goto rather than + lookup_label. Don't give errors about jumping into a statement + expression or the scope of a variably modified type. Don't set + label_context_stack_se or label_context_stack_vm. + (struct c_switch): Remove blocked_stmt_expr and blocked_vm + fields. Add bindings field. + (c_start_case): Don't set deleted fields. Set bindings field. + (do_case): Rework order of tests. Don't check blocked_stmt_expr + or blocked_vm. Call c_check_switch_jump_warnings. + (c_finish_case): Don't test blocked_stmt_expr field. Call + c_release_switch_bindings. + (c_begin_stmt_expr): Don't increment blocked_stmt_expr in + c_switch_stack. Don't walk label_context_stack_se labels. Don't + set label_context_stack_se. Call c_bindings_start_stmt_expr. + (c_finish_stmt_expr): Don't decrement blocked_stmt_expr in + c_switch_stack. Don't walk label_context_stack_se labels. Don't + set label_context_stack_se. Call c_bindings_end_stmt_expr. + (c_begin_vm_scope, c_end_vm_scope): Don't define. + * c-tree.h (C_DECL_UNJUMPABLE_STMT_EXPR): Don't define. + (C_DECL_UNDEFINABLE_STMT_EXPR): Don't define. + (C_DECL_UNJUMPABLE_VM): Don't define. + (C_DECL_UNDEFINABLE_VM): Don't define. + (struct c_label_list): Don't define. + (struct c_label_context_se): Don't define. + (struct c_label_context_vm): Don't define. + (struct c_spot_bindings): Declare. + (c_bindings_start_stmt_expr): Declare. + (c_bindings_end_stmt_expr): Declare. + (lookup_label_for_goto): Declare. + (c_get_switch_bindings, c_release_switch_bindings): Declare. + (c_check_switch_jump_warnings): Declare. + (label_context_stack_se, label_context_stack_vm): Don't declare. + (c_finish_goto_label): Update declaration. + (c_begin_vm_scope, c_end_vm_scope): Don't declare. + * doc/invoke.texi (Option Summary): Mention -Wjump-misses-init. + (Warning Options): Document -Wjump-misses-init. + +2009-06-15 Jakub Jelinek <jakub@redhat.com> + + * tree-object-size.c (addr_object_size): Fix a pasto in the last + change. + +2009-06-15 Rafael Avila de Espindola <espindola@google.com> + + * cgraph.c (cgraph_make_node_local): Use DECL_COMDAT_GROUP. + +2009-06-15 Aldy Hernandez <aldyh@redhat.com> + + * except.c (init_eh): Use BUILTINS_LOCATION when calling build_decl. + +2009-06-15 Aldy Hernandez <aldyh@redhat.com> + + * tree-eh.c (lower_try_finally_switch): Initialize tf_loc. + +2009-06-15 Rafael Avila de Espindola <espindola@google.com> + + * cgraphunit.c (cgraph_function_versioning,save_inline_function_body): + Use DECL_COMDAT_GROUP instead of DECL_ONE_ONLY. + * cgraph.c (cgraph_create_virtual_clone): Use DECL_COMDAT_GROUP. + * config/i386/i386.c (ix86_file_end): Compute DECL_COMDAT_GROUP. + * dwarf2asm.c (dw2_force_const_mem): Update call to + make_decl_one_only. + * langhooks-def.h (lhd_comdat_group, LANG_HOOKS_COMDAT_GROUP): Remove. + (LANG_HOOKS_DECLS): Remove LANG_HOOKS_COMDAT_GROUP. + * langhooks.c (lhd_comdat_group): Remove. + * langhooks.h (lang_hooks_for_decls): Remove comdat_group. + * tree.h (DECL_COMDAT_GROUP): New. + (DECL_ONE_ONLY): Use DECL_COMDAT_GROUP. + (tree_decl_with_vis): Add comdat_group. Remove one_only. + (make_decl_one_only): Change signature. + * varasm.c (get_emutls_init_templ_addr, emutls_decl): Update call to + make_decl_one_only. + (make_decl_one_only): Change signature. + (default_elf_asm_named_section): Use DECL_COMDAT_GROUP. + +2009-06-15 Richard Guenther <rguenther@suse.de> + + PR middle-end/40439 + * tree.c (widest_int_cst_value): Fix bootstrap on 32bit HWI hosts. + +2009-06-14 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * tree-ssa-math-opts.c: Remove extra divide. + +2009-06-14 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.md ("bswap<mode>2"): Only available on z900. + +2009-06-14 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * passes.c: Add bswap pass. + * tree-pass.h: Add pass_optimize_bswap declaration. + * tree-ssa-math-opts.c: Include diagnostics.h for print_gimple_stmt. + Include rtl.h, expr.h and optabs.h for optab_handler check. + (struct symbolic_number, pass_optimize_bswap): New definition. + (do_shift_rotate, verify_symbolic_number_p): New functions. + (find_bswap_1, find_bswap, execute_optimize_bswap): New functions. + (gate_optimize_bswap): New function. + * tree.c (widest_int_cst_value): New function. + * tree.h (widest_int_cst_value): Prototype added. + +2009-06-14 Steven Bosscher <steven@gcc.gnu.org> + + * cfgcleanup.c (old_insns_match_p): Remove code to substitute + REG_EQUAL/REG_EQUIV notes. + +2009-06-14 Richard Guenther <rguenther@suse.de> + + PR middle-end/40389 + * gimple.c (walk_stmt_load_store_addr_ops): The LHS of a call + has its address taken if NRV was applied and it is addressable. + * tree-ssa-structalias.c (get_constraint_for_address_of): New + function split out from ... + (get_constraint_for_1): ... here. + (handle_rhs_call): Use it to mark the return slot escaped if + it is addressable and NRV was applied. + +2009-06-13 Aldy Hernandez <aldyh@redhat.com> + + * config/rs6000/rs6000-protos.h (altivec_resolve_overloaded_builtin): + Change first argument type to location_t. + * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): Same. + Do not set input_location. + Use loc instead of input_location throughout. + +2009-06-13 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40421 + * tree-predcom.c (should_unroll_loop_p): Remove. + (tree_predictive_commoning_loop): Use can_unroll_loop_p. + +2009-06-13 Michael Meissner <meissner@linux.vnet.ibm.com> + + * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): + Add location argument. + +2009-06-13 Aldy Hernandez <aldyh@redhat.com> + + * config/alpha/alpha.c (alpha_build_builtin_va_list): Pass location to + build_decl. + * config/s390/s390.c (s390_build_builtin_va_list): Same. + (s390_gimplify_va_arg): Pass location to create_artificial_label. + * config/spu/spu-protos.h: Add location to + spu_resolve_overloaded_builtin. + * config/spu/spu.c (spu_build_builtin_va_list): Pass location to + spu_build_builtin_va_list. + * config/spu/spu-c.c (spu_resolve_overloaded_builtin): Add location + argument. Pass location to build_function_call_vec. + * config/sh/sh.c (sh_build_builtin_va_list): Pass location to + build_decl. + (emit_fpu_switch): Same. + (sh_gimplify_va_arg_expr): Pass location to create_artificial_label. + * config/xtensa/xtensa.c (xtensa_build_builtin_va_list): Pass location + to build_decl and create_artificial_label. + (xtensa_gimplify_va_arg_expr): Same. + * config/stormy16/stormy16.c (xstormy16_build_builtin_va_list): Same. + (xstormy16_gimplify_va_arg_expr): Same. + * config/iq2000/iq2000.c (iq2000_expand_prologue): Same. + * config/arm/arm.c (arm_build_builtin_va_list): Same. + * config/mips/mips.c (mips_build_builtin_va_list): Same. + (mips16_build_function_stub): Same. + (mips16_build_call_stub): Same. + +2009-06-13 Richard Earnshaw <rearnsha@arm.com> + + PR target/40327 + * arm/constraints.md (Pa, Pb): New constraints. + * arm/arm.md (thumb1_addsi3): Support more complex additions. Add a + split pattern to deal with them. + +2009-06-13 Joerg Sonnenberger <joerg@britannica.bec.de> + + * doc/invoke.texi: Add missing option -Wp,OPTION in list, + fix index entry for -Xpreprocessor. + +2009-06-12 Aldy Hernandez <aldyh@redhat.com> + + * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): + Add location argument to build_decl call. + * config/rs6000/rs6000.c (rs6000_build_builtin_va_list): Same. + (rs6000_init_builtins): Same. + (spe_init_builtins): Same. + (rs6000_gimplify_va_arg): Add location argument to + create_artificial_label call. + +2009-06-12 Steven Bosscher <steven@gcc.gnu.org> + + * timevar.def (TV_COMBINE_STACK_ADJUST): New timevar. + * combine-stack-adj.c (pass_stack_adjustments): Use it. + * Makefile.in: Fix GGC dependency for gcse.o. + +2009-06-12 Aldy Hernandez <aldyh@redhat.com> + + * tree-pretty-print.c (dump_generic_node): Dump column numbers. + * gimple-pretty-print.c (dump_gimple_stmt): Same. + * gimplify.c (gimplify_modify_expr): Set location for GIMPLE_ASSIGNs + created. + * c-parser.c (c_parser_binary_expression): Use current column while + building binary operations. + * common.opt (fshow-column): Enable by default. + * tree-vrp.c (check_array_ref): Use warning_at. + (check_array_bounds): Use location from call back if expr has no + location. + * tree.h: Add location argument to maybe_fold_*. + * tree-ssa-ccp.c (ccp_fold): Pass location to maybe_fold_*. + (maybe_fold_offset_to_array_ref): Add location argument and use it. + (maybe_fold_offset_to_component_ref): Same. + (maybe_fold_offset_to_reference): Same. + (maybe_fold_offset_to_address): Same. + (maybe_fold_stmt_indirect): Same. + (maybe_fold_stmt_addition): Same. + (fold_stmt_r): Pass location to maybe_fold_*. + (fold_gimple_assign): Same. + * c-tree.h: Add location argument to finish_decl, + default_function_array_conversion, store_init_value. + * c-decl.c (define_label): Use error_at. + (c_make_fname_decl): Pass location to finish_decl. + (finish_decl): New location argument. + (build_compound_literal): Pass location to store_init_value. + (grokdeclarator): Pass location to finish_decl. + (grokfield): Same. + * c-typeck.c (array_to_pointer_conversion): New location argument. + (function_to_pointer_conversion): Same. + (default_function_array_conversion): Same. + (parser_build_unary_op): Pass location to overflow_warning. + (parser_build_binary_op): Same. Use warning_at. + (build_unary_op): Pass location to array_to_pointer_conversion. + (build_c_cast): Pass location to digest_init. + (build_modify_expr): New location argument. + (convert_for_assignment): Same. + (store_init_value): Same. + (digest_init): Same. + (output_init_element): Pass location to digest_init and + array_to_pointer_conversion. + (c_finish_return): Pass location to convert_for_assignment. + * gimplify.c (gimplify_conversion): Pass location to + maybe_fold_offset_to_address. + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Pass location + to maybe_fold_stmt_addition. + * c-omp.c (c_finish_omp_atomic): Pass new location to + build_modify_expr. + (c_finish_omp_for): Same. + * c-common.c (overflow_warning): New argument. + * c-common.h: New argument to build_modify_expr, overflow_warning. + * c-parser.c (c_parser_declaration_or_fndef): Pass location to + finish_decl. + (c_parser_initializer): Pass location to + default_function_array_conversion. + (c_parser_initelt): Same. + (c_parser_initval): Same. + (c_parser_asm_operands): Same. + (c_parser_expr_no_commas): Same. Pass location to build_modify_expr. + (c_parser_conditional_expression): Same. + (c_parser_binary_expression): Add location info to stack. Use it. + (c_parser_unary_expression): Pass location to + default_function_array_conversion, parser_build_unary_op, + build_indirect_ref, c_parser_postfix_expression_after_primary. + (c_parser_postfix_expression_after_primary): New location argument. + Use it. + (c_parser_expression_conv): Pass location to + default_function_array_conversion. + (c_parser_expr_list): Same. + (c_parser_omp_atomic): Same. + (c_parser_omp_for_loop): Same. + * c-tree.h (struct c_declarator): Add comment to id_loc. + (build_array_declarator): New argument. + * c-decl.c (build_array_declarator): Add location argument. + (grokdeclarator): Set id_loc for cdk_array. + * c-parser.c (c_parser_direct_declarator_inner): Pass location to + build_array_declarator. + * tree.c (build_omp_clause): Add location argument. + * tree.h (OMP_CLAUSE_HAS_LOCATION): New macro. + (OMP_CLAUSE_LOCATION): New macro. + (struct tree_omp_clause): Add location field. + (build_omp_clause): Add argument. + * cp/pt.c (tsubst_omp_for_iterator): Pass location to + build_omp_clause. + * cp/parser.c (cp_parser_omp_var_list_no_open): Same. + (cp_parser_omp_clause_collapse): Same. + (cp_parser_omp_clause_default): Same. + (cp_parser_omp_clause_if): Same. + (cp_parser_omp_clause_nowait): Same. + (cp_parser_omp_clause_num_threads): Same. + (cp_parser_omp_clause_ordered): Same. + (cp_parser_omp_clause_schedule): Same. + (cp_parser_omp_clause_untied): Same. + (cp_parser_omp_for_loop): Same. + (cp_parser_omp_parallel): Pass location to c_split_parallel_clauses. + * c-tree.h (c_start_case): Add location argument. + (c_process_expr_stmt): Same. + (c_finish_goto_*): Same. + * tree-parloops.c (initialize_reductions): Pass location to + build_omp_clause. + (create_parallel_loop): Same. + * fortran/trans-openmp.c (gfc_trans_omp_variable_list): Same. + (gfc_trans_omp_reduction_list): Same. + (gfc_trans_omp_clauses): Same. + (gfc_trans_omp_do): Same. + * c-typeck.c (c_finish_goto_label): Same. + (c_finish_goto_ptr): New location argument. + (c_start_case): Same. + (emit_side_effect_warnings): Same. + (c_process_expr_stmt): Same. + (c_finish_stmt_expr): Same. + (c_finish_omp_clauses): Use error_at instead of error. + * gimplify.c (gimplify_adjust_omp_clauses_1): Pass location to + build_omp_clause. + * c-omp.c (c_split_parallel_clauses): New location argument. + * tree-nested.c (convert_nonlocal_reference_stmt): Pass location + to build_omp_clause. + (convert_local_reference_stmt): Same. + (convert_gimple_call): Same. + * c-common.h (c_split_parallel_clauses): New argument. + * c-parser.c (c_parser_statement_after_labels): Pass location to + c_finish_goto_label. + (c_parser_switch_statement): Pass location to c_start_case. + (c_parser_for_statement): Pass location to c_finish_expr_stmt, + and c_process_expr_stmt. + (c_parser_omp_variable_list): Add location argument. + (c_parser_omp_clause_collapse): Pass location to build_omp_clause. + (c_parser_omp_clause_default): Same. + (c_parser_omp_clause_if): Same. + (c_parser_omp_clause_num_threads): Same. + (-c_parser_omp_clause_ordered): Same. + (c_parser_omp_clause_reduction): Pass location to + c_parser_omp_variable_list. + (c_parser_omp_clause_schedule): Pass location to build_omp_clause. + (c_parser_omp_clause_untied): Same. + (c_parser_omp_for_loop): Pass location to c_process_expr_stmt. + (c_parser_omp_parallel): Pass location to c_split_parallel_clauses. + + * c-tree.h (check_for_loop_decls, undeclared_variable, + build_component_ref, build_array_ref, build_external_ref, + c_expr_sizeof_expr, c_expr_sizeof_type, parser_build_unary_op, + build_conditional_expr, build_compound_expr, c_cast_expr, + build_c_cast, build_asm_expr, c_end_compound_stmt, c_finish_stmt_expr, + c_finish_return, c_finish_omp_parallel, c_finish_omp_task): New + argument. + * c-semantics.c (build_stmt): Same. + (build_case_label): Same. + * c-decl.c (c_finish_incomplete_decl): Pass location on down. + (undeclared_variable): New argument. + (make_label): Same. + (lookup_label): Pass location on down. + (define_label): Same. + (finish_decl): Same. + (build_compound_literal): Same. + (finish_struct): Same. + (finish_function): Do not set location here. + (check_for_loop_decls): New argument. + * tree.c (save_expr): Set location. + (build_empty_stmt): New argument. + * tree.h (build_empty_stmt): New argument to build_empty_stmt. + (CAN_HAVE_LOCATION_P): Make sure we have a non empty node. + * builtins.c (gimplify_va_arg_expr): Use locations. + (expand_builtin_sync_operation): Same. + * c-typeck.c (build_component_ref): New argument. + (build_array_ref): Same. + (build_external_ref): Same. + (c_expr_sizeof_expr): Same. + (c_expr_sizeof_type): Same. + (parser_build_unary_op): Same. + (build_conditional_expr): Same. + (build_compound_expr): Pass location on down. + (build_compound_expr): New argument. + (build_c_cast): Same. + (c_cast_expr): Same. + (build_asm_expr): Same. + (c_finish_return): Same. + (c_process_expr_stmt): Pass location on down. + (c_finish_stmt_expr): New argument. + (push_clenaup): Same. + (c_finish_omp_parallel): Same. + (c_finish_omp_task): Same. + * gimplify.c (gimplify_call_expr): Pass location on down. + * c-omp.c (c_finish_omp_master): New argument. + (c_finish_omp_critical): Same. + (c_finish_omp_ordered): Same. + (c_finish_omp_barrier): Same. + (-c_finish_omp_taskwait): Same. + (c_finish_omp_atomic): Same. + (c_finish_omp_flush): Same. + * tree-inline.c (copy_tree_body_r): Pass location on down. + (inline_forbidden_p): Remove use of input_location. + * c-gimplify.c (c_build_bind_expr): New argument. + * c-common.c (c_common_truthvalue_conversion): Pass location on down. + (c_sizeof_or_alignof_type): New argument. + (c_alignof_expr): Same. + (build_va_arg): Same. + (c_add_case_label): Same. + * c-common.h (c_sizeof_or_alignof_type, c_alignof_expr, + c_sizeof, c_alignof, build_va_arg, build_stmt, build_case_label, + c_build_bind_expr, objc_build_selector_expr, objc_build_throw_stmt, + c_finish_omp_master, c_finish_omp_critical, c_finish_omp_ordered, + c_finish_omp_barrier, c_finish_omp_atomic, c_finish_omp_flush, + c_finish_omp_taskwait, c_finish_omp_for, c_split_parallel_clauses): + New argument. + * stub-objc.c (objc_build_selector_expr): Same. + (objc_build_throw_stmt): Same. + * c-parser.c (c_parser_declaration_or_fndef): Pass location on down. + (c_parser_initelt): Same. + (c_parser_compound_statement): Same. + (c_parser_compound_statement_nostart): Same. + (c_parser_label): Same. + (c_parser_statement_after_labels): Same. + (c_parser_if_body): Same. + (c_parser_else_body): Same. + (c_parser_if_statement): Same. + (c_parser_switch_statement): Same. + (c_parser_while_statement): Same. + (c_parser_do_statement): Same. + (c_parser_for_statement): Same. + (c_parser_asm_statement): Same. + (c_parser_conditional_expression): Same. + (c_parser_binary_expression): Same. + (c_parser_cast_expression): Same. + (c_parser_unary_expression): Same. + (c_parser_sizeof_expression): Same. + (c_parser_alignof_expression): Same. + (c_parser_postfix_expression): Same. + (c_parser_expression): Same. + (c_parser_objc_receiver): Same. + (c_parser_omp_variable_list): Same. + (c_parser_omp_structured_block): Same. + (c_parser_omp_atomic): New argument. + (c_parser_omp_barrier): Same. + (c_parser_omp_critical): Same. + (c_parser_omp_flush): Pass location on down. + (c_parser_omp_for_loop): New argument. + (c_parser_omp_for): Same. + (c_parser_omp_master): Same. + (c_parser_omp_ordered): Same. + (c_parser_omp_sections_scope): Same. + (c_parser_omp_sections): Same. + (c_parser_omp_parallel): Same. + (c_parser_omp_single): Same. + (c_parser_omp_task): Same. + (c_parser_omp_taskwait): Pass location on down. + (c_parser_omp_construct): Same. + (c_parser_omp_threadprivate): Same. + * dwarf2asm.c, targhooks.c, optabs.c, tree.c, tree.h, target.h, + builtins.c, omp-low.c, cgraphunit.c, tree-call-cdce.c, + tree-ssa-alias.c, gimple-low.c, c-tree.h, expr.c, tree-parloops.c, + c-decl.c, tree-eh.c, langhooks.c, function.c, stor-layout.c, + c-typeck.c, gimplify.c, c-pragma.c, expmed.c, except.c, coverage.c, + emit-rtl.c, cfgexpand.c, tree-mudflap.c, varasm.c, tree-nested.c, + rtl.h, tree-inline.c, tree-profile.c, c-common.c, c-common.h, + tree-switch-conversion.c, tree-cfg.c, ipa-struct-reorg.c, c-parser.c, + config/i386/i386.c, stmt.c: + Add location argument to the following function definitions and/or + function calls: build_decl, objcp_start_struct, objcp_finish_struct, + start_struct, finish_struct, PUSH_FIELD, create_artificial_label, + cp_make_fname_decl, pushtag, implicitly_declare, c_make_fname_decl, + build_compound_literal, parser_xref_tag, resolve_overloaded_builtin, + do_case, c_finish_bc_stmt, build_compound_literal, + build_function_call. + * c-decl.c (build_compound_literal): Add location argument. + Make all diagnostic calls use location. + (start_struct): Same. + (finish_struct): Same. + (start_enum): Same. + (build_enumerator): Same. + (start_function): Same. + (grokdeclarator): Make all diagnostic calls use location. + (store_parm_decls_oldstyle): Same. + * c-typeck.c (build_function_call): Add location argument. + Make all diagnostic calls use location. + (do_case): Same. + (c_finish_bc_stmt): Same. + * tree-nested.c (get_trampoline_type): Add argument. + Pass location to build_decl. + (lookup_tramp_for_decl): Pass location to get_trampoline_type. + * rtl.h (RTL_LOCATION): New. + * c-common.c (c_add_case_label): Add location argument. + Make all diagnostic calls use location. + * c-common.h: Add location argument to make_fname_decl, do_case, + c_add_case_label, build_function_call, resolve_overloaded_builtin. + * c-parser.c (c_parser_enum_specifier): Rename ident_loc to enum_loc. + Set it appropriately for every case. Pass enum_loc to start_enum + call. Pass value_loc first to build_enumerator. Pass enum_loc to + parser_xref_tag. + (c_parser_struct_or_union_specifier): Save location. Use it for + start_struct, finish_struct, and parser_xref_tag. + +2009-06-12 Ian Lance Taylor <iant@google.com> + + * fold-const.c (fold_unary): Rename local variable and to and_expr. + + * c-opts.c (c_common_handle_option): For -Wc++-compat set + cpp_opts->warn_cxx_operator_names. + +2009-06-12 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR tree-opt/38865 + * tree-ssa-sccvn.c (visit_reference_op_load): If vn_reference_lookup + is returns NULL and OP is a VCE, look through the VCE. + +2009-06-12 Ian Lance Taylor <iant@google.com> + + PR bootstrap/40430 + * collect2.c (main): Use CONST_CAST2 in code inside #if + LINK_ELIMINATE_DUPLICATE_LDIRECTORIES. + +2009-06-12 Joey Ye <joey.ye@intel.com> + + PR middle-end/39146 + * cfgexpand.c (get_decl_align_unit): Update + max_used_stack_slot_alignment with align instead of + stack_alignment_needed. + + * function.c (assign_stack_local_1): Update + max_used_stack_slot_alignment with alignment_in_bits instead + of stack_alignment_needed. + (locate_and_pad_parm): Don't update max_used_stack_slot_alignment + here. + +2009-06-12 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (last_var_location_insn): New variable. + (dwarf2out_end_epilogue): Clear last_var_location_insn. + (dwarf2out_var_location): Don't record anything after last real + insn. Only change labels if there were any real instructions + in between last note and this one, or if changed sections. + +2009-06-11 Richard Henderson <rth@redhat.com> + + * alpha.c (alpha_expand_prologue): Add a REF_CFA_REGISTER + note when storing the frame pointer in a register. + (FRP): Don't redefine to nothing for epilogue. + (alpha_expand_epilogue): Mark register and sp restores. + (unicosmk_gen_dsib): Don't mark weird frame pointer adjust. + + * config/alpha/alpha.c (alpha_emit_setcc): Fix test for + when gen_lowpart is needed. + +2009-06-11 Richard Henderson <rth@redhat.com> + + * dwarf2out.c (def_cfa_1): Likewise for DW_CFA_cfa_offset. + + * dwarf2out.c (need_data_align_sf_opcode): New. + (div_data_align): Move earlier. + (def_cfa_1, reg_save): Use it. + +2009-06-11 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (OPTION_MASK_ISA_CRC32_SET): New. + (OPTION_MASK_ISA_CRC32_UNSET): Likewise. + (ix86_handle_option): Handle OPT_mcrc32. + (ix86_target_string): Add -mcrc32. + (bdesc_args): Enable crc32 builtins with OPTION_MASK_ISA_CRC32. + + * config/i386/i386.h (TARGET_CRC32): New. + + * config/i386/i386.md (sse4_2_crc32<mode>): Also check TARGET_CRC32. + (sse4_2_crc32di): Likewise. + + * config/i386/i386.opt (mcrc32): New. + + * doc/invoke.texi: Document -mcrc32. + +2009-06-11 Richard Henderson <rth@redhat.com> + + * common.opt (gdwarf-): Accept a version number. + * doc/invoke.texi (gdwarf-): Update docs. + * opth-gen.awk: Special case -gdwarf+ to OPT_gdwarfplus. + * opts.c (common_handle_option) [OPT_gdwarf_]: Verify dwarf + version level, and record it. + + * dwarf2.h (DW_CIE_VERSION): Remove. + * dwarf2out.c (DWARF_VERSION): Remove. + (add_fde_cfi): Skip DW_CFA_set_loc addition for dwarf3. + (output_call_frame_info): Use CIE version 3 for dwarf3, + or if the return register column is out of range for version 1. + (dwarf_stack_op_name): Add all dwarf3 values. + (DEBUG_PUBTYPES_SECTION): New. + (size_of_die) [dw_val_class_die_ref]: Handle DW_FORM_ref_addr + encoding change for dwarf3. + (output_die) [dw_val_class_die_ref]: Likewise. + (output_compilation_unit_header): Emit correct version for dwarf3. + (output_line_info): Likewise. + (output_pubnames): Update for DWARF_VERSION removal. + (output_aranges): Likewise. + (gen_subprogram_die): Emit DW_OP_call_frame_cfa if emitting dwarf3. + (dwarf2out_init): Don't ifdef DEBUG_PUBTYPES_SECTION. + (dwarf2out_finish): Likewise. + +2009-06-11 David Daney <ddaney@caviumnetworks.com> + + * system.h (gcc_assert, gcc_unreachable): Revert accidental commit + in r148403. + +2009-06-11 David Daney <ddaney@caviumnetworks.com> + + PR c/39252 + * doc/extend.texi ( __builtin_unreachable): Document new builtin. + * builtins.c (expand_builtin_unreachable): New function. + (expand_builtin): Handle BUILT_IN_UNREACHABLE case. + * builtins.def (BUILT_IN_UNREACHABLE): Add new builtin. + * cfgcleanup.c (try_optimize_cfg): Delete empty blocks with no + successors. + * cfgrtl.c (rtl_verify_flow_info): Handle empty blocks when + searching for missing barriers. + +2009-06-11 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> + + * config/darwin.h (LINK_COMMAND_SPEC): Adjust spec to link libcov + when -fprofile-generate* was passed. + * config/darwin9.h (LINK_COMMAND_SPEC): Likewise. + +2009-06-11 Anthony Green <green@moxielogic.com> + + * config/moxie/moxie.md: Define length attribute for all instructions. + (rCC): Define. + (*b<cond:code>): Support limited branch ranges for new PC-relative + branch instructions. + * config/moxie/moxie.h (HAS_LONG_UNCOND_BRANCH): Define. + +2009-06-11 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.c (min_insn_size): Use get_attr_length + for normal insns other than TYPE_MULTI, TYPE_OTHER and TYPE_FCMP. + For __asm return 0. + + * config/i386/i386.c (ix86_pad_returns): Use emit_jump_insn_before + instead of emit_insn_before. + +2009-06-10 Ian Lance Taylor <iant@google.com> + + PR bootstrap/40408 + * graphite.c (add_conditions_to_domain): Change SWITCH_EXPR to + GIMPLE_SWITCH. + +2009-06-10 Revital Eres <eres@il.ibm.com> + + * passes.c (init_optimization_passes): Reschedule + predictive-commoning pass before complete unroll pass. + +2009-06-10 Martin Jambor <mjambor@suse.cz> + + * cgraph.c (cgraph_node_can_be_local_p): New function. + (cgraph_make_node_local): New function. + * cgraph.h (cgraph_node_can_be_local_p): Declare. + (cgraph_make_node_local): Declare. + +2009-06-10 Nathan Froyd <froydnj@codesourcery.com> + + * tree.h (tree_base): Add packed_flag and user_align fields. + Decrease size of spare field. + (TYPE_USER_ALIGN): Use user_align from tree_base. + (DECL_USER_ALIGN): Likewise. + (TYPE_PACKED): Use packed_flag from tree_base. + (DECL_PACKED): Likewise. + (tree_type): Delete packed_flag and user_align fields. Widen + precision field. Widen mode field and shuffle fields to align + mode on an 8-bit boundary. + (tree_decl_common): Delete decl_flag_1 and user_align fields. + Renumber decl_flag_* fields. Fix comments. Widen + decl_common_unused field. + (DECL_HAS_VALUE_EXPR_P): Adjust for renumbering of decl_flag_* fields. + (DECL_EXTERNAL): Likewise. + (DECL_BIT_FIELD): Likewise. + (DECL_NONADDRESSABLE_P): Likewise. + (TYPE_DECL_SUPRESS_DEBUG): Likewise. + * config/arm/arm-modes.def (XImode): Make it an INT_MODE. + +2009-06-10 Ian Lance Taylor <iant@google.com> + + * vec.h (DEF_VEC_ALLOC_I): Use DEF_VEC_NONALLOC_FUNCS_I. + (DEF_VEC_ALLOC_P): Use DEF_VEC_NONALLOC_FUNCS_P. + (DEF_VEC_ALLOC_O): Use DEF_VEC_NONALLOC_FUNCS_O. + (DEF_VEC_ALLOC_FUNC_P): Only define VEC_OP (T,A,alloc). + (DEF_VEC_NONALLOC_FUNCS_P): New macro, broken out of old + DEF_VEC_ALLOC_FUNC_P. + (DEF_VEC_ALLOC_FUNC_O): Only define VEC_OP (T,A,alloc). + (DEF_VEC_NONALLOC_FUNCS_O): New macro, broken out of old + DEF_VEC_ALLOC_FUNC_O. + (DEF_VEC_ALLOC_FUNC_I): Only define VEC_OP (T,A,alloc). + (DEF_VEC_NONALLOC_FUNCS_I): New macro, broken out of old + DEF_VEC_ALLOC_FUNC_I. + (vec_stack_p_reserve, vec_stack_p_reserve_exact): Declare. + (vec_stack_p_reserve_exact_1): Declare. + (vec_stack_o_reserve, vec_stack_o_reserve_exact): Declare. + (vec_stack_free): Declare. + (VEC_stack_alloc): Define. + (DEF_VEC_ALLOC_P_STACK, DEF_VEC_ALLOC_FUNC_P_STACK): Define. + (DEF_VEC_ALLOC_O_STACK, DEF_VEC_ALLOC_FUNC_O_STACK): Define. + (DEF_VEC_ALLOC_I_STACK, DEF_VEC_ALLOC_FUNC_I_STACK): Define. + * vec.c (void_p): New type. Call DEF_VEC_P and DEF_VEC_ALLOC_P + for void_p. + (stack_vecs): New static variable. + (vec_stack_p_reserve_exact_1): New function. + (vec_stack_o_reserve_1): New static function. + (vec_stack_p_reserve, vec_stack_p_reserve_exact): New functions. + (vec_stack_o_reserve, vec_stack_o_reserve_exact): New functions. + (vec_stack_free): New function. + * df-scan.c (df_ref): Use DEF_VEC_P and DEF_VEC_ALLOC_P_STACK. + (VEC_df_ref_stack_alloc): Define. + (df_mw_hardreg_ptr): New type. Use DEF_VEC_P and + DEF_VEC_ALLOC_P_STACK. + (VEC_df_mw_hardreg_ptr_stack_alloc): Define. + (struct df_collection_rec): Change _vec fields to VEC. Remove + _use fields. + (df_free_collection_rec): Adjust for new fields. + (df_insn_rescan): Use new df_collection_rec fields. + (df_notes_rescan, df_canonize_collection_rec): Likewise. + (df_ref_create_structure, df_ref_record): Likewise. + (df_get_conditional_uses, df_get_call_refs): Likewise. + (df_insn_refs_collect, df_bb_refs_collect): Likewise. + (df_bb_refs_record, df_record_entry_block_defs): Likewise. + (df_record_exit_block_uses, df_bb_verify): Likewise. + (df_swap_refs): Change ref_vec parameter to VEC. Change all callers. + (df_sort_and_compress_refs): Change ref_vec parameter to VEC. + Remove count parameter. Change return type to void. Change all + callers. + (df_sort_and_compress_mws): Change mw_vec parameter to VEC. + Remove count parameter. Change return type to void. Change all + callers. + (df_install_refs): Change old_vec parameter to VEC. Remove count + parameter. Change all callers. + (df_install_mws): Change old_vec parameter to VEC. Remove count + parameter. Change all callers. + (df_refs_verify): Change new_rec parameter to VEC. Change call + callers. + (df_mws_verify): Likewise. + +2009-06-10 Alexandre Oliva <aoliva@redhat.com> + + * gcc.c (compare_files): Cast munmap argumento to caddr_t. + +2009-06-10 H.J. Lu <hongjiu.lu@intel.com> + + * doc/extend.texi: Add description for __builtin_ia32_crc32di. + +2009-06-10 Anthony Green <green@moxielogic.com> + + * config/moxie/crti.asm: New file. + * config/moxie/crtn.asm: New file. + * config/moxie/moxie.c: New file. + * config/moxie/moxie.h: New file. + * config/moxie/sfp-machine.h: New file. + * config/moxie/moxie-protos.h: New file. + * config/moxie/t-moxie: Created. + * config/moxie/t-moxie-softfp: Created. + * config/moxie/moxie.md: Created. + * config/moxie/constraints.md: Created. + * config.gcc: Add moxie support. + * doc/md.texi (Machine Constraints): Add moxie constraints. + * doc/contrib.texi (Contributors): Mention moxie port. + * doc/install.texi (Specific): Mention the moxie port. + +2009-06-09 Ian Lance Taylor <iant@google.com> + + * system.h (HAVE_DESIGNATED_INITIALIZERS): Don't define if + compiling with C++. + * optabs.c (optab_table): Only use designated initializers if + HAVE_DESIGNATED_INITIALIZERS is defined. + (convert_optab_table): Likewise. + (init_optabs): Always call init_insn_codes if + HAVE_DESIGNATED_INITIALIZERS is not defined. + +2009-06-09 Ian Lance Taylor <iant@google.com> + + * targhooks.c (default_builtin_vectorized_function): Change fn + parameter to unsigned int. + (default_builtin_vectorized_conversion): Change code parameter to + unsigned int. + (default_builtin_reciprocal): Change fn parameter to unsigned int. + * targhooks.h: Update declarations. + * config/rs6000/rs6000.c (rs6000_builtin_conversion): Change code + parameter to unsigned int. + + * c-typeck.c (comptypes_check_enum_int): New static function. + (comptypes_internal): Add enum_and_int_p parameter. Change all + callers. + (comp_target_types): Add location parameter. Change all callers. + (tagged_types_tu_compatible_p): Add enum_and_int_p parameter. + Change all callers. + (function_types_compatible_p, type_lists_compatible_p): Likewise. + (build_conditional_expr): Add colon_loc parameter. Change all + callers. + (convert_for_assignment): Add location parameter. Change all callers. + * c-parser.c (c_parser_conditional_expression): Pass location of + colon to build_conditional_expr. + * c-tree.h (build_conditional_expr): Update declaration. + +2009-06-09 Sebastian Pop <sebastian.pop@amd.com> + + * graphite.c: Revert previous patch. + +2009-06-09 Sebastian Pop <sebastian.pop@amd.com> + + PR bootstrap/40103 + * graphite.c: Remove pragma GCC diagnostic warning "-Wc++-compat". + +2009-06-09 Ghassan Shobaki <ghassan.shobaki@amd.com> + + * tree-ssa-loop-prefetch.c + (loop_prefetch_arrays): Fixed a portability problem in printf format + string. + +2009-06-09 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40351 + * tree-sra.c (propagate_subacesses_accross_link): Check that a + refrence to a potential artifical subaccess can be constructed. + +2009-06-08 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh-protos.h (sh_optimization_options): Declare. + (sh_override_options): Likewise. + * config/sh/sh.c: Include params.h. + (sh_optimization_options): New. + (sh_override_options): Likewise. + * config/sh/sh.c (OPTIMIZATION_OPTIONS): Use sh_optimization_options. + (OVERRIDE_OPTIONS): Use sh_override_options. + +2009-06-08 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (emit_cfa_remember): New variable. + (add_fde_cfi): If emit_cfa_remember, recurse to add + DW_CFA_remember_state first. + (dwarf2out_begin_epilogue): Don't add_fde_cfi DW_CFA_remember_state, + instead just set emit_cfa_remember. + +2009-06-08 Jan Hubicka <jh@suse.cz> + + PR debug/40126 + * dwarf2out.c (dwarf2out_abstract_function): Free decl_loc_table. + +2009-06-08 Jan Hubicka <jh@suse.cz> + + PR middle-end/39834 + * cgraphunit.c (save_inline_function_body): Do not copy transform + hooks for saved inline bodies. + * ipa-passes.c (do_per_function): Do not add the hoks multiple times + for given function. + +2009-06-08 Adam Nemet <anemet@caviumnetworks.com> + + * jump.c (returnjump_p): Handle delayed branches. Add missing + function comment. + +2009-06-08 Jan Hubicka <jh@suse.cz> + + PR middle-end/40102 + * cgraph.c (cgraph_create_edge_including_clones): Also asume that the + original node might've been modified. + * tree-inline.c (copy_bb): Do not assume that all clones are the same. + +2009-06-08 Jakub Jelinek <jakub@redhat.com> + + * tree-object-size.c (addr_object_size): Add OSI argument. + Handle also INDIRECT_REF with SSA_NAME inside of it as base address. + (compute_builtin_object_size, expr_object_size): Adjust callers. + (plus_stmt_object_size): Call addr_object_size instead of + compute_builtin_object_size. + +2009-06-08 Ghassan Shobaki <ghassan.shobaki@amd.com> + Dwarakanath Rajagopal <dwarak.rajagopal@amd.com> + + * tree-ssa-loop-prefetch.c + (gather_memory_references): Introduced a counter for the number of + memory references. + (anything_to_prefetch_p): Introduced a counter for the number of + prefetches. + (is_loop_prefetching_profitable): New function with a cost model + for prefetching. + (loop_prefetch_arrays): Use the new cost model to determine if + prefetching is profitable. + * params.def (MIN_INSN_TO_PREFETCH_RATIO, + PREFETCH_MIN_INSN_TO_MEM_RATIO): New parameters. + * params.h (MIN_INSN_TO_PREFETCH_RATIO, + PREFETCH_MIN_INSN_TO_MEM_RATIO): New parameters. + * doc/invoke.texi (MIN_INSN_TO_PREFETCT_RATIO, + PREFETCH_MIN_INSN_TO_MEM_RATIO): New parameters. + +2009-06-08 Michael Matz <matz@suse.de> + + PR debug/40012 + * cfgexpand.c (set_rtl): Store place also in DECL_RTL, if all + partitions use the same. + (expand_one_var): Deal with DECL_RTL sometimes begin set also + for basevars of SSA_NAMEs. + (expand_used_vars): Reset TREE_USED for basevars of SSA_NAMEs, + to not expand them twice. + (gimple_expand_cfg): Clear DECL_RTL for those decls that have + multiple places. + +2009-06-08 Alexandre Oliva <aoliva@redhat.com> + + * common.opt (fcompare-debug=, fcompare-debug-second): New. + (fdump-final-insns=, gtoggle): New. + * doc/invoke.texi: Document them. + * final.c (rest_of_clean_state): Dump final insn stream. + * gcc.c (invoke_as): Hook in -fcompare-debug. + (static_spec_functions): Add compare-debug-dump-opt, + compare-debug-self-opt and compare-debug-auxbase-opt. + (compare_debug, compare_debug_second, compare_debug_opt): New. + (switches_debug_check, n_switches_debug_check): New. + (debug_auxbase_opt, debug_check_temp_file): New. + (process_command): Handle -fno-compare-debug, -fcompare-debug and + -fcompare-debug=*. + (do_self_spec): Handle arguments after switches. + (do_spec_1): Add .gk extension to temp file basenames for compare. + (check_live_switch): Take SWITCH_IGNORE into account, and earlier. + (cc1_options): Use it instead of normal auxbase computation for + the second compare-debug compilation. + (compare_files): New. + (main): Set up and implement compare debug mode. + (compare_debug_dump_opt_spec_function): New. + (compare_debug_self_opt_spec_function): New. + (compare_debug_auxbase_opt_spec_function): New. + * toplev.c (process_options): Handle flag_gtoggle, + flag_dump_final_insns. + * coverage.c (coverage_begin_output): Don't overwrite .gcno file + during -fcompare-debug-second compilation. + +2009-06-07 Ian Lance Taylor <iant@google.com> + + * dwarf2.h (enum dwarf_location_atom): Add INTERNAL_DW_OP_tls_addr. + * dwarf2out.c (INTERNAL_DW_OP_tls_addr): Don't #define. + + * c-common.c (c_do_switch_warnings): Don't exit early for -Wswitch + with no default node. Change warning with %H to warning_at. + Don't clear warn_switch around case checking. + * doc/invoke.texi (Warning Options): Clarify distinction between + -Wswitch and -Wswitch-enum. + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * tree-pass.h (TODO_update_ssa_any): Document internal use only. + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * gbl-ctors.h: Add header guard. + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * tree-flow.h (make_value_handle, set_value_handle, sort_vuses, + sort_vuses_heap, vn_lookup_or_add, vn_lookup_or_add_with_stmt, + vn_lookup_or_add_with_vuses, vn_add, vn_add_with_vuses, + vn_lookup_with_stmt, vn_lookup, vn_lookup_with_vuses): Remove + prototypes for removed functions. + (expressions_equal_p): Move to ... + * tree-ssa-sccvn.h: ... here and ... + * matrix-reorg.c: ... adjust includes. + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * ipa-struct-reorg.c (do_reorg_1): Fix whitespace in dump output. + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * c-decl.c (finish_decl): Use bool for variable was_incomplete. + (finish_function): Remove erroneous whitespace. + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * tree-cfg.c (gimple_merge_blocks): Commentary typo fix. + (verify_stmts): Print statement who's gimple_bb is set to a wrong BB + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * errors.c (internal_error): Commentary typo fix. + * gimple-iterator.c (gsi_insert_seq_on_edge): Ditto. + * tree-ssa-pre.c: Ditto. + +2009-06-07 Bernhard Reutner-Fischer <aldot@gcc.gnu.org> + + * basic-block.h (ENTRY_BLOCK, EXIT_BLOCK): Document that neither of + them is supposed to hold actual statements. + +2009-06-06 Ian Lance Taylor <iant@google.com> + + * doc/extend.texi (Attribute Syntax): Document that C++ labels on + empty statements can now have attributes. + +2009-06-05 Shujing Zhao <pearly.zhao@oracle.com> + + * config/mips/mips.c: Use REG_P and CONST_INT_P where applicable. + * config/mips/mips.md: Ditto. + +2009-06-05 Nathan Froyd <froydnj@codesourcery.com> + + * config/rs6000/eabi.asm (__eabi_convert): Don't define if + _RELOCATABLE. + (__eabi_uconvert): Likewise. + +2009-06-05 Nathan Froyd <froydnj@codesourcery.com> + + * config/rs6000/ppc-asm.h: Protect auto-host.h inclusion and + CFI_* definitions with IN_GCC. + +2009-06-05 David Edelsohn <edelsohn@gnu.org> + + * xcoffout.h (xcoffout_source_line): Update prototype. + +2009-06-05 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * builtins.c (do_mpc_ckconv, do_mpc_arg1): Use + mpc_realref/mpc_imagref instead of MPC_RE/MPC_IM. + +2009-06-05 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40340 + * tree-ssa-live.c (remove_unused_scope_block_p): Don't prune + inlined_function_outer_scope_p blocks for artificial inlines + even at -g0/-g1. + * tree.c (tree_nonartificial_location): Rewrite using + block_nonartificial_location. + +2009-06-05 Revital Eres <eres@il.ibm.com> + Leehod Baruch <leehod@il.ibm.com> + + * expr.c (expand_assignment): Expand MISALIGNED_INDIRECT_REF. + (expand_expr_real_1): Remove comment. + * tree-vect-data-refs.c (vect_enhance_data_refs_alignment): + Vectorize misaligned access when the target supports it. + (vect_supportable_dr_alignment): Check for unaligned access support. + * tree-vect-stmts.c (vectorizable_store): Generate misaligned store + and remove asset. + +2009-06-05 Julian Brown <julian@codesourcery.com> + + * config/arm/ieee754-df.S (cmpdf2): Avoid writing below SP. + * config/arm/ieee754-sf.S (cmpsf2): Likewise. + +2009-06-05 Richard Guenther <rguenther@suse.de> + + PR bootstrap/40350 + * dwarf2out.c (dwarf2out_begin_function): Mark discriminator + as possibly unused. + +2009-06-05 Jakub Jelinek <jakub@redhat.com> + + * config/s390/s390.c (global_not_special_regno_p): New static inline. + (save_gprs): Don't tell unwinder when a global register is saved. + (s390_emit_epilogue): Emit needed epilogue unwind info. + +2009-06-05 Alexandre Oliva <aoliva@redhat.com> + + * dwarf2out.c (deferred_asm_name): New. + (add_name_and_src_coords_attributes): Defer creation of + DW_AT_MIPS_linkage_name attribute if DECL_ASSEMBLER_NAME was not + computed yet. + (move_linkage_attr): New. + (dwarf2out_finish): Revisit deferrals and emit attributes at the + right place. + +2009-06-05 Alexandre Oliva <aoliva@redhat.com> + + * tree-nested.c (finalize_nesting_tree_1): Declare the + frame_decl in the binding tree. + +2009-06-04 Cary Coutant <ccoutant@google.com> + + * basic-block.h (struct basic_block_def): Add discriminator field. + * dbxout.c (dbxout_source_line): Add new parameter. Change all + callers. + * debug.c (do_nothing_debug_hooks): Add additional entry. + (debug_nothing_int_charstar_int): New function. + * debug.h (struct gcc_debug_hooks): Add parameter to source_line hook. + (debug_nothing_int_charstar_int): New declaration. + * dwarf2out.c (dwarf2out_source_line): Add new parameter. Write + discriminator value in .loc directive. + * final.c (last_discriminator): New variable. + (discriminator): New variable. + (final_start_function): Initialize above variables, pass current + discriminator to debug hook. + (notice_source_line): Check for discriminator change. + * gimple-pretty-print.c (dump_bb_header): Print discriminator value. + * sdbout.c (sdbout_source_line): New parameter. + * tree-cfg.c (struct locus_discrim_map): New structure type. + (discriminator_per_locus): New hash table. + (build_gimple_cfg): Allocate and free discriminator hash table. + (make_edges): Call assign_discriminator. + (locus_map_hash): New function. + (locus_map_eq): New function. + (next_discriminator_for_locus): New function. + (same_line_p): New function. + (assign_discriminator): New function. + (make_cond_expr_edges): Call assign_discriminator. + (make_gimple_switch_edges): Likewise. + (first_non_label_stmt): New function. + * vmsdbgout.c (vmsdbgout_source_line): Add new parameter. Change + all callers. + * xcoffout.c (xcoffout_source_line): Add new parameter. + + * configure.ac (gcc_cv_as_discriminator): New configury check for + gas support for discriminator. + * configure: Regenerate. + * config.in: Regenerate. + +2009-06-04 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (thumb2_legitimate_index_p): Initialize + val after checking for integers. + +2009-06-04 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.h (X86_64_MS_REGPARM_MAX): Rename from + X64_REGPARM_MAX. + (REGPARM_MAX): Use X86_64_MS_REGPARM_MAX. + (X86_64_MS_SSE_REGPARM_MAX): Rename from X64_SSE_REGPARM_MAX. + (SSE_REGPARM_MAX): Use X86_64_MS_SSE_REGPARM_MAX. + * config/i386/i386.c: Use X86_64_MS_REGPARM_MAX instead of + X64_REGPARM_MAX. Use X86_64_MS_SSE_REGPARM_MAX instead of + X64_SSE_REGPARM_MAX. + * config/i386/i386.md: Use X86_64_MS_SSE_REGPARM_MAX instead of + X64_SSE_REGPARM_MAX. + +2009-06-04 Alexandre Oliva <aoliva@redhat.com> + + * gcc.c (report_times_to_file): New. + (execute): Implement it. + (process_command): Support -time=. + * doc/invoke.texi: Document it. + +2009-06-04 Alexandre Oliva <aoliva@redhat.com> + + * tree-ssa-live.c (remove_unused_scope_block_p): Keep variables + that have value exprs. + +2009-06-04 Alexandre Oliva <aoliva@redhat.com> + + * dwarf2asm.c (dw2_force_const_mem): Defer creation of + declarations for constants until... + (dw2_output_indirect_constant_1): ... this point. + +2009-06-04 Richard Earnshaw <rearnsha@arm.com> + + PR target/10242 + * arm.md (arm_addsi3): Don't try to split an add with an + eliminable register until after reload has completed. + +2009-06-03 Ian Lance Taylor <iant@google.com> + + * dummy-checksum.c (executable_checksum): Use EXPORTED_CONST. + * genattrtab.c (write_length_unit_log): Likewise. + * genchecksum.c (dosum): Likewise. + * gengtype.c (write_rtx_next): Likewise. + (finish_root_table, write_roots): Likewise. + * gimple.c (gimple_ops_offset_): Likewise. + * tree-nomudflap.c (gt_ggc_r_gt_tree_mudflap_h): Likewise. + * config/arc/arc.c (arc_attribute_table): Likewise. + * config/arm/arm.c (arm_attribute_table): Likewise. + * config/avr/avr.c (avr_attribute_table): Likewise. + * config/crx/crx.c (crx_attribute_table): Likewise. + * config/m32r/m32r.c (m32r_attribute_table): Likewise. + * config/m68hc11/m68hc11.c (m68hc11_attribute_table): Likewise. + * config/mcore/mcore.c (mcore_attribute_table): Likewise. + * config/rs6000/rs6000.c (rs6000_attribute_table): Likewise. + * config/sh/sh.c (sh_attribute_table): Likewise. + * config/sparc/sparc.c (sparc_attribute_table): Likewise. + * config/spu/spu.c (spu_attribute_table): Likewise. + * config/v850/v850.c (v850_attribute_table): Likewise. + + * config/alpha/alpha.c (vms_attribute_table): Make static. + * config/bfin/bfin.c (bfin_attribute_table): Likewise. + * config/h8300/h8300.c (h8300_attribute_table): Likewise. + * config/mips/mips.c (mips_attribute_table): Likewise. + + * Makefile.in (dummy-checksum.o): Depend upon $(CONFIG_H) and + $(SYSTEM_H). + (cc1-checksum.o): Likewise. + +2009-06-03 Steve Ellcey <sje@cup.hp.com> + + * config/ia64/vect.md (*movv2sf_internal): Handle big endian case. + +2009-06-03 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/rs6000.c (rs6000_emit_stack_reset): Return generated + insn if it is changing sp. Use gen_add3_insn instead of + conditionally gen_addsi3 and gen_adddi3. + (offset_below_red_zone_p): New static inline function. + (rs6000_emit_epilogue): Emit needed epilogue unwind info. + Use gen_add3_insn instead of conditionally gen_addsi3 and gen_adddi3. + * config/rs6000/ppc-asm.h: Include auto-host.h. + (CFI_STARTPROC, CFI_ENDPROC, CFI_DEF_CFA_REGISTER, CFI_OFFSET, + CFI_RESTORE): Define. + * config/rs6000/crtresxgpr.asm: Add unwind info. + * config/rs6000/crtresxfpr.asm: Likewise. + * config/rs6000/crtresgpr.asm: Likewise. + * config/rs6000/crtresfpr.asm: Likewise. + * config/rs6000/crtsavgpr.asm: Likewise. + * config/rs6000/crtsavfpr.asm: Likewise. + + * dwarf2out.c (output_cfi_directive): Pass 1 instead of 0 to second + argument of DWARF2_FRAME_REG_OUT macros. + +2009-06-03 Julian Brown <julian@codesourcery.com> + + * config/arm/arm.c (arm_hard_regno_mode_ok): Permit values of four + words or less (including TImode) in core registers. + +2009-06-03 Richard Guenther <rguenther@suse.de> + + PR middle-end/40328 + * fold-const.c (fold_convert): Fold the build COMPLEX_EXPR. + +2009-06-03 Andrey Belevantsev <abel@ispras.ru> + + * statistics.c (statistics_counter_event): Do not record event + in pass dump if its number == -1. + (curr_statistics_hash): Add assert that we never get passes + with static number == -1. + +2009-06-03 Richard Guenther <rguenther@suse.de> + Andrey Belevantsev <abel@ispras.ru> + + * cfgexpand.c (discover_nonconstant_array_refs_r): Make only + non-BLKmode arrays addressable. + +2009-06-03 Maxim Kuvyrkov <maxim@codesourcery.com> + + * config/m68k/linux.h (HAVE_GAS_BALIGN_AND_P2ALIGN): Move to ... + * config/m68k/m68k.h: ... here. + +2009-06-03 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/40323 + * ipa-prop.c (get_ssa_def_if_simple_copy): Break if not single + assignment. + +2009-06-03 Richard Guenther <rguenther@suse.de> + + * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Use DECL_SIZE + consistently. + +2009-06-03 Shujing Zhao <pearly.zhao@oracle.com> + + * config/sh/predicates.md: Use REG_P, MEM_P, CONST_INT_P, LABEL_P, + JUMP_P, CALL_P, NONJUMP_INSN_P, NOTE_P, BARRIER_P and + JUMP_TABLE_DATA_P where applicable. + * config/sh/sh.c: Ditto. + * config/sh/sh.h: Ditto. + * config/sh/sh.md: Ditto. + * config/sh/symbian.c: Ditto. + +2009-06-03 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/driver-i386.c (describe_cache): Optimize + concatenation of strings. Use snprintf instead of sprintf. + (host_detect_local_cpu): Ditto. Ignore -march and -mtune for native + target when not compiling with GCC. + +2009-06-02 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c: Revert last change. + (sh_expand_epilogue): Emit a blockage insn before the frame + pointer adjustment unconditionally. + +2009-06-02 Richard Sandiford <r.sandiford@uk.ibm.com> + + * config/pa/pa-hpux.h (LINK_SPEC): Remove "%<fwhole-program". + * config/pa/pa-hpux10.h (LINK_SPEC): Likewise. + * config/pa/pa-hpux11.h (LINK_SPEC): Likewise. + * gcc.c (set_collect_gcc_options): Don't add -fwhole-program + to COLLECT_GCC_OPTIONS. + +2009-06-02 Richard Sandiford <r.sandiford@uk.ibm.com> + + * collect2.c (target_system_root): New variable. + (main): Handle --sysroot=. + (ignore_library): Strip the sysroot from the library path. + +2009-06-02 Richard Sandiford <r.sandiford@uk.ibm.com> + + * Makefile.in (COLLECT2_OBJS): Add collect2-aix.o. + (collect2.o): Depend on collect2-aix.h. + (collect2-aix.o): New rule. + * collect2-aix.h: New file. + * collect2-aix.c: Likewise. + * collect2.c: Include collect2-aix.h. Don't undefine + OBJECT_FORMAT_COFF if CROSS_AIX_SUPPORT is defined. + Guard native includes with #ifndef CROSS_DIRECTORY_STRUCTURE. + Use TARGET_AIX_VERSION instead of _AIX51. + * config/rs6000/aix43.h (TARGET_AIX_VERSION): Define. + * config/rs6000/aix51.h (TARGET_AIX_VERSION): Likewise. + * config/rs6000/aix52.h (TARGET_AIX_VERSION): Likewise. + * config/rs6000/aix53.h (TARGET_AIX_VERSION): Likewise. + * config/rs6000/aix61.h (TARGET_AIX_VERSION): Likewise. + +2009-06-02 Richard Sandiford <r.sandiford@uk.ibm.com> + + * collect2.c (ignore_library): Avoid premature post-increment + and null deference. + +2009-06-02 Richard Sandiford <r.sandiford@uk.ibm.com> + + * Makefile.in (libgcc.mvars): Add TARGET_SYSTEM_ROOT. + * config/rs6000/aix.h (LINK_SYSCALLS_SPEC): Add %R to the + !CROSS_DIRECTORY_STRUCTURE alternative and use it for + CROSS_DIRECTORY_STRUCTURE too. + (LINK_LIBG_SPEC): Likewise. + (LIB_SPEC): Add %R to sysroot paths. + * config/rs6000/aix43.h (CPP_SPEC): Add %R to sysroot paths. + (CPLUSPLUS_CPP_SPEC, LIB_SPEC): Likewise. + * config/rs6000/aix51.h: As for aix43.h. + * config/rs6000/aix52.h: Likewise. + * config/rs6000/aix53.h: Likewise. + * config/rs6000/aix61.h: Likewise. + * config/rs6000/t-aix52 (SHLIB_LINK): Add $(TARGET_SYSTEM_ROOT) + to the beginning of sysroot paths. + +2009-06-02 Alexandre Oliva <aoliva@redhat.com> + + * print_rtl (print_rtx): Don't print modes in EXPR_LISTs and + INSN_LISTs that are out of the REG_NOTE range. + +2009-06-02 Alexandre Oliva <aoliva@redhat.com> + + * loop-unroll.c (struct iv_to_split): Add pointer to next. + (struct var_to_expand): Likewise. + (struct opt_info): Add head and tail for linked lists of the above. + (analyze_insn_to_expand_var): Initialize next. + (analyze_iv_to_split_insn): Likewise. + (analyze_insns_in_loop): Create linked lists. + (allocate_basic_variable): Simplify for use without hash table. + (insert_var_expansion_initialization): Likewise, make it type-safer. + (combine_var_copies_in_loop_exit): Likewise. + (apply_opt_in_copies): Walk lists rather than hash tables. + (release_var_copies): Simplified and inlined by hand into... + (free_opt_info): ... this function. + +2009-06-02 Richard Guenther <rguenther@suse.de> + + * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Use DECL_SIZE + for field decls. + +2009-06-02 Alexandre Oliva <aoliva@redhat.com> + + * cfgexpand.c (gimple_expand_cfg): Discard the source location + only for builtins that are not overridden. + +2009-06-02 Alexandre Oliva <aoliva@redhat.com> + + * gengtype.c (adjust_field_rtx_def): Add NOTE_INSN_DELETED_LABEL's + label string. + +2009-06-02 Alexandre Oliva <aoliva@redhat.com> + + * df-core.c (df_ref_debug): Honor -fdump-noaddr. + +2009-06-02 Alexandre Oliva <aoliva@redhat.com> + + * combine.c (move_deaths): Compare LUIDs within the same BB only. + +2009-06-02 Alexandre Oliva <aoliva@redhat.com> + + * common.opt (fdump-unnumbered-links): New. + * doc/invoke.texi (-fdump-unnumbered-links): Document it. + * print-rtl.c (flag_dump_unnumbered_links): New. + (print_rtx): Test it. + +2009-06-02 Richard Earnshaw <rearnsha@arm.com> + + * arm.c (arm_get_frame_offsets): Prefer using r3 for padding a + push/pop multiple to 8-byte alignment. + +2009-06-01 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.c (queued_cfa_restores): New static variable. + (ix86_add_cfa_restore_note, ix86_add_queued_cfa_restore_notes): New + functions. + (pro_epilogue_adjust_stack): Call ix86_add_queued_cfa_restore_notes. + (ix86_emit_restore_reg_using_pop): Add RED_OFFSET argument. + Set RTX_FRAME_RELATED_P immediately after adding a REG_CFA_* note. + Call ix86_add_cfa_restore_note instead of adding REG_CFA_OFFSET + note unconditionally. + (ix86_emit_restore_regs_using_mov): Likewise. + (ix86_emit_restore_sse_regs_using_mov): Likewise. + (ix86_emit_restore_regs_using_pop): Add RED_OFFSET argument, pass + it through to ix86_emit_restore_reg_using_pop. + (ix86_emit_leave): Add RED_OFFSET argument. Call + ix86_add_queued_cfa_restore_notes. Call ix86_add_cfa_restore_note + instead of adding REG_CFA_OFFSET note unconditionally. + (ix86_expand_epilogue): Compute RED_OFFSET, pass it down to + the above functions. Call ix86_add_queued_cfa_restore_notes when + needed. + + * dwarf2out.c (dwarf2out_cfi_label): Add FORCE argument, if true, + force output of the label even for dwarf2out_do_cfi_asm. + (add_fde_cfi): If -g2 and above and cfi might change CFA, + force creation of CFI label and chain DW_CFA_set_loc jumping to it + for convert_cfa_to_fb_loc_list. Adjust other dwarf2out_cfi_label + caller. + (dwarf2out_stack_adjust, dwarf2out_frame_debug, + dwarf2out_begin_epilogue, dwarf2out_frame_debug_restore_state): Adjust + dwarf2out_cfi_label callers. + * tree.h (dwarf2out_cfi_label): Adjust prototype. + * config/arm/arm.c (thumb_pushpop, thumb1_output_function_prologue): + Adjust dwarf2out_cfi_label callers. + * config/vax/vax.c (vax_output_function_prologue): Likewise. + + * config/i386/i386.h (struct machine_cfa_state, + struct machine_function): Guard with ifndef USED_FOR_TARGET + instead of not IN_LIBGCC2 and not in IN_TARGET_LIBS. + + PR other/40024 + * emutls.c (__emutls_get_address): Change arr->size to mean number + of allocated arr->data entries instead of # of slots + 1. + + PR middle-end/40316 + * recog.c (peep2_reinit_state): New function. + (peephole2_init_state): Use it at the end of a basic block and also + when seeing a RTX_FRAME_RELATED_P insn. + +2009-06-01 Steve Ellcey <sje@cup.hp.com> + + * ia64.md (floatdirf2, fix_truncrfdi, floatunsdirf, + fixuns_truncrfdi2): New. + (fix_truncxfdi2_alts, fixuns_truncxfdi2_alts, + *nmaddsf4_alts, *nmadddf4_alts, *nmadddf4_truncsf_alts, + *mulxf3_alts, *mulxf3_truncsf_alts, *mulxf3_truncdf_alts, + *maddxf4_alts, *maddxf4_alts_truncsf, *maddxf4_alts_truncdf, + *nmaddxf4_alts, *nmaddxf4_truncsf_alts, *nmaddxf4_truncdf_alts, + *recip_approx): Remove. + (divsi3 modsi3, udivsi3, umodsi3, divsi3_internal, divdi3, + moddi3, udivdi3, umoddi3, divdi3_internal_lat, divdi3_internal_thr, + divsf3, sqrtsf2, divdf3, sqrtdf2, divxf3, sqrtxf2): Modify and + move to div.md. + * div.md (fix_truncrfdi2_alts, fixuns_truncrfdi2_alt, + setf_exp_rf): New. + +2009-06-01 Ian Lance Taylor <iant@google.com> + + * attribs.c (register_attribute): Use CONST_CAST. + * collect2.c (main): Use CONST_CAST2. + (scan_prog_file): Likewise. + * gcc.c (process_command, main): Likewise. + * toplev.c (toplev_main): Likewise. + + * c-typeck.c (handle_warn_cast_qual): New static function, + partially broken out of build_c_cast. + (build_c_cast): Call handle_warn_cast_qual. + * doc/invoke.texi (Warning Options): Document new effect of + -Wcast-qual. + +2009-06-01 Aldy Hernandez <aldyh@redhat.com> + + * diagnostic.c (diagnostic_build_prefix): Always print columns. + (diagnostic_report_current_module): Print columns. + * common.opt (flag_show_column): Enable by default. + +2009-06-01 Luis Machado <luisgpm@br.ibm.com> + + * alias.c (find_base_term): Check for NULL term before returning. + +2009-06-01 Maxim Kuvyrkov <maxim@codesourcery.com> + + Revert due to PR40320: + 2009-06-01 Maxim Kuvyrkov <maxim@codesourcery.com> + * calls.c (emit_library_call_value_1): Don't force_operand for move + and push insns. + +2009-06-01 Olivier Hainque <hainque@adacore.com> + Eric Botcazou <ebotcazou@adacore.com> + + * tree.h (CONSTRUCTOR_BITFIELD_P): True if NODE, a FIELD_DECL, is + to be processed as a bitfield for constructor output purposes. + * output.h (initializer_constant_valid_for_bitfield_p): Declare + new function. + * varasm.c (oc_local_state): New type, output_constructor + local state to support communication with helpers. + (oc_outer_state): New type, output_constructor outer state of + relevance in recursive calls. + (output_constructor_array_range): New output_constructor helper, + extracted code for an array range element. + (output_constructor_regular_field): New output_constructor helper, + extracted code for an element that is not a bitfield. + (output_constructor_bitfield): New output_constructor helper, + extracted code for a bitfield element. Accept an OUTER state + argument for recursive processing. Recurse on record or array + CONSTRUCTOR values, possibly past noop conversions. + (initializer_constant_valid_for_bitfield_p): New predicate. Whether + VALUE is a valid constant-valued expression for use in a static + bit-field initializer. + (output_constructor): Rework to use helpers. Accept and honor an + OUTER state argument for recursive calls. Return total size. Be + prepared for nested constructors initializing bitfields. + (output_constant): Feed OUTER in calls to output_constructor. + +2009-06-01 Maxim Kuvyrkov <maxim@codesourcery.com> + + * calls.c (emit_library_call_value_1): Don't force_operand for move + and push insns. + +2009-06-01 Nick Clifton <nickc@redhat.com> + + * doc/invoke.texi (IA-64 Options): Fix typo. + +2009-06-01 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/39129 + * tree-vect-loop-manip.c (conservative_cost_threshold): Change the + printed message. + (vect_do_peeling_for_loop_bound): Use + LOOP_REQUIRES_VERSIONING_FOR_ALIGNMENT and + LOOP_REQUIRES_VERSIONING_FOR_ALIAS macros. + (vect_loop_versioning): Likewise. + (vect_create_cond_for_alias_checks): Fix indentation. + * tree-vectorizer.h (struct _loop_vec_info): Fix indentation of the + macros. + (LOOP_REQUIRES_VERSIONING_FOR_ALIGNMENT): Define. + (LOOP_REQUIRES_VERSIONING_FOR_ALIAS): Likewise. + * tree-vect-loop.c (vect_analyze_loop_form): Change "too many BBs" to + "control flow in loop". + (vect_estimate_min_profitable_iters): Use + LOOP_REQUIRES_VERSIONING_FOR_ALIGNMENT and + LOOP_REQUIRES_VERSIONING_FOR_ALIAS macros. + * tree-vect-data-refs.c (vect_enhance_data_refs_alignment): Likewise. + (vect_create_data_ref_ptr): Don't mention array dimension in printing. + * tree-vect-stmts.c (vectorizable_store): Replace the check that the + statement belongs to a group of strided accesses with the exact code + check. + (vectorizable_load): Likewise. + * tree-vect-slp.c (vect_analyze_slp_instance): Spell out "basic block". + (vect_slp_analyze_bb, vect_slp_transform_bb): Likewise. + +2009-06-01 Gerald Pfeifer <gerald@pfeifer.com> + + * config/freebsd-stdint.h: New file. + * config.gcc (*-*-freebsd): Set use_gcc_stdint=wrap. + Add freebsd-stdint.h to tm_file. + +2009-06-01 Richard Earnshaw <rearnsha@arm.com> + + * arm/thumb2.md (thumb2_zero_extendhidi2): New insn and split. + (thumb2_extendhidi2): Likewise. + +2009-05-31 Ian Lance Taylor <iant@google.com> + + * regstat.c (regstat_n_sets_and_refs): Remove duplicate definition. + +2009-05-31 Ian Lance Taylor <iant@google.com> + + * Makefile.in (except.o): Depend upon gt-except.h, not gt-$(EXCEPT_H). + (ipa-cp.o): Depend upon $(FIBHEAP_H) and $(PARAMS_H). + (ipa-reference.o): Depend upon gt-ipa-reference.h. + +2009-05-31 Jason Merrill <jason@redhat.com> + + * tree-pretty-print.c (print_call_name): Take the callee, not the + call itself. Make non-static. Use dump_function_name for functions. + (dump_generic_node): Adjust. + * diagnostic.h: Declare print_call_name. + * gimple-pretty-print.c (dump_gimple_call): Use it. + +2009-05-31 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.md (ashldi3_std): New define_expand. + (ashldi3): Use it. + +2009-05-31 Kaz Kojima <kkojima@gcc.gnu.org> + + PR target/40313 + * config/sh/sh.c: Include debug.h. + (sh_expand_epilogue): Emit a blockage insn before the frame + pointer adjustment also when dwarf2out_do_frame returns true. + +2009-05-31 Richard Earnshaw <rearnsha@arm.com> + + * arm/thumb2.md (thumb2_extendsidi2): Add a split sub-pattern. + (thumb2_extendqidi2): New pattern. + +2009-05-31 Ira Rosen <irar@il.ibm.com> + + * tree-vect-loop-manip.c (slpeel_update_phi_nodes_for_guard1): Don't + mark phis for renaming. + * tree-vectorizer.c (vect_memsyms_to_rename): Remove. + (vectorize_loops): Don't allocate and free vect_memsyms_to_rename. + Call mark_sym_for_renaming. + * tree-vectorizer.h (vect_memsyms_to_rename): Remove. + * tree-vect-loop.c (vect_transform_loop): Remove + vect_memsyms_to_rename initialization and a call to + mark_set_for_renaming. + +2009-05-31 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40304 + * config/i386/i386.c (pro_epilogue_adjust_stack): Mark insns + frame related even if !set_cfa && style < 0. + +2009-05-30 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/mingw-tls.c: New file. + * config/i386/t-gthr-win32 (LIB2FUNCS_EXTRA): Add mingw-tls.c file. + * gthr-win32.h (MINGW32_SUPPORTS_MT_EH): Define it for targets + defining _WIN32 but not __CYGWIN__. + +2009-05-29 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * configure.ac: Add MPC support. + + * config.in, configure: Regenerate. + +2009-05-29 Richard Henderson <rth@redhat.com> + + * cfgcleanup.c (try_crossjump_to_edge): Only skip past + NOTE_INSN_BASIC_BLOCK. + * cfglayout.c (duplicate_insn_chain): Copy epilogue insn marks. + Duplicate NOTE_INSN_EPILOGUE_BEG notes. + * cfgrtl.c (can_delete_note_p): Allow NOTE_INSN_EPILOGUE_BEG + to be deleted. + * dwarf2out.c (struct cfa_loc): Change indirect field to bitfield, + add in_use field. + (add_cfi): Disable check redefining cfa away from drap. + (lookup_cfa_1): Add remember argument; handle remember/restore. + (lookup_cfa): Pass remember argument. + (cfa_remember): New. + (compute_barrier_args_size_1): Remove sibcall check. + (dwarf2out_frame_debug_def_cfa): New. + (dwarf2out_frame_debug_adjust_cfa): New. + (dwarf2out_frame_debug_cfa_offset): New. + (dwarf2out_frame_debug_cfa_register): New. + (dwarf2out_frame_debug_cfa_restore): New. + (dwarf2out_frame_debug): Handle REG_CFA_* notes. + (dwarf2out_begin_epilogue): New. + (dwarf2out_frame_debug_restore_state): New. + (dw_cfi_oprnd1_desc): Handle DW_CFA_remember_state, + DW_CFA_restore_state. + (output_cfi_directive): Likewise. + (convert_cfa_to_fb_loc_list): Likewise. + (dw_cfi_oprnd1_desc): Handle DW_CFA_restore. + * dwarf2out.h: Update. + * emit-rtl.c (try_split): Don't split RTX_FRAME_RELATED_P. + (copy_insn_1): Early out for null. + * final.c (final_scan_insn): Call dwarf2out_begin_epilogue + and dwarf2out_frame_debug_restore_state. + * function.c (prologue, epilogue, sibcall_epilogue): Remove. + (prologue_insn_hash, epilogue_insn_hash): New. + (free_after_compilation): Adjust freeing accordingly. + (record_insns): Create hash table if needed; push insns into + hash instead of array. + (maybe_copy_epilogue_insn): New. + (contains): Search hash table instead of array. + (sibcall_epilogue_contains): Remove. + (thread_prologue_and_epilogue_insns): Split eh_return insns + and mark them as epilogues. + (reposition_prologue_and_epilogue_notes): Rewrite epilogue + scanning in terms of basic blocks. + * insn-notes.def (CFA_RESTORE_STATE): New. + * jump.c (returnjump_p_1): Accept EH_RETURN. + (eh_returnjump_p_1, eh_returnjump_p): New. + * reg-notes.def (CFA_DEF_CFA, CFA_ADJUST_CFA, CFA_OFFSET, + CFA_REGISTER, CFA_RESTORE): New. + * rtl.def (EH_RETURN): New. + * rtl.h (eh_returnjump_p, maybe_copy_epilogue_insn): Declare. + + * config/bfin/bfin.md (UNSPEC_VOLATILE_EH_RETURN): Remove. + (eh_return_internal): Use eh_return rtx; split w/ epilogue. + + * config/i386/i386.c (gen_push): Update cfa state. + (pro_epilogue_adjust_stack): Add set_cfa argument. When true, + add a CFA_ADJUST_CFA note. + (ix86_dwarf_handle_frame_unspec): Remove. + (ix86_expand_prologue): Update cfa state. + (ix86_emit_restore_reg_using_pop): New. + (ix86_emit_restore_regs_using_pop): New. + (ix86_emit_leave): New. + (ix86_emit_restore_regs_using_mov): Add CFA_RESTORE notes. + (ix86_expand_epilogue): Add notes for unwinding the epilogue. + * config/i386/i386.h (struct machine_cfa_state): New. + (ix86_cfa_state): New. + * config/i386/i386.md (UNSPEC_EH_RETURN): Remove. + (eh_return_internal): Merge from eh_return_<mode>, + use eh_return rtx, split w/ epilogue. + +2009-05-29 Ian Lance Taylor <iant@google.com> + + * builtins.c (validate_gimple_arglist): Don't use va_arg with + enum type. + * calls.c (emit_library_call_value_1): Likewise. + + * c-typeck.c (c_build_va_arg): New function. + * c-tree.h (c_build_va_arg): Declare. + * c-parser.c (c_parser_postfix_expression): Call c_build_va_arg + instead of build_va_arg. + +2009-05-29 Eric Botcazou <ebotcazou@adacore.com> + + * tree-ssa-loop-ivopts.c (strip_offset_1) <MULT_EXPR>: New case. + (force_expr_to_var_cost) <NEGATE_EXPR>: Likewise. + (ptr_difference_cost): Use affine combinations to compute it. + (difference_cost): Likewise. + (get_computation_cost_at): Compute more accurate cost for addresses + if the ratio is a multiplier allowed in addresses. + For non-addresses, consider that an additional offset or symbol is + added only once. + +2009-05-29 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.c (ix86_decompose_address): Avoid useless + 0 displacement. Add 0 displacement if base is %[er]bp or %r13. + + * config/i386/i386.md (prefix_data16, prefix_rep): Set to 0 for + TYPE_SSE{MULADD,4ARG,IADD1,CVT1} by default. + (prefix_rex): For UNIT_MMX don't imply the prefix by default + if MODE_DI. + (prefix_extra): Default to 2 for TYPE_SSE{MULADD,4ARG} and + to 1 for TYPE_SSE{IADD1,CVT1}. + (prefix_vex_imm8): Removed. + (length_vex): Only pass 1 as second argument to + ix86_attr_length_vex_default if prefix_extra is 0. + (modrm): For TYPE_INCDEC only set to 0 if not TARGET_64BIT. + (length): For prefix vex computation use length_immediate + attribute instead of prefix_vex_imm8. + (cmpqi_ext_3_insn, cmpqi_ext_3_insn_rex64, + addqi_ext_1, addqi_ext_1_rex64, *testqi_ext_0, andqi_ext_0, + *andqi_ext_0_cc, *iorqi_ext_0, *xorqi_ext_0, *xorqi_cc_ext_1, + *xorqi_cc_ext_1_rex64): Override modrm attribute to 1. + (extendsidi2_rex64, extendhidi2, extendqidi2, extendhisi2, + *extendhisi2_zext, extendqihi2, extendqisi2, *extendqisi2_zext): Emit + a space in between the operands. + (*anddi_1_rex64, *andsi_1): Likewise. Override prefix_rex to 1 + if one operand is 0xff and the other one si, di, bp or sp. + (*andhi_1): Override prefix_rex to 1 if one operand is 0xff and the + other one si, di, bp or sp. + (*btsq, *btrq, *btcq, *btdi_rex64, *btsi): Add mode attribute. + (*ffssi_1, *ffsdi_1, ctzsi2, ctzdi2): Add + type and mode attributes. + (*bsr, *bsr_rex64, *bsrhi): Add type attribute. + (*cmpfp_i_mixed, *cmpfp_iu_mixed): For TYPE_SSECOMI, clear + prefix_rep attribute and set prefix_data16 attribute iff MODE_DF. + (*cmpfp_i_sse, *cmpfp_iu_sse): Clear prefix_rep attribute and set + prefix_data16 attribute iff MODE_DF. + (*movsi_1): For TYPE_SSEMOV MODE_SI set prefix_data16 attribute. + (fix_trunc<mode>di_sse): Set prefix_rex attribute. + (*adddi_4_rex64, *addsi_4): Use const128_operand instead of + constm128_operand in length_immediate computation. + (*addhi_4): Likewise. Fix mode attribute to MODE_HI. + (anddi_1_rex64): Use movzbl/movzwl instead of movzbq/movzwq. + (*avx_ashlti3, sse2_ashlti3, *avx_lshrti3, sse2_lshrti3): Set + length_immediate attribute to 1. + (x86_fnstsw_1, x86_fnstcw_1, x86_fldcw_1): Fix length attribute. + (*movdi_1_rex64): Override prefix_rex or prefix_data16 attributes + for certain alternatives. + (*movdf_nointeger, *movdf_integer_rex64, *movdf_integer): Override + prefix_data16 attribute if MODE_V1DF. + (*avx_setcc<mode>, *sse_setcc<mode>, *sse5_setcc<mode>): Set + length_immediate to 1. + (set_got_rex64, set_rip_rex64): Remove length attribute, set + length_address to 4, set mode attribute to MODE_DI. + (set_got_offset_rex64): Likewise. Set length_immediate to 0. + (fxam<mode>2_i387): Set length attribute to 4. + (*prefetch_sse, *prefetch_sse_rex, *prefetch_3dnow, + *prefetch_3dnow_rex): Override length_address attribute. + (sse4_2_crc32<mode>): Override prefix_data16 and prefix_rex + attributes. + * config/i386/predicates.md (ext_QIreg_nomode_operand): New predicate. + (constm128_operand): Removed. + * config/i386/i386.c (memory_address_length): For + disp && !index && !base in 64-bit mode account for SIB byte if + print_operand_address can't optimize disp32 into disp32(%rip) + and UNSPEC doesn't imply (%rip) addressing. Add 1 to length + for fs: or gs: segment. + (ix86_attr_length_immediate_default): When checking if shortform + is possible, truncate immediate to the length of the non-shortened + immediate. + (ix86_attr_length_address_default): Ignore MEM_P operands + with X constraint. + (ix86_attr_length_vex_default): Only check for DImode on + GENERAL_REG_P operands. + * config/i386/sse.md (<sse>_comi, <sse>_ucomi): Clear + prefix_rep attribute, set prefix_data16 attribute iff MODE_DF. + (sse_cvttps2pi): Clear prefix_rep attribute. + (sse2_cvttps2dq, *sse2_cvtpd2dq, sse2_cvtps2pd): Clear prefix_data16 + attribute. + (*sse2_cvttpd2dq): Don't clear prefix_rep attribute. + (*avx_ashr<mode>3, ashr<mode>3, *avx_lshr<mode>3, lshr<mode>3, + *avx_ashl<mode>3, ashl<mode>3): Set length_immediate attribute to 1 + iff operand 2 is const_int_operand. + (*vec_dupv4si, avx_shufpd256_1, *avx_shufpd_<mode>, + sse2_shufpd_<mode>): Set length_immediate attribute to 1. + (sse2_pshufd_1): Likewise. Set prefix attribute to maybe_vex + instead of vex. + (sse2_pshuflw_1, sse2_pshufhw_1): Set length_immediate to 1 and clear + prefix_data16. + (sse2_unpckhpd, sse2_unpcklpd, sse2_storehpd, *vec_concatv2df): Set + prefix_data16 attribute for movlpd and movhpd instructions. + (sse2_loadhpd, sse2_loadlpd, sse2_movsd): Likewise. Override + length_immediate for shufpd instruction. + (sse2_movntsi, sse3_lddqu): Clear prefix_data16 attribute. + (avx_cmpp<avxmodesuffixf2c><mode>3, + avx_cmps<ssemodesuffixf2c><mode>3, *avx_maskcmp<mode>3, + <sse>_maskcmp<mode>3, <sse>_vmmaskcmp<mode>3, + avx_shufps256_1, *avx_shufps_<mode>, sse_shufps_<mode>, + *vec_dupv4sf_avx, *vec_dupv4sf): Set length_immediate attribute to 1. + (*avx_cvtsi2ssq, *avx_cvtsi2sdq): Set length_vex attribute to 4. + (sse_cvtsi2ssq, sse2_cvtsi2sdq): Set prefix_rex attribute to 1. + (sse2_cvtpi2pd, sse_loadlps, sse2_storelpd): Override + prefix_data16 attribute for the first alternative to 1. + (*avx_loadlps): Override length_immediate for the first alternative. + (*vec_concatv2sf_avx): Override length_immediate and prefix_extra + attributes for second alternative. + (*vec_concatv2sf_sse4_1): Override length_immediate and + prefix_data16 attributes for second alternative. + (*vec_setv4sf_avx, *avx_insertps, vec_extract_lo_<mode>, + vec_extract_hi_<mode>, vec_extract_lo_v16hi, + vec_extract_hi_v16hi, vec_extract_lo_v32qi, + vec_extract_hi_v32qi): Set prefix_extra and length_immediate to 1. + (*vec_setv4sf_sse4_1, sse4_1_insertps, *sse4_1_extractps): Set + prefix_data16 and length_immediate to 1. + (*avx_mulv2siv2di3, *avx_mulv4si3, sse4_2_gtv2di3): Set prefix_extra + to 1. + (*avx_<code><mode>3, *avx_eq<mode>3, *avx_gt<mode>3): Set + prefix_extra attribute for variants that don't have 0f prefix alone. + (*avx_pinsr<ssevecsize>): Likewise. Set length_immediate to 1. + (*sse4_1_pinsrb, *sse2_pinsrw, *sse4_1_pinsrd, *sse4_1_pextrb, + *sse4_1_pextrb_memory, *sse2_pextrw, *sse4_1_pextrw_memory, + *sse4_1_pextrd): Set length_immediate to 1. + (*sse4_1_pinsrd): Likewise. Set prefix_extra to 1. + (*sse4_1_pinsrq, *sse4_1_pextrq): Set prefix_rex and length_immediate + to 1. + (*vec_extractv2di_1_rex64_avx, *vec_extractv2di_1_rex64, + *vec_extractv2di_1_avx, *vec_extractv2di_1_sse2): Override + length_immediate to 1 for second alternative. + (*vec_concatv2si_avx, *vec_concatv2di_rex64_avx): Override + prefix_extra and length_immediate attributes for the first + alternative. + (vec_concatv2si_sse4_1): Override length_immediate to 1 for the + first alternative. + (*vec_concatv2di_rex64_sse4_1): Likewise. Override prefix_rex + to 1 for the first and third alternative. + (*vec_concatv2di_rex64_sse): Override prefix_rex to 1 for the second + alternative. + (*sse2_maskmovdqu, *sse2_maskmovdqu_rex64): Override length_vex + attribute. + (*sse_sfence, sse2_mfence, sse2_lfence): Override length_address + attribute to 0. + (*avx_phaddwv8hi3, *avx_phadddv4si3, *avx_phaddswv8hi3, + *avx_phsubwv8hi3, *avx_phsubdv4si3, *avx_phsubswv8hi, + *avx_pmaddubsw128, *avx_pmulhrswv8hi3, *avx_pshufbv16qi3, + *avx_psign<mode>3): Set prefix_extra attribute to 1. + (ssse3_phaddwv4hi3, ssse3_phadddv2si3, ssse3_phaddswv4hi3, + ssse3_phsubwv4hi3, ssse3_phsubdv2si3, ssse3_phsubswv4hi3, + ssse3_pmaddubsw, *ssse3_pmulhrswv4hi, ssse3_pshufbv8qi3, + ssse3_psign<mode>3): Override prefix_rex attribute. + (*avx_palignrti): Override prefix_extra and length_immediate to 1. + (ssse3_palignrti): Override length_immediate to 1. + (ssse3_palignrdi): Override length_immediate to 1, override + prefix_rex attribute. + (abs<mode>2): Override prefix_rep to 0, override prefix_rex attribute. + (sse4a_extrqi): Override length_immediate to 2. + (sse4a_insertqi): Likewise. Override prefix_data16 to 0. + (sse4a_insertq): Override prefix_data16 to 0. + (avx_blendp<avxmodesuffixf2c><avxmodesuffix>, + avx_blendvp<avxmodesuffixf2c><avxmodesuffix>, + avx_dpp<avxmodesuffixf2c><avxmodesuffix>, *avx_mpsadbw, + *avx_pblendvb, *avx_pblendw, avx_roundp<avxmodesuffixf2c>256, + avx_rounds<avxmodesuffixf2c>256): Override prefix_extra + and length_immediate to 1. + (sse4_1_blendp<ssemodesuffixf2c>, sse4_1_dpp<ssemodesuffixf2c>, + sse4_2_pcmpestr, sse4_2_pcmpestri, sse4_2_pcmpestrm, + sse4_2_pcmpestr_cconly, sse4_2_pcmpistr, sse4_2_pcmpistri, + sse4_2_pcmpistrm, sse4_2_pcmpistr_cconly): Override prefix_data16 + and length_immediate to 1. + (sse4_1_blendvp<ssemodesuffixf2c>): Override prefix_data16 to 1. + (sse4_1_mpsadbw, sse4_1_pblendw): Override length_immediate to 1. + (*avx_packusdw, avx_vtestp<avxmodesuffixf2c><avxmodesuffix>, + avx_ptest256): Override prefix_extra to 1. + (sse4_1_roundp<ssemodesuffixf2c>, sse4_1_rounds<ssemodesuffixf2c>): + Override prefix_data16 and length_immediate to 1. + (sse5_pperm_zero_v16qi_v8hi, sse5_pperm_sign_v16qi_v8hi, + sse5_pperm_zero_v8hi_v4si, sse5_pperm_sign_v8hi_v4si, + sse5_pperm_zero_v4si_v2di, sse5_pperm_sign_v4si_v2di, + sse5_vrotl<mode>3, sse5_ashl<mode>3, sse5_lshl<mode>3): Override + prefix_data16 to 0 and prefix_extra to 2. + (sse5_rotl<mode>3, sse5_rotr<mode>3): Override length_immediate to 1. + (sse5_frcz<mode>2, sse5_vmfrcz<mode>2): Don't override prefix_extra + attribute. + (*sse5_vmmaskcmp<mode>3, sse5_com_tf<mode>3, + sse5_maskcmp<mode>3, sse5_maskcmp<mode>3, sse5_maskcmp_uns<mode>3): + Override prefix_data16 and prefix_rep to 0, length_immediate to 1 + and prefix_extra to 2. + (sse5_maskcmp_uns2<mode>3, sse5_pcom_tf<mode>3): Override + prefix_data16 to 0, length_immediate to 1 and prefix_extra to 2. + (*avx_aesenc, *avx_aesenclast, *avx_aesdec, *avx_aesdeclast, + avx_vpermilvar<mode>3, + avx_vbroadcasts<avxmodesuffixf2c><avxmodesuffix>, + avx_vbroadcastss256, avx_vbroadcastf128_p<avxmodesuffixf2c>256, + avx_maskloadp<avxmodesuffixf2c><avxmodesuffix>, + avx_maskstorep<avxmodesuffixf2c><avxmodesuffix>): + Override prefix_extra to 1. + (aeskeygenassist, pclmulqdq): Override length_immediate to 1. + (*vpclmulqdq, avx_vpermil<mode>, avx_vperm2f128<mode>3, + vec_set_lo_<mode>, vec_set_hi_<mode>, vec_set_lo_v16hi, + vec_set_hi_v16hi, vec_set_lo_v32qi, vec_set_hi_v32qi): Override + prefix_extra and length_immediate to 1. + (*avx_vzeroall, avx_vzeroupper, avx_vzeroupper_rex64): Override + modrm to 0. + (*vec_concat<mode>_avx): Override prefix_extra and length_immediate + to 1 for the first alternative. + * config/i386/mmx.md (*mov<mode>_internal_rex64): Override + prefix_rep, prefix_data16 and/or prefix_rex attributes in certain + cases. + (*mov<mode>_internal_avx, *movv2sf_internal_rex64, + *movv2sf_internal_avx, *movv2sf_internal): Override + prefix_rep attribute for certain alternatives. + (*mov<mode>_internal): Override prefix_rep or prefix_data16 + attributes for certain alternatives. + (*movv2sf_internal_rex64_avx): Override prefix_rep and length_vex + attributes for certain alternatives. + (*mmx_addv2sf3, *mmx_subv2sf3, *mmx_mulv2sf3, + *mmx_<code>v2sf3_finite, *mmx_<code>v2sf3, mmx_rcpv2sf2, + mmx_rcpit1v2sf3, mmx_rcpit2v2sf3, mmx_rsqrtv2sf2, mmx_rsqit1v2sf3, + mmx_haddv2sf3, mmx_hsubv2sf3, mmx_addsubv2sf3, + *mmx_eqv2sf3, mmx_gtv2sf3, mmx_gev2sf3, mmx_pf2id, mmx_pf2iw, + mmx_pi2fw, mmx_floatv2si2, mmx_pswapdv2sf2, *mmx_pmulhrwv4hi3, + mmx_pswapdv2si2): Set prefix_extra attribute to 1. + (mmx_ashr<mode>3, mmx_lshr<mode>3, mmx_ashl<mode>3): Set + length_immediate to 1 if operand 2 is const_int_operand. + (*mmx_pinsrw, mmx_pextrw, mmx_pshufw_1, *vec_dupv4hi, + *vec_extractv2si_1): Set length_immediate attribute to 1. + (*mmx_uavgv8qi3): Override prefix_extra attribute to 1 if + using old 3DNOW insn rather than SSE/3DNOW_A. + (mmx_emms, mmx_femms): Clear modrm attribute. + +2009-05-29 Martin Jambor <mjambor@suse.cz> + + * tree-sra.c: New implementation of SRA. + + * params.def (PARAM_SRA_MAX_STRUCTURE_SIZE): Removed. + (PARAM_SRA_MAX_STRUCTURE_COUNT): Removed. + (PARAM_SRA_FIELD_STRUCTURE_RATIO): Removed. + * params.h (SRA_MAX_STRUCTURE_SIZE): Removed. + (SRA_MAX_STRUCTURE_COUNT): Removed. + (SRA_FIELD_STRUCTURE_RATIO): Removed. + * doc/invoke.texi (sra-max-structure-size): Removed. + (sra-field-structure-ratio): Removed. + +2009-05-29 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40291 + * builtins.c (expand_builtin_memcmp): Convert len to sizetype + before expansion. + +2009-05-29 Andrey Belevantsev <abel@ispras.ru> + + PR rtl-optimization/40101 + * sel-sched-ir.c (get_seqno_by_preds): Allow returning negative + seqno. Adjust comment. + * sel-sched.c (find_seqno_for_bookkeeping): Assert that when + inserting bookkeeping before a jump, the jump is not scheduled. + When no positive seqno found, provide a value. Add comment. + +2009-05-29 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (nonaliasing_component_refs_p): Remove + short-cutting on the first component. + +2009-05-29 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/39958 + * omp-low.c (scan_omp_1_op): Call remap_type on TREE_TYPE + for trees other than decls/types. + +2009-05-29 Richard Guenther <rguenther@suse.de> + + * tree-ssa-operands.c (get_expr_operands): Do not handle + INDIRECT_REFs in the handled-component case. Remove + unused get_ref_base_and_extent case. + * tree-dfa.c (get_ref_base_and_extent): Avoid calling + tree_low_cst and host_integerp where possible. + * tree-ssa-structalias.c (equiv_class_label_eq): Check hash + codes for equivalence. + * dce.c (find_call_stack_args): Avoid redundant bitmap queries. + +2009-05-29 David Billinghurst <billingd@gcc.gnu.org> + + * config.gcc: Add i386/t-fprules-softfp and soft-fp/t-softfp + to tmake_file for i[34567]86-*-cygwin*. + +2009-05-29 Jakub Jelinek <jakub@redhat.com> + + PR target/40017 + * config/rs6000/rs6000-c.c (_Bool_keyword): New variable. + (altivec_categorize_keyword, init_vector_keywords, + rs6000_cpu_cpp_builtins): Define _Bool as conditional macro + similar to bool. + +2009-05-29 Kai Tietz <kai.tietz@onevision.com> + + * tree.c (handle_dll_attribute): Check if node is + of kind FUNCTION_DECL for DECL_DECLARED_INLINE_P check. + +2009-05-29 Richard Earnshaw <rearnsha@arm.com> + + * config/arm/thumb2.md (thumb2_zero_extendsidi2): Add a split + component. + (thumb2_zero_extendqidi2): Likewise. + +2009-05-28 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (sh_expand_t_scc): Use gen_xorsi3_movrt + instead of gen_movrt. + * config/sh/sh.md (movrt): Remove. + +2009-05-28 Steve Ellcey <sje@cup.hp.com> + + * doc/invoke.texi (IA-64 Options): + Add -msdata, -mfused-madd, -mno-inline-float-divide, + -mno-inline-int-divide, -mno-inline-sqrt, -msched-spec-ldc, + -msched-spec-control-ldc, -msched-prefer-non-data-spec-insns, + -msched-prefer-non-control-spec-insns, + -msched-stop-bits-after-every-cycle, + -msched-count-spec-in-critical-path, + -msel-sched-dont-check-control-spec, -msched-fp-mem-deps-zero-cost + -msched-max-memory-insns-hard-limit, -msched-max-memory-insns. + Remove -mt, -pthread, -msched-ldc, -mno-sched-control-ldc, + and -msched-spec-verbose. + +2009-05-28 Joseph Myers <joseph@codesourcery.com> + + * config/arm/lib1funcs.asm (__clear_cache): Define if L_clear_cache. + * config/arm/linux-eabi.h (CLEAR_INSN_CACHE): Define to give an + error if used. + * config/arm/t-linux-eabi (LIB1ASMFUNCS): Add _clear_cache. + +2009-05-28 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (ao_ref_init): New function. + (ao_ref_base): Likewise. + (ao_ref_base_alias_set): Likewise. + (ao_ref_alias_set): Likewise. + (refs_may_alias_p_1): Change signature. + (refs_may_alias_p): Adjust. + (refs_anti_dependent_p): Likewise. + (refs_output_dependent_p): Likewise. + (call_may_clobber_ref_p_1): Change signature. + (call_may_clobber_ref_p): Adjust. + (stmt_may_clobber_ref_p_1): New function split out from ... + (stmt_may_clobber_ref_p): ... here. + (maybe_skip_until): Adjust signature. + (get_continuation_for_phi): Likewise. + (walk_non_aliased_vuses): Likewise. + * tree-ssa-alias.h (struct ao_ref_s): New structure type. + (ao_ref_init): Declare. + (ao_ref_base): Likewise. + (ao_ref_alias_set): Likewise. + (stmt_may_clobber_ref_p_1): Likewise. + (walk_non_aliased_vuses): Adjust. + * tree-ssa-sccvn.c (ao_ref_init_from_vn_reference): New function. + (get_ref_from_reference_ops): remove. + (vn_reference_lookup_2): Adjust signature. + (vn_reference_lookup_3): Do not re-build trees. Handle unions. + (vn_reference_lookup_pieces): Adjust signature, do not re-build trees. + (vn_reference_lookup): Adjust. + (vn_reference_insert): Likewise. + (vn_reference_insert_pieces): Adjust signature. + (visit_reference_op_call): Adjust. + * tree-ssa-pre.c (get_expr_type): Simplify. + (phi_translate_1): Adjust. + (compute_avail): Likewise. + (translate_vuse_through_block): Do not re-build trees. + (value_dies_in_block_x): Likewise. + * tree-ssa-sccvn.h (struct vn_reference_s): Add type and alias-set + fields. + (vn_reference_lookup_pieces): Adjust declaration. + (vn_reference_insert_pieces): Likewise. + +2009-05-28 Benjamin Kosnik <bkoz@redhat.com> + + * tree-ssa-copy.c (replace_exp_1): Move op for warning-free use + with checking disabled. + +2009-05-28 Dave Korn <dave.korn.cygwin@gmail.com> + + PR target/37216 + + * configure.ac (HAVE_GAS_ALIGNED_COMM): Add autoconf test and + macro definition for support of three-operand format aligned + .comm directive in assembler on cygwin/pe/mingw target OS. + * configure: Regenerate. + * config.h: Regenerate. + + * config/i386/winnt.c (i386_pe_asm_output_aligned_decl_common): Use + aligned form of .comm directive if -mpe-aligned-commons is in effect. + * config/i386/cygming.opt (-mpe-aligned-commons): Add new option. + + * doc/invoke.texi (-mpe-aligned-commons): Document new target option. + * doc/tm.texi (ASM_OUTPUT_COMMON): Document zero size commons. + +2009-05-28 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/40254 + * tree-data-ref.c (dr_analyze_innermost): Take POFFSET into account + in analysis of basic blocks. + +2009-05-28 Adam Nemet <anemet@caviumnetworks.com> + + PR middle-end/33699 + * target.h (struct gcc_target): Fix indentation. Add const_anchor. + * target-def.h (TARGET_CONST_ANCHOR): New macro. + (TARGET_INITIALIZER): Use it. + * cse.c (CHEAPER): Move it up to the other macros. + (insert): Rename this ... + (insert_with_costs): ... to this. Add cost parameters. Update + function comment. + (insert): New function. Call insert_with_costs. + (compute_const_anchors, insert_const_anchor, insert_const_anchors, + find_reg_offset_for_const, try_const_anchors): New functions. + (cse_insn): Call try_const_anchors. Adjust cost of src_related + when using a const-anchor. Call insert_const_anchors. + * config/mips/mips.c (mips_set_mips16_mode): Set targetm.const_anchor. + * doc/tm.texi (Misc): Document TARGET_CONST_ANCHOR. + +2009-05-28 Alexandre Oliva <aoliva@redhat.com> + + * tree-inline.c (remap_decls): Enable nonlocalized variables + when not optimizing. + +2009-05-28 Alexandre Oliva <aoliva@redhat.com> + + * tree-ssa-live.c (remove_unused_locals): Skip when not optimizing. + Simplify other tests involving optimize. + +2009-05-27 Tom Tromey <tromey@redhat.com> + + * unwind-dw2.c (_Unwind_DebugHook): New function. + (uw_install_context): Call _Unwind_DebugHook. + +2009-05-27 Tom Tromey <tromey@redhat.com> + + * system.h (CONST_CAST2): Use C++ const_cast when compiled as C++ + +2009-05-27 Ian Lance Taylor <iant@google.com> + + * Makefile.in (LINKER, LINKER_FLAGS): Define. + (LINKER_FOR_BUILD, BUILD_LINKERFLAGS): Define. + (ALL_LINKERFLAGS): Define. + (xgcc$(exeext)): Change $(COMPILER) to $(LINKER). + (cpp$(exeext), cc1-dummy$(exeext), cc1$(exeext)): Likewise. + (collect2$(exeext), mips-tfile, mips-tdump): Likewise. + (gcov$(exeext), gcov-dump$(exeext)): Likewise. + (build/gen%$(build_exeext)): Change $(COMPILER_FOR_BUILD) to + $(LINKER_FOR_BUILD). + (build/gcov-iov$(build_exeext)): Likewise. + +2009-05-27 Julian Brown <julian@codesourcery.com> + + * gcse.c (target.h): Include. + (can_assign_to_reg_without_clobbers_p): Check that the target allows + copy of argument to a pseudo register. + +2009-05-27 Diego Novillo <dnovillo@google.com> + + * tree-ssa-live.c (dump_scope_block): Document arguments. + (dump_scope_blocks): Document. + (debug_scope_blocks): New. + * tree-flow.h (debug_scope_blocks): Declare. + +2009-05-21 Denis Chertykov <denisc@overta.ru> + + * doc/contrib.texi (Contributors): Add myself to the list. + +2009-05-27 Olivier Hainque <hainque@adacore.com> + + * expr.c (target_align): New function. Alignment the TARGET of an + assignment may be assume to have. + (highest_pow2_factor_for_target): Use it instead of relying on + immediate tree attributes of TARGET, not necessarily honored when + intermediate bitfields are involved. + +2009-05-27 H.J. Lu <hongjiu.lu@intel.com> + + PR target/40266 + * config/i386/driver-i386.c (host_detect_local_cpu): Support + AVX, SSE4, AES, PCLMUL and POPCNT. + +2009-05-27 Diego Novillo <dnovillo@google.com> + + * tree-pretty-print.c (dump_location): New. + (dump_generic_node): Call it. + Factor code to handle BLOCK nodes ... + (dump_block_node): ... here. + +2009-05-27 Rafael Avila de Espindola <espindola@google.com> + + * Makefile.in (GCC_PLUGIN_H): New. Replace all uses of gcc-plugin.h + with it. + * doc/plugins.texi: Document that gcc-plugin.h must be the first to be + included. + * gcc-plugin.h: Include config.h and system.h. + (IN_GCC): Define if not defined. + +2009-05-27 Hans-Peter Nilsson <hp@axis.com> + + PR middle-end/40249 + * Makefile.in (CRTSTUFF_CFLAGS): Replace -fno-inline-functions + with -fno-inline. + +2009-05-27 Shujing Zhao <pearly.zhao@oracle.com> + + * config/m32r/m32r.c: Use REG_P, MEM_P and CONST_INT_P where + applicable. + * config/m32r/m32r.h: Ditto. + * config/m32r/m32r.md: Ditto. + * config/m32r/predicates.md: Ditto. + +2009-05-27 Alexandre Oliva <aoliva@redhat.com> + + * cgraph.c (dump_cgraph_node): Honor -fdump-noaddr. + +2009-05-26 Basile Starynkevitch <basile@starynkevitch.net> + + * doc/plugins.texi + (Loading plugins): typo. + (Plugin callbacks): Documented PLUGIN_INFO, PLUGIN_GGC_START, + PLUGIN_GGC_MARKING, PLUGIN_GGC_END, PLUGIN_REGISTER_GGC_ROOTS. + (Interacting with the GCC Garbage Collector): Added new section. + (Giving information about a plugin): Added new section for + PLUGIN_INFO. + * ggc.h (ggc_register_root_tab): Added declaration. + * gcc-plugin.h (PLUGIN_GGC_START, PLUGIN_GGC_MARKING) + (PLUGIN_GGC_END, PLUGIN_REGISTER_GGC_ROOTS): Added new events. + (register_callback): Improved comment in declaration. + * ggc-common.c (const_ggc_root_tab_t) Added new typedef for vectors. + (extra_root_vec) Added static variable for dynamic roots registration. + (ggc_register_root_tab) Added new routine. + (ggc_mark_roots) Added iteration inside extra_root_vec, and invoke + PLUGIN_GGC_MARKING event. + * ggc-zone.c: Include plugin.h. + (ggc_collect): Invoke PLUGIN_GGC_START & PLUGIN_GGC_END events. + * ggc-page.c: Include plugin.h. + (ggc_collect): Invoke PLUGIN_GGC_START & PLUGIN_GGC_END events. + * plugin.c (plugin_event_name): added names of PLUGIN_GGC_START, + PLUGIN_GGC_MARKING, PLUGIN_GGC_END, PLUGIN_REGISTER_GGC_ROOTS + (register_callback): check lack of callbacks for + pseudo-events. Added handling of PLUGIN_REGISTER_GGC_ROOTS, + PLUGIN_GGC_START, PLUGIN_GGC_MARKING, PLUGIN_GGC_END. + (invoke_plugin_callbacks): Handle PLUGIN_GGC_START, + PLUGIN_GGC_MARKING, PLUGIN_GGC_END, PLUGIN_REGISTER_GGC_ROOTS. + * Makefile.in (ggc-common.o, ggc-zone.o, ggc-page.o): Added + dependency on plugin.h. + (plugin.o): Added dependency on ggc.h... + +2009-05-26 Richard Guenther <rguenther@suse.de> + + PR middle-end/40248 + Revert + * expr.c (expand_expr_real_1): Avoid calling do_store_flag + with mismatched comparison modes. + + * expr.c (expand_expr_real_1): Expand the operand of a + VIEW_CONVERT_EXPR in its natural mode. + +2009-05-26 Ian Lance Taylor <iant@google.com> + + * Makefile.in (COMPILER, COMPILER_FLAGS): Define. + (COMPILER_FOR_BUILD, BUILD_COMPILERFLAGS): Define. + (ALL_COMPILERFLAGS): Define. + (.c.o, xgcc$(exeext), cpp$(exeext)): Use $(COMPILER). + (cc1-dummy$(exeext), cc1$(exeext)): Likewise. + (collect2$(exeext), collect2.o): Likewise. + (c-opts.o, c-cppbuiltin.o, c-pch.o, gcc.o, gccspec.o): Likewise. + (gcc-options.o, version.o, prefix.o, toplev.o): Likewise. + ($(out_object_file), mips-tfile, mips-tdump): Likewise. + (libbackend.o, intl.o, cppdefault.o): Likewise. + (gcov$(exeext), gcov-dump$(exeext)): Likewise. + (build/%.o): Use $(COMPILER_FOR_BUILD). + (build/gen%$(build_exeext)): Likewise. + (build/gcov-iov$(build_exeext)): LIkewise. + * config/t-darwin (darwin.o): Use $(COMPILER). + (darwin-c.o, darwin-f.o, darwin-driver.o): Likewise. + * config/t-sol2 (sol2-c.o): Likewise. + (sol2.o): Likewise. + * config/t-vxworks (vxworks.o): Likewise. + * config/x-darwin (host-darwin.o): Likewise. + * config/x-hpux (host-hpux.o): Likewise. + * config/x-linux (host-linux.o): Likewise. + * config/x-solaris (host-solaris.o): Likewise. + * config/alpha/x-alpha (driver-alpha.o): Likewise. + * config/arm/t-arm (arm-c.o): Likewise. + * config/arm/t-pe (pe.o): Likewise. + * config/arm/t-wince-pe (pe.o): Likewise. + * config/i386/t-cygming (winnt.o): Likewise. + (winnt-cxx.o, winnt-stubs.o, msformat-c.o): Likewise. + * config/i386/t-cygwin (cygwin1.o): Likewise. + (cygwin2.o): Likewise. + * config/i386/t-i386 (i386-c.o): Likewise. + * config/i386/t-interix (winnt.o): Likewise. + * config/i386/t-netware (netware.o): Likewise. + * config/i386/t-nwld (nwld.o): Likewise. + * config/i386/x-darwin (host-i386-darwin.o): Likewise. + * config/i386/x-i386 (driver-i386.o): Likewise. + * config/i386/x-cygwin (host-cygwin.o): Likewise. + * config/i386/x-mingw32 (host-mingw32.o): Likewise. + * config/ia64/t-ia64 (ia64-c.o): Likewise. + * config/m32c/t-m32c (m32c-pragma.o): Likewise. + * config/mips/x-native (driver-native.o): Likewise. + * config/rs6000/t-rs6000 (rs6000-c.o): Likewise. + * config/rs6000/x-darwin (host-ppc-darwin.o): Likewise. + * config/rs6000/x-darwin64 (host-ppc64-darwin.o): Likewise. + * config/rs6000/x-rs6000 (driver-rs6000.o): Likewise. + * config/score/t-score-elf (score7.o): Likewise. + (score3.o): Likewise. + * config/sh/t-sh (sh-c.o): Likewise. + * config/sh/t-symbian (sh-c.o): Likewise. + (symbian.o): Likewise. + * config/spu/t-spu-elf (spu-c.o): Likewise. + * config/v850/t-v850 (v850-c.o): Likewise. + * config/v850/t-v850e (v850-c.o): Likewise. + +2009-05-26 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40122 + * tree-ssa-ccp.c (ccp_fold): Fold vector CONSTRUCTORs to + VECTOR_CSTs if possible. + (fold_gimple_assign): Likewise. + +2009-05-26 Richard Guenther <rguenther@suse.de> + + PR middle-end/40252 + * fold-const.c (fold_binary): Use the correct types for building + rotates. + +2009-05-26 Richard Guenther <rguenther@suse.de> + + * tree-vect-data-refs.c (vect_create_data_ref_ptr): Remove + redundant calls to merge_alias_info. + (bump_vector_ptr): Likewise. + * tree-ssa-copy.c (merge_alias_info): Remove. + (replace_exp_1): Remove call to merge_alias_info. + (propagate_tree_value): Likewise. + (fini_copy_prop): Propagate points-to info. + * tree-flow.h (merge_alias_info): Remove. + +2009-05-07 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.C (PARAM_INLINE_CALL_COST): Remove. + +2009-05-25 Jan Hubicka <jh@suse.cz> + + * cgraph.c (dump_cgraph_node): Dump size/time/benefit. + * cgraph.h (struct inline_summary): New filed self_wize, + size_inlining_benefit, self_time and time_inlining_benefit. + (struct cgraph_global_info): Replace insns by time ans size fields. + * ipa-cp (ipcp_cloning_candidate_p): Base estimate on size + (ipcp_estimate_growth, ipcp_insert_stage): Likewise. + (ipcp_update_callgraph): Do not touch function bodies. + * ipa-inline.c: Include except.h + (MAX_TIME): New constant. + (overall_insns): Remove. + (leaf_node_p): New. + (overall_size, max_benefit): New static variables. + (cgraph_estimate_time_after_inlining): New function. + (cgraph_estimate_size_after_inlining): Rewrite using benefits. + (cgraph_clone_inlined_nodes): Update size. + (cgraph_mark_inline_edge): Update size. + (cgraph_estimate_growth): Use size info. + (cgraph_check_inline_limits): Check size. + (cgraph_default_inline_p): Likewise. + (cgraph_edge_badness): Compute badness based on benefit and size cost. + (cgraph_decide_recursive_inlining): Check size. + (cgraph_decide_inlining_of_small_function): Update size; dump sizes + and times. + (cgraph_decide_inlining): Likewise. + (cgraph_decide_inlining_incrementally): Likewise; honor + PARAM_EARLY_INLINING_INSNS. + (likely_eliminated_by_inlining_p): New predicate. + (estimate_function_body_sizes): New function. + (compute_inline_parameters): Use it. + * except.c (must_not_throw_labels): New function. + * except.h (must_not_throw_labels): Declare. + * tree-inline.c (init_inline_once): Kill inlining_weigths + * tree-ssa-structalias.c: Avoid uninitialized warning. + * params.def (PARAM_MAX_INLINE_INSNS_SINGLE): Reduce to 300. + (PARAM_MAX_INLINE_INSNS_AUTO): Reduce to 60. + (PARAM_INLINE_CALL_COST): Remove. + (PARAM_EARLY_INLINING_INSNS): New. + +2009-05-25 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/36327 + * tree-ssa-alias.c (walk_non_aliased_vuses): Add second walker + callback for reference translation or lookup at the point of may-defs. + * tree-ssa-alias.h (walk_non_aliased_vuses): Adjust prototype. + * tree-ssa-sccvn.c (get_ref_from_reference_ops): Bail out + for union COMPONENT_REFs. + (vn_reference_lookup_3): New callback. Lookup from memset + and CONSTRUCTOR assignment, translate through struct copies. + (vn_reference_lookup_pieces): Make sure to not free the + passed operands array. Adjust walk_non_aliased_vuses call. + (vn_reference_lookup): Adjust walk_non_aliased_vuses call, + make sure we do not leak memory. + +2009-05-25 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.h (dump_points_to_solution): Declare. + * tree-inline.c (expand_call_inline): Reset the escaped and + callused solutions. + * tree-ssa-structalias.c (pass_build_ealias): New. + * tree-pass.h (pass_build_ealias): Declare. + * passes.c (init_optimization_passes): Add PTA during + early optimizations. + * tree-ssa-alias.c (dump_alias_info): Dump the ESCAPED + and CALLUSED solutions. + (dump_points_to_solution): New function, split out from ... + (dump_points_to_info_for): ... here. + * tree-parloops.c (parallelize_loops): Reset the escaped and + callused solutions. + +2009-05-25 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE> + + PR bootstrap/40027 + * config/i386/i386.c (USE_HIDDEN_LINKONCE): Only define if missing. + * config/i386/sol2.h [!TARGET_GNU_LD] (USE_HIDDEN_LINKONCE): Define. + +2009-05-25 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/40238 + * tree-vect-stmts.c (vect_init_vector): Insert initialization + statements after basic block's labels. + * tree-vect-slp.c (vect_slp_transform_bb): Call destroy_bb_vec_info() + to free the allocated memory. + +2009-05-24 Kaz Kojima <kkojima@gcc.gnu.org> + + * gcc/config/sh/sh.c (sh_set_return_address): Mark store of + return address with a USE. + +2009-05-24 Richard Guenther <rguenther@suse.de> + + PR middle-end/40233 + * tree.c (make_vector_type): Build the TYPE_DEBUG_REPRESENTATION_TYPEs + array type from the main variant of the inner type. + +2009-05-24 Jan-Benedict Glaw <jbglaw@lug-owl.de> + + * config/vax/vax-protos.h (legitimate_constant_address_p): Change + definition to bool (from int) to un-break build. + (legitimate_constant_p, vax_mode_dependent_address_p): Likewise. + +2009-05-24 Paolo Bonzini <bonzini@gnu.org> + + * tree-ssa-operands.h (push_stmt_changes, pop_stmt_changes, + discard_stmt_changes): Delete. + * tree-ssa-operands.c (scb_stack): Delete. + (init_ssa_operands): Do not initialize it. + (fini_ssa_operands): Do not free it. + (push_stmt_changes, pop_stmt_changes, discard_stmt_changes): Delete. + + * tree-cfg.c (replace_uses_by): Replace pop_stmt_changes with + update_stmt, remove the others. Fix comments. + * tree-dfa.c (optimize_stack_restore): Likewise. + * tree-ssa-forwprop.c (forward_propagate_addr_expr): Likewise. + * tree-ssa-loop-ivopts.c (rewrite_use): Likewise. + * tree-ssa-dce.c (eliminate_unnecessary_stmts): Likewise. + * tree-ssa-ccp.c (optimize_stack_restore, execute_fold_all_builtins): + Likewise. + * tree-ssa-propagate.c (substitute_and_fold): Likewise. + * tree-ssa-dom.c (propagate_rhs_into_lhs): Likewise. + (dom_opt_finalize_block): Likewise, adjusting access to + stmts_to_rescan. + (optimize_stmt): Likewise, adjusting access to stmts_to_rescan. + (stmts_to_rescan): Change item type to gimple. + (tree_ssa_dominator_optimize): Change type of stmts_to_rescan. + +2009-05-24 Ira Rosen <irar@il.ibm.com> + + * doc/passes.texi (Tree-SSA passes): Document SLP pass. + * tree-pass.h (pass_slp_vectorize): New pass. + * params.h (SLP_MAX_INSNS_IN_BB): Define. + * timevar.def (TV_TREE_SLP_VECTORIZATION): Define. + * tree-vectorizer.c (timevar.h): Include. + (user_vect_verbosity_level): Declare. + (vect_location): Fix comment. + (vect_set_verbosity_level): Update user_vect_verbosity_level + instead of vect_verbosity_level. + (vect_set_dump_settings): Add an argument. Ignore user defined + verbosity if dump flags require higher level of verbosity. Print to + stderr only for loop vectorization. + (vectorize_loops): Update call to vect_set_dump_settings. + (execute_vect_slp): New function. + (gate_vect_slp): Likewise. + (struct gimple_opt_pass pass_slp_vectorize): New. + * tree-vectorizer.h (struct _bb_vec_info): Define along macros to + access its members. + (vec_info_for_bb): New function. + (struct _stmt_vec_info): Add bb_vinfo and a macro for its access. + (VECTORIZATION_ENABLED): New macro. + (SLP_ENABLED, SLP_DISABLED): Likewise. + (vect_is_simple_use): Add bb_vec_info argument. + (new_stmt_vec_info, vect_analyze_data_ref_dependences, + vect_analyze_data_refs_alignment, vect_verify_datarefs_alignment, + vect_analyze_data_ref_accesses, vect_analyze_data_refs, + vect_schedule_slp, vect_analyze_slp): Likewise. + (vect_analyze_stmt): Add slp_tree argument. + (find_bb_location): Declare. + (vect_slp_analyze_bb, vect_slp_transform_bb): Likewise. + * tree-vect-loop.c (new_loop_vec_info): Adjust function calls. + (vect_analyze_loop_operations, vect_analyze_loop, + get_initial_def_for_induction, vect_create_epilog_for_reduction, + vect_finalize_reduction, vectorizable_reduction, + vectorizable_live_operation, vect_transform_loop): Likewise. + * tree-data-ref.c (dr_analyze_innermost): Update comment, + skip evolution analysis if analyzing a basic block. + (dr_analyze_indices): Likewise. + (initialize_data_dependence_relation): Skip the test whether the + object is invariant for basic blocks. + (compute_all_dependences): Skip dependence analysis for data + references in basic blocks. + (find_data_references_in_stmt): Don't fail in case of invariant + access in basic block. + (find_data_references_in_bb): New function. + (find_data_references_in_loop): Move code to + find_data_references_in_bb and add a call to it. + (compute_data_dependences_for_bb): New function. + * tree-data-ref.h (compute_data_dependences_for_bb): Declare. + * tree-vect-data-refs.c (vect_check_interleaving): Adjust to the case + that STEP is 0. + (vect_analyze_data_ref_dependence): Check for interleaving in case of + unknown dependence in basic block and fail in case of dependence in + basic block. + (vect_analyze_data_ref_dependences): Add bb_vinfo argument, get data + dependence instances from either loop or basic block vectorization + info. + (vect_compute_data_ref_alignment): Check if it is loop vectorization + before calling nested_in_vect_loop_p. + (vect_compute_data_refs_alignment): Add bb_vinfo argument, get data + dependence instances from either loop or basic block vectorization + info. + (vect_verify_datarefs_alignment): Likewise. + (vect_enhance_data_refs_alignment): Adjust function calls. + (vect_analyze_data_refs_alignment): Likewise. + (vect_analyze_group_access): Fix printing. Skip different checks if + DR_STEP is 0. Keep strided stores either in loop or basic block + vectorization data structure. Fix indentation. + (vect_analyze_data_ref_access): Fix comments, allow zero step in + basic blocks. + (vect_analyze_data_ref_accesses): Add bb_vinfo argument, get data + dependence instances from either loop or basic block vectorization + info. + (vect_analyze_data_refs): Update comment. Call + compute_data_dependences_for_bb to analyze basic blocks. + (vect_create_addr_base_for_vector_ref): Check for outer loop only in + case of loop vectorization. In case of basic block vectorization use + data-ref itself as a base. + (vect_create_data_ref_ptr): In case of basic block vectorization: + don't advance the pointer, add new statements before the current + statement. Adjust function calls. + (vect_supportable_dr_alignment): Support only aligned accesses in + basic block vectorization. + * common.opt (ftree-slp-vectorize): New flag. + * tree-vect-patterns.c (widened_name_p): Adjust function calls. + (vect_pattern_recog_1): Likewise. + * tree-vect-stmts.c (process_use): Likewise. + (vect_init_vector): Add new statements in the beginning of the basic + block in case of basic block SLP. + (vect_get_vec_def_for_operand): Adjust function calls. + (vect_finish_stmt_generation): Likewise. + (vectorizable_call): Add assert that it is loop vectorization, adjust + function calls. + (vectorizable_conversion, vectorizable_assignment): Likewise. + (vectorizable_operation): In case of basic block SLP, take + vectorization factor from statement's type and skip the relevance + check. Adjust function calls. + (vectorizable_type_demotion): Add assert that it is loop + vectorization, adjust function calls. + (vectorizable_type_promotion): Likewise. + (vectorizable_store): Check for outer loop only in case of loop + vectorization. Adjust function calls. For basic blocks, skip the + relevance check and don't advance pointers. + (vectorizable_load): Likewise. + (vectorizable_condition): Add assert that it is loop vectorization, + adjust function calls. + (vect_analyze_stmt): Add argument. In case of basic block SLP, check + that it is not reduction, get vector type, call only supported + functions, skip loop specific parts. + (vect_transform_stmt): Check for outer loop only in case of loop + vectorization. + (new_stmt_vec_info): Add new argument and initialize bb_vinfo. + (vect_is_simple_use): Fix comment, add new argument, fix conditions + for external definition. + * passes.c (pass_slp_vectorize): New pass. + * tree-vect-slp.c (find_bb_location): New function. + (vect_get_and_check_slp_defs): Add argument, adjust function calls, + check for patterns only in loops. + (vect_build_slp_tree): Add argument, adjust function calls, fail in + case of multiple types in basic block SLP. + (vect_mark_slp_stmts_relevant): New function. + (vect_supported_load_permutation_p): Fix comment. + (vect_analyze_slp_instance): Add argument. In case of basic block + SLP, take vectorization factor from statement's type, check that + unrolling factor is 1. Adjust function call. Save SLP instance in + either loop or basic block vectorization structure. Return FALSE, + if SLP failed. + (vect_analyze_slp): Add argument. Get strided stores groups from + either loop or basic block vectorization structure. Return FALSE + if basic block SLP failed. + (new_bb_vec_info): New function. + (destroy_bb_vec_info, vect_slp_analyze_node_operations, + vect_slp_analyze_operations, vect_slp_analyze_bb): Likewise. + (vect_schedule_slp): Add argument. Get SLP instances from either + loop or basic block vectorization structure. Set vectorization factor + to be 1 for basic block SLP. + (vect_slp_transform_bb): New function. + * params.def (PARAM_SLP_MAX_INSNS_IN_BB): Define. + +2009-05-23 Mark Mitchell <mark@codesourcery.com> + + * final.c (shorten_branches): Do not align labels for jump tables. + (final_scan_insn): Use JUMP_TABLE_DATA_P. + +2009-05-23 Eric Botcazou <ebotcazou@adacore.com> + + * doc/passes.texi: Standardize spelling of RTL, Tree and Tree SSA. + Remove outdated reference to flow.c and fix nits. + * doc/gccint.texi: Tweak RTL description. + * doc/rtl.texi: Likewise. + +2009-05-23 Denis Chertykov <chertykov@gmail.com> + + * config/avr/avr.c: Change my email address. + * config/avr/avr.h: Likewise. + * config/avr/avr.md: Likewise. + * config/avr/avr-protos.h: Likewise. + * config/avr/libgcc.S: Likewise. + +2009-05-22 Trevor Smigiel <Trevor_Smigiel@playstation.sony.com> + + * config/spu/spu-protos.h (aligned_mem_p, spu_valid_mov): Remove. + (spu_split_load, spu_split_store): Change return type to int. + (spu_split_convert): Declare. + * config/spu/predicates.md (spu_mem_operand): Remove. + (spu_mov_operand): Update. + (spu_dest_operand, shiftrt_operator, extend_operator): Define. + * config/spu/spu.c (regno_aligned_for_load): Remove. + (reg_aligned_for_addr, spu_expand_load): Define. + (spu_expand_extv): Reimplement and handle MEM. + (spu_expand_insv): Handle MEM. + (spu_sched_reorder): Handle insn's with length 0. + (spu_legitimate_address_p): Reimplement. + (store_with_one_insn_p): Return TRUE for any mode with size + larger than 16 bytes. + (address_needs_split): Define. + (spu_expand_mov): Call spu_split_load and spu_split_store for MEM + operands. + (spu_convert_move): Define. + (spu_split_load): Use spu_expand_load and change all MEM's to TImode. + (spu_split_store): Change all MEM's to TImode. + (spu_init_expanders): Preallocate registers that correspond to + LAST_VIRTUAL_REG+1 and LAST_VIRTUAL_REG+2 and set them with + mark_reg_pointer. + (spu_split_convert): Define. + * config/spu/spu.md (QHSI, QHSDI): New mode iterators. + (_move<mode>, _movdi, _movti): Update predicate and condition. + (load, store): Change to define_split. + (extendqiti2, extendhiti2, extendsiti2, extendditi2): Simplify to + extend<mode>ti2. + (zero_extendqiti2, zero_extendhiti2, <v>lshr<mode>3_imm): Define. + (lshr<mode>3, lshr<mode>3_imm, lshr<mode>3_re): Simplify to one + define_insn_and_split of lshr<mode>3. + (shrqbybi_<mode>, shrqby_<mode>): Simplify to define_expand. + (<v>ashr<mode>3_imm): Define. + (extv, extzv, insv): Allow MEM operands. + (trunc_shr_ti<mode>, trunc_shr_tidi, shl_ext_<mode>ti, + shl_ext_diti, sext_trunc_lshr_tiqisi, zext_trunc_lshr_tiqisi, + sext_trunc_lshr_tihisi, zext_trunc_lshr_tihisi): Define for combine. + (_spu_convert2): Change to define_insn_and_split and remove the + corresponding define_peephole2. + (stack_protect_set, stack_protect_test, stack_protect_test_si): + Change predicates to memory_operand. + +2009-05-22 Mark Mitchell <mark@codesourcery.com> + + * config/arm/thumb2.md: Add 16-bit multiply instructions. + +2009-05-21 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR tree-optimization/40219 + * tree.c (iterative_hash_expr): Make sure the builtin function is + a normal builtin function and not a front end or back end builtin + before indexing into the built_in_decls array. + +2009-05-22 Richard Guenther <rguenther@suse.de> + + PR middle-end/38964 + * alias.c (write_dependence_p): Do not use TBAA for answering + anti-dependence or output-dependence. + * tree-ssa-structalias.c (set_uids_in_ptset): Remove TBAA pruning code. + (emit_pointer_definition): Remove. + (emit_alias_warning): Likewise. + (find_what_var_points_to): Remove TBAA pruning code. + (find_what_p_points_to): Likewise. Do not warn about strict-aliasing + violations. + (compute_points_to_sets): Remove code computing the set of + dereferenced pointers. + * tree-data-ref.c (dr_may_alias_p): Properly use the split + oracle for querying anti and output dependencies. + * tree-ssa-alias.c (refs_may_alias_p_1): Add argument specifying + if TBAA may be applied. + (refs_anti_dependent_p): New function. + (refs_output_dependent_p): Likewise. + * tree-ssa-alias.h (refs_anti_dependent_p): Declare. + (refs_output_dependent_p): Likewise. + * doc/tree-ssa.texi (Memory model): New section. + * doc/c-tree.texi (CHANGE_DYNAMIC_TYPE_EXPR): Remove. + * doc/gimple.texi (GIMPLE_CHANGE_DYNAMIC_TYPE): Remove. + * cfgexpand.c (expand_gimple_basic_block): Do not handle + GIMPLE_CHANGE_DYNAMIC_TYPE or CHANGE_DYNAMIC_TYPE_EXPR. + * expr.c (expand_expr_real_1): Likewise. + * gimple-low.c (lower_stmt): Likewise. + * gimple-pretty-print.c (dump_gimple_stmt): Likewise. + (dump_gimple_cdt): Remove. + * gimple.c (gss_for_code): Do not handle GIMPLE_CHANGE_DYNAMIC_TYPE. + (gimple_size): Likewise. + (walk_gimple_op): Likewise. + (is_gimple_stmt): Likewise. + (walk_stmt_load_store_addr_ops): Likewise. + (gimple_build_cdt): Remove. + * gimple.def (GIMPLE_CHANGE_DYNAMIC_TYPE): Remove. + * gimple.h (gimple_cdt_new_type): Remove. + (gimple_cdt_new_type_ptr): Likewise. + (gimple_cdt_set_new_type): Likewise. + (gimple_cdt_location): Likewise. + (gimple_cdt_location_ptr): Likewise. + (gimple_cdt_set_location): Likewise. + * gimplify.c (gimplify_expr): Do not handle CHANGE_DYNAMIC_TYPE_EXPR. + * tree-cfg.c (remove_useless_stmts_1): Do not handle + GIMPLE_CHANGE_DYNAMIC_TYPE. + (verify_types_in_gimple_stmt): Likewise. + * tree-inline.c (estimate_num_insns): Likewise. + (expand_call_inline): Do not copy DECL_NO_TBAA_P. + (copy_decl_to_var): Likewise. + (copy_result_decl_to_var): Likewise. + * tree-pretty-print.c (dump_generic_node): Do not handle + CHANGE_DYNAMIC_TYPE_EXPR. + * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Likewise. + * tree-ssa-operands.c (get_expr_operands): Likewise. + * tree-ssa-structalias.c (struct variable_info): Remove + no_tbaa_pruning member. + (new_var_info): Do not set it based on DECL_NO_TBAA_P. + (unify_nodes): Do not copy it. + (find_func_aliases): Do not handle GIMPLE_CHANGE_DYNAMIC_TYPE. + (dump_solution_for_var): Do not dump no_tbaa_pruning state. + (set_uids_in_ptset): Do not check it. + (find_what_var_points_to): Likewise. + (compute_tbaa_pruning): Remove. + (compute_points_to_sets): Do not call it. + * tree.c (walk_tree_1): Do not handle CHANGE_DYNAMIC_TYPE_EXPR. + * tree.def (CHANGE_DYNAMIC_TYPE_EXPR): Remove. + * tree.h (CHANGE_DYNAMIC_TYPE_NEW_TYPE): Remove. + (CHANGE_DYNAMIC_TYPE_LOCATION): Likewise. + (DECL_NO_TBAA_P): Likewise. + (struct tree_decl_common): Move no_tbaa_flag to unused flags section. + * omp-low.c (copy_var_decl): Do not copy DECL_NO_TBAA_P. + (expand_omp_atomic_pipeline): Do not set it. + * print-tree.c (print_node): Do not dump it. + * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Remove + redundant check. + +2009-05-22 Vladimir Makarov <vmakarov@redhat.com> + + PR target/39856 + * reg-stack.c (subst_stack_regs_pat): Remove gcc_assert for note + for clobber. + +2009-05-22 Mark Mitchell <mark@codesourcery.com> + + * tree.c (handle_dll_attribute): Mark dllexport'd inlines as + non-external. + +2009-05-22 Ben Elliston <bje@au.ibm.com> + + * Makefile.in (bversion.h, s-bversion): New targets. + (TOPLEV_H): Add bversion.h. + * toplev.h: Include "bversion.h". + (ATTRIBUTE_GCC_DIAG): When building with checking disabled, use + the __format__ attribute only if compiling with the same version + of GCC as the sources (the "build version"). + +2009-05-22 Ben Elliston <bje@au.ibm.com> + + * c-format.c (handle_format_attribute): Fix comment typo. + +2009-05-21 Steve Ellcey <sje@cup.hp.com> + + PR target/37846 + * config/ia64/ia64.opt (mfused-madd): New. + * config/ia64/ia64.h (TARGET_DEFAULT): Set MASK_FUSED_MADD. + * config/ia64/hpux.h (TARGET_DEFAULT): Ditto. + * config/ia64/ia64.md (maddsf4, msubsf4, nmaddsf4, + madddf4, madddf4_trunc, msubdf4, msubdf4_trunc, nmadddf4, + nmadddf4_truncsf, maddxf4, maddxf4_truncsf, maddxf4_truncdf, + msubxf4, msubxf4_truncsf msubxf4_truncdf, nmaddxf4, + nmaddxf4_truncsf, nmaddxf4_truncdf): Check TARGET_FUSED_MADD. + * config/ia64/vect.md (addv2sf3, subv2sf3): Force fpma/fpms + instruction if !TARGET_FUSED_MADD. + (fpma, fpms): Remove colon from name. + +2009-05-22 Richard Guenther <rguenther@suse.de> + + * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Record + TMR_ORIGINAL. Always either record TMR_SYMBOL or TMR_BASE. + * tree-ssa-pre.c (create_component_ref_by_pieces_1): Handle + TARGET_MEM_REF. + (create_expression_by_pieces): Only convert if necessary. + * gimplify.c (gimplify_expr): Handle TARGET_MEM_REF. + * tree-ssa-loop-im.c (gen_lsm_tmp_name): Handle INTEGER_CST. + +2009-05-21 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (*extzv_trunc<mode>_exts): Turn into a + regular pattern from a template and rename it ... + (*extzv_truncsi_exts): ... to this. + +2009-05-21 Richard Guenther <rguenther@suse.de> + + * cgraph.h (struct cgraph_node): Remove inline_decl member. + * ipa-inline.c (cgraph_mark_inline_edge): Do not check it. + (cgraph_default_inline_p): Likewise. + (cgraph_decide_inlining_incrementally): Likewise. + +2009-05-21 H.J. Lu <hongjiu.lu@intel.com> + Uros Bizjak <ubizjak@gmail.com> + + * config/i386/cpuid.h (bit_MOVBE): New. + + * config/i386/driver-i386.c (host_detect_local_cpu): Check movbe. + + * config/i386/i386.c (OPTION_MASK_ISA_MOVBE_SET): New. + (OPTION_MASK_ISA_MOVBE_UNSET): Likewise. + (ix86_handle_option): Handle OPT_mmovbe. + (ix86_target_string): Add -mmovbe. + (pta_flags): Add PTA_MOVBE. + (processor_alias_table): Add PTA_MOVBE to "atom". + (override_options): Handle PTA_MOVBE. + + * config/i386/i386.h (TARGET_MOVBE): New. + + * config/i386/i386.md (bswapsi2): Check TARGET_MOVBE. + (*bswapsi_movbe): New. + (*bswapdi_movbe): Likewise. + (bswapdi2): Renamed to ... + (*bswapdi_1): This. + (bswapdi2): New expander. + + * config/i386/i386.opt (mmovbe): New. + + * doc/invoke.texi: Document -mmovbe. + +2009-05-21 Taras Glek <tglek@mozilla.com> + + * plugin.c (try_init_one_plugin): Updated to new plugin_init API. + * gcc-plugin.h (plugin_init): Updated signature. + * gcc-plugin.h (plugin_name_args): Moved to this header. + * doc/plugins.texi (plugin_init): Updated documention to reflect + API change. + * doc/plugins.texi (plugin_name_args): Added to documention. + +2009-05-21 Mark Mitchell <mark@codesourcery.com> + + * config/arm/neon.md (*mul<mode>3add<mode>_neon): New pattern. + (*mul<mode>3neg<mode>add<mode>_neon): Likewise. + +2009-05-21 Shujing Zhao <pearly.zhao@oracle.com> + + * config/i386/i386.c: Use REG_P, MEM_P, CONST_INT_P, LABEL_P and + JUMP_TABLE_DATA_P predicates where applicable. + * config/i386/predicates.md: Ditto. + * config/i386/sse.md: Ditto. + +2009-05-21 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.md (adddi_4_rex64, addsi_4, addhi_4): For + operand2 -128 override length_immediate attribute to 1. + * config/i386/predicates.md (constm128_operand): New predicate. + + * config/i386/i386.c (memory_address_length): Handle %r12 + the same as %rsp and %r13 the same as %rbp. For %rsp and %rbp + also check REGNO. + (ix86_attr_length_address_default): For MODE_SI lea in 64-bit + mode look through optional ZERO_EXTEND and SUBREG. + * config/i386/i386.md (R12_REG): New define_constant. + (prefix_data16): For sse unit set also for MODE_TI insns. + (prefix_rex): For -m32 always return 0. For TYPE_IMOVX + insns set if operand 1 is ext_QIreg_operand. + (modrm): For TYPE_IMOV clear only if not MODE_DI. For + TYPE_{ALU{,1},ICMP,TEST} insn clear if there is non-shortened + immediate. + (*movdi_extzv_1, zero_extendhidi2, zero_extendqidi2): Change + mode from MODE_DI to MODE_SI. + (movdi_1_rex64): Override modrm and length_immediate attributes + only for movabs (TYPE_IMOV, alternative 2). + (zero_extendsidi2_rex64): Clear prefix_0f attribute if TYPE_IMOVX. + (*float<SSEMODEI24:mode><MODEF:mode>2_mixed_interunit, + *float<SSEMODEI24:mode><MODEF:mode>2_mixed_nointerunit, + *float<SSEMODEI24:mode><MODEF:mode>2_sse_interunit, + *float<SSEMODEI24:mode><MODEF:mode>2_sse_nointerunit): Set + prefix_rex attribute if DImode. + (*adddi_1_rex64, *adddi_2_rex64, *adddi_3_rex64, *adddi_5_rex64, + *addsi_1, *addsi_1_zext, *addsi_2, *addsi_2_zext, *addsi_3, + *addsi_3_zext, *addsi_5, *addhi_1_lea, *addhi_1, *addhi_2, *addhi_3, + *addhi_5, *addqi_1_lea, *addqi_1): Override length_immediate + attribute to 1 if TYPE_ALU and operand 2 is const128_operand. + (pro_epilogue_adjust_stack_1, pro_epilogue_adjust_stack_rex64): + Likewise. For TYPE_IMOV clear length_immediate attribute. + (*ashldi3_1_rex64, *ashldi3_cmp_rex64, *ashldi3_cconly_rex64, + *ashlsi3_1, *ashlsi3_1_zext, *ashlsi3_cmp, **ashlsi3_cconly, + *ashlsi3_cmp_zext, *ashlhi3_1_lea, *ashlhi3_1, *ashlhi3_cmp, + *ashlhi3_cconly, *ashlqi3_1_lea, *ashlqi3_1, *ashlqi3_cmp, + *ashlqi3_cconly): Override length_immediate attribute to 0 if TYPE_ALU + or one operand TYPE_ISHIFT. + (*ashrdi3_1_one_bit_rex64, *ashrdi3_one_bit_cmp_rex64, + *ashrdi3_one_bit_cconly_rex64, *ashrsi3_1_one_bit, + *ashrsi3_1_one_bit_zext, *ashrsi3_one_bit_cmp, + *ashrsi3_one_bit_cconly, *ashrsi3_one_bit_cmp_zext, + *ashrhi3_1_one_bit, *ashrhi3_one_bit_cmp, *ashrhi3_one_bit_cconly, + *ashrqi3_1_one_bit, *ashrqi3_1_one_bit_slp, *ashrqi3_one_bit_cmp, + *ashrqi3_one_bit_cconly, *lshrdi3_1_one_bit_rex64, + *lshrdi3_cmp_one_bit_rex64, *lshrdi3_cconly_one_bit_rex64, + *lshrsi3_1_one_bit, *lshrsi3_1_one_bit_zext, *lshrsi3_one_bit_cmp, + *lshrsi3_one_bit_cconly, *lshrsi3_cmp_one_bit_zext, + *lshrhi3_1_one_bit, *lshrhi3_one_bit_cmp, *lshrhi3_one_bit_cconly, + *lshrqi3_1_one_bit, *lshrqi3_1_one_bit_slp, *lshrqi2_one_bit_cmp, + *lshrqi2_one_bit_cconly, *rotlsi3_1_one_bit_rex64, *rotlsi3_1_one_bit, + *rotlsi3_1_one_bit_zext, *rotlhi3_1_one_bit, *rotlqi3_1_one_bit_slp, + *rotlqi3_1_one_bit, *rotrdi3_1_one_bit_rex64, *rotrsi3_1_one_bit, + *rotrsi3_1_one_bit_zext, *rotrhi3_one_bit, *rotrqi3_1_one_bit, + *rotrqi3_1_one_bit_slp): Override length_immediate attribute to 0, + set mode attribute, don't override length attribute. + (*btsq, *btrq, *btcq, *btdi_rex64, *btsi): Set prefix_0f attribute + to 1. + (return_internal_long): Set length attribute to 2 instead of 1. + (*strmovqi_rex_1, *strsetqi_rex_1, *rep_stosqi_rex64, + *cmpstrnqi_nz_rex_1, *cmpstrnqi_rex_1, *strlenqi_rex_1): Clear + prefix_rex attribute. + * config/i386/predicates.md (ext_QIreg_operand, const128_operand): + New predicates. + (memory_displacement_only_operand): Always return 0 for TARGET_64BIT. + +2009-05-21 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/thumb2.md (orsi_notsi_si): Fix typo in pattern. + +2009-05-20 Ian Lance Taylor <iant@google.com> + + * tree.c (build_tree_list_vec_stat): New function. + (ctor_to_vec): New function. + (build_nt_call_vec): New function. + (build_call_array): Change args to be a const pointer. + (build_call_vec): New function. + * tree.h (build_nt_call_vec): Declare. + (build_tree_list_vec_stat): Declare. + (build_tree_list_vec): Define. + (build_call_array): Update declaration. + (build_call_vec): Declare. + (ctor_to_vec): Declare. + * c-common.c (tree_vector_cache): New static variable. + (make_tree_vector): New function. + (release_tree_vector): New function. + (make_tree_vector_single): New function. + (make_tree_vector_copy): New function. + * c-common.h (tree_vector_cache, make_tree_vector): Declare. + (make_tree_vector_single, make_tree_vector_copy): Declare. + * c-parser.c (cached_expr_list_1, cached_expr_list_2): Remove. + (c_parser_expr_list): Don't manage cache here, instead call + make_tree_vector. + (c_parser_release_expr_list): Remove static function. + (c_parser_vec_to_tree_list): Remove static function. + (c_parser_attributes): Call build_tree_list_vec instead of + c_parser_vec_to_tree_list. Call release_tree_vector instead of + c_parser_release_expr_list. + (c_parser_postfix_expression_after_primary): Likewise. + (c_parser_objc_keywordexpr): Likewise. + +2009-05-20 Sandra Loosemore <sandra@codesourcery.com> + + * doc/tm.texi (Misc): Document TARGET_INVALID_PARAMETER_TYPE, + TARGET_INVALID_RETURN_TYPE, TARGET_PROMOTED_TYPE, and + TARGET_CONVERT_TO_TYPE. + * hooks.c (hook_tree_const_tree_null): Define. + * hooks.h (hook_tree_const_tree_null): Declare. + * target.h (struct gcc_target): Add invalid_parameter_type, + invalid_return_type, promoted_type, and convert_to_type fields. + * target-def.h (TARGET_INVALID_PARAMETER_TYPE): Define. + (TARGET_INVALID_RETURN_TYPE): Define. + (TARGET_PROMOTED_TYPE): Define. + (TARGET_CONVERT_TO_TYPE): Define. + (TARGET_INITIALIZER): Update for new fields. + * c-decl.c (grokdeclarator): Check targetm.invalid_return_type. + (grokparms): Check targetm.invalid_parameter_type. + * c-typeck.c (default_conversion): Check targetm.promoted_type. + * c-convert.c (convert): Check targetm.convert_to_type. + +2009-05-20 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (*extenddi_truncate<mode>, + *extendsi_truncate<mode>): Emit exts if supported. Add attribute + defintions. + (*extendhi_truncateqi): New define_insn_and_sptit. + +2009-05-20 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40204 + * fold-const.c (fold_binary) <case BIT_AND_EXPR>: Avoid infinite + recursion if build_int_cst_type returns the same INTEGER_CST as arg1. + +2009-05-20 Eric Botcazou <ebotcazou@adacore.com> + + * fold-const.c (build_fold_addr_expr_with_type): Take the address of + the operand of VIEW_CONVERT_EXPR. + +2009-05-20 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/driver-i386.c (host_detect_local_cpu): Check + extended family and model for Intel processors. Support Intel Atom. + +2009-05-20 Olivier Hainque <hainque@adacore.com> + + * gstab.h (stab_code_type): Define, to be used instead of the + __stab_debug_code enum, made anonymous. Add 2009 to the copyright + notice. + * dbxout.c (STAB_CODE_TYPE): Remove #define and replace use + occurrences by stab_code_type. + * mips-tfile.c (STAB_CODE_TYPE): Remove #define, unused. + +2009-05-20 Martin Jambor <mjambor@suse.cz> + + * tree-flow.h (insert_edge_copies_seq): Undeclare. + (sra_insert_before): Likewise. + (sra_insert_after): Likewise. + (sra_init_cache): Likewise. + (sra_type_can_be_decomposed_p): Likewise. + * tree-mudflap.c (insert_edge_copies_seq): Copied here from tree-sra.c + * tree-sra.c (sra_type_can_be_decomposed_p): Made static. + (sra_insert_before): Likewise. + (sra_insert_after): Likewise. + (sra_init_cache): Likewise. + (insert_edge_copies_seq): Made static and moved upwards. + + * tree-complex.c (extract_component): Added VIEW_CONVERT_EXPR switch + case. + + * tree-flow-inline.h (contains_view_convert_expr_p): New function. + + * ipa-prop.c (get_ssa_def_if_simple_copy): New function. + (determine_cst_member_ptr): Call get_ssa_def_if_simple_copy to skip + simple copies. + +2009-05-20 Richard Guenther <rguenther@suse.de> + + * expr.c (expand_expr_real_1): Avoid calling do_store_flag + with mismatched comparison modes. + +2009-05-20 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.md (*arm_iorsi3): Refactored for only ARM. + (peephole ior (reg, int) -> mov, ior): Refactored for only ARM. + * config/arm/thumb2.md (*thumb_andsi_not_shiftsi_si): Allow bic + with shifts for Thumb2. + (orsi_notsi): New for orn. + (*thumb_orsi_notshiftsi_si): Allow orn with shifts. + (*thumb2_iorsi3): Rewrite support for iorsi for Thumb2. + * config/arm/arm.c (const_ok_for_op): Split case for IOR for Thumb2. + (arm_gen_constant): Set can_invert for IOR and Thumb2, Add comments. + Don't invert remainder for IOR. + +2009-05-19 Zdenek Dvorak <ook@ucw.cz> + + PR tree-optimization/40087 + * tree-ssa-loop-niter.c (number_of_iterations_ne_max, + number_of_iterations_ne): Rename never_infinite argument. + (number_of_iterations_lt_to_ne, number_of_iterations_lt, + number_of_iterations_le): Handle pointer-type ivs when + exit_must_be_taken is false. + (number_of_iterations_cond): Do not always assume that + exit_must_be_taken if the control variable is a pointer. + +2009-05-19 Andrew Pinski <andrew_pinski@playstation.sony.com> + + * c-typeck.c (build_binary_op): Allow % on integal vectors. + * doc/extend.texi (Vector Extension): Document that % is allowed too. + +2009-05-19 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (ix86_avoid_jump_mispredicts): Check + ASM_OUTPUT_MAX_SKIP_PAD instead of ASM_OUTPUT_MAX_SKIP_ALIGN. + +2009-05-19 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR c/40172 + * c.opt (Wlogical-op): Disabled by default. + * c-opt (c_common_post_options): Do not enable Wlogical-op with + Wextra. + * doc/invoke.texi (Wlogical-op): Likewise. + +2009-05-19 Eric Botcazou <ebotcazou@adacore.com> + + * tree-scalar-evolution.c (follow_ssa_edge_expr) <NOP_EXPR>: Turn + into CASE_CONVERT. + <PLUS_EXPR>: Strip useless type conversions instead of type nops. + Propagate the type of the first operand. + <ASSERT_EXPR>: Simplify. + (follow_ssa_edge_in_rhs): Use gimple_expr_type to get the type. + Rewrite using the RHS code as discriminant. + <NOP_EXPR>: Turn into CASE_CONVERT. + <PLUS_EXPR>: Propagate the type of the first operand. + +2009-05-19 Steve Ellcey <sje@cup.hp.com> + + * config/ia64/ia64-protos.h (ia64_dconst_0_5): New. + (ia64_dconst_0_375): New. + * config/ia64/ia64.c (ia64_override_options): Remove + -minline-sqrt-min-latency warning. + (ia64_dconst_0_5_rtx, ia64_dconst_0_5): New. + (ia64_dconst_0_375_rtx, ia64_dconst_0_375): New + * config/ia64/ia64.md (*sqrt_approx): Remove. + (sqrtsf2): Remove #if 0. + (sqrtsf2_internal_thr): Rewrite and move to div.md. + (sqrtdf): Remove assert. + (sqrtdf2_internal_thr): Rewrite and move to div.md. + (sqrtxf2): Remove #if 0. + (sqrtxf2_internal_thr): Rewrite and move to div.md. + * div.md (sqrt_approx_rf): New. + (sqrtsf2_internal_thr): New implementation. + (sqrtsf2_internal_lat): New. + (sqrtdf2_internal_thr: New implementation. + (sqrtxf2_internal): New implementation. + +2009-05-19 Francois-Xavier Coudert <fxcoudert@gmail.com> + Hans-Peter Nilsson <hp@axis.com> + + * defaults.h (UINT_FAST64_TYPE, INTPTR_TYPE, UINTPTR_TYPE) + (WCHAR_TYPE, MODIFIED_WCHAR_TYPE, PTRDIFF_TYPE, WINT_TYPE) + (INTMAX_TYPE, UINTMAX_TYPE, SIG_ATOMIC_TYPE, INT8_TYPE, INT16_TYPE) + (INT32_TYPE, INT64_TYPE, UINT8_TYPE, UINT16_TYPE, UINT32_TYPE) + (UINT64_TYPE, INT_LEAST8_TYPE, INT_LEAST16_TYPE, INT_LEAST32_TYPE) + (INT_LEAST64_TYPE, UINT_LEAST8_TYPE, UINT_LEAST16_TYPE) + (UINT_LEAST32_TYPE, UINT_LEAST64_TYPE, INT_FAST8_TYPE) + (INT_FAST16_TYPE, INT_FAST32_TYPE, INT_FAST64_TYPE) + (UINT_FAST8_TYPE, UINT_FAST16_TYPE, UINT_FAST32_TYPE) + (SIZE_TYPE, PID_TYPE, CHAR16_TYPE, CHAR32_TYPE): Move defaults here... + * c-common.c: ...from here. + +2009-05-19 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * c-common.c (warn_logical_operator): Remove unnecessary conditionals. + +2009-05-19 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * builtins.c (do_mpc_arg1): Separate MPFR/MPC C rounding types. + +2009-05-19 Ben Elliston <bje@au.ibm.com> + + * unwind-dw2-fde.c (fde_unencoded_compare): Replace type punning + assignments with memcpy calls. + (add_fdes): Likewise. + (binary_search_unencoded_fdes): Likewise. + (linear_search_fdes): Eliminate type puns. + +2009-05-19 Richard Guenther <rguenther@suse.de> + + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Do + not falsely claim to have propagated into all uses. + +2009-05-19 Ben Elliston <bje@au.ibm.com> + + * doc/invoke.texi (C Dialect Options): Update OpenMP specification + version to v3.0. + +2009-05-18 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh-protos.h (sh_legitimate_address_p): Remove. + * config/sh/sh.c (sh_legitimate_address_p): Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + * config/sh/sh.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/sh/sh.md: Clean up references to GO_IF_LEGITIMATE_ADDRESS. + +2009-05-18 Dodji Seketeli <dodji@redhat.com> + + PR debug/40109 + * dwarf2out.c (gen_type_die_with_usage): Generate the DIE as a + child of the containing namespace's DIE. + +2009-05-18 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (*zero_extend<GPR:mode>_trunc<SHORT:mode>, + *zero_extendhi_truncqi): Move after the zero_extend patterns. + (*extenddi_truncate<mode>, *extendsi_truncate<mode>): Move after the + extend patterns. + +2009-05-18 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39942 + * config/i386/i386.c (ix86_avoid_jump_misspredicts): Replace + gen_align with gen_pad. + (ix86_reorg): Check ASM_OUTPUT_MAX_SKIP_PAD instead of + #ifdef ASM_OUTPUT_MAX_SKIP_ALIGN. + + * config/i386/i386.h (ASM_OUTPUT_MAX_SKIP_PAD): New. + * config/i386/x86-64.h (ASM_OUTPUT_MAX_SKIP_PAD): Likewise. + + * config/i386/i386.md (align): Renamed to ... + (pad): This. Replace ASM_OUTPUT_MAX_SKIP_ALIGN with + ASM_OUTPUT_MAX_SKIP_PAD. + +2009-05-18 Andreas Schwab <schwab@linux-m68k.org> + + * config.gcc: Fix variable syntax. + + PR target/39531 + * config/m68k/m68k.c (output_andsi3): Mask off sign bit copies + before calling exact_log2. + (output_iorsi3): Likewise. + (output_xorsi3): Likewise. + +2009-05-18 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (expand_cbranchdi4): Use a scratch register + for the none zero constant operand except for EQ and NE + comprisons even when the first operand is R0. + +2009-05-18 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/2064.md: Remove trailing whitespaces. + * config/s390/2084.md: Likewise. + * config/s390/constraints.md: Likewise. + * config/s390/fixdfdi.h: Likewise. + * config/s390/libgcc-glibc.ver: Likewise. + * config/s390/s390-modes.def: Likewise. + * config/s390/s390-protos.h: Likewise. + * config/s390/s390.c: Likewise. + * config/s390/s390.h: Likewise. + * config/s390/s390.md: Likewise. + * config/s390/tpf-unwind.h: Likewise. + +2009-05-18 Maxim Kuvyrkov <maxim@codesourcery.com> + + * config/m68k/m68k.c (m68k_legitimize_address): Fix typo in signature. + +2009-05-18 Maxim Kuvyrkov <maxim@codesourcery.com> + + M68K TLS support. + * configure.ac (m68k-*-*): Check if binutils support TLS. + * configure: Regenerate. + * config/m68k/predicates.md (symbolic_operand): Extend comment. + * config/m68k/constraints.md (Cu): New constraint. + * config/m68k/m68k.md (UNSPEC_GOTOFF): Remove. + (UNSPEC_RELOC16, UNSPEC_RELOC32): New constants. + (movsi): Handle TLS symbols. + (addsi3_5200): Handle XTLS symbols, indent. + * config/m68k/m68k-protos.h (m68k_legitimize_tls_address): Declare. + (m68k_tls_reference_p): Declare. + (m68k_legitimize_address): Declare. + (m68k_unwrap_symbol): Declare. + * config/m68k/m68k.opt (mxtls): New option. + * config/m68k/m68k.c (ggc.h): Include. + (m68k_output_dwarf_dtprel): Implement hook. + (TARGET_HAVE_TLS, TARGET_ASM_OUTPUT_DWARF_DTPREL): Define. + (m68k_expand_prologue): Load GOT pointer when function needs it. + (m68k_illegitimate_symbolic_constant_p): Handle TLS symbols. + (m68k_legitimate_constant_address_p): Same. + (m68k_decompose_address): Handle TLS references. + (m68k_get_gp): New static function. + (enum m68k_reloc): New contants. + (TLS_RELOC_P): New macro. + (m68k_wrap_symbol): New static function. + (m68k_unwrap_symbol): New function. + (m68k_final_prescan_insn_1): New static function. + (m68k_final_prescan_insn): New function. + (m68k_move_to_reg, m68k_wrap_symbol_into_got_ref): New static + functions. + (legitimize_pic_address): Handle TLS references.. + (m68k_tls_get_addr, m68k_get_tls_get_addr) + (m68k_libcall_value_in_a0_p) + (m68k_call_tls_get_addr, m68k_read_tp, m68k_get_m68k_read_tp) + (m68k_call_m68k_read_tp): Helper variables and functions for ... + (m68k_legitimize_tls_address): Handle TLS references. + (m68k_tls_symbol_p, m68k_tls_reference_p_1, m68k_tls_reference_p): + New functions. + (m68k_legitimize_address): Handle TLS symbols. + (m68k_get_reloc_decoration): New static function. + (m68k_output_addr_const_extra): Handle UNSPEC_RELOC16 and + UNSPEC_RELOC32. + (m68k_output_dwarf_dtprel): Implement hook. + (print_operand_address): Handle UNSPEC_RELOC16 adn UNSPEC_RELOC32. + (m68k_libcall_value): Return result in A0 instead of D0 when asked by + m68k_call_* routines. + (sched_attr_op_type): Handle TLS symbols. + (gt-m68k.h): Include. + * config/m68k/m68k.h (FINAL_PRESCAN_INSN): Define. + (LEGITIMATE_PIC_OPERAND_P): Support TLS. + +2009-05-18 Martin Jambor <mjambor@suse.cz> + + * ipa-prop.c (ipa_check_stmt_modifications): Removed. + (visit_store_addr_for_mod_analysis): New function. + (ipa_detect_param_modifications): Use walk_stmt_load_store_addr_ops. + (determine_cst_member_ptr): Use gimple_assign_single_p. + (ipa_get_stmt_member_ptr_load_param): Use gimple_assign_single_p. + (ipa_analyze_call_uses): Use !gimple_assign_rhs2 rather than number of + operands. Don't check number of operands of a NOP_EXPR. + +2009-05-18 Eric Fisher <joefoxreal@gmail.com> + + * doc/tree-ssa.texi (SSA Operands): Fix a mistake. + +2009-05-17 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR c/40172 + * c-common.c (warn_logical_operator): Don't warn if one of + expression isn't always true or false. + +2009-05-17 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/biarch32.h: New file. + * config.gcc: Add for target i386-w64-* the biarch32.h to tm_file. + +2009-05-17 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (*zero_extend<mode>_trunchi, + *zero_extend<mode>_truncqi): Merge these into ... + (*zero_extend<GPR:mode>_trunc<SHORT:mode>): ... this new pattern. + Name the pattern following this as *zero_extendhi_truncqi. + +2009-05-16 Brad Lucier <lucier@math.purdue.edu> + + PR middle-end/39301 + * hwint.h: Add macro HOST_WIDEST_INT_PRINT. + * bitmap.c (bitmap_descriptor): Make fields HOST_WIDEST_INT. + (output_info): Make field HOST_WIDEST_INT. + (print_statistics): Use HOST_WIDEST_INT_PRINT. + (dump_bitmat_statistics): Same. + +2009-05-16 Francois-Xavier Coudert <fxcoudert@gmail.com> + + * config.gcc (use_gcc_stdint): Set to wrap. + * config/darwin.h (SIG_ATOMIC_TYPE, INT8_TYPE, INT16_TYPE, + INT32_TYPE, INT64_TYPE, UINT8_TYPE, UINT16_TYPE, UINT32_TYPE, + UINT64_TYPE, INT_LEAST8_TYPE, INT_LEAST16_TYPE, INT_LEAST32_TYPE, + INT_LEAST64_TYPE, UINT_LEAST8_TYPE, UINT_LEAST16_TYPE, + UINT_LEAST32_TYPE, UINT_LEAST64_TYPE, INT_FAST8_TYPE, + INT_FAST16_TYPE, INT_FAST32_TYPE, INT_FAST64_TYPE, + UINT_FAST8_TYPE, UINT_FAST16_TYPE, UINT_FAST32_TYPE, + UINT_FAST64_TYPE, INTPTR_TYPE, UINTPTR_TYPE): Define. + +2009-05-16 Joseph Myers <joseph@codesourcery.com> + + * config.gcc (mips*-*-*): Support arch_32, arch_64, tune_32 and + tune_64. + * config/mips/mips.h (MIPS_ABI_DEFAULT, MULTILIB_ABI_DEFAULT): + Move definitions earlier. + (OPT_ARCH64, OPT_ARCH32): Define. + (OPTION_DEFAULT_SPECS): Add entries for arch_32, arch_64, tune_32 + and tune_64. + +2009-05-16 Richard Earnshaw <rearnsha@arm.com> + + PR target/40153 + * arm.md (cstoresi_nltu_thumb1): Use a neg of ltu as the pattern name + implies. + +2009-05-16 Richard Earnshaw <rearnsha@arm.com> + + * arm.md (movdi2): Copy non-reg values to DImode registers. + +2009-05-16 Jakub Jelinek <jakub@redhat.com> + + PR target/39942 + * final.c (label_to_max_skip): New function. + (label_to_alignment): Only use LABEL_TO_ALIGNMENT if + CODE_LABEL_NUMBER <= max_labelno. + * output.h (label_to_max_skip): New prototype. + * config/i386/i386.c (ix86_avoid_jump_misspredicts): Renamed to... + (ix86_avoid_jump_mispredicts): ... this. Don't define if + ASM_OUTPUT_MAX_SKIP_ALIGN isn't defined. Update comment. + Handle CODE_LABELs with >= 16 byte alignment or with + max_skip == (1 << align) - 1. + (ix86_reorg): Don't call ix86_avoid_jump_mispredicts if + ASM_OUTPUT_MAX_SKIP_ALIGN isn't defined. + + PR target/39942 + * config/i386/x86-64.h (ASM_OUTPUT_MAX_SKIP_ALIGN): Don't emit second + .p2align 3 if MAX_SKIP is smaller than 7. + * config/i386/linux.h (ASM_OUTPUT_MAX_SKIP_ALIGN): Likewise. + +2009-05-15 Ian Lance Taylor <iant@google.com> + + * alias.c (struct alias_set_entry_d): Rename from struct + alias_set_entry. Change all uses. + * except.c (struct call_site_record_d): Rename from struct + call_site_record. Change all uses. + * except.h (struct eh_region_d): Rename from struct eh_region. + Change all uses. + * gcse.c (struct hash_table_d): Rename from struct hash_table. + Change all uses. + * graphite.c (struct ivtype_map_elt_d): Rename fromstruct + ivtype_map_elt. Change all uses. + (struct rename_map_elt_d): Rename fromstruct rename_map_elt. + Change all uses. + (struct ifsese_d): Rename fromstruct ifsese. Change all uses. + * graphite.h (struct name_tree_d): Rename from struct name_tree. + Change all uses. + (struct sese_d): Rename from struct sese. Change all uses. + * omega.h (struct eqn_d): Rename from struct eqn. Change all uses. + (struct omega_pb_d): Rename from struct omega_pb. Change all uses. + * optabs.h (struct optab_d): Rename from struct optab. Change all + uses. + (struct convert_optab_d): Rename from struct convert_optab. + Change all uses. + * tree-pass.h (struct ipa_opt_pass_d): Rename fromstruct + ipa_opt_pass. Change all uses. + * tree-predcom.c (struct dref_d): Rename from struct dref. Change + all uses. + + * c-decl.c (pushtag): If -Wc++-compat, warn if the tag is already + defined as a typedef. + (grokdeclarator): If -Wc++-compat, warn if a typedef is already + defined as a tag. + +2009-05-15 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR 16302 + * fold-const.c (make_range,build_range_check,merge_ranges): Move + declaration to... + (merge_ranges): Returns bool. + * tree.h (make_range): .. to here. + (build_range_check): Likewise. + (merge_ranges): Likewise. Renamed from merge_ranges. + * c-typeck.c (parser_build_binary_op): Update calls to + warn_logical_operator. + * c-common.c (warn_logical_operator): Add new warning. + * c-common.h (warn_logical_operator): Update declaration. + +2009-05-15 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * ira-conflicts.c (add_insn_allocno_copies): Fix wrong conditional. + +2009-05-15 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * doc/install.texi: Document MPC requirements, flags etc. + + * builtins.c (do_mpc_arg1, fold_builtin_ccos): New. + (fold_builtin_cexp): Ensure we get a complex REAL_TYPE. + Evaluate constant arguments. + (fold_builtin_carg): Ensure we get a complex REAL_TYPE. + (fold_builtin_1): Likewise, also evaluate constant arguments. + Remove superfluous break. + (do_mpc_ckconv): New. + * real.h: Include mpc.h. + * toplev.c (print_version): Output MPC version info if available. + +2009-05-15 Sandra Loosemore <sandra@codesourcery.com> + + * fold-const.c (fold_convert_const_real_from_real): Check for overflow. + +2009-05-15 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (ix86_reorg): Call optimize_function_for_speed_p + only once. + +2009-05-15 Jan Hubicka <jh@suse.cz> + + * doc/invoke.texi (max-early-inliner-iterations): New flag. + * ipa-inline.c (enum inlining_mode): New INLINE_SIZE_NORECURSIVE. + (try_inline): Fix return value. + (cgraph_decide_inlining_incrementally): Honor new value. + (cgraph_early_inlining): Handle indirect inlining. + * params.def (PARAM_EARLY_INLINER_MAX_ITERATIONS): New. + +2009-05-15 Jan Hubicka <jh@suse.cz> + + * cgraph.h (struct cgraph_node): Add finalized_by_frotnend flag. + * cgraphunit.c (cgraph_finalize_function): Set it. + (cgraph_expand_function): Use it. + +2009-05-15 Sandra Loosemore <sandra@codesourcery.com> + + * real.c (encode_ieee_half): Define. + (decode_ieee_half): Define. + (ieee_half_format): Define. + (arm_half_format): Define. + * real.h (ieee_half_format): Declare. + (arm_half_format): Declare. + +2009-05-15 Sandra Loosemore <sandra@codesourcery.com> + + * optabs.c (prepare_float_lib_cmp): Test that the comparison, + swapped, and reversed optabs exist before trying to use them. + +2009-05-15 Paul Brook <paul@codesourcery.com> + Sandra Loosemore <sandra@codesourcery.com> + + * config/arm/arm.c (neon_vector_mem_operand): Handle element/structure + loads. Allow PRE_DEC. + (output_move_neon): Handle PRE_DEC. + (arm_print_operand): Add 'A' for neon structure loads. + * config/arm/arm-protos.h (neon_vector_mem_operand): Update prototype. + * config/arm/neon.md (neon_mov): Update comment. + * config/arm/constraints.md (Un, Us): Update neon_vector_mem_operand + calls. + (Um): New constraint. + +2009-05-15 Jan Hubicka <jh@suse.cz> + + Revert the following patch until testsuite fallout is fixed: + * cgraph.c (dump_cgraph_node): Dump size/time/benefit. + * cgraph.h (struct inline_summary): New filed self_wize, + size_inlining_benefit, self_time and time_inlining_benefit. + (struct cgraph_global_info): Replace insns by time ans size fields. + * ipa-cp (ipcp_cloning_candidate_p): Base estimate on size + (ipcp_estimate_growth, ipcp_insert_stage): Likewise. + (ipcp_update_callgraph): Do not touch function bodies. + * ipa-inline.c: Include except.h + (MAX_TIME): New constant. + (overall_insns): Remove + (overall_size, max_benefit): New static variables. + (cgraph_estimate_time_after_inlining): New function. + (cgraph_estimate_size_after_inlining): Rewrite using benefits. + (cgraph_clone_inlined_nodes): Update size. + (cgraph_mark_inline_edge): Update size. + (cgraph_estimate_growth): Use size info. + (cgraph_check_inline_limits): Check size. + (cgraph_default_inline_p): Likewise. + (cgraph_edge_badness): Compute badness based on benefit and size cost. + (cgraph_decide_recursive_inlining): Check size. + (cgraph_decide_inlining_of_small_function): Update size; dump sizes + and times. + (cgraph_decide_inlining): Likewise. + (cgraph_decide_inlining_incrementally): Likewise; honor + PARAM_EARLY_INLINING_INSNS. + (likely_eliminated_by_inlining_p): New predicate. + (estimate_function_body_sizes): New function. + (compute_inline_parameters): Use it. + * except.c (must_not_throw_labels): New function. + * except.h (must_not_throw_labels): Declare. + * tree-inline.c (init_inline_once): Kill inlining_weigths + * tree-ssa-structalias.c: Avoid uninitialized warning. + * params.def (PARAM_MAX_INLINE_INSNS_SINGLE): Reduce to 300. + (PARAM_MAX_INLINE_INSNS_AUTO): Reduce to 60. + (PARAM_INLINE_CALL_COST): Remove. + (PARAM_EARLY_INLINING_INSNS): New. + +2009-05-15 Richard Guenther <rguenther@suse.de> + + * tree-ssa-pre.c (eliminate): Use TODO_update_ssa_only_virtuals, + not TODO_update_ssa. + +2009-05-15 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39999 + * gimple.h (gimple_expr_type): Use the expression type looking + through useless conversions. + * tree-ssa-sccvn.c (vn_nary_op_lookup_stmt): Use gimple_expr_type. + (vn_nary_op_insert_stmt): Likewise. + (simplify_binary_expression): Likewise. + +2009-05-15 Richard Guenther <rguenther@suse.de> + + * common.opt (-ftree-forwprop, -ftree-phiprop, -ftree-pta): + New options, enabled by default. + * doc/invoke.texi (-ftree-forwprop, -ftree-phiprop, -ftree-pta): + Document. + * tree-ssa-forwprop.c (gate_forwprop): Use flag_tree_forwprop. + * tree-ssa-phiprop.c (gate_phiprop): Use flag_tree_phiprop. + * tree-ssa-structalias.c (gate_tree_pta): New function. + (pass_build_alias): Use it. + +2009-05-15 Joseph Myers <joseph@codesourcery.com> + + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Also + recurse on an invariant address if a conversion from a pointer + type to a wider integer type is involved. + +2009-05-15 Jan Hubicka <jh@suse.cz> + + * cgraph.c (dump_cgraph_node): Dump size/time/benefit. + * cgraph.h (struct inline_summary): New filed self_wize, + size_inlining_benefit, self_time and time_inlining_benefit. + (struct cgraph_global_info): Replace insns by time ans size fields. + * ipa-cp (ipcp_cloning_candidate_p): Base estimate on size + (ipcp_estimate_growth, ipcp_insert_stage): Likewise. + (ipcp_update_callgraph): Do not touch function bodies. + * ipa-inline.c: Include except.h + (MAX_TIME): New constant. + (overall_insns): Remove + (overall_size, max_benefit): New static variables. + (cgraph_estimate_time_after_inlining): New function. + (cgraph_estimate_size_after_inlining): Rewrite using benefits. + (cgraph_clone_inlined_nodes): Update size. + (cgraph_mark_inline_edge): Update size. + (cgraph_estimate_growth): Use size info. + (cgraph_check_inline_limits): Check size. + (cgraph_default_inline_p): Likewise. + (cgraph_edge_badness): Compute badness based on benefit and size cost. + (cgraph_decide_recursive_inlining): Check size. + (cgraph_decide_inlining_of_small_function): Update size; dump sizes + and times. + (cgraph_decide_inlining): Likewise. + (cgraph_decide_inlining_incrementally): Likewise; honor + PARAM_EARLY_INLINING_INSNS. + (likely_eliminated_by_inlining_p): New predicate. + (estimate_function_body_sizes): New function. + (compute_inline_parameters): Use it. + * except.c (must_not_throw_labels): New function. + * except.h (must_not_throw_labels): Declare. + * tree-inline.c (init_inline_once): Kill inlining_weigths + * tree-ssa-structalias.c: Avoid uninitialized warning. + * params.def (PARAM_MAX_INLINE_INSNS_SINGLE): Reduce to 300. + (PARAM_MAX_INLINE_INSNS_AUTO): Reduce to 60. + (PARAM_INLINE_CALL_COST): Remove. + (PARAM_EARLY_INLINING_INSNS): New. + doc/invoke.texi (max-inline-insns-auto, early-inlining-insns): Update. + (inline-call-cost): Remove. + (early-inlining-insns): New. + +2009-05-15 Eric Botcazou <ebotcazou@adacore.com> + + * dbxout.c (dbxout_range_type): Add LOW and HIGH parameters. Use them + for bounds. + (print_int_cst_bounds_in_octal_p): Likewise. + (dbxout_type): Adjust calls to above functions. Be prepared to deal + with subtypes. + * dwarf2out.c (base_type_die): Likewise. + (is_subrange_type): Delete. + (subrange_type_die): Add LOW and HIGH parameters. Use them for bounds. + (modified_type_die): Call subrange_type_for_debug_p on subtypes. + * fold-const.c (fold_truth_not_expr) <CONVERT_EXPR>: Do not strip it + if the destination type is boolean. + (build_range_check): Do not special-case subtypes. + (fold_sign_changed_comparison): Likewise. + (fold_unary): Likewise. + * langhooks-def.h (LANG_HOOKS_GET_SUBRANGE_BOUNDS): Define. + (LANG_HOOKS_FOR_TYPES_INITIALIZER): Add LANG_HOOKS_GET_SUBRANGE_BOUNDS. + * langhooks.h (lang_hooks_for_types): Add get_subrange_bounds. + * tree.c (subrange_type_for_debug_p): New predicate based on the + former is_subrange_type. + * tree.h (subrange_type_for_debug_p): Declare. + * tree-chrec.c (avoid_arithmetics_in_type_p): Delete. + (convert_affine_scev): Remove call to above function. + (chrec_convert_aggressive): Likewise. + * tree-ssa.c (useless_type_conversion_p_1): Do not specifically return + false for conversions involving subtypes. + * tree-vrp.c (vrp_val_max): Do not special-case subtypes. + (vrp_val_min): Likewise. + (needs_overflow_infinity): Likewise. + (extract_range_from_unary_expr): Likewise. + +2009-05-15 Paolo Bonzini <bonzini@gnu.org> + + * config/frv/frv.h: Clean up references to GO_IF_LEGITIMATE_ADDRESS. + * config/frv/frv.c: Likewise. + * config/s390/s390.c: Likewise. + * config/sparc/sparc.h: Likewise. + * config/i386/i386.h: Likewise. + * config/i386/i386.c: Likewise. + * config/crx/crx.c: Likewise. + * config/m68hc11/m68hc11.h: Likewise. + * config/iq2000/iq2000.c: Likewise. + * config/mn10300/mn10300.h: Likewise. + * config/mn10300/mn10300.c: Likewise. + * config/m68k/m68k.c: Likewise. + * config/rs6000/rs6000.c: Likewise. + * config/rs6000/xcoff.h: Likewise. + * config/rs6000/linux64.h: Likewise. + * config/rs6000/sysv4.h: Likewise. + * config/score/score3.c: Likewise. + * config/score/score7.c: Likewise. + * config/score/score.c: Likewise. + * config/arm/arm.md: Likewise. + * config/mips/mips.c: Likewise. + * config/mips/mips.md: Likewise. + * config/bfin/bfin.h: Likewise. + * config/pa/pa.c: Likewise. + * config/pa/constraints.md: Likewise. + + * config/pdp11/pdp11-protos.h (legitimate_address_p): Delete. + * config/pdp11/pdp11.c (legitimate_address_p): Delete. + * config/pdp11/pdp11.h: Use memory_address_p instead. + +2009-05-14 Ian Lance Taylor <iant@google.com> + + * passes.c (finish_optimization_passes): Change i to int. + * plugin.c (plugins_active_p): Change event to int. + (dump_active_plugins): Likewise. + * reginfo.c (invalid_mode_change_p): Change to to unsigned int. + Add cast. + * tree.c (tree_range_check_failed): Change c to unsigned int. + (omp_clause_range_check_failed): Likewise. + (build_common_builtin_nodes): Change mode to int. Add cast. + * config/ia64/ia64.c (is_emitted): Change r to unsigned int. + (ia64_hard_regno_rename_ok, ia64_eh_uses): Likewise. + + * c-typeck.c (build_unary_op): If -Wc++-compat, warn about using + ++ or -- with a variable of enum type. + +2009-05-14 Steven Bosscher <steven@gcc.gnu.org> + + PR driver/40144 + * opts.c (common_handle_option): Add OPT_fcse_skip_blocks as a no-op. + +2009-05-14 Steven Bosscher <steven@gcc.gnu.org> + + * store-motion.c: Do not include params.h + * Makefile.in: Fix dependencies for various files. + +2009-05-14 Steven Bosscher <steven@gcc.gnu.org> + + * auto-inc-dec.c: Fix pass description, remove apparent + accidental duplication. + +2009-05-14 H.J. Lu <hongjiu.lu@intel.com> + + PR middle-end/40147 + * ipa-utils.h (memory_identifier_string): Moved to ... + * tree.h (memory_identifier_string): Here. Add GTY(()). + +2009-05-14 Paolo Bonzini <bonzini@gnu.org> + + * doc/tm.texi (TARGET_LEGITIMATE_ADDRESS_P): Refer mainly to this + in the former documentation of... + (GO_IF_LEGITIMATE_ADDRESS): ... this. + * ira-conflicts.c (get_dup_num): Use address_operand. + * targhooks.c (default_legitimate_address_p): New. + * targhooks.h (default_legitimate_address_p): New. + * reload.c (strict_memory_address_p) [!GO_IF_LEGITIMATE_ADDRESS]: + Call hook. + * recog.c (memory_address_p) [!GO_IF_LEGITIMATE_ADDRESS]: Call hook. + * target.h (struct target): Add legitimate_address_p. + * target-def.h (TARGET_LEGITIMATE_ADDRESS_P): New. + (TARGET_INITIALIZER): Include it. + + * config/alpha/alpha.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/alpha/alpha-protos.h (alpha_legitimate_address_p): Remove. + * config/alpha/alpha.c (alpha_legitimate_address_p): Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/frv/frv.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + (REG_OK_STRICT_P): Delete. + * config/frv/frv-protos.h (frv_legitimate_address_p): Rename to... + (frv_legitimate_address_p_1): ... this. + * config/frv/frv.c (frv_legitimate_address_p): Forward to... + (frv_legitimate_address_p_1): ... the renamed old + frv_legitimate_address_p. + * config/frv/predicates.md: Adjust calls to frv_legitimate_address_p. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/s390/s390.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/s390/s390-protos.h (legitimate_address_p): Remove. + * config/s390/s390.c (legitimate_address_p): Rename to... + (s390_legitimate_address_p): ... this, make static. + (legitimize_address): Adjust call. + (TARGET_LEGITIMATE_ADDRESS_P): New. + * config/s390/constraints.md ("e"): Call strict_memory_address_p. + + * config/m32c/m32c.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/m32c/m32c-protos.h (m32c_legitimate_address_p): Remove. + * config/m32c/m32c.c (m32c_legitimate_address_p): Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/spu/spu.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/spu/spu-protos.h (spu_legitimate_address): Remove. + * config/spu/spu.c (spu_legitimate_address): Rename to... + (spu_legitimate_address_p): ... this, make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/sparc/sparc.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/sparc/sparc-protos.h (legitimate_address_p): Remove. + * config/sparc/sparc.c (legitimate_address_p): Rename to... + (sparc_legitimate_address_p): ... this, make static and return bool. + (legitimize_address): Adjust call. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/i386/i386.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/i386/i386-protos.h (legitimate_address_p): Remove. + * config/i386/i386.c (legitimate_address_p): Rename to... + (ix86_legitimate_address_p): ... this, make static. + (constant_address_p): Move after it, adjust call. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/avr/avr.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/avr/avr-protos.h (legitimate_address_p): Remove. + * config/avr/avr.c (legitimate_address_p): Rename to... + (avr_legitimate_address_p): ... this, make static. + (legitimize_address): Adjust call. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/crx/crx.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/crx/crx-protos.h (crx_legitimate_address_p): Remove. + * config/crx/crx.c (crx_legitimate_address_p): Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/xtensa/xtensa.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/xtensa/xtensa-protos.h (xtensa_legitimate_address_p): Remove. + * config/xtensa/xtensa.c (xtensa_legitimate_address_p): Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/stormy16/stormy16.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/stormy16/stormy16-protos.h (xstormy16_legitimate_address_p): + Remove. + * config/stormy16/stormy16.c (xstormy16_legitimate_address_p): + Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/m68hc11/m68hc11.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/m68hc11/m68hc11-protos.h (m68hc11_go_if_legitimate_address): + Remove. + * config/m68hc11/m68hc11.c (m68hc11_go_if_legitimate_address): + Rename to... + (m68hc11_legitimate_address_p): ... this, make static. + (go_if_legitimate_address_internal): Rename to... + (m68hc11_legitimate_address_p_1): ... this. + (legitimize_address): Adjust call. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/iq2000/iq2000.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/iq2000/iq2000-protos.h (iq2000_legitimate_address_p): Remove. + * config/iq2000/iq2000.c (iq2000_legitimate_address_p): Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/mn10300/mn10300.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/mn10300/mn10300-protos.h (legitimate_address_p): Remove. + * config/mn10300/mn10300.c (legitimate_address_p): Rename to... + (mn10300_legitimate_address_p): ... this, make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/m68k/m68k.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/m68k/m68k-protos.h (m68k_legitimate_address_p): Remove. + * config/m68k/m68k.c (m68k_legitimate_address_p): Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/rs6000/rs6000.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + (REG_OK_STRICT_FLAG, REG_OK_FOR_BASE_P, REG_OK_FOR_INDEX_P): Delete. + (INT_REG_OK_FOR_BASE_P, INT_REG_OK_FOR_INDEX_P): Move above. + * config/rs6000/rs6000.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/rs6000/rs6000-protos.h (rs6000_legitimate_address): Remove. + * config/rs6000/rs6000.c (rs6000_legitimate_address): Rename to... + (rs6000_legitimate_address_p): ... this, make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + (REG_MODE_OK_FOR_BASE_P): Delete. + (rs6000_legitimize_reload_address): Use INT_REG_OK_FOR_BASE_P. + + * config/picochip/picochip.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/picochip/picochip-protos.h (picochip_legitimate_address_p): + Delete. + * config/picochip/picochip.c (picochip_legitimate_address_p): Make + static, adjust types. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/score/score.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/score/score.c (score_address_p): Rename to... + (score_legitimate_address_p): ... this. + (TARGET_LEGITIMATE_ADDRESS_P): New. + * config/score/score3.c (score3_address_p): Rename to... + (score3_legitimate_address_p): ... this. + * config/score/score7.c (score7_address_p): Rename to... + (score7_legitimate_address_p): ... this. + + * config/arm/arm.h (ARM_GO_IF_LEGITIMATE_ADDRESS, + THUMB2_GO_IF_LEGITIMATE_ADDRESS, THUMB1_GO_IF_LEGITIMATE_ADDRESS, + GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/arm/arm-protos.h (thumb1_legitimate_address_p, + thumb2_legitimate_address_p): Delete. + (arm_legitimate_address_p): Rename to... + (arm_legitimate_address_outer_p): ... this. + * config/arm/constraints.md ("Uq"): Adjust call. + * config/arm/predicates.md (arm_extendqisi_mem_op): Likewise. + * config/arm/arm.c (arm_legitimate_address_p): New, rename old one + to... + (arm_legitimate_address_outer_p): ... this. + (thumb1_legitimate_address_p, thumb2_legitimate_address_p): Make + static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/mips/mips.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/mips/mips-protos.h (mips_legitimate_address_p): Remove. + * config/mips/mips.c (mips_legitimate_address_p): ... Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/vax/vax.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/vax/vax-protos.h (legitimate_address_p): Remove. + * config/vax/vax.c (legitimate_address_p): Rename to... + (vax_legitimate_address_p): ... this, make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/h8300/h8300.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/h8300/h8300-protos.h (h8300_legitimate_address_p): Remove. + * config/h8300/h8300.c (h8300_legitimate_address_p): ... Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/mmix/mmix.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/mmix/mmix-protos.h (mmix_legitimize_address): Remove. + * config/mmix/mmix.c (mmix_legitimate_address): Rename to... + (mmix_legitimate_address_p): ... this, make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + + * config/bfin/bfin.h (GO_IF_LEGITIMATE_ADDRESS): Delete. + * config/bfin/bfin-protos.h (bfin_legitimate_address_p): Remove. + * config/bfin/bfin.c (bfin_legitimate_address_p): ... Make static. + (TARGET_LEGITIMATE_ADDRESS_P): New. + +2009-05-14 Paolo Bonzini <bonzini@gnu.org> + + * config/arm/arm.h (PROMOTE_FUNCTION_MODE): Remove handling + of MODE_COMPLEX_INT. + +2009-05-14 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE> + + * config/alpha/alpha.c (alpha_initialize_trampoline): Change 0 to + LCT_NORMAL in function call. + * mips-tdump.c (print_file_desc): Add cast to enum type. + * mips-tfile.c (add_ext_symbol): Add casts to enum types. + (mark_stabs): Add casts to enum types. + (parse_stabs_common): Add casts to enum types. + +2009-05-13 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.c (mips_print_operand) <REG, MEM, default>: + Check for invalid values of LETTER. + +2009-05-13 Taras Glek <tglek@mozilla.com> + + * attribs.c (register_attribute): moved out attribute registration + into register_attribute. + * doc/plugins.texi: Documented register_attribute and + PLUGIN_ATTRIBUTES. + * gcc-plugin.h: Added forward decl for register_attribute. + * gcc-plugin.h (plugins_event): Added PLUGIN_ATTRIBUTES. + * plugin.c (register_callback, invoke_plugin_callbacks): Added + PLUGIN_ATTRIBUTES boilerplate. + +2009-05-14 Dave Korn <dave.korn.cygwin@gmail.com> + + * config/i386/msformat-c.c (ms_printf_length_specs): Use enumeration + values even in sentinel and empty entries. + (ms_printf_flag_specs): Likewise. + (ms_scanf_flag_specs): Likewise. + (ms_strftime_flag_specs): Likewise. + (ms_print_char_table): Likewise. + (ms_scan_char_table): Likewise. + (ms_time_char_table): Likewise. + +2009-05-13 Doug Kwan <dougkwan@google.com> + + * tree-ssa-sccvn.c (compare_ops): Stabilize qsort. + +2009-05-13 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.md (store): Add attributes for QI and HI. + Update comment. + (truncdisi2, truncdihi2, truncdiqi2): Merge these into ... + (truncdi<mode>2): ... this new pattern. + +2009-05-13 Brad Hards <bradh@kde.org> + + * Makefile.in (TEXI_GCCINT_FILES): Add plugins.texi. + +2009-05-14 Jakub Jelinek <jakub@redhat.com> + Ben Elliston <bje@au.ibm.com> + + PR middle-end/40035 + * dse.c (check_mem_read_rtx): Guard against width == -1. + +2009-05-13 Michael Matz <matz@suse.de> + + PR middle-end/39976 + * tree-outof-ssa.c (maybe_renumber_stmts_bb): New function. + (trivially_conflicts_p): New function. + (insert_backedge_copies): Use it. + +2009-05-13 Janis Johnson <janis187@us.ibm.com> + + * c-pragma.c (enum pragma_switch_t): Prefix constants with PRAGMA_. + (handle_stdc_pragma): Use new enum constant names. + (handle_pragma_float_const_decimal64): Ditto. + +2009-05-13 Ian Lance Taylor <iant@google.com> + + * Makefile.in (build/gencheck.o): Depend upon all-tree.def, not + tree.def. + +2009-05-13 Nathan Sidwell <nathan@codesourcery.com> + + * config/m68k/t-uclinux (M68K_MLIB_CPU): Check for FL_UCLINUX. + * config/m68k/m68k-devices.def: Add FL_UCLINUX to 68020 and 54455 + multilibs. + * config/m68k/m68k.h (FL_UCLINUX): Define. + +2009-05-13 Jan Hubicka <jh@suse.cz> + + * options.c (gfc_post_options): -fwhole-program imply -fwhole-file. + +2009-05-12 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.h (OVERRIDE_OPTIONS): Clear flag_schedule_insns + unless -fschedule-insns is specified. + +2009-05-12 Kaz Kojima <kkojima@gcc.gnu.org> + + PR target/39561 + * config/sh/sh.h (OPTIMIZATION_OPTIONS): Don't set + TARGET_EXPAND_CBRANCHDI4. + * config/sh/sh.md (cbranchdi4): Don't check TARGET_EXPAND_CBRANCHDI4. + * config/sh/sh.opt (mexpand-cbranchdi): Remove. + (cmpeqdi): Fix comment. + +2009-05-12 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh-protos.h (sh_legitimate_index_p): Declare. + (sh_legitimate_address_p): Likewise. + * config/sh/sh.c (sh_legitimate_index_p): New. + (sh_legitimate_address_p): Likewise. + * config/sh/sh.h (REG_OK_FOR_BASE_P): Add STRICT parameter. + (REG_OK_FOR_INDEX_P, SUBREG_OK_FOR_INDEX_P): Likewise. + (MODE_DISP_OK_4, MODE_DISP_OK_8): Remove. + (MAYBE_BASE_REGISTER_RTX_P): New macro. + (MAYBE_INDEX_REGISTER_RTX_P): Likewise. + (BASE_REGISTER_RTX_P): Use MAYBE_BASE_REGISTER_RTX_P. + (INDEX_REGISTER_RTX_P): Use MAYBE_INDEX_REGISTER_RTX_P. + (GO_IF_LEGITIMATE_INDEX): Use sh_legitimate_index_p. + (GO_IF_LEGITIMATE_ADDRESS): Use sh_legitimate_address_p. + +2009-05-12 Jan Hubicka <jh@suse.cz> + + * tree-inline.c (estimate_operator_cost): Add operands; + when division happens by constant, it is cheap. + (estimate_num_insns): Loads and stores are not having cost of 0; + EH magic stuff is cheap; when computing runtime cost of switch, + use log2 base of amount of its cases; builtin_expect has cost of 0; + compute cost for moving return value of call. + (init_inline_once): Initialize time_based flags. + * tree-inline.h (eni_weights_d): Add time_based flag. + +2009-05-12 Paolo Bonzini <bonzini@gnu.org> + + * df-core.c: Update head documentation. + +2009-05-12 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR bootstrap/40118 + * rs6000.c (rs6000_generate_compare): Use op1b instead of + shadowing exisiting variable op1. + +2009-05-12 Uros Bizjak <ubizjak@gmail.com> + + PR target/37179 + * config/i386/driver-i386.c (processor_signatures): New enum. + (SIG_GEODE): Move from vendor_signatures to processor_signatures. + (host_detect_local_cpu): For SIG_AMD vendor, check for SIG_GEODE + processor signature to detect geode processor. + +2009-05-12 Paolo Bonzini <bonzini@gnu.org> + + Revert: + + 2009-05-12 Paolo Bonzini <bonzini@gnu.org> + + * optabs.c (prepare_cmp_insn): Temporarily disable test that + causes spurious differences between trunk and cond-optab branch. + +2009-05-12 Paolo Bonzini <bonzini@gnu.org> + + * dojump.c (compare_from_rtx): Delete. + * expmed.c (emit_store_flag): Only try cstore_optab. Canonicalize + any MODE_CC mode to the cstorecc4 pattern. Use prepare_operand, fail + if the comparison does not satisfy the predicate; test predicates for + operands 2 and 3 of a cstore pattern. Don't try cstore optab + further if one existing pattern fails. + * expr.h (compare_from_rtx): Delete. + (prepare_operand): Declare it. + * optabs.c: Change "lib call" to "libcall" throughout. + (bcc_gen_fctn, setcc_gen_code, trap_rtx, + HAVE_conditional_trap, emit_cmp_insn): Delete. + (can_compare_p): Delete cmp_optab case. + (prepare_float_lib_cmp): Return an rtx and a machine mode. + Accept other parameters by value. + (prepare_operand): Make non-static. + (prepare_cmp_insn): Return an rtx and a machine mode. Accept + other parameters by value. Try to widen operands here based on + an optab_methods argument and looking at cbranch_optab. + (emit_cmp_and_jump_insn_1): Accept test and mode, remove widening + loop. Use cbranch_optab directly. + (emit_cmp_and_jump_insns): Fix comment. Adjust call to + prepare_cmp_insn and emit_cmp_and_jump_insn_1, remove obsolete + assertion. + (emit_conditional_move, emit_conditional_add): Inline what's needed + of compare_from_rtx, using new prepare_cmp_insn for the rest. + (init_optabs): Init cmp_optab with UNKNOWN, cbranch_optab + with COMPARE. Move cmov_optab and cstore_optab above + with cbranch_optab, move cmp_optab down with ucmp_optab, + remove tst_otpab. Do not initialize trap_rtx. + (gen_cond_trap): Do it here. Use ctrap_optab. Test predicate + for trap code. Do not check HAVE_conditional_trap. Use + prepare_cmp_insn. Accept no predicate for operand 3. + * optabs.h (OTI_cmp): Mark as used only for libcalls. + (OTI_ctrap, ctrap_optab): New. + (tst_optab): Delete. + (bcc_gen_fctn, setcc_gen_code, emit_cmp_insn): Delete. + * ifcvt.c (find_if_header): Replace HAVE_conditional_trap + with lookup of ctrap_optab. + * genopinit.c (cmp_optab, tst_optab, bcc_gen_fctn, setcc_gen_code): + Delete. + (ctrap_optab): New. + + * combine.c (combine_simplify_rtx, simplify_set): Do not + special case comparing against zero for cc0 machines. + * simplify-rtx.c (simplify_binary_operation_1): Never remove + COMPARE on cc0 machines. + (simplify_relational_operation): Return a new expression when + a COMPARE could be removed. + * final.c (final_scan_insn): Compare cc_status values + against LHS of a (compare FOO (const_int 0)) cc0 source. + Also check if cc_status.value is the full compare. + + * doc/md.texi (bCC, sCC, tstMM, cmpMM): Delete. + (cstoreMM4): Document. + (conditional_trap): Document ctrapMM4 instead. + (sync_compare_and_swapMM): Refer to cbranchcc4. + (Dependent Patterns): Eliminate obsolete information referring to + the old jump optimization phase. + (Canonicalization): Include cbranchcc4 case, omit canonicalization + of compares with 0 on cc0 machines. + (Jump Patterns): Refer to MODE_CC jump patterns preferably, + avoiding references to cc0. Remove text about storing operands + in cmpMM. + * doc/tm.texi (Condition Codes): Include blurb on different + condition code representations, separate into subsections for + CC0, MODE_CC and conditional execution. + + * config/alpha/alpha-protos.h (alpha_emit_conditional_branch, + alpha_emit_setcc): Accept operands and a machine mode. + * config/alpha/alpha.c (alpha_emit_conditional_branch): + Get code/op0/op1 from operands, use machine mode argument + instead of alpha_compare.fp_p. Emit the branch here. + (alpha_emit_setcc): Likewise, and return boolean. + (alpha_emit_conditional_move): Likewise. Assert that + cmp_op_mode == cmp_mode, and simplify accordingly. + * config/alpha/alpha.h (struct alpha_compare, alpha_compare): Delete. + * config/alpha/alpha.md (cmpdf, cmptf, cmpdi, bCC, sCC): Delete. + (cbranchdf4, cbranchtf4, cbranchdi4, cstoredf4, cstoretf4,cstoredi4): + Delete. + (stack probe test): Use cbranchdi4. + * config/alpha/predicates.md (alpha_cbranch_operator): New. + + * config/arc/arc.c (gen_compare_reg): Do not emit cmp. + * config/arc/arc.h (movsicc, movsfcc): Use it. + (movdicc, *movdicc_insn, movdfcc, *movdfcc_insn): Remove. + (cbranchsi4, cstoresi4): New. + (cmpsi, bCC and sCC expanders): Remove. + + * config/arm/arm.c (arm_compare_op0, arm_compare_op1): Delete. + * config/arm/arm.h (arm_compare_op0, arm_compare_op1): Delete. + * config/arm/predicates.md (arm_comparison_operator): Only include + floating-point operators if there is a hardware floating-point unit. + * config/arm/arm.md (cbranchsi4, cstoresi4): Enable for TARGET_32BIT, + deferring to cbranch_cc and cstore_cc respectively. + (cbranchsf4, cbranchdf4, cbranchdi4, cstoresf4, cstoredf4, cstoredi4, + cbranch_cc, cstore_cc): New. + (movsicc, movsfcc, movdfcc): Do not use arm_compare_op0 and + arm_compare_op1. + (bCC, sCC, cmpsi, cmpsf, cmpdf, cmpdi): Delete. + + * config/avr/avr-protos.h (out_tstsi, out_tsthi): Adjust prototype. + * config/avr/avr.c (out_tstsi, out_tsthi): Get the tested operand + as an argument. + (adjust_insn_length): Adjust calls. + (avr_reorg): Handle (compare (foo) (const_int 0)). + * config/avr/avr.md (tstqi, tsthi, tstsi): Remove. + (*negated_tstqi, *negated_tsthi, *negated_tstsi): Unmacroize. + (*reversed_tsthi, *reversed_tstsi): Add a scratch for simplicity. + (cmpqi, cmphi, cmpsi): Prepend asterisk, fuse tst[qhs]i here. + (bCC): Remove. + (cbranchqi4, cbranchhi4, cbranchsi4): New. + (tst -> sbrc/sbrs peephole2, cpse peephole): Wrap RHS with COMPARE. + + * config/bfin/bfin.md (cmpbi, cmpsi, bCC, sCC): Delete. + (cbranchsi4, cstorebi4, cstoresi4): New. + (movbisi): This insn is duplicate, split it to zero_extend. + * config/bfin/bfin.c (bfin_compare_op0, bfin_compare_op1): Delete + (bfin_gen_compare): Do not use them. Emit VOIDmode SET, not BImode. + (bfin_optimize_loop): Use cbranch expander. + * config/bfin/bfin.h (bfin_compare_op0, bfin_compare_op1): Delete. + * config/bfin/predicates.md (bfin_cbranch_operator): Rename to... + (bfin_bimode_comparison_operator): ... this. + (bfin_direct_comparison_operator): New. + + * config/cris/cris.c (cris_normal_notice_update_cc): Look + inside (compare FOO (const_int 0)). + (cris_rtx_costs): Handle ZERO_EXTRACT. + * config/cris/cris.md (tstdi, tst<mode>, cmpdi): Delete. + (*tstdi_non_v32): Fold in *cmpdi_non_v32. + (*tstdi_v32): Delete. + (*cmpdi_non_v32): Add M alternative for operand 1. + (cmpsi, cmp<mode>): Make private. + (*tstsi, *tst<mode>_cmp, *tst<mode>_non_cmp, *btst): Wrap LHS + with COMPARE. + (cbranch<mode>4, cbranchdi4, cstore<mode>4): New. + + * config/crx/crx.md (cstore<mode>4, cbranchcc4): New. + (cmp<mode>, bCOND_internal, b<code>, s<code>): Delete. + (cbranch<mode>4, sCOND_internal): Use ordered_comparison_operator. + (cc_reg_operand): New. + (any_cond): Delete. + * config/crx/crx.c (crx_compare_op0, crx_compare_op1, + crx_expand_compare, crx_expand_branch, crx_expand_scond): Delete. + * config/crx/crx.h (crx_compare_op0, crx_compare_op1): Delete. + * config/crx/crx-protos.h (crx_expand_compare, crx_expand_branch, + crx_expand_scond): Delete. + + * config/fr30/fr30.md (cmp<mode>, bCC): Delete. + (cbranchsi4): New. + * config/fr30/fr30.c (fr30_compare_op0, fr30_compare_op1): Delete + * config/fr30/fr30.h (fr30_compare_op0, fr30_compare_op1): Delete. + + * config/frv/frv.md (cbranchsi4, cbranchsf4, cbranchdf4, + cstoresi4, cstoresf4, cstoredf4): New. + (cmpdi, cmpsi, cmpsf, cmpdf, bCC, sCC): Remove. + * config/frv/frv-protos.h (frv_emit_cbranch, frv_emit_scc): + Receive the entire operands array. + * config/frv/frv.h (frv_compare_op0, frv_compare_op1): Delete. + * config/frv/frv.c (frv_compare_op0, frv_compare_op1): Delete. + * config/frv/frv-protos.h (frv_emit_cbranch, frv_emit_scc): + Get test/op0/op1 from the operands array. + (frv_emit_cond_move): Get test/op0/op1 from the test_rtx. + + * config/h8300/h8300-protos.h (h8300_expand_branch): Accept operands. + (h8300_expand_store): New. + * config/h8300/h8300.c (h8300_rtx_costs): Handle (compare FOO + (const_int 0)). + (h8300_expand_branch): Emit compare here. Adjust for new arguments. + (h8300_expand_store): New. + * config/h8300/h8300.md (btst combine patterns): Wrap with COMPARE + or do not try to produce (set (cc0) REG). + (peepholes): Wrap arguments with COMPARE. Add a peephole to + change a compare into a move to a scratch register. Disable some + peepholes when comparing with zero. + (tstsi, tsthi, tstsi, cmpqi): Make private. + (cmphi): Delete. + (bCC, sCC): Delete. + (cbranchqi4, cbranchhi4, cbranchsi4, cstoreqi4, cstorehi4, + cstoresi4): New. + + * config/i386/i386.c (ix86_expand_int_movcc, ix86_expand_int_addcc, + ix86_expand_fp_movcc): Set ix86_compare_op0 and ix86_compare_op1. + (ix86_emit_i387_log1p): Use gen_cbranchxf4. + (ix86_emit_i387_log1p): Use cbranchxf2. + (ix86_expand_setcc): Return void. + * config/i386/i386-protos.h (ix86_expand_setcc): Return void. + * config/i386/i386.md (cmpti, cmpdi, cmpsi, cmphi, cmpqi, cmpxf, + cmp<MODEF>, cmpcc): Remove. + (cbranchti4, cbranchdi4, cbranchsi4, cbranchhi4, cbranchqi4, + cbranchxf4, cbranch<MODEF>4, cbranchcc4, cstoredi4, cstoresi4, + cstorehi4, cstoreqi4, cstorexf4, cstore<MODEF>4, cstorecc): New. + (sCC and bCC expanders): Remove. + (stack_protect_test): Use cbranchcc4. + + * config/ia64/ia64-protos.h (ia64_compare_op0, ia64_compare_op1): + Delete. + (ia64_expand_compare): Accept three rtx by reference and return void. + * config/ia64/ia64.c (ia64_compare_op0, ia64_compare_op1): Delete. + (ia64_expand_compare): Replace op0/op1 with *op0/*op1. Get code + from *expr. Update *expr with the BImode comparison to do. + * config/ia64/ia64.md (cmpbi, cmpsi, cmpdi, cmpsf, cmpdf, cmpxf, + cmptf, bCC, sCC, conditional_trap): Delete. + (cbranchbi4, cbranchsi4, cbranchdi4, cbranchsf4, cbranchdf4, + cbranchxf4, cbranchtf4, cstorebi4, cstoresi4, cstoredi4, cstoresf4, + cstoredf4, cstorexf4, cstoretf4, ctrapbi4, ctrapsi4, ctrapdi4, + ctrapsf4, ctrapdf4, ctrapxf4, ctraptf4): New. + * config/ia64/predicates.md (ia64_cbranch_operator): New. + + * config/iq2000/iq2000-protos.h (gen_conditional_branch): Change + type of last argument. + * config/iq2000/iq2000.c (branch_cmp, branch_type): Remove. + (gen_conditional_branch): Get code/cmp0/cmp1 from operands, + use machine mode argument instead of branch_type. Remove dead + code for floating-point comparisons. + * config/iq2000/iq2000.h (branch_cmp, branch_type): Remove. + * config/iq2000/iq2000.md (cmpsi, cmpdi, cmpsf, cmpdf, tstsi, bCC): + Remove. + (cbranchsi4, cstoresi4): New. + * config/iq2000/predicates.md (reg_or_const_operand): New. + + * config/m32c/m32c.md (cbranch splitter): Use match_op_dup. + * config/m32c/m32c.md (any_cond, gl_cond): Delete. + (b<code>_op): Rewrite to... + (bcc_op): ... this, using match_operator. + (s<code>_op): Rewrite to... + (scc_op): ... this, using match_operator. + (s<code>_24_op): Rewrite to... + (scc_op_24): ... this, using match_operator. + (s<code>_<mode>): Rewrite to... + (cstore<mode>4): ... this, using match_operator. + (s<code>_<mode>_24): Rewrite to... + (cstore<mode>4_24): ... this, using match_operator. + * config/m32c/m32c-protos.h (m32c_cmp_flg_0, m32c_pend_compare, + m32c_unpend_compare, m32c_expand_scc): Delete. + * config/m32c/m32c.c (compare_op0, compare_op1, m32c_cmp_flg_0, + m32c_pend_compare, m32c_unpend_compare, m32c_expand_scc): Delete. + (m32c_expand_movcc): Change NE to EQ if necessary. + (m32c_init_libfuncs): Modify cstore optab instead of setcc_gen_code. + + * config/m32r/m32r-protos.h (gen_cond_store): New. + * config/m32r/m32r.c (m32r_compare_op0, m32r_compare_op1): Delete. + (gen_cond_store): New, from sCC patterns. + (m32r_expand_block_move): Use cbranchsi4. + * config/m32r/m32r.h (m32r_compare_op0, m32r_compare_op1): Delete. + * config/m32r/m32r.md (cmpsi, bCC, sCC): Delete. + (cbranchsi4, cstoresi4): New. + + * config/m68hc11/m68hc11.c (m68hc11_compare_op0, m68hc11_compare_op1): + Delete. + (m68hc11_rtx_costs_1, m68hc11_rtx_costs): Handle ZERO_EXTRACT. + (m68hc11_notice_update_cc): Look into a compare with 0. + * config/m68hc11/m68hc11.h (m68hc11_compare_op0, m68hc11_compare_op1): + Delete. + * config/m68hc11/m68hc11.md (tstsi, tsthi, tstqi, cmpsi, + cmphi, cmpqi, bCC): Delete. + (cbranchsi4, cbranchhi4, cbranchqi4): New. + (tstqi_1, tstqi_z_used, tstqi_1, bitcmpqi, bitcmpqi_z_used, + bitcmpqi_12, bitcmphi, various splits and peephole2s): Wrap cc0<-reg + sets with COMPARE. + + * config/m68k/predicates.md (m68k_cstore_comparison_operator, + const0_operand, const1_operand, m68k_subword_comparison_operand): New. + * config/m68k/constraints.md (H): New. + * config/m68k/m68k.md (tstdi): Remove define_expand, use name for + the define_insn below. + (tstsi, tsthi, tst<FP:mode>, cmphi, cmpqi, cmp<FP:mode>): Delete. + (*tstsi_internal_68020_cf, *tstsi_internal, *tsthi_internal, + *tstqi_internal, tst<mode>_6881, tst<mode>_cf, many unnamed + patterns): Wrap RHS with COMPARE. + (tst<FP>_68881, tst<FP>_cf): Use const0_operand. + (*cmpdi_internal): Name this pattern. + (cmpdi): Change to define_insn. + (cbranchdi4, cstoredi4, cbranchsi4, cstoresi4, cbranchhi4, cstorehi4, + cbranchqi4, cstoreqi4, cbranch<FP:mode>4, cstore<FP:mode>4): New. + (scc0_di, scc0_di_5200, scc_di): Use the ordered_comparison_operator + predicate. + (seq, sne, sgt, sgtu, slt, sltu, sge, sgeu, sle, sleu, sordered, + sunordered, suneq, sunge, sungt, sunle, sunlt, sltgt): Delete + (conditional_trap): Change to... + (ctrapdi4, ctrapsi4, ctraphi4, ctrapqi4): ... these. + (*conditional_trap): Use the ordered_comparison_operator and + const1_operand predicates. + * config/m68k/m68k.c (m68k_last_compare_had_fp_operands): Delete. + (m68k_expand_prologue): Use ctrapsi4 instead of cmpsi+conditional_trap. + (m68k_rtx_costs): Look for ZERO_EXTRACT in a COMPARE. + * config/m68k/m68k.h (m68k_last_compare_had_fp_operands): Delete. + + * config/mcore/mcore-protos.h (arch_compare_op0, arch_compare_op1, + mcore_modify_comparison, mcore_gen_compare_reg): Remove. + (mcore_gen_compare): New. + * config/mcore/mcore.c (arch_compare_op0, arch_compare_op1): Delete. + (mcore_modify_comparison, mcore_gen_compare_reg): Fold into... + (mcore_gen_compare): ... this. + * config/mcore/mcore.md (cmpsi, bCC, sCC): Remove. + (cbranchsi4, cstoresi4): New, using mcore_gen_compare. + (stack probe pattern): Use cbranchsi4. + + * config/mips/predicates.md (mips_cstore_operator): New. + * config/mips/mips-ps-3d.md (movv2sfcc): Do not use cmp_operands. + * config/mips/mips.md (any_cond): Delete. + (conditional_trap): Rename to ctrap<GPR:mode>4. Adjust predicates, + always succeed. + (fixuns_truncdfsi2, fixuns_truncdfdi2, fixuns_truncsfsi2, + fixuns_truncsfdi2): Use cbranch patterns. + (cmp<GPR:mode>, cmp<SCALARF:mode>): Delete. + (b<code>): Change to cbranch<GPR:mode>4 and cbranch<SCALARF:mode>4. + Adjust call to mips_expand_conditional_branch. + (seq, sne, slt<u>, sle<u>, sgt<u>, sge<u>): Change to + cstore<GPR:mode>4. + * config/mips/mips-protos.h (mips_expand_conditional_branch, + mips_expand_scc, mips_expand_conditional_trap): Adjust prototypes. + * config/mips/mips.c (cmp_operands): Delete. + (mips_emit_compare): Get comparison operands from *op0/*op1. + (mips_expand_scc): Get code/op0/op1/target from operands. Assert + that it succeeds. Use op0/op1 instead of cmp_operands. + (mips_expand_conditional_branch, mips_expand_conditional_move, + mips_expand_conditional_trap): Likewise. + (mips_block_move_loop): Use cbranch patterns. + * config/mips/mips.h (cmp_operands): Delete. + + * config/mmix/mmix.c (mmix_valid_comparison): Delete. + (mmix_gen_compare_reg): Just return a register in the right CC mode. + * config/mmix/mmix.h (mmix_compare_op0, mmix_compare_op1): New. + * config/mmix/mmix.md (cmpdi, cmpdf): Remove. + (*cmpcc_folded): Rename to... + (*cmpdi_folded): this. + (*cmpcc): Rename to... + (*cmps): ... this. + (movdfcc, movdicc): Adjust for new semantics of mmix_gen_compare_reg. + (bCC): Remove. + (cbranchdi4): New. + (cbranchdf4): New. Handle invalid comparisons here. + * config/mmix/predicates.md (float_comparison_operator): New. + + * config/mn10300/mn10300.c (mn10300_rtx_costs): Consider 0 and + zero_extract to be cheap in (compare (zero_extract) (const_int 0). + * config/mn10300/mn10300.md (tst): Delete. + (*tst_extqisi_am33, *tst_extqisi, *tst_exthisi_am33, *tst_exthisi): + Name these patterns and wrap RHS in a compare. + (*cmpsi): Make this pattern private. Include tst. + (*cmpsf): Make this pattern private. + (and and zero_extract cc0 set): Wrap RHS in a COMPARE. + (compare with zero peepholes): Likewise. + (bCC): Remove. + (cbranchsi4, cbranchsf4): New. + (casesi): Use cbranchsi4. + + * config/pa/pa.c (hppa_compare_op0, hppa_compare_op1, + hppa_branch_type): Delete. + (return_addr_rtx): Use cbranchsi4. + (emit_bcond_fp): Accept all operands. Replace CODE with NE. + Emit CCFPmode comparison here. + (gen_cmp_fp): Delete, now part of emit_bcond_fp. + * config/pa/pa.h (enum cmp_type, hppa_compare_op0, hppa_compare_op1, + hppa_branch_type): Delete. + * config/pa/pa.md (cmpdi, cmpsi, cmpsf, cmpdf, sCC, bCC): Delete. + (movsicc, movdicc): Remove references to hppa_compare_op0, + hppa_compare_op1 and compare_from_rtx. + (cbranchdi4, cbranchsi4, cbranchsf4, cbranchdf4, cstoresi4): New. + (casesi): Use cbranchsi4. + + * config/pdp11/pdp11-protos.h (output_jump): Change prototype. + * config/pdp11/pdp11.c (output_jump): Embed opcodes here. + * config/pdp11/pdp11.md (register_or_const0_operand): New. + (cmpdf, cmphi, cmpqi): Make private. Add tst alternatives. + (cmpsi, tstsi, tstdf, tsthi, tstqi): Delete. + (bCC): Delete. + (cbranchdf4, cbranchhi4, cbranchqi4): New. + (*branch, *branch_inverted): New. + + * config/picochip/picochip.md (cbranchhi4): Use + ordered_comparison_operator. + (cmphi, bCC): Remove. + + * config/rs6000/predicates.md (rs6000_cbranch_operator): New. + (trap_comparison_operator): Delete. + * config/rs6000/rs6000-protos.h (rs6000_emit_sCOND, + rs6000_emit_cbranch): Accept mode and operands. + * config/rs6000/rs6000.c (rs6000_compare_op0, rs6000_compare_op1, + rs6000_compare_fp_p): Delete. + (rs6000_generate_compare): Accept mode and comparison. Extract code + and op0/op1 from there. Replace references to rs6000_compare_op0 + and rs6000_compare_op1. + (rs6000_emit_sCOND): Adjust call to rs6000_generate_compare and + extract result from passed operands. + (rs6000_emit_cbranch): Adjust call to rs6000_generate_compare and + extract loc from passed operands. + (rs6000_emit_cmove): Likewise. + * config/rs6000/rs6000.h (rs6000_compare_op0, rs6000_compare_op1, + rs6000_compare_fp_p): Delete. + * config/rs6000/rs6000.md (cmp<GPR>, cmp<FP>, bCC, sCC): Delete. + (cbranch<GPR>4, cbranch<FP>4): New. + (cstore<mode>4): New. Consolidate here all choices about when to use + portable or specialized sCC sequences. + (stack_protect_test): Use cbranchsi4. + (conditional_trap): Replace with ctrap<GPR>4. + (conditional trap insn): Replace trap_comparison_operator with + ordered_comparison_operator. + + * config/s390/s390.c (s390_compare_op0, s390_compare_op1): Delete. + (s390_emit_prologue): Use ctrap. + * config/s390/s390.h (s390_compare_op0, s390_compare_op1): Delete. + * config/s390/predicates.md (s390_eqne_operator, s390_scond_operator): + New predicates replacing... + * config/s390/s390.md (COMPARE, SCOND): ... these iterators. + (cmp<GPR>, cmp<FP>, cmpcc): Delete. + (trunc patterns): Use emit_cmp_and_jump_insns instead of cmp/branch. + (add<mode>cc): Do not use s390_compare_op0/op1. + (s<code>): Change to... + (cstore<mode>4): ... this. Do not use s390_compare_op0/op1. + (seq): Change to... + (cstorecc4): ... this. Handle EQ or NE equally. + (*sne): Un-privatize for use in cstorecc4. + (b<code>): Change to... + (cbranch<GPR>4, cbranch<FP>4, cbranchcc4): ... these. + (conditional_trap): Replace with... + (ctrap<GPR>4, ctrap<FP>4): ... these. + (stack_protect): Use cbranchcc4. + + * config/score/score-conv.h (cmp_op0, cmp_op1): Delete. + * config/score/score-protos.h (score_gen_cmp): Delete. + * config/score/score.c (cmp_op0, cmp_op1, score_gen_cmp): Delete. + (score_block_move-loop): Use cbranchsi4. + * config/score/score.md (cbranchsi4): New. + (cmpsi, bCC): Delete. + * config/score/score3.c (cmp_op0, cmp_op1, score3_gen_cmp): Delete. + (score3_movsicc): Use ops[1] operands instead of cmp_op0/cmp_op1. + * config/score/score7.c (cmp_op0, cmp_op1, score7_gen_cmp): Delete. + (score7_movsicc): Use ops[1] operands instead of cmp_op0/cmp_op1. + * config/score/score3.h (score3_gen_cmp): Delete. + * config/score/score7.h (score7_gen_cmp): Delete. + + * config/sh/sh-protos.h (prepare_scc_operands): Rename to... + (sh_emit_scc_to_t): ... this. Return void. + (from_compare): Rename to... + (sh_emit_compare_and_branch): ... this. + (sh_emit_compare_and_set): New. + (sh_expand_t_scc): Accept operands. + * config/sh/predicates.md (sh_float_comparison_operator): New. + * config/sh/sh.c (sh_compare_op0, sh_compare_op1): Delete. + (prepare_scc_operands): Rename to... + (sh_emit_scc_to_t): ... this. Return void. Get op0/op1 from + arguments. + (sh_emit_cheap_store_flag): New. + (sh_emit_set_t_insn): New. + (from_compare): Rename to... + (sh_emit_compare_and_branch): ... this. Accept mode. Rewrite + handling of TARGET_SH2E floating point to avoid recursive call. + Generate branch here. + (sh_emit_compare_and_set): New. + (sh_expand_t_scc): Get op0/op1 from arguments. + (sh_emit_cheap_store_flag): New. + * config/sh/sh.md (cbranchdi4, cbranchsi4): Include -mno-cbranchdi + cases. + (cbranchdi4_i): Use an "I08" constraint instead of an "i" constraint. + (cmpsi, cmpdi, cmpsf, cmpdf): Delete. + (movsicc, movdicc): Do nothing when it recreated operands from + sh_compare_*. Use sh_emit_cheap_store_flag. Adjust call to + prepare_scc_operands (now sh_emit_scc_to_t). + (udivdi3): Use cstoresi4. + (beq_media, bne_media, bge_media, bgtu_media, bgeu_media, beq, + bne, bgt, blt, ble, bge, bgtu, bltu, bgeu, bleu, bunordered): Delete. + (cbranchint4_media, cbranchfp4_media): New. + (casesi): Use cbranchdi4. + (seq, slt, sle, sgt, sge, sgtu, sltu, sgeu, sne, sleu, sunordered): + Delete. + (cstore4_media, cstoresi4, cstoredi4, cstoresf4, cstoredf4): New. + (movnegt): Remove second operand. + (cbranchsf4, cbranchdf4): New. + (stack_protect): Use cbranchdi4/cbranchsi4. + + * config/sparc/sparc.c (sparc_compare_op0, sparc_compare_op1): Delete. + (gen_compare_reg): Accept comparison, extract part of it to... + (gen_compare_reg_1): ... this. + (gen_compare_operator): Delete. + (gen_v9_scc): Accept separate destination, comparison code and arms. + Do not use sparc_compare_op0/sparc_compare_op1. + (emit_scc_insn, emit_conditional_branch_insn): New. + (emit_v9_brxx): Make static. Remove useless assertion. + (sparc_emit_float_lib_cmp): Return RTL instead of calling + emit_cmp_insn. + (sparc_expand_compare_and_swap_12): Use gen_compare_reg_1+cbranchcc4. + * config/sparc/sparc-protos.h (gen_compare_reg, + sparc_emit_float_lib_cmp): Adjust prototype. + (emit_scc_insn, emit_conditional_branch_insn): New. + (gen_v9_scc, emit_v9_brxx_insn, gen_compare_operator): Delete. + * config/sparc/sparc.h (sparc_compare_op0, sparc_compare_op1): Delete. + * config/sparc/sparc.md (P, I, F, V32, V32I, V64, V64I): Move all + iterators to the top. + (cmpsi, cmpdi, cmpsf, cmpdf, cmptf, seqsi_special_extend, + snesi_special_extend, sCC, bCC, seqdi_special_trunc, + snedi_special_trunc): Delete. + (seqdi_special, snedi_special): Use expansion of seqdi_special_trunc + and snedi_special_trunc. + (cstoresi4, cstoredi4, cstore<F:mode>4, cbranchcc4, cbranchsi4, + cbranchdi4, cbranch<F:mode>4): New. + (mov<I:mode>cc, mov<F:mode>cc): Handle sparc_emit_float_lib_cmp + here. Use gen_compare_reg instead of gen_compare_operator. + (conditional_trap): Replace with... + (ctrapsi4, ctrapdi4): ... this. + (stack_protect_test): Use cbranchcc4. + + * config/spu/spu-protos.h (spu_emit_branch_or_set): Change second + argument to rtx. + * config/spu/spu.c (spu_compare_op0, spu_compare_op1): Remove. + (spu_emit_branch_or_set): Get code/op0/op1 from second argument. + Change spu_compare_op0/op1 to op0/op1 throughout. Get target + from operands[0] or operands[3] depending on is_set. + * config/spu/spu.h (spu_compare_op0, spu_compare_op1): Remove. + * config/spu/spu.md (cmp<mode:VQHSI>, cmp<mode:DTI>, cmp<mode:VSF>, + cmpdf, bCC), sCC: Remove. + (cbranch<mode:VQHSI>4, cbranch<mode:DTI>, cbranch<mode:VSF>4, + cbranchdf4, cstore<mode:VQHSI>4, cstore<mode:DTI>, cstore<mode:VSF>4, + cstoredf4): New. + (mov<mode>cc): Accept ordered_comparison_operator, adjust call to + spu_emit_branch_or_set. + + * config/stormy16/stormy16-protos.h (xstormy16_emit_cbranch): + Add two arguments. + * config/stormy16/stormy16.h (xstormy16_compare_op0, + xstormy16_compare_op1): Delete. + * config/stormy16/stormy16.c (xstormy16_compare_op0, + xstormy16_compare_op1): Delete. + (xstormy16_emit_cbranch): Get op0/op1 from the new arguments. + Adjust calls. + * config/stormy16/stormy16.md (cbranchsi4, cbranchhi4): New. + (cmphi, cmpsi, bCC): Remove. + + * config/v850/v850.md (tstsi, cmpsi): Fold into... + (*cmpsi): ... this one. + (cbranchsi4, cstoresi4): New. + (bCC expanders): Delete. + (sCC insns): Fold into... + (*setcc): ... this one. + (casesi): Do not use gen_cmpsi and gen_bgtu. + (various splits): Wrap "naked" RHS of a cc0 set with COMPARE. + (movsicc): Simplify. + * config/v850/v850.c (v850_rtx_costs): Handle ZERO_EXTRACT in COMPARE. + + * config/vax/vax-protos.h (cond_name): New. + (vax_output_conditional_branch): Remove. + * config/vax/vax.c (cond_name): New. + (vax_output_conditional_branch): Remove. + * config/vax/vax.h (PRINT_OPERAND): Dispatch %c to cond_name. + * config/vax/vax.md (tst<VAXint>, tst<VAXfp>): Remove. + (cmp<VAXint>, cmp<VAXfp>): Privatize. Add constraints for tst. + (bit<VAXint>): Wrap source with (compare). + (b<code> and following unnamed pattern): Rename to *branch and + *branch_reversed. Change macroization to match_operator. + (cbranch<VAXint>4, cbranch<VAXfp>4): New. + + * config/xtensa/predicates.md (xtensa_cstoresi_operator): New. + * config/xtensa/xtensa-protos.h (xtensa_expand_conditional_branch): + Change last argument to machine_mode. + (xtensa_expand_scc): Add machine_mode argument. + * config/xtensa/xtensa.c (branch_cmp, branch_type): Remove. + (gen_conditional_move, xtensa_expand_conditional_branch, + xtensa_expand_scc, xtensa_expand_conditional_move): Use mode + instead of branch_type, fetch cmp0/cmp1/test_code from operands[]. + Adjust operand numbers. + * config/xtensa/xtensa.h (enum cmp_type, branch_cmp, branch_type): + Delete. + * config/xtensa/xtensa.md (any_cond, any_scc): Delete. + (cmpsi, cmpsf, b<code>, s<code>): Delete. + (cbranchsi4, cbranchsf4, cstoresi4, cstoresf4): New. + +2009-05-12 Paolo Bonzini <bonzini@gnu.org> + + * optabs.c (prepare_cmp_insn): Temporarily disable test that + causes spurious differences between trunk and cond-optab branch. + +2009-05-12 Alexandre Oliva <aoliva@redhat.com> + + PR target/37137 + * doc/install.texi (STAGE1_TFLAGS, BUILD_CONFIG): Document. + +2009-05-12 Alexandre Oliva <aoliva@redhat.com> + + * tree.c (iterative_hash_pointer): Delete. + (iterative_hash_expr): Short-circuit handling of NULL pointer. + Hash UIDs and versions of SSA names. Don't special-case built-in + function declarations. + +2009-05-11 Ian Lance Taylor <iant@google.com> + + PR bootstrap/40103 + * graphite.c: Force -Wc++-compat to only be a warning before + #including "cloog/cloog.h". + +2009-05-11 Martin Jambor <mjambor@suse.cz> + + * ipa-cp.c (ipcp_cloning_candidate_p): Add missing return false. + +2009-05-11 Jan Hubicka <jh@suse.cz> + + * tree-ssa-loop-ivcanon.c: Include target.h + (struct loop_size): new structure. + (constant_after_peeling): New predicate. + (tree_estimate_loop_size): New function. + (estimated_unrolled_size): Rewrite for new estimates. + (try_unroll_loop_completely): Use new estimates. + * Makefile.in (tree-ssa-loop-ivcanon.o): Add dependenc on target.h + +2009-05-11 Andrew Pinski <andrew_pinski@playstation.sony.com> + + * config/spu/spu-c.c (spu_categorize_keyword): Update for recent + libcpp interface change. + (spu_macro_to_expand): Likewise. + +2009-05-11 Paolo Bonzini <bonzini@gnu.org> + + PR tree-optimization/40026 + * gimplify.c (gimplify_init_constructor): Change initial conditional + to assertion. Rewrite TREE_OPERAND (*expr_p, 1) after + optimize_compound_literals_in_ctor. + +2009-05-11 Nathan Sidwell <nathan@codesourcery.com> + + * config/m68k/m68k-devices.def (52274, 52277, 5301x, 5225x, 51xx): + New devices. + * doc/invoke.texi (M680x0 Options): Document new coldfire cpus. + +2009-05-11 H.J. Lu <hongjiu.lu@intel.com> + + * tree-vect-data-refs.c (vect_analyze_group_access): Use + HOST_WIDE_INT for gap. + +2009-05-11 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/40074 + * tree-vect-data-refs.c (vect_analyze_group_access): Take gaps into + account in group size and step comparison. + +2009-05-11 Richard Guenther <rguenther@suse.de> + + * passes.c (init_optimization_passes): Strip now incorrect comment. + (execute_function_todo): Do not set PROP_alias. + * tree-pass.h (PROP_alias): Remove. + * tree-ssa-structalias.c (pass_build_alias): Do not provide PROP_alias. + * tree-if-conv.c (pass_if_conversion): Do not require PROP_alias. + * tree-nrv.c (pass_return_slot): Likewise. + * tree-object-size.c (pass_object_sizes): Likewise. + * tree-ssa-dom.c (pass_dominator): Likewise. + (pass_phi_only_cprop): Likewise. + * tree-ssa-dse.c (pass_dse): Likewise. + * tree-ssa-phiopt.c (pass_phiopt): Likewise. + (pass_cselim): Likewise. + * tree-ssa-pre.c (pass_pre): Likewise. + (pass_fre): Likewise. + * tree-ssa-reassoc.c (pass_reassoc): Likewise. + * tree-ssa-sink.c (pass_sink_code): Likewise. + * tree-stdarg.c (pass_stdarg): Likewise. + * tree-tailcall.c (pass_tail_calls): Likewise. + * tree-vrp.c (pass_vrp): Likewise. + +2009-05-10 Ian Lance Taylor <iant@google.com> + + * basic-block.h (enum profile_status): Break out of struct + control_flow_graph. + * cgraph.h (struct inline_summary): Break out of struct + cgraph_local_info. + * cgraphunit.c (enum cgraph_order_sort_kind): New enum, broken out + of struct cgraph_order_sort. + * combine.c (enum undo_kind): New enum, broken out of struct undo. + * cse.c (struct branch_path): Break out of struct + cse_basic_block_data. + * except.h (enum eh_region_type): Break out of struct eh_region. + * gcc.c (enum add_del): Break out of struct modify_target. + * genrecog.c (enum decision_type): Break out of struct decision_test. + * ggc-page.c (struct ggc_pch_ondisk): Break out of struct + ggc_pch_data. + * matrix-reorg.c (struct free_info): Break out of struct matrix_info. + * regmove.c (enum match_use): New enum, broken out of struct match. + * sched-int.h (enum post_call_group): New enum, broken out of + struct deps. + (struct deps_reg): Break out of struct deps. + * target.h (struct asm_int_op): Break out of struct gcc_target. + * tree-eh.c (struct goto_queue_node): Break out of struct + leh_tf_state. + * tree-inline.h (enum copy_body_cge_which): Break out of + copy_body_data. + * tree-pass.h (enum opt_pass_type): Break out of struct opt_pass. + + * c-decl.c (in_struct, struct_types): New static variables. + (pushtag): Add loc parameter. Change all callers. + (lookup_tag): Add ploc parameter. Change all callers. + (check_compound_literal_type): New function. + (parser_xref_tag): Add loc parameter. Change all callers. If + -Wc++-compat, warn about struct/union/enum types defined within a + struct or union. + (start_struct): Add enclosing_in_struct, enclosing_struct_types, + and loc parameters. Change all callers. Change error calls to + error_at, using loc. For a redefinition, if the location of the + original definition is known, report it. Set in_struct and + struct_types. If -Wc++-compat warn if in sizeof, typeof, or alignof. + (finish_struct): Add new parameters enclosing_in_struct and + enclosing_struct_types. Change all callers. Set + C_TYPE_DEFINED_IN_STRUCT for all struct/union/enum types defined + in the struct. If in a struct, add this struct to struct_types. + (start_enum): Add loc parameter. Change all callers. Use + error_at for errors, using loc. For a redefinition, if the + location of the original definition is known, report it. If in a + struct, add this enum type to struct_types. If -Wc++-compat warn + if in sizeof, typeof, or alignof. + * c-parser.c (disable_extension_diagnostics): Disable -Wc++-compat. + (enable_extension_diagnostics): Reenable -Wc++-compat if appropriate. + (c_parser_enum_specifier): Get enum location for start_enum. + (c_parser_struct_or_union_specifier): Get struct location for + start_struct. Save in_struct and struct_types status between + start_struct and finish_struct. + (c_parser_cast_expression): Get location of cast. + (c_parser_alignof_expression): Get location of type. + (c_parser_postfix_expression): Likewise. + (c_parser_postfix_expression_after_paren_type): Add type_loc + parameter. Change all callers. Call check_compound_literal_type. + Use type_loc for error about variable size type. + * c-typeck.c (build_external_ref): If -Wc++-compat, warn about a use + of an enum constant from an enum type defined in a struct or union. + (c_cast_expr): Add loc parameter. Change all callers. If + -Wc++-compat, warn about defining a type in a cast. + * c-tree.h (C_TYPE_DEFINED_IN_STRUCT): Define. + (start_enum, start_struct, finish_struct): Update declarations. + (parser_xref_tag, c_cast_expr): Update declarations. + (check_compound_literal_type): Declare. + +2009-05-11 Ben Elliston <bje@au.ibm.com> + + * config/rs6000/rs6000-c.c (altivec_categorize_keyword): Update + for recent libcpp interface change. + (rs6000_macro_to_expand): Likewise. + +2009-05-10 Michael Matz <matz@suse.de> + + PR target/40031 + * config/arm/arm.c (require_pic_register): Emit on entry edge, + not at entry of function. + +2009-05-10 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40081 + Revert + * tree-sra.c (instantiate_element): Instantiate scalar replacements + using the main variant of the element type. Do not fiddle with + TREE_THIS_VOLATILE or TREE_SIDE_EFFECTS. + + * tree-sra.c (sra_type_can_be_decomposed_p): Do not decompose + structs with volatile fields. + +2009-05-10 Jan Hubicka <jh@suse.cz> + + * tree-inline.c (delete_unreachable_blocks_update_callgraph): Declare. + (estimate_move_cost): Assert that it does not get called for + VOID_TYPE_P. + (estimate_num_insns): Skip VOID types in argument handling. + (optimize_inline_calls): Delete unreachable blocks and verify that + callgraph is valid. + +2009-05-10 Jan Hubicka <jh@suse.cz> + + * cgraphbuild.c (record_reference): Use cgraph_mark_address_taken_node. + * cgraph.c (cgraph_mark_address_taken_node): New function. + (dump_cgraph_node): Dump new flag. + * cgraph.h (struct cgraph_node): Add address_taken. + (cgraph_mark_address_taken_node): New function. + * ipa.c (cgraph_postorder): Prioritize functions with address taken + since new direct calls can be born. + +2009-05-10 Joseph Myers <joseph@codesourcery.com> + + * c-lex.c (c_lex_with_flags): Expect cpp_hashnode in + tok->val.node.node. + +2009-05-10 Jan Hubicka <jh@suse.cz> + + PR middle-end/40084 + * cgraph.c (cgraph_update_edges_for_call_stmt_node): Take old_call + argument; rewrite. + (cgraph_update_edges_for_call_stmt): Take old_decl argument. + * cgraph.h (cgraph_update_edges_for_call_stmt): Update prototype. + * tree-inline.c (copy_bb): Set frequency correctly. + (fold_marked_statements): Update call to + cgraph_update_edges_for_call_stmt. + +2009-05-10 Joseph Myers <joseph@codesourcery.com> + + * config/arc/arc.c (arc_handle_interrupt_attribute): Use %qE for + identifiers in diagnostics. + * config/arm/arm.c (arm_handle_fndecl_attribute, + arm_handle_isr_attribute): Likewise. + * config/avr/avr.c (avr_handle_progmem_attribute, + avr_handle_fndecl_attribute, avr_handle_fntype_attribute): Likewise. + * config/bfin/bfin.c (handle_int_attribute, + bfin_handle_longcall_attribute, bfin_handle_l1_text_attribute, + bfin_handle_l1_data_attribute, bfin_handle_longcall_attribute, + bfin_handle_l1_text_attribute, bfin_handle_l1_data_attribute): + Likewise. + * config/darwin.c (darwin_handle_kext_attribute, + darwin_handle_weak_import_attribute): Likewise. + * config/h8300/h8300.c (h8300_handle_fndecl_attribute, + h8300_handle_eightbit_data_attribute, + h8300_handle_tiny_data_attribute): Likewise. + * config/i386/i386.c (ix86_handle_cconv_attribute, + ix86_handle_abi_attribute, ix86_handle_struct_attribute): Likewise. + * config/i386/winnt.c (ix86_handle_shared_attribute, + ix86_handle_selectany_attribute): Likewise. + * config/ia64/ia64.c (ia64_handle_model_attribute): Likewise. + * config/m32c/m32c.c (function_vector_handler): Likewise. + * config/m68hc11/m68hc11.c (m68hc11_handle_page0_attribute, + m68hc11_handle_fntype_attribute): Likewise. + * config/m68k/m68k.c (m68k_handle_fndecl_attribute): Likewise. + * config/mcore/mcore.c (mcore_handle_naked_attribute): Likewise. + * config/mips/mips.c (mips_insert_attributes, + mips_merge_decl_attributes, mips_expand_builtin): Likewise. + * config/rs6000/rs6000.c (rs6000_handle_longcall_attribute, + rs6000_handle_struct_attribute): Likewise. + * config/sh/sh.c (sh_insert_attributes, + sh_handle_resbank_handler_attribute, + sh_handle_interrupt_handler_attribute, + sh2a_handle_function_vector_handler_attribute, + sh_handle_sp_switch_attribute, sh_handle_trap_exit_attribute): + Likewise. + * config/sh/symbian.c (sh_symbian_mark_dllimport): Likewise. + * config/spu/spu.c (spu_handle_fndecl_attribute, + spu_handle_vector_attribute): Likewise. + * config/stormy16/stormy16.c + (xstormy16_handle_interrupt_attribute): Likewise. + * config/v850/v850-c.c (ghs_pragma_section): Likewise. + * config/v850/v850.c (v850_handle_interrupt_attribute): Likewise. + +2009-05-10 Joseph Myers <joseph@codesourcery.com> + + * pretty-print.h (struct pretty_print_info): Add translate_identifiers. + (pp_translate_identifiers): New. + (pp_identifier): Only conditionally translate identifier to locale + character set. + * pretty-print.c (pp_construct): Set pp_translate_identifiers. + (pp_base_tree_identifier): Only conditionally translate identifier + to locale character set. + * c-pretty-print.c (M_): Define. + (pp_c_type_specifier, pp_c_primary_expression): Mark English + fragments for conditional translation with M_. + * tree-pretty-print.c (maybe_init_pretty_print): Disable + identifier translation. + +2009-05-10 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40081 + * tree-sra.c (instantiate_element): Instantiate scalar replacements + using the main variant of the element type. Do not fiddle with + TREE_THIS_VOLATILE or TREE_SIDE_EFFECTS. + +2009-05-09 Jan Hubicka <jh@suse.cz> + + PR middle-end/40080 + * cgraphunit.c (cgraph_materialize_all_clones): Do not redirect + indirect calls; verify cgraph afterwards. + +2009-05-09 Jan Hubicka <jh@suse.cz> + + PR bootstrap/40082 + * ipa.c (update_inlined_to_pointer): New function. + (cgraph_remove_unreachable_nodes): Use it. + +2009-05-09 Jan Hubicka <jh@suse.cz> + + * tree-eh.c (struct leh_state): Remove prev_try. + (lower_try_finally, lower_catch, lower_eh_filter, lower_cleanup): Do + not track prev_try. + * except.c (gen_eh_region_cleanup, duplicate_eh_regions, + copy_eh_region_1, copy_eh_region, redirect_eh_edge_to_label, + remove_eh_handler_and_replace, foreach_reachable_handler, + verify_eh_region, verify_eh_tree): Remove tracking of prev_try pointer. + * except.h (struct eh_region): Remove eh_region_u_cleanup. + (gen_eh_region_cleanup): Update prototype. + +2009-05-09 Jan Hubicka <jh@suse.cz> + + PR middle-end/40043 + * except.c (copy_eh_region): Always set prev_try. + (redirect_eh_edge_to_label): Find outer try. + (foreach_reachable_handler): When looking for prev try + handle case where previous try is not going to be taken. + +2009-05-07 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR tree-optimization/40049 + * tree-vect-stmts.c (vectorizable_operation): If the machine has + only vector/vector shifts, convert the type of the constant to the + appropriate type to avoid building incorrect trees, which + eventually have problems with garbage collection. + +2009-05-08 Joseph Myers <joseph@codesourcery.com> + + * fold-const.c (fold_binary): Do not fold multiplication by 1 or + -1 for complex floating-point types if honoring signed zeros. + +2009-05-08 Jan Hubicka <jh@suse.cz> + + * cgraphbuild.c (compute_call_stmt_bb_frequency): Accept function + argument; handle correctly when profile is absent. + (build_cgraph_edges): Update. + (rebuild_cgraph_edges): Update. + * cgraph.c: Do not include varray.h. + (cgraph_set_call_stmt_including_clones): New function. + (cgraph_create_edge_including_clones): Likewise + (cgraph_update_edges_for_call_stmt_node): New static cfunction. + (cgraph_update_edges_for_call_stmt): Handle clones. + (cgraph_remove_node): Handle clone tree. + (cgraph_remove_node_and_inline_clones): New function. + (dump_cgraph_node): Dump clone tree. + (cgraph_clone_node): Handle clone tree. + (clone_function_name): Bring here from tree-inline.c. + (cgraph_create_virtual_clone): New function. + * cgraph.h (ipa_replace_map): Move here from ipa.h. + (cgraph_clone_info): New function. + (strut cgraph_node): Add clone_info and new clone tree pointers. + (cgraph_remove_node_and_inline_clones, + cgraph_set_call_stmt_including_clones, + cgraph_create_edge_including_clones, + cgraph_create_virtual_clone): Declare. + (cgraph_function_versioning): Use VEC argument. + (compute_call_stmt_bb_frequency): Update prototype. + (cgraph_materialize_all_clones): New function. + * ipa-cp.c (ipcp_update_cloned_node): Remove. + (ipcp_create_replace_map): Update to VECtors. + (ipcp_update_callgraph): Use virtual clones. + (ipcp_update_bb_counts, ipcp_update_edges_counts): Remove. + (ipcp_update_profiling): Do not update local profiling. + (ipcp_insert_stage): Use VECtors and virtual clones. + * cgraphunit.c (verify_cgraph_node): Verify clone tree. + (clone_of_p): New function. + (cgraph_preserve_function_body_p): Use clone tree. + (cgraph_optimize): Materialize clones. + (cgraph_function_versioning): Update for VECtors. + (save_inline_function_body): Use clone tree. + (cgraph_materialize_clone): New function. + (cgraph_materialize_all_clones): Likewise. + * ipa-inline.c (cgraph_default_inline_p): Use analyzed flags. + * ipa.c: Include gimple.h. + (cgraph_remove_unreachable_nodes): Use clone tree. + * ipa-prop.c (ipa_note_param_call): Update call to + compute_call_stmt_bb_frequencycall. + * ipa-prop.h (ipa_replace_map): Move to cgraph.h. + * tree-inline.c: Do not include varray.h or gt-tree-inline.h. + (copy_bb): Handle updating of clone tree; add new edge when new call + appears. + (expand_call_inline): Be strict about every call having edge. + (clone_fn_id_num, clone_function_name): Move to cgraph.c. + (delete_unreachable_blocks_update_callgraph): New function. + (tree_function_versioning): Use VECtors; always remove unreachable + blocks and fold conditionals. + * tree-inline.h: Do not include varray.h. + (tree_function_versioning): Remove. + * Makefile.in (GTFILES): Remove tree-inline.c + * passes.c (do_per_function): Do only functions having body. + * ipa-struct-reorg.c (do_reorg_1, collect_data_accesses): Handle clone + tree. + +2009-05-08 H.J. Lu <hongjiu.lu@intel.com> + Andrew Morrow <acm@google.com> + + PR c/36892 + * c-common.c (c_common_attribute_table): Permit deprecated + attribute to take an optional argument. + (handle_deprecated_attribute): If the optional argument to + __attribute__((deprecated)) is not a string ignore the attribute + and emit a warning. + + * c-decl.c (grokdeclarator): Updated warn_deprecated_use call. + * c-typeck.c (build_component_ref): Likewise. + (build_external_ref): Likewise. + + * toplev.c (warn_deprecated_use): Add an attribute argument. + Emit the message associated with __attribute__((deprecated)). + + * toplev.h (warn_deprecated_use): Updated. + + * doc/extend.texi: Document new optional parameter to + __attribute__((deprecated)) + +2009-05-08 Michael Eager <eager@eagercon.com> + + * config/rs6000/rs6000.md (*movdf_softfloat32): replace + !TARGET_DOUBLE_FLOAT with TARGET_SINGLE_FLOAT. + +2009-05-08 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40062 + * tree-scalar-evolution.c (follow_ssa_edge_in_condition_phi): + Avoid exponential behavior. + +2009-05-08 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/33928 + PR 26854 + * fwprop.c (use_def_ref, get_def_for_use, bitmap_only_bit_bitween, + process_uses, build_single_def_use_links): New. + (update_df): Update use_def_ref. + (forward_propagate_into): Use get_def_for_use instead of use-def + chains. + (fwprop_init): Call build_single_def_use_links and let it initialize + dataflow. + (fwprop_done): Free use_def_ref. + (fwprop_addr): Eliminate duplicate call to df_set_flags. + * df-problems.c (df_rd_simulate_artificial_defs_at_top, + df_rd_simulate_one_insn): New. + (df_rd_bb_local_compute_process_def): Update head comment. + (df_chain_create_bb): Use the new RD simulation functions. + * df.h (df_rd_simulate_artificial_defs_at_top, + df_rd_simulate_one_insn): New. + * opts.c (decode_options): Enable fwprop at -O1. + * doc/invoke.texi (-fforward-propagate): Document this. + +2009-05-08 Joseph Myers <joseph@codesourcery.com> + + PR c/24581 + * c-typeck.c (build_binary_op): Handle arithmetic between one real + and one complex operand specially. + * tree-complex.c (some_nonzerop): Do not identify a real value as + zero if flag_signed_zeros. + +2009-05-08 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/33928 + * loop-invariant.c (record_use): Fix && vs. || mishap. + +2009-05-08 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/33928 + * loop-invariant.c (struct use): Add addr_use_p. + (struct def): Add n_addr_uses. + (struct invariant): Add cheap_address. + (create_new_invariant): Set cheap_address. + (record_use): Accept df_ref. Set addr_use_p and update n_addr_uses. + (record_uses): Pass df_ref to record_use. + (get_inv_cost): Do not add inv->cost to comp_cost for cheap addresses + used only as such. + +2009-05-08 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c: Do not include c-pragma.h. + +2009-05-07 Andrew Pinski <andrew_pinski@playstation.sony.com> + + * config/spu/spu.c: Remove include of c-common.h. + +2009-05-07 Janis Johnson <janis187@us.ibm.com> + + PR c/39037 + * c-common.h (mark_valid_location_for_stdc_pragma, + valid_location_for_stdc_pragma_p, set_float_const_decimal64, + clear_float_const_decimal64, float_const_decimal64_p): New. + * c.opt (Wunsuffixed-float-constants): New. + * c-lex.c (interpret_float): Use pragma FLOAT_CONST_DECIMAL64 for + unsuffixed float constant, handle new warning. + * c-cppbuiltin.c (c_cpp_builtins): Use cast for double constants. + * c-decl.c (c_scope): New flag float_const_decimal64. + (set_float_const_decimal64, clear_float_const_decimal64, + float_const_decimal64_p): New. + (push_scope): Set new flag. + * c-parser.c (c_parser_translation_unit): Mark when it's valid + to use STDC pragmas. + (c_parser_external_declaration): Ditto. + (c_parser_compound_statement_nostart): Ditto. + * c-pragma.c (valid_location_for_stdc_pragma, + mark_valid_location_for_stdc_pragma, + valid_location_for_stdc_pragma_p, handle_stdc_pragma, + handle_pragma_float_const_decimal64): New. + (init_pragma): Register new pragma FLOAT_CONST_DECIMAL64. + * cp/semantics.c (valid_location_for_stdc_pragma_p, + set_float_const_decimal64, clear_float_const_decimal64, + float_const_decimal64_p): New dummy functions. + * doc/extend.texi (Decimal Float): Remove statement that the + pragma, and suffix for double constants, are not supported. + * doc/invoke.texi (Warning Options): List new option. + (-Wunsuffixed-float-constants): New. + +2009-05-08 Steven Bosscher <steven@gcc.gnu.org> + + * config/i386/i386.c: Do not include c-common.h. + +2009-05-07 Mark Heffernan <meheff@google.com> + + * doc/invoke.texi (Debugging Options): Document change of debugging + dump location. + * opts.c (decode_options): Make dump_base_name relative to + aux_base_name directory. + +2009-05-07 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.h (NO_DOLLAR_IN_LABEL): Added. + * config/picochip/libgccExtras/divmod15.asm : Removed redefiniton. + +2009-05-07 Rafael Avila de Espindola <espindola@google.com> + + * Makefile.in (install-plugin): Simplify a bit. + +2009-05-07 Paolo Bonzini <bonzini@gnu.org> + + * Makefile.in (OBJS-common): Add regcprop.o. + (regcprop.o): New. + * timevar.def (TV_CPROP_REGISTERS): New. + * regrename.c (regrename_optimize): Return 0. + (rest_of_handle_regrename): Delete. + (pass_rename_registers): Point to regrename_optimize. + (struct value_data_entry, struct value_data, + kill_value_one_regno, kill_value_regno, kill_value, + set_value_regno, init_value_data, kill_clobbered_value, + kill_set_value, kill_autoinc_value, copy_value, + mode_change_ok, maybe_mode_change, find_oldest_value_reg, + replace_oldest_value_reg, replace_oldest_value_addr, + replace_oldest_value_mem, copyprop_hardreg_forward_1, + debug_value_data, validate_value_data): Move... + * regcprop.c: ... here. + (rest_of_handle_cprop): Delete. + (pass_cprop_hardreg): Point to copyprop_hardreg_forward. + +2009-05-07 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/40057 + * dojump.c (prefer_and_bit_test): Use immed_double_const instead of + GEN_INT for 1 << bitnum. + (do_jump) <case BIT_AND_EXPR>: Use build_int_cst_wide_type instead of + build_int_cst_type. + +2009-05-07 Uros Bizjak <ubizjak@gmail.com> + + * doc/md.texi (Standard Pattern Names For Generation) [sync_nand]: + Remove wrong description of "nand" operation. + +2009-05-06 Richard Guenther <rguenther@suse.de> + Adam Nemet <anemet@caviumnetworks.com> + + * gimple.def (GIMPLE_ASSIGN): Fix incorrect information in the + comment. Add that if LHS is not a gimple register, then RHS1 has + to be a single object (GIMPLE_SINGLE_RHS). + +2009-05-06 Adam Nemet <anemet@caviumnetworks.com> + + * expr.c (get_def_for_expr): Move it up in the file. + (store_field): When expanding a bit-field store, look at the + defining gimple stmt for the masking conversion. + +2009-05-06 Janis Johnson <janis187@us.ibm.com> + + PR middle-end/39986 + * dfp.c (encode_decimal32, decode_decimal32, encode_decimal64, + decode_decimal64, encode_decimal128, decode_decimal128): Avoid + 32-bit memcpy into long. + +2009-05-06 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (new_reg_loc_descr): Don't ever create DW_OP_regX. + (one_reg_loc_descriptor): Create DW_OP_regX here instead of calling + new_reg_loc_descr. + (loc_by_reference): If loc is DW_OP_regX, change it into DW_OP_bregX 0 + instead of appending DW_OP_deref*. + +2009-05-06 Michael Matz <matz@suse.de> + + PR middle-end/40021 + * cfgexpand.c (maybe_cleanup_end_of_block): New static function. + (expand_gimple_cond): Use it to cleanup CFG and superfluous jumps. + +2009-05-06 Rafael Avila de Espindola <espindola@google.com> + + * Makefile.in (install-plugin): Fix srcdir handling. + +2009-05-06 Andrey Belevantsev <abel@ispras.ru> + + * tree-ssa.c (execute_update_address_taken): Handle TARGET_MEM_REF + when processing for not_regs_needed bitmap. + * gimple.c (walk_stmt_load_store_addr_ops): When visiting address, + handle TARGET_MEM_REF in lhs. Check TMR_BASE for NULL while + handling it for rhs. + +2009-05-06 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.md (unnamed inc/dec peephole): Use + optimize_insn_for_size_p instead of optimize_size. + * config/i386/predicates.md (incdec_operand): Likewise. + (aligned_operand): Likewise. + * config/i386/sse.md (divv8sf3): Likewise. + (sqrtv8sf2): Likewise. + +2009-05-06 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (ix86_build_signbit_mask): Make it static. + + * config/i386/i386-protos.h (ix86_build_signbit_mask): Removed. + +2009-05-06 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.md (*avx_<code><mode>3_finite): Replace + ssemodesuffixf2c with avxmodesuffixf2c. + +2009-05-06 Joseph Myers <joseph@codesourcery.com> + + PR c/40032 + * c-decl.c (grokdeclarator): Handle incomplete type of unnamed field. + +2009-05-05 Jakub Jelinek <jakub@redhat.com> + + * tree.h: Remove DECL_BY_REFERENCE from private_flag comment. + (struct tree_base): Adjust spacing for 8 bit boundaries. + (struct tree_decl_common): Add decl_by_reference_flag bit. + (DECL_BY_REFERENCE): Adjust. + * print-tree.c (print_node): For VAR_DECL, PARM_DECL or RESULT_DECL, + print DECL_BY_REFERENCE bit. + * dbxout.c (DECL_ACCESSIBILITY_CHAR): Revert last change. + * dwarf2out.c (loc_by_reference, gen_decl_die): Check + DECL_BY_REFERENCE for all VAR_DECLs, not just non-static ones. + (gen_variable_die): Likewise. Check TREE_PRIVATE/TREE_PROTECTED + unconditionally. + + PR middle-end/39666 + * gimplify.c (gimplify_switch_expr): If case labels cover the whole + range of the type, but default label is missing, add it with one + of the existing labels instead of adding a new label for it. + +2009-05-05 Joseph Myers <joseph@codesourcery.com> + + * dwarf.h: Remove. + +2009-05-05 Rafael Avila de Espindola <espindola@google.com> + + * Makefile.in (enable_plugin, plugin_includedir): New. + (install): Depend on install-plugin. + (PLUGIN_HEADERS): New. + (install-plugin): New. + * config.gcc: Add vxworks-dummy.h to tm_file for x86 and x86-64. + +2009-05-05 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/40022 + * tree-ssa-phiprop.c (struct phiprop_d): Exchange vop_stmt for + the only vuse. + (phivn_valid_p): Fix tuplification error, simplify. + (phiprop_insert_phi): Add dumps. + (propagate_with_phi): Simplify. + +2009-05-05 Richard Guenther <rguenther@suse.de> + + PR middle-end/40023 + * builtins.c (gimplify_va_arg_expr): Properly build the address. + +2009-05-05 Shujing Zhao <pearly.zhao@oracle.com> + + * tree.h (strip_float_extensions): Remove duplicate declaration. + (build_low_bits_mask, debug_fold_checksum, expand_function_end, + expand_function_start, stack_protect_prologue, stack_protect_epilogue, + block_ultimate_origin): Rearrange the declarations line to match the + comment that indicates the .c file which the functions are defined. + (dwarf2out_*, set_decl_rtl): Add comment. + (get_base_address): Adjust comment. + (change_decl_assembler_name, maybe_fold_*, build_addr): Rearrange the + declarations line and add comment. + (is_builtin_name): Add blank after function name, for clarity. + +2009-05-04 Joseph Myers <joseph@codesourcery.com> + + * attribs.c (decl_attributes): Use %qE for identifiers in + diagnostics. + * cgraphunit.c (verify_cgraph_node): Translate function names to + locale character set in diagnostics. + * coverage.c (get_coverage_counts): Use %qE for identifiers in + diagnostics. + * doc/invoke.texi (-finstrument-functions-exclude-function-list): + Document that functions are named in UTF-8. + * expr.c (expand_expr_real_1): Translate function names to locale + character set in diagnostics. + * gimplify.c (omp_notice_variable, omp_is_private, + gimplify_scan_omp_clauses): Use %qE for identifiers in + diagnostics. + * langhooks.c (lhd_print_error_function): Translate function names + to locale character set. + * langhooks.h (decl_printable_name): Document that return value is + in internal character set. + * stmt.c: Include pretty-print.h + (tree_conflicts_with_clobbers_p): Use %qE for identifiers in + diagnostics. + (resolve_operand_name_1): Translate named operand name to locale + character set. + * stor-layout.c (finalize_record_size): Use %qE for identifiers in + diagnostics. + * toplev.c (announce_function): Translate function names to locale + character set. + (warn_deprecated_use): Use %qE for identifiers in diagnostics. + (default_tree_printer): Use pp_identifier or translate identifiers + to locale character set. Mark "<anonymous>" for translation. + * tree-mudflap.c (mx_register_decls, mudflap_finish_file): Use %qE + for identifiers in diagnostics. + * tree.c (handle_dll_attribute): Use %qE for identifiers in + diagnostics. + * varasm.c (output_constructor): Use %qE for identifiers in + diagnostics. + +2009-05-04 Rafael Avila de Espindola <espindola@google.com> + + * configure.ac: use ` ` instead of $() + * configure: Regenerate. + +2009-05-05 Ben Elliston <bje@au.ibm.com> + + * config/pa/linux-atomic.c: Eliminate conditional include of + errno.h on non-LP64 systems to simplify build requirements. + +2009-05-04 Joseph Myers <joseph@codesourcery.com> + + * c-common.c (handle_mode_attribute): Use %qE for identifiers in + diagnostics. + * c-decl.c (check_bitfield_type_and_width): Make orig_name a tree + and pass value to identifier_to_locale. + (warn_variable_length_array): Make name a tree. + (grokdeclarator): Separate diagnostic texts for named and unnamed + declarators. Use %qE for named declarators. + * c-parser.c (c_lex_one_token): Use %qE for identifiers in + diagnostics. + * c-pragma.c (pop_alignment, handle_pragma_pack): Use %qE for + identifiers in diagnostics. + * c-typeck.c (push_member_name, start_init): Pass identifiers to + identifier_to_locale. Mark "anonymous" strings for translation. + +2009-05-04 Michael Eager <eager@eagercon.com> + + * config/rs6000/rs6000.c (rs6000_legitimate_address): Allow + address for DImode/DFmode only if double-precision FP regs. + +2009-05-04 Michael Eager <eager@eagercon.com> + + * config/rs6000/rs6000.c (rs6000_libcall_value): Add + TARGET_SINGLE_FLOAT check. + +2009-05-04 Michael Eager <eager@eagercon.com> + + * config/rs6000/xilinx.h: Add CPP_SPEC for -mxilinx-fpu options. + +2009-05-04 Michael Eager <eager@eagercon.com> + + * gcc/config.gcc (powerpc-xilinx-eabi*): Add tm t-xilinx + * config/rs6000/t-xilinx: New + +2009-05-04 Paolo Bonzini <bonzini@gnu.org> + + * doc/tm.texi (LEGITIMIZE_ADDRESS): Revise documentation. + * gcc/defaults.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/explow.c (memory_address): Use target hook. + * gcc/targhooks.c (default_legitimize_address): New. + * gcc/targhooks.h (default_legitimize_address): New. + * gcc/target.h (legitimize_address): New. + * gcc/target-def.h (TARGET_LEGITIMIZE_ADDRESS): New. + (TARGET_INITIALIZER): Include it. + * gcc/system.h (LEGITIMIZE_ADDRESS): Poison. + + * config/bfin/bfin-protos.h (legitimize_address): Remove. + * config/bfin/bfin.c (legitimize_address): Remove. + * config/bfin/bfin.h (LEGITIMIZE_ADDRESS): Remove. + * config/m68hc11/m68hc11-protos.h (m68hc11_legitimize_address): + Remove. + * config/m68hc11/m68hc11.c (m68hc11_legitimize_address): Remove. + * config/m68hc11/m68hc11.h (LEGITIMIZE_ADDRESS): Remove. + + * gcc/config/arm/arm.h (LEGITIMIZE_ADDRESS, ARM_LEGITIMIZE_ADDRESS, + THUMB_LEGITIMIZE_ADDRESS, THUMB2_LEGITIMIZE_ADDRESS): Delete. + * gcc/config/s390/s390.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/m32c/m32c.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/sparc/sparc.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/m32r/m32r.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/i386/i386.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/sh/sh.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/avr/avr.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/m68hc11/m68hc11.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/iq2000/iq2000.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/mn10300/mn10300.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/m68k/m68k.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/score/score.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/pa/pa.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/mips/mips.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/alpha/alpha.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/frv/frv.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/spu/spu.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/xtensa/xtensa.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/cris/cris.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/rs6000/rs6000.h (LEGITIMIZE_ADDRESS): Delete. + * gcc/config/picochip/picochip.h (LEGITIMIZE_ADDRESS): Delete. + + * gcc/config/s390/s390-protos.h (legitimize_address): Delete. + * gcc/config/m32c/m32c-protos.h (m32c_legitimize_address): Delete. + * gcc/config/sparc/sparc-protos.h (legitimize_address): Delete. + * gcc/config/i386/i386-protos.h (legitimize_address): Delete. + * gcc/config/avr/avr-protos.h (legitimize_address): Delete. + * gcc/config/mn10300/mn10300-protos.h (legitimize_address): Delete. + * gcc/config/score/score-protos.h (score_legitimize_address): Delete. + * gcc/config/arm/arm-protos.h (arm_legitimize_address, + (thumb_legitimize_address): Delete. + * gcc/config/pa/pa-protos.h (hppa_legitimize_address): Delete. + * gcc/config/mips/mips-protos.h (mips_legitimize_address): Delete. + * gcc/config/alpha/alpha-protos.h (alpha_legitimize_address): Delete. + * gcc/config/frv/frv-protos.h (frv_legitimize_address): Delete. + * gcc/config/spu/spu-protos.h (spu_legitimize_address): Delete. + * gcc/config/xtensa/xtensa-protos.h (xtensa_legitimize_address): + Delete. + * gcc/config/rs6000/rs6000-protos.h (rs6000_legitimize_address): + Delete. + + * config/arm/arm.c (arm_legitimize_address): Maybe call Thumb version. + * config/m32c/m32c.c (m32c_legitimize_address): Standardize. + * config/m32r/m32r.c (m32r_legitimize_address): New. + * config/m68k/m68k.c (m68k_legitimize_address): New. + * config/score/score.c (score_legitimize_address): Standardize. + * config/score/score3.c (score3_legitimize_address): Standardize. + * config/score/score3.h (score3_legitimize_address): Adjust. + * config/score/score7.c (score7_legitimize_address): Standardize. + * config/score/score7.h (score7_legitimize_address): Adjust. + * config/sh/sh.c (sh_legitimize_address): New. + * config/iq2000/iq2000.c (iq2000_legitimize_address): New. + + * gcc/config/s390/s390.c (legitimize_address): Rename to... + (s390_legitimize_address): ... this. + * gcc/config/sparc/sparc.c (legitimize_address): Rename to... + (sparc_legitimize_address): ... this. + * gcc/config/i386/i386.c (legitimize_address): Rename to... + (ix86_legitimize_address): ... this. + * gcc/config/avr/avr.c (legitimize_address): Rename to... + (avr_legitimize_address): ... this. + * gcc/config/mn10300/mn10300.c (legitimize_address): Rename to... + (mn10300_legitimize_address): ... this. + * config/alpha/alpha.c (alpha_legitimize_address): Wrap... + (alpha_legitimize_address_1): ... the old alpha_legitimize_address. + (alpha_expand_mov): Adjust call. + + * config/frv/frv.c (frv_legitimize_address): Return x on failure. + * config/spu/spu.c (spu_legitimize_address): Likewise. + * config/xtensa/xtensa.c (xtensa_legitimize_address): Likewise. + * config/rs6000/rs6000.c (rs6000_legitimize_address): Likewise. + +2009-05-04 Joseph Myers <joseph@codesourcery.com> + + * intl.c (locale_encoding, locale_utf8): New. + (gcc_init_libintl): Initialize locale_encoding and locale_utf8. + * intl.h (locale_encoding, locale_utf8): Declare. + * pretty-print.c: Include ggc.h. Include iconv.h if HAVE_ICONV. + (pp_base_tree_identifier, decode_utf8_char, identifier_to_locale): + New. + * pretty-print.h (pp_identifier): Call identifier_to_locale on ID + argument. + (pp_tree_identifier): Define to call pp_base_tree_identifier. + (pp_base_tree_identifier): Declare as function. + (identifier_to_locale): Declare. + * Makefile.in (pretty-print.o): Update dependencies. + * varasm.c (finish_aliases_1): Use %qE for identifiers in diagnostics. + +2009-05-04 Richard Guenther <rguenther@suse.de> + + PR middle-end/40015 + * builtins.c (fold_builtin_memory_op): Do not decay to element + type if the size matches the whole array. + +2009-05-04 Kazu Hirata <kazu@codesourcery.com> + + * expmed.c (synth_mult): When trying out a shift, pass the result + of a signed shift. + +2009-05-04 Kazu Hirata <kazu@codesourcery.com> + + * expmed.c (shiftsub_cost): Rename to shiftsub0_cost. + (shiftsub1_cost): New. + (init_expmed): Compute shiftsub1_cost. + (synth_mult): Optimize multiplications by constants of the form + -(2^^m-1) for some constant positive integer m. + +2009-05-03 Richard Guenther <rguenther@suse.de> + + PR c/39983 + * c-typeck.c (array_to_pointer_conversion): Do not built + ADDR_EXPRs of arrays of pointer-to-element type. + * c-gimplify.c (c_gimplify_expr): Revert change fixing + up wrong ADDR_EXPRs after-the-fact. + * c-common.c (strict_aliasing_warning): Strip pointer + conversions for obtaining the original type. + * builtins.c (fold_builtin_memset): Handle array types. + (fold_builtin_memory_op): Handle folded POINTER_PLUS_EXPRs + and array types + +2009-05-03 Richard Guenther <rguenther@suse.de> + + PR middle-end/23329 + * tree-ssa.c (useless_type_conversion_p_1): Use get_deref_alias_set. + Do not lose casts from array types with unknown extent to array + types with known extent. + * tree-ssa-copy.c (may_propagate_copy): Remove hack checking for + alias set compatibility. + +2009-05-03 Manuel López-Ibáñez <manu@gcc.gnu.org> + + * flags.h (extra_warnings): Delete. + * toplev.c (process_options): Handle Wuninitialized here. + * opts.c (extra_warnings): Delete. + (set_Wextra): Delete. + (common_handle_option): -Wextra can be handled automatically. + * c-opts.c (c_common_handle_option): Delete obsolete code. + (c_common_post_options): Simplify comment. + * common.opt (W): Add Var. + (Wextra): Add Var. + (Wuninitialized): Initialize to -1. + +2009-05-03 Adam Nemet <anemet@caviumnetworks.com> + Richard Guenther <rguenther@suse.de> + + * expr.c (get_def_for_expr): New function. + (expand_expr_real_1) <PLUS_EXPR, MINUS_EXPR>: Adjust to work with + SSA rather than trees. + <MULT_EXPR>: Likewise. Use subexp0 and subexp1 instead of + TREE_OPERAND (exp, 0) and TREE_OPERAND (exp, 1). + +2009-05-03 Joseph Myers <joseph@codesourcery.com> + + * c-common.c (reswords): Add _Imaginary. + * c-common.c (enum rid): Add RID_IMAGINARY. + +2009-05-03 Paolo Bonzini <bonzini@gnu.org> + + * tree.h (TYPE_VECTOR_OPAQUE): Fix documentation. + Patch by Richard Guenther. + +2009-05-03 Anatoly Sokolov <aesok@post.ru> + + * defaults.h (FRAME_POINTER_REQUIRED): Provide default. + * doc/tm.texi (FRAME_POINTER_REQUIRED): Revise documentation. + * config/alpha/alpha.h (FRAME_POINTER_REQUIRED): Delete. + * config/s390/s390.h (FRAME_POINTER_REQUIRED): Delete. + * config/spu/spu.h (FRAME_POINTER_REQUIRED): Delete. + * config/sh/sh.h (FRAME_POINTER_REQUIRED): Delete. + * config/pdp11/pdp11.h (FRAME_POINTER_REQUIRED): Delete. + * config/stormy16/stormy16.h (FRAME_POINTER_REQUIRED): Delete. + * config/m68hc11/m68hc11.h (FRAME_POINTER_REQUIRED): Delete. + * config/iq2000/iq2000.h (FRAME_POINTER_REQUIRED): Delete. + * config/mn10300/mn10300.h (FRAME_POINTER_REQUIRED): Delete. + * config/ia64/ia64.h (FRAME_POINTER_REQUIRED): Delete. + * config/m68k/m68k.h (FRAME_POINTER_REQUIRED): Delete. + * config/rs6000/rs6000.h (FRAME_POINTER_REQUIRED): Delete. + * config/picochip/picochip.h (FRAME_POINTER_REQUIRED): Delete. + * config/mcore/mcore.h (FRAME_POINTER_REQUIRED): Delete. + * config/h8300/h8300.h (FRAME_POINTER_REQUIRED): Delete. + * config/v850/v850.h (FRAME_POINTER_REQUIRED): Delete. + +2009-05-02 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39940 + * tree-ssa-pre.c (eliminate): Make sure we may propagate before + doing so. + +2009-05-02 Richard Guenther <rguenther@suse.de> + + PR middle-end/40001 + * tree-ssa.c (execute_update_addresses_taken): Properly check + if we can mark a variable DECL_GIMPLE_REG_P. + * gimple.c (is_gimple_reg): Re-order check for DECL_GIMPLE_REG_P + back to the end of the function. + (is_gimple_reg_type): Remove complex type special casing. + * gimplify.c (gimplify_bind_expr): Do not set DECL_GIMPLE_REG_P + if not optimizing. + +2009-05-02 Ben Elliston <bje@au.ibm.com> + + * doc/collect2.texi (Collect2): Document search path behaviour + when configured with --with-ld. + +2009-05-02 Jan Hubicka <jh@suse.cz> + + * tree-ssa-coalesce.c (coalesce_cost): Do not take ciritical + parameter; update callers. + (coalesce_cost_edge): EH edges are costier because they needs + splitting even if not critical and even more costier when there are + multiple EH predecestors. + +2009-05-02 Jan Hubicka <jh@suse.cz> + + * except.c (remove_eh_handler_and_replace): Handle updating after + removing TRY blocks. + +2009-05-02 Eric Botcazou <ebotcazou@adacore.com> + + * store-motion.c (compute_store_table): Add ENABLE_CHECKING guard. + +2009-05-02 Steven Bosscher <steven@gcc.gnu.org> + + * varasm.c: Do not include c-pragma.h. + * attribs.c: Do not incude c-common.h. + +2009-05-01 Michael Matz <matz@suse.de> + + * calls.c (initialize_argument_information): Handle SSA names like + decls with a non MEM_P DECL_RTL. + +2009-05-01 Steven Bosscher <steven@gcc.gnu.org> + + * ipa-reference.c: Do not include c-common.h, include splay-tree.h. + * ipa-utils.c: Likewise. + * ipa-type-escape.c: Likewise. + * cgraphunit.c Do not include c-common.h. + * ipa-pure-const.c: Likewise. + * tree-if-conv.c: Likewise. + * matrix-reorg.c: Do not include c-common.h and c-tree.h. + * ipa-struct-reorg.c: Likewise. + * tree-nomudflap.c: Likewise. + * tree-ssa-structalias.c: Likewise. + +2009-05-01 Steven Bosscher <steven@gcc.gnu.org> + + * store-motion.c: Many cleanups to make this pass a first-class + citizen instead of an appendix to gcse load motion. Add TODO list + to make this pass faster/cleaner/better. + + (struct ls_expr): Post gcse.c-split cleanups. + Rename to st_expr. Rename "loads" field to "antic_stores". Rename + "stores" field to "avail_stores". + (pre_ldst_mems): Rename to store_motion_mems. + (pre_ldst_table): Rename to store_motion_mems_table. + (pre_ldst_expr_hash): Rename to pre_st_expr_hash, update users. + (pre_ldst_expr_eq): Rename to pre_st_expr_eq, update users. + (ldst_entry): Rename to st_expr_entry, update users. + (free_ldst_entry): Rename to free_st_expr_entry, update users. + (free_ldst_mems): Rename to free_store_motion_mems, update users. + (enumerate_ldsts): Rename to enumerate_store_motion_mems, + update caller. + (first_ls_expr): Rename to first_st_expr, update users. + (next_ls_expr): Rename to next_st_expr, update users. + (print_ldst_list): Rename to print_store_motion_mems. Print names of + fields properly for store motion instead of names inherited from load + motion in gcse.c. + (ANTIC_STORE_LIST, AVAIL_STORE_LIST): Remove. + (LAST_AVAIL_CHECK_FAILURE): Explain what this is. Undefine when we + are done with it. + + (ae_kill): Rename to st_kill, update users. + (ae_gen): Rename to st_avloc, update users. + (transp): Rename to st_transp, update users. + (pre_insert_map): Rename to st_insert_map, update users. + (pre_delete_map): Rename to st_delete_map, update users. + (insert_store, build_store_vectors, free_store_memory, + one_store_motion_pass): Update for abovementioned changes. + + (gcse_subst_count, gcse_create_count): Remove. + (one_store_motion_pass): New statistics counters "n_stores_deleted" + and "n_stores_created", local variables. + + (extract_mentioned_regs, extract_mentioned_regs_1): Rewrite to + use for_each_rtx. + + (regvec, compute_store_table_current_insn): Remove. + (reg_set_info, reg_clear_last_set): Remove. + (compute_store_table): Use DF caches instead of local dataflow + solvers. + +2009-05-01 Joseph Myers <joseph@codesourcery.com> + + * c-objc-common.c (c_tree_printer): Print identifiers with + pp_identifier, not pp_string. Mark "({anonymous})" for + translation. + * c-pretty-print.c (pp_c_ws_string): New. + (pp_c_cv_qualifier, pp_c_type_specifier, + pp_c_specifier_qualifier_list, pp_c_parameter_type_list, + pp_c_storage_class_specifier, pp_c_function_specifier, + pp_c_attributes, pp_c_bool_constant, pp_c_constant, + pp_c_primary_expression, pp_c_postfix_expression, + pp_c_unary_expression, pp_c_shift_expression, + pp_c_relational_expression, pp_c_equality_expression, + pp_c_logical_and_expression, pp_c_logical_or_expression): Mostly + use pp_string and pp_c_ws_string in place of pp_identifier and + pp_c_identifier for non-identifiers. Mark English strings for + translation. + * c-pretty-print.h (pp_c_ws_string): Declare. + +2009-04-30 Paul Pluzhnikov <ppluzhnikov@google.com> + Roland McGrath <roland@redhat.com> + + * configure.ac (HAVE_LD_BUILDID): New check for ld --build-id support. + (ENABLE_LD_BUILDID): New configuration option. + * gcc.c [HAVE_LD_BUILDID and ENABLE_LD_BUILDID] + (LINK_BUILDID_SPEC): New macro. + (init_spec): If defined, prepend it between LINK_EH_SPEC and + link_spec. + * doc/install.texi: Document --enable-linker-build-id option. + * configure: Rebuild. + * config.in: Rebuild. + +2009-04-30 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.h (FRAME_GROWS_DOWNWARD, + MIPS_GP_SAVE_AREA_SIZE): Define new macros. + (STARTING_FRAME_OFFSET): Return 0 if FRAME_GROWS_DOWNWARD. Use + MIPS_GP_SAVE_AREA_SIZE. + * config/mips/mips.c (struct mips_frame_info): Update comment + before arg_pointer_offset and hard_frame_pointer_offset. + (mips_compute_frame_info): Update diagram before function: to + correctly use stack_pointer_rtx for fp_sp_offset and gp_sp_offset, to + indicate the position of frame_pointer_rtx with -fstack-protector and + to show args_size. Don't allocate cprestore area for leaf functions + if FRAME_GROWS_DOWNWARD. Use MIPS_GP_SAVE_AREA_SIZE to set + cprestore_size. + (mips_initial_elimination_offset): Update for FRAME_GROWS_DOWNWARD. + +2009-04-30 Michael Matz <matz@suse.de> + + PR tree-optimization/39955 + * config/rs6000/rs6000.c (rs6000_check_sdmode): Also check SSA_NAMEs. + +2009-04-30 Dave Korn <dave.korn.cygwin@gmail.com> + + * ira.c (setup_cover_and_important_classes): Use safe macro + REG_CLASS_FOR_CONSTRAINT instead of calling regclass_for_constraint + directly. + * genpreds.c (write_tm_preds_h): Output suitable definition of + REG_CLASS_FOR_CONSTRAINT. + +2009-04-30 Rafael Avila de Espindola <espindola@google.com> + + * alloc-pool.c (alloc_pool_descriptor): Use an insert_opion value + instead of an int. + * bitmap.c (bitmap_descriptor): Likewise. + * ggc-common.c (loc_descriptor): Likewise. + * varray.c (varray_descriptor): Likewise. + * vec.c (vec_descriptor): Likewise. + +2009-04-30 Eric Botcazou <ebotcazou@adacore.com> + + * Makefile.in (dce.o): Add $(EXCEPT_H). + * dce.c: Include except.h and delete redundant vector definitions. + (deletable_insn_p): Return false for non-call insns that can throw + if DF is running. + +2009-04-30 Steven Bosscher <steven@gcc.gnu.org> + + * gcse.c (ae_gen): Remove. + (can_assign_to_reg_p): Rename to can_assign_to_reg_without_clobbers_p + and make non-static function to make it available in store-motion.c. + Update call sites with search-and-replace. + (enumerate_ldsts, reg_set_info, reg_clear_last_set, store_ops_ok, + extract_mentioned_regs, extract_mentioned_regs_helper, + find_moveable_store, compute_store_table, load_kills_store, find_loads, + store_killed_in_insn, store_killed_after, store_killed_before, + build_store_vectors, insert_insn_start_basic_block, insert-store, + remove_reachable_equiv_notes, replace_store_insn, delete_store, + free_store_memory, one_store_motion_pass, gate_rtl_store_motion, + execute_rtl_store_motion, pass_rtl_store_motion): Move to... + * store-motion.c: ...new file. Also copy data structures from gcse.c + and clean up to remove parts not used by store motion. + * rtl.h (can_assign_to_reg_without_clobbers_p): Add prototype. + * Makefile.in (store-motion.o): New rule. Add to OBJS-common. + +2009-04-30 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + PR target/38571 + * config/arm/arm.h (FUNCTION_BOUNDARY): Set to 16 for thumb + when optimizing for size. + +2009-04-30 Hans-Peter Nilsson <hp@axis.com> + + * gcse.c (gcse_constant_p): Fix typo in last change. + +2009-04-30 Rafael Avila de Espindola <espindola@google.com> + + * plugin.c: Include plugin-version.h only if ENABLE_PLUGIN is defined. + +2009-04-30 Andreas Krebbel <krebbel1@de.ibm.com> + + * gcse.c (gcse_constant_p): Make sure the constant is sharable. + +2009-04-29 James E. Wilson <wilson@codesourcery.com> + + * config/mips/mips.c (mips_add_offset): Use gen_int_mode for + CONST_HIGH_PART result. + +2009-04-29 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.c (initial_elimination_offset): Rename to + avr_initial_elimination_offset. + (frame_pointer_required_p): Rename to avr_frame_pointer_required_p, + change return type to bool. + (avr_can_eliminate): New function. + * config/avr/avr.h (CAN_ELIMINATE): Use avr_can_eliminate. + (FRAME_POINTER_REQUIRED): Use avr_frame_pointer_required_p. + (INITIAL_ELIMINATION_OFFSET): Use avr_initial_elimination_offset. + * config/avr/avr-protos.h (initial_elimination_offset): Rename to + avr_initial_elimination_offset. + (frame_pointer_required_p): Rename to avr_frame_pointer_required_p. + (avr_initial_elimination_offset): Define. + +2009-04-29 Eric Botcazou <ebotcazou@adacore.com> + Steven Bosscher <steven@gcc.gnu.org> + + PR rtl-optimization/39938 + * Makefile.in (cfgrtl.o): Add $(INSN_ATTR_H). + * cfgrtl.c: Include insn-attr.h. + (rest_of_pass_free_cfg): New function. + (pass_free_cfg): Use rest_of_pass_free_cfg as execute function. + * resource.c (init_resource_info): Remove call to df_analyze. + +2009-04-29 Richard Guenther <rguenther@suse.de> + + PR target/39943 + * config/i386/i386.c (ix86_vectorize_builtin_conversion): Only + allow conversion to signed integers. + +2009-04-29 Richard Guenther <rguenther@suse.de> + + * tree-cfg.c (verify_gimple_assign_binary): Allow vector + shifts of floating point vectors if the shift amount is + a constant multiple of the element size. + +2009-04-29 Andreas Krebbel <krebbel1@de.ibm.com> + Michael Matz <matz@suse.de> + + PR middle-end/39927 + PR bootstrap/39929 + * tree-outof-ssa.c (emit_partition_copy): New function. + (insert_partition_copy_on_edge, insert_rtx_to_part_on_edge, + insert_part_to_rtx_on_edge): Perform the partition base var + copy using emit_partition_copy. + (insert_value_copy_on_edge): Convert constants to the right mode. + (insert_rtx_to_part_on_edge): Add UNSIGNEDSRCP parameter. + (elim_create): Pass the sign of the src to insert_rtx_to_part_on_edge. + +2009-04-29 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.c (bfin_optimize_loop): If we need a scratch reg, + scan backwards to try to find a constant to initialize it. + + * config/bfin/bfin.c (bfin_optimize_loop): When looking for the last + insn before the loop_end instruction, don't look past labels. + +2009-04-29 Richard Guenther <rguenther@suse.de> + + PR middle-end/39937 + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Do not + loose type conversions. + (forward_propagate_addr_expr): Fix tuplification bug. Remove + stmts only if there are no uses of its definition. + +2009-04-29 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.h (splitting_loops): Declare. + * config/bfin/bfin-protos.h (WA_05000257, WA_05000283, WA_05000315): + Reorder bit definitions to be ascending. + (WA_LOAD_LCREGS, ENABLE_WA_LOAD_LCREGS): New macros. + * config/bfin/bfin.c (splitting_loops): New variable. + (bfin_cpus): Add WA_LOAD_LCREGS as needed. + (struct loop_info): Remove members INIT and LOOP_INIT. + (bfin_optimize_loop): Don't set them. Reorder the code that generates + the LSETUP sequence. Allow LC to be loaded from any register, but + also add a case to push/pop a PREG scratch if ENABLE_WA_LOAD_LCREGS. + (bfin_reorg_loops): When done, split all BB_ENDs with splitting_loops + set to 1. + * config/bfin/bfin.md (loop_end splitter): Use splitting_loops instead + of reload_completed. + + From Jie Zhang: + * config/bfin/bfin.md (movsi_insn): Refine constraints. + +2009-04-29 Rafael Avila de Espindola <espindola@google.com> + + * Makefile.in (PLUGIN_VERSION_H): New. + (OBJS-common): Remove plugin-version.o. + (plugin.o): Depend on (PLUGIN_VERSION_H). + (plugin-version.o): Remove. + * configure: Regenerate + * configure.ac: Create plugin-version.h. + * gcc-plugin.h (plugin_gcc_version): Remove. + (plugin_default_version_check): Change signature. + * plugin-version.c: Remove. + * plugin.c: Include plugin-version.h. + (str_plugin_gcc_version_name): Remove. + (try_init_one_plugin): Pass gcc version to plugin_init. + (plugin_default_version_check): Both gcc and plugin versions are now + arguments. + +2009-04-29 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.c (bfin_optimize_loop): Unify handling of + problematic last insns. Test for TYPE_CALL rather than CALL_P. + Remove special case testing for last insn of inner loops. Don't fail + if the loop ends with a jump, emit an extra nop instead. + + * config/bfin/bfin.c (bfin_register_move_cost): Test for subsets of + DREGS rather than comparing directly. Remove code that tries to + account for latencies. + +2009-04-29 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39941 + * tree-ssa-pre.c (eliminate): Schedule update-ssa after + eliminating an indirect call. + +2009-04-29 Richard Guenther <rguenther@suse.de> + + * tree-cfg.c (verify_types_in_gimple_reference): Add require_lvalue + parameter. Allow invariants as base if !require_lvalue. + (verify_gimple_assign_single): Adjust. + +2009-04-29 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.md (sp_or_sm, spm_string, spm_name): New macro. + (ss<spm_name>hi3, ss<spm_name>hi3_parts, ss<spm_name>hi3_low_parts, + ss<spm_name_hi3_high_parts): New patterns, replacing ssaddhi3, + ssubhi3, ssaddhi3_parts and sssubhi3_parts. + (flag_mulhi3_parts): Produce a HImode output rather than trying to set + a VEC_SELECT. + * config/bfin/bfin.c (bfin_expand_builtin, + case BFIN_BUILTIN_CPLX_SQU): Adjust accordingly. + +2009-04-28 Richard Guenther <rguenther@suse.de> + + * tree-vect-loop.c (get_initial_def_for_induction): Use + correct types for pointer increment. + +2009-04-29 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * toplev.c (print_version): Update GMP version string calculation. + +2009-04-28 Eric Botcazou <ebotcazou@adacore.com> + + PR rtl-optimization/39938 + * resource.c (init_resource_info): Add call to df_analyze. + +2009-04-28 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.md (usegp): Cast the result of + alpha_find_lo_sum_using_gp to enum attr_usegp. + * config/alpha/alpha.c (override_options): Remove end-of-structure + marker element from cpu_table. Use array size of cpu_table to handle + -mcpu and -mtune options. + (tls_symbolic_operand_type): Change 0 to TLS_MODEL_NONE. + +2009-04-28 Joseph Myers <joseph@codesourcery.com> + + * config.gcc (powerpc*-*-* | rs6000-*-*): Add + rs6000/option-defaults.h to tm_file. Support cpu_32, cpu_64, + tune_32 and tune_64. + * doc/install.texi (--with-cpu-32, --with-cpu-64): Document + support on PowerPC. + * config/rs6000/rs6000.h (OPTION_DEFAULT_SPECS): Move to ... + * config/rs6000/option-defaults.h: ... here. New file. + (OPT_64, OPT_32): Define. + (MASK_64BIT): Define to 0 if not already defined. + (OPT_ARCH64, OPT_ARCH32): Define. + (OPTION_DEFAULT_SPECS): Add entries for cpu_32, cpu_64, tune_32 + and tune_64. + +2009-04-28 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (arm_override_options): Emit error on using + fpa with AAPCS. + +2009-04-28 Uros Bizjak <ubizjak@gmail.com> + + PR rtl-optimization/39914 + * ira-conflicts.c (ira_build_conflicts): Prohibit call used + registers for allocnos created from user-defined variables only + when not optimizing. + +2009-04-28 Richard Guenther <rguenther@suse.de> + + PR middle-end/39937 + * fold-const.c (fold_binary): Use distribute_real_division only + on float types. + +2009-04-28 Steve Ellcey <sje@cup.hp.com> + + * config.gcc (hppa*64*-*-hpux11*): Set use_gcc_stdint and + add hpux-stdint.h to tm_file. + (hppa[12]*-*-hpux11*): Ditto. + (ia64*-*-hpux*): Ditto. + * config/hpux-stdint.h: New. + * config/ia64/hpux.h (TARGET_OS_CPP_BUILTINS): Set + __STDC_EXT__ for all compiles. + * config/pa/pa-hpux.h: Ditto. + * config/pa/pa-hpux10.h: Ditto. + * config/pa/pa-hpux11.h: Ditto. + +2009-04-28 Catherine Moore <clm@codesourcery.com> + + * debug.h (set_name): Add comment. + +2009-04-28 Andrew Pinski <pinskia@gmail.com> + + PR target/39929 + * config/darwin.c (machopic_gen_offset): Check + currently_expanding_to_rtl if current_ir_type returns IR_GIMPLE. + * config/arm/arm.c (require_pic_register): Likewise. + +2009-04-28 Paolo Bonzini <bonzini@gnu.org> + + * config/m32c/m32c.c (TARGET_PROMOTE_FUNCTION_RETURN, + m32c_promote_function_return, TARGET_PROMOTE_PROTOTYPES, + m32c_promote_prototypes): Delete. + +2009-04-28 Michael Matz <matz@suse.de> + + PR middle-end/39922 + * tree-outof-ssa.c (insert_value_copy_on_edge): Don't convert + constants. + +2009-04-28 Richard Guenther <rguenther@suse.de> + + * tree-vect-stmts.c (vect_get_vec_def_for_operand): Fix type error. + +2009-04-28 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm-cores.def: Add support for arm1156t2f-s. + * doc/invoke.texi (ARM Options): Document support for arm1156t2f-s. + * config/arm/arm-tune.md: Regenerate. + +2009-04-28 Alexander Monakov <amonakov@ispras.ru> + + * sel-sched-ir.c (maybe_tidy_empty_bb): Do not attempt to delete a + block if there are complex incoming edges. + (sel_merge_blocks): Remove useless assert. + (sel_redirect_edge_and_branch): Check that edge was redirected. + * sel-sched-ir.h (_eligible_successor_edge_p): Remove assert. + (sel_find_rgns): Delete declaration. + * sel-sched.c (purge_empty_blocks): Attempt to remove first block of + the region when it is not a preheader. + +2009-04-28 Uros Bizjak <ubizjak@gmail.com> + + PR c/39323 + * config/alpha/elf.h (MAX_OFILE_ALIGNMENT): Sync with elfos.h + +2009-04-28 Richard Guenther <rguenther@suse.de> + + * tree.h (SSA_NAME_VALUE): Remove. + (struct tree_ssa_name): Remove value_handle member. + * tree-vrp.c (execute_vrp): Initialize/free the value-handle + array for jump threading. + * tree-ssa-propagate.c (ssa_prop_init): Do not initialize + SSA_NAME_VALUEs. + * print-tree.c (print_node): Do not dump SSA_NAME_VALUEs. + * tree-flow.h (threadedge_initialize_values): Declare. + (threadedge_finalize_values): Likewise. + * tree-ssa-threadedge.c (ssa_name_values): New global variable. + (SSA_NAME_VALUE): Define. + (threadedge_initialize_values): New function. + (threadedge_finalize_values): Likewise. + * tree-ssa-dom.c (ssa_name_values): New global variable. + (SSA_NAME_VALUE): Define. + (tree_ssa_dominator_optimize): Initialize/free the value-handle array. + +2009-04-28 Ira Rosen <irar@il.ibm.com> + + * tree-vect-loop-manip.c (vect_create_cond_for_alias_checks): + Use REPORT_VECTORIZED_LOCATIONS instead + REPORT_VECTORIZED_LOOPS. + * tree-vectorizer.c (vect_verbosity_level): Make static. + (vect_loop_location): Rename to vect_location. + (vect_set_verbosity_level): Update comment. + (vect_set_dump_settings): Use REPORT_VECTORIZED_LOCATIONS + and vect_location. + (vectorize_loops): Fix comment. Use REPORT_VECTORIZED_LOCATIONS + and vect_location. Use REPORT_UNVECTORIZED_LOCATIONS + instead REPORT_UNVECTORIZED_LOOPS. + * tree-vectorizer.h (enum vect_def_type): Rename vect_invariant_def + and vect_loop_def to vect_external_def and vect_internal_def. + (enum verbosity_levels): Rename REPORT_VECTORIZED_LOOPS + and REPORT_UNVECTORIZED_LOOPS to REPORT_VECTORIZED_LOCATIONS and + REPORT_UNVECTORIZED_LOCATIONS. + (enum vect_relevant): Update comment. Rename vect_unused_in_loop + and vect_used_in_loop and to vect_unused_in_scope and + vect_used_in_scope. + (STMT_VINFO_RELEVANT_P): Use vect_unused_in_scope. + (vect_verbosity_level): Remove declaration. + (vect_analyze_operations): Likewise. + (vect_analyze_stmt): Declare. + * tree-vect-loop.c (vect_determine_vectorization_factor): Use + REPORT_UNVECTORIZED_LOCATIONS. + (vect_get_loop_niters): Fix indentation. + (vect_analyze_loop_form): Use REPORT_UNVECTORIZED_LOCATIONS. + (vect_analyze_loop_operations): New function. + (vect_analyze_loop): Call vect_analyze_loop_operations instead of + vect_analyze_operations. + (vect_is_simple_reduction): Use new names. + (vectorizable_live_operation, vect_transform_loop): Likewise. + * tree-vect-data-refs.c (vect_check_interleaving): Add a return value + to specify whether the data references can be a part of interleaving + chain. + (vect_analyze_data_ref_dependence): Use new names. + (vect_analyze_data_refs_alignment, vect_analyze_data_refs): Likewise. + (vect_create_addr_base_for_vector_ref): Remove redundant code. + * tree-vect-patterns.c (widened_name_p): Use new names. + (vect_recog_dot_prod_pattern): Likewise. + * tree-vect-stmts.c (vect_stmt_relevant_p): Use new names. + (process_use, vect_mark_stmts_to_be_vectorized, + vect_model_simple_cost, vect_model_store_cost, + vect_get_vec_def_for_operand, vect_get_vec_def_for_stmt_copy, + vectorizable_call, vectorizable_conversion, vectorizable_assignment, + vectorizable_operation, vectorizable_type_demotion, + vectorizable_type_promotion, vectorizable_store, vectorizable_load, + vectorizable_condition): Likewise. + (vect_analyze_operations): Split into vect_analyze_loop_operations + and ... + (vect_analyze_stmt): ... new function. + (new_stmt_vec_info): Use new names. + (vect_is_simple_use): Use new names and fix comment. + * tree-vect-slp.c (vect_get_and_check_slp_defs): Use new names. + (vect_build_slp_tree, vect_analyze_slp, vect_schedule_slp): Likewise. + +2009-04-28 Uros Bizjak <ubizjak@gmail.com> + + PR target/39911 + * config/i386/i386.c (print_operand) ['Z']: Handle floating point + and integer modes for x87 operands. Do not ICE for unsupported size, + generate error instead. Generate error for unsupported operand types. + ['z']: Do not handle HImode memory operands specially. Warning + for floating-point operands. Fallthru to 'Z' for unsupported operand + types. Do not ICE for unsupported size, generate error instead. + (output_387_binary_op): Use %Z to output operands. + (output_fp_compare): Ditto. + (output_387_reg_move): Ditto. + +2009-04-28 Ben Elliston <bje@au.ibm.com> + + PR c++/35652 + Revert: + + 2009-03-27 Manuel Lopez-Ibanez <manu@gcc.gnu.org> + + * builtins.c (c_strlen): Do not warn here. + * c-typeck.c (build_binary_op): Adjust calls to pointer_int_sum. + * c-common.c (pointer_int_sum): Take an explicit location. + Warn about offsets out of bounds. + * c-common.h (pointer_int_sum): Adjust declaration. + +2009-04-27 Ian Lance Taylor <iant@google.com> + + * collect2.c (is_ctor_dtor): Change type of ret field in struct + names to symkind. + * dce.c (run_fast_df_dce): Change type of old_flags to int. + * df-core.c (df_set_flags): Change return type to int. Change + type of old_flags to int. + (df_clear_flags): Likewise. + * df-scan.c (df_def_record_1): Change 0 to VOIDmode. + (df_get_conditional_uses): Likewise. + * df.h (df_set_flags, df_clear_flags): Update declarations. + * dwarf2out.c (struct indirect_string_node): Change type of form + field to enum dwarf_form. + (AT_string_form): Change return type to enum dwarf_form. + * fixed-value.c (fixed_compare): Add cast to enum type. + * fwprop.c (update_df): Change 0 to VOIDmode. + * gensupport.c: Change 0 to UNKNOWN. + * gimple.h (gimple_cond_code): Add cast to enum type. + * haifa-sched.c (reemit_notes): Add cast to enum type. + * hooks.c (hook_int_void_no_regs): Remove function. + * hooks.h (hook_int_void_no_regs): Remove declaration. + * optabs.c (expand_widen_pattern_expr): Change 0 to VOIDmode. + * predict.c (combine_predictions_for_insn): Add casts to enum type. + * real.c (real_arithmetic): Add cast to enum type. + (real_compare): Likewise. + * target.h (struct gcc_target): Change return type of + branch_target_register_class to enum reg_class. + * target-def.h (TARGET_BRANCH_TARGET_REGISTER_CLASS): Define as + default_branch_target_register_class. + * targhooks.c (default_branch_target_register_class): New function. + * targhooks.h (default_branch_target_register_class): Declare. + * tree-data-ref.c (print_direction_vector): Add cast to enum type. + * tree-vect-data-refs.c (vect_supportable_dr_alignment): Remove + cast to int. + * tree-vect-loop.c (vect_create_epilog_for_reduction): Change 0 to + ERROR_MARK. + * tree-vect-slp.c (vect_build_slp_tree): Change 0 to + vect_uninitialized_def. Change 0 to ERROR_MARK. + * tree-vect-stmts.c (supportable_widening_operation): Don't + initialize icode1 and icode2. + * tree-vectorizer.h (enum vect_def_type): Add vect_uninitialized_def. + * config/sol2-c.c (cmn_err_length_specs): Change 0 to FMT_LEN_none + and to STD_C89. + (cmn_err_flag_specs): Change 0 to STD_C89. + (cmn_err_char_table): Likewise. + * config/arm/arm.c (get_arm_condition_code): Change type of code + to enum arm_cond_code. + (IWMMXT_BUILTIN): Change 0 to UNKNOWN. + (IWMMXT_BUILTIN2): Likewise. + (neon_builtin_type_bits): Don't define typedef. + (neon_builtin_datum): Change type of bits field to int. + (arm_expand_neon_args): Add cast to enum type. + * config/ia64/ia64.c (tls_symbolic_operand_type): Change 0 to + TLS_MODEL_NONE. + * config/i386/i386.c (bdesc_multi_arg): Change 0 to UNKNOWN. Add + casts to enum type. + * config/mips/mips.c (LOONGSON_BUILTIN_ALIAS): Change 0 to + MIPS_FP_COND_f. + * config/mips/mips.md (jal_macro): Return enum constant. + (single_insn): Likewise. + * config/rs6000/rs6000.c (bdesc_altivec_preds): Change 0 to + CODE_FOR_nothing. + * config/rs6000/rs6000-c.c (altivec_overloaded_builtins): Add + casts to enum type. + * config/s390/s390.c (s390_tune_flags): Change type to int. + (s390_arch_flags): Likewise. + (s390_handle_arch_option): Change flags field of struct pta to int. + * config/s390/s390.h (s390_tune_flags): Update declaration. + (s390_arch_flags): Likewise. + * config/sh/sh.c (prepare_move_operands): Compare + tls_symbolic_operand result with enum constant. + (sh_reorg): Change PUT_MODE to PUT_REG_NOTE_KIND. + (sh_expand_prologue): Add cast to enum type. + (sh_expand_epilogue): Likewise. + (tls_symbolic_operand): Change return type to enum tls_model. + (fpscr_set_from_mem): Add cast to enum type. + (legitimize_pic_address): Compare tls_symbolic_operand result with + enum constant. + (sh_target_reg_class): Change return type to enum reg_class. + * config/sh/sh.h (OVERRIDE_OPTIONS): Change CPU_xxx to + PROCESSOR_xxx. + * config/sh/sh-protos.h (tls_symbolic_operand): Update declaration. + * config/sparc/sparc.c (sparc_override_options): Add cast to enum type. + * config/sparc/sparc.md (empty_delay_slot): Return enum constant. + (pic, calls_alloca, calls_eh_return, leaf_function): Likewise. + (delayed_branch, tls_call_delay): Likewise. + (eligible_for_sibcall_delay): Likewise. + (eligible_for_return_delay): Likewise. + * config/spu/spu.c (expand_builtin_args): Add cast to enum type. + (spu_expand_builtin_1): Likewise. + + * c-typeck.c (convert_for_assignment): Issue -Wc++-compat warnings + for all types of conversions. + (output_init_element): Issue -Wc++-compat warning if needed when + initializing a bitfield with enum type. + * c-parser.c (c_parser_expression): Set original_type to + original_type of right hand operand of comma operator. + +2009-04-27 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/c-tree.texi (Types, Functions, Expression trees): Fix + grammar nits. + * doc/cfg.texi (Maintaining the CFG, Liveness information): Likewise. + * doc/cpp.texi (Standard Predefined Macros) + (Implementation-defined behavior): Likewise. + * doc/extend.texi (Function Attributes, Type Attributes): Likewise. + * doc/gimple.texi (GIMPLE Exception Handling) + (@code{GIMPLE_ASSIGN}): Likewise. + * doc/install.texi (Prerequisites, Configuration, Specific): Likewise. + * doc/invoke.texi (Warning Options, Optimize Options) + (AVR Options, Darwin Options): Likewise. + (Optimize Options): Reformulate -fwhole-program description. + * doc/loop.texi (Lambda): Likewise. + * doc/md.texi (Output Template, Define Constraints) + (Standard Names, Insn Splitting): Likewise. + * doc/options.texi (Option properties): Likewise. + * doc/passes.texi (Tree-SSA passes): Likewise. + * doc/rtl.texi (Side Effects, Assembler, Insns): Likewise. + * doc/tm.texi (Register Classes, Old Constraints, Scalar Return) + (File Names and DBX): Likewise. + * doc/trouble.texi (Incompatibilities): Likewise. + +2009-04-27 Trevor Smigiel <trevor_smigiel@playstation.sony.com> + + * spu.c (spu_machine_dependent_reorg): Make sure branch label on hint + instruction is correct. + +2009-04-27 Trevor Smigiel <trevor_smigiel@playstation.sony.com> + + Allow non-constant arguments to conversion intrinsics. + * spu-protos.h (exp2_immediate_p, spu_gen_exp2): Declare. + * predicates.md (spu_inv_exp2_operand, spu_exp2_operand): New. + * spu.c (print_operand): Handle 'v' and 'w'. + (exp2_immediate_p, spu_gen_exp2): Define. + * spu-builtins.def (spu_convts, spu_convtu, spu_convtf_0, + spu_convtf_1): Update parameter descriptions. + * spu-builtins.md (spu_csflt, spu_cuflt, spu_cflts, spu_cfltu): Update. + * constraints.md ('v', 'w'): New. + * spu.md (UNSPEC_CSFLT, UNSPEC_CFLTS, UNSPEC_CUFLT, UNSPEC_CFLTU): + Remove. + (i2f, I2F): New define_mode_attr. + (floatsisf2, floatv4siv4sf2, fix_truncsfsi2, fix_truncv4sfv4si2, + floatunssisf2, floatunsv4siv4sf2, fixuns_truncsfsi2, + fixuns_truncv4sfv4si2): Update to use mode attribute. + (float<mode><i2f>2_mul, float<mode><i2f>2_div, + fix_trunc<mode><f2i>2_mul, floatuns<mode><i2f>2_mul, + floatuns<mode><i2f>2_div, fixuns_trunc<mode><f2i>2_mul): New + patterns for combine. + +2009-04-27 Steven Bosscher <steven@gcc.gnu.org> + + * dbgcnt.def (cprop1, cprop2, gcse, jump_bypass): Remove + (cprop, hoist, pre, store_motion): New debug counters. + * tree-pass.h (pass_tracer): Move to list of gimple passes, it + is not an RTL pass anymore. + (pass_profiling): Remove extern decl for pass removed in 2005. + (pass_gcse, pass_jump_bypass): Remove. + * final.c (rest_of_clean_state): Set flag_rerun_cse_after_global_opts + to 0 for clean state. + * toplev.h (flag_rerun_cse_after_global_opts): Add extern declaration. + * cse.c (gate_handle_cse_after_global_opts, + rest_of_handle_cse_after_global_opts): New functions. + (pass_cse_after_global_opts): New pass, does local CSE. + * timevar.def (TV_GCSE, TV_CPROP1, TV_CPROP2, TV_BYPASS): Remove. + (TV_CPROP): New timevar. + * gcse.c (flag_rerun_cse_after_global_opts): New global variable. + (run_jump_opt_after_gcse, max_gcse_regno): Remove global vars. + (gcse_main, recompute_all_luids): Remove. + (compute_hash_table_work): Call max_reg_num instead of reading + max_gcse_regno. + (cprop_jump): Don't set run_jump_opt_after_gcse. + (constprop_register): Always allow to alter jumps. + (cprop_insn): Likewise. + (do_local_cprop): Likewise. + (local_cprop_pass): Likewise. Return non-zero if something changed. + (cprop): Remove function, fold interesting bits into one_cprop_pass. + (find_implicit_sets): Add note about missed optimization opportunity. + (one_cprop_pass): Rewrite to be "the" CPROP pass, called from the + pass_rtl_cprop execute function. + Don't bother tracking the pass number, each pass gets its own dumpfile + now anyway. + Always allow to alter jumpsand bypass jumps. + (bypass_block): Don't ignore regno >= max_gcse_regno, find_bypass_set + will just find no suitable set. + (pre_edge_insert): Fix dumping, this function is for PRE only. + (one_pre_gcse_pass): Rewrite to be "the" PRE pass, called from the + pass_rtl_pre execute function. + (hoist_code): Return non-zero if something changed. Keep track of + substitutions and insertions for statistics gathering similar to PRE. + (one_code_hoisting_pass): Rewrite to be "the" code hoisting pass, + called from the pass_rtl_hoist execute function. Show pass statistics. + (compute_store_table): Use max_reg_num directly instead of using the + formerly global max_gcse_regno. + (build_store_vectors): Likewise. + (replace_store_insn): Fix dumping. + (store_motion): Rename to ... + (one_store_motion_pass): ... this. Rewrite to be "the" STORE_MOTION + pass, called from the pass_rtl_store_motion execute function. Keep + track of substitutions and insertions for statistics gathering similar + to PRE. + (bypass_jumps): Remove, fold interesting bits into ... + (one_cprop_pass): ... this. Rewrite to be "the" CPROP pass, called + from the pass_rtl_cprop execute function. + (gate_handle_jump_bypass, rest_of_handle_jump_bypass, + pass_jump_bypass): Remove. + (gate_handle_gcse, rest_of_handle_gcse): Remove. + (gate_rtl_cprop, execute_rtl_cprop, pass_rtl_cprop): New. + (gate_rtl_pre, execute_rtl_pre, pass_rtl_pre): New. + (gate_rtl_hoist, execute_rtl_hoist, pass_rtl_hoist): New. + (gate_rtl_store_motion, execute_rtl_store_motion, + pass_rtl_store_motion): New. + * common.opt: Remove flag_cse_skip_blocks, adjust documentation to + make it clear that -fcse-skip-blocks is a no-op for backward compat. + * passes.c (init_optimization_passes): Remove pass_gcse and + pass_jump_bypass. Schedule cprop, pre, hoist, cprop, store_motion, + and cse_after_global_opts in place of pass_gcse. Schedule cprop + instead of pass_jump_bypass. + +2009-04-27 Richard Guenther <rguenther@suse.de> + + PR middle-end/39928 + * gimplify.c (gimplify_expr): If we are required to create + a temporary make sure it ends up as register. + +2009-04-27 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39903 + * config/i386/i386.c (construct_container): Don't call + gen_reg_or_parallel with BLKmode on X86_64_SSE_CLASS, + X86_64_SSESF_CLASS and X86_64_SSEDF_CLASS. + +2009-04-27 Michael Matz <matz@suse.de> + + * ssaexpand.h (struct ssaexpand): Member 'values' is a bitmap. + (get_gimple_for_ssa_name): Adjust, lookup using SSA_NAME_DEF_STMT. + * tree-ssa-live.h (find_replaceable_exprs): Return a bitmap. + (dump_replaceable_exprs): Take a bitmap. + * cfgexpand.c (gimple_cond_pred_to_tree): Handle bitmap instead of + array. + (expand_gimple_basic_block): Likewise. + * tree-ssa-ter.c (struct temp_expr_table_d): Make + replaceable_expressions member a bitmap. + (free_temp_expr_table): Pass back and deal with bitmap, not gimple*. + (mark_replaceable): Likewise. + (find_replaceable_in_bb, dump_replaceable_exprs): Likewise. + * tree-outof-ssa.c (remove_ssa_form): 'values' is a bitmap. + +2009-04-27 Richard Guenther <rguenther@suse.de> + + * tree-cfg.c (remove_useless_stmts): Verify stmts afterwards. + (verify_stmts): Dispatch to gimple/type verification code. + * tree-inline.c (remap_gimple_op_r): Work around C++ FE + issue with call argument types. + +2009-04-27 Michael Matz <matz@suse.de> + + * tree-into-ssa.c (regs_to_rename, mem_syms_to_rename): Remove. + (init_update_ssa, delete_update_ssa, update_ssa): Remove references + to above. + +2009-04-27 Richard Sandiford <rdsandiford@googlemail.com> + Eric Botcazou <ebotcazou@adacore.com> + + * resource.c (find_basic_block): Use BLOCK_FOR_INSN to look up + a label's basic block. + (mark_target_live_regs): Tidy and rework obsolete comments. + Change back DF problem to LIVE. If a label starts a basic block, + assume that all registers that used to be live then still are. + (init_resource_info): If a label starts a basic block, set its + BLOCK_FOR_INSN accordingly. + (fini_resource_info): Undo the setting of BLOCK_FOR_INSN. + +2009-04-27 Richard Guenther <rguenther@suse.de> + + * tree-flow-inline.h (function_ann): Remove. + (get_function_ann): Likewise. + * tree-dfa.c (create_function_ann): Remove. + * tree-flow.h (struct static_var_ann_d): Remove. + (struct function_ann_d): Likewise. + (union tree_ann_d): Remove fdecl member. + (function_ann_t): Remove. + (function_ann, get_function_ann, create_function_ann): Remove + declarations. + +2009-04-27 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (code_for_builtin): Declare as enum insn_code. + +2009-04-27 Jan Hubicka <jh@suse.cz> + + * ipa-pure-const.c (struct funct_state_d): New fields + state_previously_known, looping_previously_known; remove + state_set_in_source. + (analyze_function): Use new fields. + (propagate): Avoid assumption that state_set_in_source imply + nonlooping. + + * tree-ssa-loop-niter.c (finite_loop_p): New function. + * tree-ssa-loop-ivcanon.c (empty_loop_p): Use it. + * cfgloop.h (finite_loop_p): Declare. + +2009-04-26 Michael Matz <matz@suse.de> + + * tree-flow.h (tree_ann_common_d): Remove aux and value_handle members. + +2009-04-26 Michael Matz <matz@suse.de> + + * tree-pass.h (pass_del_ssa, pass_mark_used_blocks, + pass_free_cfg_annotations, pass_free_datastructures): Remove decls. + * gimple-low.c (mark_blocks_with_used_vars, mark_used_blocks, + pass_mark_used_blocks): Remove. + * tree-optimize.c (pass_free_datastructures, + execute_free_cfg_annotations, pass_free_cfg_annotations): Remove. + * passes.c (init_optimization_passes): Don't call + pass_mark_used_blocks, remove dead code. + +2009-04-26 H.J. Lu <hongjiu.lu@intel.com> + + * tree-outof-ssa.c (rewrite_trees): Add ATTRIBUTE_UNUSED. + * tree-ssa-live.h (register_ssa_partition): Likewise. + +2009-04-26 Michael Matz <matz@suse.de> + + Expand from SSA. + * builtins.c (fold_builtin_next_arg): Handle SSA names. + * tree-ssa-copyrename.c (rename_ssa_copies): Use ssa_name() directly. + * tree-ssa-coalesce.c (create_outofssa_var_map): Mark only useful + SSA names. + (compare_pairs): Swap cost comparison. + (coalesce_ssa_name): Don't use change_partition_var. + * tree-nrv.c (struct nrv_data): Add modified member. + (finalize_nrv_r): Set it. + (tree_nrv): Use it to update statements. + (pass_nrv): Require PROP_ssa. + * tree-mudflap.c (mf_decl_cache_locals, + mf_build_check_statement_for): Use make_rename_temp. + (pass_mudflap_2): Require PROP_ssa, run ssa update at finish. + * alias.c (find_base_decl): Handle SSA names. + * emit-rtl (set_reg_attrs_for_parm): Make non-static. + (component_ref_for_mem_expr): Don't leak SSA names into RTL. + * rtl.h (set_reg_attrs_for_parm): Declare. + * tree-optimize.c (pass_cleanup_cfg_post_optimizing): Rename + to "optimized", remove unused locals at finish. + (execute_free_datastructures): Make global, call + delete_tree_cfg_annotations. + (execute_free_cfg_annotations): Don't call + delete_tree_cfg_annotations. + + * ssaexpand.h: New file. + * expr.c (toplevel): Include ssaexpand.h. + (expand_assignment): Handle SSA names the same as register variables. + (expand_expr_real_1): Expand SSA names. + * cfgexpand.c (toplevel): Include ssaexpand.h. + (SA): New global variable. + (gimple_cond_pred_to_tree): Fold TERed comparisons into predicates. + (SSAVAR): New macro. + (set_rtl): New helper function. + (add_stack_var): Deal with SSA names, use set_rtl. + (expand_one_stack_var_at): Likewise. + (expand_one_stack_var): Deal with SSA names. + (stack_var_size_cmp): Use code (SSA_NAME / DECL) as tie breaker + before unique numbers. + (expand_stack_vars): Use set_rtl. + (expand_one_var): Accept SSA names, add asserts for them, feed them + to above subroutines. + (expand_used_vars): Expand all partitions (without default defs), + then only the local decls (ignoring those expanded already). + (expand_gimple_cond): Remove edges when jumpif() expands an + unconditional jump. + (expand_gimple_basic_block): Don't clear EDGE_EXECUTABLE here, + or remove abnormal edges. Ignore insns setting the LHS of a TERed + SSA name. + (gimple_expand_cfg): Call into rewrite_out_of_ssa, initialize + members of SA; deal with PARM_DECL partitions here; expand + all PHI nodes, free tree datastructures and SA. Commit instructions + on edges, clear EDGE_EXECUTABLE and remove abnormal edges here. + (pass_expand): Require and destroy PROP_ssa, verify SSA form, flow + info and statements at start, collect garbage at finish. + * tree-ssa-live.h (struct _var_map): Remove partition_to_var member. + (VAR_ANN_PARTITION) Remove. + (change_partition_var): Don't declare. + (partition_to_var): Always return SSA names. + (var_to_partition): Only accept SSA names. + (register_ssa_partition): Only check argument. + * tree-ssa-live.c (init_var_map): Don't allocate partition_to_var + member. + (delete_var_map): Don't free it. + (var_union): Only accept SSA names, simplify. + (partition_view_init): Mark only useful SSA names as used. + (partition_view_fini): Only deal with SSA names. + (change_partition_var): Remove. + (dump_var_map): Use ssa_name instead of partition_to_var member. + * tree-ssa.c (delete_tree_ssa): Don't remove PHI nodes on RTL + basic blocks. + * tree-outof-ssa.c (toplevel): Include ssaexpand.h and expr.h. + (struct _elim_graph): New member const_dests; nodes member vector of + ints. + (set_location_for_edge): New static helper. + (create_temp): Remove. + (insert_partition_copy_on_edge, insert_part_to_rtx_on_edge, + insert_value_copy_on_edge, insert_rtx_to_part_on_edge): New functions. + (new_elim_graph): Allocate const_dests member. + (clean_elim_graph): Truncate const_dests member. + (delete_elim_graph): Free const_dests member. + (elim_graph_size): Adapt to new type of nodes member. + (elim_graph_add_node): Likewise. + (eliminate_name): Likewise. + (eliminate_build): Don't take basic block argument, deal only with + partition numbers, not variables. + (get_temp_reg): New static helper. + (elim_create): Use it, deal with RTL temporaries instead of trees. + (eliminate_phi): Adjust all calls to new signature. + (assign_vars, replace_use_variable, replace_def_variable): Remove. + (rewrite_trees): Only do checking. + (edge_leader, stmt_list, leader_has_match, leader_match): Remove. + (same_stmt_list_p, identical_copies_p, identical_stmt_lists_p, + init_analyze_edges_for_bb, fini_analyze_edges_for_bb, + contains_tree_r, MAX_STMTS_IN_LATCH, + process_single_block_loop_latch, analyze_edges_for_bb, + perform_edge_inserts): Remove. + (expand_phi_nodes): New global function. + (remove_ssa_form): Take ssaexpand parameter. Don't call removed + functions, initialize new parameter, remember partitions having a + default def. + (finish_out_of_ssa): New global function. + (rewrite_out_of_ssa): Make global. Adjust call to remove_ssa_form, + don't reset in_ssa_p here, don't disable TER when mudflap. + (pass_del_ssa): Remove. + * tree-flow.h (struct var_ann_d): Remove out_of_ssa_tag and + partition members. + (execute_free_datastructures): Declare. + * Makefile.in (SSAEXPAND_H): New variable. + (tree-outof-ssa.o, expr.o, cfgexpand.o): Depend on SSAEXPAND_H. + * basic-block.h (commit_one_edge_insertion): Declare. + * passes.c (init_optimization_passes): Move pass_nrv and + pass_mudflap2 before pass_cleanup_cfg_post_optimizing, remove + pass_del_ssa, pass_free_datastructures, pass_free_cfg_annotations. + * cfgrtl.c (commit_one_edge_insertion): Make global, don't declare. + (redirect_branch_edge): Deal with super block when expanding, split + out jump patching itself into ... + (patch_jump_insn): ... here, new static helper. + +2009-04-26 Michael Matz <matz@suse.de> + + * tree-ssa-copyrename.c (rename_ssa_copies): Don't iterate + beyond num_ssa_names. + * tree-ssa-ter.c (free_temp_expr_table): Likewise. + * tree-ssa-coalesce.c (create_outofssa_var_map): Likewise. + +2009-04-26 Jakub Jelinek <jakub@redhat.com> + + PR inline-asm/39543 + * fwprop.c (forward_propagate_asm): New function. + (forward_propagate_and_simplify): Propagate also into __asm, if it + doesn't increase the number of referenced registers. + + PR c/39889 + * stmt.c (warn_if_unused_value): Look through NON_LVALUE_EXPR. + +2009-04-26 Jakub Jelinek <jakub@redhat.com> + + * tree-nested.c (get_nonlocal_vla_type): If not optimizing, call + note_nonlocal_vla_type for nonlocal VLAs. + (note_nonlocal_vla_type, note_nonlocal_block_vlas, + contains_remapped_vars, remap_vla_decls): New functions. + (convert_nonlocal_reference_stmt): If not optimizing, call + note_nonlocal_block_vlas on GIMPLE_BIND block vars. + (nesting_copy_decl): Return {VAR,PARM,RESULT}_DECL unmodified + if it wasn't found in var_map. + (finalize_nesting_tree_1): Call remap_vla_decls. If outermost + GIMPLE_BIND doesn't have gimple_bind_block, chain debug_var_chain + to BLOCK_VARS (DECL_INITIAL (root->context)) instead of calling + declare_vars. + * gimplify.c (nonlocal_vlas): New variable. + (gimplify_var_or_parm_decl): Add debug VAR_DECLs for non-local + referenced VLAs. + (gimplify_body): Create and destroy nonlocal_vlas. + + * dwarf2out.c (loc_descr_plus_const): New function. + (build_cfa_aligned_loc, tls_mem_loc_descriptor, + mem_loc_descriptor, loc_descriptor_from_tree_1, + descr_info_loc, gen_variable_die): Use it. + + * tree.h (DECL_BY_REFERENCE): Note that it is also valid for + !TREE_STATIC VAR_DECLs. + * dwarf2out.c (loc_by_reference, gen_decl_die): Handle + DECL_BY_REFERENCE on !TREE_STATIC VAR_DECLs. + (gen_variable_die): Likewise. Don't look at TREE_PRIVATE if + DECL_BY_REFERENCE is valid. + * dbxout.c (DECL_ACCESSIBILITY_CHAR): Don't look at TREE_PRIVATE + for PARM_DECLs, RESULT_DECLs or !TREE_STATIC VAR_DECLs. + * tree-nested.c (get_nonlocal_debug_decl, get_local_debug_decl): + Copy DECL_BY_REFERENCE. + (struct nesting_copy_body_data): New type. + (nesting_copy_decl): New function. + (finalize_nesting_tree_1): Remap types of debug_var_chain variables, + if they have variable length. + +2009-04-26 Michael Matz <matz@suse.de> + + * tree-sra.c (sra_build_assignment): Don't use into_ssa mode, + mark new temporaries for renaming. + +2009-04-26 Joseph Myers <joseph@codesourcery.com> + + PR c/39581 + * c-decl.c (global_bindings_p): Return negative value. + (c_variable_size): New. Based on variable_size from + stor-layout.c. + (grokdeclarator): Call c_variable_size not variable_size. + +2009-04-26 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.c (print_operand) ['z']: Fix typo. + +2009-04-26 Kai Tietz <kai.tietz@onevision.com> + + * config/i386/mingw-w64.h (STANDARD_INCLUDE_DIR): + Redefine it to just use mingw/include. + (ASM_SPEC): Rules for -m32 and -m64. + (LINK_SPEC): Use Likewise. + (SPEC_32): New define. + (SPEC_64): Likewise. + (SUB_LINK_SPEC): Likewise. + (MULTILIB_DEFAULTS): New define. + * config/i386/t-mingw-w64 (MULTILIB_OPTIONS): + Add multilib options. + (MULTILIB_DIRNAMES): Likewise. + (MULTILIB_OSDIRNAMES): Likewise. + (LIBGCC): Likewise. + (INSTALL_LIBGCC): Likewise. + +2009-04-26 Joseph Myers <joseph@codesourcery.com> + + PR c/39556 + * c-tree.h (enum c_inline_static_type): New. + (record_inline_static): Declare. + * c-decl.c (struct c_inline_static, c_inline_statics, + record_inline_static, check_inline_statics): New. + (pop_file_scope): Call check_inline_statics. + (start_decl): Call record_inline_static instead of pedwarning + directly for static in inline function. + * c-typeck.c (build_external_ref): Call record_inline_static + instead of pedwarning directly for static referenced in inline + function. + +2009-04-26 Steven Bosscher <steven@gcc.gnu.org> + + * df-scan.c (df_insn_rescan): Salvage insn's LUID if the insn is + not new but only being rescanned. + * gcse.c (uid_cuid, max_uid, INSN_CUID, max_cuid, struct reg_set, + reg_set_table, REG_SET_TABLE_SLOP, reg_set_in_block, + alloc_reg_set_mem, free_reg_set_mem, record_one_set, + record_set_info, compute_set, grealloc): Remove. + (recompute_all_luids): New function. + (gcse_main): Don't compute sets, and don't do related memory + allocations/free-ing. If something changed before the end of the + pass, update LUIDs using recompute_all_luids. + (alloc_gcse_mem): Don't compute LUIDs. Don't allocate reg_set memory. + (free_gcse_mem): Don't free it either. + (oprs_unchanged_p, load_killed_in_block, record_last_reg_set_info): + Use the df insn LUIDs. + (load_killed_in_block): Likewise. + (compute_hash_table_work): Don't compute reg_set_in_block. + (compute_transp): Use DF_REG_DEF_CHAINs. + (local_cprop_pass): Don't use compute_sets and related functions. + (one_cprop_pass, pre_gcse, one_pre_gcse_pass, one_code_hoisting_pass): + Use get_max_uid() instead of max_cuid. + (insert_insn_end_basic_block, pre_insert_copy_insn, + update_ld_motion_stores): Don't try to + keep reg_set tables up to date. + (pre_insert_copies): Use df insn LUIDs. + (sbitmap pre_redundant_insns): Replace with uses of INSN_DELETED_P. + (reg_set_info): Don't use extra bitmap argument. + (compute_store_table): Don't compute reg_set_in_block. Use DF scan + information to compute regs_set_in_block. + (free_store_memory, store_motion): Don't nullify reg_set_in_block. + (bypass_jumps): Don't use compute_sets and friends. + +2009-04-26 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + PR testsuite/39710 + * opts.c (undocumented_msg): Do not leave blank even with + ENABLE_CHECKING. + +2009-04-25 Joseph Myers <joseph@codesourcery.com> + + * c-decl.c (build_enumerator): Allow values folding to integer + constants but not integer constant expressions with a pedwarn if + pedantic. + +2009-04-25 Joseph Myers <joseph@codesourcery.com> + + PR c/39582 + * c-typeck.c (c_expr_sizeof_type): Create a C_MAYBE_CONST_EXPR + with non-null C_MAYBE_CONST_EXPR_PRE if size of a variable-length + type is an integer constant. + +2009-04-25 Uros Bizjak <ubizjak@gmail.com> + + PR target/39897 + * config/i386/i386.c (print_operand) ['z']: Revert handling of + HImode operands. + +2009-04-25 Joseph Myers <joseph@codesourcery.com> + + PR c/39564 + * c-decl.c (grokdeclarator): Diagnose declarations of functions + with variably modified return type and no storage class + specifiers, except for the case of nested functions. Distinguish + extern declarations of functions with variably modified return + types from those of objects with variably modified types. + +2009-04-25 Jan Hubicka <jh@suse.cz> + + * tree.c (list_equal_p): New function. + * tree.h (list_equal_p): Declare. + * coretypes.h (edge_def, edge, const_edge, basic_block_def + basic_block_def, basic_block, const_basic_block): New. + * tree-eh.c (make_eh_edge): EH edges are not abnormal. + (redirect_eh_edge): New function. + (make_eh_edge_update_phi): EH edges are not abnormal. + * except.c: Include tree-flow.h. + (list_match): New function. + (eh_region_replaceable_by_p): New function. + (replace_region): New function. + (hash_type_list): New function. + (hash_eh_region): New function. + (eh_regions_equal_p): New function. + (merge_peers): New function. + (remove_unreachable_regions): Verify EH tree when checking; + merge peers. + (copy_eh_region_1): New function. + (copy_eh_region): New function. + (push_reachable_handler): New function. + (build_post_landing_pads, dw2_build_landing_pads): Be ready for + regions without label but with live RESX. + * except.h (redirect_eh_edge_to_label): New. + * tree-flow.h (redirect_eh_edge): New. + * coretypes.h (edge_def, edge, const_edge, basic_block_def + basic_block_def, basic_block, const_basic_block): Remove. + * Makefile.in (except.o): Add dependency on tree-flow.h + * tree-cfg.c (gimple_redirect_edge_and_branch): Handle EH edges. + * basic-block.h (edge, const_edge, basic_block, const_basic_block): + Remove. + +2009-04-25 Eric Botcazou <ebotcazou@adacore.com> + + PR bootstrap/39645 + * config/sparc/sparc.c (sparc_gimplify_va_arg): Set TREE_ADDRESSABLE + on the destination of memcpy. + +2009-04-25 Paolo Bonzini <bonzini@gnu.org> + + * doc/tm.texi (REGNO_OK_FOR_BASE_P, REGNO_MODE_OK_FOR_BASE_P, + REGNO_MODE_OK_FOR_REG_BASE_P, REGNO_MODE_CODE_OK_FOR_BASE_P, + REGNO_OK_FOR_INDEX_P): Mention strict/nonstrict difference. + +2009-04-25 Jan Hubicka <jh@suse.cz> + + * tree-eh.c (tree_remove_unreachable_handlers): Handle shared labels. + (tree_empty_eh_handler_p): Allow non-EH predecestors; allow region + to be reached by different label than left. + (update_eh_edges): Update comment; remove edge_to_remove if possible + and return true if suceeded. + (cleanup_empty_eh): Accept sharing map; handle shared regions. + (cleanup_eh): Compute sharing map. + * except.c (remove_eh_handler_and_replace): Add argument if we should + update regions. + (remove_unreachable_regions): Update for label sharing. + (label_to_region_map): Likewise. + (get_next_region_sharing_label): New function. + (remove_eh_handler_and_replace): Add update_catch_try parameter; update + prev_try pointers. + (remove_eh_handler): Update. + (remove_eh_region_and_replace_by_outer_of): New function. + * except.h (struct eh_region): Add next_region_sharing_label. + (remove_eh_region_and_replace_by_outer_of, + get_next_region_sharing_label): Declare. + * tree-cfgcleanup.c (tree_forwarder_block_p): Simplify. + +2009-04-25 Jan Hubicka <jh@suse.cz> + + * tree-cfg.c (split_critical_edges): Split also edges where we can't + insert code even if they are not critical. + +2009-04-25 Jan Hubicka <jh@suse.cz> + + * tree-cfg.c (gimple_can_merge_blocks_p): EH edges are unmergable. + (gimple_can_remove_branch_p): EH edges won't remove branch by + redirection. + * tree-inline.c (update_ssa_across_abnormal_edges): Do handle + updating of non-abnormal EH edges. + * tree-cfg.c (gimple_can_merge_blocks_p): EH edges are unmergable. + (gimple_can_remove_branch_p): EH edges are unremovable by redirection. + (split_critical_edges): Split also edges where emitting code on them + will lead to splitting later. + +2009-04-25 Uros Bizjak <ubizjak@gmail.com> + H.J. Lu <hongjiu.lu@intel.com> + + PR target/39590 + * configure.ac (HAVE_AS_IX86_FILDQ): On x86 targets check whether + the configured assembler supports fildq and fistpq mnemonics. + (HAVE_AS_IX86_FILDS): Rename from HAVE_GAS_FILDS_FISTS. + * configure: Regenerated. + * config.in: Ditto. + + * config/i386/i386.c (print_operand): Handle 'Z'. + ['z']: Remove handling of special fild/fist suffixes. + (output_fix_trunc): Use '%Z' to output suffix of fist{,p,tp} insn. + * config/i386/i386.md (*floathi<mode>2_i387): Use '%Z' to output + suffix of fild insn. + (*floatsi<mode>2_vector_mixed): Ditto. + (*float<SSEMODEI24:mode><MODEF:mode>2_mixed_interunit): Ditto. + (*float<SSEMODEI24:mode><MODEF:mode>2_mixed_nointerunit): Ditto. + (*float<SSEMODEI24:mode><X87MODEF:mode>2_i387_with_temp): Ditto. + (*float<SSEMODEI24:mode><X87MODEF:mode>2_i387): Ditto. + * config/i386/gas.h (GAS_MNEMONICS): Remove. + +2009-04-25 Ben Elliston <bje@au.ibm.com> + + * genrecog.c (validate_pattern): Do not warn for VOIDmode CALLs as + the source of a set operation. + +2009-04-25 Anatoly Sokolov <aesok@post.ru> + + * target.h (struct gcc_target): Add case_values_threshold field. + * target-def.h (TARGET_CASE_VALUES_THRESHOLD): New. + (TARGET_INITIALIZER): Use TARGET_CASE_VALUES_THRESHOLD. + * targhooks.c (default_case_values_threshold): New function. + * targhooks.h (default_case_values_threshold): Declare function. + * stmt.c (expand_case): Use case_values_threshold target hook. + * expr.h (case_values_threshold): Remove declartation. + * expr.c (case_values_threshold): Remove function. + * doc/tm.texi (CASE_VALUES_THRESHOLD): Revise documentation. + + * config/avr/avr.h (CASE_VALUES_THRESHOLD): Remove macro. + * config/avr/avr.c (TARGET_CASE_VALUES_THRESHOLD): Define macro. + (avr_case_values_threshold): Declare as static. + * config/avr/avr-protos.h (avr_case_values_threshold): Remove. + + * config/avr/mn10300.h (CASE_VALUES_THRESHOLD): Remove macro. + * config/avr/mn10300.c (TARGET_CASE_VALUES_THRESHOLD): Define macro. + (mn10300_case_values_threshold): New function. + +2009-04-24 H.J. Lu <hongjiu.lu@intel.com> + + * ira.c (setup_cover_and_important_classes): Add enum cast. + +2009-04-24 Vladimir Makarov <vmakarov@redhat.com> + + * genpreds.c (write_enum_constraint_num): Output definition of + CONSTRAINT_NUM_DEFINED_P macro. + * ira.c (setup_cover_and_important_classes): Use + CONSTRAINT_NUM_DEFINED_P instead of CONSTRAINT__LIMIT in #ifdef. + +2009-04-24 DJ Delorie <dj@redhat.com> + + * config/sh/sh.h (LIBGCC2_DOUBLE_TYPE_SIZE): Test + __SH2A_SINGLE_ONLY__ also. + +2009-04-24 Steve Ellcey <sje@cup.hp.com> + + * config/ia64/ia64.md (movfs_internal): Allow flt constants. + (movdf_internal): Ditto. + * config/ia64/ia64.c (ia64_legitimate_constant_p): Allow + SFmode and DFmode constants. + (ia64_print_operand): Add 'G' format for printing + floating point constants. + +2009-04-24 Richard Guenther <rguenther@suse.de> + + * tree-vrp.c (extract_range_from_binary_expr): Handle overflow + from unsigned additions. + +2009-04-24 Joseph Myers <joseph@codesourcery.com> + + * c-typeck.c (set_init_index): Allow array designators that are + not integer constant expressions with a pedwarn if pedantic. + +2009-04-24 Bernd Schmidt <bernd.schmidt@analog.com> + + * simplify-rtx.c (simplify_binary_operation_1, case AND): Result is + zero if no overlap in nonzero bits between the operands. + +2009-04-24 Ian Lance Taylor <iant@google.com> + + * combine.c (record_value_for_reg): Change 0 to VOIDmode, twice. + (record_dead_and_set_regs): Likewise. + * df.h (struct df_mw_hardreg): Change flags field to int. + (struct df_base_ref): Likewise. + (struct df): Change changeable_flags field to int. + * df-scan.c (df_defs_record): Change clobber_flags to int. + * dwarf2.h (enum dwarf_tag): Make lo_user and hi_user values enum + constants rather than #define macros. + (enum dwarf_attribute, enum dwarf_location_atom): Likewise. + (enum dwarf_type, enum dwarf_endianity_encoding): Likewise. + (enum dwarf_calling_convention): Likewise. + (enum dwarf_line_number_x_ops): Likewise. + (enum dwarf_call_frame_info): Likewise. + (enum dwarf_source_language): Likewise. + * dwarf2out.c (int_loc_descriptor): Add cast to enum type. + (add_calling_convention_attribute): Likewise. + * fold-const.c (fold_undefer_overflow_warnings): Add cast to enum type. + (combine_comparisons): Change compcode to int. Add cast to enum type. + * genrecog.c (maybe_both_true_2): Change c to int. + (write_switch): Likewise. Add cast to enum type. + * gimplify.c (gimplify_omp_for): Handle return values from + gimplify_expr using MIN rather than bitwise or. + (gimplify_expr): Add cast to enum type. + * ipa-prop.c (update_jump_functions_after_inlining): Change + IPA_BOTTOM to IPA_JF_UNKNOWN. + * ira.c (setup_class_subset_and_memory_move_costs): Change mode to int. + Add casts to enum type. + (setup_cover_and_important_classes): Change cl to int. Add casts + to enum type. + (setup_class_translate): Change cl and mode to int. + (ira_init_once): Change mode to int. + (free_register_move_costs): Likewise. + (setup_prohibited_mode_move_regs): Add casts to enum type. + * langhooks.c (add_builtin_function_common): Rework assertion that + value fits bitfield. + * mcf.c (add_fixup_edge): Change type parameter to edge_type. + * omega.c (omega_do_elimination): Avoid math on enum types. + * optabs.c (expand_vec_shift_expr): Remove casts to int. + * opts.c (set_debug_level): Change 2 to enum constant. Use new + int local to handle integral_argment value. + * regmove.c (try_auto_increment): Change PUT_MODE to + PUT_REG_NOTE_KIND. + * reload.c (push_secondary_reload): Add casts to enum type. + (secondary_reload_class, find_valid_class): Likewise. + * reload1.c (emit_input_reload_insns): Likewise. + * rtl.h (NOTE_VAR_LOCATION_STATUS): Likewise. + * sel-sched.c (init_hard_regs_data): Change cur_mode to int. + * sel-sched-ir.c (hash_with_unspec_callback): Change 0 to enum + constant. + * tree.c (build_common_builtin_nodes): Add casts to enum type. + * tree-complex.c (complex_lattice_t): Typedef to int rather than + enum type. + (expand_complex_libcall): Add casts to enum type. + * tree-into-ssa.c (get_ssa_name_ann): Change 0 to enum constant. + * tree-vect-loop.c (vect_model_reduction_cost): Compare reduc_code + with ERROR_MARK, not NUM_TREE_CODES. + (vect_create_epilog_for_reduction): Likewise. + (vectorizable_reduction): Don't initialize epiloc_reduc_code. + When not using it, set it to ERROR_MARK rather than NUM_TREE_CODES. + * tree-vect-patterns.c (vect_pattern_recog_1): Change vec_mode to + enum machine_mode. + * tree-vect-stmts.c (new_stmt_vec_info): Change 0 to + vect_unused_in_loop. Change 0 to loop_vect. + * tree-vectorizer.c (vect_set_verbosity_level): Add casts to enum type. + * var-tracking.c (get_init_value): Change return type to enum + var_init_status. + * vec.h (DEF_VEC_FUNC_P) [iterate]: Cast 0 to type T. + * config/arm/arm.c (fp_model_for_fpu): Change to array to enum + arm_fp_model. + (arm_override_options): Add casts to enum type. + (arm_emit_tls_decoration): Likewise. + * config/i386/i386.c (ix86_function_specific_restore): Add casts + to enum type. + * config/i386/i386-c.c (ix86_pragma_target_parse): Likewise. + * config/ia64/ia64.c (ia64_expand_compare): Change magic to int. + * config/rs6000/rs6000.c (rs6000_override_options): Add casts to + enum type. + * config/s390/s390.c (code_for_builtin_64): Change to array of + enum insn_code. + (code_for_builtin_31): Likewise. + (s390_expand_builtin): Change code_for_builtin to enum insn_code + const *. + * config/sparc/sparc.c (sparc_override_options): Change value + field in struct code_model to enum cmodel. In initializer change + 0 to NULL and add cast to enum type. + + * c-typeck.c (build_modify_expr): Add lhs_origtype parameter. + Change all callers. Issue a -Wc++-compat warning using + lhs_origtype if necessary. + (convert_for_assignment): Issue -Wc++-compat warnings about + invalid conversions to enum type on assignment. + * c-common.h (build_modify_expr): Update declaration. + +2009-04-24 Nick Clifton <nickc@redhat.com> + + * config/iq2000/iq2000.c (function_arg): Handle TImode values. + (function_arg_advance): Likewise. + * config/iq2000/iq2000.md (movsi_internal2): Fix the length of the + 5th alternative. + +2009-04-24 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/constraints.md ('I', 'J'): Fix condition. + +2009-04-24 Diego Novillo <dnovillo@google.com> + + * gengtype-parse.c (parse_error): Add newline after message. + +2009-04-24 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/sse.md (avxmodesuffixs): Removed. + (*avx_pinsr<avxmodesuffixs>): Renamed to ... + (*avx_pinsr<ssevecsize>): This. + +2009-04-24 Bernd Schmidt <bernd.schmidt@analog.com> + + * loop-iv.c (replace_single_def_regs): Look for REG_EQUAL notes; + follow chains of regs with a single definition, and allow expressions + that are function_invariant_p. + (simple_rhs_p): Allow expressions that are function_invariant_p. + +2009-04-24 Paolo Bonzini <bonzini@gnu.org> + + PR middle-end/39867 + * fold-const.c (fold_cond_expr_with_comparison): When folding + > and >= to MAX, make sure the MAX uses the same type as the + comparison's operands. + +2009-04-24 Nick Clifton <nickc@redhat.com> + + * config/frv/frv.c (frv_frame_access): Do not use reg+reg + addressing for DImode accesses. + (frv_print_operand_address): Handle PLUS case. + * config/frv/frv.h (FIXED_REGISTERS): Mark link register as fixed. + +2009-04-24 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/39794 + * alias.c (canon_true_dependence): Add x_addr argument. + * rtl.h (canon_true_dependence): Adjust prototype. + * cse.c (check_dependence): Adjust canon_true_dependence callers. + * cselib.c (cselib_invalidate_mem): Likewise. + * gcse.c (compute_transp): Likewise. + * dse.c (scan_reads_nospill): Likewise. + (record_store, check_mem_read_rtx): Likewise. For non-const-or-frame + addresses pass base->val_rtx as mem_addr, for const-or-frame addresses + canon_base_addr of the group, plus optional offset. + (struct group_info): Rename canon_base_mem to + canon_base_addr. + (get_group_info): Set canon_base_addr to canon_rtx of base, not + canon_rtx of base_mem. + +2009-04-23 Paolo Bonzini <bonzini@gnu.org> + + * config/sh/sh.c (sh_expand_prologue, sh_expand_epilogue): + Use memory_address_p instead of GO_IF_LEGITIMATE_ADDRESS. + +2009-04-23 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * config/spu/spu-builtins.h: Delete file. + + * config/spu/spu.h (enum spu_builtin_type): Move here from + spu-builtins.h. + (struct spu_builtin_description): Likewise. Add GTY marker. + Do not use enum spu_function_code or enum insn_code. + (spu_builtins): Add extern declaration. + + * config/spu/spu.c: Do not include "spu-builtins.h". + (enum spu_function_code, enum spu_builtin_type_index, + V16QI_type_node, V8HI_type_node, V4SI_type_node, V2DI_type_node, + V4SF_type_node, V2DF_type_node, unsigned_V16QI_type_node, + unsigned_V8HI_type_node, unsigned_V4SI_type_node, + unsigned_V2DI_type_node): Move here from spu-builtins.h. + (spu_builtin_types): Make static. Add GTY marker. + (spu_builtins): Add extern declaration with GTY marker. + Include "gt-spu.h". + + * config/spu/spu-c.c: Do not include "spu-builtins.h". + (spu_resolve_overloaded_builtin): Do not use spu_function_code. + Check programmatically whether all parameters are scalar. + + * config/spu/t-spu-elf (spu.o, spu-c.o): Update dependencies. + +2009-04-23 Eric Botcazou <ebotcazou@adacore.com> + + * gimplify.c (gimplify_modify_expr_rhs) <VAR_DECL>: Do not do a direct + assignment from the constructor either if the target is volatile. + +2009-04-23 Daniel Jacobowitz <dan@codesourcery.com> + + * config/arm/arm.md (insv): Do not share operands[0]. + +2009-04-23 Nathan Sidwell <nathan@codesourcery.com> + + * config/vxlib-tls.c (active_tls_threads): Delete. + (delete_hook_installed): New. + (tls_delete_hook): Don't delete the delete hook. + (tls_destructor): Delete it here. + (__gthread_set_specific): Adjust installing the delete hook. + (tls_delete_hook): Use __gthread_enter_tsd_dtor_context and + __gthread_leave_tsd_dtor_context. + +2009-04-23 Rafael Avila de Espindola <espindola@google.com> + + * c-format.c (gcc_tdiag_char_table): Add support for %E. + +2009-04-23 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_legitimize_reload_address): Add cast to + enum type. + (alpha_rtx_costs): Ditto. + (emit_unlikely_jump): Use add_reg_note. + (emit_frame_store_1): Ditto. + (alpha_expand_prologue): Ditto. + (alpha_expand_builtin): Change 0 to EXPAND_NORMAL in function call. + * config/alpha/alpha.c (Unicos/Mk address splitter): Use add_reg_note. + +2009-04-23 Nick Clifton <nickc@redhat.com> + + * config/v850/v850.md (epilogue): Remove suppressed code. + (return): Rename to return_simple and remove test of frame size. + * config/v850/v850.c (expand_epilogue): Rename call to gen_return + to gen_return_simple. + +2009-04-22 Jing Yu <jingyu@google.com> + + PR testsuite/39781 + * config/arm/arm.h: Define HANDLE_PRAGMA_PACK_PUSH_POP. + +2009-04-22 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR C/31499 + * c-typeck.c (process_init_element): Treat VECTOR_TYPE like ARRAY_TYPE + and RECORD_TYPE/UNION_TYPE. When outputing the actual element and the + value is a VECTOR_CST, the element type is the element type of the + vector. + +2009-04-22 DJ Delorie <dj@redhat.com> + + * config/m32c/m32c.h: Update GTY annotations to new syntax. + +2009-04-22 Jakub Jelinek <jakub@redhat.com> + + * alias.c (find_base_term): Move around LO_SUM case, so that + CONST falls through into PLUS/MINUS handling. + + PR c/39855 + * fold-const.c (fold_binary) <case LSHIFT_EXPR>: When optimizing + into 0, use omit_one_operand. + +2009-04-23 Ben Elliston <bje@au.ibm.com> + + * config/rs6000/linux-unwind.h (get_regs): Remove type + puns. Change the type of `pc' to an array of unsigned ints and + update all users. Constify frame24. + +2009-04-22 DJ Delorie <dj@redhat.com> + + * config/m32c/m32c.c (m32c_special_page_vector_p): Move + declarations before code. + (current_function_special_page_vector): Likewise. + (m32c_expand_insv): Silence a warning. + +2009-04-21 Taras Glek <tglek@mozilla.com> + + * alias.c: Update GTY annotations to new syntax. + * basic-block.h: Likewise. + * bitmap.h: Likewise. + * c-common.h: Likewise. + * c-decl.c: Likewise. + * c-parser.c: Likewise. + * c-pragma.c: Likewise. + * c-tree.h: Likewise. + * cfgloop.h: Likewise. + * cgraph.h: Likewise. + * config/alpha/alpha.c: Likewise. + * config/arm/arm.h: Likewise. + * config/avr/avr.h: Likewise. + * config/bfin/bfin.c: Likewise. + * config/cris/cris.c: Likewise. + * config/darwin.c: Likewise. + * config/frv/frv.c: Likewise. + * config/i386/i386.c: Likewise. + * config/i386/i386.h: Likewise. + * config/i386/winnt.c: Likewise. + * config/ia64/ia64.h: Likewise. + * config/iq2000/iq2000.c: Likewise. + * config/mips/mips.c: Likewise. + * config/mmix/mmix.h: Likewise. + * config/pa/pa.c: Likewise. + * config/pa/pa.h: Likewise. + * config/rs6000/rs6000.c: Likewise. + * config/s390/s390.c: Likewise. + * config/sparc/sparc.c: Likewise. + * config/xtensa/xtensa.c: Likewise. + * cselib.h: Likewise. + * dbxout.c: Likewise. + * dwarf2out.c: Likewise. + * except.c: Likewise. + * except.h: Likewise. + * fixed-value.h: Likewise. + * function.c: Likewise. + * function.h: Likewise. + * gimple.h: Likewise. + * integrate.c: Likewise. + * optabs.c: Likewise. + * output.h: Likewise. + * real.h: Likewise. + * rtl.h: Likewise. + * stringpool.c: Likewise. + * tree-data-ref.c: Likewise. + * tree-flow.h: Likewise. + * tree-scalar-evolution.c: Likewise. + * tree-ssa-address.c: Likewise. + * tree-ssa-alias.h: Likewise. + * tree-ssa-operands.h: Likewise. + * tree.c: Likewise. + * tree.h: Likewise. + * varasm.c: Likewise. + * varray.h: Likewise. + * vec.h: Likewise. + * coretypes.h: Do not define GTY macro if it is already defined. + * doc/gty.texi: Update GTY documentation to new syntax. + * gengtype-lex.l: Enforce attribute-like syntax for GTY + annotations on structs. + * gengtype-parse.c: Likewise. + +2009-04-22 Mark Heffernan <meheff@google.com> + + * gcc.c (LINK_COMMAND_SPEC): Link with gcov with -fprofile-generate=. + +2009-04-22 Kazu Hirata <kazu@codesourcery.com> + + * config/arm/arm.c (arm_rtx_costs_1): Use power_of_two_operand + where appropriate. + +2009-04-22 Kazu Hirata <kazu@codesourcery.com> + + * config/arm/arm.c (arm_size_rtx_costs): Treat a PLUS with a shift + the same as a PLUS without a shift. Increase the cost of a + CONST_INT in MULT. + +2009-04-22 Manuel Lopez-Ibanez <manu@gcc.gnu.org> + + * Makefile.in: Update dependencies. + * errors.c (warning): Remove unused parameter 'opt'. Returns 'void'. + * errors.h: Remove bogus comment about compatibility. + (warning): Update declaration. + * genautomata.c: Update all calls to warning. + * gimple.c: Do not include errors.h. Include toplev.h. + * tree-ssa-structalias.c: Do not include errors.h. + * omega.c: Likewise. + * tree-ssa-reassoc.c: Likewise. + * config/spu/spu-c.c: Likewise. + * config/spu/t-spu-elf: Update dependencies. + +2009-04-22 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39824 + * tree-ssa-ccp.c (fold_const_aggregate_ref): For INDIRECT_REFs + make sure the types are compatible. + +2009-04-22 Manuel Lopez-Ibanez <manu@gcc.gnu.org> + + PR c++/14875 + * c-common.c (c_parse_error): Take a token_flags parameter. + Use token_type for the token type instead. + Pass token_flags to cpp_type2name. + * c-common.h (c_parse_error): Update declaration. + * c-parser.c (c_parser_error): Pass 0 as token flags. + +2009-04-22 Andrey Belevantsev <abel@ispras.ru> + + PR rtl-optimization/39580 + * sel-sched-ir.c (insert_in_history_vect): Remove incorrect gcc_assert. + +2009-04-22 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * function.c (expand_function_end): Do not emit a jump to the "naked" + return label for fall-through returns. + * except.c (sjlj_emit_function_exit): Always place the call to the + unregister function at the location installed by expand_function_end. + +2009-04-22 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39845 + * tree-switch-conversion.c (build_arrays): Add new referenced vars. + (gen_inbound_check): Likewise. + +2009-04-22 Nathan Sidwell <nathan@codesourcery.com> + + * gthr-vxworks.h (struct __gthread_once_t): Add alignment and + padding for PPC. + (__GTHREAD_ONCE_INIT): Adjust ppc initializer. + * config/vxlib.c (__gthread_once): Add race guard for PPC. + +2009-04-22 Paolo Bonzini <bonzini@gnu.org> + + * config/sh/sh.c (shift_insns_rtx, shiftcosts, gen_shifty_op, + sh_dynamicalize_shift_p, shl_and_scr_length): Truncate + shift counts to avoid out-of-bounds array accesses. + +2009-04-22 Paolo Bonzini <bonzini@gnu.org> + + * config/sparc/sparc.h (POINTER_SIZE): Fix comment. + (Pmode): Move above. + +2009-04-22 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c: Use REG_P, MEM_P, CONST_INT_P, JUMP_P, + NONJUMP_INSN_P, CALL_P, LABEL_P and NOTE_P predicates instead of + GET_CODE macro. Use IN_RANGE macro where appropriate. + * config/alpha/alpha.h: Ditto. + * config/alpha/alpha.md: Ditto. + * config/alpha/constraints.md: Ditto. + * config/alpha/predicates.md: Ditto. + +2009-04-22 Paolo Bonzini <bonzini@gnu.org> + + * defaults.h (GO_IF_MODE_DEPENDENT_ADDRESS): Provide empty default. + * config/frv/frv.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/s390/s390.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/m32c/m32c.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/spu/spu.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/i386/i386.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/sh/sh.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/pdp11/pdp11.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/avr/avr.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/crx/crx.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/fr30/fr30.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/m68hc11/m68hc11.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/cris/cris.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/iq2000/iq2000.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/mn10300/mn10300.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/ia64/ia64.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/m68k/m68k.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/picochip/picochip.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/arc/arc.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/mcore/mcore.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/score/score.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/arm/arm.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/pa/pa.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/mips/mips.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/v850/v850.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/mmix/mmix.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + * config/bfin/bfin.h (GO_IF_MODE_DEPENDENT_ADDRESS): Delete. + +2009-04-22 Laurynas Biveinis <laurynas.biveinis@gmail.com> + + * cfghooks.c (tidy_fallthru_edges): Remove find_basic_blocks + references from comments. + * cfgbuild.c (count_basic_blocks): Delete. + (find_basic_blocks_1): Delete. + (find_basic_blocks): Delete. + * except.c (finish_eh_generation): Make static. Move comment from + except.h here. Remove find_basic_blocks references from comments. + * except.h (finish_eh_generation): Delete. + * basic-block.h (find_basic_blocks): Delete. + * config/sh/sh.c (sh_output_mi_thunk): Delete a "#if 0" block. + +2009-04-22 Dave Korn <dave.korn.cygwin@gmail.com> + + * sdbout.c (sdbout_symbol): Pass VOIDmode to eliminate_regs. + (sdbout_parms): Likewise. + +2009-04-21 Kaz Kojima <kkojima@gcc.gnu.org> + + * config/sh/sh.c (prepare_cbranch_operands): Use + LAST_AND_UNUSED_RTX_CODE instead of CODE_FOR_nothing. + (expand_cbranchdi4): Likewise. + (from_compare): Add cast to enum type. + (expand_cbranchsi4): Use add_reg_note. + (output_stack_adjust, push, pop, sh_expand_prologue): Likewise. + (sh_insn_length_adjustment): Use sh_cpu_attr instead of sh_cpu. + (sh_initialize_trampoline): Change 0 to LCT_NORMAL in function call. + (sh_expand_builtin): Change 0 to EXPAND_NORMAL in function call. + * config/sh/sh.md (cbranchsi4): Use LAST_AND_UNUSED_RTX_CODE + instead of CODE_FOR_nothing. + (cbranchdi4): Likewise. Fix the order of arguments for + gen_rtx_fmt_ee. + (push_fpscr): Use add_reg_note. + (pop_fpscr, movdf_i4+1, reload_outdf__RnFRm+3, reload_outdf__RnFRm+4, + reload_outdf__RnFRm+5, fpu_switch+1, fpu_switch+2): Likewise. + +2009-04-21 Joseph Myers <joseph@codesourcery.com> + + * ABOUT-GCC-NLS, ChangeLog, ChangeLog-1997, ChangeLog-1998, + ChangeLog-1999, ChangeLog-2000, ChangeLog-2001, ChangeLog-2002, + ChangeLog-2003, ChangeLog-2004, ChangeLog-2005, ChangeLog-2006, + ChangeLog-2007, ChangeLog-2008, ChangeLog.dataflow, ChangeLog.lib, + ChangeLog.ptr, ChangeLog.tree-ssa, ChangeLog.tuples, FSFChangeLog, + FSFChangeLog.10, FSFChangeLog.11, LANGUAGES, ONEWS, acinclude.m4, + config/alpha/gnu.h, config/alpha/libgcc-alpha-ldbl.ver, + config/alpha/t-osf4, config/alpha/t-vms, config/alpha/va_list.h, + config/alpha/x-vms, config/arc/t-arc, + config/arm/README-interworking, config/arm/arm-c.c, + config/arm/gentune.sh, config/arm/libgcc-bpabi.ver, + config/arm/t-arm, config/arm/t-arm-elf, config/arm/t-arm-softfp, + config/arm/t-bpabi, config/arm/t-linux, config/arm/t-linux-eabi, + config/arm/t-netbsd, config/arm/t-pe, config/arm/t-strongarm-elf, + config/arm/t-symbian, config/arm/t-vxworks, config/arm/t-wince-pe, + config/avr/t-avr, config/bfin/elf.h, config/bfin/libgcc-bfin.ver, + config/bfin/linux.h, config/bfin/t-bfin, config/bfin/t-bfin-elf, + config/bfin/t-bfin-linux, config/bfin/t-bfin-uclinux, + config/bfin/uclinux.h, config/cris/mulsi3.asm, config/cris/t-cris, + config/cris/t-elfmulti, config/crx/t-crx, + config/darwin-ppc-ldouble-patch.def, config/darwin-sections.def, + config/divmod.c, config/fr30/t-fr30, config/frv/libgcc-frv.ver, + config/frv/t-frv, config/frv/t-linux, config/h8300/genmova.sh, + config/h8300/t-h8300, config/i386/athlon.md, + config/i386/darwin-libgcc.10.4.ver, + config/i386/darwin-libgcc.10.5.ver, config/i386/libgcc-glibc.ver, + config/i386/mach.h, config/i386/netbsd.h, config/i386/t-crtpc, + config/i386/t-cygming, config/i386/t-cygwin, config/i386/t-i386, + config/i386/t-linux64, config/i386/t-nwld, + config/i386/t-rtems-i386, config/i386/t-sol2-10, + config/i386/x-mingw32, config/ia64/div.md, config/ia64/elf.h, + config/ia64/ia64.opt, config/ia64/libgcc-glibc.ver, + config/ia64/libgcc-ia64.ver, config/ia64/linux.h, + config/ia64/sysv4.h, config/ia64/t-hpux, config/ia64/t-ia64, + config/iq2000/abi, config/iq2000/lib2extra-funcs.c, + config/iq2000/t-iq2000, config/libgcc-glibc.ver, + config/m32r/libgcc-glibc.ver, config/m32r/t-linux, + config/m32r/t-m32r, config/m68hc11/t-m68hc11, + config/m68k/t-floatlib, config/m68k/t-linux, config/m68k/t-mlibs, + config/m68k/t-uclinux, config/mcore/t-mcore, + config/mcore/t-mcore-pe, config/mips/20kc.md, config/mips/4130.md, + config/mips/5400.md, config/mips/5500.md, config/mips/crti.asm, + config/mips/crtn.asm, config/mips/irix-crti.asm, + config/mips/irix-crtn.asm, config/mips/libgcc-mips16.ver, + config/mips/mips-dsp.md, config/mips/mips-dspr2.md, + config/mips/mips-fixed.md, config/mips/sb1.md, + config/mips/sr71k.md, config/mips/t-elf, config/mips/t-gofast, + config/mips/t-iris6, config/mips/t-isa3264, + config/mips/t-libgcc-mips16, config/mips/t-linux64, + config/mips/t-mips, config/mips/t-r3900, config/mips/t-rtems, + config/mips/t-sb1, config/mips/t-sde, config/mips/t-sdemtk, + config/mips/t-slibgcc-irix, config/mips/t-sr71k, config/mips/t-st, + config/mips/t-vr, config/mips/t-vxworks, config/mmix/t-mmix, + config/mn10300/t-linux, config/mn10300/t-mn10300, + config/pa/pa32-regs.h, config/pa/t-hpux-shlib, config/pa/t-linux, + config/pa/t-linux64, config/pa/t-pa64, config/pdp11/t-pdp11, + config/picochip/libgccExtras/clzsi2.asm, + config/picochip/t-picochip, config/rs6000/darwin-ldouble-format, + config/rs6000/darwin-libgcc.10.4.ver, + config/rs6000/darwin-libgcc.10.5.ver, + config/rs6000/libgcc-ppc-glibc.ver, config/rs6000/ppc-asm.h, + config/rs6000/t-aix43, config/rs6000/t-aix52, + config/rs6000/t-darwin, config/rs6000/t-fprules, + config/rs6000/t-fprules-fpbit, config/rs6000/t-linux64, + config/rs6000/t-lynx, config/rs6000/t-netbsd, + config/rs6000/t-ppccomm, config/rs6000/t-ppcendian, + config/rs6000/t-ppcgas, config/rs6000/t-rs6000, + config/rs6000/t-rtems, config/rs6000/t-spe, + config/rs6000/t-vxworks, config/s390/libgcc-glibc.ver, + config/score/t-score-elf, config/sh/divcost-analysis, + config/sh/libgcc-glibc.ver, config/sh/t-netbsd, config/sh/t-sh, + config/sh/t-sh64, config/sh/t-superh, config/sh/t-symbian, + config/sparc/libgcc-sparc-glibc.ver, config/sparc/sol2-bi.h, + config/sparc/sol2-gas.h, config/sparc/sol2-gld-bi.h, + config/sparc/t-elf, config/sparc/t-linux64, config/sparc/t-sol2, + config/stormy16/stormy-abi, config/stormy16/t-stormy16, + config/t-darwin, config/t-libunwind, config/t-libunwind-elf, + config/t-linux, config/t-lynx, config/t-slibgcc-elf-ver, + config/t-slibgcc-sld, config/t-sol2, config/t-vxworks, + config/udivmod.c, config/udivmodsi4.c, config/v850/t-v850, + config/v850/t-v850e, config/xtensa/t-xtensa, diagnostic.def, + gdbinit.in, glimits.h, gstab.h, gsyms.h, java/ChangeLog, + java/ChangeLog.ptr, java/ChangeLog.tree-ssa, libgcc-std.ver, + limitx.h, version.c, xcoff.h: Add copyright and license notices. + * config/h8300/genmova.sh: Include copyright and license notices + in generated output. + * config/h8300/mova.md: Regenerate. + * doc/install.texi2html: Include word "Copyright" in copyright + notice and use name "Free Software Foundation, Inc.". + * ChangeLog, ChangeLog-2000, ChangeLog-2001, ChangeLog-2002, + ChangeLog-2003, ChangeLog-2004, ChangeLog-2005, ChangeLog-2006, + ChangeLog-2007, ChangeLog-2008: Correct dates. + +2009-04-21 Eric Botcazou <ebotcazou@adacore.com> + + * c-common.c (c_common_truthvalue_conversion): Use LOCATION to build + NE_EXPR operations as well. + * c-parser.c (c_parser_condition): Do not set location information on + the condition. + (c_parser_conditional_expression): Likewise. + (c_parser_binary_expression): Set location information on operators. + * c-typeck.c (build_unary_op) <TRUTH_NOT_EXPR>: Reset the location if + TRUTH_NOT_EXPR has been folded. + * fold-const.c (fold_truth_not_expr): Copy location information from + the incoming expression to the outgoing one. + * gimplify.c (shortcut_cond_r): Add locus parameter. Pass it to + recursive calls on the LHS of the operator but pass that of the + operator to recursive calls on the RHS of the operator. Set it + on the COND_EXPR. + (shortcut_cond_expr): Set the locus of the operator on the second + COND_EXPR and that of the expression on the first in degenerate cases. + Pass the locus of the expression to calls to shortcut_cond_r. + Set the locus of the 'then' block on the associated jump, if any. + (gimplify_boolean_expr): Add locus parameter. Set it on the COND_EXPR. + (gimplify_expr) <TRUTH_ANDIF_EXPR>: Pass the locus of the outer + expression to call to gimplify_boolean_expr. + +2009-04-21 Kai Tietz <kai.tietz@onevision.com> + + * config.gcc: Add additional configuration for + i686-w64-mingw* and x86_64-w64-mingw* triplet. + * config/i386/mingw-w64.h: New mingw-w64 specific header. + (CPP_SPEC): Redefine for allowing -municode option. + (STARTFILE_SPEC): Likewise. + * config/i386/t-mingw-w64: New. + * config/i386/mingw-w64.opt: New. + (municode): Add new target option. + * doc/invoke.texi (municode): Add documentation for new option. + +2009-04-21 Ian Lance Taylor <iant@google.com> + + * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): + Correct test for number of arguments. + * config/spu/spu-c.c (spu_resolve_overloaded_builtin): Likewise. + +2009-04-21 Andreas Schwab <schwab@linux-m68k.org> + + * config/m68k/linux.h (FINALIZE_TRAMPOLINE): Use enum for second + argument of emit_library_call. + +2009-04-21 Richard Guenther <rguenther@suse.de> + + PR middle-end/39829 + * gimple.c (walk_stmt_load_store_addr_ops): Catch addresses + inside VIEW_CONVERT_EXPRs. + +2009-04-21 Martin Jambor <mjambor@suse.cz> + + * tree-switch-conversion.c (build_constructors): Split a long line. + (constructor_contains_same_values_p): New function. + (build_one_array): Create assigns of constants if possible, do not + call mark_sym_for_renaming, call update_stmt. + (build_arrays): Call make_ssa_name (create_tmp_var ()) instead of + make_rename_temp. Do not call mark_symbols_for_renaming, call + update_stmt. + (gen_def_assigns): Do not call mark_symbols_for_renaming or + find_new_referenced_vars, call update_stmt. + (gen_inbound_check): Use create_tmp_var and create ssa names manually + instead of calling make_rename_temp. Do not call + find_new_referenced_vars or mark_symbols_for_renaming, call + update_stmt. + +2009-04-21 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39827 + * tree-ssa-phiprop.c (propagate_with_phi): Check SSA_NAME is in range. + (tree_ssa_phiprop): Pass the correct array size. + +2009-04-21 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.md (tune): Add cast to enum attr_tune. + +2009-04-21 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR 16202 + * c-typeck.c (lvalue_p): Move declaration ... + * c-common.h (lvalue_p): ... to here. + * c-common.c (candidate_equal_p): New. + (add_tlist): Use it. + (merge_tlist): Use it. + (warn_for_collisions_1): Likewise. + (warning_candidate_p): Accept more candidates. + (verify_tree): A warning candidate can be an expression. Use + candidate_equal_p. + +2009-04-21 Ben Elliston <bje@au.ibm.com> + + PR target/5267 + * doc/invoke.texi (RS/6000 and PowerPC Options): Add documentation + for -mcall-eabi, -mcall-aixdesc, -mcall-freebsd and -mcall-openbsd + options. Remove -mcall-solaris documentation. + +2009-04-21 Manuel Lopez-Ibanez <manu@gcc.gnu.org> + + PR c++/13358 + * doc/invoke.texi (-Wlong-long): Update description. + * c-lex (interpret_integer): Only warn if there was no previous + overflow and -Wlong-long is enabled. + * c-decl.c (declspecs_add_type): Drop redundant flags. + * c.opt (Wlong-long): Init to -1. + * c-opts.c (sanitize_cpp_opts): Synchronize cpp's warn_long_long + and front-end warn_long_long. Wlong-long only depends on other + flags if it is uninitialized. + * c-parser.c (disable_extension_diagnostics): warn_long_long is + the same for CPP and FE. + (restore_extension_diagnostics): Likewise. + +2009-04-20 Ian Lance Taylor <iant@google.com> + + Fix enum conversions which are invalid in C++: + * auto-inc-dec.c (attempt_change): Change 0 to SET in function call. + * calls.c (store_one_arg): Change 0 to EXPAND_NORMAL in function call. + * cse.c (hash_rtx_cb): Change 0 to VOIDmode in function call. + * dbgcnt.c (dbg_cnt_set_limit_by_name): Add cast to enum type. + * dbxout.c (dbxout_symbol): Change 0 to VOIDmode in function call. + (dbxout_parms): Likewise. + * df-core.c (df_set_flags): Change changeable_flags parameter to int. + (df_clear_flags): Likewise. + * df-problems.c (df_rd_bb_local_compute_process_def): Change + top_flag parameter to int. + (df_chain_create_bb_process_use): Likewise. + (df_chain_add_problem): Change chain_flags parameter to unsigned int. + Remove cast. + * df-scan.c (df_ref_create): Change ref_flags parameter to int. + (df_ref_create_structure, df_def_record_1): Likewise. + (df_defs_record, df_uses_record, df_get_call_refs): Likewise. + (df_notes_rescan): Change 0 to VOIDmode in function call. + (df_get_call_refs, df_insn_refs_collect): Likewise. + (df_bb_regs_collect): Likewise. + (df_entry_block_defs_collect): Likewise. + (df_exit_block_uses_collect): Likewise. + * df.h: Update declarations. + * double-int.c (double_int_divmod): Add cast to enum type. + * dse.c (replace_inc_dec): Reverse parameters to gen_int_mode. + * dwarf2out.c (new_reg_loc_descr): Add casts to enum type. + (based_loc_descr): Likewise. + (loc_descriptor_from_tree_1): Change first_op and second_op to + enum dwarf_location_atom. Add cast to enum type. + * expmed.c (init_expmed): Change 0 to SET in function call. + * expr.c (init_expr_target): Change 0 to VOIDmode in function call. + (expand_expr_real_1): Change 0 to EXPAND_NORMAL in function call. + (do_store_flag): Likewise. + * fixed-value.h (struct fixed_value): Change mode to enum + machine_mode. + * function.c (assign_parms): Change 0 to VOIDmode in function call. + * genautomata.c (insert_automaton_decl): Change 1 to INSERT in + function call. + (insert_insn_decl, insert_decl, insert_state): Likewise. + (automata_list_finish): Likewise. + * genrecog.c (process_define_predicate): Add cast to enum type. + * gensupport.c (init_predicate_table): Add cast to enum type. + * gimple.c (gimple_build_return): Change 0 to ERROR_MARK in + function call. + (gimple_build_call_1, gimple_build_label): Likewise. + (gimple_build_goto, gimple_build_asm_1): Likewise. + (gimple_build_switch_1, gimple_build_cdt): Likewise. + * gimple.h (GIMPLE_CHECK): Change 0 to ERROR_MARK in function call. + (enum fallback): Rename from enum fallback_t. + (fallback_t): Typedef as int. + * gimple-low.c (lower_builtin_setjmp): Change TSI_SAME_STMT to + GSI_SAME_STMT in function call. + * ira.c (setup_class_subset_and_memory_move_costs): Add casts to + enum type. + (setup_reg_class_relations): Likewise. + (setup_reg_class_nregs): Change cl to int. Add casts to enum type. + (setup_prohibited_class_mode_regs): Add cast to enum type. + (setup_prohibited_mode_move_regs): Likewise. + * ira-costs.c (record_reg_classes): Change rclass to enum reg_class. + (record_address_regs): Change i to enum reg_class. + * lists.c (alloc_EXPR_LIST): Add cast to enum type. + * machmode.h (GET_MODE_CLASS): Cast value to enum mode_class. + (GET_MODE_WIDER_MODE): Cast value to enum machine_mode. + (GET_MODE_2XWIDER_MODE): Likewise. + (GET_CLASS_NARROWEST_MODE): Likewise. + * omp-low.c (expand_omp_for): Add cast to enum type. + * optabs.c (debug_optab_libfuncs): Add casts to enum type. + * opts.c (enable_warning_as_error): Change kind to diagostic_t. + * postreload.c (reload_cse_simplify_operands): Change rclass local + to enum reg_class. + * predict.c (combine_predictions_for_insn): Change best_predictor + and predictor to enum br_predictor. + (combine_predictions_for_bb): Likewise. + (build_predict_expr): Change assignment to PREDICT_EXPR_OUTCOME to + use SET_PREDICT_EXPR_OUTCOME. + * real.c (real_arithmetic): Change icode to code in function call. + * reginfo.c (init_move_cost): Add casts to enum type. + (init_reg_sets_1, init_fake_stack_mems): Likewise. + * regmove.c (regclass_compatible_p): Change class0 and class1 to + enum reg_class. + * reload.c (find_valid_class): Add casts to enum type. + (push_reload): Change 0 to NO_REGS in function call. + (find_reloads): Change this_alternative to array of enum + reg_class. Remove some now-unnecessary casts. + (make_memloc): Change 0 to VOIDmode in function call. + * reload1.c (reload): Change 0 to VOIDmode in function call. + (eliminate_regs_1, elimination_effects): Likewise. + (eliminate_regs_in_insn): Likewise. + (emit_input_reload_insns): Add cast to enum type. + (delete_output_reload): Change 0 to VOIDmode in function call. + * reorg.c (insn_sets_resource_p): Convert include_delayed_effects + to enum type in function call. + * tree.h (PREDICT_EXPR_OUTCOME): Add cast to enum type. + (SET_PREDICT_EXPR_OUTCOME): Define. + * tree-dump.c (get_dump_file_info): Change phase parameter to int. + (get_dump_file_name, dump_begin, dump_enabled_p): Likewise. + (dump_initialized_p, dump_flag_name, dump_end): Likewise. + (dump_function): Likewise. + * tree-dump.h: Update declarations. + * tree-pass.h: Update declarations. + * varasm.c (assemble_integer): Change mclass to enum mode_class. + * config/arm/arm.c (thumb_legitimize_reload_address): Add cast to + enum type. + (arm_rtx_costs_1): Correct parenthesization. + (arm_rtx_costs): Add casts to enum type. + (adjacent_mem_locations): Reverse arguments to const_ok_for_op. + (vfp_emit_fstmd): Use add_rg_note. + (emit_multi_reg_push, emit_sfm): Likewise. + (thumb_set_frame_pointer): Likewise. + (arm_expand_prologue): Likewise. + (arm_regno_class): Change return type to enum reg_class. + (thumb1_expand_prologue): Use add_reg_note. + * config/arm/arm-protos.h (arm_regno_class): Update declaration. + * config/arm/arm.h (INITIALIZE_TRAMPOLINE): Change 0 to LCT_NORMAL + in function call. + * config/arm/gentune.sh: Add cast to enum type. + * config/arm/arm-tune.md: Rebuild. + * config/i386/i386.c (ix86_expand_prologue): Use add_reg_note. + (ix86_split_fp_branch, predict_jump): Likewise. + (ix86_expand_multi_arg_builtin): Change sub_code from enum + insn_code to enum rtx_code. + (ix86_builtin_vectorized_function): Add cast to enum type. + * config/i386/i386.md (truncdfsf2): Change slot to enum + ix86_stack_slot. + (truncxf<mode>2, isinf<mode>2): Likewise. + * config/i386/i386-c.c (ix86_pragma_target_parse): Add cast to + enum type. + * config/ia64/ia64.c (ia64_split_tmode_move): Use add_reg_note. + (spill_restore_mem, do_spill, ia64_expand_prologue): Likewise. + (insert_bundle_state): Change 1 to INSERT in function call. + (ia64_add_bundle_selector_before): Likewise. + * config/ia64/ia64.md (cpu attr): Add cast to enum type. + (save_stack_nonlocal): Change 0 to LCT_NORMAL in function call. + (restore_stack_nonlocal): Likewise. + * config/mips/mips.h (MIPS_ICACHE_SYNC): Change 0 to LCT_NORMAL in + function call. + * config/mips/mips.c (mips_binary_cost): Change 0 to SET in + function call. + (mips_rtx_costs): Likewise. + (mips_override_options): Add casts to enum type. + * config/mips/sdemtk.h (MIPS_ICACHE_SYNC): Change 0 to LCT_NORMAL + in function call. + * config/pa/pa.c (legitimize_pic_address): Use add_reg_note. + (store_reg, set_reg_plus_d): Likewise. + (hppa_expand_prologue, hppa_profile_hook): Likewise. + * config/rs6000/rs6000.c (rs6000_init_hard_regno_mode_ok): Add + cast to enum type. + (altivec_expand_vec_set_builtin): Change 0 to EXPAND_NORMAL in + function call. + (emit_unlikely_jump): Use add_reg_note. + (rs6000_emit_allocate_stack): Likewise. + (rs6000_frame_related, rs6000_emit_prologue): Likewise. + (output_toc): Change 1 to INSERT in function call. + (output_profile_hook): Change 0 to LCT_NORMAL in function call. + (rs6000_initialize_trampoline): Likewise. + (rs6000_init_dwarf_reg_sizes_extra): Change 0 to EXPAND_NORMAL in + function call. + * config/s390/s390.c (s390_rtx_costs): Add cast to enum type. + (s390_expand_movmem): Change 0 to OPTAB_DIRECT in function call. + (s390_expand_setmem, s390_expand_cmpmem): Likewise. + (save_gprs): Use add_reg_note. + (s390_emit_prologue): Likewise. + (s390_expand_builtin): Change 0 to EXPAND_NORMAL in function call. + * config/sparc/sparc.c (sparc_expand_prologue): Use add_reg_note. + (sparc_fold_builtin): Add cast to enum type. + * config/spu/spu.c (spu_emit_branch_or_set): Change ior_code to + enum insn_code. + (spu_expand_prologue): Use add_reg_note. + (expand_builtin_args): Change 0 to EXPAND_NORMAL in function call. + +2009-04-20 Ian Lance Taylor <iant@google.com> + + * c-parser.c (c_parser_attributes): Change VEC back to tree list. + (c_parser_postfix_expression_after_primary): Get VEC for list of + arguments. Get original types of arguments. Call + build_function_call_vec. + (cached_expr_list_1, cached_expr_list_2): New static variables. + (c_parser_expr_list): Change return type to VEC *. Add + p_orig_types parameter. Change all callers. + (c_parser_release_expr): New static function. + (c_parser_vec_to_tree_list): New static function. + * c-typeck.c (build_function_call): Rewrite to build a VEC and + call build_function_call_vec. + (build_function_call_vec): New function, based on old + build_function_call. + (convert_arguments): Remove nargs and argarray parameters. Change + values to a VEC. Add origtypes parameter. + (build_modify_expr): Add rhs_origtype parameter. Change all callers. + (convert_for_assignment): Add origtype parameter. Change all + callers. If warn_cxx_compat, check for conversion to an enum + type when calling a function. + (store_init_value): Add origtype parameter. Change all callers. + (digest_init): Likewise. + (struct init_node): Add origtype field. + (add_pending_init): Add origtype parameter. Change all callers. + (output_init_element): Likewise. + (output_pending_init_elements): Pass origtype from init_node to + output_init_element. + (process_init_element): Pass origtype from c_expr to + output_init_element. + (c_finish_return): Add origtype parameter. Change all callers. + * c-common.c (sync_resolve_size): Change params to VEC *. Change + caller. + (sync_resolve_params): Likewise. + (sync_resolve_return): Change params to first_param. Change caller. + (resolve_overloaded_builtins): Change params to VEC *. Change + callers. Save first parameter around call to build_function_call_vec. + * c-decl.c (finish_decl): Add origtype parameter. Change all + callers. Call build_function_call_vec rather than + build_function_call for cleanup. + * c-tree.h: Update declarations. + * c-common.h: Update declarations. + * stub-objc.c (objc_rewrite_function_call): Change parameter from + params to first_param. + * target.h (struct gcc_target): Change resolve_overloaded_builtin + params parameter from tree to void *. + * config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin): + Change arglist parameter to have type void *, and to be a pointer + to a VEC. + * config/rs6000/rs6000-protos.h + (altivec_resolve_overloaded_builtin): Update declaration. + * config/spu/spu-c.c (spu_resolved_overloaded_builtin): Change + fnargs parameter to have type void *, and to be a pointer to a + VEC. Call build_function_call_vec instead of + build_function_call. + * config/spu/spu-protos.h (spu_expand_builtin): Update declaration. + +2009-04-20 Joey Ye <joey.ye@intel.com> + Xuepeng Guo <xuepeng.guo@intel.com> + H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/atom.md: Add bypasses with ix86_dep_by_shift_count. + + * config/i386/i386.c (LEA_SEARCH_THRESHOLD): New macro. + (IX86_LEA_PRIORITY): Likewise. + (distance_non_agu_define): New function. + (distance_agu_use): Likewise. + (ix86_lea_for_add_ok): Likewise. + (ix86_dep_by_shift_count): Likewise. + + * config/i386/i386.md: Call ix86_lea_for_add_ok to decide we + should split for LEA. + + * config/i386/i386-protos.h (ix86_lea_for_add_ok): Declare new + function. + (ix86_dep_by_shift_count): Likewise. + +2009-04-20 Richard Guenther <rguenther@suse.de> + + * expr.c (handled_component_p): Move ... + * tree.h (handled_component_p): ... here. + * tree.def: Re-order BIT_FIELD_REF, COMPONENT_REF, + ARRAY_REF, ARRAY_RANGE_REF, VIEW_CONVERT_EXPR, IMAGPART_EXPR + and REALPART_EXPR to be in one group. + +2009-04-20 Richard Guenther <rguenther@suse.de> + + * basic-block.h (get_all_dominated_blocks): Declare. + * dominance.c (get_all_dominated_blocks): New function. + * tree-cfg.c (get_all_dominated_blocks): Remove. + (remove_edge_and_dominated_blocks): Adjust. + * tree-ssa-phiprop.c (tree_ssa_phiprop_1): Fold in ... + (tree_ssa_phiprop): ... here. Use get_all_dominated_blocks + instead of recursing. + +2009-04-20 Doug Kwan <dougkwan@google.com> + + * cgraph.h (cgraph_node_ptr): New type for vector functions. + (struct cgraph_node_set_def): New type. + (cgraph_node_set) New type. Also declare vector functions. + (struct cgraph_node_set_element_def): New type. + (cgraph_node_set_element): Ditto. + (cgraph_node_set_iterator): New iterator type. + (cgraph_node_set_new, cgraph_node_set_find, cgraph_node_set_add, + cgraph_node_set_remove, dump_cgraph_node_set, + debug_cgraph_node_set): New prototypes. + (csi_end_p, csi_next, csi_node, csi_start, cgraph_node_in_set_p, + cgraph_node_set_size): New inlines. + * tree-pass.h (struct cgraph_node_set_def): New decl to avoid + including cgraph.h. + (struct ipa_opt_pass): Add struct cgraph_node_set_def + argument to function 'write_summary'. + * ipa.c: Include ggc.h. + (hash_cgraph_node_set_element, + eq_cgraph_node_set_element, cgraph_node_set_new, + cgraph_node_set_add, cgraph_node_set_remove, + cgraph_node_set_find, dump_cgraph_node_set, + debug_cgraph_node_set): New functions. + * Makefile.in (ipa.o): Add dependency on GGC_H. + +2009-04-20 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/39675 + * tree-vect-loop.c (vect_transform_loop): Remove currently redundant + check of the return code of vect_schedule_slp. Check that + stmt_vec_info still exists for the statement, before checking its + vectorization type. + +2009-04-20 Michael Matz <matz@suse.de> + + * Makefile.in (generated_files): Take out $(simple_generated_c). + +2009-04-19 Dave Korn <dave.korn.cygwin@gmail.com> + + * config/i386/cygwin-stdint.h (INTPTR_TYPE): Remove "long". + (UINTPTR_TYPE): Likewise. + +2009-04-19 Joseph Myers <joseph@codesourcery.com> + + PR c/37481 + * c-typeck.c (digest_init): Check for initializing an array with a + string literal. + +2009-04-19 Joseph Myers <joseph@codesourcery.com> + + PR c/19771 + * c-semantics.c (pop_stmt_list): Propagate + STATEMENT_LIST_HAS_LABEL to parent statement list. + +2009-04-19 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.h (mips_tune_attr): New macro. + * config/mips/mips.md (cpu): Use it. + +2009-04-19 Joseph Myers <joseph@codesourcery.com> + + PR c/38243 + * c-decl.c (shadow_tag_warned): Diagnose use of restrict when + declaring a tag. + +2009-04-19 Diego Novillo <dnovillo@google.com> + + * toplev.c (compile_file): Move call to coverage_finish ... + * cgraphunit.c (ipa_passes): ... here. + Call cgraph_process_new_functions. + * ipa-utils.c (get_base_var): Handle CONSTRUCTOR. + * Makefile.in (cgraphunit.o): Add dependency on COVERAGE_H. + +2009-04-19 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_create_edge, cgraph_set_call_stmt): Set proper + cfun. + (dump_cgraph_node): Dump can throw external flag. + * ipa-pure-const.c (propagate): Fix propagation of nothrow flags. + +2009-04-19 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR c/32061 + PR c++/36954 + * doc/invoke.texi: Add -Wlogical-op to -Wextra. + * common.opt (Wlogical-op): Move from here... + * c.opt (Wlogical-op): ... to here. + * c-typeck.c (parser_build_binary_op): Update call to + warn_logical_operator. + * c-opts.c (c_common_post_options): Enable warn_logical_op with + extra_warnings. + * c-common.c (warn_logical_op): Update. + * c-common.h (warn_logical_op): Update declaration. + +2009-04-19 Eric Botcazou <ebotcazou@adacore.com> + + * tree.c (protected_set_expr_location): Fix formatting. + +2009-04-18 Joseph Myers <joseph@codesourcery.com> + + PR c/27676 + * c-typeck.c (readonly_warning): new. + (build_unary_op, build_modify_expr): Use readonly_warning for + storing into something readonly but not const-qualified. + +2009-04-18 Joseph Myers <joseph@codesourcery.com> + + PR c/22367 + * c-typeck.c (build_unary_op): Check for taking address of + expression of type void. + +2009-04-18 Joseph Myers <joseph@codesourcery.com> + + PR c/35210 + * c-typeck.c (build_function_call): Check for calling a function + with qualified void return types. Call require_complete_type when + generating a trap. + +2009-04-18 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_make_edge, dump_cgraph_node, cgraph_set_call_stmt): + Set nothrow flag. + * cgraph.h (struct function): Reduce loop_nest to 30 bits; add + can_throw_external flag. + * ipa-reference.c (ipa_utils_reduced_inorder): Update call. + * ipa-pure-const.c (ignore_edge): New function. + (propagate): Compute order for NOTHROW computation; set NOTHROWs + only over can_throw_external edges. + (local_pure_const): Add nothrow flag. + * ipa-utils.c (searchc): Add ignore_edge callback. + (ipa_utils_reduced_inorder): Add ignore_edge callback. + * ipa-utils.h (ipa_utils_reduced_inorder): Update prototype. + (set_nothrow_function_flags): Update cgraph. + * tree-cfg.c (verify_stmt): Relax nothrow checking when in IPA mode. + +2009-04-18 Richard Guenther <rguenther@suse.de> + + PR middle-end/39804 + * tree-ssa-ccp.c (fold_stmt_1): New function factored from ... + (fold_stmt): ... this and ... + (fold_stmt_inplace): ... this. + (fold_stmt_1): Fold references in calls and asms. + * tree-cfg.c (remove_useless_stmts_cond): Use fold_stmt. + +2009-04-18 Kazu Hirata <kazu@codesourcery.com> + + * tree-vrp.c (ssa_name_nonzero_p): Remove. + * tree.h: Remove the prototype for ssa_name_nonzero_p. + +2009-04-18 Kazu Hirata <kazu@codesourcery.com> + + * tree.c (function_args_count): Remove. + * tree.h: Remove the prototype for function_args_count. + +2009-04-18 Kazu Hirata <kazu@codesourcery.com> + + * tree-iterator.c (expr_only): Remove. + * tree.h: Remove the prototype for expr_only. + +2009-04-18 Kazu Hirata <kazu@codesourcery.com> + + * reginfo.c (cannot_change_mode_set_regs): Remove. + * rtl.h: Remove the prototype for cannot_change_mode_set_regs. + +2009-04-08 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.md (*rotlsi3_8, *rotlsi3_16, *rotlsi3_24 ): Check + whether operands 0 and 1 overlaps. + +2009-04-18 Manuel López-Ibáñez <manu@gcc.gnu.org> + + PR middle-end/36902 + * tree-vrp.c (check_array_ref): Pass a location_t instead of a + pointer. Use warning_at instead of warning. + (search_for_addr_array): Likewise. + (check_array_bounds): Likewise. + (check_all_array_refs): Check that the incoming edge is not in the + list of edges to be removed. + (check_all_array_refs): Avoid the temporal pointer. + (vrp_visit_cond_stmt): Fix typo. + (simplify_switch_using_ranges): Handle the case where the switch + index is an integer constant. + +2009-04-18 Adam Nemet <anemet@caviumnetworks.com> + + * config/mips/mips.c (mips_final_postscan_insn): Make it static. + +2009-04-18 Kazu Hirata <kazu@codesourcery.com> + + * doc/extend.texi, doc/invoke.texi: Fix typos. + +2009-04-17 Cary Coutant <ccoutant@google.com> + + * tree-flow-inline.h (get_lineno): Fix inverted test. + +2009-04-17 Diego Novillo <dnovillo@google.com> + + * tree-ssa-pre.c (create_expression_by_pieces): Remove + assertion for AVAIL_OUT. + +2009-04-17 Mike Frysinger <vapier@gentoo.org> + + PR target/38627 + * config/sh/lib1funcs.asm [__ELF__ && __linux__]: Add .note.GNU-stack. + * config/sh/linux-atomic.asm: Likewise. + +2009-04-17 Diego Novillo <dnovillo@google.com> + + * except.c (debug_eh_tree): New. + (struct eh_region, struct eh_status): Move ... + * except.h: ... here. + (add_type_for_runtime): Declare extern. + (lookup_type_for_runtime): Likewise. + (debug_eh_tree): Declare. + * Makefile.in (GTFILES): List except.h before except.c + +2009-04-17 Diego Novillo <dnovillo@google.com> + + * omp-low.c (create_omp_child_function): Set DECL_CONTEXT for DECL. + * cgraphunit.c (cgraph_build_static_cdtor): Likewise. + * tree-dfa.c (find_referenced_vars_in): Factor out of ... + (find_vars_r): ... here. + * tree-flow.h (find_referenced_vars_in): Declare. + * tree-ssa-pre.c (create_expression_by_pieces): Assert + that AVAIL_OUT exists for BLOCK. + * Makefile.in (CGRAPH_H): Add dependency on cif-code.def + (tree-loop-distribution.o): Fix dependency on TREE_VECTORIZER_H. + (tree-parloops.o): Likewise. + +2009-04-17 Simon Baldwin <simonb@google.com> + + * toplev.c (default_tree_printer): Add handling for %E format. + +2009-04-17 Diego Novillo <dnovillo@google.com> + + * tree-pretty-print.c (dump_generic_node): Add break after + TREE_BINFO handler. Handle COMPLEX_TYPE, REAL_TYPE and + FIXED_POINT_TYPE. Handle NULL TREE_TYPEs. Handle METHOD_TYPE and + FUNCTION_TYPE together. Call print_struct_decl when printing + structures and TDF_SLIM is not given. + (print_struct_decl): Fix logic for detecting recursion. + +2009-04-17 Rafael Avila de Espindola <espindola@google.com> + + PR 31567 + * gcc.c (create_at_file): New. + (compile_input_file_p): New. + (do_spec_1): Use @args files for %i. Use create_at_file for %o. + * main.c (main): Update call to toplev_main. + * toplev.c (toplev_main): Change signature. Call expandargv. + * toplev.h (toplev_main): Change signature. + +2009-04-17 Eric Botcazou <ebotcazou@adacore.com> + + * dwarf2out.c (field_byte_offset): Use the type size as the field size + if the latter is not constant. + +2009-04-17 David Edelsohn <edelsohn@gnu.org> + + * dbxout.c (xcoff_debug_hooks): Add set_name_debug_nothing. + +2009-04-17 Eric Botcazou <ebotcazou@adacore.com> + + * dbxout.c (dbxout_block): Reinstate test on TREE_USED. + * tree-ssa-live.c (remove_unused_scope_block_p): Update TREE_USED bit. + +2009-04-17 Richard Guenther <rguenther@suse.de> + + * tree-ssa-structalias.c (get_constraint_for_component_ref): + Handle component references view-converting an invariant address. + +2009-04-17 Adam Nemet <anemet@caviumnetworks.com> + + * doc/tm.texi (TARGET_DEFAULT_TARGET_FLAGS, + TARGET_MIN_ANCHOR_OFFSET, TARGET_MAX_ANCHOR_OFFSET, + TARGET_HAVE_SRODATA_SECTION, TARGET_HAVE_TLS, + TARGET_UNWIND_TABLES_DEFAULT, TARGET_TERMINATE_DW2_EH_FRAME_INFO): + Use @deftypevr rather than @deftypevar. + +2009-04-17 Richard Guenther <rguenther@suse.de> + + * tree-ssa-forwprop.c (get_prop_dest_stmt): Clean up tuplification. + (get_prop_source_stmt): Likewise. + (can_propagate_from): Likewise. + +2009-04-17 Andrew Stubbs <ams@codesourcery.com> + + * configure.ac: Add new AC_SUBST for TM_ENDIAN_CONFIG, + TM_MULTILIB_CONFIG and TM_MULTILIB_EXCEPTIONS_CONFIG. + (--with-multilib-list): Add default value. + * configure: Regenerate. + * Makefile.in (TM_ENDIAN_CONFIG): Define. + (TM_MULTILIB_CONFIG, TM_MULTILIB_EXCEPTIONS_CONFIG): Define. + * config.gcc (sh-*-*): Switch to using TM_ENDIAN_CONFIG, + TM_MULTILIB_CONFIG, and TM_MULTILIB_EXCEPTIONS_CONFIG. + Don't add default cpu to multilib list unnecessarily, but do enable + the relevant compiler option.. + Add support for --with-multilib-list=<blank> and + --with-multilib-list=!<somelib> to supress unwanted multilibs. + * config/sh/t-sh (DEFAULT_ENDIAN, OTHER_ENDIAN): New variables. + (MULTILIB_ENDIAN, MULTILIB_CPUS): Delete variables. + (MULTILIB_OPTIONS): Redefine using OTHER_ENDIAN and + TM_MULTILIB_CONFIG. + (MULTILIB_EXCEPTIONS): Add TM_MULTILIB_EXCEPTIONS_CONFIG. + (MULTILIB_OSDIRNAMES): New variable. + * config/sh/t-1e: Delete file. + * config/sh/t-mlib-sh1: Delete file. + * config/sh/t-mlib-sh2: Delete file. + * config/sh/t-mlib-sh2a: Delete file. + * config/sh/t-mlib-sh2a-nofpu: Delete file. + * config/sh/t-mlib-sh2a-single: Delete file. + * config/sh/t-mlib-sh2a-single-only: Delete file. + * config/sh/t-mlib-sh2e: Delete file. + * config/sh/t-mlib-sh3e: Delete file. + * config/sh/t-mlib-sh4: Delete file. + * config/sh/t-mlib-sh4-nofpu: Delete file. + * config/sh/t-mlib-sh4-single: Delete file. + * config/sh/t-mlib-sh4-single-only: Delete file. + * config/sh/t-mlib-sh4a: Delete file. + * config/sh/t-mlib-sh4a-nofpu: Delete file. + * config/sh/t-mlib-sh4a-single: Delete file. + * config/sh/t-mlib-sh4a-single-only: Delete file. + * config/sh/t-mlib-sh4al: Delete file. + * config/sh/t-mlib-sh5-32media: Delete file. + * config/sh/t-mlib-sh5-32media-nofpu: Delete file. + * config/sh/t-mlib-sh5-64media: Delete file. + * config/sh/t-mlib-sh5-64media-nofpu: Delete file. + * config/sh/t-mlib-sh5-compact: Delete file. + * config/sh/t-mlib-sh5-compact-nofpu: Delete file. + * config/sh/t-linux: Don't override MULTILIB_EXCEPTIONS. + * doc/install.texi (Options specification): Add + --with-multilib-list and --with-endian. + +2009-04-17 Rafael Avila de Espindola <espindola@google.com> + + * Makefile.in (REVISION_s): Always include quotes. Change ifdef to use + REVISION_c. + (OBJS-common): Add plugin-version.o. + (plugin-version.o): New. + * gcc-plugin.h (plugin_gcc_version): New. + (plugin_default_version_check): New. + (plugin_init_func, plugin_init): Add version argument. + * plugin-version.c: New. + * plugin.c (str_plugin_gcc_version_name): New. + (try_init_one_plugin): Read plugin_gcc_version from the plugin and + pass it to the init function. + (plugin_default_version_check): New. + +2009-04-17 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (refs_may_alias_p_1): Do not use TBAA + for decl-vs-decl disambiguation. + +2009-04-17 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/s390.h (s390_tune_attr): New macro definition. + * config/s390/s390.md (cpu attribute): Map to s390_tune_attr. + +2009-04-17 Richard Guenther <rguenther@suse.de> + + * tree-ssa-ccp.c (struct fold_stmt_r_data): Remove. + (fold_stmt_r): Likewise. + (maybe_fold_reference): New function. + (fold_gimple_assign): Handle cases fold_stmt_r did. + (fold_stmt): Do not use fold_stmt_r. + (fold_stmt_inplace): Likewise. + +2009-04-17 Richard Guenther <rguenther@suse.de> + + * tree-ssa-dom.c (gimple_assign_unary_useless_conversion_p): Remove. + (record_equivalences_from_stmt): Remove useless checks and + simplifications. + * tree-ssa-pre.c (eliminate): Avoid converting a constant if + the type is already suitable. + +2009-04-17 Paolo Bonzini <bonzini@gnu.org> + + * config/sh/sh.h (FUNCTION_VALUE): Fix call to sh_promote_prototypes. + +2009-04-17 Uros Bizjak <ubizjak@gmail.com> + + * config/arm/sfp-machine.h (__gcc_CMPtype): New typedef. + (CMPtype): Define as __gcc_CMPtype. + +2009-04-17 Aurelien Jarno <aurelien@aurel32.net> + + * config.gcc: Add soft-fp/t-softfp and i386/t-linux to tmake_file + for i[34567]86-*-kfreebsd*-gnu*, x86_64-*-kfreebsd*-gnu*. + +2009-04-17 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39746 + * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Remove + special-casing for builtins and static variable use/def. + (call_may_clobber_ref_p_1): Likewise. + +2009-04-16 Ian Lance Taylor <iant@google.com> + + * df.h: Include "timevar.h". + (struct df_problem): Change tv_id field to timevar_id_t. + * tree-pass.h: Include "timevar.h". + (struct opt_pass): Change tv_id field to timevar_id_t. + * timevar.h (timevar_id_t): Define TV_NONE. + * passes.c (execute_one_ipa_transform_pass): Check for tv_id != + TV_NONE rather than tv_id != 0. + (execute_one_pass): Likewise. + * Makefile.in (DF_H): Add $(TIMEVAR_H). + (TREE_PASS_H): Define. Change all instances of tree-pass.h in + dependencies to $(TREE_PASS_H). + * bt-load.c (pass_branch_target_load_optimize1): Set tv_id field + to TV_NONE. + (pass_branch_target_load_optimize2): Likewise. + * cfglayout.c (pass_into_cfg_layout_mode): Likewise. + (pass_outof_cfg_layout_mode): Likewise. + * cgraphbuild.c (pass_remove_cgraph_callee_edges): Likewise. + (pass_rebuild_cgraph_edges): Likewise. + (pass_remove_cgraph_callee_edges): Likewise. + * df-core.c (pass_df_initialize_opt): Likewise. + (pass_df_initialize_no_opt): Likewise. + (pass_df_finish): Likewise. + * emit-rtl.c (pass_unshare_all_rtl): Likewise. + * except.c (pass_set_nothrow_function_flags): Likewise. + (pass_convert_to_eh_region_ranges): Likewise. + * final.c (pass_compute_alignments): Likewise. + * function.c (pass_instantiate_virtual_regs): Likewise. + (pass_init_function): Likewise. + (pass_leaf_regs): Likewise. + (pass_match_asm_constraints): Likewise. + * gimple-low.c (pass_lower_cf): Likewise. + (pass_mark_used_blocks): Likewise. + * init-regs.c (pass_initialize_regs): Likewise. + * integrate.c (pass_initial_value_sets): Likewise. + * ira.c (pass_ira): Likewise. + * jump.c (pass_cleanup_barriers): Likewise. + * omp-low.c (pass_expand_omp): Likewise. + (pass_lower_omp): Likewise. + * matrix-reorg.c (pass_ipa_matrix_reorg): Likewise. + * recog.c (pass_split_all_insns): Likewise. + (pass_split_after_reload): Likewise. + (pass_split_before_regstack): Likewise. + (pass_split_before_sched2): Likewise. + (pass_split_for_shorten_branches): Likewise. + * reginfo.c (pass_reginfo_init): Likewise. + (pass_subregs_of_mode_init): Likewise. + (pass_subregs_of_mode_finish): Likewise. + * passes.c (pass_postreload): Likewise. + * stack-ptr-mod.c (pass_stack_ptr_mod): Likewise. + * tree-cfg.c (pass_remove_useless_stmts): Likewise. + (pass_warn_function_return): Likewise. + (pass_warn_function_noreturn): Likewise. + * tree-complex.c (pass_lower_complex): Likewise. + (pass_lower_complex_O0): Likewise. + * tree-if-conv.c (pass_if_conversion): Likewise. + * tree-into-ssa.c (pass_build_ssa): Likewise. + * tree-mudflap.c (pass_mudflap_1): Likewise. + (pass_mudflap_2): Likewise. + * tree-nomudflap.c (pass_mudflap_1): Likewise. + (pass_mudflap_2): Likewise. + * tree-nrv.c (pass_return_slot): Likewise. + * tree-object-size.c (pass_object_sizes): Likewise. + * tree-optimize.c (pass_all_optimizations): Likewise. + (pass_early_local_passes): Likewise. + (pass_all_early_optimizations): Likewise. + (pass_cleanup_cfg): Likewise. + (pass_cleanup_cfg_post_optimizing): Likewise. + (pass_free_datastructures): Likewise. + (pass_free_cfg_annotations): Likewise. + (pass_fixup_cfg): Likewise. + (pass_init_datastructures): Likewise. + * tree-ssa.c (pass_early_warn_uninitialized): Likewise. + (pass_late_warn_uninitialized): Likewise. + (pass_update_address_taken): Likewise. + * tree-ssa-ccp.c (pass_fold_builtins): Likewise. + * tree-ssa-math-opts.c (pass_cse_reciprocals): Likewise. + (pass_cse_sincos): Likewise. + (pass_convert_to_rsqrt): Likewise. + * tree-ssa-structalias.c (pass_build_alias): Likewise. + * tree-stdarg.c (pass_stdarg): Likewise. + * tree-tailcall.c (pass_tail_recursion): Likewise. + (pass_tail_calls): Likewise. + * tree-vect-generic.c (pass_lower_vector): Likewise. + (pass_lower_vector_ssa): Likewise. + * tree-vectorizer.c (pass_ipa_increase_alignment): Likewise. + +2009-04-16 Joseph Myers <joseph@codesourcery.com> + + * config/mips/mips.c (mips_rtx_cost_data): Use SOFT_FP_COSTS in + XLR entry. + * config/mips/mips.h (MIPS_ISA_LEVEL_SPEC, MIPS_ARCH_FLOAT_SPEC): + Handle -march=xlr. + * config/mips/xlr.md (ir_xlr_alu): Also accept insn types move, + logical and signext. + +2009-04-16 Kaz Kojima <kkojima@gcc.gnu.org> + + PR target/39767 + * config/sh/predicates.md (arith_operand): Check if the operand + of TRUNCATE is a REG. + +2009-04-16 Kazu Hirata <kazu@codesourcery.com> + + * cfgrtl.c (delete_insn_chain_and_edges): Remove. + * rtl.h: Remove the prototype for delete_insn_chain_and_edges. + +2009-04-16 Kazu Hirata <kazu@codesourcery.com> + + * tree-iterator.c (tsi_split_statement_list_after, + tsi_split_statement_list_before): Remove. + * tree-iterator.h: Remove the prototypes for + tsi_split_statement_list_after and tsi_split_statement_list_before. + +2009-04-16 Kazu Hirata <kazu@codesourcery.com> + + * tree-ssa-propagate.c (stmt_makes_single_load): Remove. + * tree-ssa-propagate.h: Remove the prototype for + stmt_makes_single_load. + +2009-04-16 Kazu Hirata <kazu@codesourcery.com> + + * emit-rtl.c (set_mem_attrs_from_reg): Remove. + * rtl.h: Remove the prototype for set_mem_attrs_from_reg. + +2009-04-16 Kazu Hirata <kazu@codesourcery.com> + + * tree-iterator.c (EXPR_LAST_BODY): Remove. + +2009-04-16 Kazu Hirata <kazu@codesourcery.com> + + * except.c (eh_region_outer_p): Remove. + * except.h: Remove the prototype for eh_region_outer_p. + +2009-04-16 Kazu Hirata <kazu@codesourcery.com> + + * function.c (current_function_assembler_name): Remove. + * function.h: Remove the prototype for + current_function_assembler_name. + +2009-04-16 Ian Lance Taylor <iant@google.com> + + * rtlanal.c (alloc_reg_note): New function, broken out of add_reg_note. + (add_reg_note): Call alloc_reg_note. + * rtl.h (alloc_reg_note): Declare. + * combine.c (try_combine): Use alloc_reg_note. + (recog_for_combine, move_deaths): Likewise. + (distribute_notes): Use alloc_reg_note and add_reg_note. + * haifa-sched.c (sched_create_recovery_edges): Use add_reg_note. + * combine-stack-adj.c (adjust_frame_related_expr): Likewise. + * reload1.c (eliminate_regs_1): Use alloc_reg_note. + +2009-04-16 Vladimir Makarov <vmakarov@redhat.com> + + PR rtl-optimization/39762 + * ira-int.h (ira_register_move_cost, ira_may_move_in_cost, + ira_may_move_out_cost): Add comments about way of their usage. + (ira_get_register_move_cost, ira_get_may_move_cost): New functions. + + * ira-conflicts.c (process_regs_for_copy): Use function + ira_get_register_move_cost instead of global + ira_register_move_cost. + + * ira-color.c (update_copy_costs, calculate_allocno_spill_cost, + color_pass, move_spill_restore, update_curr_costs): Ditto. + + * ira-lives.c (process_single_reg_class_operands): Ditto. + + * ira-emit.c (emit_move_list): Ditto. + + * ira-costs.c (copy_cost): Don't call ira_init_register_move_cost. + (record_reg_classes): Ditto. Use functions + ira_get_register_move_cost and ira_get_may_move_cost instead of + global vars ira_register_move_cost, ira_may_move_out_cost and + ira_may_move_in_cost. + (record_address_regs): Don't call ira_init_register_move_cost. + Use function ira_get_may_move_cost instead of global + ira_may_move_in_cost. + (process_bb_node_for_hard_reg_moves): Use function + ira_get_register_move_cost instead of global ira_register_move_cost. + (ira_costs): Don't call ira_init_register_move_cost. + +2009-04-16 Richard Guenther <rguenther@suse.de> + + * tree-cfg.c (verify_gimple_assign_binary): + Allow POINTER_PLUS_EXPR-like PLUS_EXPR for vectors. + * ipa-struct-reorg.c (gen_size): Fold the built expressions. + (create_general_new_stmt): Note that this function is broken. + +2009-04-16 Rafael Avila de Espindola <espindola@google.com> + + * common.opt (fhelp): Add Var(help_flag). + * gcc-plugin.h (plugin_info): Add help. + * plugin.c (plugin_name_args): Add help. + (register_plugin_info): Set plugin->help. + (print_help_one_plugin): New. + (print_plugins_help): New. + * plugin.h (print_plugins_help): New. + * toplev.c (toplev_main): Call print_plugins_help if needed. + +2009-04-16 Richard Guenther <rguenther@suse.de> + + * gimple.c (gimple_copy): Do not clear addresses_taken bitmap. + (gimple_ior_addresses_taken_1): New function. + (gimple_ior_addresses_taken): Likewise. + * gimple.h (struct gimple_statement_with_ops_base): Remove + addresses_taken member. + (gimple_ior_addresses_taken): Declare. + (gimple_addresses_taken, gimple_addresses_taken_ptr, + gimple_set_addresses_taken): Remove. + * ipa-reference.c (mark_address): New function. + (scan_stmt_for_static_refs): Use it for marking addresses taken. + * tree-ssa-operands.c (add_to_addressable_set): Rename to ... + (mark_address_taken): ... this. Just set TREE_ADDRESSABLE. + (gimple_add_to_addresses_taken): Remove. + (get_tmr_operands): Call mark_address_taken. + (get_asm_expr_operands): Likewise. + (get_expr_operands): Likewise. + (build_ssa_operands): Do not clear the addresses_taken bitmap. + (free_stmt_operands): Do not free it. + * tree-ssa.c (delete_tree_ssa): Likewise. + (execute_update_addresses_taken): Use gimple_ior_addresses_taken. + +2009-04-16 Richard Guenther <rguenther@suse.de> + + * gimple.h (walk_stmt_load_store_addr_ops): Declare. + (walk_stmt_load_store_ops): Likewise. + * gimple.c (get_base_loadstore): New function. + (walk_stmt_load_store_addr_ops): Likewise. + (walk_stmt_load_store_ops): Likewise. + * ipa-pure-const.c (check_op): Simplify. + (check_load, check_store): New functions. + (check_stmt): Use walk_stmt_load_store_ops. + * ipa-reference.c (mark_load): Adjust signature. + (mark_store): Likewise. + (scan_stmt_for_static_refs): Use walk_stmt_load_store_addr_ops. + +2009-04-16 Rafael Avila de Espindola <espindola@google.com> + + * gcc-plugin.h (plugin_event): Add PLUGIN_INFO. + (plugin_info): New. + * opts.c (common_handle_option): Don't call print_version. + * plugin.c (plugin_name_args): Add version. + (register_plugin_info): New. + (register_callback): Handle PLUGIN_INFO. + (try_init_one_plugin): New. + (init_one_plugin): Use try_init_one_plugin. Only free plugin_name_args + if failed to init. + (finalize_one_plugin): New. + (finalize_plugins): New. + (print_one_plugin): New. + (print_plugins_versions): New. + * plugin.h (print_plugins_versions): New. + (finalize_plugins): New. + * toplev.c (compile_file): Don't call initialize_plugins. + (print_version): Call print_plugins_versions. + (toplev_main): Call initialize_plugins. Print version if needed. + Call finalize_plugins. + +2009-04-16 Rafael Avila de Espindola <espindola@google.com> + + * common.opt (fversion): New. + * gcc.c (print_version): New. + (process_command): Don't print the version. Just set print_version. + (main): Print version. Call subprocesses if print_version and + verbose_flag are set. + * opts.c (common_handle_option): Handle OPT_fversion. + +2009-04-16 Richard Guenther <rguenther@suse.de> + Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/39698 + * tree-vect-loop.c (get_initial_def_for_reduction): Use the + type of the reduction variable. Only generate the def if + it is needed. + + * omp-low.c (expand_omp_for_generic): When converting to a pointer + make sure to first convert to an integer of the same precision. + * tree-vect-loop-manip.c (vect_update_ivs_after_vectorizer): Retain + the type of the evolution correctly in computing the new + induction variable base. + +2009-04-16 Richard Guenther <rguenther@suse.de> + + PR middle-end/39625 + * tree-cfg.c (make_blocks): Split statements with to-be + abnormal SSA names on the lhs. + +2009-04-16 Paolo Bonzini <bonzini@gnu.org> + + * c-common.c (vector_targets_convertible_p, vector_types_convertible_p): + Use TYPE_VECTOR_OPAQUE instead of targetm.vector_opaque_p. + * c-typeck.c (really_start_incremental_init): Likewise. + * target-def.h (TARGET_VECTOR_OPAQUE_P): Remove. + (TARGET_INITIALIZER): Remove it. + * target.h (struct target): Remove vector_opaque_p. + * tree.c (build_opaque_vector_type): New. + * tree.h (TYPE_VECTOR_OPAQUE): New. + (build_opaque_vector_type): Declare. + * doc/tm.texi (TARGET_VECTOR_OPAQUE_P): Remove. + * config/rs6000/rs6000.c (build_opaque_vector_type, + rs6000_is_vector_type, TARGET_VECTOR_OPAQUE_P): Remove. + (rs6000_init_builtins): Use build_opaque_vector_type for + opaque_V4SI_type_node. + +2009-04-15 Catherine Moore <clm@codesourcery.com> + + * debug.h (set_name): Declare. + * dwarf2out.c (dwarf2out_set_name): Declare. + (dwarf2_debug_hooks): Add set_name. + (find_AT_string): New. + (add_AT_string): Call find_AT_string. + (dwarf2out_set_name): New. + * cp/decl.c (grokdeclarator): Call set_name. + * vmsdbgout.c (vmsdbg_debug_hooks): Add set_name_debug_nothing. + * debug.c (do_nothing_debug_hooks): Likewise. + * dbxout.c (dbx_debug_hooks): Likewise. + * sdbout.c (sdb_debug_hooks): Likewise. + +2009-04-15 Michael Eager <eager@eagercon.com> + + * config/rs6000/rs6000.c (rs6000_function_value): Set function return + reg for single-precision FPU. + * config/rs6000/rs6000.md (movsi_internal1): Only for + !TARGET_SINGLE_FPU. + (movsi_internal1_single): New. Add pattern to move SI values to/from + single-precision FP regs. + +2009-04-15 Richard Guenther <rguenther@suse.de> + + * omp-low.c (lower_rec_input_clauses): Build correct address + expressions. + (expand_omp_for_generic): Fix multiplication type. + * tree-loop-distribution.c (build_size_arg): Build a size_t argument. + (generate_memset_zero): Fix types. + * tree-profile.c (prepare_instrumented_value): Correctly + widen a pointer. + +2009-04-15 Ian Lance Taylor <iant@google.com> + + * c.opt (Wenum-compare): Enable for C and Objc. Initialize to -1. + * c-opts.c (c_common_handle_option): For C, set warn_enum_compare + for -Wall and for -Wc++-compat. + (c_common_post_options): For C++, set warn_enum_compare if not + already set. + * c-tree.h (struct c_expr): Add field original_type. + (build_external_ref): Update declaration. + * c-parser.c (c_parser_braced_init): Set original_type. + (c_parser_initelt): Likewise. + (c_parser_expr_no_commas): Likewise. + (c_parser_conditional_expression): Likewise. + (c_parser_cast_expression): Likewise. + (c_parser_unary_expression): Likewise. Pull setting of + original_code to top of function. + (c_parser_sizeof_expression): Set original_type. + (c_parser_alignof_expression): Likewise. + (c_parser_postfix_expression): Likewise. Pull setting of + original_code to top of function. + (c_parser_postfix_expression_after_paren_type): Set original_type. + (c_parser_postfix_expression_after_primary): Likewise. + (c_parser_expression): Likewise. + * c-typeck.c (build_external_ref): Add type parameter. Change all + callers. + (c_expr_sizeof_expr): Set original_type field. + (parser_build_unary_op): Likewise. + (parser_build_binary_op): Likewise. Optionally warn about + comparisons of enums of different types. + (digest_init): Set original_type field. + (really_start_incremental_init): Likewise. + (push_init_level, pop_init_level): Likewise. + * doc/invoke.texi (Warning Options): -Wenum-compare now + supported in C. + +2009-04-15 Richard Guenther <rguenther@suse.de> + + * tree-ssa-pre.c (eliminate): When replacing a PHI node carry + out a necessary conversion. + * tree-ssa-sccvn.c (run_scc_vn): Also assign value-ids to + names we didn't value number. + * tree-mudflap.c (mf_build_check_statement_for): Use correct types. + +2009-04-15 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39764 + * tree-ssa-ccp.c (get_value): Canonicalize value with + canonicalize_float_value. + +2009-04-15 Jan Hubicka <jh@suse.cz> + + * builtins.def (va_start, va_end, va_copy): Fix my previous commit. + Wrong version of patch. + +2009-04-15 Jan Hubicka <jh@suse.cz> + + * builtins.def (va_start, va_end, va_copy): Mark nothrow. + +2009-04-15 Nathan Sidwell <nathan@codesourcery.com> + + * config/rs6000/rs6000.c (rs6000_init_builtins): Set TYPE_NAME of + our distinct integral and vector types. + +2009-04-15 Rafael Avila de Espindola <espindola@google.com> + + * class.c (build_vtbl_ref_1): Remove call to assemble_external. + * init.c (build_vtbl_address): Remove call to assemble_external. + +2009-04-14 Daniel Jacobowitz <dan@codesourcery.com> + + * config/rs6000/rs6000.c (rs6000_dwarf_register_span): Fix debug + output for other floating point modes. + +2009-04-14 Diego Novillo <dnovillo@google.com> + + * diagnostic.c (diagnostic_report_diagnostic): Do not + warn about loaded plugins for DK_ERROR and DK_WARNING. + * c-decl.c (declspecs_add_type): Move call to + invoke_plugin_callbacks ... + * c-parser.c (c_parser_declspecs): ... here. + * plugin.c (dump_active_plugins): Tidy output. + +2009-04-14 Diego Novillo <dnovillo@google.com> + Le-Chun Wu <lcwu@google.com> + + * configure.ac: Add --enable-plugin support. + Define ENABLE_PLUGIN and PLUGINLIBS when specified. + * Makefile.in (PLUGIN_H): Define. + Export ENABLE_PLUGIN and GMPINC to site.exp. + Add PLUGINLIBS to link command. + Add/modify dependencies for plugin.o and files including plugin.h. + (plugin.o): New. + * config.in: Regenerate. + + * opts.c (common_handle_option): Handle OPT_fplugin_ and + OPT_fplugin_arg_. + +2009-04-14 Le-Chun Wu <lcwu@google.com> + + * tree-pass.h (register_one_dump_file): Add a prototype for + register_one_dump_file. + * toplev.c (compile_file): Call initialize_plugins. + (do_compile): Call invoke_plugin_callbacks. + (toplev_main): Call invoke_plugin_callbacks. + * common.opt: Add -fplugin= and -fplugin-arg-. + * gcc-plugin.h: New public header file for plugins to include. + * plugin.c: New source file. + * plugin.h: New internal header file. + * passes.c (register_one_dump_file): Make it external. + + * c-parser.c (c_parser_declspecs): Call invoke_plugin_callbacks. + +2009-04-14 Diego Novillo <dnovillo@google.com> + + * doc/plugins.texi: New. + * doc/gccint.texi: Add reference to Plugins chapter. + * doc/invoke.texi: Document -fplugin and -fplugin-arg + * diagnostic.c (diagnostic_report_diagnostic): Warn about + loaded plugins, if any. + * timevar.def (TV_PLUGIN_INIT): Define. + (TV_PLUGIN_RUN): Define. + * plugin.c: Include timevar.h + (plugins_active_p): New. + (dump_active_plugins): New. + (debug_active_plugins): New. + +2009-04-14 Joseph Myers <joseph@codesourcery.com> + + * config/sol2.h (LINK_ARCH32_SPEC_BASE): Use %R with absolute + library paths. + * config/sparc/sol2-bi.h (LINK_ARCH64_SPEC_BASE): Likewise. + +2009-04-14 Kazu Hirata <kazu@codesourcery.com> + + * config/arm/arm.c (arm_rtx_costs_1): Treat a minus with a shift + the same as a minus without a shift. + +2009-04-14 Nick Clifton <nickc@redhat.com> + + * config/stormy16/stormy16.md (ineqbranch_1): Do not assume that + comparisons with small integers will always produce a short + branch. + +2009-04-14 Rafael Avila de Espindola <espindola@google.com> + + Merge: + 2008-12-19 Diego Novillo <dnovillo@google.com> + + * cgraph.c (dump_cgraph_node): Show memory address of NODE. + +2009-04-14 Richard Guenther <rguenther@suse.de> + + * tree-cfg.c (verify_gimple_assign_unary): Adjust vector code + verification. + (verify_gimple_assign_binary): Likewise. Handle shifts and + rotates correctly. + (verify_gimple_phi): Print the mismatched argument position. + * tree-vect-loop-manip.c (vect_update_ivs_after_vectorizer): + Fix types. + (vect_update_init_of_dr): Likewise. + * matrix-reorg.c (transform_access_sites): Do what the + comment suggests. + * omp-low.c (expand_omp_atomic_pipeline): Use the correct types. + +2009-04-13 Michael Eager <eager@eagercon.com> + + * config/rs6000/rs6000-c.c: generate defines if rs6000_xilinx_fpu: + _XFPU, _XFPU_SP_LITE, _XFPU_SP_FULL, _XFPU_DP_LITE, _XFPU_DP_FULL + * config/rs6000/xilinx.h: New. Spec for powerpc-xilinx-eabi + * config.gcc (powerpc-xilinx-eabi): add xilinx.h to tm_file, + remove duplicate config + +2009-04-13 Dwarakanath Rajagopal <dwarak.rajagopal@amd.com> + + * ipa-inline.c (cgraph_decide_inlining_of_small_function): Dump + file_name:line_number type locator of the call site. + +2009-04-13 Vladimir Makarov <vmakarov@redhat.com> + + * genautomata.c: Put blank after comma. + (automaton_decls): New. + (struct unit_usage): Add comments to member next. + (store_alt_unit_usage): Keep the list ordered. + (unit_present_on_list_p, equal_alternatives_p): New. + (check_regexp_units_distribution): Check units distribution + correctness correctly. + (main): Don't write automata if error is found. Return correct + exit code. + + * config/m68k/cf.md (cfv4_ds): Remove. + (cfv4_pOEP1, cfv4_sOEP1, cfv4_pOEP2,cfv4_sOEP2, cfv4_pOEP3, + cfv4_sOEP3): Assign to cfv4_oep instead of cfv4_ds. + + * config/rs6000/power4.md (lsuq_power4, iq_power4, fpq_power4, + power4-load-ext, power4-store, power4-store-update, + power4-fpstore, power4-fpstore-update, power4-two, power4-three, + power4-insert, power4-compare, power4-lmul-cmp, power4-imul-cmp, + power4-lmul, , power4-imul, power4-imul3, power4-sdiv, + power4-sqrt, power4-isync): Modify reservation to make correct + unit distribution to automata. + + * config/rs6000/power5.md (iq_power5, fpq_power5, power5-store, + power5-store-update, power5-two, power5-three, power5-lmul, + power5-imul, power5-imul3, power5-sdiv, power5-sqrt): Ditto. + +2009-04-13 Adam Nemet <anemet@caviumnetworks.com> + + * except.c (pass_set_nothrow_function_flags): Set name and add + TODO_dump_func. + (set_nothrow_function_flags): Mention in the dump file when + changing a function to nothrow. + +2009-04-13 Ozkan Sezer <sezeroz@gmail.com> + + PR/39066 + * gbl-ctors.h (DO_GLOBAL_CTORS_BODY): Use __SIZE_TYPE__ + instead of unsigned long. + +2009-04-13 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * config/arm/arm.c (return_used_this_function): Remove. + (arm_output_function_prologue): Remove use of + return_used_this_function. + (output_return_instruction): Replace use of + return_used_this_function + by cfun->machine->return_used_this_function. + (arm_output_epilogue): Likewise. + (arm_output_function_epilogue): Likewise. + (thumb_unexpanded_epilogue): Likewise. + * config/arm/arm.h (struct machine_function): + New member return_used_this_function. + +2009-04-12 Mark Mitchell <mark@codesourcery.com> + + * doc/install.texi: Correct description of default directory for + --with-gxx-include-dir. + +2009-04-12 Eric Botcazou <ebotcazou@adacore.com> + + * fold-const.c (build_range_check): Properly deal with enumeral and + boolean base types. + +2009-04-12 Steven Bosscher <steven@gcc.gnu.org> + + * doc/invoke.texi (max_gcse_passes): Remove documentation. + * params.def (PARAM_MAX_GCSE_PASSES): Remove. + * params.h (MAX_GCSE_PASSES): Remove. + * gcse.c (gcse_main): Run CPROP1, PRE or HOIST, and CPROP2 + in sequence. Remove ability to run multiple passes. + (bypass_jumps): Report run as third CPROP pass. + +2009-04-12 Adam Nemet <anemet@caviumnetworks.com> + + PR middle-end/39651 + * except.c (can_throw_external): Look at each insn in a SEQUENCE + when deciding whether the whole SEQUENCE can throw. + +2009-04-12 Uros Bizjak <ubizjak@gmail.com> + + PR target/39740 + * config/alpha/predicates.md (local_symbolic_operand): Return 1 for + offseted label references. + +2009-04-11 Jan Hubicka <jh@suse.cz> + + * tree-ssa-pre.c (eliminate): Fix call of update_stmt. + +2009-04-11 Richard Guenther <rguenther@suse.de> + + PR middle-end/39732 + * tree-inline.c (declare_return_variable): Mark DECL_BY_REFERENCE + return variables as TREE_ADDRESSABLE. + +2009-04-11 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39713 + * tree-ssa-sccvn.c (vn_get_expr_for): Make sure built + reference trees have SSA_NAME operands. + +2009-04-11 Richard Guenther <rguenther@suse.de> + + PR c/39712 + * c-gimplify.c (c_gimplify_expr): Adjust check for mismatched + address expressions. + +2009-04-11 Dave Korn <dave.korn.cygwin@gmail.com> + + * config/i386/cygwin-stdint.h (INT_LEAST32_TYPE): Update to + match changes in Cygwin 1.7 + (UINT_LEAST32_TYPE, INT_FAST16_TYPE, INT_FAST32_TYPE, + UINT_FAST16_TYPE, UINT_FAST32_TYPE): Likewise. + +2009-04-10 Paolo Bonzini <bonzini@gnu.org> + + PR tree-optimization/39701 + * doc/invoke.texi (Optimization Options): Document change in + meaning and initialization of -fdelete-null-pointer-checks. + +2009-04-10 H.J. Lu <hongjiu.lu@intel.com> + + PR middle-end/39701 + * common.opt (-fdelete-null-pointer-checks): Initialize to 1. + + * opts.c (decode_options): Don't set flag_delete_null_pointer_checks + here. + + * doc/invoke.texi: Update -fdelete-null-pointer-checks. + +2009-04-10 Chao-ying Fu <fu@mips.com> + + * doc/tm.texi (Instruction Output): Document + TARGET_ASM_FINAL_POSTSCAN_INSN. + * target.h (final_postscan_insn): New field in asm_out. + * target-def.h (TARGET_ASM_FINAL_POSTSCAN_INSN): New define. + (TARGET_ASM_OUT): Add TARGET_ASM_FINAL_POSTSCAN_INSN. + * final.c (final_scan_insn): Call + targetm.asm_out.final_postscan_insn after outputting + an asm macro and a normal instruction. + + * config/mips/mips.h (FINAL_PRESCAN_INSN): New define. + * config/mips/mips-protos.h (mips_final_prescan_insn): Declare. + * config/mips/mips.c (mips_at_reg_p): New for_each_rtx callback. + (mips_final_prescan_insn, mips_final_postscan_insn): New functions. + (TARGET_ASM_FINAL_POSTSCAN_INSN): New define. + +2009-04-10 Paolo Bonzini <bonzini@gnu.org> + + PR middle-end/39701 + * fold-const.c (tree_single_nonzero_warnv_p): Pass non-static + variables as non-NULL even with -fdelete-null-pointer-checks. + +2009-04-10 H.J. Lu <hongjiu.lu@intel.com> + + * config/rs6000/darwin-vecsave.asm: Remove extra "*/". + +2009-04-09 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39678 + * config/i386/i386.c (classify_argument): Handle SCmode with + (bit_offset % 64) != 0. + +2009-04-09 Sandra Loosemore <sandra@codesourcery.com> + + * doc/invoke.texi (Optimize Options): Add cross-reference to + -Q --help=optimizers examples. + +2009-04-10 Ben Elliston <bje@au.ibm.com> + + PR target/36800 + * config/rs6000/rs6000.c (rs6000_gimplify_va_arg): Do not set + regalign for the reg == fpr and TDmode case. + +2009-04-09 David Ayers <ayers@fsfe.org> + + PR objc/29200 + * objc/objc-act.c (warn_with_method): Remove helper function. + (check_duplicates): Call warning and inform directly. + (really_start_method): Likewise. + +2009-04-09 Paolo Bonzini <bonzini@gnu.org> + + * expmed.c (expand_divmod): Always use a comparison for a division + by a large unsigned integer. + + * fold-const.c (tree_single_nonzero_warnv_p): Always treat decls + for things others than variables or functions as nonzero. + +2009-04-09 Nick Clifton <nickc@redhat.com> + + * unwind-compat.c: Change copyright header to refer to version + 3 of the GNU General Public License with version 3.1 of the + GCC Runtime Library Exception and to point readers at the + COPYING3 and COPYING3.RUNTIME files and the FSF's license web page. + * config/alpha/crtfastmath.c: Likewise. + * config/alpha/linux-unwind.h: Likewise. + * config/alpha/qrnnd.asm: Likewise. + * config/alpha/vms-crt0-64.c: Likewise. + * config/alpha/vms-crt0.c: Likewise. + * config/alpha/vms-dwarf2.asm: Likewise. + * config/alpha/vms-dwarf2eh.asm: Likewise. + * config/alpha/vms-psxcrt0-64.c: Likewise. + * config/alpha/vms-psxcrt0.c: Likewise. + * config/alpha/vms_tramp.asm: Likewise. + * config/arc/initfini.c: Likewise. + * config/arc/lib1funcs.asm: Likewise. + * config/arm/bpabi-v6m.S: Likewise. + * config/arm/bpabi.S: Likewise. + * config/arm/bpabi.c: Likewise. + * config/arm/crti.asm: Likewise. + * config/arm/crtn.asm: Likewise. + * config/arm/ieee754-df.S: Likewise. + * config/arm/ieee754-sf.S: Likewise. + * config/arm/lib1funcs.asm: Likewise. + * config/arm/libunwind.S: Likewise. + * config/arm/linux-atomic.c: Likewise. + * config/arm/mmintrin.h: Likewise. + * config/arm/pr-support.c: Likewise. + * config/arm/unaligned-funcs.c: Likewise. + * config/arm/unwind-arm.c: Likewise. + * config/arm/unwind-arm.h: Likewise. + * config/avr/libgcc.S: Likewise. + * config/bfin/crti.s: Likewise. + * config/bfin/crtlibid.s: Likewise. + * config/bfin/crtn.s: Likewise. + * config/bfin/lib1funcs.asm: Likewise. + * config/bfin/linux-unwind.h: Likewise. + * config/cris/arit.c: Likewise. + * config/cris/cris_abi_symbol.c: Likewise. + * config/darwin-64.c: Likewise. + * config/darwin-crt2.c: Likewise. + * config/darwin-crt3.c: Likewise. + * config/darwin.h: Likewise. + * config/dbxelf.h: Likewise. + * config/dfp-bit.c: Likewise. + * config/dfp-bit.h: Likewise. + * config/elfos.h: Likewise. + * config/fixed-bit.c: Likewise. + * config/fixed-bit.h: Likewise. + * config/fp-bit.c: Likewise. + * config/fp-bit.h: Likewise. + * config/fr30/crti.asm: Likewise. + * config/fr30/crtn.asm: Likewise. + * config/fr30/lib1funcs.asm: Likewise. + * config/freebsd-spec.h: Likewise. + * config/frv/cmovd.c: Likewise. + * config/frv/cmovh.c: Likewise. + * config/frv/cmovw.c: Likewise. + * config/frv/frvbegin.c: Likewise. + * config/frv/frvend.c: Likewise. + * config/frv/lib1funcs.asm: Likewise. + * config/glibc-stdint.h: Likewise. + * config/h8300/clzhi2.c: Likewise. + * config/h8300/crti.asm: Likewise. + * config/h8300/crtn.asm: Likewise. + * config/h8300/ctzhi2.c: Likewise. + * config/h8300/fixunssfsi.c: Likewise. + * config/h8300/lib1funcs.asm: Likewise. + * config/h8300/parityhi2.c: Likewise. + * config/h8300/popcounthi2.c: Likewise. + * config/i386/ammintrin.h: Likewise. + * config/i386/att.h: Likewise. + * config/i386/avxintrin.h: Likewise. + * config/i386/biarch64.h: Likewise. + * config/i386/bmmintrin.h: Likewise. + * config/i386/cpuid.h: Likewise. + * config/i386/cross-stdarg.h: Likewise. + * config/i386/crtfastmath.c: Likewise. + * config/i386/crtprec.c: Likewise. + * config/i386/cygming-crtbegin.c: Likewise. + * config/i386/cygming-crtend.c: Likewise. + * config/i386/cygwin.asm: Likewise. + * config/i386/emmintrin.h: Likewise. + * config/i386/gmm_malloc.h: Likewise. + * config/i386/gthr-win32.c: Likewise. + * config/i386/i386.h: Likewise. + * config/i386/immintrin.h: Likewise. + * config/i386/linux-unwind.h: Likewise. + * config/i386/linux64.h: Likewise. + * config/i386/mm3dnow.h: Likewise. + * config/i386/mmintrin-common.h: Likewise. + * config/i386/mmintrin.h: Likewise. + * config/i386/nmmintrin.h: Likewise. + * config/i386/pmm_malloc.h: Likewise. + * config/i386/pmmintrin.h: Likewise. + * config/i386/smmintrin.h: Likewise. + * config/i386/sol2-c1.asm: Likewise. + * config/i386/sol2-ci.asm: Likewise. + * config/i386/sol2-cn.asm: Likewise. + * config/i386/sol2-gc1.asm: Likewise. + * config/i386/tmmintrin.h: Likewise. + * config/i386/unix.h: Likewise. + * config/i386/w32-unwind.h: Likewise. + * config/i386/wmmintrin.h: Likewise. + * config/i386/x86-64.h: Likewise. + * config/i386/x86intrin.h: Likewise. + * config/i386/xmmintrin.h: Likewise. + * config/ia64/crtbegin.asm: Likewise. + * config/ia64/crtend.asm: Likewise. + * config/ia64/crtfastmath.c: Likewise. + * config/ia64/crti.asm: Likewise. + * config/ia64/crtn.asm: Likewise. + * config/ia64/fde-glibc.c: Likewise. + * config/ia64/lib1funcs.asm: Likewise. + * config/ia64/linux-unwind.h: Likewise. + * config/ia64/quadlib.c: Likewise. + * config/ia64/unwind-ia64.c: Likewise. + * config/linux.h: Likewise. + * config/m32c/m32c-lib1.S: Likewise. + * config/m32c/m32c-lib2-trapv.c: Likewise. + * config/m32c/m32c-lib2.c: Likewise. + * config/m32r/initfini.c: Likewise. + * config/m68hc11/larith.asm: Likewise. + * config/m68hc11/m68hc11-crt0.S: Likewise. + * config/m68k/cf.md: Likewise. + * config/m68k/crti.s: Likewise. + * config/m68k/crtn.s: Likewise. + * config/m68k/lb1sf68.asm: Likewise. + * config/m68k/linux-unwind.h: Likewise. + * config/mcore/crti.asm: Likewise. + * config/mcore/crtn.asm: Likewise. + * config/mcore/lib1.asm: Likewise. + * config/mips/linux-unwind.h: Likewise. + * config/mips/loongson.h: Likewise. + * config/mips/mips16.S: Likewise. + * config/mmix/crti.asm: Likewise. + * config/mmix/crtn.asm: Likewise. + * config/pa/fptr.c: Likewise. + * config/pa/hpux-unwind.h: Likewise. + * config/pa/lib2funcs.asm: Likewise. + * config/pa/linux-atomic.c: Likewise. + * config/pa/linux-unwind.h: Likewise. + * config/pa/milli64.S: Likewise. + * config/pa/quadlib.c: Likewise. + * config/pa/stublib.c: Likewise. + * config/picochip/libgccExtras/adddi3.asm: Likewise. + * config/picochip/libgccExtras/ashlsi3.asm: Likewise. + * config/picochip/libgccExtras/ashlsi3.c: Likewise. + * config/picochip/libgccExtras/ashrsi3.asm: Likewise. + * config/picochip/libgccExtras/ashrsi3.c: Likewise. + * config/picochip/libgccExtras/cmpsi2.asm: Likewise. + * config/picochip/libgccExtras/divmod15.asm: Likewise. + * config/picochip/libgccExtras/divmodhi4.asm: Likewise. + * config/picochip/libgccExtras/divmodsi4.asm: Likewise. + * config/picochip/libgccExtras/longjmp.asm: Likewise. + * config/picochip/libgccExtras/lshrsi3.asm: Likewise. + * config/picochip/libgccExtras/lshrsi3.c: Likewise. + * config/picochip/libgccExtras/parityhi2.asm: Likewise. + * config/picochip/libgccExtras/popcounthi2.asm: Likewise. + * config/picochip/libgccExtras/setjmp.asm: Likewise. + * config/picochip/libgccExtras/subdi3.asm: Likewise. + * config/picochip/libgccExtras/ucmpsi2.asm: Likewise. + * config/picochip/libgccExtras/udivmodhi4.asm: Likewise. + * config/picochip/libgccExtras/udivmodsi4.asm: Likewise. + * config/rs6000/750cl.h: Likewise. + * config/rs6000/altivec.h: Likewise. + * config/rs6000/biarch64.h: Likewise. + * config/rs6000/crtresfpr.asm: Likewise. + * config/rs6000/crtresgpr.asm: Likewise. + * config/rs6000/crtresxfpr.asm: Likewise. + * config/rs6000/crtresxgpr.asm: Likewise. + * config/rs6000/crtsavfpr.asm: Likewise. + * config/rs6000/crtsavgpr.asm: Likewise. + * config/rs6000/darwin-asm.h: Likewise. + * config/rs6000/darwin-fallback.c: Likewise. + * config/rs6000/darwin-fpsave.asm: Likewise. + * config/rs6000/darwin-ldouble.c: Likewise. + * config/rs6000/darwin-tramp.asm: Likewise. + * config/rs6000/darwin-unwind.h: Likewise. + * config/rs6000/darwin-vecsave.asm: Likewise. + * config/rs6000/darwin-world.asm: Likewise. + * config/rs6000/e500crtres32gpr.asm: Likewise. + * config/rs6000/e500crtres64gpr.asm: Likewise. + * config/rs6000/e500crtres64gprctr.asm: Likewise. + * config/rs6000/e500crtrest32gpr.asm: Likewise. + * config/rs6000/e500crtrest64gpr.asm: Likewise. + * config/rs6000/e500crtresx32gpr.asm: Likewise. + * config/rs6000/e500crtresx64gpr.asm: Likewise. + * config/rs6000/e500crtsav32gpr.asm: Likewise. + * config/rs6000/e500crtsav64gpr.asm: Likewise. + * config/rs6000/e500crtsav64gprctr.asm: Likewise. + * config/rs6000/e500crtsavg32gpr.asm: Likewise. + * config/rs6000/e500crtsavg64gpr.asm: Likewise. + * config/rs6000/e500crtsavg64gprctr.asm: Likewise. + * config/rs6000/eabi-ci.asm: Likewise. + * config/rs6000/eabi-cn.asm: Likewise. + * config/rs6000/eabi.asm: Likewise. + * config/rs6000/linux-unwind.h: Likewise. + * config/rs6000/linux64.h: Likewise. + * config/rs6000/paired.h: Likewise. + * config/rs6000/paired.md: Likewise. + * config/rs6000/ppc64-fp.c: Likewise. + * config/rs6000/ppu_intrinsics.h: Likewise. + * config/rs6000/rs6000.h: Likewise. + * config/rs6000/si2vmx.h: Likewise. + * config/rs6000/sol-ci.asm: Likewise. + * config/rs6000/sol-cn.asm: Likewise. + * config/rs6000/spe.h: Likewise. + * config/rs6000/spu2vmx.h: Likewise. + * config/rs6000/sysv4.h: Likewise. + * config/rs6000/tramp.asm: Likewise. + * config/rs6000/vec_types.h: Likewise. + * config/s390/linux-unwind.h: Likewise. + * config/s390/tpf-unwind.h: Likewise. + * config/score/crti.asm: Likewise. + * config/score/crtn.asm: Likewise. + * config/sh/crt1.asm: Likewise. + * config/sh/crti.asm: Likewise. + * config/sh/crtn.asm: Likewise. + * config/sh/divtab-sh4-300.c: Likewise. + * config/sh/divtab-sh4.c: Likewise. + * config/sh/divtab.c: Likewise. + * config/sh/lib1funcs-4-300.asm: Likewise. + * config/sh/lib1funcs-Os-4-200.asm: Likewise. + * config/sh/lib1funcs.asm: Likewise. + * config/sh/lib1funcs.h: Likewise. + * config/sh/linux-atomic.asm: Likewise. + * config/sh/linux-unwind.h: Likewise. + * config/sh/shmedia.h: Likewise. + * config/sh/sshmedia.h: Likewise. + * config/sh/ushmedia.h: Likewise. + * config/sparc/crtfastmath.c: Likewise. + * config/sparc/linux-unwind.h: Likewise. + * config/sparc/sol2-c1.asm: Likewise. + * config/sparc/sol2-ci.asm: Likewise. + * config/sparc/sol2-cn.asm: Likewise. + * config/spu/divmodti4.c: Likewise. + * config/spu/divv2df3.c: Likewise. + * config/spu/float_disf.c: Likewise. + * config/spu/float_unsdidf.c: Likewise. + * config/spu/float_unsdisf.c: Likewise. + * config/spu/float_unssidf.c: Likewise. + * config/spu/mfc_multi_tag_release.c: Likewise. + * config/spu/mfc_multi_tag_reserve.c: Likewise. + * config/spu/mfc_tag_release.c: Likewise. + * config/spu/mfc_tag_reserve.c: Likewise. + * config/spu/mfc_tag_table.c: Likewise. + * config/spu/multi3.c: Likewise. + * config/spu/spu_internals.h: Likewise. + * config/spu/spu_intrinsics.h: Likewise. + * config/spu/spu_mfcio.h: Likewise. + * config/spu/vec_types.h: Likewise. + * config/spu/vmx2spu.h: Likewise. + * config/stormy16/stormy16-lib2.c: Likewise. + * config/svr4.h: Likewise. + * config/sync.c: Likewise. + * config/v850/lib1funcs.asm: Likewise. + * config/vxlib-tls.c: Likewise. + * config/vxlib.c: Likewise. + * config/vxworks-dummy.h: Likewise. + * config/xtensa/crti.asm: Likewise. + * config/xtensa/crtn.asm: Likewise. + * config/xtensa/ieee754-df.S: Likewise. + * config/xtensa/ieee754-sf.S: Likewise. + * config/xtensa/lib1funcs.asm: Likewise. + * config/xtensa/lib2funcs.S: Likewise. + * config/xtensa/linux-unwind.h: Likewise. + * config/xtensa/unwind-dw2-xtensa.c: Likewise. + * config/xtensa/unwind-dw2-xtensa.h: Likewise. + * coretypes.h: Likewise. + * crtstuff.c: Likewise. + * defaults.h: Likewise. + * dwarf2.h: Likewise. + * emutls.c: Likewise. + * gbl-ctors.h: Likewise. + * gcov-io.h: Likewise. + * ginclude/float.h: Likewise. + * ginclude/iso646.h: Likewise. + * ginclude/stdarg.h: Likewise. + * ginclude/stdbool.h: Likewise. + * ginclude/stddef.h: Likewise. + * ginclude/stdfix.h: Likewise. + * ginclude/stdint-gcc.h: Likewise. + * ginclude/tgmath.h: Likewise. + * gthr-aix.h: Likewise. + * gthr-dce.h: Likewise. + * gthr-gnat.c: Likewise. + * gthr-gnat.h: Likewise. + * gthr-lynx.h: Likewise. + * gthr-mipssde.h: Likewise. + * gthr-nks.h: Likewise. + * gthr-posix.c: Likewise. + * gthr-posix.h: Likewise. + * gthr-posix95.h: Likewise. + * gthr-rtems.h: Likewise. + * gthr-single.h: Likewise. + * gthr-solaris.h: Likewise. + * gthr-tpf.h: Likewise. + * gthr-vxworks.h: Likewise. + * gthr-win32.h: Likewise. + * gthr.h: Likewise. + * libgcc2.c: Likewise. + * libgcc2.h: Likewise. + * libgcov.c: Likewise. + * tsystem.h: Likewise. + * typeclass.h: Likewise. + * unwind-c.c: Likewise. + * unwind-compat.h: Likewise. + * unwind-dw2-fde-compat.c: Likewise. + * unwind-dw2-fde-darwin.c: Likewise. + * unwind-dw2-fde-glibc.c: Likewise. + * unwind-dw2-fde.c: Likewise. + * unwind-dw2-fde.h: Likewise. + * unwind-dw2.c: Likewise. + * unwind-dw2.h: Likewise. + * unwind-generic.h: Likewise. + * unwind-pe.h: Likewise. + * unwind-sjlj.c: Likewise. + * unwind.inc: Likewise. + * config/arm/neon-gen.ml: Change generated copyright header to + refer to version 3 of the GNU General Public License with + version 3.1 of the GCC Runtime Library Exception and to point + readers at the COPYING3 and COPYING3.RUNTIME files and the + FSF's license web page. + * config/arm/arm_neon.h: Regenerate. + +2009-04-09 Jakub Jelinek <jakub@redhat.com> + + * config/cris/cris.md: Change copyright header to refer to version + 3 of the GNU General Public License. + * doc/install.texi2html: Change copyright header to refer to version + 3 of the GNU General Public License and to point readers at the + COPYING3 file and the FSF's license web page. + * config/vax/linux.h: Likewise. + +2009-04-09 Paolo Bonzini <bonzini@gnu.org> + + * config/i386/i386.md (cmpcc): New. + * config/i386/sync.md (sync_compare_and_swap*): Set FLAGS_REG. + (sync_compare_and_swap_cc*): Delete. + + * config/s390/s390.c (s390_compare_emitted): Remove. + (s390_emit_compare): Handle MODE_CC s390_compare_op0 like + s390_compare_emitted used to be handled. Assert that modes match. + (s390_emit_compare_and_swap): Use s390_emit_compare, do not + refer to sync_compare_and_swap_ccsi. + * config/s390/s390.h (s390_compare_emitted): Remove. + * config/s390/s390.md (seq): Look for MODE_CC s390_compare_op0 + instead of s390_compare_emitted. + (stack_protect_test, sync_compare_and_swap_cc): Set s390_compare_op0 + instead of s390_compare_emitted. + * config/s390/s390.md (cmpcc): New. + (sync_compare_and_swapqi, sync_compare_and_swaphi): Clobber + CC_REGNUM, do not pretend it's set. + (sync_compare_and_swap_cc*): Delete. + * config/s390/predicates.md (cc_reg_operand): New. + + * expr.c (sync_compare_and_swap_cc): Delete. + * optabs.h (sync_compare_and_swap_cc): Delete. + * optabs.c (prepare_cmp_insn): Ignore which specific CCmode + is being used with can_compare_p. + (emit_cmp_and_jump_insn_1): Likewise when looking in the optab. + (find_cc_set): New. + (expand_bool_compare_and_swap): Do not use sync_compare_and_swap_cc, + look for a MODE_CC set instead. Use emit_store_flag. + (expand_compare_and_swap_loop): Likewise, with some additional + complication to avoid a force_reg when useless. Use + emit_cmp_and_jump_insns. + * genopinit.c (optabs): Delete sync_compare_and_swap_cc. + * doc/md.texi (sync_compare_and_swap_cc): Merge with + sync_compare_and_swap documentation. + +2009-04-09 Jan Hubicka <jh@suse.cz> + + * except.c (find_prev_try): Break out from .... + (duplicate_eh_regions): ... here; properly update prev_try pointers + when duplication part of tree. + (dump_eh_tree): Improve dumping. + (verify_eh_region): New. + (verify_eh_tree): Use it. + +2009-04-06 Richard Guenther <rguenther@suse.de> + + * c-gimplify.c (c_gimplify_expr): Fix the invalid GENERIC + &ARRAY addresses by adjusting their types and prepending + a conversion. + * tree-cfg.c (verify_gimple_assign_single): Verify that + addresses are correct. + +2009-04-09 Richard Guenther <rguenther@suse.de> + + * tree-ssa-ccp.c (maybe_fold_stmt_addition): Move non-constant + indices into an array reference if possible. + * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars): + Fold POINTER_PLUS_EXPR statements with invariant address. + +2009-04-09 Alan Modra <amodra@bigpond.net.au> + + PR target/39634 + * config.gcc (powerpc64-*-linux*): Always build biarch. + +2009-04-09 Joseph Myers <joseph@codesourcery.com> + + PR c/39613 + * c-typeck.c (do_case): If case label is not an INTEGER_CST, fold + it and pedwarn if this results in an INTEGER_CST. + +2009-04-08 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * doc/install.texi: Update minimum GMP version. Remove obsolete + text in MPFR section. + +2009-04-08 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (class_scope_p): New static inline. + (class_or_namespace_scope_p): Use it. + (gen_variable_die): Use DW_TAG_member tag for static data member + declarations instead of DW_TAG_variable. + + PR middle-end/39573 + * omp-low.c (expand_omp_taskreg): Finalize taskreg static local_decls + variables. + +2009-04-08 Richard Guenther <rguenther@suse.de> + + * tree-ssa-sccvn.c (valueize_refs): Do not continue to + valueize random data. + +2009-04-08 David Edelsohn <edelsohn@gnu.org> + + * config.gcc (aix tm_file): Add aix-stdint.h. + (aix tm clause use_gcc_stdint): Set to wrap. + * config/rs6000/aix-stdint.h: New file. + +2009-04-08 Richard Guenther <rguenther@suse.de> + + PR middle-end/36291 + * tree-dfa.c (add_referenced_var): Do not recurse into + global initializers. + * tree-ssa-ccp.c (get_symbol_constant_value): Add newly + exposed variables. + (fold_const_aggregate_ref): Likewise. + +2009-04-08 Paolo Bonzini <bonzini@gnu.org> + + * recog.c (ordered_comparison_operator): New. + * gensupport.c (std_preds): Add it. + * doc/md.texi (Machine-Independent Predicates): Document it. + +2009-04-08 Jan Hubicka <jh@suse.cz> + + * tree-eh.c (cleanup_eh): When not optimizing, do not try EH merging. + * function.h (rtl_eh): Remove exception_handler_label_map. + * except.c (ehl_hash, ehl_eq, add_ehl_entry, + remove_exception_handler_label, for_each_eh_label_1): Remove. + (rtl_remove_unreachable_regions): Remove. + (convert_from_eh_region_ranges): Do not remove unreachable regions. + (find_exception_handler_labels): Don't build the hashtable. + (maybe_remove_eh_handler): Remove. + (for_each_eh_label): Rewrite to walk the tree. + (rest_of_handle_eh): Do not cleanup cfg prior EH construction. + * except.h (maybe_remove_eh_handler): Remove. + * passes.c (init_optimization_passes): Schedule second EH cleanup + before out-of-ssa. + * cfgrtl.c (rtl_delete_block, rtl_merge_blocks, + cfg_layout_merge_blocks): Do not call maybe_remove_eh_handler. + +2009-04-08 Paolo Bonzini <bonzini@gnu.org> + + * genoutput.c (validate_optab_operands): New. + (gen_insn, gen_expand): Call it. + + * genflags.c (gen_insn): Detect misused iterators. + (main): Pass line_no to gen_insn, exit with status 1 on error. + + * genextract.c (line_no): Make global. + (VEC_safe_set_locstr): Change assertion to error message. + (main): Exit with status 1 on error. + +2009-04-08 Joseph Myers <joseph@codesourcery.com> + + PR c/39614 + PR c/39673 + * c-common.h (C_MAYBE_CONST_EXPR_PRE, C_MAYBE_CONST_EXPR_EXPR, + C_MAYBE_CONST_EXPR_INT_OPERANDS, C_MAYBE_CONST_EXPR_NON_CONST, + EXPR_INT_CONST_OPERANDS): Remove duplicate definitions. + * c-convert.c (convert): Do not call fold on results of conversion + functions when the result is a C_MAYBE_CONST_EXPR. + * c-parser.c (c_parser_postfix_expression): Do not fold condition + of __builtin_choose_expr. + * c-typeck.c (remove_c_maybe_const_expr): New. + (build_unary_op, build_conditional_expr, build_compound_expr, + build_binary_op, c_objc_common_truthvalue_conversion): Call + remove_c_maybe_const_expr on any input C_MAYBE_CONST_EXPR with + integer operands. + +2009-04-08 Bingfeng Mei <bmei@broadcom.com> + + * fold-const.c (const_binop): Combine two VECTOR_CST under operation + CODE to produce a new one. Add a prototype to use fold_convert_const + +2009-04-08 Danny Smith <dannysmith@users.sourceforge.net> + + PR bootstrap/39660 + * config/i386/host-mingw32.c (mingw32_gt_pch_use_address): Don't + mix declarations and code. + +2009-04-08 Ben Elliston <bje@au.ibm.com> + + * gcc.c: Replace `CC' with `GCC' throughout. + +2009-04-07 H.J. Lu <hongjiu.lu@intel.com> + + * doc/invoke.texi: Document Atom support. + +2009-04-07 Jason Merrill <jason@redhat.com> + + PR c++/25185 + * c-common.h, c-common.c: Add flag_pretty_templates. + * c-opts.c (c_common_handle_option): Set it. + * c.opt: Add -fno-pretty-templates. + * doc/invoke.texi (C++ Dialect Options): Likewise. + +2009-04-07 Uros Bizjak <ubizjak@gmail.com> + + * config/ia64/ia64.c (ia64_builtins): Add IA64_BUILTIN_HUGE_VALQ. + (ia64_init_builtins): Handle IA64_BUILTIN_HUGE_VALQ. + (ia64_expand_builtin): Likewise. + +2009-04-07 Martin Jambor <mjambor@suse.cz> + + * tree-ssa-alias.c (refs_may_alias_p_1): Check for + is_gimple_min_invariant rather than CONSTANT_CLASS_P so that invariant + ADDR_EXPRS are include too. + +2009-04-07 Richard Guenther <rguenther@suse.de> + + * tree-ssa-alias.c (ref_maybe_used_by_call_p_1): Non-aliased + decls are only used if passes as parameters or if they are + local statics and the call is not to a builtin. + (call_may_clobber_ref_p_1): Likewise. + +2009-04-07 Paolo Bonzini <bonzini@gnu.org> + + * expr.c (do_store_flag): Remove last argument. Simplify code + to avoid duplication of tests already done by can_compare_p. + (expand_expr_real_1): Adjust caller. + +2009-04-07 Paolo Bonzini <bonzini@gnu.org> + + * optabs.c (can_compare_p): Test the predicate of a + cbranch and cstore pattern. + +2009-04-07 Paolo Bonzini <bonzini@gnu.org> + + * expr.c (convert_move): Use emit_store_flag instead of + "emulating" it. + +2009-04-07 Paolo Bonzini <bonzini@gnu.org> + + * config/i386/i386.c (ix86_compare_emitted): Remove. + (ix86_expand_compare, ix86_expand_branch): Handle MODE_CC + ix86_compare_op0 like ix86_compare_emitted used to be handled. + * config/i386/i386.h (ix86_compare_emitted): Remove. + * config/i386/i386.md (stack_protect_test): Set ix86_compare_op0 + instead of ix86_compare_emitted. + * config/i386/sync.md (sync_compare_and_swap_cc): Likewise. + +2009-04-07 Andrew Stubbs <ams@codesourcery.com> + + * config.gcc (sh-*-*): Add sysroot-suffix.h to tm_file. + Add t-sysroot-suffix to tmake_file. + * config/print-sysroot-suffix.sh: New file. + * config/t-sysroot-suffix: New file. + +2009-04-07 Ben Elliston <bje@au.ibm.com> + + * libgcc2.c (INFINITY): Use __builtin_huge_val, not __builtin_inf, + as the latter produces a warning when the target does not support + infinity. + +2009-04-07 Ben Elliston <bje@au.ibm.com> + + * dfp.c: Replace type punning assignments with memcpy throughout. + * Makefile.in (dfp.o-warn): Remove. + +2009-04-07 Alan Modra <amodra@bigpond.net.au> + + PR target/39634 + * config.gcc: Merge powerpc-*-linux* and powerpc64-*-linux*. + Include soft-fp/t-softfp after rs6000/t-linux64. + +2009-04-06 Eric Botcazou <ebotcazou@adacore.com> + + * stor-layout.c (set_sizetype): Use the full precision of their + machine mode for bitsize types. + +2009-04-06 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.md: Revert 2 accidental checkins. + +2009-04-06 Joey Ye <joey.ye@intel.com> + Xuepeng Guo <xuepeng.guo@intel.com> + H.J. Lu <hongjiu.lu@intel.com> + + Atom pipeline model, tuning and insn selection. + * config.gcc (atom): Add atom config options and target. + + * config/i386/atom.md: New. + + * config/i386/i386.c (atom_cost): New cost. + (m_ATOM): New macro flag. + (initial_ix86_tune_features): Set m_ATOM. + (x86_accumulate_outgoing_args): Likewise. + (x86_arch_always_fancy_math_387): Likewise. + (processor_target): Add Atom cost. + (cpu_names): Add Atom cpu name. + (override_options): Set Atom ISA. + (ix86_issue_rate): New case PROCESSOR_ATOM. + (ix86_adjust_cost): Likewise. + + * config/i386/i386.h (TARGET_ATOM): New target macro. + (ix86_tune_indices): Add X86_TUNE_OPT_AGU. + (TARGET_OPT_AGU): New target option. + (target_cpu_default): Add TARGET_CPU_DEFAULT_atom. + (processor_type): Add PROCESSOR_ATOM. + + * config/i386/i386.md (cpu): Add new value "atom". + (use_carry, movu): New attr. + (atom.md): Include atom.md. + (adddi3_carry_rex64): Set attr "use_carry". + (addqi3_carry): Likewise. + (addhi3_carry): Likewise. + (addsi3_carry): Likewise. + (*addsi3_carry_zext): Likewise. + (subdi3_carry_rex64): Likewise. + (subqi3_carry): Likewise. + (subhi3_carry): Likewise. + (subsi3_carry): Likewise. + (x86_movdicc_0_m1_rex64): Likewise. + (*x86_movdicc_0_m1_se): Likewise. + (x86_movsicc_0_m1): Likewise. + (*x86_movsicc_0_m1_se): Likewise. + (*adddi_1_rex64): Emit add insn as much as possible. + (*addsi_1): Likewise. + (return_internal): Set atom_unit. + (return_internal_long): Likewise. + (return_pop_internal): Likewise. + (*rcpsf2_sse): Set atom_sse_attr attr. + (*qrt<mode>2_sse): Likewise. + (*prefetch_sse): Likewise. + + * config/i386/i386-c.c (ix86_target_macros_internal): New case + PROCESSOR_ATOM. + (ix86_target_macros_internal): Likewise. + + * config/i386/sse.md (cpu): Set attr "atom_sse_attr". + (*prefetch_sse_rex): Likewise. + (sse_rcpv4sf2): Likewise. + (sse_vmrcpv4sf2): Likewise. + (sse_sqrtv4sf2): Likewise. + (<sse>_vmsqrt<mode>2): Likewise. + (sse_ldmxcsr): Likewise. + (sse_stmxcsr): Likewise. + (*sse_sfence): Likewise. + (sse2_clflush): Likewise. + (*sse2_mfence): Likewise. + (*sse2_lfence): Likewise. + (avx_movup<avxmodesuffixf2c><avxmodesuffix>): Set attr "movu". + (<sse>_movup<ssemodesuffixf2c>): Likewise. + (avx_movdqu<avxmodesuffix>): Likewise. + (avx_lddqu<avxmodesuffix>): Likewise. + (sse2_movntv2di): Change attr "type" to "ssemov". + (sse2_movntsi): Likewise. + (rsqrtv8sf2): Change attr "type" to "sseadd". + (sse3_addsubv2df3): Set attr "atom_unit". + (sse3_h<plusminus_insn>v4sf3): Likewise. + (*sse2_pmaddwd): Likewise. + (*vec_extractv2di_1_rex64): Likewise. + (*vec_extractv2di_1_avx): Likewise. + (sse2_psadbw): Likewise. + (ssse3_phaddwv8hi3): Likewise. + (ssse3_phaddwv4hi3): Likewise. + (ssse3_phadddv4si3): Likewise. + (ssse3_phadddv2si3): Likewise. + (ssse3_phaddswv8hi3): Likewise. + (ssse3_phaddswv4hi3): Likewise. + (ssse3_phsubwv8hi3): Likewise. + (ssse3_phsubwv4hi3): Likewise. + (ssse3_phsubdv4si3): Likewise. + (ssse3_phsubdv2si3): Likewise. + (ssse3_phsubswv8hi3): Likewise. + (ssse3_phsubswv4hi3): Likewise. + (ssse3_pmaddubsw128): Likewise. + (sse3_pmaddubsw: Likewise. + (ssse3_palignrti): Likewise. + (ssse3_palignrdi): Likewise. + +2009-04-06 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (Specific): Fix two cross-references to MinGW. + +2009-04-06 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/28868 + * tree-ssa-pre.c (inserted_phi_names): New bitmap to keep track + of which PHI results we inserted. + (insert_into_preds_of_block): Record inserted PHIs. + (eliminate): Eliminate redundant PHI nodes. + (init_pre): Init inserted_phi_names. + +2009-04-06 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39643 + * tree-ssa-ccp.c (ccp_fold): Fold REALPART_EXPRs and + IMAGPART_EXPRs of complex constants. + (execute_fold_all_builtins): If we folded a call queue + TODO_update_address_taken. + +2009-04-06 Jan Hubicka <jh@suse.cz> + + PR middle-end/39659 + * except.c (remove_unreachable_regions): Propagate may_contain_throw + flag. + +2009-04-06 Andrew Stubbs <ams@codesourcery.com> + + * config/sh/lib1funcs.asm (ic_invalidate): Move ICBI out of the + delay slot. + (ic_invalidate_array): Likewise. + +2009-04-06 Hariharan Sandanagobalane <hariharan@picochip.com> + + * calls.c (emit_library_call_value_1): Fix a problem with parameter + alignment for library calls. + +2009-04-06 Danny Smith <dannysmith@users.sourceforge.net> + + * config.gcc (mingw32 tm_file): Add mingw-stdint.h. + (mingw32 tm clause use_gcc_stdint): Set to wrap. + * config/i386/mingw-stdint.h: New file. + +2009-04-05 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39648 + * tree-ssa-sccvn.c (vn_reference_fold_indirect): Work around + our &A vs. &A[0] IL deficiencies. + +2009-04-04 Jan Hubicka <jh@suse.cz> + + * except.c (sjlj_find_directly_reachable_regions): Be ready for + removed toplevel regions. + (sjlj_mark_call_sites): Likewise. + +2009-04-04 Dave Korn <dave.korn.cygwin@gmail.com> + + * config.gcc (cygwin tm_file): Add cygwin-stdint.h. + (cygwin tm clause use_gcc_stdint): Set to wrap. + * config/i386/cygwin-stdint.h: New file. + +2009-04-04 Richard Guenther <rguenther@suse.de> + + * Makefile.in (tree-ssa-copy.o): Add $(CFGLOOP_H) dependency. + * tree-ssa-copy.c (init_copy_prop): Do not propagate through + single-argument PHIs if we are in loop-closed SSA form. + * tree-vect-loop-manip.c (slpeel_add_loop_guard): Pass extra guards + for the pre-condition. + (slpeel_tree_peel_loop_to_edge): Likewise. + (vect_build_loop_niters): Take an optional sequence to append stmts. + (vect_generate_tmps_on_preheader): Likewise. + (vect_do_peeling_for_loop_bound): Take extra guards for the + pre-condition. + (vect_do_peeling_for_alignment): Adjust. Unconditionally apply + the cost model check. + (vect_loop_versioning): Take stmt and stmt list to put pre-condition + guards if we are going to peel. Do not apply versioning in that case. + * tree-vectorizer.h (vect_loop_versioning): Adjust declaration. + (vect_do_peeling_for_loop_bound): Likewise. + * tree-vect-loop.c (vect_transform_loop): If we are peeling for + loop bound only record extra pre-conditions, do not apply loop + versioning. + +2009-04-04 Richard Guenther <rguenther@suse.de> + + * tree-ssa-operands.c (pop_stmt_changes): Remove automatic + renaming code. + +2009-04-04 Jan Hubicka <jh@suse.cz> + + * tree-ssa-uncprop.c (associate_equivalences_with_edges): Use + last_basic_block for size of bb->index indexed array. + * bt-load.c (compute_defs_uses_and_gen, compute_kill, + compute_out, link_btr_uses, build_btr_def_use_webs, + build_btr_def_use_webs, migrate_btr_defs): Likewise. + +2009-04-04 Jan Hubicka <jh@suse.cz> + + * except.c (remove_eh_handler_and_replace): Break out from ... + (remove_eh_handler): ... here. + (bring_to_root): New function. + (remove_unreachable_regions): Collect MUST_NOT_THROW, unify runtime + handled ones, bring others to root of tree. + +2009-04-04 Jan Hubicka <jh@suse.cz> + + * tree-eh.c (tree_empty_eh_handler_p): Pattern match more curefully. + (all_phis_safe_to_merge): New function. + (update_info): New structure. + (make_eh_edge_and_update_phi, update_eh_edges): New functions. + (cleanup_empty_eh): Update SSA if possible. + +2009-04-04 Richard Guenther <rguenther@suse.de> + + * tree-ssa.c (verify_ssa): With -O0 we do not need VOPs. + * tree-ssa-operands.c (append_vdef): Do not append VOPs at -O0. + (append_vuse): Likewise. + +2009-04-04 Jakub Jelinek <jakub@redhat.com> + + * unwind-dw2.h (_Unwind_FrameState): Add REG_UNDEFINED enum value. + * unwind-dw2.c (execute_cfa_program): Set how to REG_UNDEFINED + instead of REG_UNSAVED for DW_CFA_undefined. + (uw_update_context_1): Handle REG_UNDEFINED the same as REG_UNSAVED. + (uw_update_context): If RA column is REG_UNDEFINED, mark it as + outermost frame. + +2009-04-04 Richard Earnshaw <rearnsha@arm.com> + + PR target/39501 + * arm.md (movsfcc): Disable if not TARGET_HARD_FLOAT. + +2009-04-04 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/8781 + PR tree-optimization/37892 + * tree-ssa-sccvn.h (vn_reference_fold_indirect): Declare. + * tree-ssa-sccvn.c (vn_reference_fold_indirect): New function. + (valueize_refs): Call it for *& valueizations. + (shared_reference_ops_from_ref): Rename to ... + (valueize_shared_reference_ops_from_ref): ... this and valueize. + (shared_reference_ops_from_call): Rename to ... + (valueize_shared_reference_ops_from_call): ... this and valueize. + (vn_reference_lookup): Update. + (visit_reference_op_call): Likewise. + * tree-ssa-pre.c (phi_translate_1): Fold *&. + (eliminate): Value-replace the call address in call statements. + +2009-04-04 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39636 + * tree-ssa-forwprop.c + (forward_propagate_addr_into_variable_array_index): Check for + GIMPLE_ASSIGN before accessing the rhs code. + +2009-04-03 Jason Merrill <jason@redhat.com> + + * stor-layout.c (set_sizetype): Set TYPE_CANONICAL. + +2009-04-03 Steve Ellcey <sje@cup.hp.com> + + * config/ia64/ia64.md (extendsfdf2, extendsfxf2, extenddfxf2, + truncdfsf2, truncxfsf2, truncxfdf2, floatdixf2, fix_truncsfdi2, + fix_truncdfdi2, fix_truncxfdi2, fix_truncxfdi2_alts, floatunsdisf2, + floatunsdidf2, floatunsdixf2, fixuns_truncsfdi2, fixuns_truncdfdi2, + fixuns_truncxfdi2, fixuns_truncxfdi2_alts, divsi3_internal, + smuldi3_highpart, umuldi3_highpart, ctzdi2, *getf_exp_xf, + divdi3_internal_lat, divdi3_internal_thr, mulditi3, *mulditi3_internal, + umulditi3, *umulditi3_internal, addsf3, mulsf3, abssf2, negsf2, + *nabssf2, sminsf3, smaxsf3, *maddsf4, *msubsf4, *nmulsf3, *nmaddsf4, + *nmaddsf4_alts, divsf3, *sqrt_approx, sqrtsf2, sqrtsf2_internal_thr, + adddf3, *adddf3_trunc, muldf3, *muldf3_trunc, absdf2, negdf2, *nabsdf2, + smindf3, smaxdf3, *madddf4, *madddf4_trunc, *msubdf4, *msubdf4_trunc, + *nmuldf3, *nmuldf3_trunc, *nmadddf4, *nmadddf4_alts, *nmadddf4_truncsf, + *nmadddf4_truncsf_alts, divdf3, sqrtdf2, sqrtdf2_internal_thr, divxf3, + sqrtxf2, sqrtxf2_internal_thr, *recip_approx): + Use fr_reg_or_fp01_operand instead of fr_register_operand + + * config/ia64/div.md (extend<mode>rf2, truncrf<mode>2, + recip_approx_rf, divsf3_internal_thr, divsf3_internal_lat, + divdf3_internal_thr, divdf3_internal_lat divxf3_internal): Ditto. + +2009-04-03 Vladimir Makarov <vmakarov@redhat.com> + + PR rtl-optimization/39607 + PR rtl-optimization/39631 + + Revert: + + 2009-03-30 Vladimir Makarov <vmakarov@redhat.com> + * reload.c (push_reload, find_dummy_reload): Use df_get_live_out + instead of DF_LR_OUT. + * ira-lives.c (process_bb_node_lives): Ditto. + * ira-color.c (ira_loop_edge_freq): Use df_get_live_{out,in} + instead of DF_LR_{OUT,IN}. + * ira-emit.c (generate_edge_moves, add_ranges_and_copies): Ditto. + * ira-build.c (create_bb_allocnos, create_loop_allocnos): Ditto. + +2009-04-03 Steven Bosscher <steven@gcc.gnu.org> + + * omp-low.c (pass_expand_omp): Don't claim to provide PROP_gimple_lomp. + (execute_lower_omp): Always run but take the short way out if -fopenmp + is not given. + (gate_lower_omp): Remove, forcing the pass manager to always run the + pass and always set PROP_gimple_lomp. + (pass_lower_omp): Remove gate function. + * matrix-reorg.c (pass_ipa_matrix_reorg): Don't claim to provide + PROP_trees. Instead, require it. + * ipa-cp.c (pass_ipa_cp): Likewise. + * ipa-inline.c (pass_early_inline): Don't claim to provide PROP_cfg. + (pass_ipa_early_inline, pass_inline_parameters, pass_ipa_inline): Idem. + * tree-profile.c (pass_tree_profile): Don't claim to provide PROP_cfg + and PROP_gimple_leh. + +2009-04-03 Richard Guenther <rguenther@suse.de> + + PR middle-end/13146 + PR tree-optimization/23940 + PR tree-optimization/33237 + PR middle-end/33974 + PR middle-end/34093 + PR tree-optimization/36201 + PR tree-optimization/36230 + PR tree-optimization/38049 + PR tree-optimization/38207 + PR tree-optimization/38230 + PR tree-optimization/38301 + PR tree-optimization/38585 + PR middle-end/38895 + PR tree-optimization/38985 + PR tree-optimization/39299 + * tree-ssa-structalias.h: Remove. + * tree-ssa-operands.h (NULL_USE_OPERAND_P): Make of type use_operand_p. + (NULL_DEF_OPERAND_P): Make of type def_operand_p. + (struct vuse_element_d): Remove. + (struct vuse_vec_d): Likewise. + (VUSE_VECT_NUM_ELEM, VUSE_VECT_ELEMENT_NC, VUSE_ELEMENT_PTR_NC, + VUSE_ELEMENT_VAR_NC, VUSE_VECT_ELEMENT, VUSE_ELEMENT_PTR, + SET_VUSE_VECT_ELEMENT, SET_VUSE_ELEMENT_VAR, SET_VUSE_ELEMENT_PTR, + VUSE_ELEMENT_VAR): Likewise. + (struct voptype_d): Likewise. + (NUM_VOP_FREE_BUCKETS): Likewise. + (struct ssa_operands): Remove vop_free_buckets and mpt_table fields. + (struct stmt_operands_d): Remove. + (VUSE_OP_PTR, VUSE_OP, SET_VUSE_OP, VUSE_NUM, VUSE_VECT, + VDEF_RESULT_PTR, VDEF_RESULT, VDEF_OP_PTR, VDEF_OP, SET_VDEF_OP, + VDEF_NUM, VDEF_VECT): Likewise. + (copy_virtual_operands): Remove. + (operand_build_cmp): Likewise. + (create_ssa_artificial_load_stmt): Likewise. + (enum ssa_op_iter_type): Remove ssa_op_iter_vdef. + (struct ssa_operand_iterator_d): Remove vuses, vdefs, mayusesm + vuse_index and mayuse_index members. Pack and move done and iter_type + members to the front. + (SSA_OP_VMAYUSE): Remove. + (SSA_OP_VIRTUAL_USES): Adjust. + (FOR_EACH_SSA_VDEF_OPERAND): Remove. + (unlink_stmt_vdef): Declare. + (add_to_addressable_set): Remove. + * tree-vrp.c (stmt_interesting_for_vrp): Adjust. + (vrp_visit_stmt): Likewise. + * doc/tree-ssa.texi (Alias analysis): Update. + * doc/invoke.texi (max-aliased-vops): Remove docs. + (avg-aliased-vops): Likewise. + * tree-into-ssa.c (syms_to_rename): Remove. + (need_to_update_vops_p): Likewise. + (need_to_initialize_update_ssa_p): Rename to ... + (update_ssa_initialized_fn): ... this. Track function we are + initialized for. + (symbol_marked_for_renaming): Simplify. + (add_new_name_mapping): Do not set need_to_update_vops_p. + (dump_currdefs): Use SYMS_TO_RENAME. + (rewrite_update_stmt): Always walk all uses/defs. + (dump_update_ssa): Adjust. + (init_update_ssa): Take function argument. Track what we are + initialized for. + (delete_update_ssa): Reset SYMS_TO_RENAME and update_ssa_initialized_fn. + (create_new_def_for): Initialize for cfun, assert we are initialized + for cfun. + (mark_sym_for_renaming): Simplify. + (mark_set_for_renaming): Do not initialize update-ssa. + (need_ssa_update_p): Simplify. Take function argument. + (name_mappings_registered_p): Assert we ask for the correct function. + (name_registered_for_update_p): Likewise. + (ssa_names_to_replace): Likewise. + (release_ssa_name_after_update_ssa): Likewise. + (update_ssa): Likewise. Use SYMS_TO_RENAME. + (dump_decl_set): Do not print a newline. + (debug_decl_set): Do it here. + (dump_update_ssa): And here. + * tree-ssa-loop-im.c (move_computations): Adjust. + (movement_possibility): Likewise. + (determine_max_movement): Likewise. + (gather_mem_refs_stmt): Likewise. + * tree-dump.c (dequeue_and_dump): Do not handle SYMBOL_MEMORY_TAG + or NAME_MEMORY_TAG. + * tree-complex.c (update_all_vops): Remove. + (expand_complex_move): Adjust. + * tree-ssa-loop-niter.c (chain_of_csts_start): Use NULL_TREE. + Simplify test for memory referencing statement. Exclude + non-invariant ADDR_EXPRs. + * tree-pretty-print.c (dump_generic_node): Do not handle memory tags. + * tree-loop-distribution.c (generate_memset_zero): Adjust. + (rdg_flag_uses): Likewise. + * tree-tailcall.c (suitable_for_tail_opt_p): Remove memory-tag + related code. + (tree_optimize_tail_calls_1): Also split the + edge from the entry block if we have degenerate PHI nodes in + the first basic block. + * tree.c (init_ttree): Remove memory-tag related code. + (tree_code_size): Likewise. + (tree_node_structure): Likewise. + (build7_stat): Re-write to be build6_stat. + * tree.h (MTAG_P, TREE_MEMORY_TAG_CHECK, TMR_TAG): Remove. + (SSA_VAR_P): Adjust. + (struct tree_memory_tag): Remove. + (struct tree_memory_partition_tag): Likewise. + (union tree_node): Adjust. + (build7): Re-write to be build6. + * tree-pass.h (pass_reset_cc_flags): Remove. + (TODO_update_address_taken): New flag. + (pass_simple_dse): Remove. + * ipa-cp.c (ipcp_update_callgraph): Update SSA form. + * params.h (MAX_ALIASED_VOPS): Remove. + (AVG_ALIASED_VOPS): Likewise. + * omp-low.c (expand_omp_taskreg): Update SSA form. + * tree-ssa-dse.c (dse_optimize_stmt): Properly query if the rhs + aliases the lhs in a copy stmt. + * tree-ssa-dse.c (struct address_walk_data): Remove. + (memory_ssa_name_same): Likewise. + (memory_address_same): Likewise. + (get_kill_of_stmt_lhs): Likewise. + (dse_possible_dead_store_p): Simplify, use the oracle. Handle + unused stores. Look through PHI nodes into post-dominated regions. + (dse_optimize_stmt): Simplify. Properly remove stores. + (tree_ssa_dse): Compute dominators. + (execute_simple_dse): Remove. + (pass_simple_dse): Likewise. + * ipa-reference.c (scan_stmt_for_static_refs): Open-code + gimple_loaded_syms and gimple_stored_syms computation. + * toplev.c (dump_memory_report): Dump alias and pta stats. + * tree-ssa-sccvn.c (vn_reference_compute_hash): Simplify. + (vn_reference_eq): Likewise. + (vuses_to_vec, copy_vuses_from_stmt, vdefs_to_vec, + copy_vdefs_from_stmt, shared_lookup_vops, shared_vuses_from_stmt, + valueize_vuses): Remove. + (get_def_ref_stmt_vuses): Simplify. Rename to ... + (get_def_ref_stmt_vuse): ... this. + (vn_reference_lookup_2): New function. + (vn_reference_lookup_pieces): Use walk_non_aliased_vuses for + walking equivalent vuses. Simplify. + (vn_reference_lookup): Likewise. + (vn_reference_insert): Likewise. + (vn_reference_insert_pieces): Likewise. + (visit_reference_op_call): Simplify. + (visit_reference_op_load): Likewise. + (visit_reference_op_store): Likewise. + (init_scc_vn): Remove shared_lookup_vuses initialization. + (free_scc_vn): Remove shared_lookup_vuses freeing. + (sort_vuses, sort_vuses_heap): Remove. + (get_ref_from_reference_ops): Export. + * tree-ssa-sccvn.h (struct vn_reference_s): Replace vuses + vector with single vuse pointer. + (vn_reference_lookup_pieces, vn_reference_lookup, + vn_reference_insert, vn_reference_insert_pieces): Adjust prototypes. + (shared_vuses_from_stmt): Remove. + (get_ref_from_reference_ops): Declare. + * tree-ssa-loop-manip.c (slpeel_can_duplicate_loop_p): Adjust. + * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Remove + memory-tag related code. + * tree-ssa-ccp.c (get_symbol_constant_value): Remove memory-tag code. + (likely_value): Add comment, skip static-chain of call statements. + (surely_varying_stmt_p): Adjust. + (gimplify_and_update_call_from_tree): Likewise. + (execute_fold_all_builtins): Do not rebuild alias info. + (gimplify_and_update_call_from_tree): Properly update VOPs. + * tree-ssa-loop-ivopts.c (get_ref_tag): Remove. + (copy_ref_info): Remove memory-tag related code. + * tree-call-cdce.c (tree_call_cdce): Rename the VOP. + * ipa-pure-const.c (check_decl): Remove memory-tag related code. + (check_stmt): Open-code gimple_loaded_syms and gimple_stored_syms + computation. + * tree-ssa-dom.c (gimple_p): Remove typedef. + (eliminate_redundant_computations): Adjust. + (record_equivalences_from_stmt): Likewise. + (avail_expr_hash): Likewise. + (avail_expr_eq): Likewise. + * tree-ssa-propagate.c (update_call_from_tree): Properly update VOPs. + (stmt_makes_single_load): Likewise. + (stmt_makes_single_store): Likewise. + * tree-ssa-alias.c: Rewrite completely. + (debug_memory_partitions, dump_mem_ref_stats, debug_mem_ref_stats, + debug_mem_sym_stats, dump_mem_sym_stats_for_var, + debug_all_mem_sym_stats, debug_mp_info, update_mem_sym_stats_from_stmt, + delete_mem_ref_stats, create_tag_raw, dump_points_to_info, + dump_may_aliases_for, debug_may_aliases_for, new_type_alias): + Remove public functions. + (pass_reset_cc_flags): Remove. + (pass_build_alias): Move ... + * tree-ssa-structalias.c (pass_build_alias): ... here. + * tree-ssa-alias.c (may_be_aliased): Move ... + * tree-flow-inline.h (may_be_aliased): ... here. + tree-ssa-alias.c (struct count_ptr_d, count_ptr_derefs, + count_uses_and_derefs): Move ... + * gimple.c: ... here. + * gimple.h (count_uses_and_derefs): Declare. + * tree-ssa-alias.c (dump_alias_stats, ptr_deref_may_alias_global_p, + ptr_deref_may_alias_decl_p, ptr_derefs_may_alias_p, + same_type_for_tbaa, nonaliasing_component_refs_p, decl_refs_may_alias_p, + indirect_ref_may_alias_decl_p, indirect_refs_may_alias_p, + ref_maybe_used_by_call_p, ref_maybe_used_by_stmt_p, + call_may_clobber_ref_p, stmt_may_clobber_ref_p, maybe_skip_until, + get_continuation_for_phi, walk_non_aliased_vuses, walk_aliased_vdefs): + New functions. + * tree-dfa.c (refs_may_alias_p): Move ... + * tree-ssa-alias.c (refs_may_alias_p): ... here. Extend. + * tree-ssa-alias.h: New file. + * tree-ssa-sink.c (is_hidden_global_store): Adjust. + (statement_sink_location): Likewise. + * opts.c (decode_options): Do not adjust max-aliased-vops or + avg-aliased-vops values. + * timevar.def (TV_TREE_MAY_ALIAS): Remove. + (TV_CALL_CLOBBER): Likewise. + (TV_FLOW_SENSITIVE): Likewise. + (TV_FLOW_INSENSITIVE): Likewise. + (TV_MEMORY_PARTITIONING): Likewise. + (TV_ALIAS_STMT_WALK): New timevar. + * tree-ssa-loop-ivcanon.c (empty_loop_p): Adjust. + * tree-ssa-address.c (create_mem_ref_raw): Use build6. + (get_address_description): Remove memory-tag related code. + * tree-ssa-ifcombine.c (bb_no_side_effects_p): Adjust. + * treestruct.def (TS_MEMORY_TAG, TS_MEMORY_PARTITION_TAG): Remove. + * tree-eh.c (cleanup_empty_eh): Do not leave stale SSA_NAMEs + and immediate uses in statements. Document. + * gimple-pretty-print.c (dump_gimple_mem_ops): Adjust. + (dump_symbols): Remove. + (dump_gimple_mem_ops): Do not dump loaded or stored syms. + * alias.c (get_deref_alias_set): New function split out from ... + (get_alias_set): ... here. + * alias.h (get_deref_alias_set): Declare. + * tree-vect-data-refs.c (vect_create_data_ref_ptr): Remove unused + type parameter. Remove restrict pointer handling. Create a + ref-all pointer in case type-based alias sets do not conflict. + (vect_analyze_data_refs): Remove SMT related code. + * tree-vect-stmts.c (vectorizable_store): Re-instantiate TBAA assert. + (vectorizable_load): Likewise. + * tree-data-ref.h (struct dr_alias): Remove symbol_tag field. + (DR_SYMBOL_TAG, DR_VOPS): Remove. + * tree-data-ref.c (dr_may_alias_p): Use the alias-oracle. + Ignore vops and SMTs. + (dr_analyze_alias): Likewise.. + (free_data_ref): Likewise. + (create_data_ref): Likewise. + (analyze_all_data_dependences): Likewise. + (get_references_in_stmt): Adjust. + * tree-flow-inline.h (gimple_aliases_computed_p, + gimple_addressable_vars, gimple_call_clobbered_vars, + gimple_call_used_vars, gimple_global_var, may_aliases, memory_partition, + factoring_name_p, mark_call_clobbered, clear_call_clobbered, + compare_ssa_operands_equal, symbol_mem_tag, set_symbol_mem_tag, + gimple_mem_ref_stats): Remove. + (gimple_vop): New function. + (op_iter_next_use): Remove vuses and mayuses cases. + (op_iter_next_def): Remove vdefs case. + (op_iter_next_tree): Remove vuses, mayuses and vdefs cases. + (clear_and_done_ssa_iter): Do not set removed fields. + (op_iter_init): Likewise. Skip vuse and/or vdef if requested. + Assert we are not iterating over vuses or vdefs if not also + iterating over uses or defs. + (op_iter_init_use): Likewise. + (op_iter_init_def): Likewise. + (op_iter_next_vdef): Remove. + (op_iter_next_mustdef): Likewise. + (op_iter_init_vdef): Likewise. + (compare_ssa_operands_equal): Likewise. + (link_use_stmts_after): Handle vuse operand. + (is_call_used): Use is_call_clobbered. + (is_call_clobbered): Global variables are always call clobbered, + query the call-clobbers bitmap. + (mark_call_clobbered): Ignore global variables. + (clear_call_clobbered): Likewise. + * tree-ssa-coalesce.c (create_outofssa_var_map): Adjust + virtual operands sanity check. + * tree.def (NAME_MEMORY_TAG, SYMBOL_MEMORY_TAG, MEMORY_PARTITION_TAG): + Remove. + (TARGET_MEM_REF): Remove TMR_TAG operand. + * tree-dfa.c (add_referenced_var): Initialize call-clobber state. + Remove call-clobber related code. + (remove_referenced_var): Likewise. Do not clear mpt or symbol_mem_tag. + (dump_variable): Do not dump SMTs, memory stats, may-aliases or + partitions or escape reason. + (get_single_def_stmt, get_single_def_stmt_from_phi, + get_single_def_stmt_with_phi): Remove. + (dump_referenced_vars): Tidy. + (get_ref_base_and_extent): Allow bare decls. + (collect_dfa_stats): Adjust. + * graphite.c (rename_variables_in_stmt): Adjust. + (graphite_copy_stmts_from_block): Likewise. + (translate_clast): Likewise. + * tree-ssa-pre.c (struct bb_bitmap_sets): Add expr_dies bitmap. + (EXPR_DIES): New. + (translate_vuse_through_block): Use the oracle. + (phi_translate_1): Adjust. + (value_dies_in_block_x): Use the oracle. Cache the outcome + in EXPR_DIES. + (valid_in_sets): Check if the VUSE for + a REFERENCE is available. + (eliminate): Do not remove stmts during elimination, + instead queue and remove them afterwards. + (do_pre): Do not rebuild alias info. + (pass_pre): Run TODO_rebuild_alias before PRE. + * tree-ssa-live.c (remove_unused_locals): Remove memory-tag code. + * tree-sra.c (sra_walk_function): Use gimple_references_memory_p. + (mark_all_v_defs_stmt): Remove. + (mark_all_v_defs_seq): Adjust. + (sra_replace): Likewise. + (scalarize_use): Likewise. + (scalarize_copy): Likewise. + (scalarize_init): Likewise. + (scalarize_ldst): Likewise. + (todoflags): Remove. + (tree_sra): Do not rebuild alias info. + (tree_sra_early): Adjust. + (pass_sra): Run TODO_update_address_taken before SRA. + * tree-predcom.c (set_alias_info): Remove. + (prepare_initializers_chain): Do not call it. + (mark_virtual_ops_for_renaming): Adjust. + (mark_virtual_ops_for_renaming_list): Remove. + (initialize_root_vars): Adjust. + (initialize_root_vars_lm): Likewise. + (prepare_initializers_chain): Likewise. + * tree-ssa-copy.c (may_propagate_copy): Remove memory-tag related code. + (may_propagate_copy_into_stmt): Likewise. + (merge_alias_info): Do nothing for now. + (propagate_tree_value_into_stmt): Adjust. + (stmt_may_generate_copy): Likewise. + * tree-ssa-forwprop.c (tidy_after_forward_propagate_addr): Do + not mark symbols for renaming. + (forward_propagate_addr_expr): Match up push/pop_stmt_changes + with the same statement, make sure to update the new pointed-to one. + * tree-ssa-dce.c (eliminate_unnecessary_stmts): Do not copy + call statements, do not mark symbols for renaming. + (mark_operand_necessary): Dump something. + (ref_may_be_aliased): New function. + (mark_aliased_reaching_defs_necessary_1): New helper function. + (mark_aliased_reaching_defs_necessary): Likewise. + (mark_all_reaching_defs_necessary_1): Likewise. + (mark_all_reaching_defs_necessary): Likewise. + (propagate_necessity): Do not process virtual PHIs. For + non-aliased loads mark all reaching definitions as necessary. + For aliased loads and stores mark the immediate dominating + aliased clobbers as necessary. + (visited): New global static. + (perform_tree_ssa_dce): Free visited bitmap after propagating + necessity. + (remove_dead_phis): Perform simple dead virtual PHI removal. + (remove_dead_stmt): Properly unlink virtual operands when + removing stores. + (eliminate_unnecessary_stmts): Schedule PHI removal after + stmt removal. + * tree-ssa-ter.c (is_replaceable_p): Adjust. + (process_replaceable): Likewise. + (find_replaceable_in_bb): Likewise. + * tree-ssa.c (verify_ssa_name): Verify all VOPs are + based on the single gimple vop. + (verify_flow_insensitive_alias_info): Remove. + (verify_flow_sensitive_alias_info): Likewise. + (verify_call_clobbering): Likewise. + (verify_memory_partitions): Likewise. + (verify_alias_info): Likewise. + (verify_ssa): Adjust.. + (execute_update_addresses_taken): Export. Update SSA + manually. Optimize only when optimizing. Use a local bitmap. + (pass_update_address_taken): Remove TODO_update_ssa, add + TODO_dump_func. + (pass_update_address_taken): Just use TODO_update_address_taken. + (init_tree_ssa): Do not initialize addressable_vars. + (verify_ssa): Verify new VUSE / VDEF properties. + Verify that all stmts definitions have the stmt as SSA_NAME_DEF_STMT. + Do not call verify_alias_info. + (delete_tree_ssa): Clear the VUSE, VDEF operands. + Do not free the loaded and stored syms bitmaps. Reset the escaped + and callused solutions. Do not free addressable_vars. + Remove memory-tag related code. + (warn_uninitialized_var): Aliases are always available. + * tree-ssa-loop-prefetch.c (gather_memory_references): Adjust. + * lambda-code.c (can_put_in_inner_loop): Adjust. + (can_put_after_inner_loop): Likewise. + (perfect_nestify): Likewise. + * tree-vect-stmts.c (vect_stmt_relevant_p): Adjust. + (vect_gen_widened_results_half): Remove CALL_EXPR handling. + (vectorizable_conversion): Do not mark symbols for renaming. + * tree-inline.c (remap_gimple_stmt): Clear VUSE/VDEF. + (expand_call_inline): Unlink the calls virtual operands before + replacing it. + (tree_function_versioning): Do not call update_ssa if we are not + updating clones. Simplify. + * tree-ssa-phiprop.c (phivn_valid_p): Adjust. + (propagate_with_phi): Likewise.. + * tree-outof-ssa.c (create_temp): Remove memory tag and call + clobber code. Assert we are not aliased or global. + * tree-flow.h: Include tree-ssa-alias.h + (enum escape_type): Remove. + (struct mem_sym_stats_d): Likewise. + (struct mem_ref_stats_d): Likewise. + (struct gimple_df): Add vop member. Remove global_var, + call_clobbered_vars, call_used_vars, addressable_vars, + aliases_compted_p and mem_ref_stats members. Add syms_to_rename, + escaped and callused members. + (struct ptr_info_def): Remove all members, add points-to solution + member pt. + (struct var_ann_d): Remove in_vuse_list, in_vdef_list, + call_clobbered, escape_mask, mpt and symbol_mem_tag members. + * Makefile.in (TREE_FLOW_H): Add tree-ssa-alias.h. + (tree-ssa-structalias.o): Remove tree-ssa-structalias.h. + (tree-ssa-alias.o): Likewise. + (toplev.o): Add tree-ssa-alias.h + (GTFILES): Remove tree-ssa-structalias.h, add tree-ssa-alias.h. + * gimple.c (gimple_set_bb): Fix off-by-one error. + (is_gimple_reg): Do not handle memory tags. + (gimple_copy): Also copy virtual operands. + Delay updating the statement. Do not reset loaded and stored syms. + (gimple_set_stored_syms): Remove. + (gimple_set_loaded_syms): Likewise. + (gimple_call_copy_skip_args): Copy the virtual operands + and mark the new statement modified. + * tree-ssa-structalias.c (may_alias_p): Remove. + (set_uids_in_ptset): Take the alias set to prune with as + parameter. Fold in the alias test of may_alias_p. + (compute_points_to_sets): Compute whether a ptr is dereferenced + in a local sbitmap. + (process_constraint): Deal with &ANYTHING on the lhs, reject all + other ADDRESSOF constraints on the lhs. + (get_constraint_for_component_ref): Assert that we don't get + ADDRESSOF constraints from the base of the reference. + Properly generate UNKNOWN_OFFSET for DEREF if needed. + (struct variable_info): Remove collapsed_to member. + (get_varinfo_fc): Remove. + (new_var_info): Do not set collapsed_to. + (dump_constraint): Do not follow cycles. + (dump_constraint_graph): Likewise. + (build_pred_graph): Likewise. + (build_succ_graph): Likewise. + (rewrite_constraints): Likewise. + (do_simple_structure_copy): Remove. + (do_rhs_deref_structure_copy): Remove. + (do_lhs_deref_structure_copy): Remove. + (collapse_rest_of_var): Remove. + (do_structure_copy): Re-implement. + (pta_stats): New global variable. + (dump_pta_stats): New function. + (struct constraint_expr): Make offset signed. + (UNKNOWN_OFFSET): Define special value. + (dump_constraint): Dump UNKNOWN_OFFSET as UNKNOWN. + (solution_set_expand): New helper function split out from ... + (do_sd_constraint): ... here. + (solution_set_add): Handle UNKNOWN_OFFSET. Handle negative offsets. + (do_ds_constraint): Likewise. + (do_sd_constraint): Likewise. Do not special-case ESCAPED = *ESCAPED + and CALLUSED = *CALLUSED. + (set_union_with_increment): Make inc argument signed. + (type_safe): Remove. + (get_constraint_for_ptr_offset): Handle unknown and negative + constant offsets. + (first_vi_for_offset): Handle offsets before start. Bail + out early for offsets beyond the variable extent. + (first_or_preceding_vi_for_offset): New function. + (init_base_vars): Add ESCAPED = ESCAPED + UNKNOWN_OFFSET constraint. + Together with ESCAPED = *ESCAPED this properly computes reachability. + (find_what_var_points_to): New function. + (find_what_p_points_to): Implement in terms of find_what_var_points_to. + (pt_solution_reset, pt_solution_empty_p, pt_solution_includes_global, + pt_solution_includes_1, pt_solution_includes, pt_solutions_intersect_1, + pt_solutions_intersect): New functions. + (compute_call_used_vars): Remove. + (compute_may_aliases): New main entry into PTA computation. + * gimple.h (gimple_p): New typedef. + (struct gimple_statement_base): Remove references_memory_p. + (struct gimple_statement_with_memory_ops_base): Remove + vdef_ops, vuse_ops, stores and loads members. Add vdef and vuse + members. + (gimple_vuse_ops, gimple_set_vuse_ops, gimple_vdef_ops, + gimple_set_vdef_ops, gimple_loaded_syms, gimple_stored_syms, + gimple_set_references_memory): Remove. + (gimple_vuse_op, gimple_vdef_op, gimple_vuse, gimple_vdef, + gimple_vuse_ptr, gimple_vdef_ptri, gimple_set_vuse, gimple_set_vdef): + New functions. + * tree-cfg.c (move_block_to_fn): Fix off-by-one error. + (verify_expr): Allow RESULT_DECL. + (gimple_duplicate_bb): Do not copy virtual operands. + (gimple_duplicate_sese_region): Adjust. + (gimple_duplicate_sese_tail): Likewise. + (mark_virtual_ops_in_region): Remove. + (move_sese_region_to_fn): Do not call it. + * passes.c (init_optimization_passes): Remove pass_reset_cc_flags + and pass_simple_dse. + (execute_function_todo): Handle TODO_update_address_taken, + call execute_update_addresses_taken for TODO_rebuild_alias. + (execute_todo): Adjust. + (execute_one_pass): Init dump files early. + * ipa-struct-reorg.c (finalize_var_creation): Do not mark vars + call-clobbered. + (create_general_new_stmt): Clear vops. + * tree-ssa-reassoc.c (get_rank): Adjust. + * tree-vect-slp.c (vect_create_mask_and_perm): Do not mark + symbols for renaming. + * params.def (PARAM_MAX_ALIASED_VOPS): Remove. + (PARAM_AVG_ALIASED_VOPS): Likewise. + * tree-ssanames.c (init_ssanames): Allocate SYMS_TO_RENAME. + (duplicate_ssa_name_ptr_info): No need to copy the shared bitmaps. + * tree-ssa-operands.c: Simplify for new virtual operand representation. + (operand_build_cmp, copy_virtual_operands, + create_ssa_artificial_load_stmt, add_to_addressable_set, + gimple_add_to_addresses_taken): Remove public functions. + (unlink_stmt_vdef): New function. + +2009-04-03 Alan Modra <amodra@bigpond.net.au> + + * config.gcc (powerpc-*-linux*): Merge variants. + +2009-04-02 Chao-ying Fu <fu@mips.com> + James Grosbach <james.grosbach@microchip.com> + + * config/mips/mips.c (mips_frame_info): Add acc_mask, num_acc, + num_cop0_regs, acc_save_offset, cop0_save_offset, acc_sp_offset, + cop0_sp_offset. + (machine_function): Add interrupt_handler_p, use_shadow_register_set_p, + keep_interrupts_masked_p, use_debug_exception_return_p. + (mips_attribute_table): Add interrupt, use_shadow_register_set, + keep_interrupts_masked, use_debug_exception_return. + (mips_interrupt_type_p, mips_use_shadow_register_set_p, + mips_keep_interrupts_masked_p, mips_use_debug_exception_return_p): + New functions. + (mips_function_ok_for_sibcall): Return false for interrupt handlers. + (mips_print_operand): Process COP0 registers to print $0 .. $31 + correctly for GAS to process. + (mips_interrupt_extra_call_saved_reg_p): New function. + (mips_cfun_call_saved_reg_p): For interrupt handlers, we need to check + extra registers. + (mips_cfun_might_clobber_call_saved_reg_p): Likewise. + (mips_compute_frame_info): Add supports for interrupt context that + includes doubleword accumulators and COP0 registers. + (mips_for_each_saved_acc): New function. + (mips_for_each_saved_gpr_and_fpr): Change the function name from + mips_for_each_saved_reg. + (mips_save_reg): Save accumulators. + (mips_kernel_reg_p): A new for_each_rtx callback. + (mips_expand_prologue): Support interrupt handlers. + (mips_restore_reg): Restore accumulators. + (mips_expand_epilogue): Support interrupt handlers. + (mips_can_use_return_insn): Return false for interrupt handlers. + (mips_epilogue_uses): New function. + * config/mips/mips.md (UNSPEC_ERET, UNSPEC_DERET, UNSPEC_DI, + UNSPEC_EHB, UNSPEC_RDPGPR, UNSPEC_COP0): New UNSPEC. + (mips_eret, mips_deret, mips_di, mips_ehb, mips_rdpgpr, + cop0_move): New instructions. + * config/mips/mips-protos.h (mips_epilogue_uses): Declare. + * config/mips/mips.h (K0_REG_NUM, K1_REG_NUM, KERNEL_REG_P): New + defines. + (COP0_STATUS_REG_NUM, COP0_CAUSE_REG_NUM, COP0_EPC_REG_NUM): + New defines. + (CAUSE_IPL, SR_IPL, SR_EXL, SR_IE): New defines. + (MIPS_PROLOGUE_TEMP_REGNUM, MIPS_EPILOGUE_TEMP_REGNUM): For + interrupt handlers, we use K0 as the temporary register. + (EPILOGUE_USES): Change to a function call. + * config/mips/sde.h (MIPS_EPILOGUE_TEMP_REGNUM): For interrupt + handlers, we use K0 as the temporary register. + + * doc/extend.texi (Function Attributes): Document interrupt, + use_shadow_register_set, keep_interrupts_masked, + use_debug_exception_return for MIPS attributes. + +2009-04-03 Alan Modra <amodra@bigpond.net.au> + + * config.gcc (powerpc64-*-gnu*): Add rs6000/default64.h to tm_file. + Remove a number of t-files from tmake_file. + * config/rs6000/sysv4.opt (mprototype): Name variable target_prototype. + * config/rs6000/sysv4.h (TARGET_PROTOTYPE): Define. + * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Set + target_prototype, not TARGET_PROTOTYPE. + (LINK_OS_GNU_SPEC): Define. + * config/rs6000/t-linux64 (LIB2FUNCS_EXTRA): Delete tramp.S + and darwin-ldoubdle.c. + +2009-04-02 Michael Meissner <meissner@linux.vnet.ibm.com> + + PR driver/39293 + * gcc.c (save_temps_flag): Add support for -save-temps=obj. + (cpp_options): Ditto. + (default_compilers): Ditto. + (display_help): Ditto. + (process_command): Ditto. + (do_spec_1): Ditto. + (set_input): Use lbasename instead of duplicate code. + (save_temps_prefix): New static for -save-temps=obj. + (save_temps_length): Ditto. + + * doc/invoke.texi (-save-temps=obj): Document new variant to + -save-temps switch. + +2009-04-02 Jeff Law <law@redhat.com> + + * reload1.c (fixup_eh_region_notes): Remove write-only "trap_count" + variable. + +2009-04-02 H.J. Lu <hongjiu.lu@intel.com> + + * configure.ac: Support -Bstatic/-Bdynamic for linker version > 2. + * configure: Regenerated. + +2009-04-02 Rafael Avila de Espindola <espindola@google.com> + + * c-decl.c (merge_decls): Make sure newdecl and olddecl don't + share the argument list. + +2009-04-02 Rafael Avila de Espindola <espindola@google.com> + + Merge + + 2009-02-12 Diego Novillo <dnovillo@google.com> + + * varpool.c (debug_varpool): New. + * cgraph.h (debug_varpool): Declare. + +2009-04-02 Jan Hubicka <jh@suse.cz> + + * passes.c (init_optimization_passes): Remove two copies of ehcleanup + pass. + +2009-04-02 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (ix86_abi): Move initialization to ... + (override_options): Here. + +2009-04-02 Christian Bruel <christian.bruel@st.com> + + * config/sh/sh.c (sh_dwarf_register_span): New function. + (TARGET_DWARF_REGISTER_SPAN): Define. + * config/sh/sh-protos.h (sh_dwarf_register_span): Declare. + +2009-04-02 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/39595 + * tree-vect-slp.c (vect_build_slp_tree): Check that the size of + interleaved loads group is not greater than the SLP group size. + +2009-04-02 Rafael Avila de Espindola <espindola@google.com> + + * builtins.c (is_builtin_name): New. + (called_as_built_in): Use is_builtin_name. + * tree.h (is_builtin_name): New. + * varasm.c (incorporeal_function_p): Use is_builtin_name + +2009-04-02 Andrew Stubbs <ams@codesourcery.com> + + * config/sh/linux-unwind.h: Disable when inhibit_libc is defined. + +2009-04-02 Dodji Seketeli <dodji@redhat.com> + + PR c++/26693 + * c-decl.c (clone_underlying_type): Move this ... + * c-common.c (set_underlying_type): ... here. + Also, make sure the function properly sets TYPE_STUB_DECL() on + the newly created typedef variant type. + * c-common.h (is_typedef_decl, set_underlying_type): Declare ... + * c-common.c (is_typedef_decl, set_underlying_type): ... new entry + points. + +2009-04-02 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/37221 + * tree-flow.h (degenerate_phi_result): Declare. + * tree-ssa-dom.c (degenerate_phi_result): Export. + * tree-scalar-evolution.c (analyze_initial_condition): If + the initial condition is defined by a degenerate PHI node + use the degenerate value. + +2009-04-01 Eric Botcazou <ebotcazou@adacore.com> + + PR rtl-optimization/39588 + * combine.c (merge_outer_ops): Do not set the constant when this + is not necessary. + (simplify_shift_const_1): Do not modify it either in this case. + +2009-04-01 Steven Bosscher <steven@gcc.gnu.org> + + * config/ia64/ia64.c (ia64_handle_option): Inform user that Itanium1 + tuning is deprecated if -mtune value is set to an Itanium1 variant. + +2009-04-01 Janis Johnson <janis187@us.ibm.com> + + PR c/29027 + * c-lex.c (interpret_float): Default (no suffix) is double. + +2009-04-1 Xinliang David Li <davidxl@google.com> + + * config/i386/i386.c (legitimate_constant_p): Recognize + all one vector constant. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/vax.c: Add #includes to silence warnings. + Change #include order to silence two warnings. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/linux.h (TARGET_DEFAULT): Add the MASK_QMATH flag bit. + (ASM_SPEC): Pass -k to the assembler for PIC code. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config.gcc: Add vax-*-linux* to the switch. + * config/vax/linux.h: New file. (TARGET_VERSION, + TARGET_OS_CPP_BUILTINS, TARGET_DEFAULT, CPP_SPEC, LINK_SPEC): Define. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/vax.c (vax_output_int_move, adjacent_operands_p): + Use predicate macros instead of GET_CODE() == foo. + * config/vax/vax.md (movsi_2, movstrictqi, and<mode>3, ashrsi3, + ashlsi3, rotrsi3, <unnamed>): Likewise. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/builtins.md (jbbssiqi, jbbssihi, jbbssisi, jbbcciqi, + jbbccihi, jbbccisi): Remova trailing whitespace. + * config/vax/constraints.md: Likewise. + * config/vax/elf.h (ASM_PREFERRED_EH_DATA_FORMAT): Likewise. + * config/vax/openbsd1.h (OBSD_OLD_GAS): Likewise. + * config/vax/predicates.md: Likewise. + * config/vax/vax.c (print_operand_address, vax_output_int_move, + vax_expand_addsub_di_operands, adjacent_operands_p): Likewise. + * config/vax/vax.h: Likewise. + * config/vax/vax.md (nonlocal_goto): Likewise. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/vax.c (vax_float_literal, vax_output_int_move) + (indirectable_address_p, adjacent_operands_p): Add spaces around + braces. + * config/vax/vax-protos.h (adjacent_operands_p): Likewise. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/vax.c (legitimate_constant_address_p, + legitimate_constant_p, indirectable_address_p, nonindexed_address_p, + index_term_p, reg_plus_index_p, legitimate_address_p, + vax_mode_dependent_address_p): Update comments to match functions + modified by the recent int->bool conversion. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/builtins.md: Update copyright message. + * config/vax/constraints.md: Likewise. + * config/vax/netbsd-elf.h: Likewise. + * config/vax/predicates.md: Likewise. + * config/vax/vax-protos.h: Likewise. + * config/vax/vax.c: Likewise. + * config/vax/vax.h: Likewise. + * config/vax/vax.md: Likewise. + * config/vax/vax.opt: Likewise. + +2009-04-01 Jan-Benedict Glaw <jbglaw@jbglaw-dev.homezone.telefonica.de> + + * config/vax/builtins.md (ffssi2, ffssi2_internal, + sync_lock_test_and_set<mode>, sync_lock_release<mode>): Fix indention. + * config/vax/constraints.md (B, R): Likewise. + * config/vax/predicates.md (external_memory_operand, + nonimmediate_addsub_di_operand): Likewise. + * config/vax/vax.c (vax_output_int_add): Likewise. + * config/vax/vax.md (movsi, movsi_2, mov<mode>, call_value, + untyped_call): Likewise. + +2009-04-01 Matt Thomas <matt@3am-software.com> + + * config/vax/predicates.md: New file. + (symbolic_operand, local_symbolic_operand, external_symbolic_operand, + external_const_operand, nonsymbolic_operand, external_memory_operand, + indirect_memory_operand, indexed_memory_operand, + illegal_blk_memory_operand, illegal_addsub_di_memory_operand, + nonimmediate_addsub_di_operand, general_addsub_di_operand): New + predicate. + * config/vax/constraints.md: New file. + (Z0, U06, U08, U16, CN6, S08, S16, I, J, K, L, M, N, O, G, Q, B, R, T): + New constraint. + * config/vax/builtins.md: New file. + (ffssi2, ffssi2_internal, sync_lock_test_and_set<mode>, jbbssiqi, + jbbssihi, jbbssisi, sync_lock_release<mode>, jbbcciqi, jbbccihi, + jbbccisi): Define. + * config/vax/vax.opt (mqmath): Add option. + * config/vax/vax.md (isfx): Extend with DI. + (VAXintQH, VAXintQHSD): Define. + (tst<mode>, cmp<mode>, *bit<mode>, movmemhi1, truncsiqi2, truncsihi2, + mulsidi3, add<mode>3, sub<mode>, mul<mode>3, div<mode>3, and<mode>, + and<mode>_const_int, ior<mode>3, xor<mode>3, neg<mode>2, + one_cmpl<mode>2, ashlsi3, lshrsi3, rotlsi3): Update constraints. + (movdi): Update constraints and use vax_output_int_move(). + (movsi, movsi_2, pushlclsymreg, pushextsymreg, movlclsymreg, + movextsymreg, adddi3, adcdi3, subdi3, sbcdi3, pushextsym, movextsym, + pushlclsym, movlclsym, movaddr<mode>, pushaddr<mode>, + nonlocal_goto): New. + (mov<mode>): Extend accepted operand types. + (subdi3_old): Rename from subdi3, change update constraints and use + a new implementation. + * config/vax/vax.h (PCC_BITFIELD_TYPE_MATTERS): Add space. + (FRAME_POINTER_CFA_OFFSET, IRA_COVER_CLASSES, CLASS_MAX_NREGS, + MOVE_RATIO, CLEAR_RATIO): Define. + (REG_CLASS_FROM_LETTER, CONST_OK_FOR_LETTER_P, + CONST_DOUBLE_OK_FOR_LETTER_P, EXTRA_CONSTRAINT): Delete. + (PRINT_OPERAND): Redefine using a function instead of inlined code. + * config/vax/vax.c (TARGET_BUILTIN_SETJMP_FRAME_VALUE): Define. + (split_quadword_operands): Make static and really allow variable + splitting. + (print_operand_address): Update for PIC generation. + (print_operand, vax_builtin_setjmp_frame_value, vax_output_int_subtract, + indexable_address_p, fixup_mathdi_operand, + vax_expand_addsub_di_operands, adjacent_operands_p): New. + (vax_float_literal, legitimate_constant_p, + indirectable_constant_address_p, index_term_p, + reg_plus_index_p): Return bool instead of int. + (vax_rtx_costs): Fix cost for CONST_INT, indent and use HOST_WIDE_INT + where needed. + (vax_output_int_move, vax_output_int_add): Extend to allow PIC + generation. + (vax_output_conditional_branch): Indent. + (legitimate_constant_address_p, indirectable_constant_address_p, + indirectable_address_p, nonindexed_address_p, legitimate_address_p, + vax_mode_dependent_address_p): Return bool instead of int, update for + PIC generation. + * config/vax/vax-protos.h (legitimate_constant_address_p, + legitimate_constant_p, legitimate_address_p, + vax_mode_dependent_address_p): Change declaration to bool. + (legitimate_pic_operand_p, adjacent_operands_p, print_operand, + vax_expand_addsub_di_operands, vax_output_int_subtract, + vax_output_movmemsi): Declare. + (split_quadword_operands, vax_float_literal): Delete declaration. + * config/vax/netbsd-elf.h (CC1_SPEC, CC1PLUS_SPEC) Define. + * config/vax/elf.h (NO_EXTERNAL_INDIRECT_ADDRESS, + VAX_CC1_AND_CC1PLUS_SPEC, ASM_PREFERRED_EH_DATA_FORMAT, + ASM_OUTPUT_DWARF_PCREL): Define. + (ASM_SPEC): Change definition to allow PIC generation. + +2009-04-01 Steve Ellcey <sje@cup.hp.com> + + * doc/sourcebuild.texi: Update front-end requirements. + +2009-04-01 Jakub Jelinek <jakub@redhat.com> + + PR target/39226 + * config/rs6000/rs6000.md (andsi3_internal5_nomc, + anddi3_internal2_nomc, anddi3_internal3_nomc): Removed. + (booldi3_internal3): Use boolean_or_operator instead of + boolean_operator. + +2009-04-01 Joseph Myers <joseph@codesourcery.com> + + PR c/39605 + * c-decl.c (grokdeclarator): Pedwarn for file-scope array + declarator whose size is not an integer constant expression but + folds to an integer constant, then treat it as a constant + subsequently. + +2009-04-01 Richard Guenther <rguenther@suse.de> + + * fold-const.c (fold_plusminus_mult_expr): Do not fold + i * 4 + 2 to (i * 2 + 1) * 2. + +2009-04-01 Jakub Jelinek <jakub@redhat.com> + + PR c/37772 + * c-parser.c (c_parser_asm_statement): Skip until close paren and + return if c_parser_asm_string_literal returned NULL. + +2009-04-01 Nick Clifton <nickc@redhat.com> + + * config/m32c/m32c.h (LIBGCC2_UNITS_PER_WORD): Define if not + already defined. + * config/m32c/t-m32c (LIB2FUNCS_EXTRA): Add m32c-lib2-trapv.c. + * config/m32c/m32c-lib2.c: Remove unused typedefs. Rename the + other typedefs to avoid conflicts with libgcc2.c. Define labels + to gain 16-bit bit-manipulation functions from libgcc2.c and then + include it. + * config/m32c/m32c-lib2-trapv.c: New file. Define labels + to gain 16-bit trapping arithmetic functions from libgcc2.c and + then include it. + +2009-04-01 Rafael Avila de Espindola <espindola@google.com> + + * varasm.c (default_function_rodata_section): Declare DOT as + const char*. + +2009-04-01 Kai Tietz <kai.tietz@onevision.com> + Andrey Galkin <agalkin@hypercom.com> + + PR/39492 + * config/i386/host-mingw32.c (mingw32_gt_pch_use_address): + Make object_name unique for each process. + +2009-04-01 Jakub Jelinek <jakub@redhat.com> + + PR other/39591 + * omp-low.c (remove_exit_barrier): Don't optimize if there are any + addressable variables in the parallel that could go out of scope while + running queued tasks. + +2009-04-01 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.h (avr_case_values_threshold): Remove declaration. + (CASE_VALUES_THRESHOLD): Redefine. + * config/avr/avr.c (avr_override_options): Remove initialization of + avr_case_values_threshold variable. + (avr_case_values_threshold): Remove variable. Add new function. + * config/avr/avr-protos.h (avr_case_values_threshold): Declare. + * config/avr/avr.opt (mno-tablejump): Remove option. + * doc/invoke.texi (AVR Options): Remove -mno-tablejump. + +2009-04-01 DJ Delorie <dj@redhat.com> + + * varasm.c (default_function_rodata_section): Don't assume + anything about where the first '.' in the section name is. + +2009-04-01 Alan Modra <amodra@bigpond.net.au> + + * config/rs6000/rs6000.c (rs6000_emit_stack_reset): Delete redundant + rs6000_emit_stack_tie. + +2009-03-31 Ian Lance Taylor <iant@google.com> + + * tree-eh.c (tree_remove_unreachable_handlers): Compare + gimple_code with GIMPLE_RESX, not RESX. + +2009-03-31 Joseph Myers <joseph@codesourcery.com> + + * c-common.c (c_get_ident): New. + (c_common_nodes_and_builtins): Call it for type names that may be NULL. + +2009-04-01 Ben Elliston <bje@au.ibm.com> + + * config/rs6000/sysv4.opt (msdata): Improve option description. + +2009-03-31 Steve Ellcey <sje@cup.hp.com> + + * config/ia64/ia64.md (divsf3_internal_lat): Remove. + (divdf3_internal_lat): Remove. + (divxf3_internal_lat): Remove. + (divxf3_internal_thr): Remove. + (divxf): Use divxf3_internal. + * config/ia64/div.md (divsf3_internal_lat): New. + (divdf3_internal_lat): New. + (divxf3_internal): New. + +2009-03-31 Joseph Myers <joseph@codesourcery.com> + + PR c/448 + * Makefile.in (USE_GCC_STDINT): Define. + (stmp-int-hdrs): Install stdint.h if applicable. + * c-common.c (CHAR16_TYPE): Define in terms of UINT_LEAST16_TYPE + if known. + (CHAR32_TYPE): Define in terms of UINT_LEAST32_TYPE if known. + (SIG_ATOMIC_TYPE, INT8_TYPE, INT16_TYPE, INT32_TYPE, INT64_TYPE, + UINT8_TYPE, UINT16_TYPE, UINT32_TYPE, UINT64_TYPE, + INT_LEAST8_TYPE, INT_LEAST16_TYPE, INT_LEAST32_TYPE, + INT_LEAST64_TYPE, UINT_LEAST8_TYPE, UINT_LEAST16_TYPE, + UINT_LEAST32_TYPE, UINT_LEAST64_TYPE, INT_FAST8_TYPE, + INT_FAST16_TYPE, INT_FAST32_TYPE, INT_FAST64_TYPE, + UINT_FAST8_TYPE, UINT_FAST16_TYPE, UINT_FAST32_TYPE, + UINT_FAST64_TYPE, INTPTR_TYPE, UINTPTR_TYPE): Define. + (c_common_nodes_and_builtins): Initialize + underlying_wchar_type_node. Do not initialize + signed_wchar_type_node or unsigned_wchar_type_node. Initialize + nodes for new types. + (c_stddef_cpp_builtins): Define macros for new types. + * c-common.h (CTI_SIGNED_WCHAR_TYPE, CTI_UNSIGNED_WCHAR_TYPE): + Remove. + (CTI_UNDERLYING_WCHAR_TYPE, CTI_SIG_ATOMIC_TYPE, CTI_INT8_TYPE, + CTI_INT16_TYPE, CTI_INT32_TYPE, CTI_INT64_TYPE, CTI_UINT8_TYPE, + CTI_UINT16_TYPE, CTI_UINT32_TYPE, CTI_UINT64_TYPE, + CTI_INT_LEAST8_TYPE, CTI_INT_LEAST16_TYPE, CTI_INT_LEAST32_TYPE, + CTI_INT_LEAST64_TYPE, CTI_UINT_LEAST8_TYPE, CTI_UINT_LEAST16_TYPE, + CTI_UINT_LEAST32_TYPE, CTI_UINT_LEAST64_TYPE, CTI_INT_FAST8_TYPE, + CTI_INT_FAST16_TYPE, CTI_INT_FAST32_TYPE, CTI_INT_FAST64_TYPE, + CTI_UINT_FAST8_TYPE, CTI_UINT_FAST16_TYPE, CTI_UINT_FAST32_TYPE, + CTI_UINT_FAST64_TYPE, CTI_INTPTR_TYPE, CTI_UINTPTR_TYPE): Define. + (signed_wchar_type_node, unsigned_wchar_type_node): Remove. + (underlying_wchar_type_node, sig_atomic_type_node, int8_type_node, + int16_type_node, int32_type_node, int64_type_node, + uint8_type_node, uint16_type_node, c_uint32_type_node, + c_uint64_type_node, int_least8_type_node, int_least16_type_node, + int_least32_type_node, int_least64_type_node, + uint_least8_type_node, uint_least16_type_node, + uint_least32_type_node, uint_least64_type_node, + int_fast8_type_node, int_fast16_type_node, int_fast32_type_node, + int_fast64_type_node, uint_fast8_type_node, uint_fast16_type_node, + uint_fast32_type_node, uint_fast64_type_node, intptr_type_node, + uintptr_type_node): Define. + * c-cppbuiltin.c (builtin_define_constants, + builtin_define_type_minmax): New. + (builtin_define_stdint_macros): Define more macros. + (c_cpp_builtins): Define more limit macros. + (type_suffix): New. + (builtin_define_type_max): Define in terms of + builtin_define_type_minmax. Remove is_long parameter. All + callers changed. + * config.gcc (use_gcc_stdint): Define. + (tm_file): Add glibc-stdint.h for targets using glibc or uClibc. + Add newlib-stdint.h for generic targets. + * config/glibc-stdint.h, config/newlib-stdint.h, + ginclude/stdint-gcc.h, ginclude/stdint-wrap.h: New. + * config/m32c/m32c.h (UINTPTR_TYPE): Define. + * config/score/score.h (UINTPTR_TYPE): Define. + * config/sol2.h (SIG_ATOMIC_TYPE, INT8_TYPE, INT16_TYPE, + INT32_TYPE, INT64_TYPE, UINT8_TYPE, UINT16_TYPE, UINT32_TYPE, + UINT64_TYPE, INT_LEAST8_TYPE, INT_LEAST16_TYPE, INT_LEAST32_TYPE, + INT_LEAST64_TYPE, UINT_LEAST8_TYPE, UINT_LEAST16_TYPE, + UINT_LEAST32_TYPE, UINT_LEAST64_TYPE, INT_FAST8_TYPE, + INT_FAST16_TYPE, INT_FAST32_TYPE, INT_FAST64_TYPE, + UINT_FAST8_TYPE, UINT_FAST16_TYPE, UINT_FAST32_TYPE, + UINT_FAST64_TYPE, INTPTR_TYPE, UINTPTR_TYPE): Define. + * config/spu/spu.h (STDINT_LONG32): Define. + * configure.ac (use_gcc_stdint): Substitute. + * configure: Regenerate. + * doc/cpp.texi (__SIG_ATOMIC_TYPE__, __INT8_TYPE__, + __INT16_TYPE__, __INT32_TYPE__, __INT64_TYPE__, __UINT8_TYPE__, + __UINT16_TYPE__, __UINT32_TYPE__, __UINT64_TYPE__, + __INT_LEAST8_TYPE__, __INT_LEAST16_TYPE__, __INT_LEAST32_TYPE__, + __INT_LEAST64_TYPE__, __UINT_LEAST8_TYPE__, __UINT_LEAST16_TYPE__, + __UINT_LEAST32_TYPE_, __UINT_LEAST64_TYPE__, __INT_FAST8_TYPE__, + __INT_FAST16_TYPE__, __INT_FAST32_TYPE__, __INT_FAST64_TYPE__, + __UINT_FAST8_TYPE__, __UINT_FAST16_TYPE__, __UINT_FAST32_TYPE__, + __UINT_FAST64_TYPE__, __INTPTR_TYPE__, __UINTPTR_TYPE__, + __WINT_MAX__, __SIZE_MAX__, __PTRDIFF_MAX__, __UINTMAX_MAX__, + __SIG_ATOMIC_MAX__, __INT8_MAX__, __INT16_MAX__, __INT32_MAX__, + __INT64_MAX__, __UINT8_MAX__, __UINT16_MAX__, __UINT32_MAX__, + __UINT64_MAX__, __INT_LEAST8_MAX__, __INT_LEAST16_MAX__, + __INT_LEAST32_MAX__, __INT_LEAST64_MAX__, __UINT_LEAST8_MAX__, + __UINT_LEAST16_MAX__, __UINT_LEAST32_MAX__, __UINT_LEAST64_MAX__, + __INT_FAST8_MAX__, __INT_FAST16_MAX__, __INT_FAST32_MAX__, + __INT_FAST64_MAX__, __UINT_FAST8_MAX__, __UINT_FAST16_MAX__, + __UINT_FAST32_MAX__, __UINT_FAST64_MAX__, __INTPTR_MAX__, + __UINTPTR_MAX__, __WCHAR_MIN__, __WINT_MIN__, __SIG_ATOMIC_MIN__, + __INT8_C, __INT16_C, __INT32_C, __INT64_C, __UINT8_C, __UINT16_C, + __UINT32_C, __UINT64_C, __INTMAX_C, __UINTMAX_C): Document. + * doc/tm.texi (SIG_ATOMIC_TYPE, INT8_TYPE, INT16_TYPE, INT32_TYPE, + INT64_TYPE, UINT8_TYPE, UINT16_TYPE, UINT32_TYPE, UINT64_TYPE, + INT_LEAST8_TYPE, INT_LEAST16_TYPE, INT_LEAST32_TYPE, + INT_LEAST64_TYPE, UINT_LEAST8_TYPE, UINT_LEAST16_TYPE, + UINT_LEAST32_TYPE, UINT_LEAST64_TYPE, INT_FAST8_TYPE, + INT_FAST16_TYPE, INT_FAST32_TYPE, INT_FAST64_TYPE, + UINT_FAST8_TYPE, UINT_FAST16_TYPE, UINT_FAST32_TYPE, + UINT_FAST64_TYPE, INTPTR_TYPE, UINTPTR_TYPE): Document. + +2009-03-31 Bernd Schmidt <bernd.schmidt@analog.com> + + * loop-iv.c (suitable_set_for_replacement): Renamed from + simplify_using_assignment; changed to return bool and to accept new + args DEST and SRC. Return true iff we find a source/destination pair + that can be used to make a replacement, and fill SRC and DEST if so. + Remove arg ALTERED. Don't deal with altered regs here. All callers + changed. + (simplify_using_initial_values): Deal with altered regs here and track + more precisely the effect they have on the validity of our expression. + + * loop-iv.c (simplify_using_condition): A condition of the form + (EQ REG CONST) can be used to simply make a substitution. + (simplify_using_initial_values): Keep track of conditions we have seen + and keep using them to simplify new expressions, while applying the + same substitutions to them as to the expression. + + * simplify-rtx.c (simplify_relational_operation_1): Simplify + (LTU (PLUS a C) C) or (LTU (PLUS a C) a) to (GEU a -C); likewise with + GEU/LTU reversed. + + * loop-iv.c (determine_max_iter): New arg OLD_NITER. All callers + changed. Use this when trying to improve the upper bound. + Generate the comparison by using simplify_gen_relational. + + * loop-iv.c (simple_rhs_p): Allow more kinds of expressions. + + * loop-iv.c (replace_single_def_regs, replace_in_expr): New static + functions. + (simplify_using_assignment, simplify_using_initial_values): Call + replace_in_expr to make replacements. Call replace_single_def_regs + once on the initial version of the expression. + +2009-03-31 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + PR target/27237 + * doc/invoke.texi (ARM Options): Update documentation for -mthumb. + +2009-03-31 Richard Guenther <rguenther@suse.de> + + PR middle-end/31029 + * fold-const.c (fold_binary): Fold X +- Y CMP X to Y CMP 0 for + equality comparisons. Fold C - X CMP X if C % 2 == 1. + +2009-03-31 Richard Guenther <rguenther@suse.de> + + * tree.h (div_if_zero_remainder): Declare. + * fold-const.c (div_if_zero_remainder): Export. + * tree-ssa-forwprop.c + (forward_propagate_addr_into_variable_array_index): Handle + constant array index addition outside of the variable index. + +2009-03-31 Joseph Myers <joseph@codesourcery.com> + + PR target/39592 + * config/i386/i386.md (*floatunssi<mode>2_1, two unnamed + define_splits, floatunssi<mode>2): Require x87 conversions from + DImode to be permitted. + +2009-03-31 Joseph Myers <joseph@codesourcery.com> + + PR preprocessor/15638 + * c-common.c (c_cpp_error): Handle CPP_DL_FATAL. + +2009-03-31 Richard Guenther <rguenther@suse.de> + + PR middle-end/23401 + PR middle-end/27810 + * tree.h (DECL_GIMPLE_FORMAL_TEMP_P): Remove. + (struct tree_decl_with_vis): Remove gimple_formal_temp member. + * tree-eh.c (lower_eh_constructs_2): Move LHS assignment to + a separate statement. + * gimplify.c (pop_gimplify_context): Remove formal temp handling. + (lookup_tmp_var): Likewise. + (is_gimple_formal_tmp_or_call_rhs): Remove. + (is_gimple_reg_or_call_rhs): Rename to ... + (is_gimple_reg_rhs_or_call): ... this. + (is_gimple_mem_or_call_rhs): Rename to ... + (is_gimple_mem_rhs_or_call): ... this. + (internal_get_tmp_var): Use is_gimple_reg_rhs_or_call. Set + DECL_GIMPLE_REG_P only if is_formal is true. + (gimplify_compound_lval): Use is_gimple_reg. Remove workaround + for non-proper post-modify expression gimplification. + (gimplify_self_mod_expr): For post-modify expressions gimplify + the lvalue to a minimal lvalue. + (rhs_predicate_for): Remove formal temp case. + (gimplify_modify_expr_rhs): Likewise. + (gimplify_addr_expr): Use is_gimple_reg. + (gimplify_expr): Remove formal temp cases. + (gimple_regimplify_operands): Likewise. + * tree-ssa-pre.c (get_or_alloc_expr_for): Treat EXC_PTR_EXPR + and FILTER_EXPR like constants. + * gimple.c (walk_gimple_op): Fix val_only initialization, use + is_gimple_reg. + (is_gimple_formal_tmp_rhs): Remove. + (is_gimple_reg_rhs): Remove special casing. + (is_gimple_mem_rhs): Fix. + (is_gimple_reg): Move DECL_GIMPLE_REG_P handling earlier. + (is_gimple_formal_tmp_var): Remove. + (is_gimple_formal_tmp_reg): Likewise. + (is_gimple_min_lval): Allow invariant component ref parts. + * gimple.h (is_gimple_formal_tmp_rhs, is_gimple_formal_tmp_var, + is_gimple_formal_tmp_reg): Remove declarations. + * tree-cfg.c (verify_expr): Verify that variables with address + taken do not have DECL_GIMPLE_REG_P set. + * tree-mudflap.c (mf_build_check_statement_for): Use + force_gimple_operand instead of gimplify_expr. + +2009-03-31 Ayal Zaks <zaks@il.ibm.com> + + * modulo-sched.c (sms_schedule_by_order): Pass the actual + schedulable rows to compute_split_row. + +2009-03-31 Ben Elliston <bje@au.ibm.com> + + PR target/31635 + * config/rs6000/rs6000.c (rs6000_handle_option): Handle + OPT_mvrsave. + +2009-03-31 Alan Modra <amodra@bigpond.net.au> + + * doc/invoke.texi (RS/6000 and PowerPC Options):Document mtls-markers. + * configure.ac (HAVE_AS_TLS_MARKERS): New gas feature check. + * configure: Regenerate. + * config.in: Regenerate. + * config/rs6000/rs6000.opt (mtls-markers): Add. + * config/rs6000/rs6000.h (TARGET_TLS_MARKERS): Define. + * config/rs6000/rs6000.md (tls_gd_aix, tls_gd_sysv): Add splitter. + (tls_ld_aix, tls_ld_sysv): Likewise. + (tls_gd, tls_gd_call_aix, tls_gd_call_sysv): New insns. + (tls_ld, tls_ld_call_aix, tls_ld_call_sysv): Likewise. + +2009-03-31 Alan Modra <amodra@bigpond.net.au> + + * config/spu/spu.c (spu_expand_prologue): Delete redundant code. + +2009-03-30 Jan Hubicka <jh@suse.cz> + + * tree-eh.c (make_eh_edges): Set probability 100% to first edge + out of RESX. + (tree_remove_unreachable_handlers): Cleanup EH predecestor + detection and label handling. + +2009-03-30 Vladimir Makarov <vmakarov@redhat.com> + + * ira-int.h (ira_allocno): Rename left_conflicts_num to + left_conflicts_size. + (ALLOCNO_LEFT_CONFLICTS_NUM): Rename to + ALLOCNO_LEFT_CONFLICTS_SIZE. + + * ira-color.c (allocno_spill_priority, push_allocno_to_stack, + remove_allocno_from_bucket_and_push, + allocno_spill_priority_compare, push_allocnos_to_stack, + setup_allocno_available_regs_num): Use ALLOCNO_LEFT_CONFLICTS_SIZE + instead of ALLOCNO_LEFT_CONFLICTS_NUM. + (setup_allocno_left_conflicts_num): Ditto. Rename to + setup_allocno_left_conflicts_size. + (put_allocno_into_bucket): Use ALLOCNO_LEFT_CONFLICTS_SIZE + instead of ALLOCNO_LEFT_CONFLICTS_NUM and + setup_allocno_left_conflicts_size instead of + setup_allocno_left_conflicts_num. + + * ira-build.c (ira_create_allocno): Use + ALLOCNO_LEFT_CONFLICTS_SIZE instead of + ALLOCNO_LEFT_CONFLICTS_NUM. + +2009-03-30 Vladimir Makarov <vmakarov@redhat.com> + + * reload.c (push_reload, find_dummy_reload): Use df_get_live_out + instead of DF_LR_OUT. + + * ira-lives.c (process_bb_node_lives): Ditto. + + * ira-color.c (ira_loop_edge_freq): Use df_get_live_{out,in} + instead of DF_LR_{OUT,IN}. + + * ira-emit.c (generate_edge_moves, add_ranges_and_copies): Ditto. + + * ira-build.c (create_bb_allocnos, create_loop_allocnos): Ditto. + +2009-03-30 Jan Hubicka <jh@suse.cz> + + * except.c (label_to_region_map): Fix thinko. + +2009-03-30 Steve Ellcey <sje@cup.hp.com> + + PR middle-end/38237 + * tree.h (tree_find_value): New declaration. + * tree.c (tree_find_value): New function. + * varasm.c (assemble_external): Avoid duplicate entries on lists. + +2009-03-30 Jakub Jelinek <jakub@redhat.com> + + PR debug/39563 + * c-decl.c (struct c_binding): Add locus field. + (bind): Add locus argument, set locus field from it. + (pop_scope): For b->nested VAR_DECL or FUNCTION_DECL, + add a DECL_EXTERNAL copy of b->decl to current BLOCK_VARS. + (push_file_scope, pushtag, pushdecl, pushdecl_top_level, + implicitly_declare, undeclared_variable, lookup_label, + declare_label, c_make_fname_decl, c_builtin_function, + c_builtin_function_ext_scope, store_parm_decls_newstyle): Adjust + bind callers. + +2009-03-30 H.J. Lu <hongjiu.lu@intel.com> + + PR target/38781 + * config/i386/i386.c (classify_argument): Check total size of + structure. + +2009-03-30 Martin Jambor <mjambor@suse.cz> + + * ipa-prop.h (jump_func_type): Rename IPA_UNKNOWN, IPA_CONST, + IPA_CONST_MEMBER_PTR, and IPA_PASS_THROUGH to IPA_JF_UNKNOWN, + IPA_JF_CONST, IPA_JF_CONST_MEMBER_PTR, and IPA_JF_PASS_THROUGH + respectively. + + * tree-dfa.c (get_ref_base_and_extent): Return -1 maxsize if + seen_variable_array_ref while also traversing a union. + + * tree-inline.c (optimize_inline_calls): Do not call + cgraph_node_remove_callees. + * cgraphbuild.c (remove_cgraph_callee_edges): New function. + (pass_remove_cgraph_callee_edges): New variable. + * passes.c (init_optimization_passes): Add + pass_remove_cgraph_callee_edges after early inlining and before all + late intraprocedural passes. + + * omp-low.c (expand_omp_taskreg): Always set current_function_decl. + +2009-03-30 Paolo Bonzini <bonzini@gnu.org> + + * config/sparc/sparc.md (*nand<V64mode>_vis, *nand<V32mode>_vis): + Fix typos in names. + +2009-03-30 Paolo Bonzini <bonzini@gnu.org> + + * combine.c (simplify_comparison): Use have_insn_for. + * dojump.c (do_jump): Likewise. + +2009-03-30 Paolo Bonzini <bonzini@gnu.org> + + * config/sparc/sparc.c (sparc_compare_emitted): Remove. + (gen_compare_reg, emit_v9_brxx_insn): Handle MODE_CC + sparc_compare_op0 like sparc_compare_emitted used to be handled. + (sparc_expand_compare_and_swap_12): Set sparc_compare_op0 + instead of sparc_compare_emitted. + * config/sparc/sparc.h (sparc_compare_emitted): Remove. + * config/sparc/sparc.md (stack_protect_test): Set sparc_compare_op0 + instead of sparc_compare_emitted. + +2009-03-30 Paolo Bonzini <bonzini@gnu.org> + + * bb-reorder.c (partition_hot_cold_basic_blocks): Do not + enter/exit cfglayout mode. + (pass_partition_block): Require it. + * combine.c (find_single_use, reg_dead_at_p): Use CFG. + (combine_instructions): Track basic blocks instead of labels. + (update_cfg_for_uncondjump): New. + (try_combine): Use it. Update jumps after rescanning. + (pass_combine): Require PROP_cfglayout. + * passes.c (pass_outof_cfg_layout_mode): Move after regmove. + +2009-03-30 Paolo Bonzini <bonzini@gnu.org> + + * cfglayout.c (pass_into_cfg_layout_mode, pass_outof_cfg_layout_mode): + Provide/destroy PROP_cfglayout respectively. + * gcse.c (pass_jump_bypass, pass_gcse): Require it. + * tree-pass.h (PROP_cfglayout): New. + +2009-03-30 Paolo Bonzini <bonzini@gnu.org> + + * fold-const.c (const_binop, fold_convert_const_real_from_fixed, + fold_convert_const_fixed_from_fixed, + fold_convert_const_fixed_from_int, + fold_convert_const_fixed_from_real, fold_negate_const): Do not + set TREE_CONSTANT_OVERFLOW. + * tree.def: Remove mention of TREE_CONSTANT_OVERFLOW. + * tree.h (TREE_CONSTANT_OVERFLOW): Delete. + +2009-03-30 Ira Rosen <irar@il.ibm.com> + + * tree-vect-loop-manip.c: New file. + * tree-vectorizer.c: Update documentation and included files. + (vect_loop_location): Make extern. + (rename_use_op): Move to tree-vect-loop-manip.c + (rename_variables_in_bb, rename_variables_in_loop, + slpeel_update_phis_for_duplicate_loop, + slpeel_update_phi_nodes_for_guard1, + slpeel_update_phi_nodes_for_guard2, slpeel_make_loop_iterate_ntimes, + slpeel_tree_duplicate_loop_to_edge_cfg, slpeel_add_loop_guard, + slpeel_can_duplicate_loop_p, slpeel_verify_cfg_after_peeling, + set_prologue_iterations, slpeel_tree_peel_loop_to_edge, + find_loop_location): Likewise. + (new_stmt_vec_info): Move to tree-vect-stmts.c. + (init_stmt_vec_info_vec, free_stmt_vec_info_vec, free_stmt_vec_info, + get_vectype_for_scalar_type, vect_is_simple_use, + supportable_widening_operation, supportable_narrowing_operation): + Likewise. + (bb_in_loop_p): Move to tree-vect-loop.c. + (new_loop_vec_info, destroy_loop_vec_info, + reduction_code_for_scalar_code, report_vect_op, + vect_is_simple_reduction, vect_is_simple_iv_evolution): Likewise. + (vect_can_force_dr_alignment_p): Move to tree-vect-data-refs.c. + (vect_supportable_dr_alignment): Likewise. + * tree-vectorizer.h (tree-data-ref.h): Include. + (vect_loop_location): Declare. + Reorganize function declarations according to the new file structure. + * tree-vect-loop.c: New file. + * tree-vect-analyze.c: Remove. Move functions to tree-vect-data-refs.c, + tree-vect-stmts.c, tree-vect-slp.c, tree-vect-loop.c. + * tree-vect-data-refs.c: New file. + * tree-vect-patterns.c (timevar.h): Don't include. + * tree-vect-stmts.c: New file. + * tree-vect-transform.c: Remove. Move functions to tree-vect-stmts.c, + tree-vect-slp.c, tree-vect-loop.c. + * Makefile.in (OBJS-common): Remove tree-vect-analyze.o and + tree-vect-transform.o. Add tree-vect-data-refs.o, tree-vect-stmts.o, + tree-vect-loop.o, tree-vect-loop-manip.o, tree-vect-slp.o. + (tree-vect-analyze.o): Remove. + (tree-vect-transform.o): Likewise. + (tree-vect-data-refs.o): Add rule. + (tree-vect-stmts.o, tree-vect-loop.o, tree-vect-loop-manip.o, + tree-vect-slp.o): Likewise. + (tree-vect-patterns.o): Remove redundant dependencies. + (tree-vectorizer.o): Likewise. + * tree-vect-slp.c: New file. + +2009-03-30 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * optc-gen.awk: Warn if an option flag has multiple different + help strings. + +2009-03-30 Sebastian Pop <sebastian.pop@amd.com> + + * doc/invoke.texi (-floop-interchange, -floop-strip-mine, + -floop-block): Document dependences on PPL, CLooG and Graphite. + +2009-03-30 Joseph Myers <joseph@codesourcery.com> + + PR rtl-optimization/323 + * c-common.c (c_fully_fold, convert_and_check, + c_common_truthvalue_conversion): Handle EXCESS_PRECISION_EXPR. + (c_fully_fold_internal): Disallow EXCESS_PRECISION_EXPR. + * c-common.def (EXCESS_PRECISION_EXPR): New. + * c-cppbuiltin.c (builtin_define_float_constants): Define + constants with enough digits for long double. + * c-lex.c (interpret_float): Interpret constant with excess + precision where appropriate. + * c-opts.c (c_common_post_options): Set + flag_excess_precision_cmdline. Give an error for + -fexcess-precision=standard for C++ for processors where the + option is significant. + * c-parser.c (c_parser_conditional_expression): Handle excess + precision in condition. + * c-typeck.c (convert_arguments): Handle arguments with excess + precision. + (build_unary_op): Move excess precision outside operation. + (build_conditional_expr): Likewise. + (build_compound_expr): Likewise. + (build_c_cast): Do cast on operand of EXCESS_PRECISION_EXPR. + (build_modify_expr): Handle excess precision in RHS. + (convert_for_assignment): Handle excess precision in converted + value. + (digest_init, output_init_element, process_init_element): Handle + excess precision in initializer. + (c_finish_return): Handle excess precision in return value. + (build_binary_op): Handle excess precision in operands and add + excess precision as needed for operation. + * common.opt (-fexcess-precision=): New option. + * config/i386/i386.h (X87_ENABLE_ARITH, X87_ENABLE_FLOAT): New. + * config/i386/i386.md (float<SSEMODEI24:mode><X87MODEF:mode>2): + For standard excess precision, output explicit conversion to and + truncation from XFmode. + (*float<SSEMODEI24:mode><X87MODEF:mode>2_1, + *float<SSEMODEI24:mode><X87MODEF:mode>2_i387_with_temp, + *float<SSEMODEI24:mode><X87MODEF:mode>2_i387, two unnamed + define_splits, floatdi<X87MODEF:mode>2_i387_with_xmm, two unnamed + define_splits, *floatunssi<mode>2_1, two unnamed define_splits, + floatunssi<mode>2, add<mode>3, sub<mode>3, mul<mode>3, divdf3, + divsf3, *fop_<mode>_comm_i387, *fop_<mode>_1_i387, + *fop_<MODEF:mode>_2_i387, *fop_<MODEF:mode>_3_i387, + *fop_df_4_i387, *fop_df_5_i387, *fop_df_6_i387, two unnamed + define_splits, sqrt<mode>2): Disable where appropriate for + standard excess precision. + * convert.c (convert_to_real): Do not shorten arithmetic to type + for which excess precision would be used. + * defaults.h (TARGET_FLT_EVAL_METHOD_NON_DEFAULT): Define. + * doc/invoke.texi (-fexcess-precision=): Document option. + (-mfpmath=): Correct index entry. + * flags.h (enum excess_precision, flag_excess_precision_cmdline, + flag_excess_precision): New. + * langhooks.c (lhd_post_options): Set + flag_excess_precision_cmdline. + * opts.c (common_handle_option): Handle -fexcess-precision=. + * toplev.c (flag_excess_precision_cmdline, flag_excess_precision, + init_excess_precision): New. + (lang_dependent_init_target): Call init_excess_precision. + * tree.c (excess_precision_type): New. + * tree.h (excess_precision_type): Declare. + +2009-03-30 Joseph Myers <joseph@codesourcery.com> + + PR c/35235 + * c-typeck.c (build_component_ref): Do not copy qualifiers from + non-lvalue to component. + +2009-03-29 Joseph Myers <joseph@codesourcery.com> + + PR preprocessor/34695 + * Makefile.in (c-opts.o): Depend on c-tree.h. + * c-common.c: Move down include of diagnostic.h. + (done_lexing, c_cpp_error): New. + * c-common.h (done_lexing): Declare. + * c-decl.c (c_write_global_declarations): Don't check cpp_errors + (parse_in). + * c-opts.c: Include c-tree.h. + (c_common_init_options): Set preprocessor error callback. + (c_common_handle_option): Do not set preprocessor + inhibit_warnings, warnings_are_errors, warn_system_headers, + pedantic_errors or inhibit_warnings flags. + (c_common_post_options): Do not check cpp_errors (parse_in). + (c_common_finish): Do not output dependencies if there were + errors. Do not check return value of cpp_finish. + * c-ppoutput.c (pp_file_change): Set input_location. + * c-tree.h (c_cpp_error): Declare. + * diagnostic.c (diagnostic_set_info_translated): Also initialize + override_column. + (diagnostic_build_prefix): Check override_column. + * diagnostic.h (diagnostic_info): Add override_column field. + (diagnostic_override_column): Define. + +2009-03-28 Paolo Bonzini <bonzini@gnu.org> + + * c-common.c (c_expand_expr, c_staticp): Remove. + * c-common.def (COMPOUND_LITERAL_EXPR): Delete. + * c-common.h (emit_local_var, c_staticp, COMPOUND_LITERAL_EXPR_DECL, + COMPOUND_LITERAL_EXPR_DECL_EXPR): Remove. + * c-gimplify.c (gimplify_compound_literal_expr, + optimize_compound_literals_in_ctor): Remove. + (c_gimplify_expr): Remove COMPOUND_LITERAL_EXPR handling. + * c-objc-common.h (LANG_HOOKS_STATICP): Remove. + * c-semantics.c (emit_local_var): Remove. + + * langhooks-def.h (lhd_expand_expr): Remove. + * langhooks.c (lhd_expand_expr): Remove. + * langhooks.h (LANG_HOOKS_DEF): Remove LANG_HOOKS_EXPAND_EXPR. + + * expr.c (expand_expr_real_1): Move COMPOUND_LITERAL_EXPR + handling from c-semantics.c; don't call into langhook. + (expand_expr_addr_expr_1): Check that we don't get non-GENERIC trees. + * gimplify.c (gimplify_compound_literal_expr, + optimize_compound_literals_in_ctor): Move from c-gimplify.c. + (gimplify_init_constructor): Call optimize_compound_literals_in_ctor. + (gimplify_modify_expr_rhs, gimplify_expr): Handle COMPOUND_LITERAL_EXPR + as was done in c-gimplify.c. + * tree.c (staticp): Move COMPOUND_LITERAL_EXPR handling from c_staticp. + * tree.h (COMPOUND_LITERAL_EXPR_DECL, COMPOUND_LITERAL_EXPR_DECL_EXPR): + Move from c-common.h. + * tree.def (COMPOUND_LITERAL_EXPR): Move from c-common.def. + + * tree.c (staticp): Do not call langhook. + * langhooks.c (lhd_staticp): Delete. + * langhooks-def.h (lhd_staticp): Delete prototype. + (LANG_HOOKS_STATICP): Delete. + (LANG_HOOKS_INITIALIZER): Delete LANG_HOOKS_STATICP. + + * doc/c-tree.texi (Expression nodes): Refer to DECL_EXPRs + instead of DECL_STMTs. + +2009-03-29 Joseph Myers <joseph@codesourcery.com> + + PR c/456 + PR c/5675 + PR c/19976 + PR c/29116 + PR c/31871 + PR c/35198 + * builtins.c (fold_builtin_sincos): Build COMPOUND_EXPR in + void_type_node. + (fold_call_expr): Return a NOP_EXPR from folding rather than the + contained expression. + * c-common.c (c_fully_fold, c_fully_fold_internal, c_save_expr): New. + (c_common_truthvalue_conversion): Use c_save_expr. Do not fold + conditional expressions for C. + (decl_constant_value_for_optimization): Move from + decl_constant_value_for_broken_optimization in c-typeck.c. Check + whether optimizing and that the expression is a VAR_DECL not of + array type instead of doing such checks in the caller. Do not + check pedantic. Call gcc_unreachable for C++. + * c-common.def (C_MAYBE_CONST_EXPR): New. + * c-common.h (c_fully_fold, c_save_expr, + decl_constant_value_for_optimization): New prototypes. + (C_MAYBE_CONST_EXPR_PRE, C_MAYBE_CONST_EXPR_EXPR, + C_MAYBE_CONST_EXPR_INT_OPERANDS, C_MAYBE_CONST_EXPR_NON_CONST, + EXPR_INT_CONST_OPERANDS): Define. + * c-convert.c (convert): Strip nops from expression. + * c-decl.c (groktypename): Take extra parameters expr and + expr_const_operands. Update call to grokdeclarator. + (start_decl): Update call to grokdeclarator. Add statement for + expressions used in type of decl. + (grokparm): Update call to grokdeclarator. + (push_parm_decl): Update call to grokdeclarator. + (build_compound_literal): Add parameter non_const and build a + C_MAYBE_COSNT_EXPR if applicable. + (grokdeclarator): Take extra parameters expr and + expr_const_operands. Track expressions used in declaration + specifiers and declarators. Fold array sizes and track whether + they are constant expressions and whether they are integer + constant expressions. + (parser_xref_tag): Set expr and expr_const_operands fields in + return value. + (grokfield): Update call to grokdeclarator. + (start_function): Update call to grokdeclarator. + (build_null_declspecs): Set expr and expr_const_operands fields in + return value. + (declspecs_add_type): Handle expressions in typeof specifiers. + * c-parser.c (c_parser_declspecs): Set expr and + expr_const_operands fields for declaration specifiers. + (c_parser_enum_specifier): Likewise. + (c_parser_struct_or_union_specifier): Likewise. + (c_parser_typeof_specifier): Likewise. Update call to + groktypename. Fold expression as needed. Return expressions with + type instead of adding statements. + (c_parser_attributes): Update calls to c_parser_expr_list. + (c_parser_statement_after_labels): Fold expression before passing + to objc_build_throw_stmt. + (c_parser_condition): Fold expression. + (c_parser_asm_operands): Fold expression. + (c_parser_conditional_expression): Use c_save_expr. Update call + to build_conditional_expr. + (c_parser_alignof_expression): Update call to groktypename. + (c_parser_postfix_expression): Preserve C_MAYBE_CONST_EXPR as + original_code. Fold expression argument of va_arg. Create + C_MAYBE_CONST_EXPR to preserve side effects of expressions in type + argument to va_arg. Update calls to groktypename. Fold array + index for offsetof. Verify that first argument to + __builtin_choose_expr has integer type. + (c_parser_postfix_expression_after_paren_type): Update calls to + groktypename and build_compound_literal. Handle expressions with + side effects in type name. + (c_parser_postfix_expression_after_primary): Update call to + c_parser_expr_list. Set original_code for calls to + __builtin_constant_p. + (c_parser_expr_list): Take extra parameter fold_p. Fold + expressions if requested. + (c_parser_objc_type_name): Update call to groktypename. + (c_parser_objc_synchronized_statement): Fold expression. + (c_parser_objc_receiver): Fold expression. + (c_parser_objc_keywordexpr): Update call to c_parser_expr_list. + (c_parser_omp_clause_num_threads, c_parser_omp_clause_schedule, + c_parser_omp_atomic, c_parser_omp_for_loop): Fold expressions. + * c-tree.h (CONSTRUCTOR_NON_CONST): Define. + (struct c_typespec): Add elements expr and expr_const_operands. + (struct c_declspecs): Add elements expr and expr_const_operands. + (groktypename, build_conditional_expr, build_compound_literal): + Update prototypes. + (in_late_binary_op): Declare. + * c-typeck.c (note_integer_operands): New function. + (in_late_binary_op): New variable. + (decl_constant_value_for_broken_optimization): Move to c-common.c + and rename to decl_constant_value_for_optimization. + (default_function_array_conversion): Do not strip nops. + (default_conversion): Do not call + decl_constant_value_for_broken_optimization. + (build_array_ref): Do not fold result. + (c_expr_sizeof_expr): Fold operand. Use C_MAYBE_CONST_EXPR for + result when operand is a VLA. + (c_expr_sizeof_type): Update call to groktypename. Handle + expressions included in type name. Use C_MAYBE_CONST_EXPR for + result when operand names a VLA type. + (build_function_call): Update call to build_compound_literal. + Only fold result for calls to __builtin_* functions. Strip + NOP_EXPR from INTEGER_CST returned from such functions. Fold + the function designator. + (convert_arguments): Fold arguments. Update call to + convert_for_assignment. + (build_unary_op): Handle increment and decrement of + C_MAYBE_CONST_EXPR. Move lvalue checks for increment and + decrement earlier. Fold operand of increment and decrement. + Handle address of C_MAYBE_CONST_EXPR. Only fold expression being + built for integer operand. Wrap returns that are INTEGER_CSTs + without being integer constant expressions or that have integer + constant operands without being INTEGER_CSTs. + (lvalue_p): Handle C_MAYBE_CONST_EXPR. + (build_conditional_expr): Add operand ifexp_bcp. Track whether + result is an integer constant expression or can be used in + unevaluated parts of one and avoid folding and wrap as + appropriate. Fold operands before possibly doing -Wsign-compare + warnings. + (build_compound_expr): Wrap result for C99 if operands can be used + in integer constant expressions. + (build_c_cast): Update call to digest_init. Do not ignore + overflow from casting floating-point constants to integers. Wrap + results that could be confused with integer constant expressions, + null pointer constants or floating-point constants. + (c_cast_expr): Update call to groktypename. Handle expressions + included in type name. + (build_modify_expr): Handle modifying a C_MAYBE_CONST_EXPR. Fold + lhs inside possible SAVE_EXPR. Fold RHS before assignment. + Update calls to convert_for_assignment. + (convert_for_assignment): Take new parameter + null_pointer_constant. Do not strip nops or call + decl_constant_value_for_broken_optimization. Set + in_late_binary_op for conversions to boolean. + (store_init_value): Update call to digest_init. + (digest_init): Take new parameter null_pointer_constant. Do not + call decl_constant_value_for_broken_optimization. pedwarn for + initializers not constant expressions. Update calls to + convert_for_assignment. + (constructor_nonconst): New. + (struct constructor_stack): Add nonconst element. + (really_start_incremental_init, push_init_level, pop_init_level): + Handle constructor_nonconst and nonconst element. + (set_init_index): Call constant_expression_warning for array + designators. + (output_init_element): Fold value. Set constructor_nonconst as + applicable. pedwarn for initializers not constant expressions. + Update call to digest_init. Call constant_expression_warning + where constant initializers are required. + (process_init_element): Use c_save_expr. + (c_finish_goto_ptr): Fold expression. + (c_finish_return): Fold return value. Update call to + convert_for_assignment. + (c_start_case): Fold switch expression. + (c_process_expr_stmt): Fold expression. + (c_finish_stmt_expr): Create C_MAYBE_CONST_EXPR as needed to + ensure statement expression is not evaluated in constant expression. + (build_binary_op): Track whether results are integer constant + expressions or may occur in such, disable folding and wrap results + as applicable. Fold operands for -Wsign-compare warnings unless + in_late_binary_op. + (c_objc_common_truthvalue_conversion): Handle results folded to + integer constants that are not integer constant expressions. + * doc/extend.texi: Document when typeof operands are evaluated, + that condition of __builtin_choose_expr is an integer constant + expression, and more about use of __builtin_constant_p in + initializers. + +2009-03-29 Richard Guenther <rguenther@suse.de> + + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Properly + propagate addresses of array references. + +2009-03-29 Steven Bosscher <steven@gcc.gnu.org> + + * regmove.c (perhaps_ends_bb_p): Remove. + (optimize_reg_copy_1): Don't call perhaps_ends_bb_p. Get basic block + from INSN and check that the main loop stays within that basic block. + (optimize_reg_copy_1, optimize_reg_copy_3, fixup_match_2): Likewise. + (regmove_forward_pass): Split out from regmove_optimize. Use + FOR_EACH_BB and FOR_BB_INSNS instead of traversing the insns stream. + (regmove_backward_pass): Split out from regmove_optimize. Use + FOR_EACH_BB_REVERSE and FOR_BB_INSNS_REVERS_SAFE. + (regmove_optimize): Simplify. + +2009-03-29 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39545 + * config/i386/i386.c (classify_argument): Ignore flexible array + member in struct and warn ABI change. + +2009-03-29 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386-protos.h (ix86_agi_dependent): New. + + * config/i386/i386.c (ix86_agi_dependent): Rewrite. + (ix86_adjust_cost): Updated. + +2009-03-29 Jan Hubicka <jh@suse.cz> + + PR middle-end/28850 + * tree-pass.h (pass_cleanup_eh): New function. + (remove_unreachable_regions): Break code handling RTL + to rtl_remove_unreachable_regions; remove ERT_MUST_NOT_THROW + that can not be reached by runtime. + (can_be_reached_by_runtime): New function. + (label_to_region_map): New function. + (num_eh_regions): New function. + (rtl_remove_unreachable_regions): New function. + (convert_from_eh_region_ranges): Call rtl_remove_unreachable_regions. + (remove_eh_region): New function. + * except.h: Include sbitmap and vecprim. + (remove_eh_region, remove_unreachable_regions, label_to_region_map, + num_eh_regions): Declare. + * passes.c (init_optimization_passes): Schedule cleanup_eh. + * Makefile.in (EXCEPT_H): New; replace all uses of except.h by it. + * tree-eh.c (tree_remove_unreachable_handlers): New function. + (tree_empty_eh_handler_p): New function. + (cleanup_empty_eh): New function. + (cleanup_eh): New function. + (pass_cleanup_eh): New function. + +2009-03-29 Jan Hubicka <jh@suse.cz> + + * except.c (verify_eh_tree): Fix handling of fun!=cfun; be ready + for removed regions. + +2009-03-29 Jan Hubicka <jh@suse.cz> + + * except.c (dump_eh_tree): Dump all datastructures. + +2009-03-29 Jan Hubicka <jh@suse.cz> + + * except.c (duplicate_eh_regions_0): Handle AKA bitmap. + (duplicate_eh_regions_1): Likewise. + (duplicate_eh_regions): Likewise; cleanup code gorwing the region + vector; call EH verification. + (foreach_reachable_handler, can_throw_internal_1, can_throw_external_1): + Be ready for region being removed. + +2009-03-29 Jan Hubicka <jh@suse.cz> + + * bitmap.c (bitmap_last_set_bit): New function. + * bitmap.h (bitmap_last_set_bit): Declare. + +2009-03-29 David Ayers <ayers@fsfe.org> + + PR objc/27377 + * c-typeck.c (build_conditional_expr): Emit ObjC warnings + by calling objc_compare_types and surpress warnings about + incompatible C pointers that are compatible ObjC pointers. + +2009-03-29 Adam Nemet <anemet@caviumnetworks.com> + + * cgraphbuild.c (build_cgraph_edges, rebuild_cgraph_edges): Don't + call initialize_inline_failed. + (initialize_inline_failed): Move it from here ... + * cgraph.c (initialize_inline_failed): ... to here. + (cgraph_create_edge): Call initialize_inline_failed rather than + setting inline_failed directly. + +2009-03-29 Ben Elliston <bje@au.ibm.com> + + PR target/32542 + * sysv4.opt (msdata): Improve comment. + * linux64.h (ASM_SPEC32): Do not pass -memb when -msdata is given. + * sysv4.h (SVR4_ASM_SPEC): Likewise. + +2009-03-29 Ben Elliston <bje@au.ibm.com> + + PR target/30451 + * config/rs6000/rs6000.md (*movti_ppc64): Correct the order of + load and store attributes. + +2009-03-29 Ben Elliston <bje@au.ibm.com> + + * config/i386/i386.c (enum ix86_builtins): Add IX86_BUILTIN_HUGE_VALQ. + (ix86_init_builtins): Add built-in function __builtin_huge_valq. + (ix86_expand_builtin): Handle IX86_BUILTIN_HUGE_VALQ. + * doc/extend.texi (X86 Built-in Functions): Add index entries for + __builtin_infq and __builtin_huge_valq. + +2009-03-28 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.c (avr_mcu_t): Add atmega8c1, atmega16c1 and + atmega8m1 devices. + * config/avr/avr.h (LINK_SPEC, CRT_BINUTILS_SPECS): (Ditto.). + * config/avr/t-avr (MULTILIB_MATCHES): (Ditto.) + +2009-03-28 Xinliang David Li <davidxl@google.com> + + * tree-ssa-ccp.c (ccp_finalize): Add dbg_count support. + (do_dbg_cnt): New function. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + Merge from pretty-ipa: + + 2009-03-27 Jan Hubicka <jh@suse.cz> + + * cgraph.c (dump_cgraph_node): Add replace output flag by process. + * tree-pass.h (function_called_by_processed_nodes_p): Declare. + * passes.c (function_called_by_processed_nodes_p): New. + * ipa-pure-const.c (check_call): Fix handling of operands. + (analyze_function): Dump debug output for skipped bodies. + (local_pure_const): Use function_called_by_processed_nodes_p. + * dwarf2out.c (reference_to_unused): Use output. + * passes.c (do_per_function_toporder): Likewise. + + 2008-11-12 Jan Hubicka <jh@suse.cz> + + * tree-pass.h (pass_fixup_cfg, pass_local_pure_const): Declare. + * ipa-pure-const.c (funct_state_d): Add can throw field; make + state_set_in_source enum + (check_decl): Ignore memory tags; do not set fake looping flags; + dump diagnostics. + (check_operand, check_tree, check_rhs_var, check_lhs_var, + get_asm_expr_operands, scan_function_op, scan_function_stmt): Remove. + (check_call, analyze_function): Rewrite. + (check_stmt): New. + (add_new_function): Update call of analyze_function. + (generate_summary): Add call of analyze_function. + (propagate): Propagate can_throw; handle state_set_in_source correctly. + (local_pure_const): New function. + (pass_local_pure_const): New pass. + * ipa-inline.c (inline_transform): Set after_inlining. + * tree-eh.c (stmt_can_throw_external): New. + * tree-optimize.c (execute_fixup_cfg): Do not set after_inlining; + work with aliasing built. + * tree-flow.h (stmt_can_throw_external): New. + * passes.c (init_optimization_passes): Schedule fixup_cfg pass early; + and local pure/const pass in early and late optimization queue. + +2009-03-28 Martin Jambor <mjambor@suse.cz> + + * fold-const.c (get_pointer_modulus_and_residue): New parameter + allow_func_align. + (fold_binary): Allow function decl aligment consideration is the + second argument is integer constant one. + * tree-ssa-forwprop.c (simplify_bitwise_and): New function. + (tree_ssa_forward_propagate_single_use_vars): Handle assing statements + with BIT_AND_EXPR on the RHS by calling simplify_bitwise_and. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + * dwarf2out.c (dwarf2out_begin_prologue): Use crtl->nothrow + * tree-eh.c (stmt_could_throw_p): Remove check for WEAK decls. + * function.h (rtl_data): Add nothrow flag. + * except.c (set_nothrow_function_flags): Use crtl->nothrow; + set DECL_NOTHROW for AVAILABLE functions. + +2009-03-28 Jakub Jelinek <jakub@redhat.com> + + * config/rs6000/rs6000-c.c (rs6000_macro_to_expand): If macro + following vector keyword has expansion starting with pixel or bool + keyword, expand vector to __vector and pixel or bool to __pixel or + __bool. + + PR c++/39554 + * opts.c (warning_disallowed_functions, warn_disallowed_functions, + warn_if_disallowed_function_p): Removed. + (common_handle_option): Don't handle OPT_Wdisallowed_function_list_. + * c-parser.c (c_parser_postfix_expression_after_primary): Don't call + warning_if_disallowed_function_p. + * flags.h (warn_if_disallowed_function_p, + warn_disallowed_functions): Removed. + * common.opt (Wdisallowed-function-list=): Removed. + * doc/invoke.texi (-Wdisallowed-function-list=): Removed. + +2009-03-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38723 + * tree-ssa-pre.c (compute_avail): Add all default definitions to + the entry block. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + * tree-ssa-structalias.c (ipa_pta_execute): Fix bogus node->analyzed + test introduced by my previous patch. + +2009-03-28 Richard Guenther <rguenther@suse.de> + + * tree-ssa-copy.c (copy_prop_visit_phi_node): Do not leave + the PHIs value undefined. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + * tree-pass.h (pass_fixup_cfg): New pass. + * ipa-inline.c (inline_transform): Set + always_inline_functions_inlined/after_inlining. + * tree-optimize.c (execute_fixup_cfg): Do not set them here. + (pass_fixup_cfg): New pass. + * passes.c (init_optimization_passes): Add fixup_cfg. + +2009-03-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38458 + * tree-ssa-copy.c (copy_prop_visit_phi_node): For the first + argument use the arguments copy-of value. + +2009-03-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38180 + * tree-ssa-ccp.c (get_default_value): Simplify. + (likely_value): Likewise. + (surely_varying_stmt_p): Properly handle VOP case. + (ccp_initialize): Likewise. + (ccp_fold): Handle propagating through *&. + (fold_const_aggregate_ref): Also handle decls. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + * cgraph.c (dump_cgraph_node): Add replace output flag by process. + * cgraph.h (cgraph_node): Likewise. + * cgraphunit.c (cgraph_process_new_functions): Set process flag. + (cgraph_reset_node): Use process flag. + (cgraph_mark_functions_to_output): Likewise. + (cgraph_expand_function): Likewise. + (cgraph_expand_all_functions): Likewise. + (cgraph_output_in_order): Likewise. + * dwarf2out.c (reference_to_unused): Likewise. + * passes.c do_per_function_toporder): Likewise. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + Bring from lto-branch: + + 2008-09-03 Doug Kwan <dougkwan@google.com> + + * cgraphbuild.c (initialize_inline_failed): Use cgraph_inline_failed_t + enums instead of reason strings. + * cgraph.c (cgraph_create_edge): Same. + (cgraph_inline_failed_string): New function. + * cgraph.h (cgraph_inline_failed_t): New enum type. + (cgraph_inline_failed_string): New prototype. + (struct cgraph_edge): Change type of INLINED_FAILED from constant + char pointer to cgraph_inline_failed_t. + (cgraph_inline_p): Adjust prototype to use cgraph_inline_failed_t. + (cgraph_default_inline_p): Ditto. + * cgraphunit.c (cgraph_inline_p): Change type of parameter REASON + to cgraph_inline_failed_t pointer. + * cif-code.def: New file. + * ipa-inline.c (cgraph_mark_inline_edge): Use an enum instead of a + reason string. + (cgraph_check_inline_limits): Change type of REASON to pointer to + cgraph_inline_failed_t. Replace reason strings with enums. + (cgraph_default_inline_p): Ditto. + (cgraph_recursive_inlining_p): Ditto. + (update_caller_keys): Change type of FAILED_REASON to + cgraph_inline_failed_t. + (cgraph_set_inline_failed): Change type of REASON to pointer to + cgraph_inline_failed_t. Call cgraph_inline_failed_string to + convert enums to strings for text output. + (cgraph_decide_inlining_of_small_function): Change FAILED_REASON + to be of type cgraph_inline_failed_t. Replace reason strings with + enums. Call cgraph_inline_failed_string to covert enums + to strings for text output. + (cgraph_decide_inlining): Replace reason strings with enums. + (cgraph_decide_inlining_incrementally): Change type of FAILED_REASON + to cgraph_inline_failed_t type. Call cgraph_inline_failed_string + for text output. + * tree-inline.c (expand_call_inline): Change type of REASON + to cgraph_inline_failed_t. Replace reason strings with enums. + Call cgraph_inline_failed_string for text output. + * Makefile.in (CGRAPH_H): Add cif-code.def to dependencies. + (cgraph.o): Ditto. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_node, cgraph_remove_node, dump_cgraph_node, + cgraph_clone_node): Remove master clone handling. + (cgraph_is_master_clone, cgraph_master_clone): Remove. + * cgraph.h (master_clone): Remove. + (cgraph_is_master_clone, cgraph_master_clone): Remove. + * ipa-type-escape.c (type_escape_execute): Remove use of master clone. + (tree-ssa-structalias.c (ipa_pta_execute): Likewise. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + * cgraph.c (cgraph_function_body_availability): Functions declared + inline are always safe to assume that it is not going to be replaced. + +2009-03-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38513 + * tree-ssa-pre.c (eliminate): Remove redundant stores. + * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle + EXC_PTR_EXPR and FILTER_EXPR. + (get_ref_from_reference_ops): Likewise. + +2009-03-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38968 + * tree-vect-analyze.c (vect_compute_data_ref_alignment): + Use FLOOR_MOD_EXPR to compute misalignment. + +2009-03-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/37795 + * tree.h (combine_comparisons): Declare. + * fold-const.c (combine_comparisons): Export. + * tree-ssa-ifcombine.c (ifcombine_ifandif): Optimize two successive + comparisons. + (ifcombine_iforif): Use combine_comparisons. + +2009-03-28 Jan Hubicka <jh@suse.cz> + + * tree-eh.c (inlinable_call_p): New function. + (make_eh_edges): Use it. + (verify_eh_edges): Use it. + (stmt_can_throw_external, stmt_can_throw_internal): Use it. + * except.c (reachable_next_level): Add inlinable_function argument + (sjlj_find_directly_reachable_regions): Update. + (add_reachable_handler): Do not set saw_any_handlers. + (reachable_next_level): Handle MUST_NOT_THROW more curefully. + (foreach_reachable_handler, can_throw_internal_1, can_throw_external_1): + Add new inlinable call parameter. + (can_throw_internal, can_throw_external): Update. + * except.h (can_throw_internal_1, can_throw_external_1, + foreach_reachable_handler): Update declaration. + +2009-03-28 Joseph Myers <joseph@codesourcery.com> + + * config/arm/t-arm-coff, config/h8300/coff.h, + config/i386/i386-aout.h, config/i386/i386-coff.h, + config/libgloss.h, config/m68k/coff.h, config/m68k/m68k-aout.h, + config/pdp11/2bsd.h, config/rs6000/aix41.h, + config/rs6000/aix41.opt, config/rs6000/t-newas, config/sh/coff.h, + fix-header.c, fixproto, gen-protos.c, protoize.c, scan-decls.c, + scan-types.sh, scan.c, scan.h, sort-protos, sys-protos.h, + sys-types.h: Remove. + * Makefile.in: Remove protoize and fixproto support and references + in comments. + (SYSCALLS.c.X-warn, TARGET_GETGROUPS_T, STMP_FIXPROTO, + PROTOIZE_INSTALL_NAME, UNPROTOIZE_INSTALL_NAME, FIXPROTO_DEFINES): + Remove. + (ALL_HOST_OBJS): Remove $(PROTO_OBJS). + (MOSTLYCLEANFILES): Remove protoize$(exeext) and + unprotoize$(exeext). + (rest.encap): Don't depend on $(STMP_FIXPROTO) + (.PHONY): Don't depend on proto. + (libgcc-support): Don't depend on $(STMP_FIXPROTO). + (proto, PROTO_OBJS, protoize$(exeext), unprotoize$(exeext), + protoize.o, unprotoize.o, SYSCALLS.c.X, test-protoize-simple, + deduced.h, GEN_PROTOS_OBJS, build/gen-protos$(build_exeext), + build/gen-protos.o, build/scan.o, xsys-protos.h, + build/fix-header$(build_exeext), build/fix-header.o, + build/scan-decls.o, fixhdr.ready, stmp-fixproto, + stmp-install-fixproto): Remove. + (mostlyclean): Don't remove xsys-protos.hT, SYSCALLS.c.X, + SYSCALLS.c or fixproto files. + (install-common): Don't install protoize. + (install-headers-tar, install-headers-cpio, install-headers-cp): + Don't depend on $(STMP_FIXPROTO). + (install-mkheaders): Don't depend on $(STMP_FIXPROTO). Don't + install fixproto files or write out fixproto settings. + (uninstall): Don't uninstall protoize. + * config.gcc (use_fixproto): Remove. + (arm-*-coff*, armel-*-coff*, h8300-*-*, i[34567]86-*-aout*, + i[34567]86-*-coff*, m68k-*-aout*, m68k-*-coff*, pdp11-*-bsd, + rs6000-ibm-aix4.[12]*, powerpc-ibm-aix4.[12]*, sh-*-*): Remove. + * config/m32r/t-linux (STMP_FIXPROTO): Remove. + * config/m68k/m68k.c: Remove M68K_TARGET_COFF-conditional code. + * config/mips/t-iris (FIXPROTO_DEFINES): Remove. + * config/pa/t-pa-hpux (FIXPROTO_DEFINES): Remove. + * config/pdp11/pdp11.c: Remove TWO_BSD-conditional code. + * config/t-svr4 (FIXPROTO_DEFINES): Remove. + * config/t-vxworks (STMP_FIXPROTO): Remove. + * configure.ac (AC_TYPE_GETGROUPS, TARGET_GETGROUPS_T, + STMP_FIXPROTO): Remove. + * config.in, configure: Regenerate. + * crtstuff.c (gid_t, uid_t): Don't undefine. + * doc/install.texi: Change m68k-coff to m68k-elf in example. + (arm-*-coff, arm-*-aout: Remove target entries. + (*-ibm-aix*): Mention removal of support for AIX 4.2 and older. + Remove mention of AIX 4.1. + (m68k-*-*): Remove mention of m68k-*-aout and m68k-*-coff*. + * doc/invoke.texi (Running Protoize): Remove. + * doc/trouble.texi (Actual Bugs): Remove mention of fixproto. + (Protoize Caveats): Remove. + * tsystem.h: Update comments on headers assumed to exist. + +2009-03-27 Vladimir Makarov <vmakarov@redhat.com> + + * genautomata.c: Add a new year to the copyright. Add a new + reference. + (struct insn_reserv_decl): Add comments for member bypass_list. + (find_bypass): Remove. + (insert_bypass): New. + (process_decls): Use insert_bypass. + (output_internal_insn_latency_func): Output all bypasses with the + same input insn in one switch case. + + * rtl.def (define_bypass): Describe bypass choice. + * doc/md.texi (define_bypass): Ditto. + +2009-03-27 Richard Guenther <rguenther@suse.de> + + * gimplify.c (mark_addressable): Export. + * tree-flow.h (mark_addressable): Declare. + * tree-ssa-loop-manip.c (create_iv): Mark the base addressable. + * tree-ssa.c (verify_phi_args): Verify that address taken + variables have TREE_ADDRESSABLE set. + +2009-03-27 Richard Guenther <rguenther@suse.de> + + * fold-const.c (build_fold_addr_expr_with_type_1): Rename back to ... + (build_fold_addr_expr_with_type): ... this. Remove in_fold handling. + Do not mark decls TREE_ADDRESSABLE. + (build_fold_addr_expr): Adjust. + (fold_addr_expr): Remove. + (fold_unary): Use build_fold_addr_expr. + (fold_comparison): Likewise. + (split_address_to_core_and_offset): Likewise. + * coverage.c (tree_coverage_counter_addr): Mark the array decl + TREE_ADDRESSABLE. + * gimplify.c (mark_addressable): Do not exclude RESULT_DECLs. + (gimplify_modify_expr_to_memcpy): Mark source and destination + addressable. + * omp-low.c (create_omp_child_function): Mark the object decl + TREE_ADDRESSABLE. + (lower_rec_input_clauses): Mark the var we take the address of + TREE_ADDRESSABLE. + (lower_omp_taskreg): Mark the sender decl TREE_ADDRESSABLE. + +2009-03-27 H.J. Lu <hongjiu.lu@intel.com> + + PR middle-end/39315 + * cfgexpand.c (expand_one_stack_var_at): Change alignment + limit to MAX_SUPPORTED_STACK_ALIGNMENT. + +2009-03-27 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39120 + * tree-ssa-structalias.c (handle_rhs_call): Fill out return + constraints. + (handle_lhs_call): Process return constraints. Add escape + constraints if necessary. + (handle_const_call): Fill out return constraints. Make nested + case more precise. Avoid consttmp if possible. + (handle_pure_call): Fill out return constraints. Avoid + callused if possible. + (find_func_aliases): Simplify call handling. + +2009-03-27 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39120 + * tree-ssa-structalias.c (do_sd_constraint): Do not use CALLUSED + as a representative. + (solve_graph): Do propagate CALLUSED. + (handle_pure_call): Use a scalar constraint from CALLUSED for + the return value. + (find_what_p_points_to): CALLUSED shall not appear in poins-to + solutions. + +2009-03-27 H.J. Lu <hongjiu.lu@intel.com> + + PR c/39323 + * c-common.c (handle_aligned_attribute): Properly check alignment + overflow. Use (1U << i) instead of (1 << i). + + * emit-rtl.c (get_mem_align_offset): Use "unsigned int" for align. + + * expr.h (get_mem_align_offset): Updated. + + * tree.h (tree_decl_common): Change align to "unsigned int" and + move it before pointer_alias_set. + +2009-03-27 H.J. Lu <hongjiu.lu@intel.com> + Jakub Jelinek <jakub@redhat.com> + + PR target/38034 + * config/ia64/sync.md (cmpxchg_rel_<mode>): Replace input + gr_register_operand with gr_reg_or_0_operand. + (cmpxchg_rel_di): Likewise. + (sync_lock_test_and_set<mode>): Likewise. + +2009-03-27 H.J. Lu <hongjiu.lu@intel.com> + + * jump.c (rtx_renumbered_equal_p): Use subreg_get_info. + (true_regnum): Likewise. + + * rtlanal.c (subreg_info): Moved to ... + * rtl.h (subreg_info): Here. New. + (subreg_get_info): New. + + * rtlanal.c (subreg_get_info): Make it extern. + +2009-03-27 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39472 + * config/i386/i386.c (ix86_abi): New. + (override_options): Handle -mabi=. + (ix86_function_arg_regno_p): Replace DEFAULT_ABI with ix86_abi. + (ix86_call_abi_override): Likewise. + (init_cumulative_args): Likewise. + (function_arg_advance): Likewise. + (function_arg_64): Likewise. + (function_arg): Likewise. + (ix86_pass_by_reference): Likewise. + (ix86_function_value_regno_p): Likewise. + (ix86_build_builtin_va_list_abi): Likewise. + (setup_incoming_varargs_64): Likewise. + (is_va_list_char_pointer): Likewise. + (ix86_init_machine_status): Likewise. + (ix86_reg_parm_stack_space): Use enum calling_abi on call_abi. + (ix86_function_type_abi): Return enum calling_abi. Rewrite + for 64bit. Replace DEFAULT_ABI with ix86_abi. + (ix86_function_abi): Make it static and return enum calling_abi. + (ix86_cfun_abi): Return enum calling_abi. Replace DEFAULT_ABI + with ix86_abi. + (ix86_fn_abi_va_list): Updated. + + * config/i386/i386.h (ix86_abi): New. + (STACK_BOUNDARY): Replace DEFAULT_ABI with ix86_abi. + (CONDITIONAL_REGISTER_USAGE): Likewise. + (CUMULATIVE_ARGS): Change call_abi type to enum calling_abi. + (machine_function): Likewise. + + * config/i386/i386.md (untyped_call): Replace DEFAULT_ABI + with ix86_abi. + * config/i386/cygming.h (TARGET_64BIT_MS_ABI): Likewise. + (STACK_BOUNDARY): Likewise. + * config/i386/mingw32.h (EXTRA_OS_CPP_BUILTINS): Likewise. + + * config/i386/i386.opt (mabi=): New. + + * config/i386/i386-protos.h (ix86_cfun_abi): Changed to + return enum calling_abi. + (ix86_function_type_abi): Likewise. + (ix86_function_abi): Removed. + + * doc/invoke.texi: Document -mabi= option for x86. + +2009-03-27 Kaveh R. Ghazi <ghazi@caip.rutgers.edu> + + * builtins.c (real_dconstp): Delete. + (fold_builtin_logarithm): Remove inaccurate log(e) special case. + +2009-03-27 Dodji Seketeli <dodji@redhat.com> + Jakub Jelinek <jakub@redhat.com> + + PR debug/37959 + * dwarf2out.c (dwarf_attr_name): Handle DW_AT_explicit attribute. + (gen_subprogram_die): When a function is explicit, generate the + DW_AT_explicit attribute. + * langhooks.h (struct lang_hooks_for_decls): Add + function_decl_explicit_p langhook. + * langhooks-def.h (LANG_HOOKS_FUNCTION_DECL_EXPLICIT_P): Define. + (LANG_HOOKS_DECLS): Add LANG_HOOKS_FUNCTION_DECL_EXPLICIT_P. + +2009-03-27 Jakub Jelinek <jakub@redhat.com> + + * builtins.c (fold_builtin_memory_op): Optimize memmove + into memcpy if we can prove source and destination don't overlap. + + * tree-inline.c: Include gt-tree-inline.h. + (clone_fn_id_num): New variable. + (clone_function_name): New function. + (tree_function_versioning): Use it. + * Makefile.in (GTFILES): Add tree-inline.c. + +2009-03-27 Mark Mitchell <mark@codesourcery.com> + + * BASE-VER: Change to 4.5.0. + +2009-03-27 Xinliang David Li <davidxl@google.com> + + PR tree-optimization/39557 + * tree-ssa.c (warn_uninitialized_vars): free postdom info. + +2009-03-27 Xinliang David Li <davidxl@google.com> + + PR tree-optimization/39548 + * tree-ssa-copy.c (copy_prop_visit_phi_node): Add copy + candidate check. + +2009-03-27 H.J. Lu <hongjiu.lu@intel.com> + + * c-common.c (pointer_int_sum): Use %wd on return from + tree_low_cst. + +2009-03-27 H.J. Lu <hongjiu.lu@intel.com> + + * c-common.c (pointer_int_sum): Use HOST_WIDE_INT_PRINT_DEC + on return from tree_low_cst. + +2009-03-27 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR c++/36799 + * ginclude/stdarg.h (va_copy): Define also for + __GXX_EXPERIMENTAL_CXX0X__. + +2009-03-27 Manuel Lopez-Ibanez <manu@gcc.gnu.org> + + PR c++/35652 + * builtins.h (c_strlen): Do not warn here. + * c-typeck.c (build_binary_op): Adjust calls to pointer_int_sum. + * c-common.c (pointer_int_sum): Take an explicit location. + Warn about offsets out of bounds. + * c-common.h (pointer_int_sum): Adjust declaration. + +2009-03-26 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/invoke.texi (i386 and x86-64 Windows Options): Fix texinfo + markup glitch. + +2009-03-26 Jakub Jelinek <jakub@redhat.com> + + PR c++/39554 + * opts.c (warn_if_disallowed_function_p): Don't assume + get_callee_fndecl must return non-NULL. + +2009-03-26 Vladimir Makarov <vmakarov@redhat.com> + + PR rtl-optimization/39522 + * reload1.c (reload_as_needed): Invalidate reg_last_reload_reg too + when reg_reloaded_valid is set. + +2009-03-26 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * config/spu/divv2df3.c: New file. + * config/spu/t-spu-elf (LIB2FUNCS_STATIC_EXTRA): Add it. + (DPBIT_FUNCS): Filter out _div_df. + +2009-03-26 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.c (bfin_optimize_loop): If the LSETUP goes before + a jump insn, count that jump in the distance to the loop start. + +2009-03-25 Kaz Kojima <kkojima@gcc.gnu.org> + + PR target/39523 + * config/sh/sh.c (calc_live_regs): Fix condition for global + registers except PIC_OFFSET_TABLE_REGNUM. + +2009-03-25 Kai Tietz <kai.tietz@onevision.com> + + PR/39518 + * doc/invoke.texi (-mconsole): New. + (-mcygwin): New. + (-mno-cygwin): New. + (-mdll): New. + (-mnop-fun-dllimport): New. + (-mthread): New. + (-mwin32): New. + (-mwindows): New. + (sub section "i386 and x86-64 Windows Options"): New. + +2009-03-25 Ralf Corsépius <ralf.corsepius@rtems.org> + + * config/arm/rtems-elf.h: Remove LINK_GCC_C_SEQUENCE_SPEC. + * config/rs6000/t-rtems: Remove MULTILIB_EXTRA_OPTS. + +2009-03-25 Richard Guenther <rguenther@suse.de> + + PR middle-end/39497 + * Makefile.in (dfp.o-warn): Use -fno-strict-aliasing instead + of -Wno-error. + +2009-03-25 Andrey Belevantsev <abel@ispras.ru> + + * config/ia64/ia64.c (ia64_set_sched_flags): Zero spec_info->mask when + neither of haifa/selective schedulers are working. + +2009-03-25 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/invoke.texi (Debugging Options): Fix description of + -fno-merge-debug-strings. + +2009-03-24 Hans-Peter Nilsson <hp@axis.com> + + * config/cris/libgcc.ver: New version-script. + * config/cris/t-linux (SHLIB_MAPFILES): Use it. + + * configure.ac <GAS features, nop mnemonic>: Add pattern + crisv32-*-* for "nop". + <GAS features, Thread-local storage>: Add item for CRIS and CRIS v32. + * configure: Regenerate. + +2009-03-24 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/39529 + * tree-vect-transform.c (vect_create_data_ref_ptr): Call + mark_sym_for_renaming for the tag copied to the new vector + pointer. + +2009-03-24 Arthur Loiret <aloiret@debian.org> + + * config.host (alpha*-*-linux*): Use driver-alpha.o and alpha/x-alpha. + * config/alpha/linux.h (host_detect_local_cpu): Declare, add to + EXTRA_SPEC_FUNCTIONS. + (MCPU_MTUNE_NATIVE_SPECS, DRIVER_SELF_SPECS): New macros. + * config/alpha/driver-alpha.c, config/alpha/x-alpha: New. + * doc/invoke.texi (DEC Alpha Options): Document 'native' value for + -march and -mtune options. + +2009-03-24 Ralf Corsépius <ralf.corsepius@rtems.org> + + * config/m68k/t-rtems: Add m5329 multilib. + +2009-03-24 Dodji Seketeli <dodji@redhat.com> + Jakub Jelinek <jakub@redhat.com> + + PR debug/39524 + * dwarf2out.c (gen_variable_die): Avoid adding duplicate declaration + nodes. + +2009-03-23 Jakub Jelinek <jakub@redhat.com> + + PR c/39495 + * c-parser.c (c_parser_omp_for_loop): Call c_parser_binary_expression + instead of c_parser_expression_conv, if original_code isn't one of the + 4 allowed comparison codes, fail. + +2009-03-23 Richard Guenther <rguenther@suse.de> + + * cgraph.h (struct cgraph_node): Reorder fields for 64-bit hosts. + * tree.h (struct tree_type): Likewise. + * reload.h (struct insn_chain): Likewise. + * dwarf2out.c (struct dw_loc_descr_struct): Likewise. + * function.h (struct function): Likewise. + * tree-ssa-structalias.c (struct equiv_class_label): Likewise. + +2009-03-23 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/39516 + * lambda-code.c (perfect_nestify): Fix type of the uboundvar variable. + +2009-03-23 Bingfeng Mei <bmei@broadcom.com> + + * config.gcc (need_64bit_hwint): Make clear that need_64bit_hwint + should be set true if BITS_PER_WORD of target is bigger than 32 + +2009-03-22 Hans-Peter Nilsson <hp@axis.com> + + * config/cris/linux.h (CRIS_LINK_SUBTARGET_SPEC): + Translate -B-options to -rpath-link. Correct existing + rpath-link and conditionalize on !nostdlib. + +2009-03-22 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * doc/extend.texi (Function Attributes, Variable Attributes): + Fix typos. + * doc/invoke.texi (Debugging Options, Optimize Options) + (i386 and x86-64 Options, MCore Options): Likewise. + +2009-03-20 Jakub Jelinek <jakub@redhat.com> + + PR debug/37890 + * dwarf2out.c (gen_namespace_die): Add context_die argument and use + it for block local namespace aliases. + (gen_decl_die): Pass context_die to gen_namespace_die. + +2009-03-19 Jakub Jelinek <jakub@redhat.com> + + PR c/39495 + * c-omp.c (c_finish_omp_for): Allow NE_EXPR with TREE_TYPE (decl)'s + minimum or maximum value. + +2009-03-19 Alexandre Oliva <aoliva@redhat.com> + + * reginfo.c (globalize_reg): Recompute derived reg sets. + +2009-03-19 Ozkan Sezer <sezeroz@gmail.com> + + PR target/39063 + * libgcc2.c (mprotect): Do not use signed arguments for + VirtualProtect, use DWORD arguments. Also fix the 'may + be used uninitialized' warning for the np variable. + +2009-03-19 Jakub Jelinek <jakub@redhat.com> + + PR target/39496 + * config/i386/i386.c (ix86_function_regparm): Don't optimize local + functions using regparm calling conventions when not optimizing. + (ix86_function_sseregparm): Similarly for sseregparm calling + conventions. + +2009-03-19 Li Feng <nemokingdom@gmail.com> + + PR middle-end/39500 + * tree-data-ref.c (analyze_subscript_affine_affine): There is no + dependence if the first conflict is after niter iterations. + +2009-03-19 Hans-Peter Nilsson <hp@axis.com> + + PR middle-end/38609 + * config/cris/cris.h (FRAME_POINTER_REQUIRED): Force for all + functions with dynamic stack-pointer adjustments. + +2009-03-19 Ben Elliston <bje@au.ibm.com> + + * doc/invoke.texi (RS/6000 and PowerPC Options): Fix -msdata-data + option; change to -msdata=data. + +2009-03-18 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * c.opt: Unify help texts for -Wdeprecated, -Wsystem-headers, + and -fopenmp. + +2009-03-18 Eric Botcazou <ebotcazou@adacore.com> + + PR target/35180 + * config/sparc/sparc.md (do_builtin_setjmp_setup): Prettify asm output. + +2009-03-18 Sandra Loosemore <sandra@codesourcery.com> + + * doc/invoke.texi (Code Gen Options): Expand discussion of + -fno-common. + +2009-03-18 Jakub Jelinek <jakub@redhat.com> + + * dse.c (struct group_info): Reorder fields for 64-bit hosts. + * matrix-reorg.c (struct matrix_info): Likewise. + * tree-ssa-loop-ivopts.c (struct ivopts_data): Likewise. + * rtl.h (struct mem_attrs): Likewise. + * df.h (struct df): Likewise. + * tree-data-ref.h (struct data_dependence_relation): Likewise. + * ira-int.h (struct ira_allocno): Likewise. + * df-scan.c (struct df_collection_rec): Likewise. + * ira.c (struct equivalence): Likewise. + * function.c (struct temp_slot): Likewise. + * cfgloop.h (struct loop): Likewise. + + PR debug/39485 + * function.c (use_register_for_decl): When not optimizing, disregard + register keyword for variables with types containing methods. + +2009-03-18 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/39447 + * graphite.c (exclude_component_ref): Renamed contains_component_ref_p. + (is_simple_operand): Call contains_component_ref_p before calling data + reference analysis that would fail on COMPONENT_REFs. + + * tree-vrp.c (search_for_addr_array): Fix formatting. + +2009-03-18 Richard Guenther <rguenther@suse.de> + + * tree-vect-transform.c (vect_loop_versioning): Fold the + generated comparisons. + * tree-vectorizer.c (set_prologue_iterations): Likewise. + (slpeel_tree_peel_loop_to_edge): Likewise. + +2009-03-17 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + PR middle-end/37805 + * opts.c (print_specific_help): In addition to `undocumented', + accept `separate' and `joined' flags if passed alone. Describe + output by the first matched one of those. + (common_handle_option): Skip over empty strings. + * gcc.c (display_help): Fix help string for `--help='. + * doc/invoke.texi (Option Summary, Overall Options): With + `--help=', classes and qualifiers can both be repeated, but + only the latter can be negated. One should not pass only + negated qualifiers. Fix markup and examples. + + Revert + 2008-10-14 Jakub Jelinek <jakub@redhat.com> + PR middle-end/37805 + * opts.c (common_handle_option): Don't ICE on -fhelp=joined + and -fhelp=separate. + +2009-03-17 Jing Yu <jingyu@google.com> + + PR middle-end/39378 + * function.h (struct rtl_data): Move is_thunk from here... + (struct function): ...to here. + * cp/method.c (use_thunk): Change is_thunk from crtl to cfun. + * varasm.c (assemble_start_function): Change is_thunk from crtl to + cfun. + * config/alpha/alpha.c (alpha_sa_mask): Change is_thunk from crtl to + cfun. + (alpha_does_function_need_gp, alpha_start_function): Likewise. + (alpha_output_function_end_prologue): Likewise. + (alpha_end_function, alpha_output_mi_thunk_osf): Likewise. + * config/rs6000/rs6000.c (rs6000_ra_ever_killed): Likewise. + (rs6000_output_function_epilogue): Likewise. + * config/arm/arm.h (ARM_DECLARE_FUNCTION_NAME): Likewise. + +2009-03-17 Uros Bizjak <ubizjak@gmail.com> + + PR target/39482 + * config/i386/i386.md (*truncdfsf_mixed): Avoid combining registers + from different units in a single alternative. + (*truncdfsf_i387): Ditto. + (*truncxfsf2_mixed): Ditto. + (*truncxfdf2_mixed): Ditto. + +2009-03-17 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (dwarf2out_imported_module_or_decl_1): Allow + non-NAMESPACE_DECL IMPORTED_DECL_ASSOCIATED_DECL. + + PR debug/39474 + * tree-ssa-live.c (remove_unused_locals): Don't remove local + unused non-artificial variables when not optimizing. + + PR debug/39471 + * dwarf2out.c (dwarf2out_imported_module_or_decl_1): Emit + DW_TAG_imported_module even if decl is IMPORTED_DECL with + NAMESPACE_DECL in its DECL_INITIAL. + + PR middle-end/39443 + * optabs.c (set_user_assembler_libfunc): New function. + * expr.h (set_user_assembler_libfunc): New prototype. + * c-common.c: Include libfuncs.h. + (set_builtin_user_assembler_name): Call set_user_assembler_libfunc + for memcmp, memset, memcpy, memmove and abort. + * Makefile.in (c-common.o): Depend on libfuncs.h. + + PR debug/39412 + * dwarf2out.c (gen_inlined_enumeration_type_die, + gen_inlined_structure_type_die, gen_inlined_union_type_die, + gen_tagged_type_instantiation_die): Removed. + (gen_decl_die): For TYPE_DECL_IS_STUB with non-NULL decl_origin + do nothing. + +2009-03-17 Janis Johnson <janis187@us.ibm.com> + + PR testsuite/38526 + * Makefile.in (site.exp): Rename TEST_GCC_EXEC_PREFIX and comment + its use. + (check-%): Don't set GCC_EXEC_PREFIX when invoking runtest. + (check-parallel-%): Ditto. + (check-consistency): Ditto. + +2009-03-17 Kai Tietz <kai.tietz@onevision.com> + + * ipa-struct-reorg.c (create_general_new_stmt): Initialize + local variable rhs by NULL_TREE. + +2009-03-17 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39477 + * doc/extend.texi: Correct register behavior for regparm on Intel 386. + +2009-03-17 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39476 + * config/i386/i386.c (ix86_function_regparm): Rewrite for 64bit. + +2009-03-17 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39473 + * config/i386/i386.c (ix86_expand_call): Check extra clobbers + for ms->sysv ABI calls only in 64bit mode. + + * config/i386/i386.md (untyped_call): Support 32bit. + +2009-03-16 H.J. Lu <hongjiu.lu@intel.com> + + * doc/extend.texi: Replace x86_65 with x86_64. + +2009-03-16 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/39455 + * tree-ssa-loop-niter.c (number_of_iterations_lt_to_ne): Fix types + mismatches for POINTER_TYPE_P (type). + (number_of_iterations_le): Likewise. + +2009-03-16 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.c: Removed profiling support. + * config/picochip/picochip.md: Removed profiling instruction. + * config/picochip/picochip.h: Removed profiling builtin. + +2009-03-16 Joseph Myers <joseph@codesourcery.com> + + * doc/install.texi (--with-host-libstdcxx): Document. + +2009-03-14 Anatoly Sokolov <aesok@post.ru> + + PR target/34299 + * config/avr/avr.c (avr_handle_fndecl_attribute): Move code for + generate a warning if the function name does not begin with + "__vector" and the function has either the 'signal' or 'interrupt' + attribute, from here to ... + (avr_declare_function_name): ...here. New function. + * config/avr/avr.h (ASM_DECLARE_FUNCTION_NAME): Redefine. + * config/avr/avr-protos.h (avr_declare_function_name): Declare. + +2009-03-14 Jakub Jelinek <jakub@redhat.com> + + PR bootstrap/39454 + * cse.c (fold_rtx): Don't modify original const_arg1 when + canonicalizing SHIFT_COUNT_TRUNCATED shift count, do it on a + separate variable instead. + * rtlanal.c (nonzero_bits1) <case ASHIFTRT>: Don't assume anything + from out of range shift counts. + (num_sign_bit_copies1) <case ASHIFTRT, case ASHIFT>: Similarly. + +2009-03-13 Catherine Moore <clm@codesourcery.com> + + * config/i386/x-mingw32 (host-mingw32.o): Replace + diagnostic.h with $(DIAGNOSTIC_H). + +2009-03-12 Jakub Jelinek <jakub@redhat.com> + + PR target/39431 + * config/i386/predicates.md (cmpxchg8b_pic_memory_operand): New + predicate. + * config/i386/sync.md (sync_compare_and_swap<mode>, + sync_compare_and_swap_cc<mode>): For DImode with -m32 -fpic check + if operands[1] is cmpxchg8b_pic_memory_operand, if not force address + into a register. + (sync_double_compare_and_swapdi_pic, + sync_double_compare_and_swap_ccdi_pic): Require operand 1 to be + cmpxchg8b_pic_memory_operand instead of just memory_operand. + +2009-03-12 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39445 + * config/i386/i386.c (ix86_expand_push): Don't set memory alignment. + +2009-03-12 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39327 + * config/i386/sse.md (avx_addsubv8sf3): Correct item bits. + (avx_addsubv4df3): Likewise. + (*avx_addsubv4sf3): Likewise. + (sse3_addsubv4sf3): Likewise. + +2009-03-12 H.J. Lu <hongjiu.lu@intel.com> + + PR target/38824 + * config/i386/i386.md: Compare REGNO on the new peephole2 patterns. + +2009-03-12 Vladimir Makarov <vmakarov@redhat.com> + + PR debug/39432 + * ira-int.h (struct allocno): Fix comment for calls_crossed_num. + * ira-conflicts.c (ira_build_conflicts): Prohibit call used + registers for allocnos created from user-defined variables. + +2009-03-11 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + PR target/39181 + * config/spu/spu.c (spu_expand_mov): Handle invalid subregs + of non-integer mode as well. + +2009-03-11 Adam Nemet <anemet@caviumnetworks.com> + + * gimplify.c (gimplify_call_expr): Don't set CALL_CANNOT_INLINE_P + for functions for which the parameter types are unknown. + +2009-03-11 Jakub Jelinek <jakub@redhat.com> + + PR target/39137 + * cfgexpand.c (get_decl_align_unit): Use LOCAL_DECL_ALIGNMENT macro. + * defaults.h (LOCAL_DECL_ALIGNMENT): Define if not yet defined. + * config/i386/i386.h (LOCAL_DECL_ALIGNMENT): Define. + * config/i386/i386.c (ix86_local_alignment): For + -m32 -mpreferred-stack-boundary=2 use 32-bit alignment for + long long variables on the stack to avoid dynamic realignment. + Allow the first argument to be a decl rather than type. + * doc/tm.texi (LOCAL_DECL_ALIGNMENT): Document. + +2009-03-11 Nick Clifton <nickc@redhat.com> + + PR target/5362 + * config/mcore/mcore.opt: Remove deprecated m4align and m8align + options. + Add description to mno-lsim option. + * config/mcore/mcore.h: Remove comment about deprecated m4align + option. + (TARGET_DEFAULT): Remove deprecated MASK_M8ALIGN. + * doc/invoke.texi: Add description of mno-lsim and + mstack-increment options. + + * config/fr30/fr30.opt: Document the -mno-lsim option. + * doc/invoke.texi: Add descriptions of the FR30's -msmall-model + and -mno-lsim options. + +2009-03-11 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * fold-const.c (fold_comparison): Only call fold_inf_compare + if the mode supports infinities. + +2009-03-11 Jason Merrill <jason@redhat.com> + + PR debug/39086 + * tree-nrv.c (tree_nrv): Don't do this optimization if the front + end already did. Notice GIMPLE_CALL modifications of the result. + Don't copy debug information from an ignored decl or a decl from + another function. + +2009-03-10 Richard Guenther <rguenther@suse.de> + Nathan Froyd <froydnj@codesourcery.com> + + PR middle-end/37850 + * libgcc2.c (__mulMODE3): Use explicit assignments to form the result. + (__divMODE3): Likewise. + +2009-03-09 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/39394 + * gimplify.c (gimplify_type_sizes): Gimplify DECL_SIZE and + DECL_SIZE_UNIT of variable length FIELD_DECLs. + +2009-03-09 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * recog.c (verfiy_changes): Disallow renaming of hard regs in + inline asms for register asm ("") declarations. + +2009-03-09 Eric Botcazou <ebotcazou@adacore.com> + + * fold-const.c (fold_unary): Fix comment. + +2009-03-07 Jan Hubicka <jh@suse.cz> + + PR target/39361 + * tree-inline.c (setup_one_parameter): Do replacement of const + argument by constant in SSA form. + +2009-03-07 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + PR middle-end/38028 + * function.c (assign_parm_setup_stack): Use STACK_SLOT_ALIGNMENT to + determine alignment passed to assign_stack_local. + (assign_parms_unsplit_complex): Likewise. + * except.c (sjlj_build_landing_pads): Likewise. + +2009-03-06 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/39360 + * tree-flow.h (add_referenced_var): Return bool instead of void. + * tree-dfa.c (add_referenced_var): Return result of + referenced_var_check_and_insert call. + * tree-inline.c (expand_call_inline): Call add_referenced_var instead + of referenced_var_check_and_insert. + + PR debug/39372 + * dwarf2out.c (add_abstract_origin_attribute): Return origin_die. + (gen_variable_die): Emit DW_AT_location on abstract static variable's + DIE, don't emit it if abstract origin already has it. + * tree-cfg.c (remove_useless_stmts_bind): GIMPLE_BINDs with any + BLOCK_NONLOCALIZED_VARS in its gimple_bind_block aren't useless. + +2009-03-06 Jan-Benedict Glaw <jbglaw@lug-owl.de> + + * genpreds.c (needs_variable): Fix parentheses at variable name + detection. + (write_tm_constrs_h): Indent generated code. + +2009-03-06 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> + + * doc/extend.texi (Function Attributes): Add documentation + for isr attributes. + +2009-03-06 Jakub Jelinek <jakub@redhat.com> + + PR debug/39387 + * dwarf2out.c (dwarf2out_imported_module_or_decl_1): For IMPORTED_DECL + take locus from its DECL_SOURCE_LOCATION instead of input_location. + +2009-03-05 Bernd Schmidt <bernd.schmidt@analog.com> + + * config/bfin/bfin.c (bfin_discover_loop): When retrying fails, mark + the loop as bad. + +2009-03-05 Jakub Jelinek <jakub@redhat.com> + + PR debug/39379 + * tree-cfg.c (remove_useless_stmts_bind): Don't remove GIMPLE_BINDs + with blocks containing IMPORTED_DECLs in BLOCK_VARS. + +2009-03-05 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (R8_REG, R9_REG): New constants. + * config/i386/i386.h (CONDITIONAL_REGISTER_USAGE): Use named + constants instead of magic numbers. + (HARD_REGNO_CALLER_SAVE_MODE): Ditto. + (QI_REG_P): Ditto. + * config/i386/i386.c (x86_64_int_parameter_registers): Ditto. + (x86_64_ms_abi_int_parameter_registers): Ditto. + (x86_64_int_return_registers): Ditto. + (ix86_maybe_switch_abi): Ditto. + (ix86_expand_call): Ditto for clobbered_registers array. + (ix86_hard_regno_mode_ok): Ditto. + (x86_extended_QIreg_mentioned_p): Ditto. + +2009-03-05 J"orn Rennecke <joern.rennecke@arc.com> + + PR tree-optimization/39349 + * cse.c (cse_insn): Fix loop to stop at VOIDmode. + + * combine.c (gen_lowpart_for_combine): Use omode when generating + clobber. + +2009-03-04 J"orn Rennecke <joern.rennecke@arc.com> + + PR rtl-optimization/39235 + * loop-iv.c (get_simple_loop_desc): Use XCNEW. + +2009-03-04 Zdenek Dvorak <ook@ucw.cz> + + * graphite.c (nb_reductions_in_loop): Update simple_iv arguments. + +2009-03-04 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39362 + * tree-ssa-sccvn.c (visit_use): Stores and copies from SSA_NAMEs + that occur in abnormal PHIs should be varying. + +2009-03-04 Zdenek Dvorak <ook@ucw.cz> + + * tree-scalar-evolution.c (analyze_scalar_evolution_in_loop): + Extend comments. + (simple_iv): Take loop as an argument instead of statement. + * tree-scalar-evolution.h (simple_iv): Declaration changed. + * tree-ssa-loop-niter.c (number_of_iterations_exit): Update calls + to simple_iv. + * tree-ssa-loop-ivopts.c (determine_biv_step, find_givs_in_stmt_scev): + Ditto. + * tree-parloops.c (loop_parallel_p, canonicalize_loop_ivs): Ditto. + * matrix-reorg.c (analyze_transpose): Ditto. + * tree-data-ref.c (dr_analyze_innermost): Ditto. + * tree-vect-analyze.c (vect_analyze_data_refs): Ditto. + * tree-predcom.c (ref_at_iteration): Ditto. + * tree-ssa-loop-prefetch.c (idx_analyze_ref): Ditto. + +2009-03-04 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39358 + * tree-ssa-structalias.c (do_sd_constraint): Fix check for + escaped_id and callused_id. + (solve_graph): Likewise. + +2009-03-04 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39339 + * tree-sra.c (try_instantiate_multiple_fields): Make it + no longer ICE on the above. + +2009-03-03 Joseph Myers <joseph@codesourcery.com> + + * emit-rtl.c (adjust_address_1): Reduce offset to a signed value + that fits within Pmode. + +2009-03-03 Steve Ellcey <sje@cup.hp.com> + + PR middle-end/10109 + * tm.texi (LIBCALL_VALUE): Update description. + +2009-03-03 Steve Ellcey <sje@cup.hp.com> + + PR middle-end/34443 + * doc/extend.texi (section): Update description. + +2009-03-03 H.J. Lu <hongjiu.lu@intel.com> + + PR middle-end/39345 + * tree-inline.c (remapped_type): New. + (can_be_nonlocal): Call remapped_type instead of remap_type. + +2009-03-03 Jakub Jelinek <jakub@redhat.com> + + PR fortran/39354 + * gimplify.c (goa_stabilize_expr): Handle tcc_comparison, + TRUTH_ANDIF_EXPR and TRUTH_ORIF_EXPR. + +2009-03-03 Richard Guenther <rguenther@suse.de> + + PR middle-end/39272 + * tree.c (tree_nonartificial_location): New function. + * tree.h (tree_nonartificial_location): Declare. + * builtins.c (expand_builtin_memory_chk): Provide location + of the call location for artificial function pieces. + (maybe_emit_chk_warning): Likewise. + (maybe_emit_sprintf_chk_warning): Likewise. + (maybe_emit_free_warning): Likewise. + * expr.c (expand_expr_real_1): Likewise. + +2009-03-03 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/39343 + * tree-ssa-ccp.c (maybe_fold_offset_to_address): Don't check if + COMPONENT_REF t has ARRAY_TYPE. + +2009-03-02 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/39335 + * tree-parloops.c (canonicalize_loop_ivs): Call fold_convert + when the type precision of the induction variable should be + larger than the type precision of nit. + (gen_parallel_loop): Update use of canonicalize_loop_ivs. + * graphite.c (graphite_loop_normal_form): Same. + * tree-flow.h (canonicalize_loop_ivs): Update declaration. + +2009-03-02 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.md (ST?_REG, MM?_REG): New constants. + (*call_1_rex64_ms_sysv): Use named constants instead of magic + numbers to describe clobbered registers. + (*call_value_0_rex64_ms_sysv): Ditto. + * config/i386/mmx.md (mmx_emms): Ditto. + (mmx_femms): Ditto. + +2009-03-02 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.c (mips_mdebug_abi_name): Fix the handling + of ABI_64. + +2009-03-02 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * config/spu/spu.c (TARGET_SECTION_TYPE_FLAGS): Define. + (spu_section_type_flags): New function. + +2009-03-02 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.h (CONDITIONAL_REGISTER_USAGE): Do not copy + reg_class_contents of FLOAT_REGS into a temporary. + +2009-03-02 Richard Guenther <rguenther@suse.de> + Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/39318 + * tree-vect-transform.c (vectorizable_call): Transfer the EH region + information to the vectorized statement. + +2009-03-01 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.h (CONDITIONAL_REGISTER_USAGE): Do not shadow "i" + variable. Use defined names instead of magic constants for REX SSE + registers. + +2009-03-01 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39331 + * omp-low.c (lower_send_shared_vars): Do not receive new + values for the reference of DECL_BY_REFERENCE parms or results. + +2009-03-01 Jan Hubicka <jh@suse.cz> + + PR debug/39267 + * tree.h (BLOCK_NONLOCALIZED_VARS, BLOCK_NUM_NONLOCALIZED_VARS, + BLOCK_NONLOCALIZED_VAR): New macros. + (tree_block): Add nonlocalized_vars. + * dwarf2out.c (gen_formal_parameter_die, gen_variable_die, + gen_decl_die): Add origin argument. Allow generation of die with + origin at hand only. + (gen_member_die, gen_type_die_with_usage, force_decl_die, + declare_in_namespace, gen_namescpace_die, dwarf2out_decl): Update use + of gen_*. + (gen_block_die): Fix checking for unused blocks. + (process_scope_var): Break out from .... ; work with origins only. + (decls_for_scope) ... here; process nonlocalized list. + (dwarf2out_ignore_block): Look for nonlocalized vars. + * tree-ssa-live.c (remove_unused_scope_block_p): Look for nonlocalized + vars. + (dump_scope_block): Dump them. + * tree-inline.c (remap_decls): Handle nonlocalized vars. + (remap_block): Likewise. + (can_be_nonlocal): New predicate. + (copy_bind_expr, copy_gimple_bind): Update use of remap_block. + +2009-03-01 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * configure: Regenerate. + +2009-03-01 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> + + * optc-gen.awk: No need to duplicate option flags twice. + Reuse help texts for duplicate options which do not have any. + + * gcc.c (display_help): Document --version. + + * gcc.c (main): If print_help_list and verbose_flag, ensure + driver output comes before subprocess output. + + * optc-gen.awk: Assign all remaining fields to help string, + space-separated, for multi-line help in *.opt. + + * doc/invoke.texi (Warning Options): -Wsync-nand is C/C++ only. + -Wno-pedantic-ms-format is for MinGW targets only. + + * doc/options.texi (Option file format): Fix bad indentation, + restoring dropped sentence. + +2009-02-28 Jan Hubicka <jh@suse.cz> + + * tree-inline.c (tree_function_versioning): Output debug info. + +2009-02-28 Jan Hubicka <jh@suse.cz> + + PR debug/39267 + * tree-inline.c (setup_one_parameter): Do not copy propagate + arguments when not optimizing. + +2009-02-28 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39327 + * config/i386/sse.md (avx_addsubv8sf3): Correct item bits. + (avx_addsubv4df3): Likewise. + (*avx_addsubv4sf3): Likewise. + (sse3_addsubv4sf3): Likewise. + (*avx_addsubv2df3): Likewise. + (sse3_addsubv2df3): Likewise. + (avx_unpckhps256): Correct item selectors. + (avx_unpcklps256): Likewise. + (avx_unpckhpd256): Likewise. + (avx_unpcklpd256): Likewise. + +2009-02-28 Jan Hubicka <jh@suse.cz> + + * tree-inline.c (expand_call_inline): Avoid duplicate declarations of + static vars. + (copy_arguments_for_versioning): If var is declared don't declare it. + (tree_function_versioning): First setup substitutions and then copy + args. + +2009-02-27 Jan Hubicka <jh@suse.cz> + + PR debug/39267 + * cgraph.h (varpool_output_debug_info): Remove. + * cgraphunit.c (varpool_output_debug_info): Remove. + * dwarf2out.c (deferred_locations_struct): New struct + (deferred_locations): New type. + (deferred_locations_list): New static var. + (deffer_location): New function. + (gen_variable_die): Use it. + (decls_for_scope): Output info on local static vars. + (dwarf2out_finish): Process deferred locations. + * varpool.c (varpool_output_debug_info): Remove. + +2009-02-27 Jan Hubicka <jh@suse.cz> + + PR debug/39267 + * tree.h (TREE_PROTECTED): Fix comment. + (BLOCK_HANDLER_BLOCK): Remove. + (struct tree_block): Remove handler_block add body_block. + (inlined_function_outer_scope_p): New. + (is_body_block): Remove. + * dbxout.c (dbxout_block): Remove BLOCK_HANDLER_BLOCK. + * dwarf2out.c (is_inlined_entry_point): Remove. + (add_high_low_attributes): Use inlined_function_outer_scope_p. + (gen_block_die): Use is_inlined_entry_point check. Remove body block + code. + * langhooks.h (struct lang_hooks): Remove no_bodu_blocks. + * gimplify.c (gimplify_expr): Gimplify body blocks. + * tree-ssa-live.c (remove_unused_scope_block_p): Allow removing wrapper + block with multiple subblocks. + (dump_scope_block): Prettier output; dump more flags and info. + (dump_scope_blocks): New. + (remove_unused_locals): Use dump_scope_blocks. + * tree-flow.h (dump_scope_blocks): Declare. + * tree-cfg.c (execute_build_cfg): Dump scope blocks. + * stmt.c (is_body_block): Remove. + * tree-inline.c (remap_block): Copy BODY_BLOCK info. + * langhooks-def.h (LANG_HOOKS_NO_BODY_BLOCKS): Remove. + +2009-02-27 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/39308 + * graphite.c (graphite_loop_normal_form): Do not call + number_of_iterations_exit from a gcc_assert. + +2009-02-27 Andreas Krebbel <Andreas.Krebbel@de.ibm.com> + + * config/s390/s390.c (s390_swap_cmp): Look for conditional + jumps if COND is NULL. + (find_cond_jump): New function. + (s390_z10_optimize_cmp): Handling for reg-reg compares added. + * config/s390/s390.md: Remove z10_cobra attribute value. + +2009-02-26 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.h (alpha_expand_mov): Return false if + force_const_mem returns NULL_RTX. + +2009-02-26 Jan Hubicka <jh@suse.cz> + + PR debug/39267 + * cgraph.h (varpool_output_debug_info): Remove. + * cgraphunit.c (varpool_output_debug_info): Remove. + * dwarf2out.c (deferred_locations_struct): New struct + (deferred_locations): New type. + (deferred_locations_list): New static var. + (deffer_location): New function. + (gen_variable_die): Use it. + (decls_for_scope): Output info on local static vars. + (dwarf2out_finish): Process deferred locations. + * varpool.c (varpool_output_debug_info): Remove. + +2009-02-25 H.J. Lu <hongjiu.lu@intel.com> + + PR rtl-optimization/39241 + * jump.c (rtx_renumbered_equal_p): Remove 2 superfluous calls + to subreg_offset_representable_p. + +2009-02-25 Paolo Bonzini <bonzini@gnu.org> + + * regmove.c (regmove_optimize): Conform to struct rtl_opt_pass + execute function prototype. Get f and nregs from max_reg_num + and get_insns. Remove the first backward pass as it's dead, + guard the forward pass by flag_expensive_optimizations. + (rest_of_handle_regmove): Delete. + (pass_regmove): Replace it with regmove_optimize. + +2009-02-25 Martin Jambor <mjambor@suse.cz> + + PR tree-optimization/39259 + * tree-inline.c (initialize_cfun): Remove asserts for calls_setjmp and + calls_alloca function flags. + (copy_bb): Set calls_setjmp and alls_alloca function flags if such + calls are detected. + +2009-02-25 Paolo Bonzini <bonzini@gnu.org> + + * regmove.c (discover_flags_reg, flags_set_1, mark_flags_life_zones, + flags_set_1_rtx, flags_set_1_set): Delete. + (regmove_optimize): Do not call mark_flags_life_zones. + +2009-02-24 Julian Brown <julian@codesourcery.com> + + PR target/35965 + * config/arm/arm.c (require_pic_register): Only set + cfun->machine->pic_reg once per function. + +2009-02-24 Sandra Loosemore <sandra@codesourcery.com> + + * doc/invoke.texi (Link Options): Document an easier way to pass + options that take arguments to the GNU linker using -Xlinker and -Wl. + +2009-02-24 Steve Ellcey <sje@cup.hp.com> + + PR target/33785 + * doc/tm.texi (TARGET_C99_FUNCTIONS): Fix description. + +2009-02-24 Richard Guenther <rguenther@suse.de> + + PR debug/39285 + * dwarf2out.c (gen_enumeration_type_die): Handle CONST_DECLs. + +2009-02-24 Richard Guenther <rguenther@suse.de> + Zdenek Dvorak <ook@ucw.cz> + + PR tree-optimization/39233 + * tree-ssa-loop-ivopts.c (add_candidate_1): Do not except pointers + from converting them to a generic type. + +2009-02-23 Sebastian Pop <sebastian.pop@amd.com> + + PR tree-optimization/39260 + * graphite.c (harmful_stmt_in_bb): Stop a SCoP when the basic block + contains a condition with a real type. + (build_scop_conditions_1): Conditions are always last_stmt of a bb. + +2009-02-23 Jason Merrill <jason@redhat.com> + + PR c++/38880 + * varasm.c (initializer_constant_valid_p) [PLUS_EXPR]: Check + narrowing_initializer_constant_valid_p. + (narrowing_initializer_constant_valid_p): Don't return + null_pointer_node for adding a pointer to itself. + +2009-02-23 Jan Hubicka <jh@suse.cz> + + PR c/12245 + * ggc.h (htab_create_ggc): Use ggc_free to free hashtable when + resizing. + +2009-02-23 Jan Hubicka <jh@suse.cz> + + PR tree-optimization/37709 + * tree.c (block_ultimate_origin): Move here from dwarf2out. + * tree.h (block_ultimate_origin): Declare. + * dwarf2out.c (block_ultimate_origin): Move to tree.c + * tree-ssa-live.c (remove_unused_scope_block_p): + Eliminate blocks containig no instructions nor live variables nor + nested blocks. + (dump_scope_block): New function. + (remove_unused_locals): Enable removal of dead blocks by default; + enable dumping at TDF_DETAILS. + +2009-02-21 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (classify_argument): Don't allow COImode + and OImode. + (function_arg_advance_32): Don't allow OImode. + (function_arg_32): Likewise. + (function_value_32): Likewise. + (return_in_memory_32): Likewise. + (function_arg_64): Remove OImode comment. + +2009-02-21 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39261 + * config/i386/i386.c (ix86_expand_vector_init_one_nonzero): Use + ix86_expand_vector_set for V4DImode in 64bit mode only. + (ix86_expand_vector_init_one_var): Likewise. + +2009-02-21 Sebastian Pop <sebastian.pop@amd.com> + + * graphite.c (graphite_trans_loop_block): Adjust tile size to 51. + +2009-02-21 Richard Sandiford <rdsandiford@googlemail.com> + + PR bootstrap/39257 + * loop-iv.c: Revert last change. + * emit-rtl.c: Likewise. + +2009-02-21 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39256 + * config/i386/i386.c (type_natural_mode): Remove an extra + space in the warning message. + (function_value_32): Handle 32-byte vector modes. + (return_in_memory_32): Likewise. + +2009-02-21 Richard Sandiford <rdsandiford@googlemail.com> + + * loop-iv.c (truncate_value): New function. + (iv_subreg, get_iv_value, iv_number_of_iterations): Use it instead + of lowpart_subreg. + (lowpart_subreg): Move to... + * emit-rtl.c: ...here. + +2009-02-21 Danny Smith <dannysmith@users.sourceforge.net> + + * config/i386/winnt.c (i386_pe_asm_output_aligned_decl_common): Revert + accidental and undocumented change at revision 140860. + +2009-02-21 Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (arm_gimplify_va_arg_expr): Update prototype to + take gimple_seq * arguments. + (arm_mangle_type): Use CONST_CAST_TREE on type argument passed to + types_compatible_p langhook. + +2009-02-20 Mark Mitchell <mark@codesourcery.com> + Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (arm_builtin_va_list): New function. + (arm_expand_builtin_va_start): Likewise. + (arm_gimplify_va_arg_expr): Likewise. + (TARGET_BUILD_BUILTIN_VA_LIST): Define. + (TARGET_BUILD_BUILTIN_VA_START): Likewise. + (TARGET_BUILD_BUILTIN_VA_ARG_EXPR): Likewise. + (va_list_type): New variable. + (arm_mangle_type): Mangle va_list_type appropriately. + +2009-02-20 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/39157 + * Makefile.in (loop-invariant.o): Depend on $(PARAMS_H). + * params.h (LOOP_INVARIANT_MAX_BBS_IN_LOOP): Define. + * params.def (loop-invariant-max-bbs-in-loop): New parameter. + * opts.c (decode_options): Set loop-invariant-max-bbs-in-loop + parameter to 1000 for -O1 by default. + * doc/invoke.texi (loop-invariant-max-bbs-in-loop): Document new + parameter. + * loop-invariant.c: Include params.h. + (move_loop_invariants): Don't call move_single_loop_invariants on + very large loops. + +2009-02-20 Jaka Mocnik <jaka@xlab.si> + + * calls.c (emit_library_call_value_1): Use slot_offset instead of + offset when calculating bounds for indexing stack_usage_map. Fixes + a buffer overflow with certain target setups. + +2009-02-20 Jakub Jelinek <jakub@redhat.com> + + PR target/39240 + * calls.c (expand_call): Clear try_tail_call if caller and callee + disagree in promotion of function return value. + +2009-02-19 Jakub Jelinek <jakub@redhat.com> + + PR target/39175 + * c-common.c (c_determine_visibility): If visibility changed and + DECL_RTL has been already set, call make_decl_rtl to update symbol + flags. + +2009-02-19 H.J. Lu <hongjiu.lu@intel.com> + + PR c++/39188 + * varasm.c (assemble_variable): Don't check DECL_NAME when + globalizing a variable. + +2009-02-19 Joseph Myers <joseph@codesourcery.com> + + PR c/38483 + * builtins.c (gimplify_va_arg_expr): Evaluate the va_list + expression before any __builtin_trap call. + * c-typeck.c (build_function_call): Convert and check function + arguments before generating a call to a trap. Evaluate the + function arguments before the trap. + +2009-02-19 Uros Bizjak <ubizjak@gmail.com> + + PR target/39228 + * config/i386/i386.md (isinfxf2): Split from isinf<mode>2. + (UNSPEC_FXAM_MEM): New unspec. + (fxam<mode>2_i387_with_temp): New insn and split pattern. + (isinf<mode>2): Use MODEF mode iterator. Force operand[1] through + memory using fxam<mode>2_i387_with_temp to remove excess precision. + +2009-02-19 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39207 + PR tree-optimization/39074 + * tree-ssa-structalias.c (storedanything_id, var_storedanything, + storedanything_tree): New. + (do_ds_constraint): Simplify ANYTHING shortcutting. Update + the STOREDANYTHING solution if the lhs solution contains ANYTHING. + (build_succ_graph): Add edges from STOREDANYTHING to all + non-direct nodes. + (init_base_vars): Initialize STOREDANYTHING. + (compute_points_to_sets): Free substitution info after + building the succ graph. + (ipa_pta_execute): Likewise. + + * tree-ssa-structalias.c (struct variable_info): Add may_have_pointers + field. + (do_ds_constraint): Do not add to special var or non-pointer + field solutions. + (type_could_have_pointers): Split out from ... + (could_have_pointers): ... here. For arrays use the element type. + (create_variable_info_for): Initialize may_have_pointers. + (new_var_info): Likewise. + (handle_lhs_call): Make the HEAP variable unknown-sized. + (intra_create_variable_infos): Use a type with pointers for + PARM_NOALIAS, make it unknown-sized. + +2009-02-18 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39224 + * config/i386/i386.c (ix86_return_in_memory): Properly check ABI. + +2009-02-18 Jason Merrill <jason@redhat.com> + + PR target/39179 + * tree-ssa-ccp.c (get_symbol_constant_value): Don't assume zero + value if DECL_EXTERNAL. + * tree-sra.c (sra_walk_gimple_assign): Likewise. + * target.h (gcc_target::binds_local_p): Clarify "module". + * tree.h (TREE_PUBLIC): Clarify "module". + +2009-02-17 Xuepeng Guo <xuepeng.guo@intel.com> + + PR target/38891 + * config/i386/i386.h (CONDITIONAL_REGISTER_USAGE): Move the hunk of + initialization for MS_ABI prior to the hunk of !TARGET_MMX. + +2009-02-17 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39082 + * c.opt (Wabi): Support C and ObjC. + (Wpsabi): New. + + * c-opts.c (c_common_handle_option): Handle OPT_Wabi. + + * config/i386/i386.c (classify_argument): Warn once about the ABI + change when passing union with long double. + + * doc/invoke.texi: Update -Wabi for warning psABI changes. + +2009-02-18 Joseph Myers <joseph@codesourcery.com> + + PR c/35447 + * c-parser.c (c_parser_compound_statement): Always enter and leave + a scope. + +2009-02-17 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + PR target/34587 + * config/darwin.h (SUPPORTS_INIT_PRIORITY): Define. + +2009-02-18 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/36922 + * tree-data-ref.c (initialize_matrix_A): Handle BIT_NOT_EXPR. + * tree-scalar-evolution.c (interpret_rhs_expr, instantiate_scev_1): + Likewise. + +2009-02-17 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.c (mips_override_options): Set flag_dwarf2_cfi_asm + to 0 for EABI64. + +2009-02-17 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.md (type): Reclassify lui_movf as "unknown". + +2009-02-17 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.c (mips_gimplify_va_arg_expr): Fix invalid + tree sharing. + +2009-02-17 Ruan Beihong <ruanbeihong@gmail.com> + Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.c (CODE_FOR_loongson_biadd): Delete. + * config/mips/loongson.md (reduc_uplus_<mode>): Rename to... + (loongson_biadd): ...this. + +2009-02-17 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39202 + * tree-ssa-structalias.c (do_structure_copy): Before collapsing + a var make sure to follow existing collapses. + +2009-02-17 Richard Guenther <rguenther@suse.de> + + PR middle-end/39214 + * langhooks.c (lhd_print_error_function): Check for NULL block. + +2009-02-17 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39204 + * tree-ssa-pre.c (phi_translate_1): Lookup the value-number + of the PHI arg. + +2009-02-17 Uros Bizjak <ubizjak@gmail.com> + + * config/soft-fp/double.h: Update from glibc CVS. + +2009-02-17 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39207 + * tree-ssa-structalias.c (find_what_p_points_to): Do not emit + strict-aliasing warnings for pointers pointing to NULL. + +2009-02-16 Joseph Myers <joseph@codesourcery.com> + + PR c/35446 + * c-parser.c (c_parser_braced_init): Call pop_init_level when + skipping until next close brace. + +2009-02-16 H.J. Lu <hongjiu.lu@intel.com> + + PR target/37049 + * config/i386/i386.c (ix86_expand_push): Set memory alignment + to function argument boundary. + +2009-02-16 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.md (lea_add): Allow any nonimmediate + in the lea_add. Reload eventually constraints it properly. + * config/picochip/constraints.md: Remove the target constraint + "b", since it is not needed anymore. + +2009-02-16 Jakub Jelinek <jakub@redhat.com> + + * gthr-dce.h: Uglify function parameter and local variable names. + * gthr-gnat.h: Likewise. + * gthr-mipssde.h: Likewise. + * gthr-nks.h: Likewise. + * gthr-posix95.h: Likewise. + * gthr-posix.h: Likewise. + * gthr-rtems.h: Likewise. + * gthr-single.h: Likewise. + * gthr-solaris.h: Likewise. + * gthr-tpf.h: Likewise. + * gthr-vxworks.h: Likewise. + * gthr-win32.h: Likewise. + +2009-02-15 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39196 + * config/i386/i386.md: Restrict the new peephole2 to move + between MMX/SSE registers. + +2009-02-15 Richard Guenther <rguenther@suse.de> + + Revert + 2009-02-13 Richard Guenther <rguenther@suse.de> + + * configure.ac: Enable LFS. + * configure: Re-generate. + * config.in: Likewise. + +2009-02-13 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * config/spu/spu_internals.h (spu_sr, spu_sra, spu_srqw, + spu_srqwbyte, spu_srqwbytebc): Define. + * config/spu/spu-builtins.def (spu_sr, spu_sra, spu_srqw, + spu_srqwbyte, spu_srqwbytebc): New overloaded builtins. + * config/spu/spu.md ("shrqbybi_<mode>", "shrqbi_<mode>", + "shrqby_<mode>"): New insn-and-split patterns. + * config/spu/spu.c (expand_builtin_args): Determine and return + number of operands using spu_builtin_description data. + (spu_expand_builtin_1): Use it. + +2009-02-13 Steve Ellcey <sje@cup.hp.com> + + PR target/38056 + * config/ia64/ia64.c (ia64_function_ok_for_sibcall): Check + TARGET_CONST_GP. + +2009-02-13 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39149 + * config/i386/i386.c (override_options): Correct warning + messages for -malign-loops, -malign-jumps and -malign-functions. + +2009-02-13 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39152 + * config/i386/i386.md: Restrict the new peephole2 to move + between the general purpose registers. + +2009-02-13 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39162 + * config/i386/i386.c (type_natural_mode): Add a new argument. + Return the original mode and warn ABI change if vector size is 32byte. + (function_arg_advance): Updated. + (function_arg): Likewise. + (ix86_function_value): Likewise. + (ix86_return_in_memory): Likewise. + (ix86_sol10_return_in_memory): Likewise. + (ix86_gimplify_va_arg): Likewise. + (function_arg_32): Don't warn ABX ABI change here. + (function_arg_64): Likewise. + +2009-02-13 Bernd Schmidt <bernd.schmidt@analog.com> + + * loop-iv.c (implies_p): In the final case, test that operands 0 + of the two comparisons match. + + * config/bfin/bfin.c (find_prev_insn_start): New function. + (bfin_optimize_loop): Use it in some cases instead of PREV_INSN. + (find_next_insn_start): Move. + +2009-02-13 Richard Guenther <rguenther@suse.de> + + * configure.ac: Enable LFS. + * configure: Re-generate. + * config.in: Likewise. + +2009-02-13 Joseph Myers <joseph@codesourcery.com> + + PR c/35444 + * c-parser.c (c_parser_parms_list_declarator): Discard pending + sizes on syntax error after some arguments have been parsed. + +2009-02-12 Jakub Jelinek <jakub@redhat.com> + + * doc/invoke.texi (-fira): Remove. + +2009-02-12 H.J. Lu <hongjiu.lu@intel.com> + + * caller-save.c: Replace regclass.c with reginfo.c in comments. + * recog.c: Likewise. + * rtl.h: Likewise. + +2009-02-12 Uros Bizjak <ubizjak@gmail.com> + + * longlong.h (sub_ddmmss): New for ia64. Ported from GMP 4.2. + (umul_ppmm): Likewise. + (count_leading_zeros): Likewise. + (count_trailing_zeros): Likewise. + (UMUL_TIME): Likewise. + +2009-02-12 H.J. Lu <hongjiu.lu@intel.com> + + * config.gcc (ia64*-*-linux*): Add ia64/t-fprules-softfp and + soft-fp/t-softfp to tmake_file. + + * config/ia64/ia64.c (ia64_soft_fp_init_libfuncs): New. + (ia64_expand_compare): Use HPUX library for TFmode only for HPUX. + (ia64_builtins) [IA64_BUILTIN_COPYSIGNQ, IA64_BUILTIN_FABSQ, + IA64_BUILTIN_INFQ]: New. + (ia64_init_builtins): Initialize __builtin_infq, + __builtin_fabsq and __builtin_copysignq if not HPUX. + (ia64_expand_builtin): Handle IA64_BUILTIN_COPYSIGNQ, + IA64_BUILTIN_FABSQ and IA64_BUILTIN_INFQ. + + * config/ia64/lib1funcs.asm (__divtf3): Define only if + SHARED is defined. + (__fixtfti): Likewise. + (__fixunstfti): Likewise. + (__floattitf): Likewise. + + * config/ia64/libgcc-glibc.ver: New. + * config/ia64/t-fprules-softfp: Likewise. + * config/ia64/sfp-machine.h: Likewise. + + * config/ia64/linux.h (LIBGCC2_HAS_TF_MODE): New. + (LIBGCC2_TF_CEXT): Likewise. + (TF_SIZE): Likewise. + (TARGET_INIT_LIBFUNCS): Likewise. + + * config/ia64/t-glibc (SHLINB_MAPFILES): + Add $(srcdir)/config/ia64/libgcc-glibc.ver. + +2009-02-12 H.J. Lu <hongjiu.lu@intel.com> + + * config/i386/i386.c (construct_container): Rewrite processing + BLKmode with X86_64_SSE_CLASS. + +2009-02-12 Paolo Bonzini <bonzini@gnu.org> + + PR target/39152 + * config/i386/i386.md: Replace simplify_replace_rtx with + replace_rtx in the new peephole2. + +2009-02-12 Nathan Sidwell <nathan@codesourcery.com> + + * doc/invoke.texi (Optimize Options): Stop claiming inlining and + loop unrolling do not happen at -O2. + +2009-02-12 Michael Matz <matz@suse.de> + + * gcc.c (ASM_DEBUG_SPEC): Check for -g0. + +2009-02-12 Jakub Jelinek <jakub@redhat.com> + + * dwarf2out.c (dwarf2out_finish): Force output of comp_unit_die + for -g3. + +2009-02-12 Ben Elliston <bje@au.ibm.com> + + * config/rs6000/rs6000.md (allocate_stack): Use _stack form of + patterns when updating the back chain. Missed in the 2009-02-10 + change. + +2009-02-11 Janis Johnson <janis187@us.ibm.com> + + * doc/extend.texi (Decimal Floating Types): Update identifier of + draft TR and list of missing support. + +2009-02-11 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/39154 + * gimplify.c (omp_notice_variable): If adding GOVD_SEEN + bit to variable length decl's flags, add it also to its + pointer replacement variable. + +2009-02-11 Uros Bizjak <ubizjak@gmail.com> + Jakub Jelinek <jakub@redhat.com> + + PR target/39118 + * config/i386/i386.md (UNSPEC_MEMORY_BLOCKAGE): New constant. + (memory_blockage): New expander. + (*memory_blockage): New insn pattern. + * config/i386/i386.c (ix86_expand_prologue): Use memory_blockage + instead of general blockage at the end of function prologue when + frame pointer is used to access red zone area. Do not emit blockage + when profiling, it is emitted in generic code. + (ix86_expand_epilogue): Emit memory_blockage at the beginning of + function epilogue when frame pointer is used to access red zone area. + +2009-02-11 Paolo Bonzini <bonzini@gnu.org> + + PR target/38824 + * config/i386/i386.md: Add two new peephole2 to avoid mov followed + by arithmetic with memory operands. + * config/i386/predicates.md (commutative_operator): New. + +2009-02-10 Janis Johnson <janis187@us.ibm.com> + + * doc/extend.texi (Fixed-Point Types): Break long paragraphs into + bulleted lists. + +2009-02-10 Eric Botcazou <ebotcazou@adacore.com> + + * alias.h (record_alias_subset): Declare. + * alias.c (record_alias_subset): Make global. + +2009-02-10 Nick Clifton <nickc@redhat.com> + + * tree-parloops.c: Change license to GPLv3. + * ipa-struct-reorg.c: Change license to GPLv3. + * ipa-struct-reorg.h: Change license to GPLv3. + +2009-02-10 Steve Ellcey <sje@cup.hp.com> + + PR c/39084 + * c-decl.c (start_struct): Return NULL on error. + +2009-02-10 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/39124 + * cfgloopmanip.c (remove_path): Call remove_bbs after + cancel_loop_tree, not before it. + + PR target/39139 + * function.h (struct function): Add has_local_explicit_reg_vars bit. + * gimplify.c (gimplify_bind_expr): Set it if local DECL_HARD_REGISTER + VAR_DECLs were seen. + * tree-ssa-live.c (remove_unused_locals): Recompute + cfun->has_local_explicit_reg_vars. + * tree-ssa-sink.c (statement_sink_location): Don't sink BLKmode + copies or clearings if cfun->has_local_explicit_reg_vars. + +2009-02-10 Uros Bizjak <ubizjak@gmail.com> + + PR target/39118 + * config/i386/i386.c (expand_prologue): Emit blockage at the end + of function prologue when frame pointer is used to access + red zone area. + +2009-02-10 Richard Guenther <rguenther@suse.de> + + PR middle-end/39127 + * gimplify.c (gimple_regimplify_operands): Always look if + we need to create a temporary. + +2009-02-10 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39132 + * tree-loop-distribution.c (todo): New global var. + (generate_memset_zero): Trigger TODO_rebuild_alias. + (tree_loop_distribution): Return todo. + +2009-02-10 H.J. Lu <hongjiu.lu@intel.com> + + PR target/39119 + * config/i386/i386.c (x86_64_reg_class): Remove X86_64_AVX_CLASS. + (x86_64_reg_class_name): Removed. + (classify_argument): Return 0 if bytes > 32. Return 0 if the + first one isn't X86_64_SSE_CLASS or any other ones aren't + X86_64_SSEUP_CLASS when size > 16bytes. Don't turn + X86_64_SSEUP_CLASS into X86_64_SSE_CLASS if the preceded one + is X86_64_SSEUP_CLASS. Set AVX modes to 1 X86_64_SSE_CLASS + and 3 X86_64_SSEUP_CLASS. + (construct_container): Remove X86_64_AVX_CLASS. Handle 4 + registers with 1 X86_64_SSE_CLASS and 3 X86_64_SSEUP_CLASS. + +2009-02-10 Ben Elliston <bje@au.ibm.com> + + * config/rs6000/rs6000.md (allocate_stack): Always use an update + form instruction to update the stack back chain word, even if the + user has disabled the generation of update instructions. + (movdi_<mode>_update_stack): New. + (movsi_update_stack): Likewise. + * config/rs6000/rs6000.c (rs6000_emit_allocate_stack): Likewise, + always use an update form instruction to update the stack back + chain word. + +2009-02-09 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/38953 + * graphite.c (if_region_set_false_region): After moving a region in + the false branch of a condition, remove the empty dummy basic block. + (gloog): Remove wrong fix for PR38953. + +2009-02-09 Ulrich Weigand <Ulrich.Weigand@de.ibm.com> + + * config/spu/spu.c (array_to_constant): Fix (latent) wrong-code + generation due to implicit sign extension. + +2009-02-09 Eric Botcazou <ebotcazou@adacore.com> + + PR middle-end/38981 + * tree-ssa-coalesce.c (add_coalesce): Cap the costs of coalesce pairs + at MUST_COALESCE_COST-1 instead of MUST_COALESCE_COST. + +2009-02-09 Richard Guenther <rguenther@suse.de> + + PR middle-end/35202 + * convert.c (convert_to_real): Disable (float)fn((double)x) + to fnf(x) conversion if errno differences may occur and + -fmath-errno is set. + +2009-02-07 Anatoly Sokolov <aesok@post.ru> + + * config/avr/avr.c (avr_mcu_t): Add ata6289 device. + * config/avr/avr.h (LINK_SPEC, CRT_BINUTILS_SPECS): (Ditto.). + * config/avr/t-avr (MULTILIB_MATCHES): (Ditto.). + +2009-02-06 Joseph Myers <joseph@codesourcery.com> + + PR c/35434 + * c-common.c (handle_alias_attribute): Disallow attribute for + anything not a FUNCTION_DECL or VAR_DECL. + +2009-02-06 Janis Johnson <janis187@us.ibm.com> + + PR c/39035 + * real.c (do_compare): Special-case compare of zero against + decimal float value. + +2009-02-06 Joseph Myers <joseph@codesourcery.com> + + PR c/36432 + * c-decl.c (grokdeclarator): Don't treat [] declarators in fields + as indicating flexible array members unless the field itself is + being declarared as the incomplete array. + +2009-02-06 Jan Hubicka <jh@suse.cz> + + PR tree-optimization/38844 + * ipa-inline.c (try_inline): Stop inlining recursion when edge + is already inlined. + +2009-02-06 Richard Guenther <rguenther@suse.de> + + PR middle-end/38977 + * tree-cfg.c (need_fake_edge_p): Force a fake edge for + fork because we may expand it as __gcov_fork. + +2009-02-06 Nick Clifton <nickc@redhat.com> + + * config/m32c/m32c.h (PCC_BITFIELD_TYPE_MATTERS): Define to zero. + +2009-02-06 Paolo Bonzini <bonzini@gnu.org> + + PR tree-optimization/35659 + * tree-ssa-sccvn.c (vn_constant_eq, vn_reference_eq, vn_nary_op_eq + vn_phi_eq): Shortcut if hashcode does not match. + (vn_reference_op_compute_hash): Do not call iterative_hash_expr for + NULL operands. + * tree-ssa-pre.c (pre_expr_hash): Look at hashcode if available, + and avoid iterative_hash_expr. + (FOR_EACH_VALUE_ID_IN_SET): New. + (value_id_compare): Remove. + (sorted_array_from_bitmap_set): Use FOR_EACH_VALUE_ID_IN_SET to + sort expressions by value id. + +2009-02-05 Kaz Kojima <kkojima@gcc.gnu.org> + + PR target/38991 + * config/sh/predicates.md (general_movsrc_operand): Don't check + the subreg of system registers here. + +2009-02-05 Jakub Jelinek <jakub@redhat.com> + + PR c++/39106 + * cgraphunit.c (cgraph_function_versioning): Clear also DECL_VIRTUAL_P + on the copied decl. + +2009-02-05 Paolo Bonzini <bonzini@gnu.org> + + PR rtl-optimization/39110 + * rtlanal.c (rtx_addr_can_trap_p_1): Shortcut unaligned + addresses, not aligned ones. + +2009-02-05 Daniel Berlin <dberlin@dberlin.org> + Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39100 + * tree-ssa-structalias.c (do_ds_constraint): Actually do what the + comment says and add edges. + +2009-02-05 Joseph Myers <joseph@codesourcery.com> + + PR c/35435 + * c-common.c (handle_tls_model_attribute): Ignore attribute for + non-VAR_DECLs without checking DECL_THREAD_LOCAL_P. + +2009-02-04 Tobias Grosser <grosser@fim.uni-passau.de> + + * graphite.c (bb_in_sese_p, sese_build_livein_liveouts_use, + sese_build_livein_liveouts_bb, sese_build_livein_liveouts, + register_bb_in_sese, new_sese, free_sese): Moved. + (dot_scop_1, build_scop_loop_nests, build_loop_iteration_domains, + outermost_loop_in_scop, build_scop_iteration_domain, + expand_scalar_variables_ssa_name, get_vdef_before_scop, + limit_scops): Use bb_in_sese_p instead of bb_in_scop_p. + Use loop_in_sese_p instead of loop_in_scop_p. + (new_graphite_bb, gloog): Do not initialize SCOP_BBS_B. + (new_scop, free_scop): Remove SCOP_LOOP2CLOOG_LOOP and SCOP_BBS_B. + (scopdet_basic_block_info): Fix bug in scop detection. + (new_loop_to_cloog_loop_str, hash_loop_to_cloog_loop, + eq_loop_to_cloog_loop): Remove. + (nb_loops_around_loop_in_scop, nb_loop + ref_nb_loops): Moved here... + * graphite.h (ref_nb_loops): ... from here. + (struct scop): Remove bbs_b bitmap and loop2cloog_loop. + (loop_domain_dim, loop_iteration_vector_dim): Remove. + (SCOP_BBS_B, bb_in_scop_p, loop_in_scop_p): Removed. + +2009-02-04 Paolo Bonzini <bonzini@gnu.org> + Hans-Peter Nilsson <hp@axis.com> + + PR rtl-optimization/37889 + * rtlanal.c (rtx_addr_can_trap_p_1): Add offset and size arguments. + Move offset handling from PLUS to before the switch. Use new + arguments when considering SYMBOL_REFs too. + (rtx_addr_can_trap_p): Pass dummy offset and size. + (enum may_trap_p_flags): Remove. + (may_trap_p_1): Pass size from MEM_SIZE. + + PR rtl-optimization/38921 + * loop-invariant.c (find_invariant_insn): Use may_trap_or_fault_p. + * rtl.h (may_trap_after_code_motion_p): Delete prototype. + * rtlanal.c (may_trap_after_code_motion_p): Delete. + (may_trap_p, may_trap_or_fault_p): Pass 0/1 as flags. + +2009-02-04 H.J. Lu <hongjiu.lu@intel.com> + + AVX Programming Reference (January, 2009) + * config/i386/sse.md (*vpclmulqdq): New. + +2009-02-04 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/38977 + PR gcov-profile/38292 + * calls.c (special_function_p): Disregard __builtin_ prefix. + +2009-02-04 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.c (GO_IF_LEGITIMATE_ADDRESS): Disallow + non-indexable addresses even before reload. + +2009-02-03 Joseph Myers <joseph@codesourcery.com> + + PR c/29129 + * c-decl.c (grokdeclarator): Mark [*] arrays in field declarators + as having variable size. Do not give an error for unnamed + parameters with [*] declarators. Give a warning for type names + with [*] declarators and mark them as variable size. + * c-parser.c (c_parser_sizeof_expression): Do not give an error + for sizeof applied to [*] type names. + +2009-02-03 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR C++/36607 + * convert.c (convert_to_integer): Treat OFFSET_TYPE like INTEGER_TYPE. + +2009-02-03 Jakub Jelinek <jakub@redhat.com> + + * gcc.c (process_command): Update copyright notice dates. + * gcov.c (print_version): Likewise. + * gcov-dump.c (print_version): Likewise. + * mips-tfile.c (main): Likewise. + * mips-tdump.c (main): Likewise. + +2009-02-03 Joseph Myers <joseph@codesourcery.com> + + PR c/35433 + * c-typeck.c (composite_type): Set TYPE_SIZE and TYPE_SIZE_UNIT + for composite type involving a zero-length array type. + +2009-02-03 Jakub Jelinek <jakub@redhat.com> + + PR target/35318 + * function.c (match_asm_constraints_1): Skip over + initial optional % in the constraint. + + PR inline-asm/39059 + * c-parser.c (c_parser_postfix_expression): If fixed point is not + supported, don't accept FIXED_CSTs. + * c-decl.c (finish_declspecs): Error if fixed point is not supported + and _Sat is used without _Fract/_Accum. Set specs->type to + integer_type_node for cts_fract/cts_accum if fixed point is not + supported. + +2009-02-02 Catherine Moore <clm@codesourcery.com> + + * sde.h (SUBTARGET_ARM_SPEC): Don't assemble -fpic code as -mabicalls. + +2009-02-02 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/mips.h (FILE_HAS_64BIT_SYMBOLS): New macro. + (ABI_HAS_64BIT_SYMBOLS): Use it. + (DWARF2_ADDR_SIZE): Use it instead of ABI_HAS_64BIT_SYMBOLS. + +2009-02-02 Paul Brook <paul@codesourcery.com> + + * config/arm/arm.md (arm_addsi3): Add r/r/k alternative. + +2009-02-02 Jakub Jelinek <jakub@redhat.com> + + PR inline-asm/39058 + * recog.h (asm_operand_ok): Add constraints argument. + * recog.c (asm_operand_ok): Likewise. If it is set, for digits + recurse on matching constraint. + (check_asm_operands): Pass constraints as 3rd argument to + asm_operand_ok. Don't look up matching constraint here. + * stmt.c (expand_asm_operands): Pass NULL as 3rd argument + to asm_operand_ok. + +2009-02-02 Ben Elliston <bje@au.ibm.com> + + * doc/tm.texi (Storage Layout): Fix TARGET_ALIGN_ANON_BITFIELD and + TARGET_NARROW_VOLATILE_BITFIELD macro names. + +2009-01-31 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * doc/install.texi (hppa*-hp-hpux*): Update binutils and linker + information. Remove some obsolete information. Reorganize. + + * config/pa/fptr.c: Revert license to GPL 2. + * config/pa/milli64.S: Likewise. + +2009-01-31 Dave Korn <dave.korn.cygwin@gmail.com> + + PR target/38904 + * mkmap-flat.awk (END): Use pe_dll command-line arg to pass + LIBRARY name in, instead of hard-coding it. + * config.gcc (i[34567]86-*-pe | i[34567]86-*-cygwin*): Add an + extra target make frag to tmake_files according to EH model. + (i[34567]86-*-mingw* | x86_64-*-mingw*): Likewise. + * config/i386/t-dw2-eh, config/i386/t-sjlj-eh: Add new target + frags that define makefile variable EH_MODEL appropriately. + * config/i386/cygming.h (DWARF2_UNWIND_INFO): Add comment. + * config/i386/cygwin.h (LIBGCC_EH_EXTN): Define to nothing or + to "-sjlj" according to type of EH configured. + (LIBGCC_SONAME): Concatenate it to shared library base name. + * config/i386/mingw32.h (LIBGCC_EH_EXTN): Define to "_dw2" or + to "_sjlj" according to type of EH configured. + (LIBGCC_SONAME): Concatenate it to shared library base name. + * config/i386/t-cygming (SHLIB_SONAME): Use EH_MODEL. + (SHLIB_LINK): Add missing semicolon to if-else construct. + (SHLIB_MKMAP_OPTS): Pass library name to mkmap-flat.awk as + string value of "pe_dll" command-line option. + * config/i386/t-cygwin (SHLIB_EH_EXTENSION): New helper. + (SHLIB_SONAME): Use it when overriding t-cygming default. + (SHLIB_IMPLIB): Override t-cygming default. + (SHLIB_MKMAP_OPTS): Pass library name to mkmap-flat.awk as + string value of "pe_dll" command-line option. + +2009-01-31 Dave Korn <dave.korn.cygwin@gmail.com> + + PR target/38952 + * config/i386/i386.c (ix86_builtin_setjmp_frame_value): New. + (TARGET_BUILTIN_SETJMP_FRAME_VALUE): Override default to point at it. + +2009-01-31 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38937 + * tree-ssa-structalias.c (do_sd_constraint): Do not shortcut + computing the transitive closure. + +2009-01-30 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/39041 + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): + Propagate variable indices only if the types match for this stmt. + +2009-01-30 Jakub Jelinek <jakub@redhat.com> + + PR target/39013 + * c-decl.c (pop_scope): Set DECL_EXTERNAL for functions declared + inline but never defined. + +2009-01-30 Wolfgang Gellerich <gellerich@de.ibm.com> + + * config/s390/s390.md (*insv<mode>_reg_extimm): Removed. + (*insv_h_di_reg_extimm): New insn. + (*insv_l<mode>_reg_extimm): New insn. + +2009-01-30 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.c (flag_conserve_stack): set + PARAM_LARGE_STACK_FRAME and PARAM_STACK_FRAME_GROWTH to zero under + fconserve-stack. Reduce call-overhead used by inliner. + +2009-01-30 Hariharan Sandanagobalane <hariharan@picochip.com> + + PR/38157 + * common.opt (flag_conserve_stack): Initialised to zero. + +2009-01-30 Kai Tietz <kai.tietz@onevision.com> + + PR/39002 + * config/i386/i386.c (ix86_can_use_return_insn_p): Check for nsseregs. + (ix86_expand_epilogue): Take nsseregs in account to use proper restore + method. + +2009-01-29 H.J. Lu <hongjiu.lu@intel.com> + + * ira-color.c (allocno_reload_assign): Update comments. + * regmove.c (regmove_optimize): Likewise. + + * ra.h: Removed. + +2009-01-29 Robert Millan <rmh@aybabtu.com> + + * config.gcc: Recognize GNU/kOpenSolaris (*-*-kopensolaris*-gnu). + * config/i386/kopensolaris-gnu.h: New file. Undefine + `MD_UNWIND_SUPPORT'. + * config/kopensolaris-gnu.h: New file (based on kfreebsd-gnu.h). + +2009-01-29 Kazu Hirata <kazu@codesourcery.com> + + PR tree-optimization/39007 + * tree-loop-distribution.c (generate_builtin): Use + recompute_dominator to compute the immediate dominator of the + basic block just after the loop. + +2009-01-29 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE> + + * config/i386/sol2-10.h [!HAVE_AS_IX86_DIFF_SECT_DELTA] + (ASM_OUTPUT_DWARF_PCREL): Define. + +2009-01-29 Vladimir Makarov <vmakarov@redhat.com> + + * doc/tm.texi (TARGET_IRA_COVER_CLASSES): Modify description. + * doc/passes.texi: Remove entries about regclass, local-alloc, and + global. Modify entries about regmove and IRA. + + * ra-conflict.c: Remove the file. + + * reload.c (push_reload, find_dummy_reload): Remove flag_ira. + + * tree-pass.h (pass_local_alloc, pass_global_alloc): Remove. + (pass_regclass_init): Rename to pass_reginfo_init. + + * cfgloopanal.c (estimate_reg_pressure_cost): Remove flag_ira. + + * toplev.h (flag_ira): Remove. + + * caller-save.c (setup_save_areas): Remove flag_ira. + + * ira-color.c (ira_reuse_stack_slot, ira_mark_new_stack_slot): Ditto. + + * global.c: Remove the file. + + * opts.c (decode_options): Remove flag_ira. + + * hard-reg-set.h (losing_caller_save_reg_set): Remove. + + * regmove.c: Modify file description. + (find_use_as_address, try_auto_increment): Define them only if + AUTO_INC_DEC is defined. + (replacement_quality, replace_in_call_usage, fixup_match_1, + stable_and_no_regs_but_for_p): Remove. + (reg_set_in_bb): Make it static. + (regmove_optimize): Remove flag_ira and code which worked for + !flag_ira. + + * local-alloc.c: Remove the file. + + * common.opt (fira): Remove. + + * ira.c: Include except.h. + (eliminable_regset): Move from global.c. + (mark_elimination): Ditto. Remove flag_ira. + (reg_renumber, struct equivalence, reg_equiv, equiv_mem, + equiv_mem_modified, validate_equiv_mem_from_store, + validate_equiv_mem, equiv_init_varies_p, equiv_init_movable_p, + contains_replace_regs, memref_referenced_p, memref_used_between_p, + no_equiv, recorded_label_ref): Move from local-alloc.c. + (update_equiv_regs): Ditto. Make it static. + (print_insn_chain, print_insn_chains): Move it from global.c. + (pseudo_for_reload_consideration_p): Ditto. Remove flag_ira. + (build_insn_chain): Ditto. Make it static. + (ra_init_live_subregs): Move from ra-conflict.c. Make it static. + Rename to init_live_subregs. + (gate_ira): Remove flag_ira. + + * regclass.c: Rename reginfo.c. Change file description. + (FORBIDDEN_INC_DEC_CLASSES): Remove. + (reg_class_superclasses, forbidden_inc_dec_class, in_inc_dec): Remove. + (init_reg_sets_1): Remove code for evaluation of + reg_class_superclasses and losing_caller_save_reg_set. + (init_regs): Remove init_reg_autoinc. + (struct costs, costs, init_cost, ok_for_index_p_nonstrict, + ok_for_base_p_nonstrict): Remove. + (regclass_init): Rename to reginfo_init. Don't initialize init_cost. + (pass_regclass_init): Rename to pass_reginfo_init. Modify + corresponding entries. + (dump_regclass, record_operand_costs, scan_one_insn, + init_reg_autoinc, regclass, record_reg_classes, copy_cost, + record_address_regs, auto_inc_dec_reg_p): Remove. + (gt-regclass.h): Rename to gt-reginfo.h. + + * rtl.h (dump_global_regs, retry_global_alloc, + build_insn_chain, dump_local_alloc, update_equiv_regs): Remove. + + * Makefile.in (RA_H): Remove. + (OBJS-common): Remove global.o, local-alloc.o, and ra-conflict.o. + Rename regclass.o to reginfo.o. + (regclass.o): Rename to reginfo.o. Rename gt-regclass.h to + gt-reginfo.h. + (global.o, local-alloc.o, ra-conflict.o): Remove entries. + (GTFILES): Rename regclass.c to reginfo.c. + + * passes.c (init_optimization_passes): Remove pass_local_alloc and + pass_global_alloc. Rename pass_regclass_init to pass_reginfo_init. + + * reload1.c (compute_use_by_pseudos, reload, count_pseudo, + count_spilled_pseudo, find_reg, alter_reg, delete_output_reload): + Remove flag_ira. + (finish_spills): Ditto. Remove code for !flag_ira. + +2009-01-29 Kenneth Zadeck <zadeck@naturalbridge.com> + + PR middle-end/35854 + * doc/invoke.texi (rtl debug options): Complete rewrite. + * auto-inc-dec.c (pass_inc_dec): Rename pass from "auto-inc-dec" + to auto_inc_dec". + * mode-switching.c (pass_mode_switching): Rename pass from + "mode-sw" to "mode_sw". + * except.c (pass_convert_to_eh_ranges): Rename pass from + "eh-ranges" to "eh_ranges". + * lower-subreg.c (pass_lower_subreg): Renamed pass from "subreg" + to "subreg1". + + +2009-01-29 Andrey Belevantsev <abel@ispras.ru> + Alexander Monakov <amonakov@ispras.ru> + + PR middle-end/38857 + * sel-sched.c (count_occurrences_1): Check that *cur_rtx is a hard + register. + (move_exprs_to_boundary): Change return type and pass through + should_move from move_op. Relax assert. Update usage ... + (schedule_expr_on_boundary): ... here. Use should_move instead of + cant_move. + (move_op_orig_expr_found): Indicate that insn was disconnected from + stream. + (code_motion_process_successors): Do not call after_merge_succs + callback if original expression was not found when traversing any of + the branches. + (code_motion_path_driver): Change return type. Update prototype. + (move_op): Update comment. Add a new parameter (should_move). Update + prototype. Set *should_move based on indication provided by + move_op_orig_expr_found. + +2009-01-28 Pat Haugen <pthaugen@us.ibm.com> + + * doc/invoke.texi (avoid-indexed-addresses): Document new option. + * config/rs6000/rs6000-protos.h (avoiding_indexed_address_p): Declare. + * config/rs6000/rs6000.opt (avoid-indexed-addresses): New option. + * config/rs6000/rs6000.c (rs6000_override_options): Default + avoid-indexed-addresses on for Power6, off for everything else. + (avoiding_indexed_address_p): New function. + (rs6000_legitimize_address): Use it. + (rs6000_legitimate_address): Likewise. + * config/rs6000/rs6000.md (movXX_updateX): Likewise + +2009-01-28 Kazu Hirata <kazu@codesourcery.com> + + PR tree-optimization/38997 + * tree-loop-distribution.c (generate_memset_zero): Use + POINTER_PLUS_EXPR for a pointer addition. + +2009-01-28 Andreas Krebbel <krebbel1@de.ibm.com> + + * config/s390/s390.md (bswap<mode>2): New pattern added. + +2009-01-28 Wolfgang Gellerich <gellerich@de.ibm.com> + + * config/s390/s390.md (*tls_load_31): Added type attribute. + +2009-01-28 Wolfgang Gellerich <gellerich@de.ibm.com> + + * config/s390/s390.md: Fix a few comments. + +2009-01-28 Wolfgang Gellerich <gellerich@de.ibm.com> + + * config/s390/s390.md (*tmsi_reg): Fixed z10prop attribute. + (*tm<mode>_full): Fixed z10prop attribute. + (*tst<mode>_extimm): Fixed z10prop attribute. + (*tst<mode>_cconly_extimm): Fixed z10prop attribute. + (*tstqiCCT_cconly): Fixed z10prop attribute. + (*cmpsi_ccu_zerohi_rlsi): Fixed z10prop attribute. + (*movsi_larl): Fixed z10prop attribute. + (*movsi_zarch): Fixed z10prop attribute. + (*movsi_eas): Fixed z10prop attribute. + (*movhi): Fixed z10prop attribute. + (*movqi): Fixed z10prop attribute. + (*movstrictqi): Fixed z10prop attribute. + (*mov<mode>): Fixed z10prop attribute. + (*movcc): Fixed z10prop attribute. + (*sethighpartdi_64): Fixed z10prop attribute. + (*zero_extendhi<mode>2_z10): Fixed z10prop attribute. + (*negdi2_sign_cc): Fixed z10prop attribute. + (*negdi2_sign): Fixed z10prop attribute. + (*absdi2_sign_cc): Fixed z10prop attribute. + (*absdi2_sign): Fixed z10prop attribute. + (*negabsdi2_sign_cc): Fixed z10prop attribute. + (*negabsdi2_sign): Fixed z10prop attribute. + (*cmp_and_trap_signed_int<mode>): Fixed z10prop attribute. + (*cmp_and_trap_unsigned_int<mode>): Fixed z10prop attribute. + (doloop_si64): Fixed z10prop attribute. + (doloop_si31): Fixed z10prop attribute. + (doloop_long): Fixed z10prop attribute. + (indirect_jump): Fixed z10prop attribute. + (nop): Fixed z10prop attribute. + (main_base_64): Fixed z10prop attribute. + (reload_base_64): Fixed z10prop attribute. + +2009-01-28 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/38740 + * reorg.c (gate_handle_delay_slots): Avoid dbr scheduling + if !optimize. + * config/mips/mips.c (mips_reorg): Likewise. + +2009-01-28 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38926 + * tree-ssa-pre.c (add_to_value): Assert we add only expressions + with the correct value id to a value. + (do_regular_insertion): Use the value number of edoubleprime + for the value number of the expr. + + Revert + 2008-08-21 Richard Guenther <rguenther@suse.de> + + * tree-ssa-pre.c (insert_into_preds_of_block): Before inserting + a PHI ask VN if it is already available. + * tree-ssa-sccvn.h (vn_phi_lookup): Declare. + * tree-ssa-sccvn.c (vn_phi_lookup): Export. + +2009-01-28 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/38934 + * tree-vrp.c (extract_range_from_assert): For LE_EXPR and LT_EXPR + set to varying whenever max has TREE_OVERFLOW set, similarly + for GE_EXPR and GT_EXPR and TREE_OVERFLOW min. + +2009-01-28 Richard Guenther <rguenther@suse.de> + + PR middle-end/38908 + * tree-ssa.c (warn_uninitialized_var): Do not warn for seemingly + uninitialized aggregate uses in call arguments. + +2009-01-28 Paolo Bonzini <bonzini@gnu.org> + + PR tree-optimization/38984 + * tree-ssa-structalias.c (get_constraints_for_1): Do not use + the nothing_id variable if -fno-delete-null-pointer-checks. + +2009-01-28 Uros Bizjak <ubizjak@gmail.com> + + PR target/38988 + * config/i386/i386.md (set_rip_rex64): Wrap operand 1 in label_ref. + (set_got_offset_rex64): Ditto. + +2009-01-27 H.J. Lu <hongjiu.lu@intel.com> + + PR target/38941 + * doc/extend.texi: Improve local variable with asm reg. + +2009-01-27 Adam Nemet <anemet@caviumnetworks.com> + + * c.opt (Wpacked-bitfield-compat): Change init value to -1. + * c-opts.c (c_common_post_options): If -W*packed-bitfield-compat + was not supplied then set warn_packed_bitfield_compat to the + default value of 1. + * stor-layout.c (place_field): Check warn_packed_bitfield_compat + against 1. + +2009-01-27 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38503 + * cfgexpand.c (expand_gimple_basic_block): Ignore + GIMPLE_CHANGE_DYNAMIC_TYPE during expansion. + * tree-ssa-structalias.c (set_uids_in_ptset): Do not prune + variables that cannot have TBAA applied. + (compute_points_to_sets): Do not remove GIMPLE_CHANGE_DYNAMIC_TYPE + statements. + +2009-01-27 Uros Bizjak <ubizjak@gmail.com> + + PR middle-end/38969 + * calls.c (initialize_argument_information): Do not wrap complex + arguments in SAVE_EXPR. + +2009-01-26 Andreas Tobler <a.tobler@schweiz.org> + + * config/t-vxworks (LIBGCC2_INCLUDES): Fix typo. + (INSTALL_LIBGCC): Revert typo commit. + +2009-01-26 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38745 + * tree-ssa-alias.c (update_alias_info_1): Exclude RESULT_DECL + from special handling. + +2009-01-26 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38745 + * tree-ssa.c (execute_update_addresses_taken): Do not include + variables that cannot possibly be a register in not_reg_needs. + Do not clear TREE_ADDRESSABLE on vars that may not become + registers. + * tree-ssa.c (update_alias_info_1): Include those in the set + of addressable vars. + +2009-01-26 Richard Guenther <rguenther@suse.de> + + PR middle-end/38851 + * Makefile.in (tree-ssa-dse.o): Add langhooks.h. + * tree-ssa-dse.c: Include langhooks.h + (execute_simple_dse): Remove stores with zero size. + +2009-01-24 Jakub Jelinek <jakub@redhat.com> + + PR c/38957 + * c-typeck.c (c_finish_return): Handle POINTER_PLUS_EXPR the same way + as PLUS_EXPR. + +2009-01-24 Julian Brown <julian@codesourcery.com> + + * config/arm/t-linux-eabi (LIB2FUNCS_STATIC_EXTRA): Add + config/arm/linux-atomic.c. + * config/arm/linux-atomic.c: New. + +2009-01-24 Eric Botcazou <ebotcazou@adacore.com> + + * config/sparc/linux.h (DBX_REGISTER_NUMBER): Delete. + * config/sparc/linux64.h (DBX_REGISTER_NUMBER): Likewise. + * config/sparc/sysv4.h (DBX_REGISTER_NUMBER): Likewise. + +2009-01-24 H.J. Lu <hongjiu.lu@intel.com> + + PR c/38938 + * c-opts.c (c_common_handle_option): Update warn_pointer_sign + properly. + +2009-01-24 Sebastian Pop <sebastian.pop@amd.com> + + PR tree-optimization/38953 + * graphite.c (graphite_verify): Add a call to verify_loop_closed_ssa. + (scop_adjust_phis_for_liveouts): Initialize false_i to zero. + (gloog): Split the exit of the scop when the scop exit is a loop exit. + (graphite_transform_loops): Only call cleanup_tree_cfg if gloog + changed the CFG. + +2009-01-24 Paul Brook <paul@codesourcery.com> + + * config/arm/neon.md (neon_type): Move to arm.md. + (neon_mov<VSTRUCT>): Add neon_type attribute. + * config/arm/arm.md (neon_type): Move to here. + (conds): Add "unconditioal" and use as default for NEON insns. + +2009-01-24 Ben Elliston <bje@au.ibm.com> + + * bitmap.h (BITMAP_FREE): Eliminate `implicit conversion from + void *' warning from -Wc++-compat. + * Makefile.in (dominance.o-warn): Remove. + +2009-01-23 Paolo Bonzini <bonzini@gnu.org> + + PR tree-optimization/38932 + * fold-const.c (fold_unary_ignore_overflow): New. + * tree.h (fold_unary_ignore_overflow): Declare. + * tree-ssa-ccp.c (ccp_fold): Use fold_unary_ignore_overflow. + * tree-ssa-sccvn.c (visit_reference_op_load, + simplify_unary_expression): Likewise. + +2009-01-22 Adam Nemet <anemet@caviumnetworks.com> + + * c-decl.c (finish_struct): Move code to set DECL_PACKED after + DECL_BIT_FIELD is alreay known. Also inherit packed for bitfields + regardless of their type. + * c-common.c (handle_packed_attribute): Don't ignore packed on + bitfields. + * c.opt (Wpacked-bitfield-compat): New warning option. + * stor-layout.c (place_field): Warn if offset of a field changed. + * doc/extend.texi (packed): Mention the ABI change. + * doc/invoke.texi (-Wpacked-bitfield-compat): Document. + (Warning Options): Add it to the list. + +2009-01-22 H.J. Lu <hongjiu.lu@intel.com> + + * c-opts.c (c_common_post_options): Fix a typo in comments. + +2009-01-22 Steve Ellcey <sje@cup.hp.com> + + PR middle-end/38615 + * gimplify.c (gimplify_init_constructor): Fix promotion of const + variables to static. + * doc/invoke.texi (-fmerge-all-constants): Update description. + +2009-01-22 Uros Bizjak <ubizjak@gmail.com> + + PR target/38931 + * config/i386/i386.md (*movsi_1): Use type "mmx" for alternative 2. + (*movdi_1_rex64): Use type "mmx" for alternative 5. + +2009-01-22 Richard Earnshaw <rearnsha@arm.com> + + * arm.h (DATA_ALIGNMENT): Align structures, unions and arrays to + a word boundary. + (LOCAL_ALIGNMENT): Similarly. + +2009-01-22 Mark Shinwell <shinwell@codesourcery.com> + Joseph Myers <joseph@codesourcery.com> + + * config/arm/arm.c (all_architectures): Add iWMMXt2 entry. + * config/arm/arm-cores.def: New ARM_CORE entry for iWMMXt2. + * config/arm/arm-tune.md: Regenerate. + * doc/invoke.texi (ARM Options): Document -mcpu=iwmmxt2 and + -march=iwmmxt2. + +2009-01-22 Mark Shinwell <shinwell@codesourcery.com> + + * config/arm/bpabi.h (SUBTARGET_EXTRA_ASM_SPEC): Bump EABI + version number to five. + +2009-01-22 Dodji Seketeli <dodji@redhat.com> + + PR c++/38930 + * c-decl.c (clone_underlying_type): Revert PR c++/26693 changes. + * c-common.c (set_underlying_type): Likewise. + (is_typedef_decl ): Likewise + * tree.h: Likewise + (set_underlying_type): Likewise. + (is_typedef_type): Likewise. + +2009-01-21 Vladimir Makarov <vmakarov@redhat.com> + + PR middle-end/38587 + * ira-color.c (coalesce_spill_slots): Don't coalesce allocnos + crossing setjmps. + +2009-01-21 Dave Korn <dave.korn.cygwin@gmail.com> + + PR bootstrap/37660 + * config/i386/cygwin.h (SHARED_LIBGCC_SPEC): New helper macro. + (LIBGCC_SPEC): Don't define. + (REAL_LIBGCC_SPEC): Define instead, using SHARED_LIBGCC_SPEC. + +2009-01-21 Uros Bizjak <ubizjak@gmail.com> + + PR rtl-optimization/38879 + * alias.c (base_alias_check): Unaligned access via AND address can + alias all surrounding object types except those with sizes equal + or wider than the size of unaligned access. + +2009-01-21 Dodji Seketeli <dodji@redhat.com> + + PR c++/26693 + * c-decl.c (clone_underlying_type): Move this ... + * c-common.c (set_underlying_type): ... here. + Also, make sure the function properly sets TYPE_STUB_DECL() on + the newly created typedef variant type. + (is_typedef_decl ): New entry point. + * tree.h: Added a new member member_types_needing_access_check to + struct tree_decl_non_common. + (set_underlying_type): New entry point. + (is_typedef_type): Likewise. + +2009-01-21 Bingfeng Mei <bmei@broadcom.com> + + * alias.c (walk_mems_1, walk_mems_2, insn_alias_sets_conflict_p): + Check whether two instructions have memory references that + belong to conflicting alias sets. walk_mems_1 and walk_mems_2 + are helper functions for traversing. + * alias.h (insn_alias_sets_confilict_p): New prototypes. + * ddg.c (add_inter_loop_mem_dep): Call insn_alias_sets_conflict_p + not to draw dependency edge for instructions with non-conflicting + alias sets. + +2009-01-20 Joseph Myers <joseph@codesourcery.com> + + PR other/38758 + * longlong.h: Update copyright years. Use soft-fp license notice. + Sync __clz_tab declaration with glibc. + +2009-01-20 Steve Ellcey <sje@cup.hp.com> + + PR target/30687 + * doc/extend.texi (syscall_linkage): New. + (version_id): Modify. + +2009-01-20 Andrew Pinski <andrew_pinski@playstation.sony.com> + Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38747 + PR tree-optimization/38748 + * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Disable the VCE + conversion if the base address is an indirect reference and the + aliasing sets could cause issues. + +2009-01-20 Sebastian Pop <sebastian.pop@amd.com> + + * common.opt (fgraphite, fgraphite-identity): Add comment for + explaining why these options are not documented. + +2009-01-20 Sebastian Pop <sebastian.pop@amd.com> + + * graphite.c (stmt_simple_for_scop_p): Also handle cases when + gimple_call_lhs is NULL. + +2009-01-20 Paolo Bonzini <bonzini@gnu.org> + + PR target/38868 + * emit-rtl.c (adjust_address_1): Make sure memref is never + overwritten. + +2009-01-20 Ben Elliston <bje@au.ibm.com> + + * libgcov.c (__gcov_execl, __gcov_execlp, __gcov_execle): Remove + const qualifier from arg parameter. Remove unnecessary cast to char *. + * gcov-io.h (__gcov_execl, __gcov_execlp, __gcov_execle): Remove + const qualifier from arg 2. + +2009-01-19 Iain Sandoe <iain.sandoe@sandoe-acoustics.co.uk> + + * config/darwin.h: Add static-libgfortran to LINK_SPEC. + +2009-01-19 Vladimir Makarov <vmakarov@redhat.com> + + PR c/38869 + * rtl.h (reinit_regs): New prototype. + * regclass.c: Include ira.h. + (reinit_regs): New. + * Makefile.in (regclass.o): Add ira.h. + * config/i386/i386.c (ix86_maybe_switch_abi): Use reinit_regs. + +2009-01-18 H.J. Lu <hongjiu.lu@intel.com> + + PR target/38736 + * c-common.c (handle_aligned_attribute): Use + ATTRIBUTE_ALIGNED_VALUE instead of BIGGEST_ALIGNMENT for + default alignment value. + + * c-cppbuiltin.c (c_cpp_builtins): Define __BIGGEST_ALIGNMENT__. + + * defaults.h (ATTRIBUTE_ALIGNED_VALUE): New. + * config/i386/i386.h (ATTRIBUTE_ALIGNED_VALUE): Likewise. + + * doc/extend.texi: Update __attribute__ ((aligned)). Document + __BIGGEST_ALIGNMENT__. + + * doc/tm.texi: Document ATTRIBUTE_ALIGNED_VALUE. + +2009-01-18 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38819 + * tree-flow.h (operation_could_trap_helper_p): Declare. + * tree-eh.c (operation_could_trap_helper_p): Export. + * tree-ssa-sccvn.h (vn_nary_may_trap): Declare. + * tree-ssa-sccvn.c (vn_nary_may_trap): New function. + * tree-ssa-pre.c (insert_into_preds_of_block): Check if we + are about to insert a possibly trapping instruction and fail + in this case. + +2009-01-18 Andreas Schwab <schwab@suse.de> + + * doc/install.texi (Configuration): Remove obsolete paragraph + about use of --with-gnu-ld with --with-gnu-as. + +2009-01-18 Kazu Hirata <kazu@codesourcery.com> + + * doc/extend.texi, doc/gimple.texi, doc/invoke.texi, + doc/md.texi, doc/sourcebuild.texi, doc/tm.texi: Fix typos. + Follow spelling conventions. + +2009-01-18 Ben Elliston <bje@au.ibm.com> + + * bitmap.c (bitmap_obstack_alloc_stat): Adjust cast to eliminate + C++ warning about implicit conversion from void * to struct + bitmap_head_def *. + (bitmap_obstack_free): Likewise for bitmap_element *. + * Makefile.in (bitmap.o-warn): Remove. + +2009-01-17 Dave Korn <dave.korn.cygwin@gmail.com> + + * Makefile.in (BACKENDLIBS): Reorder to match dependencies. + +2009-01-17 Sebastian Pop <sebastian.pop@amd.com> + Tobias Grosser <tobi.grosser@amd.com> + + * graphite.c (graphite_trans_scop_block): Do not block single + nested loops. + +2009-01-16 Alexandre Oliva <aoliva@redhat.com> + + * ebitmap.h (ebitmap_iter_init): Initialize all fields. + * ipa-struct-reorg.c (gen_struct_type): Replace known-true + test with assertion. + +2009-01-16 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38835 + PR middle-end/36227 + * fold-const.c (fold_binary): Remove PTR + INT -> (INT)(PTR p+ INT) + and INT + PTR -> (INT)(PTR p+ INT) folding. + * tree-ssa-address.c (create_mem_ref): Properly use POINTER_PLUS_EXPR. + +2009-01-16 Adam Nemet <anemet@caviumnetworks.com> + + PR target/38554 + * expmed.c (expand_shift): With SHIFT_COUNT_TRUNCATED, don't lift + the subreg from a lowpart subreg if it is also casting the value. + +2009-01-16 Sebastian Pop <sebastian.pop@amd.com> + Tobias Grosser <tobi.grosser@amd.com> + + * graphite.c (compare_prefix_loops): New. + (build_scop_canonical_schedules): Rewritten. + (graphite_transform_loops): Move build_scop_canonical_schedules + after build_scop_iteration_domain. + +2009-01-16 Sebastian Pop <sebastian.pop@amd.com> + Tobias Grosser <tobi.grosser@amd.com> + + * graphite.c (add_conditions_to_domain): Add the loops to + the dimension of the iteration domain. Do copy the domain + only when it exists. + (build_scop_conditions_1): Do not call add_conditions_to_domain. + (add_conditions_to_constraints): New. + (can_generate_code_stmt, can_generate_code): Removed. + (gloog): Do not call can_generate_code. + (graphite_transform_loops): Call add_conditions_to_constraints + after building the iteration domain. + +2009-01-16 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/38789 + * tree-ssa-threadedge.c + (record_temporary_equivalences_from_stmts_at_dest): Ignore calls to + __builtin_constant_p. + +2009-01-16 Kenneth Zadeck <zadeck@naturalbridge.com> + + * dce.c (delete_unmarked_insns): Reversed the order that insns are + examined before deleting them. + +2009-01-16 Richard Earnshaw <rearnsha@arm.com> + + * function.c (aggregate_value_p): Correctly extract the function + type from CALL_EXPR_FN lookup. + +2009-01-16 Hariharan Sandanagobalane <hariharan@picochip.com> + + * config/picochip/picochip.c (picochip_override_options): Revert + CFI asm flag disable commited previously. + +2009-01-15 Sebastian Pop <sebastian.pop@amd.com> + Tobias Grosser <tobi.grosser@amd.com> + Jan Sjodin <jan.sjodin@amd.com> + + * graphite.c (scan_tree_for_params): On substractions negate + all the coefficients of the term. + (clast_to_gcc_expression_red): New. Handle reduction expressions + of more than two operands. + (clast_to_gcc_expression): Call clast_to_gcc_expression_red. + (get_vdef_before_scop): Handle also the case of default definitions. + +2009-01-15 Richard Sandiford <rdsandiford@googlemail.com> + + * caller-save.c (add_used_regs_1, add_used_regs): New functions. + (insert_one_insn): Use them instead of REG_DEAD and REG_INC notes. + Also use them when walking CALL_INSN_FUNCTION_USAGE. + +2009-01-15 H.J. Lu <hongjiu.lu@intel.com> + Joey Ye <joey.ye@intel.com> + + PR middle-end/37843 + * cfgexpand.c (expand_stack_alignment): Don't update stack + boundary nor check incoming stack boundary here. + (gimple_expand_cfg): Update stack boundary and check incoming + stack boundary here. + +2009-01-15 Kenneth Zadeck <zadeck@naturalbridge.com> + + * dce.c (find_call_stack_args, delete_unmarked_insns): Fixed comments. + +2009-01-14 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/38245 + * calls.c (expand_call): Add stack arguments to + CALL_INSN_FUNCTION_USAGE even for pure calls (when + ACCUMULATE_OUTGOING_ARGS) and even for args partially passed + in regs and partially in memory or BLKmode arguments. + (emit_library_call_value_1): Add stack arguments to + CALL_INSN_FUNCTION_USAGE even for pure calls (when + ACCUMULATE_OUTGOING_ARGS). + * dce.c: Include tm_p.h. + (find_call_stack_args): New function. + (deletable_insn_p): Call it for CALL_P insns. Add ARG_STORES + argument. + (mark_insn): Call find_call_stack_args for CALL_Ps. + (prescan_insns_for_dce): Walk insns backwards in bb rather than + forwards. Allocate and free arg_stores bitmap if needed, pass it + down to deletable_insn_p, don't mark stores set in arg_stores + bitmap, clear the bitmap at the beginning of each bb. + * Makefile.in (dce.o): Depend on $(TM_P_H). + +2009-01-14 Michael Meissner <gnu@the-meissners.org> + + PR target/22599 + * config/i386/i386.c (print_operand): Add tests for 'D', 'C', 'F', 'f' + to make sure the insn is a conditional test (bug 22599). Reformat a + few long lines. + +2009-01-14 Sebastian Pop <sebastian.pop@amd.com> + + PR middle-end/38431 + * graphite.c (get_vdef_before_scop, scop_adjust_vphi): New. + (scop_adjust_phis_for_liveouts): Call scop_adjust_vphi. + (gloog): Do not call cleanup_tree_cfg. + (graphite_transform_loops): Call cleanup_tree_cfg after all + scops have been code generated. + +2009-01-14 Basile Starynkevitch <basile@starynkevitch.net> + * doc/gty.texi (Invoking the garbage collector): Added new node + and section documenting ggc_collect. + +2009-01-14 Richard Guenther <rguenther@suse.de> + + PR tree-optimization/38826 + PR middle-end/38477 + * tree-ssa-structalias.c (emit_alias_warning): Emit the pointer + initialization notes only if we actually emitted a warning. + (intra_create_variable_infos): Add constraints for a result decl + that is passed by hidden reference. + (build_pred_graph): Mark all related variables non-direct on + address-taking. + +2009-01-14 Nick Clifton <nickc@redhat.com> + + * ira-conflicts.c: Include addresses.h for the definition of + base_reg_class. + (ira_build_conflicts): Use base_reg_class instead of BASE_REG_CLASS. + * Makefile.in: Add a dependency of ira-conflicts.o on addresses.h. + +2009-01-13 Vladimir Makarov <vmakarov@redhat.com> + + PR target/38811 + * Makefile.in (ira-lives.o): Add except.h. + + * ira-lives.c: Include except.h. + (process_bb_node_lives): Process can_throw_internal. + +2009-01-13 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/38774 + * combine.c (simplify_set): When undoing cc_use change, don't do + PUT_CODE on the newly created comparison, but instead put back the + old comparison. + +2009-01-13 Joseph Myers <joseph@codesourcery.com> + + * doc/invoke.texi (ARM Options): Update lists of -mcpu and -march + values. Remove duplicate arm8 entry. + +2009-01-13 Sebastian Pop <sebastian.pop@amd.com> + + PR tree-optimization/38786 + * graphite.c (expand_scalar_variables_ssa_name): New, outlined from + the SSA_NAME case of expand_scalar_variables_expr. + Set the type of an expression to the type of its assign statement. + (expand_scalar_variables_expr): Also gather the scalar computation + used to index the memory access. Do not pass loop_p. + Fix comment. Stop recursion on tcc_constant or tcc_declaration. + (expand_scalar_variables_stmt): Pass to expand_scalar_variables_expr + the gimple_stmt_iterator where it inserts new code. + Do not pass loop_p. + (copy_bb_and_scalar_dependences): Do not pass loop_p. + (translate_clast): Update call to copy_bb_and_scalar_dependences. + +2009-01-13 Sebastian Pop <sebastian.pop@amd.com> + + * graphite.h (debug_value): Removed. + * graphite.c (debug_value): Removed. + +2009-01-13 Richard Earnshaw <rearnsha@arm.com> + + * config/arm/arm.c (output_move_double): Don't synthesize thumb-2 + ldrd/strd with two 32-bit instructions. + +2009-01-13 Richard Earnshaw <rearnsha@arm.com> + + * config/arm/arm.c (struct processors): Pass for speed down into + cost helper functions. + (const_ok_for_op): Handle COMPARE and inequality nodes. + (arm_rtx_costs_1): Rewrite. + (arm_size_rtx_costs): Update prototype. + (arm_rtx_costs): Pass speed down to helper functions. + (arm_slowmul_rtx_costs): Rework cost calculations. + (arm_fastmul_rtx_costs, arm_xscale_rtx_costs): Likewise. + (arm_9e_rtx_costs): Likewise. + +2009-01-13 Uros Bizjak <ubizjak@gmail.com> + + * config/alpha/alpha.c (alpha_legitimate_address_p): Explicit + relocations of local symbols wider than UNITS_PER_WORD are not valid. + (alpha_legitimize_address): Do not split local symbols wider than + UNITS_PER_WORD into HIGH/LO_SUM parts. + +2009-01-13 Danny Smith <dannysmith@users.sourceforge.net> + + PR bootstrap/38580 + * gcc.c (process_command): Replace call to execvp with calls + to pex_one and exit. + +2009-01-03 Anatoly Sokolov <aesok@post.ru> + + PR target/29141 + * config/avr/t-avr (LIB1ASMFUNCS): Add _tablejump_elpm. + * config/avr/libgcc.S (__do_global_ctors, __do_global_dtors): Add + variant for devices with 3-byte PC. + (__tablejump_elpm__): New. + +2009-01-12 Jakub Jelinek <jakub@redhat.com> + + PR c/32041 + * c-parser.c (c_parser_postfix_expression): Allow `->' in + offsetof member-designator, handle it as `[0].'. + +2009-01-12 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa.c (pa_asm_output_mi_thunk): Use pc-relative branch to thunk + function when not using named sections on targets with named sections + if branch distance is less than 262132. + +2009-01-12 Richard Earnshaw <rearnsha@arm.com> + + * combine.c (combine_instructions): Recompute + optimize_this_for_speed_p for each BB in the main combine loop. + +2009-01-12 Tomas Bily <tbily@suse.cz> + + PR middlend/38385 + * tree-loop-distribution.c (prop_phis): New function. + (generate_builtin): Call prop_phis. + +2009-01-12 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/38807 + * tree-ssa-reassoc.c (remove_visited_stmt_chain): Don't look at + gimple_visited_p unless stmt is GIMPLE_ASSIGN. + +2009-01-11 Adam Nemet <anemet@caviumnetworks.com> + + * expmed.c (store_bit_field_1): Properly truncate the paradoxical + subreg of op0 to the original op0. + +2009-01-11 Laurent GUERBY <laurent@guerby.net> + + * doc/sourcebuild.texi (Source Tree): Move up intl and fixinc. + +2009-01-11 Markus Schoepflin <markus.schoepflin@comsoft.de> + + PR debug/7055 + * mips-tfile.c (parse_def): Fix parsing of def strings + starting with digits. + +2009-01-10 Jakub Jelinek <jakub@redhat.com> + + PR target/38695 + * config/arm/arm.c (arm_is_long_call_p): Don't call + arm_function_in_section_p if decl isn't a FUNCTION_DECL. + +2009-01-09 Steven Bosscher <steven@gcc.gnu.org> + + * regrename.c (regrename_optimize): Fix dumping. + (find_oldest_value_reg): Preserve REG_POINTER. + (copy_hardreg_forward_1): Likewise. + +2009-01-09 Diego Novillo <dnovillo@google.com> + + * gimple.h (struct gimple_statement_base) <uid>: Document + the restrictions on its use. + (gimple_uid): Tidy. + (gimple_set_uid): Tidy. + +2009-01-09 Jakub Jelinek <jakub@redhat.com> + + * config/i386/i386.c (ix86_expand_movmem, ix86_expand_setmem): Add + zero guard even if align_bytes != 0 and count is smaller than + size_needed. + +2009-01-09 Vladimir Makarov <vmakarov@redhat.com> + + PR rtl-optimization/38495 + * ira-emit.c (print_move_list, ira_debug_move_list): New functions. + (add_range_and_copies_from_move_list): Print all added ranges. + Add ranges to memory optimized destination. + +2009-01-09 Jakub Jelinek <jakub@redhat.com> + + PR target/38686 + PR target/38708 + * config/i386/i386.c (override_options): Reject + -mstringop-strategy=rep_8byte with -m32. + (ix86_expand_movmem): For size_needed == 1 set epilogue_size_needed + to 1. Do count comparison against epilogue_size_needed at compile + time even when count_exp was constant forced into register. For + size_needed don't jump to epilogue, instead just avoid aligning + and invoke the body algorithm. If need_zero_guard, add zero guard + even if count is non-zero, but smaller than size_needed + number of + bytes that could be stored for alignment. + (ix86_expand_setmem): For size_needed == 1 set epilogue_size_needed + to 1. If need_zero_guard, add zero guard even if count is non-zero, + but smaller than size_needed + number of bytes that could be stored + for alignment. Compare size_needed with epilogue_size_needed instead + of desired_align - align, don't adjust size_needed, pass + epilogue_size_needed to the epilogue expanders. + + PR c/35742 + * c-pretty-print.c (pp_c_expression): Handle GOTO_EXPR like BIND_EXPR. + +2009-01-09 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa.c (last_address): Change to unsigned. + (update_total_code_bytes): Change argument to unsigned. Don't + check if insn addresses are set. + (pa_output_function_epilogue): Set last_address to UINT_MAX if insn + addresses are not set. + (pa_asm_output_mi_thunk): Handle wrap when updating last_address. + +2009-01-09 Nick Clifton <nickc@redhat.com> + + * config/sh/symbian.c: Replace uses of DECL_INLINE with + DECL_DECLARED_INLINE_P. + +2009-01-09 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/38347 + * dojump.c (do_jump_by_parts_zero_rtx): Use mode instead of + GET_MODE (op0) in operand_subword_force calls. + + PR middle-end/38771 + * fold-const.c (fold_unary): For COMPOUND_EXPR and COND_EXPR, + fold_convert arg0 operands to TREE_TYPE (op0) first. + +2009-01-08 Vladimir Makarov <vmakarov@redhat.com> + + * params.def (ira-max-conflict-table-size): Decrease default value + to 1000. + +2009-01-08 Jakub Jelinek <jakub@redhat.com> + + PR tree-optimization/37031 + * lambda-code.c (lambda_collect_parameters): Call pointer_set_destroy + on parameter_set. + (build_access_matrix): Reserve correct size for AM_MATRIX vector, + allocate it using gc instead of heap, use VEC_quick_push instead of + VEC_safe_push. + * graphite.c (build_access_matrix): Allocate AM_MATRIX vector using gc + instead of heap, use VEC_quick_push instead of VEC_safe_push. + * tree-data-ref.h (struct access_matrix): Change matrix to gc + allocated vector from heap allocated. + * lambda.h: Add DEF_VEC_ALLOC_P for gc allocated lambda_vector. + * tree-loop-linear.c (linear_transform_loops): Allocate nest + vector only after perfect_loop_nest_depth call. + +2009-01-08 Sebastian Pop <sebastian.pop@amd.com> + Jan Sjodin <jan.sjodin@amd.com> + + PR tree-optimization/38559 + * graphite.c (debug_value, copy_constraint, + swap_constraint_variables, scale_constraint_variable, ): New. + (get_lower_bound, get_upper_bound): Removed. + (graphite_trans_bb_strip_mine): Clean up this code that works + only for constant number of iterations. Fully copy upper and + lower bound constraints, not only the constant part of them. + * graphite.h (debug_value): Declared. + +2009-01-08 Ira Rosen <irar@il.ibm.com> + + PR tree-optimization/37194 + * tree-vect-transform.c (vect_estimate_min_profitable_iters): + Don't add the cost of cost model guard in prologue to scalar + outside cost in case of known number of iterations. + +2009-01-07 Nathan Froyd <froydnj@codesourcery.com> + Alan Modra <amodra@bigpond.net.au> + + * config/rs6000/rs6000.c (rs6000_legitimize_address): Check for + non-word-aligned REG+CONST addressing. + +2009-01-07 Uros Bizjak <ubizjak@gmail.com> + + PR target/38706 + * config/alpha/alpha.c (alpha_end_function): For TARGET_ABI_OSF, call + free_after_compilation when outputting a thunk. + (alpha_output_mi_thunk_osf): Assert that we are processing a thunk. + Do not call free_after_compilation here. + +2009-01-07 Uros Bizjak <ubizjak@gmail.com> + + * config/i386/i386.c (ix86_target_string): Use ARRAY_SIZE. + (ix86_valid_target_attribute_inner_p): Ditto. + +2009-01-07 Jan Sjodin <jan.sjodin@amd.com> + + PR tree-optimization/38492 + PR tree-optimization/38498 + * tree-check.c (operator_is_linear, scev_is_linear_expression): New. + * tree-chrec.h (scev_is_linear_expression): Declared. + * graphite.c (graphite_cannot_represent_loop_niter): New. + (scopdet_basic_block_info): Call graphite_cannot_represent_loop_niter. + (graphite_loop_normal_form): Use gcc_assert. + (scan_tree_for_params): Use CASE_CONVERT. + (phi_node_is_iv, bb_contains_non_iv_scalar_phi_nodes): New. + (build_scop_conditions_1): Call bb_contains_non_iv_scalar_phi_nodes. + Use gcc_assert. Discard scops that contain unhandled cases. + (build_scop_conditions): Return a boolean status for unhandled cases. + (strip_mine_profitable_p): Print the loop number, not its depth. + (is_interchange_valid): Pass the depth of the loop nest, don't + recompute it wrongly. + (graphite_trans_bb_block): Same. + (graphite_trans_bb_block): Print tentative of loop blocking. + (graphite_trans_scop_block): Do not print that the loop has been + blocked. + (graphite_transform_loops): Do not handle scops that contain condition + scalar phi nodes. + +2009-01-07 H.J. Lu <hongjiu.lu@intel.com> + + AVX Programming Reference (December, 2008) + * config/i386/avxintrin.h (_mm256_stream_si256): New. + (_mm256_stream_pd): Likewise. + (_mm256_stream_ps): Likewise. + + * config/i386/i386.c (ix86_builtins): Add IX86_BUILTIN_MOVNTDQ256, + IX86_BUILTIN_MOVNTPD256 and IX86_BUILTIN_MOVNTPS256. + (ix86_special_builtin_type): Add VOID_FTYPE_PV4DI_V4DI. + (bdesc_special_args): Add __builtin_ia32_movntdq256, + __builtin_ia32_movntpd256 and __builtin_ia32_movntps256. + (ix86_init_mmx_sse_builtins): Handle VOID_FTYPE_PV4DI_V4DI. + (ix86_expand_special_args_builtin): Likewise. + + * config/i386/sse.md (AVXMODEDI): New. + (avx_movnt<mode>): Likewise. + (avx_movnt<mode>): Likewise. + (<sse>_movnt<mode>): Remove AVX support. + (sse2_movntv2di): Likewise. + +2009-01-07 Richard Guenther <rguenther@suse.de> + + PR middle-end/38751 + * fold-const.c (extract_muldiv): Remove obsolete comment. + (fold_plusminus_mult_expr): Undo MINUS_EXPR + to PLUS_EXPR canonicalization for the canonicalization. + +2009-01-07 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/install.texi (alpha*-dec-osf*): Remove note on 32-bit + hosted cross-compilers generating less efficient code. + +2009-01-06 Richard Sandiford <rdsandiford@googlemail.com> + + * function.h (rtl_data): Add a dbr_scheduled_p field. + * reorg.c (dbr_schedule): Set it. + (gate_handle_delay_slots): Check it. + * config/mips/mips.c (mips_base_delayed_branch): Delete. + (mips_reorg): Check flag_delayed_branch instead of + mips_base_delayed_branch. + (mips_override_options): Don't set mips_base_delayed_branch + or flag_delayed_branch. + +2009-01-06 Richard Sandiford <rdsandiford@googlemail.com> + + PR rtl-optimization/38426. + * ira.c (ira): Set current_function_is_leaf earlier. + +2009-01-06 Jakub Jelinek <jakub@redhat.com> + + PR rtl-optimization/38722 + * combine.c (try_combine): Don't modify PATTERN (i3) and notes + too early, only set a flag and modify after last possible + undo_all point. + +2009-01-06 Janis Johnson <janis187@us.ibm.com> + + PR c/34252 + * ginclude/float.h: Rename DECnn_DEN to DECnn_SUBNORMAL_MIN. + * real.c (decimal_single_format): Correct values of emin and emax. + (decimal_double_format): Ditto. + (decimal_quad_format): Ditto. + * c-cppbuiltin.c (builtin_define_decimal_float_constants): Adjust + computation of DECnn_MIN and DECnn_MAX for corrected values of + emin and emax. Define __DECnn_SUBNORMAL_MIN__ instead of + __DECnn_MIN__, and adjust its computation for the corrected value + of emin. + +2009-01-06 Jan Hubicka <jh@suse.cz> + + PR target/38744 + * config/i386/i386.c (ix86_expand_call): Use ARRAY_SIZE. + +2009-01-06 Gerald Pfeifer <gerald@pfeifer.com> + + * doc/contrib.texi (Contributors): Slightly adjust the end note. + Add Robert Clark to the list of testers. + +2009-01-06 Jan Hubicka <jh@suse.cz> + Kai Tietz <kai.tietz@onevision.com> + + * config/i386/i386.md (*msabi_syvabi): Add SSE regs clobbers. + * config/i386/i386.c (ix86_expand_call): Add clobbers. + +2009-01-06 Jan Hubicka <jh@suse.cz> + Kai Tietz <kai.tietz@onevision.com> + + * config/i386/i386.h (CONDITIONAL_CALL_USAGE): SSE regs are not used + for w64 ABI. + * config/i386/i386.c (struct ix86_frame): Add padding0 and nsseregs. + (ix86_nsaved_regs): Count only general purpose regs. + (ix86_nsaved_sseregs): New. + (ix86_compute_frame_layout): Update nsseregs; set preferred alignment + to 16 for w64; compute padding and size of sse reg save area. + (ix86_emit_save_regs, ix86_emit_save_regs_using_mov): Save only + general purpose regs. + (ix86_emit_save_sse_regs_using_mov): New. + (ix86_expand_prologue): Save SSE regs if needed. + (ix86_emit_restore_regs_using_mov): Use only general purpose regs. + (ix86_emit_restore_sse_regs_using_mov): New. + (ix86_expand_epilogue): Save SSE regs if needed. + +2009-01-06 Jan Hubicka <jh@suse.cz> + Kai Tietz <kai.tietz@onevision.com> + + * config/i386/i386.h (ACCUMULATE_OUTGOING_ARGS): Enable for MSABI + * config/i386/i386.c (init_cumulative_args): Disallow calls of MSABI + functions when accumulate outgoing args is off. + +2009-01-06 H.J. Lu <hongjiu.lu@intel.com> + + PR bootstrap/38742 + * ira-color.c (ira_reuse_stack_slot): Check ENABLE_IRA_CHECKING + before using pseudos_have_intersected_live_ranges_p. + + * ira-int.h (ira_assert): Always define. + +2009-01-06 H.J. Lu <hongjiu.lu@intel.com> + + AVX Programming Reference (December, 2008) + * config/i386/avxintrin.h (_mm_permute2_pd): Removed. + (_mm256_permute2_pd): Likewise. + (_mm_permute2_ps): Likewise. + (_mm256_permute2_ps): Likewise. + * config/i386/i386.md (UNSPEC_VPERMIL2): Likewise. + * config/i386/sse.md (avx_vpermil2<mode>3): Likewise. + + * config/i386/i386.c (ix86_builtins): Remove + IX86_BUILTIN_VPERMIL2PD, IX86_BUILTIN_VPERMIL2PS, + IX86_BUILTIN_VPERMIL2PD256 and IX86_BUILTIN_VPERMIL2PS256. + (ix86_builtin_type): Remove V8SF_FTYPE_V8SF_V8SF_V8SI_INT, + V4DF_FTYPE_V4DF_V4DF_V4DI_INT, V4SF_FTYPE_V4SF_V4SF_V4SI_INT + and V2DF_FTYPE_V2DF_V2DF_V2DI_INT. + (bdesc_args): Remove __builtin_ia32_vpermil2pd, + __builtin_ia32_vpermil2ps, __builtin_ia32_vpermil2pd256 and + __builtin_ia32_vpermil2ps256. + (ix86_init_mmx_sse_builtins): Updated. + (ix86_expand_args_builtin): Likewise. + +2009-01-05 John David Anglin <dave.anglin@nrc-cnrc.gc.ca> + + * pa.c (output_call): Relocate non-jump insns in the delay slot of + long absolute calls when generating PA 2.0 code. + +2009-01-05 Vladimir Makarov <vmakarov@redhat.com> + + PR rtl-optimization/38583 + * params.h (IRA_MAX_CONFLICT_TABLE_SIZE): New macro. + + * params.def (ira-max-conflict-table-size): New. + + * doc/invoke.texi (ira-max-conflict-table-size): Decribe. + + * ira.h (ira_conflicts_p): New external definition. + + * ira-conflicts.c (build_conflict_bit_table): Do not build too big + table. Report this. Return result of building. + (ira_build_conflicts): Use ira_conflicts_p. Check result of + building conflict table. + + * ira-color.c (fast_allocation): Use num instead of ira_allocnos_num. + (ira_color): Use ira_conflicts_p. + + * global.c: Include ira.h. + (pseudo_for_reload_consideration_p, build_insn_chain): Use + ira_conflicts_p. + + * Makefile.in (global.o): Add ira.h. + + * ira-build.c (mark_all_loops_for_removal, + propagate_some_info_from_allocno): New. + (remove_unnecessary_allocnos): Call + propagate_some_info_from_allocno. + (remove_low_level_allocnos): New. + (remove_unnecessary_regions): Add parameter. Call + mark_all_loops_for_removal and remove_low_level_allocnos. Pass + parameter to remove_unnecessary_regions. + (ira_build): Remove all regions but root if the conflict table was + not built. Update conflict hard regs for allocnos crossing calls. + + * ira.c (ira_conflicts_p): New global. + (ira): Define and use ira_conflicts_p. + + * reload1.c (compute_use_by_pseudos, reload, count_pseudo, + count_spilled_pseudo, find_reg, alter_reg, finish_spills, + emit_input_reload_insns, delete_output_reload): Use ira_conflicts_p. + +2009-01-06 Ben Elliston <bje@au.ibm.com> + + * gengtype-lex.l (YY_NO_INPUT): Define. + +2009-01-05 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR c/34911 + * c-common.c (handle_vector_size_attribute): Also reject + BOOLEAN_TYPE types. + +2009-01-05 Sebastian Pop <sebastian.pop@amd.com> + + PR tree-optimization/38492 + * graphite.c (rename_map_elt, debug_rename_elt, + debug_rename_map_1, debug_rename_map, new_rename_map_elt, + rename_map_elt_info, eq_rename_map_elts, + get_new_name_from_old_name, bb_in_sese_p): Moved around. + (sese_find_uses_to_rename_use): Renamed sese_build_livein_liveouts_use. + (sese_find_uses_to_rename_bb): Renamed sese_build_livein_liveouts_bb. + (sese_build_livein_liveouts): New. + (new_sese, free_sese): New. + (new_scop): Call new_sese. + (free_scop): Call free_sese. + (rename_variables_from_edge, rename_phis_end_scop): Removed. + (register_old_new_names): Renamed register_old_and_new_names. + (register_scop_liveout_renames, add_loop_exit_phis, + insert_loop_close_phis, struct igp, + default_liveout_before_guard, add_guard_exit_phis, + insert_guard_phis, copy_renames): New. + (translate_clast): Call insert_loop_close_phis and insert_guard_phis. + (sese_add_exit_phis_edge): Renamed scop_add_exit_phis_edge. + (rewrite_into_sese_closed_ssa): Renamed scop_insert_phis_for_liveouts. + (scop_adjust_phis_for_liveouts): New. + (gloog): Call scop_adjust_phis_for_liveouts. + + * graphite.h (struct sese): Documented. Added fields liveout, + num_ver and livein. + (SESE_LIVEOUT, SESE_LIVEIN, SESE_LIVEIN_VER, SESE_NUM_VER): New. + (new_sese, free_sese, sese_build_livein_liveouts): Declared. + (struct scop): Added field liveout_renames. + (SCOP_LIVEOUT_RENAMES): New. + +2009-01-05 Harsha Jagasia <harsha.jagasia@amd.com> + + PR tree-optimization/38510 + * graphite.c (recompute_all_dominators): Call mark_irreducible_loops. + (translate_clast): Call recompute_all_dominators before + graphite_verify. + (gloog): Call recompute_all_dominators before graphite_verify. + +2009-01-05 Harsha Jagasia <harsha.jagasia@amd.com> + Jan Sjodin <jan.sjodin@amd.com> + + PR tree-optimization/38500 + * graphite.c (create_sese_edges): Call fix_loop_structure after + splitting blocks. + +2009-01-05 Joel Sherrill <joel.sherrill@oarcorp.com> + + * config.gcc: Add m32r*-*-rtems*. + * config/m32r/rtems.h: New file. + +2009-01-05 Ben Elliston <bje@au.ibm.com> + + * Makefile.in (.po.gmo): Use mkinstalldirs, not test -d || mkdir. + (.po.pox): Likewise. + (po/gcc.pot): Likewise. + +2009-01-04 David S. Miller <davem@davemloft.net> + + * config/sparc/sparc.h (SECONDARY_MEMORY_NEEDED_RTX): Delete. + (STARTING_FRAME_OFFSET): Always set to zero. + +2009-01-04 Richard Sandiford <rdsandiford@googlemail.com> + + * tree.def (LSHIFT_EXPR, RSHIFT_EXPR): Add commentary. + * tree-cfg.c (verify_gimple_assign_binary): Allow shifts of + fixed-point types, and vectors of the same. + +2009-01-04 Richard Sandiford <rdsandiford@googlemail.com> + + * config/mips/sync.md (*mb_barrier): Rename to... + (*memory_barrier): ...this. + +2009-01-04 Jonathan Wakely <jwakely.gcc@gmail.com> + + * doc/extend.texi (Function Attributes): Move @cindex after @item + for 'artificial' and 'flatten'. Fix grammar for 'externally_visible' + and put in alphabetical order. Fix 'target' name and put in order. + * doc/invoke.texi (-Wstrict-null-sentinel, -fipa-matrix-reorg): Fix + typos. + +2009-01-04 Uros Bizjak <ubizjak@gmail.com> + + * config/s390/s390.md (UNSPEC_MB): Rename from UNSPECV_MB. + (memory_barrier): Expand as unspec instead of unspec_volatile. + Remove mem:BLK from insn operands. Use Pmode scratch register. + (*memory_barrier): Define as unspec instead of unspec_volatile. + Use (match_dup 0) as input operand. + + * config/sparc/sparc.md (UNSPEC_MEMBAR): Rename from UNSPECV_MEMBAR. + * config/sparc/sync.md (memory_barrier): Expand as unspec instead of + unspec_volatile. Remove mem:BLK from insn operands. Use Pmode + scratch register. Remove operand 1. + (*stbar): Define as unspec instead of unspec_volatile. + Use (match_dup 0) as input operand, remove (const_int 8). + (*membar): Define as unspec instead of unspec_volatile. + Use (match_dup 0) as input operand, remove input operand 2. + + * config/xtensa/xtensa.md (UNSPEC_MEMW): Rename from UNSPECV_MEMW. + (memory_barrier): Expand as unspec instead of unspec_volatile. + Remove mem:BLK from insn operands. Use Pmode scratch register. + (*memory_barrier): Define as unspec instead of unspec_volatile. + Use (match_dup 0) as input operand. + + * config/ia64/sync.md (memory_barrier): Redefine as expander pattern. + Remove mem:BLK from insn operands. Use Pmode scratch register. + Set volatile flag on operand 0. + (*memory_barrier): New insn pattern. + + * config/rs6000/sync.md (memory_barrier): Remove mem:BLK from + insn operands. + (*memory_barrier): Use (match_dup 0) as input operand. + + * config/mips/sync.md (memory_barrier): Redefine as expander pattern. + Remove mem:BLK from insn operands. Use Pmode scratch register. + Set volatile flag on operand 0. + (*mb_internal): New insn pattern. + + * config/alpha/sync.md (*memory_barrier): Rename from *mb_internal. + +2009-01-04 Steven Bosscher <steven@gcc.gnu.org> + + PR middle-end/38586 + * function.c (struct temp_slot): Move to the section of the file + that deals with temp slots. Remove field 'address'. + (temp_slot_address_table): New hash table of address -> temp slot. + (struct temp_slot_address_entry): New struct, items for the table. + (temp_slot_address_compute_hash, temp_slot_address_hash, + temp_slot_address_eq, insert_temp_slot_address): Support functions + for the new table. + (find_temp_slot_from_address): Rewrite to use the new hash table. + (remove_unused_temp_slot_addresses): Remove addresses of temp + slots that have been made available. + (remove_unused_temp_slot_addresses_1): Call-back for htab_traverse, + worker function for remove_unused_temp_slot_addresses. + (assign_stack_temp_for_type): Don't clear the temp slot address list. + Add the temp slot address to the address -> temp slot map. + (update_temp_slot_address): Update via insert_temp_slot_address. + (free_temp_slots): Call remove_unused_temp_slot_addresses. + (pop_temp_slots): Likewise. + (init_temp_slots): Allocate the address -> temp slot map, or empty + the map if it is already allocated. + (prepare_function_start): Initialize temp slot processing. + +2009-01-04 Steven Bosscher <steven@gcc.gnu.org> + + PR middle-end/38584 + * cfgexpand.c (estimate_stack_frame_size): Simplify the estimate: + Calculate the size of all stack vars assuming no packing of stack + vars will happen, replacing a quadratic algorithm with a linear one. + +2009-01-03 Jakub Jelinek <jakub@redhat.com> + + PR target/38707 + * expmed.c (store_bit_field_1): Don't modify op0 if movstrict insn + can't be used. + +2009-01-03 Diego Novillo <dnovillo@google.com> + + * doc/contrib.texi: Update contributions. + +2009-01-03 Jakub Jelinek <jakub@redhat.com> + + PR c++/38705 + * builtins.c (fold_builtin_memory_op): Give up if either operand + is volatile. Set srctype or desttype to non-qualified version + of the other type. + + PR c/38700 + * builtins.c (fold_builtin_expect): Only check DECL_WEAK for VAR_DECLs + and FUNCTION_DECLs. + +2009-01-02 Kenneth Zadeck <zadeck@naturalbridge.com> + + PR rtl-optimization/35805 + * df-problems.c (df_lr_finalize): Add recursive call to resolve lr + problem if fast dce is able to remove any instructions. + * dce.c (dce_process_block): Fix dump message. + +2009-01-02 Mark Mitchell <mark@codesourcery.com> + + PR 33649 + * tree-ssa-pre.c (compute_antic): Correct loop bounds. + +2009-01-02 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/38690 + * tree-flow.h (op_code_prio, op_prio): New prototypes. + * tree-pretty-print.c (op_code_prio): New function. + (op_prio): No longer static. Use op_code_prio. + * gimple-pretty-print.c (dump_unary_rhs, dump_binary_rhs): + Use op_prio and op_code_prio to determine if () should be + printed around operand(s) or not. + + * gimple-pretty-print.c (dump_unary_rhs, dump_binary_rhs, + dump_gimple_call, dump_gimple_switch, dump_gimple_cond, + dump_gimple_label, dump_gimple_try, dump_symbols, dump_gimple_phi, + dump_gimple_mem_ops, dump_bb_header, dump_bb_end, pp_cfg_jump): Use + pp_character instead of pp_string for single letter printing. + +2009-01-02 Richard Sandiford <rdsandiford@googlemail.com> + + * doc/extend.texi: Fix '#pragma GCC option' typo. + +2009-01-02 Richard Guenther <rguenther@suse.de> + + * doc/install.texi (--enable-checking): Mention different + default for stage1. + (--enable-stage1-checking): Document. + +2009-01-01 Andrew Pinski <pinskia@gmail.com> + + PR middle-end/30142 + * tree-cfg.c (verify_expr): Add INDIRECT_REF case. Change MODIFY_EXPR + case to be an error. + +2009-01-02 Ben Elliston <bje@au.ibm.com> + + * config/fp-bit.h (pack_d): Constify argument. + * config/fp-bit.c (makenan): Constify return type. Remove casts. + (isnan): Constify argument. + (isinf): Likewise. + (iszero): Likewise. + (pack_d): Likewise. + (_fpadd_parts): Constify return type. + (_fpmul_parts): Likewise. + (_fpdiv_parts): Likewise. + +2009-01-01 Jakub Jelinek <jakub@redhat.com> + + PR c/36489 + * c-typeck.c (add_pending_init): Add IMPLICIT argument. Only + warn about overwriting initializer with side-effects or + -Woverride-init if !IMPLICIT. + (output_init_element): Likewise. Pass IMPLICIT down to + add_pending_init. + (process_init_element): Add IMPLICIT argument. Pass it down + to output_init_element. + (push_init_element, pop_init_level, set_designator): Adjust + process_init_element callers. + (set_nonincremental_init, set_nonincremental_init_from_string): + Adjust add_pending_init callers. + (output_pending_init_elements): Adjust output_init_element callers. + * c-tree.h (process_init_element): Adjust prototype. + * c-parser.c (c_parser_initelt, c_parser_initval): Adjust + process_init_element callers. + + +Copyright (C) 2009 Free Software Foundation, Inc. + +Copying and distribution of this file, with or without modification, +are permitted in any medium without royalty provided the copyright +notice and this notice are preserved. |