]> oss.titaniummirror.com Git - msp430-gcc.git/blobdiff - gcc/ChangeLog-2007
Imported gcc-4.4.3
[msp430-gcc.git] / gcc / ChangeLog-2007
diff --git a/gcc/ChangeLog-2007 b/gcc/ChangeLog-2007
new file mode 100644 (file)
index 0000000..e76781b
--- /dev/null
@@ -0,0 +1,34171 @@
+2007-12-31  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR driver/33772
+       * collect2.c (SHLIB_SUFFIX): Define if not defined.
+       (write_c_file_stat): Use SHLIB_SUFFIX.
+       * som.h (SHLIB_SUFFIX): Define.
+       * doc/tm.texi (SHLIB_SUFFIX): Document.
+
+2007-12-29  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/sse.md ("*divv4sf3"): Rename to "sse_divv4sf3".
+       ("*sse_rsqrtv4sf2"): Export.
+       ("*sse_sqrtv4sf2"): Ditto.
+       * config/i386/i386.c (enum ix86_builtins) [IX86_BUILTIN_RSQRTPS_NR,
+       IX86_BUILTIN_SQRTPS_NR]: New constants.
+       (struct builtin_description) [IX86_BUILTIN_DIVPS]: Use
+       CODE_FOR_sse_divv4sf3.
+       [IX86_BUILTIN_SQRTPS]: Use CODE_FOR_sse_sqrtv4sf2.
+       [IX86_BUILTIN_SQRTPS_NR]: New.
+       [IX86_BUILTIN_RSQRTPS_NR]: Ditto.
+       (ix86_init_mmx_sse_builtins): Initialize __builtin_ia32_rsqrtps_nr and
+       __builtin_ia32_sqrtps_nr.
+       (ix86_builtin_vectorized_function): Convert BUILT_IN_SQRTF to
+       IX86_BUILTIN_SQRTPS_NR.
+       (ix86_builtin_reciprocal): Convert IX86_BUILTIN_SQRTPS_NR to
+       IX86_BUILTIN_RSQRTPS_NR.
+
+2007-12-27  Brian Dessent  <brian@dessent.net>
+
+       * doc/invoke.texi (Optimize Options): Add missing opindex for
+       -fno-toplevel-reorder.
+
+2007-12-27  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/34591
+       * tree-vect-trasnform.c (vect_estimate_min_profitable_iters): Skip
+       stmts (including reduction stmts) that are not live.
+
+2007-12-27  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/34281
+       * config/arm/arm.c (arm_setup_incoming_varargs): If last named
+       argument needs double word alignment and cum->nregs is odd, account
+       for the inserted padding.
+
+       PR debug/34535
+       * tree-mudflap.c (mf_make_builtin): Make decl artificial
+       and don't emit debug info for it.
+
+2007-12-26  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.h (LINK_SPEC, CRT_BINUTILS_SPECS): Move AT90USB82 
+       and AT90USB162 devices from 'avr5' to 'avr35' architecture.
+       (ASM_SPEC): Add 'avr35' architecture.
+       * config/avr/avr.c (avr_mcu_types): Move AT90USB82 and AT90USB162 
+       devices from 'avr5' to 'avr35' architecture.
+       (avr_arch_types): Add "avr23" entries.
+       (avr_arch): Add 'ARCH_AVR35'.
+       * config/avr/t-avr (MULTILIB_OPTIONS, MULTILIB_DIRNAMES): Add 'avr35'.
+       (MULTILIB_MATCHES): Move AT90USB82 and AT90USB162 devices from 'avr5'
+       to 'avr35' architecture.
+
+2007-12-22  David Daney  <ddaney@avtrex.com>
+
+       * doc/install.texi (disable-libgcj-bc): Document new option.
+
+2007-12-21  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * config/pa/pa.c (hppa_legitimize_address): Use INT14_OK_STRICT in
+       mask selection.
+
+       PR target/34525
+       * pa.c (legitimize_pic_address): Emit insn to load function label
+       forced to memory.
+
+2007-12-21  Andrew Pinski  <pinskia@gmail.com>
+       Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/8835
+       * config/mcore/mcore.c (mcore_function_value): Call promote_mode
+       instead of PROMOTE_MODE.
+
+2007-12-21  Sebastian Pop  <sebastian.pop@amd.com>
+
+       * lambda-code.c (lambda_loopnest_to_gcc_loopnest): Fix typo.
+
+2007-12-21  Sebastian Pop  <sebastian.pop@amd.com>
+
+       * tree-data-ref.c (signed_type_for_types): New.
+       (affine_fn_op): Use signed_type_for_types and signed_type_for instead
+       of long_integer_type_node.
+       (analyze_ziv_subscript): Same.
+       (analyze_siv_subscript_cst_affine): Same.
+       (analyze_miv_subscript): Same.
+       (omega_setup_subscript): Same.
+
+2007-12-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_emit_loadgp): Replace gen_* calls with
+       separate gen_*_si and gen_*_di calls.  Pass pic_offset_table_rtx
+       as the first argument.
+       * config/mips/mips.md (loadgp_newabi, loadgp_absolute)
+       (loadgp_rtp): Rename to...
+       (loadgp_newabi_<mode>, loadgp_absolute<mode>, loadgp_rtp<mode>):
+       ...these.  Add modes to all operands.  Add the target register
+       as an operand.  Combine loadgp_rtp<mode> with its splitter.
+
+2007-12-20  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.md (fix_return_addr): Remove.
+       * config/xtensa/xtensa-protos.h (xtensa_initialize_trampoline): New.
+       (xtensa_trampoline_template): New.
+       * config/xtensa/xtensa.c (MIN_FRAME_SIZE): Moved here from xtensa.h.
+       (xtensa_return_addr): Expand to standard Xtensa insns instead of
+       fix_return_addr.  Get high bits from a local label.
+       (xtensa_trampoline_template): New function with code moved from
+       TRAMPOLINE_TEMPLATE in xtensa.h.  Use L32R instead of CALL0 except
+       when using CONST16 or absolute-mode literals.
+       (xtensa_initialize_trampoline): New function with code moved from
+       INITIALIZE_TRAMPOLINE in xtensa.h.  Use different offsets depending
+       on which trampoline version is used.
+       * config/xtensa/lib2funcs.S (TRAMPOLINE_SIZE): Add comment.
+       * config/xtensa/xtensa.h (TARGET_ABSOLUTE_LITERALS): Define.
+       (MIN_FRAME_SIZE): Moved to xtensa.c.
+       (TRAMPOLINE_TEMPLATE): Use xtensa_trampoline_template.
+       (TRAMPOLINE_SIZE): Two versions of the trampoline have different sizes.
+       (INITIALIZE_TRAMPOLINE): Use xtensa_initialize_trampoline.
+       * config/xtensa/ieee754-df.S (XCHAL_NO_MUL): Define.
+       (__muldf3): Use CALL12 instead of CALL0 to invoke .Lmul_mulsi3
+       helper when not using the CALL0 ABI.  Change .Lmul_mulsi3 to match.
+       * config/xtensa/lib1funcs.asm (__umulsidi3): Likewise.
+       * config/xtensa/ieee754-sf.S (__mulsf3): Likewise.
+       
+2007-12-20  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/34459
+       * tree-ssa-dse.c (dse_optimize_stmt): Don't eliminate store if
+       USE_STMT not only stores into the same object as STMT, but might
+       read it too.
+
+2007-12-19  Sebastian Pop  <sebastian.pop@amd.com>
+
+       PR tree-optimization/34413
+       * tree-data-ref.c (affine_fn_op, analyze_ziv_subscript,
+       analyze_siv_subscript_cst_affine, analyze_miv_subscript,
+       omega_setup_subscript): Use long_integer_type_node instead of
+       integer_type_node.
+
+2007-12-19  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR target/34525
+       * pa.c (legitimize_pic_address): Force function labels into memory.
+
+2007-12-19  Zdenek Dvorak  <ook@ucw.cz>
+
+       * omp-low.c (build_omp_regions_1): Recognition of combined parallels
+       moved ...
+       (expand_omp): ... here.
+
+2007-12-19  Zdenek Dvorak  <ook@ucw.cz>
+
+       PR tree-optimization/34355
+       * tree-parloops.c (take_address_of): Handle expresions
+       instead of just variables.
+       (eliminate_local_variables_1): Force whole invariant
+       address to ssa name.
+
+2007-12-19  Alexander Monakov  <amonakov@ispras.ru>
+           Revital Eres  <eres@il.ibm.com>
+
+       * modulo-sched.c (generate_reg_moves): Insert the reg-moves
+       right before the notes which precedes the insn, if they exists.
+       (loop_canon_p): Add dump info.
+       (sms_schedule): Likewise.
+
+2007-12-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * tree.h (set_decl_incoming_rtl): Add a by_reference_p parameter.
+       * emit-rtl.c (set_decl_incoming_rtl): Likewise.  Don't set the
+       rtl's register attributes when the parameter is true.
+       * function.c (assign_parms_unsplit_complex, assign_parms)
+       (expand_function_start): Update calls to set_decl_incoming_rtl.
+
+2007-12-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * rtl.def (SUBREG): Update comments.
+       * rtl.h (reg_attrs): Be explicit about the type of offset used.
+       (set_reg_attrs_from_mem): Rename to...
+       (set_reg_attrs_from_value): ...this.
+       (adjust_reg_mode, byte_lowpart_offset): Declare.
+       * emit-rtl.c (byte_lowpart_offset): New function.
+       (update_reg_offset): Remove special offset handling for big-endian
+       targets.
+       (gen_rtx_REG_offset, gen_reg_rtx_offset): Explicitly say that the
+       offset parameter is added to REG_OFFSET.
+       (adjust_reg_mode): New function.
+       (set_reg_attrs_for_mem): Rename to...
+       (set_reg_attrs_for_value): ...this and generalize to all values.
+       If the register is a lowpart of the value, adjust the offset
+       accordingly.
+       (set_reg_attrs_for_parm): Update after the above renaming.
+       (set_reg_attrs_for_decl_rtl): New function, split out from
+       set_decl_incoming_rtl.  Set the offset of plain REGs to the
+       offset of the REG's mode from the decl's.  Assert that all
+       subregs are lowparts and handle their inner registers in the
+       same way as plain REGs.
+       (set_decl_rtl, set_incoming_decl_rtl): Use reg_attrs_for_decl_rtl.
+       (subreg_lowpart_offset): Explicitly say that the returned offset
+       is a SUBREG_BYTE.
+       * combine.c (do_SUBST_MODE, try_combine, undo_all): Use adjust_reg_mode
+       instead of PUT_MODE.
+       * final.c (alter_subreg): Fix/update argument to gen_rtx_REG_offset.
+       * config/ia64/ia64.c (ia64_expand_load_address): Likewise.
+       * regclass.c (reg_scan_mark_refs): Use set_reg_attrs_from_value.
+       * reload.c (find_reloads_subreg_address): Call set_mem_offset
+       when offseting a MEM.
+       * var-tracking.c (offset_valid_for_tracked_p): Delete.
+       (mode_for_reg_attrs): Replace with...
+       (track_loc_p): ...this new function.  Return the mode and offset
+       to the caller, checking that the latter is valid.  If the rtx is
+       a paradoxical lowpart of the decl, use the decl's mode instead.
+       Do the same when storing to a register that contains the entire decl.
+       (var_lowpart): Use byte_lowpart_offset rather than
+       subreg_lowpart_offset when adjusting the offset attribute.
+       (count_uses, add_uses, add_stores): Use track_reg_p instead of
+       REG_EXPR, MEM_EXPR, REG_OFFSET, INT_MEM_OFFSET, track_expr_p,
+       offset_valid_for_tracked_p and mode_for_reg_attrs.  Generate
+       lowparts for MEMs as well as REGs.
+       (vt_add_function_parameters): When obtaining the information from
+       the decl_rtl, adjust the offset to match incoming.  Use track_loc_p
+       and var_lowpart.
+
+2007-12-18  Sebastian Pop  <sebastian.pop@amd.com>
+
+       PR tree-optimization/34123
+       * lambda-code.c (can_duplicate_iv): New.
+       (cannot_convert_modify_to_perfect_nest): New.
+       (cannot_convert_bb_to_perfect_nest): New.
+       (can_convert_to_perfect_nest): Split up.
+
+2007-12-18  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/mips.md (clear_hazard): Use PRINT_OPERAND punctuation
+       instead of .set push and .set pop.
+
+2007-12-18  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/33474
+       * config/bfin/bfin.c (bfin_adjust_cost): Dig into PARALLELs to find
+       the SET.
+
+2007-12-18  Razya Ladelsky <razya@il.ibm.com>
+
+       * tree-parloops.c (reduiction_info): Change documentation of
+       reduction_initial field.
+       (initialize_reductions): Remove creation of reduction_initial variable.
+       (create_loads_for_reductions): don't join reduction_initial to
+       the loaded value.
+
+2007-12-18  Kaz Kylheku  <kaz@zeugmasystems.com>
+
+       PR rtl-optimization/34456
+       * resource.c (mark_set_resources): Use regs_invalidated_by_call
+       rather than call_used_regs and global_regs.
+
+2007-12-18  Jakub Jelinek  <jakub@redhat.com>
+
+       PR rtl-optimization/34490
+       * simplify-rtx.c (simplify_const_relational_operation): If !sign,
+       don't reduce mmin/mmax using num_sign_bit_copies.
+
+2007-12-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * doc/install.texi: Change recommended MPFR from 2.2.1 -> 2.3.0.
+
+2007-12-17  Andreas Schwab  <schwab@suse.de>
+
+       * doc/invoke.texi (Warning Options): Use @itemx.
+
+2007-12-17  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vectorizer.h (verbosity_levels): Add new verbosity level
+       REPORT_COST.
+       * tree-vect-transform.c (vect_estimate_min_profitable_iters): Change
+       verbosity level to REPORT_COST.
+       (vect_model_reduction_cost): Likewise.
+       (vect_model_induction_cost): Likewise.
+       (vect_model_simple_cost): likewise.
+       (vect_model_store_cost): likewise.
+       (vect_model_load_cost): likewise.
+       (conservative_cost_threshold): Likewise. Remove print.
+
+2007-12-17  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * doc/tm.texi (TARGET_SECONDARY_RELOAD): Fix typos.
+
+2007-12-17  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/34506
+       * c-parser.c (c_parser_omp_all_clauses): Accept optional comma
+       in between clauses.
+
+2007-12-17  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/34445
+       * tree-vect-trasnform.c (vect_estimate_min_profitable_iters): Skip 
+       stmts (including live stmts) that are not relevant.
+
+2007-12-17  Jack Howarth  <howarth@bromo.med.uc.edu>
+
+       PR target/34025
+       * config/i386/t-crtpc: Add $(MULTILIB_CFLAGS).
+       * config/i386/t-crtfm: Likewise.
+
+2007-12-17  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (WIDEST_HARDWARE_FP_SIZE): Define.
+
+2007-12-16  Uros Bizjak  <ubizjak@gmail.com>
+
+       * tree-vect-transform.c (conservative_cost_threshold): Add missing
+       space to "not vectorized" message.
+
+2007-12-16  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR rtl-optimization/34415
+       * df.h (DF_LR_IN, DF_LR_OUT): Update comments.
+       * resource.c (mark_target_live_regs): Use DF_LR_IN rather than
+       df_get_live_in.  Don't handle pseudos.
+
+2007-12-16  Jakub Jelinek  <jakub@redhat.com>
+
+       PR bootstrap/34003
+       * c-decl.c (merge_decls): Copy RTL from olddecl to newdecl.
+       * config/pa/pa.c (pa_encode_section_info): If !first, preserve
+       SYMBOL_FLAG_REFERENCED flag.
+
+2007-12-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree.c (type_hash_add): Fix whitespace.
+
+2007-12-15  Hans-Peter Nilsson  <hp@axis.com>
+
+       Add CRIS v32 support.  Fix -mcc-init.
+       * config.gcc: Make crisv32-* have cpu_type cris.  Handle
+       crisv32-*-elf and crisv32-*-none like cris-*-elf and cris-*-none
+       but without multilibs and with target_cpu_default=32.
+       (crisv32-*-linux*): Handle as cris-*-linux*.  Set
+       target_cpu_default to 32 and 10 accordingly.
+       * config/cris/cris.c (ASSERT_PLT_UNSPEC): Remove unused macro.
+       (cris_movem_load_rest_p, cris_store_multiple_op_p): Remove FIXME.
+       Change regno_dir and regno only if !TARGET_V32.
+       (cris_conditional_register_usage): If TARGET_V32, set
+       reg_alloc_order as per REG_ALLOC_ORDER_V32 and make
+       CRIS_ACR_REGNUM non-fixed.
+       (cris_print_base): Add gcc_assert for post_inc on CRIS_ACR_REGNUM.
+       (cris_print_operand) <case 'Z', case 'u'>: New cases.
+       <case REG of case 'H'>: Allow for CRIS_SRP_REGNUM.
+       (cris_reload_address_legitimized): Always return false for TARGET_V32.
+       (cris_register_move_cost): New function, guts from
+       REGISTER_MOVE_COST adjusted for CRIS v32.
+       (cris_normal_notice_update_cc): New function split out from...
+       (cris_notice_update_cc): Set cc_status.flags CC_REVERSED for
+       TARGET_CCINIT.  Call cris_normal_notice_update_cc for CC_REV,
+       CC_NOOV32 and CC_NORMAL, but set cc_status.flags CC_NO_OVERFLOW
+       for CC_NOOV32 and TARGET_V32.
+       (cris_simple_epilogue): Always return false for TARGET_V32 if
+       cris_return_address_on_stack yields true.
+       (cris_cc0_user_requires_cmp): New function.
+       (cris_valid_pic_const): Add argument ANY_OPERAND.  All callers
+       changed.  Handle CRIS_UNSPEC_PLT_PCREL and CRIS_UNSPEC_PCREL.
+       (cris_asm_output_case_end): New function, guts from
+       ASM_OUTPUT_CASE_END adjusted for CRIS v32.
+       (cris_override_options): Adjust for CRIS v32.  Mask out
+       TARGET_SIDE_EFFECT_PREFIXES and TARGET_MUL_BUG if v32.
+       (cris_asm_output_mi_thunk, cris_expand_epilogue)
+       (cris_gen_movem_load, cris_emit_movem_store)
+       (cris_expand_pic_call_address, cris_asm_output_symbol_ref)
+       (cris_asm_output_label_ref, cris_output_addr_const_extra): Adjust
+       for CRIS v32.
+       (cris_split_movdx): Copy re-used MEM.
+       * config/cris/t-elfmulti: Add multilib v32 for -march=v32.
+       * config/cris/predicates.md
+       ("cris_general_operand_or_pic_source"): New predicate.
+       ("cris_general_operand_or_plt_symbol"): Replace by...
+       ("cris_nonmemory_operand_or_callable_symbol"): New predicate.
+       * config/cris/linux.h: Sanity-check TARGET_CPU_DEFAULT for
+       presence and contents.
+       (CRIS_SUBTARGET_DEFAULT_ARCH): New macro, MASK_AVOID_GOTPLT for
+       v32, 0 otherwise.
+       (CRIS_CPP_SUBTARGET_SPEC, CRIS_CC1_SUBTARGET_SPEC,
+       CRIS_ASM_SUBTARGET_SPEC): Adjust for different TARGET_CPU_DEFAULT.
+       (CRIS_SUBTARGET_DEFAULT): Add CRIS_SUBTARGET_DEFAULT_ARCH.
+       * config/cris/cris.h: Sanity-check TARGET_CPU_DEFAULT for contents.
+       (CRIS_DEFAULT_TUNE, CRIS_ARCH_CPP_DEFAULT)
+       (CRIS_DEFAULT_ASM_ARCH_OPTION): New macros.
+       (CRIS_CC1_SUBTARGET_SPEC): Change default tuning to use
+       CRIS_DEFAULT_TUNE. 
+       (CRIS_CPP_SUBTARGET_SPEC): Ditto.  Add CRIS_ARCH_CPP_DEFAULT.
+       (ASM_SPEC): Add sanity-check erroring out when both -march= and
+       -mcpu= are specified.  Pass on either as --march=v32.
+       (CRIS_ASM_SUBTARGET_SPEC): When neither -march= or -mcpu= are
+       specified, pass on CRIS_DEFAULT_ASM_ARCH_OPTION.
+       (CRIS_CPU_V32): New macro.
+       [!TARGET_CPU_DEFAULT]: Default-define as CRIS_CPU_BASE.
+       [!TARGET_DEFAULT, TARGET_CPU_DEFAULT == 32]: Move default
+       TARGET_DEFAULT definition after new TARGET_CPU_DEFAULT definition.
+       Define v32-adjusted TARGET_DEFAULT.
+       (CRIS_DEFAULT_CPU_VERSION): Change to TARGET_CPU_DEFAULT from
+       CRIS_CPU_BASE.
+       (TARGET_V32): New macro.
+       (REG_ALLOC_ORDER_V32): New macro.
+       (HARD_REGNO_MODE_OK): Do not allow larger-than-register-size modes
+       into CRIS_ACR_REGNUM.
+       (enum reg_class): New classes ACR_REGS, SPEC_ACR_REGS, GENNONACR_REGS
+       and SPEC_GENNONACR_REGS.
+       (REG_CLASS_NAMES, REG_CLASS_CONTENTS): Adjust for new classes.
+       (REGNO_REG_CLASS): Give ACR_REGS for CRIS_ACR_REGNUM.
+       (MODE_CODE_BASE_REG_CLASS): Define, give for OCODE POST_INC
+       GENNONACR_REGS, BASE_REG_CLASS otherwise.
+       (REG_CLASS_FROM_LETTER): 'a' is for ACR_REGS.
+       (REGNO_MODE_CODE_OK_FOR_BASE_P): Define, refusing OCODE POST_INC
+       for CRIS_ACR_REGNUM.
+       (PREFERRED_RELOAD_CLASS): Keep ACR_REGS as preferred.
+       (HARD_REGNO_RENAME_OK): Refuse CRIS_ACR_REGNUM as TO.
+       (EXTRA_CONSTRAINT): New constraint 'U'.
+       (TRAMPOLINE_TEMPLATE, TRAMPOLINE_SIZE, INITIALIZE_TRAMPOLINE)
+       (ASM_OUTPUT_ADDR_DIFF_ELT): Adjust for CRIS v32.
+       (BASE_OR_AUTOINCR_P): Refuse POST_INC for CRIS_ACR_REGNUM.
+       (SIMPLE_ADDRESS_P): Remove.
+       (GO_IF_LEGITIMATE_ADDRESS): Use BASE_OR_AUTOINCR_P, not redundant
+       SIMPLE_ADDRESS_P.  Make one chained if-else, finishing as
+       non-match after BASE_OR_AUTOINCR_P for TARGET_V32.
+       (REGISTER_MOVE_COST): Just call the new function
+       cris_register_move_cost.
+       (enum cris_pic_symbol_type): Rename cris_gotrel_symbol to
+       cris_rel_symbol.  All users changed.
+       (REGISTER_NAMES): Replace "pc" with "acr".
+       (ADDITIONAL_REGISTER_NAMES): Add "pc" for 15.
+       (ASM_OUTPUT_REG_PUSH): Change to v32-compatible sequence.
+       (ASM_OUTPUT_REG_POP): Change to v32-compatible syntax.
+       (ASM_OUTPUT_CASE_END): Just call the new function
+       cris_asm_output_case_end.
+       * gcc/config/cris/cris.md: Group related constants together, with
+       comments local.
+       (CRIS_UNSPEC_PLT_GOTREL, CRIS_UNSPEC_PLT_PCREL, CRIS_UNSPEC_PCREL)
+       (CRIS_UNSPEC_CASESI): New constants.
+       (CRIS_UNSPEC_PLT): Remove constant.
+       (CRIS_ACR_REGNUM): New constant.
+       ("slottable"): New attr alternatives "has_return_slot" and
+       "has_call_slot".
+       ("cc"): New attr alternatives "noov32" and "rev".
+       ((eq_attr "slottable" "has_call_slot"))
+       ((eq_attr "slottable" "has_return_slot")): New define_delays.
+       ("movdi", "movsi"): Adjust operands for CRIS v32.
+       ("tstdi", "cmpdi", "adddi3", "subdi3", "uminsi3")
+       ("indirect_jump"): Ditto.  Make define_expand.
+       ("*tstdi_non_v32", "*tstdi_v32", "*tst<mode>_cmp")
+       ("*tst<mode>_non_cmp", "*cmpdi_non_v32", "*cmpdi_v32")
+       ("*movdi_v32", "*adddi3_non_v32", "*adddi3_v32")
+       ("*addsi3_non_v32", "*addsi3_v32", "*addhi3_non_v32")
+       ("*addhi3_v32", "*addqi3_non_v32", "*addqi3_v32")
+       ("*subdi3_non_v32", "*subdi3_v32", "*subsi3_non_v32")
+       ("*subsi3_v32", "*sub<mode>3_nonv32", "*sub<mode>3_v32")
+       ("*andqi3_non_v32", "*andqi3_v32", "*iorsi3_non_v32")
+       ("*iorsi3_v32", "*iorhi3_non_v32", "*iorhi3_v32")
+       ("*iorqi3_non_v32", "*iorqi3_v32", "*uminsi3_non_v32")
+       ("*uminsi3_v32", "*indirect_jump_non_v32", "*indirect_jump_v32")
+       ("*expanded_call_v32", "*expanded_call_value_v32"): New patterns,
+       for the corresponding standard name.
+       ("tst<mode>"): Limit to BW and make define_expand.
+       ("tstsi"): Make separate insn, adjusting for CRIS v32.
+       ("*cmp_swapext<mode>"): Adjust for v32.  Specify "rev" for attr "cc".
+       ("cmpsi", "cmp<mode>"): Remove special cases for zero.  Specify
+       attr "cc".
+       ("*btst"): Don't match for TARGET_CCINIT.  Replace test of
+       register with compatible "cmpq 0".  Specify attr "cc".
+       ("*movdi_insn_non_v32"): New pattern, replacing "*movdi_insn" and
+       define_split.
+       (define_split for DI move): Match CRIS v32 only.
+       ("*movsi_got_load", "*movsi_internal", "*addi"): Adjust for CRIS v32.
+       ("load_multiple", "store_multiple", "*addsbw_v32", "*addubw_v32")
+       ("*adds<mode>_v32", "*addu<mode>_v32", "*bound<mode>_v32")
+       ("*casesi_jump_v32", "*expanded_andsi_v32", "*expanded_andhi_v32")
+       ("*extop<mode>si_v32", "*extopqihi_v32", "*andhi_lowpart_v32")
+       ("*andqi_lowpart_v32", "cris_casesi_v32"): New patterns. 
+       ("add<mode>3"): Make addsi3, addhi3 and addqi3 define_expand.
+       ("sub<mode>3"): Ditto subsi3, subhi3 and subqi3.
+       ("ior<mode>3"): Ditto iorsi3, iorhi3 and iorqi3.
+       ("*extopqihi_non_v32"): Replace "*extopqihi".
+       ("*extop<mode>si_non_v32"): Replace "*extop<mode>si".
+       ("*addxqihi_swap_non_v32"): Rename from "*extopqihi_swap", make
+       non-v32 only.
+       ("*extop<mode>si_swap_non_v32"): Ditto "*extop<mode>si_swap".
+       ("*expanded_andsi_non_v32"): Ditto "*expanded_andsi".
+       ("*expanded_andhi_non_v32"): Ditto "*expanded_andhi".
+       ("*andhi_lowpart_non_v32"): Ditto "*andhi_lowpart".
+       ("*andqi_lowpart_non_v32"): Ditto "*andqi_lowpart".
+       ("*expanded_call_non_v32"): Ditto "*expanded_call".  Change from
+       "cris_general_operand_or_plt_symbol" to "general_operand".
+       ("*expanded_call_value_non_v32") Ditto "*expanded_call_value".
+       ("*casesi_adds_w", "mstep_shift", "mstep_mul")
+       ("*expanded_call_side", "*expanded_call_value_side")
+       (op-extend-split, op-extend-split-rx=rz, op-extend-split-swapped)
+       (op-extend-split-swapped-rx=rz, op-extend, op-split-rx=rz)
+       (op-split-swapped, op-split-swapped-rx=rz): Make non-v32 only.
+       ("dstep_mul", "xorsi3", "one_cmplsi2", "<shlr>si3")
+       ("*expanded_<shlr><mode>", "*<shlr><mode>_lowpart", "ashl<mode>3")
+       ("*ashl<mode>_lowpart", "abssi2", "clzsi2", "bswapsi2")
+       ("cris_swap_bits"): Specify "noov32" for attr "cc".
+       ("<su>mulsi3_highpart"): Ditto.  Correct operand 0 to register_operand.
+       ("andqi3"): Make define_expand.
+       ("*return_expanded"): For attr "slottable", change from "has_slot"
+       to "has_return_slot".
+       ("cris_casesi_non_v32"): New pattern, old contents of "casesi".
+       ("casesi"): Divert into "cris_casesi_v32" and "cris_casesi_non_v32".
+       (moversideqi, movemsideqi, mover2side): Require
+       TARGET_SIDE_EFFECT_PREFIXES.
+       (gotplt-to-plt, gotplt-to-plt-side): Change from CRIS_UNSPEC_PLT
+       to CRIS_UNSPEC_PLT_GOTREL.
+       * config/cris/cris-protos.h (cris_register_move_cost)
+       (cris_cc0_user_requires_cmp, cris_asm_output_case_end): Declare.
+
+2007-12-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR debug/7081
+       * dwarf2out.c (dwarf_tag_name): Synchronize with dwarf2.h.
+       (is_type_die): Cover interface types.
+       (class_or_namespace_scope_p): Cover interface and class types.
+       (record_type_tag): New.
+       (gen_inlined_structure_type_die): Use it.
+       (gen_struct_or_union_type_die): Likewise.
+       (prune_unused_types_walk): Cover interface types.
+       * langhooks.h (classify_record): New enum.
+       (classify_record): New member in struct langhooks_for_types.
+       * langhooks-def.h (LANG_HOOKS_CLASSIFY_RECORD): New.
+       (LANGHOOKS_FOR_TYPES_INITIALIZER): Adjust.
+
+2007-12-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       * dwarf2out.c (reference_to_unused): Don't emit strings in
+       initializers just because of debug information.
+       * tree.h (TREE_ASM_WRITTEN): Document use for STRING_CSTs.
+
+2007-12-15  Sebastian Pop  <sebastian.pop@amd.com>
+
+       * tree-scalar-evolution.c (number_of_iterations_for_all_loops): Replace
+       print_loop_ir with print_loops.
+       * tree-flow.h (dot_cfg, debug_loops, debug_loop, debug_loop_num,
+       print_loops, print_loops_bb): Declare.
+       * tree-cfg.c (print_loops_bb): New.
+       (print_loop): Print header, latch, bounds, estimation of iterations.
+       (print_loop_and_siblings): New.
+       (print_loop_ir): Renamed print_loops.
+       (debug_loop_ir): Renamed debug_loops.
+       (debug_loop, debug_loop_num): New.
+
+2007-12-15  Bernhard Fischer  <aldot@gcc.gnu.org>
+
+       * tree-flow-inline.h.c (next_readonly_imm_use): Fix typo in comment.
+
+2007-12-15  Bernhard Fischer  <aldot@gcc.gnu.org>
+
+       * toplev.c (process_options): Fix typo in warning.
+
+2007-12-14  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/29978
+       * config/i386/i386.c (ix86_expand_branch): Optimize LE/LEU/GT/GTU
+       DImode comparisons against constant with all 1's in the lower word.
+
+2007-12-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/sse.md (sse4_2_pcmpestr): Use reg_not_xmm0_operand
+       constraint for operand 2.  Use nonimm_not_xmm0_operand constraint
+       for operand 4.  Update arguments in the call to
+       gen_sse4_2_pcmpestr_cconly.
+       (sse_4_2_pcmpestr_cconly): Renumber insn operands and update insn
+       template accordingly.
+       (sse4_2_pcmpistr): Use reg_not_xmm0_operand constraint for operand2.
+       Use nonimm_not_xmm0_operand constraint for operand 3.  Update
+       arguments in the call to gen_sse4_2_pcmpistr_cconly.
+       (sse_4_2_pcmpistr_cconly): Renumber insn operands and update insn
+       template accordingly.
+
+2007-12-14  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34462
+       * tree-ssa-operands.h (create_ssa_artificial_load_stmt): Add
+       parameter to say whether to unlink immediate uses.
+       * tree-ssa-operands.c (create_ssa_artificial_load_stmt): Do not
+       mark the artificial stmt as modified.  Unlink immediate uses
+       only if requested.
+       * tree-ssa-dom.c (record_equivalences_from_stmt): Update caller.
+       * tree-ssa-pre.c (insert_fake_stores): Likewise.
+
+2007-12-13  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR middle-end/33088
+       * gimplify.c (gimplify_modify_expr_complex_part): Add note to comment.
+       * tree-complex.c (init_dont_simulate_again): Return true if there are
+       uninitialized loads generated by gimplify_modify_expr_complex_part.
+       * tree-gimple.c (is_gimple_reg_type): Return false for complex types
+       if not optimizing.
+       * tree-ssa.c (ssa_undefined_value_p): New predicate extracted from...
+       (warn_uninit): ...here.  Use ssa_undefined_value_p.
+       * tree-ssa-pre.c (is_undefined_value): Delete.
+       (phi_translate_1): Use ssa_undefined_value_p.
+       (add_to_exp_gen): Likewise.
+       (make_values_for_stmt): Likewise.
+       * tree-flow.h (ssa_undefined_value_p): Declare.
+
+2007-12-13  Andrew Pinski  <pinskia@gmail.com>
+           David Daney  <ddaney@avtrex.com>
+
+       PR bootstrap/34144
+       * system.h: Make -Wuninitialized non-fatal if ASSERT_CHECKING
+       is disabled.
+
+2007-12-13  Jakub Jelinek  <jakub@redhat.com>
+
+       PR rtl-optimization/32636
+       * df-scan.c (df_get_entry_block_def_set): Set struct_value_rtx
+       regno in entry_block_defs even if HAVE_prologue && epilogue_completed.
+
+2007-12-13  Uros Bizjak  <ubizjak@gmail.com>
+           Richard Guenther  <rguenther@suse.de>
+
+       PR target/34435
+       * config/i386/emmintrin.h (_mm_shuffle_pd, _mm_extract_epi16,
+       _mm_insert_epi16, _mm_shufflehi_epi16, _mm_shufflelo_epi16,
+       _mm_shuffle_epi32): Cast non-constant input values to either __m64,
+       __m128, __m128i or __m128d in a macro version of the intrinsic.
+       Cast constant input values to int.
+       * config/i386/ammintrin.h (_mm_extracti_si64, _mm_inserti_si64): Ditto.
+       * config/i386/bmmintrin.h (_mm_roti_epi8, _mm_roti_epi16,
+       _mm_roti_epi32, _mm_roti_epi64): Ditto.
+       * config/i386/smmintrin.h (_mm_blend_epi16, _mm_blend_ps, _mm_blend_pd,
+       _mm_dp_ps, _mm_dp_pd, _mm_insert_ps, _mm_extract_ps, _mm_insert_epi8,
+       _mm_insert_epi32, _mm_insert_epi64, _mm_extract_epi8, mm_extract_epi32,
+       _mm_extract_epi64, _mm_mpsadbw_epu8, _mm_cmpistrm, _mm_cmpistri,
+       _mm_cmpestrm, _mm_cmpestri, _mm_cmpistra, _mm_cmpistrc, _mm_cmpistro,
+       _mm_cmpistrs, _mm_cmpistrz, _mm_cmpestra, _mm_cmpestrc, _mm_cmpestro,
+       _mm_cmpestrs, _mm_cmpestrz): Ditto.
+       * config/i386/tmmintrin.h (_mm_alignr_epi8, _mm_alignr_pi8): Ditto.
+       * config/i386/xmmintrin.h (_mm_shuffle_ps, _mm_extract_pi16, _m_pextrw,
+       _mm_insert_pi16, _m_pinsrw, _mm_shuffle_pi16, _m_pshufw): Ditto.
+       * config/i386/mmintrin-common.h (_mm_round_pd, _mm_round_sd,
+       _mm_round_ps, _mm_round_ss): Ditto.
+
+2007-12-13  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34450
+       * params.def (PARAM_SCCVN_MAX_SCC_SIZE): New param.
+       * invoke.texi (sccvn-max-scc-size): Document.
+       * Makefile.in (tree-ssa-sccvn.o): Add $(PARAMS_H) dependency.
+       * tree-ssa-sccvn.h (run_scc_vn): Return true on success, false
+       on error.
+       * tree-ssa-sccvn.c (params.h): Include.
+       (DFS): Return true if all went well, return false as soon as
+       a SCC exceeds the size of PARAM_SCCVN_MAX_SCC_SIZE.
+       (run_scc_vn): Return true if all went well, return false if
+       we aborted during DFS.
+       * tree-ssa-pre.c (execute_pre): Check if SCCVN finished
+       successfully, otherwise bail out.
+
+2007-12-13  Olga Golovanevsky  <olga@il.ibm.com>
+
+       * ipa-struct-reorg.c (is_candidate): Print information to dump 
+       file when the type is initialized.
+       (get_stmt_accesses):  Likewise when a structure has bitfields
+       or field access is too complicate.
+       (safe_cond_expr_check): Likewise for unsafe condition expressions.
+       (exclude_cold_structs): Likewise for cold structures.
+       (collect_structures): Suppress redundant print when there are 
+       no structures to transform.
+       (do_reorg): Print to dump file a number of structures that 
+       will be transformed.
+       (dump_new_types): Print a number of new types to replace 
+       an original structure type.
+       
+2007-12-13  Olga Golovanevsky  <olga@il.ibm.com>
+
+       * doc/invoke.texi (Optimiza Options): Document new -fipa-struct-reorg
+       option and struct-reorg-cold-struct-ratio parameter.
+       
+2007-12-13  Torbjorn Granlund  <tege@swox.com>
+
+       * config/i386/i386.c (ix86_rtx_costs) [MULT]: Check op0 for
+       ZERO_EXTEND when computing costs for widening multiplication.
+
+2007-12-13  Richard Earnshaw  <rearnsha@arm.com>
+
+       PR target/30192
+       * config/arm/ieee754-df.S (floatundidf): Fix for wrong sp value on
+       exit when using hard FPA.
+       * config/arm/ieee754-df.S (floatdidf): Likewise.
+
+2007-12-12  Jakub Jelinek  <jakub@redhat.com>
+
+       PR bootstrap/30589
+       * doc/install.texi: Document that for MinGW only runtime 3.12 and
+       later is supported.
+
+2007-12-12  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/rs6000.c (is_mem_ref): Ignore STACK_TIE.
+
+2007-12-12  Aldy Hernandez  <aldyh@redhat.com>
+
+       PR tree-optimization/32901
+       * gimplify.c (gimplify_modify_expr_rhs): Handle the case when we
+       are assigning from a constant constructor.
+       Fix wrapping in function comment.
+
+2007-12-12  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.c (s390_O_constraint_str): Limit the range
+       for 'On' to -4G+1..-1.
+       * config/s390/constraints.md: Adjust comment accordingly.
+
+2007-12-11  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/rs6000/rs6000.c (rs6000_emit_prologue): Use frame_reg_rtx
+       for SPE saves.
+
+2007-12-11  Kai Tietz  <kai.tietz@onevision.com>
+
+       * config/i386/cygming.h (DWARF2_UNWIND_INFO): Handle 64-bit
+       target same as 32-bit.
+
+2007-12-10  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/34371
+       * tree-vectorizer.h (struct _loop_vec_info): Add num_iters_unchanged
+       field.
+       (LOOP_VINFO_NITERS_UNCHANGED): Define to num_iters_unchanged field.
+       * tree-vectorizer.c (set_prologue_iterations,
+       slpeel_tree_peel_loop_to_edge): Call unshare_expr on
+       LOOP_VINFO_NITERS_UNCHANGED before using it.
+
+2007-12-10  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR target/34403
+       * config/i386/i386.c (ix86_expand_movmem): Punt if the count is large.
+       (ix86_expand_setmem): Likewise.
+
+2007-12-10  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR rtl-optimization/34302
+       * auto-inc-dec.c (attempt_change): Change place where move is
+       inserted.
+
+2007-12-10  Jakub Jelinek  <jakub@redhat.com>
+
+       * dwarf2out.c (gen_array_type_die, gen_descr_array_type_die): For
+       Fortran multi-dimensional arrays use DW_AT_ordering
+       DW_ORD_col_major.
+
+2007-12-10  Paolo Bonzini  <bonzini@gnu.org>
+
+       PR target/32086
+       * config/i386/i386.c (override_options): Enable -fvect-cost-model.
+
+2007-12-10 Uros Bizjak <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_function_regparm): Do not check global_regs
+       array, registers that are members of global_regs are also members of
+       fixed_regs array.  Use REGPARM_MAX to check that no regparm hard
+       register is taken by a fixed register variable.  Check up to and
+       including DI_REG when adjusting regparm value due to fixed regs usage.
+       (rep_prefix_usable): Check fixed_regs array, not global_regs array for
+       available hard registers.
+       (ix86_expand_strlen): Ditto.
+       * config/i386/i386.md (strmov): Ditto.
+       (cmpstrnsi): Ditto.
+
+2007-12-10  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * genopinit.c: Include tm_p.h in generated file.
+
+       * config/arm/neon.md (vec_set<mode>_internal): Use INTVAL
+       to extract the integer from operands[2].
+       (vec_setv2di_internal): Likewise.
+
+       * config/arm/arm.c (arm_size_return_regs): Make return type unsigned.
+       (arm_init_neon_builtins): Move code after declarations.
+
+2007-12-10  Hans-Peter Nilsson  <hp@axis.com>
+
+       * reload.c (find_reloads_address_1): To properly mark as an
+       autoincdec, pass X for non-NULL OUT in call to push_reload for
+       autoincdec which can't be trivially used as an address.
+
+2007-12-10  Pranav Bhandarkar  <pranav.bhandarkar@celunite.com>
+           Hans-Peter Nilsson  <hp@axis.com>
+
+       * caller-save.c (insert_one_insn): If inserting before a call_insn
+       then the registers containing the arguments of the call are
+       live_throughout in the new insn.
+
+2007-12-09  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR middle-end/32889
+       PR target/34091
+       * pa.md: Consolidate HImode and QImode move patterns into one pattern
+       each, eliminating floating-point alternatives.
+       * pa-protos.h (pa_cannot_change_mode_class, pa_modes_tieable_p):
+       Declare functions.
+       * pa-64.h (SECONDARY_MEMORY_NEEDED): Define here.
+       * pa.c (pa_secondary_reload): Use an intermediate general register
+       for copies to/from floating-point register classes.  Simplify code
+       SHIFT_REGS class.  Provide additional comments.
+       (pa_cannot_change_mode_class, pa_modes_tieable_p): New functions.
+       * pa.h (MODES_TIEABLE_P): Use pa_modes_tieable_p.
+       (SECONDARY_MEMORY_NEEDED): Delete define.
+       (INT14_OK_STRICT): Define.
+       (MODE_OK_FOR_SCALED_INDEXING_P): Allow SFmode and DFmode when using
+       soft float.
+       (MODE_OK_FOR_UNSCALED_INDEXING_P): Likewise.
+       (GO_IF_LEGITIMATE_ADDRESS): Use INT14_OK_STRICT in REG+D case for
+       SFmode and DFmode.
+       (LEGITIMIZE_RELOAD_ADDRESS): Use INT14_OK_STRICT in mask selection.
+       Align DImode offsets when generating 64-bit code.
+       * pa32-regs.h (VALID_FP_MODE_P): Remove QImode and HImode.
+       (CANNOT_CHANGE_MODE_CLASS): Define.
+       * pa64-regs.h (VALID_FP_MODE_P): Remove QImode and HImode.
+       (CANNOT_CHANGE_MODE_CLASS): Define using pa_cannot_change_mode_class.
+
+2007-12-09  Jakub Jelinek  <jakub@redhat.com>
+
+       PR fortran/22244
+       * langhooks-def.h (LANG_HOOKS_GET_ARRAY_DESCR_INFO): Define.
+       (LANG_HOOKS_FOR_TYPES_INITIALIZER): Add it.
+       * langhooks.h (struct array_descr_info): Forward declaration.
+       (struct lang_hooks_for_types): Add get_array_descr_info field.
+       * dwarf2.h (DW_AT_bit_stride, DW_AT_byte_stride): New.
+       (DW_AT_stride_size, DW_AT_stride): Keep around for Dwarf2
+       compatibility.
+       * dwarf2out.h (struct array_descr_info): New type.
+       * dwarf2out.c (dwarf_attr_name): Rename DW_AT_stride to
+       DW_AT_byte_stride and DW_AT_stride_size to DW_AT_bit_size.
+       (descr_info_loc, add_descr_info_field, gen_descr_array_type_die):
+       New functions.
+       (gen_type_die_with_usage): Call lang_hooks.types.get_array_descr_info
+       and gen_descr_array_type_die.
+
+2007-12-08  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34391
+       * tree-vect-transform.c (vect_setup_realignment): Mark new
+       symbols for renaming.
+
+2007-12-07  Bob Wilson  <bob.wilson@acm.org>
+       
+       * config/xtensa/xtensa.h (ASM_PREFERRED_EH_DATA_FORMAT): Define.
+       (ASM_OUTPUT_DWARF_PCREL): Define.
+       
+2007-12-07  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34382
+       * opts.c (common_handle_option): Handle OPT_fforce_addr.
+
+2007-12-07  Aldy Hernandez  <aldyh@redhat.com>
+
+       * m32c.h (LEGITIMIZE_ADDRESS): Use WIN instead of win.
+       (LEGITIMIZE_RELOAD_ADDRESS): Same.
+
+2007-12-07  Samuel Tardieu  <sam@rfc1149.net>
+
+       PR ada/29157
+       * doc/install.texi: Explain how to check for a clean environment when
+       building GNAT.
+
+2007-12-07  Richard Guenther  <rguenther@suse.de>
+
+       * tree-profile.c (gcov_type_tmp_var): New global variable.
+       (tree_gen_edge_profiler): Use a single shared variable decl per
+       function for edge counter incrementing.
+       (tree_profiling): Re-set the shared variable.
+
+2007-12-06  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_va_start): Add prototype.
+
+2007-12-06  Tom Tromey  <tromey@redhat.com>
+
+       PR c/29172
+       * c-opts.c (c_common_parse_file): Call cpp_clear_file_cache.
+
+2007-12-06  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_function_ok_for_sibcall): Check
+       targetm.binds_local_p as well as DECL_EXTERNAL.
+
+2007-12-06  Harsha Jagasia <harsha.jagasia@amd.com>
+
+       * tree-vectorizer.c (slpeel_add_loop_guard): Gimplify the condition.
+       (set_prologue_iterations): New. Set the prologue iterations to total
+       number of scalar iterations if the cost model check indicates that
+       scalar code should be generated.
+       (slpeel_tree_peel_loop_to_edge): Add a new parameter and code for 
+       generating the cost condition for epilog. Call
+       set_prologue_iterations to generate cost condition for prolog.
+       (new_loop_vec_info): Initialize LOOP_VINFO_NITERS_UNCHANGED.
+       * tree-vectorizer.h (LOOP_VINFO_NITERS_UNCHANGED): New.
+       (slpeel_tree_peel_loop_to_edge): Update declaration.
+       (set_prologue_iterations): New declaration.
+       * tree-vect-analyze.c (vect_analyze_loop_form): Update 
+       LOOP_VINFO_NITERS_UNCHANGED.
+       * tree-vect-transform.c
+       (vect_estimate_min_profitable_iters): Add new parameter and
+       code to  check if run time cost model test is needed.
+       Remove code that adds builtin vectorization cost to scalar
+       outside cost for the run time cost model test. If run time
+       cost model test is needed add the appropriate guard cost to
+       the scalar outside cost. The guard cost depends on whether
+       the guard is generated at versioning or at prolog generation
+       or at epilog generation. Change cost model equation to include
+       scalar outside cost.
+       (conservative_cost_threshold): New. Return the less conservative
+       profitability threshold between the cost model threshold and the
+       user defined vectorization threshold.
+       (vect_do_peeling_for_loop_bound): Call conservative_cost_threshold.
+       (vect_do_peeling_for_alignment): Same.
+       (vect_loop_versioning): Same.
+       (vect_create_cond_for_align_checks): ANDs the cost model condition
+       with the alignment condition.
+       (vect_transform_loop): Call loop versioning only when there is a
+       misalignment or an aliasing problem.
+
+2007-12-06  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/20983
+       * tree-ssa-ccp.c (optimize_stdarg_builtin): New function.
+       (execute_fold_all_builtins): Call it for BUILT_IN_VA_START,
+       BUILT_IN_VA_COPY and BUILT_IN_VA_END.
+
+       * target.h (struct ggc_target): Add expand_builtin_va_start hook.
+       * target-def.h (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       (TARGET_INITIALIZER): Add it.
+       * builtins.c (expand_builtin_va_start): Use
+       targetm.expand_builtin_va_start hook instead of
+       EXPAND_BUILTIN_VA_START macro.
+       * alpha/alpha.c (alpha_va_start): Made static.
+       (override_options): Clear targetm.expand_builtin_va_start if
+       TARGET_UNICOSMK.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * alpha/unicosmk.h (EXPAND_BUILTIN_VA_START): Remove.
+       * alpha/alpha.h (EXPAND_BUILTIN_VA_START): Remove.
+       * alpha/alpha-protos.h (alpha_va_start): Remove prototype.
+       * xtensa/xtensa.h (EXPAND_BUILTIN_VA_START): Remove.
+       * xtensa/xtensa.c (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       (xtensa_va_start): Made static.
+       * xtensa/xtensa-protos.h (xtensa_va_start): Remove prototype.
+       * pa/pa-protos.h (hppa_va_start): Remove prototype.
+       * pa/pa.h (EXPAND_BUILTIN_VA_START): Remove.
+       * pa/pa.c (hppa_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * frv/frv.c (frv_expand_builtin_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * frv/frv-protos.h (frv_expand_builtin_va_start): Remove prototype.
+       * frv/frv.h (EXPAND_BUILTIN_VA_START): Remove.
+       * i386/i386.c (override_options): Clear
+       targetm.expand_builtin_va_start if -m32 or 64-bit MS ABI.
+       (ix86_va_start): Made static.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * i386/i386.h (EXPAND_BUILTIN_VA_START): Remove.
+       * i386/i386-protos.h (ix86_va_start, ix86_va_arg): Remove prototypes.
+       * iq2000/iq2000-protos.h (iq2000_va_start): Remove prototype.
+       * iq2000/iq2000.h (EXPAND_BUILTIN_VA_START): Remove.
+       * iq2000/iq2000.c (iq2000_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * rs6000/rs6000-protos.h (rs6000_va_start): Remove prototype.
+       * rs6000/rs6000.c (rs6000_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       (rs6000_override_options): Clear targetm.expand_builtin_va_start if
+       DEFAULT_ABI != ABI_V4.
+       * rs6000/rs6000.h (EXPAND_BUILTIN_VA_START): Remove.
+       * spu/spu.c (spu_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * spu/spu.h (EXPAND_BUILTIN_VA_START): Remove.
+       * spu/spu-protos.h spu_va_start): Remove prototype.
+       * stormy16/stormy16.h (EXPAND_BUILTIN_VA_START): Remove.
+       * stormy16/stormy16-protos.h (xstormy16_expand_builtin_va_start):
+       Remove prototype.
+       * stormy16/stormy16.c (xstormy16_expand_builtin_va_start): Made static.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * s390/s390-protos.h (s390_va_start): Remove prototype.
+       * s390/s390.c (s390_va_start): Made static.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * s390/s390.h (EXPAND_BUILTIN_VA_START): Remove.
+       * mn10300/mn10300.h (EXPAND_BUILTIN_VA_START): Remove.
+       * mn10300/mn10300-protos.h (mn10300_va_start): Remove prototype.
+       * mn10300/mn10300.c (mn10300_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * arc/arc.c (arc_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * arc/arc.h (EXPAND_BUILTIN_VA_START): Remove.
+       * arc/arc-protos.h (arc_va_start): Remove prototype.
+       * mt/mt-protos.h (mt_va_start): Remove prototype.
+       * sparc/sparc.c (sparc_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * sparc/sparc-protos.h (sparc_va_start): Remove prototype.
+       * sparc/sparc.h (EXPAND_BUILTIN_VA_START): Remove.
+       * sh/sh.c (sh_va_start): Made static, add prototype.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+       * sh/sh-protos.h (sh_va_start): Remove prototype.
+       * sh/sh.h (EXPAND_BUILTIN_VA_START): Remove.
+       * mips/mips-protos.h (mips_va_start): Remove prototype.
+       * mips/mips.h (EXPAND_BUILTIN_VA_START): Remove.
+       * mips/mips.c (mips_va_start): Made static.
+       (TARGET_EXPAND_BUILTIN_VA_START): Define.
+
+2007-12-06  Uros Bizjak  <ubizjak@gmail.com>
+
+       * tree-ssa-loop.c (gate_tree_parallelize_loops): Return true when
+       "flag_tree_parallelize_loops > 1".
+       
+2007-12-06  Zdenek Dvorak  <ook@ucw.cz>
+           Dorit Nuzman  <dorit@il.ibm.com>
+           Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/34005
+       * tree-gimple.c (is_gimple_formal_tmp_rhs): Add a case for COND_EXPR.
+       * gimplify.c (gimplify_ctx): Add a new member allow_rhs_cond_expr.
+       (gimplify_pure_cond_expr): New function.
+       (generic_expr_could_trap_p): New function.
+       (gimplify_cond_expr): Call gimplify_pure_cond_expr.
+       (force_gimple_operand): Initialize new field allow_rhs_cond_expr.
+
+2007-12-06  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.c (s390_emit_stack_tie): New function.
+       (s390_emit_prologue): Emit a stack tie when writing to the
+       f8-f15 stack slots.
+       * config/s390/s390.md ("stack_tie"): New insn definition.
+
+2007-12-06  Ben Elliston  <bje@au.ibm.com>
+
+       * SERVICE: Remove.
+       * doc/sourcebuild.texi (Miscellaneous Docs): Remove SERVICE item.
+
+2007-12-05  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/34337
+       * fold-const.c (fold_binary) <case BIT_IOR_EXPR>: Don't minimize
+       number of bits set in C1 if a mode mask for some mode can be used
+       instead.
+
+2007-12-05  Bernhard Fischer  <aldot@gcc.gnu.org>
+
+       * varasm.c (merge_weak, weak_finish, assemble_alias): Commentary typo
+       fixes.
+
+2007-12-05  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34138
+       * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars):
+       Do not forward propagate addresses if that changes volatileness of
+       the pointed-to type.
+
+2007-12-05  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/34312
+       * config/i386/i386.c (ix86_function_regparm): Also check for fixed
+       registers when checking that regparm registers are available.
+       Lower regparm value due to fixed registers usage in addition to
+       global regs usage.
+
+2007-12-05  Bernhard Fischer  <aldot@gcc.gnu.org>
+
+       * sparseset.c: Include config.h and system.h before sparseset.h.
+       * sparseset.h: Remove inclusion of system.h.
+
+2007-12-05  Jakub Jelinek  <jakub@redhat.com>
+           Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * optabs.c (init_insn_codes): New function.
+       (new_optab): Delete.
+       (init_optab, init_optabv): Don't call new_optab.
+       (init_convert_optab): Don't clear the insn codes.
+       (init_optabs): Call init_insn_codes.
+
+2007-12-04  Jakub Jelinek  <jakub@redhat.com>
+
+       * omp-low.c (optimize_omp_library_calls): New function.
+       (expand_omp_parallel): Call it if optimizing.
+
+       PR middle-end/34134
+       * stmt.c (expand_stack_restore): Call expand_normal on var to get
+       rtx for it instead of assuming it will be a VAR_DECL.
+
+2007-12-04  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * c-parser (c_parser_statement_after_labels): Move error from here...
+       (c_parser_label): ... to here. Check that the declaration is not
+       actually just another label.
+
+2007-12-04  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34334
+       PR middle-end/34222
+       * tree-ssa-operands.c (get_addr_dereference_operands): If we
+       fall back to using the SMTs aliases, make sure to add virtual
+       operands for the SMT itself.
+       (create_ssa_artificial_load_stmt): Fix typo.  Make sure to also
+       clear the loaded and stored symbols bitmaps.
+
+2007-12-04  Ben Elliston  <bje@au.ibm.com>
+
+       * config/spu/spu.h (ASM_FORMAT_PRIVATE_NAME): Remove; use default.
+
+2007-12-04  Ben Elliston  <bje@au.ibm.com>
+
+       * doc/tm.texi (Exception Handling): Mention unwind-dw2-xtensa.c.
+
+2007-12-03  Steven Bosscher  <stevenb.gcc@gmail.com>
+
+       PR middle-end/33713
+       * doc/invoke.texi: Remove -fforce-addr documentation.
+       * expr.c (emit_move_insn): Remove use of flag_force_addr.
+       (expand_expr_real_1): Same.
+       (do_tablejump): Same.
+       Call memory_address instead of memory_address_noforce.
+       * expr.h (memory_address_noforce): Remove prototype.
+       * explow.c (memory_address): Remove support for flag_force_addr.
+       (validize_mem): Same.
+       (memory_address_noforce): Remove.
+       * common.opt: Add dummy documentation for -fforce-addr.
+       * combine.c (can_combine_p): Remove -fforce-addr comment.
+       * config/cris/cris.h (OPTIMIZATION_OPTIONS): Remove set of
+       flag_force_addr.
+       * config/m68k/m68k.h (PIC_CASE_VECTOR_ADDRESS): Remove comment
+       relating to memory_address_noforce.
+       * testsuite/gcc.c-torture/compile/20050802-1.c: Remove.
+       * testsuite/gcc.c-torture/compile/20011113-1.c: Remove.
+       
+2007-12-03  Jakub Jelinek  <jakub@redhat.com>
+
+       * omp-low.c (lookup_decl_in_outer_ctx): Allow calling this
+       with !ctx->is_nested.
+       (maybe_lookup_decl_in_outer_ctx): Look up in outer contexts
+       even if !ctx->is_nested.
+       (lower_copyprivate_clauses, lower_send_clauses,
+       lower_send_shared_vars): Call lookup_decl_in_outer_ctx
+       unconditionally.
+
+       PR middle-end/29749
+       * fold-const.c (fold_binary) <case BIT_AND_EXPR>: Optimize
+       (X << C1) & C2 into (X << C1) & (C2 | ((1 << C1) - 1))
+       and (X >> C1) & C2 into (X >> C1) & (C2 | ~((type) -1 >> C1)).
+       (fold_binary) <case LSHIFT_EXPR, case RSHIFT_EXPR>: Optimize
+       (X & C2) << C1 into (X << C1) & (C2 << C1) and
+       (X & C2) >> C1 into (X >> C1) & (C2 >> C1) if that allows further
+       optimizations.
+
+       PR tree-optimization/33453
+       * tree-data-ref.c (split_constant_offset): Use POINTER_PLUS_EXPR
+       for pointer addition.
+       * tree-parloops.c (canonicalize_loop_ivs): Likewise.
+       (separate_decls_in_loop_name): Copy DECL_GIMPLE_REG_P from var to
+       var_copy.
+
+2007-12-03  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.h (TARGET_CPU_CPP_BUILTINS): Define __FDPIC__ as
+       necessary.
+
+2007-12-03  Razya Ladelsky <razya@il.ibm.com>
+
+       * doc/invoke.texi (fipa-cp, fipa-matrix-reorg): Add documentation.
+
+2007-12-03  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/34317
+       * opts.c (common_handle_option): Handle OPT_ftree_store_copy_prop.
+       * common.opt (ftree-store-copy-prop): Use the same help text as for
+       other nop switches.
+
+2007-12-02  Ayal Zaks  <zaks@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * modulo-sched.c (calculate_must_precede_follow,
+       try_scheduling_node_in_cycle): New functions.
+       (sms_schedule_by_order): Call the new functions.
+       (ps_insn_find_column): Use must_follow and must_precede only if
+       they are not NULL.
+       (ps_insn_advance_column): Likewise.
+
+2007-12-02  Ayal Zaks  <zaks@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * modulo-sched.c (get_sched_window): Fix the direction of the
+       scheduling window and add dump info.
+
+2007-12-02  Samuel Tardieu  <sam@rfc1149.net>
+
+       * config/sh/sh.md (cmpgeusi_t): Fix condition.
+
+2007-11-30  Jan Hubicka  <jh@suse.cz>
+
+       * ggc-common.c (dump_ggc_loc_statistics): Reset ggc_force_collect flag.
+
+2007-11-30  Seongbae Park <seongbae.park@gmail.com>
+
+       PR rtl-optimization/34171
+       * cfgrtl.c (update_bb_for_insn_chain): New function,
+       refactored from update_bb_for_insn.
+       (update_bb_for_insn): Call update_bb_for_insn.
+       (rtl_merge_blocks, try_redirect_by_replacing_jump):
+       Replace a loop with update_bb_for_insn_chain call.
+       (cfg_layout_merge_blocks): Add a call to
+       update_bb_for_insn_chain. Replace the for loop
+       with a call to update_bb_for_insn_chain.
+
+2007-11-30  Ben Elliston  <bje@au.ibm.com>
+
+       * config/vax/vax.h (ASM_FORMAT_PRIVATE_NAME): Remove. Use default.
+
+2007-11-29  Zdenek Dvorak  <ook@ucw.cz>
+
+       PR tree-optimization/34244
+       * tree-vrp.c (adjust_range_with_scev): Clear scev cache.
+       (record_numbers_of_iterations): New function.
+       (execute_vrp): Cache the numbers of iterations of loops.
+       * tree-scalar-evolution.c (scev_reset_except_niters): New function.
+       (scev_reset): Use scev_reset_except_niters.
+       * tree-scalar-evolution.h (scev_reset_except_niters): Declare.
+
+2007-11-29  Jan Hubicka  <jh@suse.cz>
+           Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/33434
+       * tree-inline.c (setup_one_parameter): If the value passed to
+       a parameter is never used, don't set it up.
+
+2007-11-29  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/32130
+       * config/rs6000/eabi-cn.asm (__DTOR_END__): Make it weak.
+       * config/rs6000/sol-cn.asm (__DTOR_END__): Likewise.
+
+2007-11-29  Andris Pavenis <andris.pavenis@iki.fi>
+
+       * Makefile.in: Use separate vpath lines for each path.
+
+2007-11-29  Ben Elliston  <bje@au.ibm.com>
+
+       * SERVICE: Update URL.
+
+2007-11-28  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/34140
+       * tree-if-conv.c (if_convertible_phi_p): Fail if BB other than
+       loop->header has virtual phi nodes.
+
+2007-11-28  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR target/32406
+       * builtins.c (expand_builtin_nonlocal_goto): Also emit a use
+       of GP register, if valid and fixed.
+
+       Revert:
+       2007-06-21  David Daney  <ddaney@avtrex.com>
+
+       PR target/32406
+       * config/mips/mips.md (define_constants): Rename UNSPEC_EH_RECEIVER
+       to UNSPEC_NONLOCAL_GOTO_RECEIVER globally.
+       (exception_receiver): Renamed to ...
+       (nonlocal_goto_receiver): ... this.
+
+2007-11-27  H.J. Lu  <hongjiu.lu@intel.com>
+           Joey Ye <joey.ye@intel.com>
+
+       PR target/34001
+       * config/i386/i386.c (function_arg_32): Don't pass aggregate
+       arguments in ECX/EDX for fastcall.
+
+2007-11-28  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * config/i386/linux.h (CRT_GET_RFIB_DATA): Add Intel syntax inline
+       asm to macro.
+       * config/i386/sco5.h (CRT_GET_RFIB_DATA): Likewise.
+       * config/i386/sysv4.h (CRT_GET_RFIB_DATA): Likewise.
+
+2007-11-28  Ben Elliston  <bje@au.ibm.com>
+
+       * config/rs6000/aix64.opt (maix64): Add Negative(maix32).
+       (maix32): Add Negative(maix64).
+
+2007-11-27  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/34016
+       * tree-ssa-loop.c (pass_linear_transform): Add
+       TODO_update_ssa_only_virtuals to todo_flags_finish.
+
+2007-11-27  Eric B. Weddington  <eric.weddington@atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Add atmega32hvb.
+       * config/avr/avr.h (LINK_SPEC): Likewise.
+       (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+       
+2007-11-27  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/34225
+       * config/rs6000/rs6000.c (adjacent_mem_locations): Don't assume
+       MEM_SIZE is set on all MEMs.
+
+2007-11-27  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.opt (mhard-float): Add the option to be
+       overridden.  That was missing in my last patch.
+
+2007-11-27  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34241
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr): Make sure
+       to only delete real conversion chains.
+
+2007-11-27  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.opt (m31, m64, mesa, mzarch, msoft-float,
+       mhard-float, mlong-double-64, mlong-double-128): Add the
+       option to be overridden.
+
+2007-11-27  Richard Guenther  <rguenther@suse.de>
+
+       * builtins.c (fold_builtin_1): Verify the argument types
+       of BUILT_IN_ISNORMAL.
+       (fold_builtin_n): Verify the number of arguments to variadic
+       built-in functions.
+
+2007-11-27  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/elf.h (SUBTARGET_DRIVER_SELF_SPECS): New macro.
+       * doc/invoke.texi (Blackfin Options): Document the effects.
+
+2007-11-27  Ben Elliston  <bje@au.ibm.com>
+
+       * config/rs6000/sysv4.opt (m32): Add Negative(m64).
+       (m64): Add Negative(m32).
+       * config/rs6000/darwin.opt (m32): Add Negative(m64).
+       (m64): Add Negative(m32).
+
+2007-11-26  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-ssa-propagate.c (set_rhs) <GIMPLE_MODIFY_STMT>: Fix typo.
+
+2007-11-26  Michael Meissner  <michael.meissner@amd.com>
+
+       PR target/34077
+       * config/i386/i386.c (ix86_expand_movmem): If the copy size is a
+       constant, avoid calling emit_cmp_and_jump_insns.  Use counter_mode
+       to get the mode for loading a pseudo register with a count rather
+       than duplicating code.
+
+2007-11-25  Eric B. Weddington  <eric.weddington@atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Add atmega1284p.
+       * config/avr/avr.h (LINK_SPEC): Likewise.
+       (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+
+2007-11-26  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+       
+       * c-common.c (conversion_warning): Use get_unwidened instead of
+       get_narrower.
+       
+2007-11-26  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c/23722
+       * c-parser.c (struct c_parser): New bit in_if_block.
+       (c_parser_compound_statement_nostart): Handle unexpected 'else'
+       keyword.
+       (c_parser_statement_after_labels): Set in_if_block to false while
+       parsing.
+       (c_parser_if_body): Don't call c_parser_statement_after_labels if
+       a semicolon is found, just consume it. Don't call
+       c_parser_statement_after_labels if an open brace is found, call
+       c_parser_compound_statement instead.
+       (c_parser_else_body): New.
+       (c_parser_if_statement): Set in_if_block to true when parsing the
+       body of the 'if' statement. Use c_parser_else_body.
+
+2007-11-26  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       PR c++/34081
+       * c-decl.c (store_parm_decls): Pass 'false' for the new
+       allocate_struct_function parameter.
+       * cgraphunit.c (cgraph_build_static_cdtor): Likewise.
+       * tree-parloops.c (create_loop_fn): Likewise.
+       * function.c (push_function_context_to, push_struct_function,
+       init_function_start): Likewise.
+       (allocate_struct_function): Add boolean parameter.
+       * tree.h (allocate_struct_function): Add boolean parameter.
+       * function.h (struct function): Move returns_struct and
+       returns_pcc_struct to the end of the structure definiton.
+
+2007-11-26  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/34215
+       * config/i386/i386.md (truncdfsf2): Select SLOT_TEMP stack slot if
+       virtual registers are already instantiated.
+       (truncxf<mode>2): Ditto.
+       (floatsi<mode>2): Ditto.
+       (floatdisf2): Ditto.
+       (floatdidf2): Ditto.
+
+2007-11-26  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/34174
+       * config/fr30/fr30.c (fr30_move_double): Sanitize mem->reg case. Copy
+       the address before it is clobbered.
+
+2007-11-26  Nick Clifton  <nickc@redhat.com>
+
+       * config/mn10300/mn10300.md: (call_internal): Remove mode on
+       operand 0 in order to match UNPSEC'ed calls generated in PIC mode.
+       (call_value_internal): Remove mode on operands 0 and 1 in order to
+       match UNPSEC'ed calls generated in PIC mode.
+       (GOTaddr2picreg): Use copy_rtx to prevent sharing an rtx between
+       two insns.
+
+2007-11-26  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34233
+       * builtins.c (expand_builtin_pow): Use expand_expr to expand
+       the result of build_call_expr.
+
+2007-11-26  Steven Bosscher  <stevenb.gcc@gmail.com> 
+           Revital Eres  <eres@il.ibm.com> 
+
+       PR middle-end/34085
+       * bb-reorder.c (insert_section_boundary_note): Clear
+       BLOCK_FOR_INSN in NOTE_INSN_SWITCH_TEXT_SECTIONS.
+
+2007-11-26  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/elfoabi.h (DRIVER_SELF_SPECS): Add missing comma.
+
+2007-11-26  Alexandre Oliva  <aoliva@redhat.com>
+
+       * dwarf2asm.c (splay_tree_compare_strings): New function.
+       (dw2_force_const_mem): Use it.
+
+2007-11-26  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree.c (type_hash_add): Don't violate strict aliasing rules.
+
+2007-11-26  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR c/27898
+       * c-typeck.c (tagged_types_tu_compatible_p): Enable exact
+       matches between anonymous union fields.
+
+2007-11-26  Alexandre Oliva  <aoliva@redhat.com>, Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-live.c (remove_unused_scope_block_p): Drop
+       declarations and blocks only after inlining.  Check that
+       non-empty blocks are not dropped.
+       * tree-inline.c (expand_call_inline): Check that functions are
+       not inlined too late.
+
+2007-11-26  Ben Elliston  <bje@au.ibm.com>
+
+       * unwind-dw2-fde.c: Fix comment typo.
+       * unwind-generic.h: Likewise, fix comment typos.
+       
+2007-11-25  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * tree-sra.c (scalarize_use): Adjust the vpos argument to
+       sra_explode_bitfield_assignment in cases where the type is
+       wider than the bitfield.
+
+2007-11-25  Richard Guenther  <rguenther@suse.de>
+
+       * tree.h (struct tree_block): Move locus member next to flags.
+       * c-decl.c (SCOPE_LIST_APPEND): Use BLOCK_CHAIN.
+       (SCOPE_LIST_CONCAT): Likewise.
+       (pop_scope): Likewise.
+       * function.c (instantiate_decls_1): Likewise.
+       (setjmp_vars_warning): Likewise.
+       * emit-rtl.c (set_used_decls): Likewise.
+       * tree-inline.c (add_lexical_block): Likewise.
+
+2007-11-24  Hans-Peter Nilsson  <hp@axis.com>
+
+       * rtlanal.c (label_is_jump_target_p): Return true for a matching
+       REG_LABEL_TARGET.
+       * reorg.c (fill_slots_from_thread): Correct last change to use
+       NULL_RTX, not NULL.  Outside of REG_NOTES loop, increase and
+       decrease LABEL_NUSES for JUMP_LABEL (trial), not XEXP (note, 0).
+       * jump.c (mark_jump_label_1): Add comment for last change
+       regarding JUMP_LABEL setting.
+       * gcse.c (add_label_notes): Remove conditional that the label is
+       mentioned in insn before adding regnote.
+       * sched-rgn.c (is_cfg_nonregular): Don't return 1 for a
+       single_set insn only feeding a label to a jump through a
+       register that dies there.
+
+2007-11-23  Dirk Mueller  <dmueller@suse.de>
+           Richard Guenther <rguenther@suse.de>
+
+       PR middle-end/34197
+       * tree-vrp.c (check_array_ref): Move check for valid location..
+       (check_array_bounds) here. Use EXPR_HAS_LOCATION().
+
+2007-11-23  Hans-Peter Nilsson  <hp@axis.com>
+
+       * reload.c (find_reloads_address_1) <autoincdec cases>:
+       Call REG_OK_FOR_CONTEXT with the autoincdec code, not outer_code.
+
+2007-11-23  Richard Guenther  <rguenther@suse.de>
+           Michael Matz  <matz@suse.de>
+
+       PR tree-optimization/34176
+       * alloc-pool.h (empty_alloc_pool): Declare.
+       * alloc-pool.c (empty_alloc_pool): New function.
+       * tree-ssa-sccvn.c (vn_reference_lookup): Also lookup from the
+       valid table if a lookup from the optimistic table failed.
+       (vn_unary_op_lookup): Likewise.
+       (vn_binary_op_lookup): Likewise.
+       (vn_phi_lookup): Likewise.
+       (process_scc): Clear optimistic tables before every iteration.
+
+2007-11-23  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-copy.c (may_propagate_copy): Remove redundant checks.
+       (merge_alias_info): Do verification only if checking is
+       enabled.  Merge flow-sensitive alias information in simple cases.
+       * tree-ssa-operands.c (get_addr_dereference_operands): Also
+       complain about missing NMTs.
+
+2007-11-23  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/34198
+       * c-common.c (conversion_warning): For INTEGER_TYPE to
+       INTEGER_TYPE conversions call get_narrower on expr to avoid
+       spurious warnings from binop shortening or when the implicit
+       conversion can't change the value.
+
+2007-11-22  Joseph Myers  <joseph@codesourcery.com>
+
+       PR c/14050
+       * c-decl.c (set_array_declarator_inner): Don't give error for
+       static or type qualifiers in abstract declarator.  Remove
+       abstract_p parameter.
+       * c-tree.h (set_array_declarator_inner): Update prototype.
+       * c-parser.c (c_parser_direct_declarator_inner): Update call to
+       set_array_declarator_inner.
+       * doc/standards.texi: Update for C99 TC3.
+
+2007-11-22  Hans-Peter Nilsson  <hp@bitrange.com>
+
+       * config/mmix/mmix.c (mmix_encode_section_info): Remove duplicate
+       line in my edit of the last change.
+
+2007-11-22  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/33947
+       * config/arm/arm.c (arm_init_tls_builtins): Set TREE_NOTHROW
+       and TREE_READONLY on the fn decl rather than passing a chain
+       of attributes.
+
+2007-11-22  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.md (divsi_inv_m3): Handle zero dividend specially.
+
+2007-11-22  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (TARGET_CPU_CPP_BUILTINS): Change checking
+       of ix86_arch and ix86_tune into a switch statement.
+       (enum processor_type): Default PROCESSOR_I386 to 0.
+       * config/i386/i386.c (ix86_decompose_address): Use TARGET_K6 instead
+       of "ix86_tune == PROCESSOR_K6".
+       (ia32_multipass_dfa_lookahead): Change checking of ix86_tune into
+       a switch statement.
+
+2007-11-22  Tom Tromey  <tromey@redhat.com>
+
+       * config/mmix/mmix.c (mmix_encode_section_info): Use alloca to
+       avoid writing into string allocated by ggc_alloc_string.
+
+2007-11-21  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/34155
+       * config/sh/sh.md (binary_sf_op): Remove.
+       (binary_sf_op0, binary_sf_op1): New define_insn_and_split.
+       * config/sh/sh.c (sh_expand_binop_v2sf): Use gen_binary_sf_op0
+       and gen_binary_sf_op1.
+
+2007-11-21  Hans-Peter Nilsson  <hp@axis.com>
+
+       * regclass.c (init_reg_autoinc): Fix typo preventing test of
+       secondary output reload when setting forbidden_inc_dec_class.
+
+2007-11-21  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34148
+       * tree-ssa-structalias.c (create_variable_info_for): Do not use
+       field-sensitive PTA for single-element structures.
+       * tree-ssa-alias.c (create_overlap_variables_for): Do not create
+       SFTs for single-element structures.
+
+2007-11-20  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34154
+       * gimplify.c (gimplify_switch_expr): Use tree_int_cst_lt instead
+       of the signed INT_CST_LT.
+       * stmt.c (expand_case): Likewise.
+       (estimate_case_costs): Likewise.
+
+2007-11-20  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * read-rtl.c (fatal_expected_char): Print EOF as text rather that
+       its binary representation.
+
+2007-11-20  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-operands.c (add_virtual_operand): Consistently prune
+       accesses.
+
+2007-11-20  Thiemo Seufer  <ths@mips.com>
+
+       * config/mips/mips.c (mips_file_start): Add support for
+       flagging 32-bit code with -mfp64 floating-point.
+
+2007-11-20  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/34146
+       * c-gimplify.c (optimize_compound_literals_in_ctor): New function.
+       (c_gimplify_expr): Use it.
+
+2007-11-20  Ben Elliston  <bje@au.ibm.com>
+
+       * config/spu/spu_mfcio.h: Fix typo.
+
+2007-11-20  Ben Elliston  <bje@au.ibm.com>
+
+       * unwind.inc: Comment that unwind-sjlj.c includes this file.
+
+2007-11-20  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
+           Ben Elliston  <bje@au.ibm.com>
+
+       * config/spu/mfc_tag_release.c: New file.
+       * 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/t-spu-elf (LIB2FUNCS_STATIC_EXTRA): Compile them.
+       (TARGET_LIBGCC2_CFLAGS): Define __IN_LIBGCC2.
+       * config/spu/spu_mfcio.h: Avoid <stdint.h>.
+       (uint64_t): Typedef if __IN_LIBGCC2 is defined.
+       (MFC_TAG_INVALID, MFC_TAG_VALID): New macros.
+       (mfc_tag_reserve, mfc_tag_release, mfc_multi_tag_reserve,
+       mfc_multi_tag_release): Likewise.
+       (__mfc_tag_reserve, __mfc_tag_release, __mfc_multi_tag_reserve,
+       __mfc_multi_tag_release): Declare.
+
+2007-11-19  Jason Merrill  <jason@redhat.com>
+
+       PR debug/28834, debug/29436, c/32326
+       * tree.c (build_type_attribute_qual_variant): Refuse to make
+       a distinct copy of a struct/enum type.  Use build_distinct_type_copy.
+       * doc/extend.texi (Type Attributes): Don't encourage people to add
+       attributes to struct/enum types in a typedef.  Fix
+       transparent_union example.
+
+       * tree-inline.c (remap_type_1): Remove code that's redundant with
+       remap_type.
+       (build_duplicate_type): Set id.copy_decl.
+       * c-common.c (handle_transparent_union_attribute): Simplify logic.
+
+2007-11-19  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * config/rs6000/rs6000.c (invalid_e500_subreg,
+       rs6000_legitimate_offset_address_p, legitimate_lo_sum_address_p,
+       rs6000_legitimize_address, rs6000_legitimize_reload_address,
+       rs6000_legitimate_address, function_arg_advance,
+       spe_build_register_parallel, rs6000_spe_function_arg,
+       rs6000_split_multireg_move, spe_func_has_64bit_regs_p,
+       emit_frame_save, gen_frame_mem_offset, rs6000_function_value,
+       rs6000_libcall_value, rs6000_dwarf_register_span): Handle DDmode and
+       TDmode similarly to DFmode and TFmode.
+       * config/rs6000/rs6000.h (LOCAL_ALIGNMENT, MEMBER_TYPE_FORCES_BLK,
+       DATA_ALIGNMENT, CLASS_MAX_NREGS, CANNOT_CHANGE_MODE_CLASS): Likewise.
+
+2007-11-19  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * stor-layout.c (lang_adjust_rli): Delete.
+       (set_lang_adjust_rli): Likewise.
+       (layout_type): Do not call lang_adjust_rli hook.
+       * tree.h (set_lang_adjust_rli): Delete.
+
+2007-11-19  Bernd Schmidt  <bernd.schmidt@analog.com>
+       
+       * config/bfin/bfin.c (must_save_p): New function, mostly broken out of
+       n_dregs_to_save and n_pregs_to_save.
+       (n_pregs_to_save, n_dregs_to_save): Use it.  New argument CONSECUTIVE;
+       all callers changed.
+       (expand_prologue_reg_save, expand_epilogue_reg_restore): Enhance to be
+       able to save single D/P registers that aren't saved by the push/pop
+       multiple insns.
+
+2007-11-19  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34099
+       * tree-ssa-ccp.c (likely_value): Exclude all but PLUS_EXPR,
+       MINUS_EXPR and POINTER_PLUS_EXPR from handling as UNDEFINED
+       if only one operand is undefined.
+
+2007-11-19  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR tree-optimization/34036
+       * opts.c (set_fast_math_flags): Do not set flags in common
+       with set_unsafe_math_optimizations_flags, invoke it directly.
+       (set_unsafe_math_optimizations_flags): Unset flag_trapping_math
+       and flag_signed_zeros.
+       * toplev.c (process_options): Force flag_associative_math to 0 and
+       warn, if it is set and either flag_trapping_math or flag_signed_zeros
+       is set too.
+       * doc/invoke.texi (Optimize Options): Document the new behavior
+       of -funsafe-math-optimizations, that -fassociative-math requires
+       both -fno-signed-zeros and -fno-trapping-math and make it clear
+       that -fno-trapping-math requires -fno-signaling-nans.  Refactor
+       documentation of -ffast-math.
+
+2007-11-18  Jakub Jelinek  <jakub@redhat.com>
+
+       PR rtl-optimization/34132
+       * gcse.c (try_replace_reg): Avoid rtx sharing between REG_EQUAL note
+       and insn.
+
+       PR middle-end/33335
+       * optabs.h (optab_table): Change type to struct optab from optab.
+       (convert_optab_table): Similarly.
+       Adjust all _optab macros to expand to addresses of optab_table
+       resp. convert_optab_table elements rather than the values of the
+       elements.
+       * optabs.c (optab_table): Change typype to struct optab from optab.
+       If compiled by recent GCC, initialize all the insn_code fields in
+       the array using designated range initializers.
+       (convert_optab_table): Similarly.
+       (convert_optab_libfunc, optab_libfunc, set_optab_libfunc,
+       set_conv_libfunc): Into libfunc_entry's optab field store index within
+       optab_table resp. convert_optab_table array instead of difference
+       between two separately malloced addresses.
+       (new_optab): Add op argument, don't return anything.  Initialize
+       just the insn_code field in handlers array and only when needed.
+       (init_optab, init_optabv): Add op argument, don't return anything.
+       Adjust new_optab caller.
+       (new_convert_optab): Removed.
+       (init_convert_optab): Add op argument, don't return anything, don't
+       call new_convert_optab.  If needed, initialize insn_code field in
+       handlers array.
+       (init_optabs): Adjust init_optab, init_optabv and init_convert_optab
+       callers.
+       (debug_optab_libfuncs): Adjust uses of optab_table and
+       convert_optab_table arrays.
+
+2007-11-18  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34127
+       * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars):
+       Make code match up the comments, require compatibility of the
+       pointed-to types.
+
+2007-11-17  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34130
+       * fold-const.c (extract_muldiv_1): Do not move negative
+       constants inside ABS_EXPR.
+
+2007-11-16  Ian Lance Taylor  <iant@google.com>
+
+       * collect2.c (dump_file): If a demangled symbol is followed by a
+       space, make sure we output at least one space.
+
+2007-11-16  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34030
+       * fold-const.c (fold_binary): Use correct types for folding
+       1 << X & Y to Y >> X & 1.
+
+2007-11-16  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33870
+       * tree.h (struct tree_memory_tag): Add base_for_components flag.
+       (struct tree_struct_field_tag): Remove nesting_level field.
+       (SFT_NESTING_LEVEL): Remove.
+       (SFT_BASE_FOR_COMPONENTS_P): Add.
+       * tree-flow.h (struct fieldoff): Remove nesting_level field.  Add
+       base_for_components flag.
+       (push_fields_onto_fieldstack): Remove nesting_level parameter.
+       * tree-ssa-alias.c (create_sft): Likewise.  Add base_for_components
+       parameter.
+       (create_overlap_variables_for): Deal with it.
+       * tree-dfa.c (dump_subvars_for): Likewise.
+       (dump_variable): Likewise.
+       * tree-ssa-structalias.c (push_fields_onto_fieldstack): Likewise.
+       Set base_for_components for first elements of sub-structures.
+       (create_variable_info_for): Handle base_for_components.
+       (set_uids_in_ptset): Always set SFT_UNPARTITIONABLE_P for
+       pointed-to SFTs if SFT_BASE_FOR_COMPONENTS_P is set.
+       * tree-ssa-operands.c (ref_nesting_level): Remove.
+       (add_vars_for_offset): Remove full_ref parameter, always add
+       the offset of the pointed-to SFT.
+       (add_virtual_operand): Adjust for changed signature of
+       add_vars_for_offset.
+
+2007-11-16  Sa Liu  <saliu@de.ibm.com>
+
+       * config/spu/spu.md (floatunssidf2, floatunsdidf2): Inlined 
+       floatunssidf2 and floatunsdidf2.
+
+2007-11-16  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34113
+       * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars):
+       Use correct conversion direction for checking type compatibility.
+
+2007-11-16  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/34099
+       * tree-ssa-ccp.c (likely_value): Use a whitelist for operators
+       that produce UNDEFINED result if at least one of its operands
+       is UNDEFINED.  By default the result is only UNDEFINED if all
+       operands are UNDEFINED.
+
+2007-11-16  Jakub Jelinek  <jakub@redhat.com>
+
+       PR driver/30460
+       * gcc.c (init_spec): Don't initialize asm_debug here...
+       (main): ... but here.
+
+2007-11-07  Tom Tromey  <tromey@redhat.com>
+
+       * tree-ssa-structalias.c (ipa_pta_execute): Rename 'cfun' to 'func'. 
+       * tree-parloops.c (create_loop_fn): Use set_cfun.
+       * gengtype.c (open_base_files): Emit #undef cfun.
+       * ipa-struct-reorg.c (do_reorg_1): Use set_cfun.
+       * function.h (cfun): New define.
+       * function.c: Undefine cfun.
+
+2007-11-07  Eric B. Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Add attiny88.
+       * config/avr/avr.h (LINK_SPEC): Likewise.
+       (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+
+2007-11-15  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/23848
+       * tree-ssa-ccp.c (optimize_stack_restore): New function.
+       (execute_fold_all_builtins): Call optimize_stack_restore for
+       BUILT_IN_STACK_RESTORE.
+
+2007-11-15  Paolo Bonzini  <bonzini@gnu.org>
+
+       * fwprop.c (try_fwprop_subst): Skip profitability check for forward
+       propagation into an address; that's done in should_replace_address.
+               
+2007-11-15  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
+
+       * config/spu/spu-protos.h (legitimate_const): Remove prototype.
+       * config/spu/spu.c (legitimate_const): Remove.
+       (classify_immediate): Inline call to legitimate_const.
+       (spu_legitimate_address): Likewise.  Allow SYMBOL_REF + CONST_INT
+       for any constant, not just -512 .. 511.
+
+2007-11-15  Sa Liu  <saliu@de.ibm.com>
+
+       * config/spu/spu.c (spu_emit_branch_or_set): Remove PROCESSOR_CELL
+       condition from HONOR_NANS test.
+       * config/spu/spu.md (ceq_df): Always generate comparison code
+       inline, including checks for NaNs and infinities.
+       (cgt_df): Likewise.
+       (cgt_v2df): Likewise.
+       (cmpdf): Make this expander unconditional.
+
+2007-11-15  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-alias.c (create_overlap_variables_for): Make sure
+       to only create SFTs if we also create variable infos for PTA.
+       * tree-ssa-structalias.c (set_uids_in_ptset): Add all overlapping SFTs.
+
+2007-11-15  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-structalias.c (set_uids_in_ptset): Use the pointed-to
+       type for TBAA pruning.
+       (find_what_p_points_to): Call set_uids_in_ptset with the original
+       pointer, not the decl of the solution we collapsed to.
+
+2007-11-14  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/linux-unwind.h (mips_fallback_frame_state): Use CFA
+       to find sigcontext.
+
+2007-11-14  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR target/33923
+       * config/ia64/ia64.h (CANNOT_CHANGE_MODE_CLASS): Forbid mode changes
+       for registers in BR_REGS class.
+
+2007-11-14  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/34088
+       * tree-ssa.c (delete_tree_ssa): Don't call fini_ssa_operands if
+       init_ssa_operands has not been called for cfun.
+
+2007-11-14  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR tree-optimization/34046
+       * cfg.c (update_bb_profile_for_threading): Avoid the division for the
+       scaling if the old probability is greater than the new base.
+
+2007-11-14  Sebastian Pop  <sebastian.pop@amd.com>
+
+       * tree-ssa-loop-ivcanon.c (try_unroll_loop_completely): Remove
+       unused edges after loop duplication.
+
+2007-11-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (TARGET_CPU_DEFAULT_*): Substitute with ...
+       (enum target_cpu_default): ... this enum.
+       (TARGET_CPU_DEFAULT_NAMES): Remove macro.  Move initializer to ...
+       * config/i386/i386.c (override_options): ... here.
+       * config/i386/i386-interix.h (TARGET_CPU_DEFAULT): Use
+       TARGET_CPU_DEFAULT_i486.
+
+2007-11-14  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * global.c (rest_of_handle_global_alloc): Fix comment typos.
+       * config/sh/sh.c (sh_rtx_costs): Likewise.
+       * ChangeLog: Likewise.
+
+2007-11-13  Sebastian Pop  <sebastian.pop@amd.com>
+
+       * tree-chrec.h (build_polynomial_chrec): RHS of a chrec
+       should not be of pointer type.
+
+2007-11-13  Michael Meissner  <michael.meissner@amd.com>
+
+       * config/i386/i386.c (ix86_sse5_valid_op_p): Put type on separate line.
+
+2007-11-13  Sterling Augustine  <sterling@tensilica.com>
+           Bob Wilson  <bob.wilson@acm.org>
+       
+       * config/xtensa/unwind-dw2-xtensa.c: New.
+       * config/xtensa/unwind-dw2-xtensa.h: New.
+       * config/xtensa/xtensa.h (MUST_USE_SJLJ_EXCEPTIONS): Remove.
+       (DWARF2_UNWIND_INFO): Remove.
+       (DWARF_FRAME_REGISTERS): Define.
+       (EH_RETURN_DATA_REGNO): Define.
+       * config/xtensa/xtensa.md (UNSPECV_EH_RETURN): Define.
+       (eh_return): New.
+       * config/xtensa/t-xtensa (LIB2ADDEH): Define.
+       
+2007-11-13  Jakub Jelinek  <jakub@redhat.com>
+
+       * doc/invoke.texi: Fix description of -fsched-stalled-insns=0,
+       -fsched-stalled-insns.
+
+       PR tree-optimization/34063
+       * tree-chrec.c (chrec_evaluate): Put CHREC_LEFT based argument
+       as first chrec_fold_plus operand rather than second.
+
+2007-11-13  Diego Novillo  <dnovillo@google.com>
+
+       PR tree-optimization/33870
+       * tree.h (strcut tree_memory_tag): Add field unpartitionable.
+       Remove field in_nested_struct.
+       (struct tree_struct_field_tag): Add field nesting_level.
+       (sft_in_nested_struct): Remove.
+       (sft_nesting_level): Define.
+       (sft_unpartitionable_p): Define.
+       * tree-ssa-alias.c (mem_sym_score): If mp->var is not
+       partitionable, return long_max.
+       (compute_memory_partitions): Do not partition sfts marked
+       unpartitionable.
+       (create_sft): Add argument nesting_level.  Set
+       sft_nesting_level with it.  Update all users.
+       (create_overlap_variables_for): Show nesting level.
+       * tree-dfa.c (dump_subvars_for): Likewise.
+       (dump_variable): Likewise. Show whether the sft is
+       partitionable or not.
+       * tree-flow.h (struct fieldoff): Remove field in_nested_struct.
+       Add field nesting_level.
+       * tree-ssa-structalias.c (struct variable_info): Remove
+       field in_nested_struct.
+       (push_fields_onto_fieldstack): Add argument nesting_level.
+       Update all users.  Update documentation. Update pair->nesting_level
+       with nesting_level.  Make recursive calls with nesting_level + 1.
+       (set_uids_in_ptset): If an sft is added to the points-to set,
+       mark it as unpartitionable.
+       * tree-ssa-operands.c (ref_nesting_level): New.
+       (add_vars_for_offset): Call it.  Add argument full_ref. Update
+       callers.  If var is inside a nested structure and the nesting level
+       of full_ref is lower than the nesting level of var,
+       adjust offset by the offset of var.
+
+2007-11-13  Victor Kaplansky  <victork@il.ibm.com>
+
+       PR tree-optimization/32582
+       * Makefile.in (CRTSTUFF_CFLAGS): Add -fno-tree-vectorize
+
+2007-11-12  Danny Smith  <dannysmith@users.sourceforge.net>
+
+       * doc/extend.texi (dllimport): Document that pointers to dllimport'd
+       functions can be used as constant.
+
+2007-11-12  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/34035
+       * cse.c (cse_cfg_altered): New global variable.
+       (cse_jumps_altered): Make boolean.
+       (recorded_label_ref): Likewise.
+       (cse_insn): Adjust for above changes.
+       (cse_extended_basic_block): Likewise.  Set cse_cfg_altered
+       if dead edges have been purged.
+       (cse_main): Change return value specification and adjust code.
+       (rest_of_handle_cse): Adjust for above change.
+       (rest_of_handle_cse2): Likewise.
+       * gcse.c (rest_of_handle_gcse): Likewise.
+
+2007-11-12  Dwarakanath Rajagopal  <dwarak.rajagopal@amd.com>
+           Michael Meissner  <michael.meissner@amd.com>
+
+       * config/i386/i386.md (sse5_setcc<mode>): Use <ssemodefsuffix> to
+       get the appropriate suffix for the coms* instruction.
+       (sse5_pcmov_<mode>): Restrict operands of pcmov
+       for scalar case to be only xmm registers and not memory.
+
+       * config/i386/sse.md (sse5_pcmov_<mode>): Correct the operand
+       constraints to follow the mnemonics for the pcmov instruction   
+
+2007-11-12  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR target/34042
+       * config/mips/mips.c (mips_return_fpr_single): New function.
+       (mips_function_value): Use it when returning single-field
+       aggregates in FPRs.
+       (mips_expand_call): Handle the PARALLELs created by
+       mips_return_fpr_single.
+
+2007-11-12  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34070
+       * fold-const.c (fold_binary): If testing for non-negative
+       operands with tree_expr_nonnegative_warnv_p make sure to
+       use op0 which has all (sign) conversions retained.
+
+2007-11-12  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/34027
+       * fold-const.c (fold_binary): Fold n - (n / m) * m to n % m.
+       (fold_binary): Fold unsinged FLOOR_DIV_EXPR to TRUNC_DIV_EXPR.
+
+2007-11-12  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/33953
+       * tree-vect-transform.c (vectorizable_operation): In case of SLP,
+       allocate vec_oprnds1 according to the number of created vector
+       statements. In case of shift with scalar argument, store scalar
+       operand for every vector statement to be created for the SLP node.
+       Fix a comment.
+
+2007-11-10  Steven Bosscher  <stevenb.gcc@gmail.com>
+
+       * gcse.c (CUID_INSN): Remove.
+       (cuid_insn): Ditto.
+       (alloc_gcse_mem): Don't allocate cuid_insn.
+       (free_gcse_mem): Don't free cuid_insn.
+
+2007-11-10  Jakub Jelinek  <jakub@redhat.com>
+
+       PR fortran/34020
+       * gimplify.c (goa_lhs_expr_p): Inside INDIRECT_REF handle unshared
+       nops.
+
+       PR middle-end/34018
+       * tree-inline.h (copy_body_data): Add regimplify field.
+       * tree-inline.c (copy_body_r): Set id->regimplify to true
+       if an TREE_INVARIANT ADDR_EXPR is no longer invariant after
+       substitutions.
+       (copy_bb): Clear id->regimplify before walk_tree, if it is
+       set afterwards, regimplify the whole statement.
+
+       PR tree-optimization/33680
+       * tree-data-ref.c (split_constant_offset) <case ADDR_EXPR>: Punt
+       if the added cast involves variable length types.
+
+2007-11-09  Alexander Monakov  <amonakov@ispras.ru>
+           Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * sched-deps.c (sched_analyze_insn): Use MOVE_BARRIER
+       instead of TRUE_BARRIER for jumps.  Add register dependencies
+       even when reg_pending_barrier is set.
+
+2007-11-09  Alexander Monakov  <amonakov@ispras.ru>
+
+       * haifa-sched.c (haifa_classify_insn): Rename to ...
+       (haifa_classify_rtx): ...  this.  Improve handling of COND_EXECs,
+       handle PARALLELs by recursing.  Use it ...  
+       (haifa_classify_insn): ...  here.  Reimplement.
+
+2007-11-09  Richard Guenther  <rguenther@suse.de>
+
+       * bitmap.h (bitmap_single_bit_set_p): Declare.
+       * bitmap.c (bitmap_single_bit_set_p): New function.
+       * tree-ssa-alias.c (add_may_alias_for_new_tag): Use it.
+       (maybe_create_global_var): Use bitmap_empty_p.
+
+2007-11-09  Paolo Bonzini  <bonzini@gnu.org>
+           Jakub Jelinek  <jakub@redhat.com>
+
+       PR rtl-optimization/34012
+       * fwprop.c (try_fwprop_subst): Do not replace if the new
+       SET_SRC has a higher cost than the old one.
+
+2007-11-09  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/33732
+       * reload.c (push_reload): Check that the REG_DEAD note was referring
+       to a hardreg or to a pseudo that has been assigned exactly one hardreg
+       before considering it in order to select the reload register.
+       (combine_reloads): Likewise.
+       (find_dummy_reload): Likewise.
+
+2007-11-09  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow.h (struct ptr_info_def): Make escape_mask a ENUM_BITFIELD.
+       (struct ptr_info_def): Likewise.
+       (enum escape_type): Also use bit zero.
+
+2007-11-09  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33604
+       * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_vars):
+       Disregard changes in CV qualifiers of pointed to types for
+       forward propagating ADDR_EXPRs.
+       * tree-ssa-ccp.c (fold_stmt_r): Preserve volatileness of the original
+       expression.
+
+2007-11-09  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * dse.c (find_shift_sequence): Always choose an integer mode for
+       new_mode.
+       (replace_read): Require both the read and store mode to be
+       integer ones.  Remove a then-redundant FLOAT_P check.
+
+2007-11-08  Richard Guenther  <rguenther@suse.de>
+
+       * tree-dfa.c (remove_referenced_var): If removing a
+       variable which has subvars, also remove those from
+       the referenced vars.  Do not create a variable annotation.
+
+2007-11-08  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_expand_prologue): Remove first
+       argument for gen_entry calls.
+       * config/xtensa/xtensa.md: Add new "entry" value to "type" attribute.
+       (entry): Use the new attribute value.  Remove unused first operand.
+
+2007-11-08  Tom Tromey  <tromey@redhat.com>
+
+       * c-parser.c (c_parser_translation_unit): Use location in error.
+       (c_parser_external_declaration): Likewise.
+       (c_parser_declaration_or_fndef): Likewise.
+       (c_parser_enum_specifier): Likewise.
+       (c_parser_struct_or_union_specifier): Likewise.
+       (c_parser_struct_declaration): Likewise.
+       (c_parser_typeof_specifier): Likewise.
+       (c_parser_parms_list_declarator): Likewise.
+       (c_parser_asm_string_literal): Likewise.
+       (c_parser_braced_init): Likewise.
+       (c_parser_initelt): Likewise.
+       (c_parser_compound_statement_nostart): Likewise.
+       (c_parser_statement_after_labels): Likewise.
+       (c_parser_do_statement): Likewise.
+       (c_parser_asm_statement): Likewise.
+       (c_parser_conditional_expression): Likewise.
+       (c_parser_unary_expression): Likewise.
+       (c_parser_sizeof_expression): Likewise.
+       (c_parser_postfix_expression): Likewise.
+       (c_parser_postfix_expression_after_paren_type): Likewise.
+       (c_parser_objc_class_instance_variables): Likewise.
+       (c_parser_objc_method_definition): Likewise.
+       (c_parser_objc_methodprotolist): Likewise.
+       (c_parser_pragma): Likewise.
+       (c_parser_omp_clause_num_threads): Likewise.
+       (c_parser_omp_clause_schedule): Likewise.
+       (c_parser_omp_all_clauses): Likewise.
+       (c_parser_omp_sections_scope): Likewise.
+       (c_parser_label): Use location of label, not colon.
+
+2007-11-08  Danny Smith  <dannysmith@users.sourceforge.net>
+
+       PR target/33774
+       * config/i386/cygming.h (BIGGEST_FIELD_ALIGNMENT): Define only if
+       IN_TARGET_LIBS.
+
+2007-11-07  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/33826
+       * ipa-pure-const.c (static_execute): Added code to keep recursive
+       functions from being marked as pure or const.
+       * ipa-utils.c (searchc): Fixed comment.
+               
+2007-11-08  Tom Tromey  <tromey@redhat.com>
+
+       * common.opt (fshow-column): Default to 0.
+       * configure: Rebuilt.
+       * configure.ac (--enable-mapped-location): Default to 'yes'.
+
+2007-11-07  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * common.opt: Add pointer to doc/options.texi.
+       * doc/invoke.texi (-fdse, -fdce, -fauto-inc-dec, -fipa-pure-const,
+       -fipa-reference): Add or correct doc.  Sorted options list for -Os
+       -O, -O2.
+
+2007-11-07  Bernhard Fischer  <aldot@gcc.gnu.org>
+
+       PR target/16350
+       * config.gcc: For arm*b-* define TARGET_BIG_ENDIAN_DEFAULT.
+       * config/arm/linux-elf.h (TARGET_ENDIAN_DEFAULT): Define based on
+       TARGET_BIG_ENDIAN_DEFAULT.  Use for MULTILIB_DEFAULTS.
+       (TARGET_DEFAULT): Set according to TARGET_ENDIAN_DEFAULT.
+       (LINUX_TARGET_LINK_SPEC): Pass -mlittle-endian on to the assembler.
+       * config/arm/linux-eabi.h (TARGET_LINKER_EMULATION): Set according
+       to TARGET_BIG_ENDIAN_DEFAULT.
+       (SUBTARGET_EXTRA_LINK_SPEC): Likewise.
+       * config/arm/bpabi.h (TARGET_DEFAULT_MASK): Set according
+       to TARGET_BIG_ENDIAN_DEFAULT.
+
+2007-11-07  Diego Novillo  <dnovillo@google.com>
+
+       * tree.h (struct tree_struct_field_tag): Move field
+       in_nested_struct ...
+       (struct tree_memory_tag): ... here.
+
+2007-11-07  Diego Novillo  <dnovillo@google.com>
+
+       PR 33870
+       * tree.h (struct tree_struct_field_tag): Add field in_nested_struct.
+       (SFT_IN_NESTED_STRUCT): Define.
+       * tree-dfa.c (dump_subvars_for): Show offset of each sub-var.
+       * tree-flow.h (struct fieldoff): Add field in_nested_struct.
+       * tree-ssa-structalias.c (struct variable_info): Likewise.
+       (push_fields_onto_fieldstack): If OFFSET is positive,
+       set in_nested_struct.
+       (create_variable_info_for): Copy setting of
+       in_nested_struct from the field offset object.
+       (set_uids_in_ptset): Set SFT_IN_NESTED_STRUCT from the
+       variable info object.
+       * tree-ssa-operands.c (add_vars_for_offset): If VAR
+       belongs to a nested structure, adjust OFFSET by SFT_OFFSET(VAR).
+
+2007-11-07  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/33737
+       * cfgcleanup.c (try_crossjump_to_edge): Add count and frequency of
+       target block after computing the probabilities of outgoing edges.
+       Cap the frequency to BB_FREQ_MAX.
+       * tree-ssa-threadupdate.c (redirect_edges): Also adjust count and
+       frequency of the basic block if it has been reused.
+
+2007-11-07  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/33822
+       * rtl.h (REG_OFFSET): Fix comment.
+       * var-tracking.c (INT_MEM_OFFSET): New macro.
+       (var_mem_set): Use it.
+       (var_mem_delete_and_set): Likewise.
+       (var_mem_delete): Likewise.
+       (same_variable_part_p): Likewise.
+       (vt_get_decl_and_offset): Likewise.
+       (offset_valid_for_tracked_p): New predicate.
+       (count_uses): Do not track locations with invalid offsets.
+       (add_uses): Likewise.
+       (add_stores): Likewise.
+
+2007-11-07  Tom Tromey  <tromey@redhat.com>
+
+       * Makefile.in (tree-ssa-structalias.o): Depend on $(FUNCTION_H)
+       (BASIC_BLOCK_H): Add vec.h, $(FUNCTION_H).
+
+2007-11-07  Dmitry Zhurikhin  <zhur@ispras.ru>
+           Andrey Belevantsev  <abel@ispras.ru>
+
+       * modulo-sched.c (sms_order_nodes, permute_partial_schedule,
+       generate_prolog_epilog, duplicate_insns_of_cycles): Fix prototypes.
+       (calculate_order_params, sms_order_nodes): New parameter pmax_asap.
+       Save calculated max_asap in it.         
+       (sms_schedule): Calculate maxii using max_asap.
+
+2007-11-07  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * doc/invoke.texi: Replace rs6000 dfp switches -mdfp/-mno-dfp
+       with -mhard-dfp/-mno-hard-dfp.
+
+2007-11-07  Maxim Kuvyrkov  <maxim@codesourcery.com>
+           Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/33670
+       * haifa-sched.c (check_sched_flags): Remove.
+       (sched_init): Don't call it.
+
+2007-11-06  Diego Novillo  <dnovillo@google.com>
+
+       * tree-flow.h (struct fieldoff): Reformat comment. Document fields.
+       * tree-ssa-operands.c: Tidy top-level comments.
+       (add_vop): Likewise.
+       (add_vars_for_offset): Tidy parameter formatting..
+       (get_addr_dereference_operands): Likewise.
+       (get_indirect_ref_operands): Likewise.
+       (get_expr_operands) <OMP_ATOMIC_LOAD>: Reformat.
+       <OMP_ATOMIC_STORE>: Likewise.
+
+2007-11-06  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/32787
+       * config/i386/driver-i386.c: Test for __GNUC__ instead of
+       GCC_VERSION which is always defined.
+
+2007-11-06  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
+
+       PR target/30961
+       * reload.c (find_reloads): Also check in_reg when handling a
+       simple move with an input reload and a destination of a hard
+       register.
+
+2007-11-06  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * config/m68k/m68k.c (sched-int.h, insn-codes.h): New includes.
+       (TARGET_SCHED_ADJUST_COST, TARGET_SCHED_VARIABLE_ISSUE,
+       TARGET_SCHED_INIT_GLOBAL, TARGET_SCHED_FINISH_GLOBAL,
+       TARGET_SCHED_INIT, TARGET_SCHED_DFA_PRE_ADVANCE_CYCLE,
+       TARGET_SCHED_DFA_POST_ADVANCE_CYCLE): Redefine.
+       (m68k_sched_attr_type2): New function.
+       (sched_adjust_cost_state): New static variable.
+       (m68k_sched_adjust_cost): New static function implementing
+       scheduler hook.
+       (sched_ib_size, sched_ib_filled, sched_ib_insn, sched_mem_unit_code):
+       New static variables.
+       (m68k_sched_variable_issue): New static function implementing
+       scheduler hook.
+       (sched_dump_class_def, sched_dump_class_func_t): New typedefs.
+       (sched_dump_split_class): New static function.
+       (sched_dump_dfa_guess_unit_code, sched_dump_dfa_state): New static
+       variables.
+       (sched_dump_dfa_class, m68k_sched_dump): New static function.
+       (m68k_sched_md_init_global, m68k_sched_md_finish_global,
+       m68k_sched_md_init, m68k_sched_dfa_pre_advance_cycle,
+       m68k_sched_dfa_post_advance_cycle): New static functions implementing
+       scheduler hooks.
+
+       * config/m68k/m68k.h (m68k_sched_attr_type2): Declare.
+       (CPU_UNITS_QUERY): Define.
+
+       * config/m68k/cf.md: New file.
+       * config/m68k/m68.md (cf.md): New include.
+
+2007-11-06  Tom Tromey  <tromey@redhat.com>
+
+       PR c++/32256
+       PR c++/32368
+       * function.c (saved_in_system_header): New global.
+       (push_cfun): Save in_system_header.
+       (pop_cfun): Restore in_system_header.
+       (push_struct_function): Save in_system_header.
+
+2007-11-06  Douglas Gregor  <doug.gregor@gmail.com>
+
+       PR c++/33977
+       PR c++/33886
+       * c-common.c (c_build_qualified_type): Moved to c-typeck.c.
+       (complete_array_type): Set canonical type appropriately.
+       * c-typeck.c (c_build_qualified_type): Moved from c-common.c. The
+       C and C++ front ends now have different versions of this function,
+       because the C++ version needs to maintain canonical types here.
+
+2007-11-04  Razya Ladelsky  <razya@il.ibm.com>
+       
+       * tree-parloops.c (reduction_info): Remove reduction_init field.
+       (initialize_reductions): Remove creation of the reduction_init variable.
+       (struct data_arg): Remove.
+       (add_field_for_reduction, create_stores_for_reduction): New functions.
+       (add_field_for_name): Remove reduction handling.
+       (separate_decls_in_loop): Call add_field_for_reduction,
+       create_stores_for_reduction.
+
+2007-11-06  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/33458
+       * tree-inline.c (copy_phis_for_bb): If PHI arg substitution creates
+       !is_gimple_val PHI argument, gimplify it and insert it on edge.
+
+       PR tree-optimization/33993
+       * tree-vect-transform.c (vect_get_constant_vectors): Use build_vector
+       rather than build_constructor_from_list if all list values are
+       constants.
+       (get_initial_def_for_induction): Use build_vector instead of
+       build_constructor_from_list.
+
+2007-11-05  Mark Mitchell  <mark@codesourcery.com>
+
+       PR target/33579
+       * tree.h (DECL_INIT_PRIORITY): Do not require DECL_HAS_INIT_PRIORITY_P.
+       (DECL_FINI_PRIORITY): Likewise.
+       * tree.c (decl_init_priority_lookup): Remove assert.
+       (decl_fini_priority_insert): Likewise.
+       * cgraphunit.c (static_ctors): Make it a VEC.
+       (static_dtors): Likewise.
+       (record_cdtor_fn): Adjust accordingly.
+       (build_cdtor): Generate multiple functions for each initialization
+       priority.
+       (compare_ctor): New function.
+       (compare_dtor): Likewise.
+       (cgraph_build_cdtor_fns): Sort the functions by priority before
+       calling build_cdtor.
+       (cgraph_build_static_cdtor): Put the priority in the function's name.
+
+2007-11-05  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR driver/32632
+       * common.opt: Add shared and pie.
+
+2007-11-05  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_expand_nonlocal_goto): Do not
+       replace references to virtual_stack_vars_rtx in goto_handler.
+
+2007-11-05  Paul Brook  <paul@codesourcery.com>
+
+       * config.gcc (arm*-*-*): Set c_target_objs and cxx_target_objs.
+       * config/arm/arm.c (arm_lang_output_object_attributes_hook): New.
+       (arm_file_start): Don't set Tag_ABI_PCS_wchar_t.  Call
+       arm_lang_output_object_attributes_hook.
+       * config/arm/arm.h (arm_lang_output_object_attributes_hook): Declare.
+       (REGISTER_TARGET_PRAGMAS): Call arm_lang_object_attributes_init.
+       * config/arm/arm-protos.h (arm_lang_object_attributes_init): Add
+       prototype.
+       * config/arm/t-arm.c (arm.o): New rule.
+       * config/arm/arm-c.c: New file.
+
+2007-11-05  Nick Clifton  <nickc@redhat.com>
+           Sebastian Pop  <sebastian.pop@amd.com>
+
+       PR tree-optimization/32540
+       PR tree-optimization/33922
+       * doc/invoke.texi: Document PARAM_MAX_PARTIAL_ANTIC_LENGTH.
+       * tree-ssa-pre.c: Include params.h.
+       (compute_partial_antic_aux): Use PARAM_MAX_PARTIAL_ANTIC_LENGTH
+       to limit the maximum length of the PA set for a given block.
+       * Makefile.in: Add a dependency upon params.h for tree-ssa-pre.c
+       * params.def (PARAM_MAX_PARTIAL_ANTIC_LENGTH): New parameter.
+
+2007-11-05  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * libgcc2.c (__fixunstfDI, __fixunsxfDI, __fixunsdfDI,
+       __fixunssfDI): Make return type unsigned.
+       * libgcc2.h (__fixunstfDI, __fixunsxfDI, __fixunsdfDI,
+       __fixunssfDI): Make return type unsigned.
+
+2007-11-05  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/33856
+       * tree-data-ref.c (get_references_in_stmt): Don't add
+       REFERENCE_CLASS_P trees to references vector if get_base_address
+       returns NULL on them.
+
+2007-11-05  Alexandre Oliva  <aoliva@redhat.com>
+
+       * cfg.c (dump_cfg_bb_info): Update bb_bitnames to match enum.
+
+2007-11-04  Andrew Pinski  <pinskia@gmail.com>
+
+       PR middle-end/32931
+       * fold-const.c (fold_binary <case EQ_EXPR>): Convert the inner type
+       for TRUTH_NOT_EXPR to type.
+
+2007-11-04  Gerald Pfeifer  <gerald@pfeifer.com>
+
+       * doc/contrib.texi (Contributors): Add Manuel Lopez-Ibanez.
+
+2007-11-04  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
+
+       PR fortran/10220
+       * dwarf2out.c (add_calling_convention_attribute): Change
+       second argument. Set calling convention to DW_CC_program for
+       Fortran main program.
+       (gen_subprogram_die): Adjust to new prototype for
+       add_calling_convention_attribute.
+
+2007-11-03  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/33987
+       * tree-vect-transform.c (get_initial_def_for_reduction): Fix assert.
+       Fix indentation.
+       (vectorizable_reduction): Add type check.
+
+2007-11-03  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c/29062
+       * c-parser.c (c_parser_statement_after_labels): Error if a
+       declaration is parsed after a label.
+       
+2007-11-03  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       PR debug/33921
+       * reorg.c (emit_delay_sequence): Do not clear the locator on
+       the jump instruction.
+
+2007-11-03  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/33670
+       * haifa-sched.c (ok_for_early_queue_removal): Don't walk out of the
+       current sched region.
+
+2007-11-02  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/ia64/ia64.c (struct reg_write_state): Change into
+       unsigned short bitfields rather than unsigned int, decrease
+       first_pred to just 10 bits.
+       (rws_insn): Change into a bitmap or if not ENABLE_CHECKING
+       into two char array.
+       (rws_insn_set, rws_insn_test): New functions.
+       (in_safe_group_barrier): New variable.
+       (rws_update): Remove first argument, always set rws_sum array.
+       (rws_access_regno): Use rws_insn_set macro.  Only call rws_update
+       or update rws_sum if !in_safe_group_barrier, adjust rws_update args.
+       (rtx_needs_barrier): Use rws_insn_test macro.
+       (safe_group_barrier_needed): Don't save/restore rws_sum array,
+       instead set/clear in_safe_group_barrier flag.
+
+2007-11-02  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_expand_prologue): Put a
+       REG_FRAME_RELATED_EXPR note on the last insn that sets up the stack
+       pointer or frame pointer.
+       * config/xtensa/xtensa.h (DWARF_UNWIND_INFO): Delete.
+       (MUST_USE_SJLJ_EXCEPTIONS): Define.
+       (DWARF2_UNWIND_INFO): Define.
+       (INCOMING_RETURN_ADDR_RTX): Define.
+       (DWARF_FRAME_RETURN_COLUMN): Define.
+
+2007-11-02  Tom Tromey  <tromey@redhat.com>
+
+       * varpool.c (dump_varpool): Use 'next', not 'next_needed' when
+       traversing pool.
+
+2007-11-02  Diego Novillo  <dnovillo@google.com>
+
+       * langhooks.h (struct lang_hooks_for_callgraph): Remove third
+       argument from function pointer ANALYZE_EXPR.  Update all users.
+       * cgraph.c (debug_cgraph_node): New.
+       (debug_cgraph): New.
+
+2007-11-02  Jakub Jelinek  <jakub@redhat.com>
+
+       PR rtl-optimization/33648
+       * cfgrtl.c (cfg_layout_split_edge): Initialize BB_PARTITION of
+       the newly created basic block.
+
+2007-11-01  Richard Guenther  <rguenther@suse.de>
+
+       * ggc-page.c (extra_order_size_tab): Add bitmap_head size.
+
+2007-11-01  Steven Bosscher  <stevenb.gcc@gmail.com>
+
+       PR rtl-optimization/33828
+       * gcse.c (compute_code_hoist_vbeinout): Fix order of computation
+       of VBEIN and VBEOUT.
+
+2007-11-01  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * optabs.c (prepare_cmp_insn): Merge a couple of conditional blocks.
+       * sched-rgn.c (compute_trg_info): Zero 'el' local variable.
+       * tree-if-conv.c (process_phi_nodes): Zero 'cond' local variable.
+
+2007-11-01  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * gcc.c (getenv_spec_function): Escape the environment variable's
+       value.
+
+2007-11-01  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/invoke.texi (Optimize Options): Under -fcse-follow-jumps,
+       show that CSE means common subexpression elimination.  Change wording
+       for -fsee and define LCM.  Remove capitalization of optimizations
+       for -ftree-reassoc, -ftree-pre, and -ftree-fre.
+
+2007-11-01  Janis Johnson  <janis187@us.ibm.com>
+
+       PR testsuite/25352
+       * doc/sourcebuild.texi (Test Directives): Document that xfail
+       has no effect for dg-do except when dg-do-what is "run".
+
+2007-11-01  Tom Tromey  <tromey@redhat.com>
+
+       * c-decl.c (grokdeclarator): Set decl source locations.
+       * c-parser.c (c_parser_enum_specifier): Set location.
+       (c_parser_struct_or_union_specifier): Likewise.
+
+2007-11-01  Tom Tromey  <tromey@redhat.com>
+
+       * print-tree.c (print_node): Print column number.
+
+2007-11-01  Jakub Jelinek  <jakub@redhat.com>
+
+       PR debug/33537
+       * dwarf2out.c (gen_formal_parameter_die, gen_variable_die,
+       gen_decl_die): Use TREE_TYPE (TREE_TYPE (decl)) as type
+       rather than TREE_TYPE (decl) if DECL_BY_REFERENCE (decl).
+
+       PR rtl-optimization/33673
+       * gcse.c (cprop_jump): If a conditional jump has been optimized
+       into unconditional jump, make the remaining normal edge fallthru
+       and delete the jump insn.
+
+2007-11-01  Ben Elliston  <bje@au.ibm.com>
+
+       * emit-rtl.c (set_reg_attrs_from_mem): Clarify function comment.
+       (set_mem_attrs_from_reg): Likewise.
+
+2007-11-01  Michael Matz  <matz@suse.de>
+
+       PR tree-optimization/33961
+       * tree-ssa-phiopt.c (struct name_to_bb.store): New member.
+       (name_to_bb_hash, name_to_bb_eq): Consider and check it.
+       (add_or_mark_expr): New argument 'store', using it to search
+       the hash table.
+       (nt_init_block): Adjust calls to add_or_mark_expr.
+
+2007-10-31  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/31507
+       * config/i386/i386.md (pushsf_rex64): Use X instead of < constraints
+       for the first push_operand.
+
+2007-10-31  Revital Eres  <eres@il.ibm.com>
+
+       * config/rs6000/paired.md (sminv2sf3, smaxv2sf3, reduc_smax_v2sf,
+       reduc_smin_v2sf vec_interleave_highv2sf, vec_interleave_lowv2sf,
+       vec_extract_evenv2sf, vec_extract_oddv2sf, reduc_splus_v2sf,
+       movmisalignv2sf, vcondv2sf): New.
+       (UNSPEC_INTERHI_V2SF, UNSPEC_INTERLO_V2SF, UNSPEC_EXTEVEN_V2SF,
+       UNSPEC_EXTODD_V2SF): Define new constants.
+       * config/rs6000/rs6000-protos.h (paired_expand_vector_move,
+       paired_emit_vector_cond_expr): New.
+       * config/rs6000/rs6000-c.c (__PAIRED__): Add new builtin_define.
+       * config/rs6000/rs6000.c (paired_expand_vector_move,
+       paired_emit_vector_cond_expr, paired_emit_vector_compare):
+       New functions.
+       * config/rs6000/750cl.h (ASM_CPU_SPEC): Pass down -m750cl option.
+
+2007-10-31  Sebastian Pop  <sebastian.pop@amd.com>
+
+       PR tree-optimization/32377
+       * tree-data-ref.c (compute_overlap_steps_for_affine_univar): Make it
+       work also for unknown number of iterations.
+       (analyze_subscript_affine_affine): Clean up.  Don't fail when the 
+       number of iterations is not known.
+
+2007-10-31  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33779
+       * fold-const.c (extract_muldiv_1): Make sure to not introduce
+       new undefined integer overflow.
+       (fold_binary): Avoid useless conversion.
+
+2007-10-31  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR target/33948
+       * config/mips/mips.c (mips_fpr_return_fields): Fix SCALAR_TYPE_P check.
+
+2007-10-31  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/rs6000/rs6000.opt: Rename -mdfp option to -mhard-dfp.
+
+       * config/s390/s390.c: (override_options): Replace
+       -mhard-dfp/-msoft-dfp with -mhard-dfp/-mno-hard-dfp.
+       * config/s390/s390.opt: Likewise.
+       * config/s390/s390.h: Add MASK_HARD_DFP to the TARGET_DEFAULT
+       definition.
+
+2007-10-30  Janis Johnson  <janis187@us.ibm.com>
+
+       * tree-ssa.c (execute_update_addresses_taken): Initialize update_vops.
+
+2007-10-30  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/invoke.texi (Option Summary): Add -fdce and -fdse to list of
+       optimization options.
+       (Optimize Options): Add -fdce and -fdse to the list of optimizations
+       enabled by -O.  Document -fdce and -fdse.
+
+2007-10-30  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/33709
+       * fold-const.c (fold_binary): If one argument is COMPOUND_EXPR,
+       convert second operand of COMPOUND_EXPR to the original type of
+       that argument.
+
+2007-10-30  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-operands.c (add_vars_for_offset): Fix exit test
+       of loop adding SFTs as virtual operands.
+
+2007-10-30  Richard Guenther  <rguenther@suse.de>
+
+       * Makefile.in (dse.o): Add $(OPTABS_H) and $(RECOG_H) dependencies.
+
+2007-10-29  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/32893
+       * tree-vectorize.c (vect_can_force_dr_alignment_p): Check
+       STACK_BOUNDARY instead of PREFERRED_STACK_BOUNDARY.
+
+2007-10-29  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * longlong.h (add_ssaaaa): Support Intel asm syntax in i386 and
+       x86_64 versions.
+       (sub_ddmmss): Likewise.
+       (umul_ppmm): Likewise.
+       (udiv_qrnnd): Likewise.
+
+2007-10-29  Janis Johnson  <janis187@us.ibm.com>
+
+       PR testsuite/24841
+       * doc/sourcebuild.texi (Test Directives): Document that dg-require
+       directives must come before dg-additional-sources.
+
+2007-10-29  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/33723
+       * c-gimplify.c (c_gimplify_expr): Optimize INIT_EXPR or
+       MODIFY_EXPR with non-addressable COMPOUND_LITERAL_EXPR as source.
+
+2007-10-29  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR tree-optimization/33614
+       * gimplify.c (gimplify_init_constructor): Gimplify vector constructors
+       if they can't be reduced to VECTOR_CSTs and aren't legitimate
+       initializer constants.
+
+2007-10-29  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33870
+       * tree-ssa-operands.c (add_vars_for_offset): Remove mpt_vars parameter.
+       (add_virtual_operand): Do not recurse into MPTs looking for pointed-to
+       SFTs.
+
+2007-10-29  Richard Guenther  <rguenther@suse.de>
+
+       * passes.c (init_optimization_passes): Exchange store_copy_prop
+       with copy_prop.
+       * tree-pass.h (pass_store_copy_prop): Remove.
+       * tree-ssa-copy.c (do_store_copy_prop): Remove.
+       (stmt_may_generate-copy): Do not handle store_copy_prop.
+       (get_copy_of_val): Likewise.
+       (set_copy_of_val): Likewise.
+       (copy_prop_visit_assignment): Likewise.
+       (copy_prop_visit_stmt): Likewise.
+       (copy_prop_visit_phi_node): Likewise.
+       (init_copy_prop): Likewise.
+       (execute_copy_prop): Likewise.
+       (do_copy_prop): Remove.
+       (gate_store_copy_prop): Likewise.
+       (store_copy_prop): Likewise.
+       (pass_store_copy_prop): Likewise.
+       (pass_copy_prop): Call execute_copy_prop.
+       * opts.c (decode_options): Do not set flag_tree_store_copy_prop.
+       * common.opt (ftree-store-copy-prop): Mark obsolete.
+       * doc/invoke.texi (ftree-store-copy-prop): Remove documentation.
+
+2007-10-29  Ian Lance Taylor  <iant@google.com>
+
+       * ifcvt.c (noce_can_store_speculate_p): New static function.
+       (noce_process_if_block): Call it.
+       (if_convert): Remove recompute_dominance parameter.  Change all
+       callers.
+
+2007-10-29  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow-inline.h (get_subvar_at): Use binary search.
+       (get_first_overlapping_subvar): New function to binary search
+       for the first overlapping subvar.
+       * tree-ssa-operands.c (add_vars_for_offset): Strip down to
+       just handle adding subvars for a pointed-to subvar.  Optimize
+       and use get_first_overlapping_subvar.
+       (add_vars_for_bitmap): Fold into single caller.
+       (add_virtual_operand): Streamline, inherit add_vars_for_bitmap
+       and non pointed-to bits of add_vars_for_offset.
+
+2007-10-29  Revital Eres  <eres@il.ibm.com> 
+
+       * modulo-sched.c (sms_schedule): Add DF_UD_CHAIN problem.
+
+2007-10-29  Razya Ladelsky  <razya@il.ibm.com>
+           Zdenek Dvorak  <ook@ucw.cz>
+
+       OMP_ATOMIC Changes,
+       reduction support for automatic parallelization.
+
+       * expr.c (expand_expr_real_1): Add cases for OMP_ATOMIC_LOAD,
+       OMP_ATOMIC_STORE.
+       * Makefile.in: Add dependencies to expr.o, tree-parloops.o, omp-low.o
+       * tree-pretty-print.c (dump_generic_node): Add OMP_ATOMIC_LOAD
+       and OMP_ATOMIC_STORE.
+       * tree.h (OMP_DIRECTIVE_P): Add OMP_ATOMIC_LOAD, OMP_ATOMIC_STORE.
+       * gimple-low.c (lower_stmt): Same.
+       * gimplify.c (gimplify_expr): Same.
+       (gimplify_omp_atomic_fetch_op, gimplify_omp_atomic_pipeline,
+       gimplify_omp_atomic_mutex): Remove.
+       (gimplify_omp_atomic): Change it to simply gimplify the
+       statement instead of expanding it.
+       * omp-low.c: Add includes to optabs.h, cfgloop.h.
+       (expand_omp_atomic, expand_omp_atomic_pipeline,
+       goa_stabilize_expr, expand_omp_atomic_mutex,
+       expand_omp_atomic_fetch_op): New functions to implement
+       expansion of OMP_ATOMIC.
+       (expand_omp, build_omp_regions_1): Add support for
+       OMP_ATOMIC_LOAD/OMP_ATOMIC_STORE.
+       * tree-cfg.c (make_edges): add case for OMP_ATOMIC_LOAD,
+       OMP_ATOMIC_STORE.
+       * tree-gimple.c (is_gimple_stmt): Add OMP_ATOMIC_LOAD,
+       OMP_ATOMIC_STORE.
+       * tree-parloops.c: add include to tree-vectorizer.h.
+       (reduction_info): New structure for reduction.
+       (reduction_list): New list to represent list of reductions per loop.
+       (struct data_arg): New helper structure for reduction.
+       (reduction_info_hash, reduction_info_eq, reduction_phi,
+       initialize_reductions, create_call_for_reduction,
+       create_phi_for_local_result, create_call_for_reduction_1,
+       create_loads_for_reductions, create_final_loads_for_reduction):
+       New functions.
+       (loop_parallel_p): Identify reductions, add reduction_list parameter.
+       (separate_decls_in_loop_name): Support reduction variables.
+       (separate_decls_in_loop): Add reduction_list and ld_st_data arguments,
+       call create_loads_for_reduction for each reduction.
+       (canonicalize_loop_ivs): Identify reductions, add reduction_list
+       parameter.
+       (transform_to_exit_first_loop): Add reduction support, add
+       reduction_list parameter.
+       (gen_parallel_loop): Add reduction_list parameter.  Add call
+       separate_decls_in_loop with
+       the new argument.  Traverse reductions and call
+       initialize_reductions, create_call_for_reduction.
+       (parallelize_loops): Create and delete the reduction list.
+       (add_field_for_name): Change use of data parameter.  Add fields for
+       reductions.
+       * tree-vectorizer.h (vect_analyze_loop_form): Add declaration.
+       * tree-vect-analyze.c (vect_analyze_loop_form): export it.
+       * tree.def: Add definitions for OMP_ATOMIC_LOAD, OMP_ATOMIC_STORE.
+       * tree-inline.c (estimate_num_insns_1): add cases for
+       OMP_ATOMIC_LOAD, OMP_ATOMIC_STORE.
+       * tree-cfg.c (make_edges): Add OMP_ATOMIC_LOAD, OMP_ATOMIC_STORE.
+       * tree-ssa-operands.c (get_addr_dereference_operands):
+       New function.  Subroutine of get_indirect_ref_operands.
+       (get_indirect_ref_operands): Call get_addr_dereference_operands.
+       (get_expr_operands): Support OMP_ATOMIC_LOAD, OMP_ATOMIC_STORE.
+
+
+2007-10-29  Hans-Peter Nilsson  <hp@axis.com>
+
+       * config/cris/cris.c: Include df.h.
+       (cris_address_cost): Add gcc_assert for canonicalization
+       assumptions.  For PLUS with MULT or register, correct
+       test for register in other arm.  Tweak comments.
+
+2007-10-28  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-operands.c (add_vars_for_offset): Add parameter
+       telling if the var is to be treated as points-to location.
+       (add_vars_for_bitmap): Pass true to add_vars_for_offset.
+       (add_virtual_operand): Only recurse into MPTs if aliases
+       is from a NMT.
+
+2007-10-28  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-operands.c (add_vars_for_offset): Clean and speed up.
+       (add_vars_for_bitmap): Do not recurse further.  Only add vars
+       for pointed-to SFTs.
+       (add_virtual_operand): Re-instantiate loop to add operands for
+       aliases.  Recurse into MPTs.
+       (get_indirect_ref_operands): If we fall back to use a pointers
+       SMT, make sure to not prune based on the access offset and size.
+
+2007-10-28  Andrew Pinski  <pinskia@gmail.com>
+
+       PR tree-opt/33589
+       * tree-outof-ssa.c (rewrite_trees): If the statement changed, cleanup
+       the eh information on the statement.
+
+2007-10-28  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow.h (subvar_t): Make it a VEC.
+       (struct subvar): Remove.
+       (struct var_ann_d): Use VEC(tree,gc) to store subvars.
+       * tree-flow-inline.h (get_subvar_at): Adjust iterators over
+       variable subvars.
+       * tree-into-ssa.c (mark_sym_for_renaming): Likewise.
+       * tree-nrv.c (dest_safe_for_nrv_p): Likewise.
+       * tree-ssa-alias.c (mark_aliases_call_clobbered): Likewise.
+       (set_initial_properties): Likewise.
+       (setup_pointers_and_addressables): Likewise.
+       (new_type_alias): Likewise.
+       (create_overlap_variables_for): Likewise.
+       * tree-dfa.c (dump_subvars_for): Likewise.
+       * tree-ssa-operands.c (add_vars_for_offset): Likewise.
+       (get_expr_operands): Likewise.
+       (add_to_addressable_set): Likewise.
+       * tree-ssa-structalias.c (set_uids_in_ptset): Likewise.
+
+2007-10-28  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/33920
+       * tree-if-conv.c (tree_if_conversion): Force predicate of single
+       successor bb to true when predecessor bb has NULL predicate.
+       (find_phi_replacement_condition): Assert that tmp_cond is non-null.
+
+2007-10-28  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.md: Add combiner patterns for DImode extensions
+       of HImode and QImode truncations.  Reformat HImode <- QImode pattern
+       for consistency.
+
+2007-10-28  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR target/33895
+       * config/mips/mips.c (mips_output_dwarf_dtprel): Add ATTRIBUTE_UNUSED.
+
+2007-10-28  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * dce.c (delete_unmarked_insns): Just delete the RETVAL and
+       LIBCALL notes if they are about to be moved to the same insn.
+
+2007-10-27  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33870
+       * tree-ssa-operands.c (add_vars_for_offset): Reduce code
+       duplication.  Remove redundant call to access_can_touch_variable.
+       (add_vars_for_bitmap): New helper for recursing over MPT contents.
+       (add_virtual_operand): Use it.
+
+2007-10-26  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR fortran/31608
+       * pa.h (ASM_PN_FORMAT): Delete define.
+
+2007-10-26  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/invoke.texi (Option Summary, optimizations): Remove
+       -fbounds-check.  Add -fassociative-math, -freciprocal-math,
+       -ftree-vrp and -funit-at-a-time.  Change -fno-split-wide-types to
+       -fsplit-wide-types to match later entry.  Break up a long line.
+       (Option Summary, code gen options)  Add -fno-stack-limit.  Add
+       missing @gol to the end of a line.
+       (Optimization Options): Remove -fbounds-check, which is also
+       documented under Code Generation Options.  Remove =n from
+       index entry for -ftree-parallelize-loops.  Change -fno-cprop-registers
+       to -fcprop-registers to match other options, and say when it is
+       enabled rather than disabled.  Remove extra index entry for
+       -fno-cx-limited-range.  Add index entries for -fstack-protector
+       and -fstack-protector-all.
+       (Code Gen Options): Add index entry for -ftls-model.
+
+2007-10-26  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (avr_OS_task_function_p): Add new function.
+       (avr_regs_to_save): Handle functions with 'OS_task' attribute.
+       (avr_simple_epilogue, expand_prologue, avr_asm_function_end_prologue,
+       expand_epilogue, output_movhi): Don't handle 'main' function.
+       (avr_attribute_table): Add 'OS_task' function attribute.
+       * config/avr/avr.h (machine_function): Remove 'is_main' field, add
+       'is_OS_task' field.
+       * config/avr/avr.md (return_from_main_epilogue): Remove insn.
+       (return_from_epilogue, return_from_interrupt_epilogue): Don't handle
+       'main' function.
+       * config/avr/avr.opt (minit-stack): Remove.
+
+2007-10-26  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-nested.c (get_trampoline_type): Fix thinko.
+
+2007-10-26  Douglas Gregor  <doug.gregor@gmail.com>
+
+       PR c++/33601
+       * tree.c (build_offset_type): Build canonical type based on the
+       TYPE_MAIN_VARIANT of the base type.
+
+2007-10-26  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * reorg.c (emit_delay_sequence): Move insn locator from the
+       first insn to the sequence.
+
+2007-10-26  Samuel Tardieu  <sam@rfc1149.net>
+
+       * ipa-pure-const.c (check_decl): Return immediately when
+       pure_const_state has been set to IPA_NEITHER.
+
+2007-10-25  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/33833
+       * tree-vect-analyze.c (vect_analyze_data_refs): Use POINTER_PLUS_EXPR
+       and convert init to sizetype in inner_base construction.
+
+2007-10-25  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow.h (mem_sym_stats): Remove.
+       (dump_mem_sym_stats_for_var): Declare.
+       * tree-dfa.c (dump_variable): Call dump_mem_sym_stats_for_var.
+       (mem_sym_stats): Move ...
+       * tree-ssa-alias.c (mem_sym_stats): ... here and make it static.
+       (mem_sym_score): Rename from ...
+       (pscore): ... this.  Remove.
+       (dump_mem_sym_stats_for_var): New function.  Dump the score, but
+       not the frequencies.
+       (compare_mp_info_entries): Make sort stable by disambiguating
+       on DECL_UID.
+
+2007-10-25  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/33866
+       * tree-vect-transform.c (vectorizable_store): Check operands of all
+       the stmts in the group of strided accesses. Get def stmt type for each
+       store in the group and pass it to vect_get_vec_def_for_stmt_copy ().
+
+2007-10-25  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/constraints.md (Y0): Rename register constraint to Yz.
+       (Yt): Rename register constraint to Y2.
+       * config/i386/sse.md: Use renamed register constraints.
+       * config/i386/mmx.md: Ditto.
+       * config/i386/i386.md: Ditto.
+
+2007-10-25  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * config/i386/i386.md (*dummy_extendsfdf2): Fix operand 1 constraint.
+
+2007-10-24  Chao-ying Fu  <fu@mips.com>
+
+       * dwarf2out.c (base_type_die): Use DW_ATE_unsigned_fixed or
+       DW_ATE_signed_fixed to describe FIXED_POINT_TYPE.
+
+2007-10-24  Samuel Tardieu  <sam@rfc1149.net>
+           Olga Golovanevsky <olga@il.ibm.com>
+       
+       * ipa-struct-reorg.c (replace_field_acc): Make it clear to
+       the compiler that wr.wrap and wr.domain are initialized in
+       any case.
+
+2007-10-24  Samuel Tardieu  <sam@rfc1149.net>
+
+       * ipa-struct-reorg.c (sum_counts): Use HOST_WIDEST_PRINT_DEC
+       to print gcov_type values.
+
+2007-10-24  Eric B. Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/avr.h: Do not include progmem_section definition when
+       building with IN_TARGET_LIBS.
+
+2007-10-24  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR target/33755
+       * config/mips/mips.c (mips_lo_sum_offset): New structure.
+       (mips_hash_base, mips_lo_sum_offset_hash, mips_lo_sum_offset_eq)
+       (mips_lo_sum_offset_lookup, mips_record_lo_sum)
+       (mips_orphaned_high_part_p: New functions.
+       (mips_avoid_hazard): Don't check INSN_P here.
+       (mips_avoid_hazards): Rename to...
+       (mips_reorg_process_insns): ...this.  Cope with
+       !TARGET_EXPLICIT_RELOCS.  Delete orphaned high-part relocations,
+       or turn them into nops.
+       (mips_reorg): Remove TARGET_EXPLICIT_RELOCS check from calls to
+       dbr_schedule and mips_avoid_hazards/mips_reorg_process_insns.
+       (mips_set_mips16_mode): Don't set flag_delayed_branch here.
+       (mips_override_options): Set flag_delayed_branch to 0.
+
+2007-10-24  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h (MOVE_MAX): Use UNITS_PER_WORD and describe
+       MIPS-specific implementation details.
+       (MIPS_MAX_MOVE_BYTES_PER_LOOP_ITER): New macro.
+       (MIPS_MAX_MOVE_BYTES_STRAIGHT): Likewise.
+       (MOVE_RATIO): Define to MIPS_MAX_MOVE_BYTES_STRAIGHT / UNITS_PER_WORD
+       for targets with movmemsi.
+       (MOVE_BY_PIECES_P): Define.
+       * config/mips/mips.c (MAX_MOVE_REGS, MAX_MOVE_BYTES): Delete.
+       (mips_block_move_loop): Add a bytes_per_iter argument.
+       (mips_expand_block_move): Use MIPS_MAX_MOVE_BYTES_STRAIGHT.
+       Update call to mips_block_move_loop.
+
+2007-10-24  Michael Matz  <matz@suse.de>
+
+       PR debug/33868
+       * var-tracking.c (variable_union): Don't break after one loop
+       iteration but only when a difference is found.
+       (dump_variable): Also print DECL_UID.
+
+2007-10-24  Olga Golovanevsky  <olga@il.ibm.com>
+
+       * ipa-type-escape.h: Expose function
+       is_array_access_through_pointer_and_index.
+       * ipa-type-escape.c
+       (is_array_access_through_pointer_and_index):
+       Add three new parameters. Add support of
+       POINTER_PLUS_EXPR tree code.
+
+2007-10-24  Olga Golovanevsky  <olga@il.ibm.com>
+
+       * ipa-struct-reorg.c, ipa-struct-reorg.h: New files.
+       * tree-pass.h: Add pass_ipa_struct_reorg.
+       * common.opt: Add ipa-struct-reorg flag.
+       * Makefile.in: Add ipa-strcut-reorg.o compilation.
+       * passes.c: Add pass pass_ipa_struct_reorg.
+       * params.h:  Add STRUCT_REORG_COLD_STRUCT_RATIO.
+       * params.def: Add PARAM_STRUCT_REORG_COLD_STRUCT_RATIO.
+
+2007-10-24  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/33804
+       * tree-vect-transform.c (vectorizable_operation): Remove the
+       checks that the vectorization is worthwhile from the transformation
+       phase.
+
+2007-10-24  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-vect-analyze.c (vect_build_slp_tree): Return false if
+       vectype cannot be determined for the scalar type.
+       (vect_analyze_slp_instance): Likewise.
+       * tree-vect-transform.c (vect_model_reduction_cost): Change the
+       return type to bool. Return false if vectype cannot be determined 
+       for the scalar type.
+       (vect_get_constant_vectors): Return false if vectype cannot be
+       determined for the scalar type.
+       (get_initial_def_for_induction, vect_get_vec_def_for_operand,
+       get_initial_def_for_reduction, vect_create_epilog_for_reduction,
+       vectorizable_reduction): Likewise.      
+
+2007-10-23  Craig Rodrigues  <rodrigc@gcc.gnu.org>
+
+       * config.gcc: For a FreeBSD target, parse the value of ${target}
+       to determine the value of FBSD_MAJOR, instead of adding an
+       explicit check for every possible FreeBSD major version.
+
+2007-10-23  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR rtl-optimization/33846
+       * combine.c (simplify_shift_const_1) [NOT]: Skip vector modes.
+
+2007-10-23  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/33860
+       * tree-vect-transform.c (vect_analyze_data_ref_access): Don't allow
+       interleaved accesses in case the dr is inside the inner-loop during
+       outer-loop vectorization.
+
+2007-10-23  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * doc/rtl.texi (Flags): Fix MEM_SCALAR_P entry.
+       Document MEM_POINTER.  Replace mentions of "integrated"
+       field with "return_val".  Delete outdated stuff.
+
+2007-10-23  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/rs6000.c (rs6000_override_options): Set
+       rs6000_altivec_abi on AIX.
+       (conditional_register_usage): Set VR20:31 fixed on AIX.
+
+2007-10-23  Richard Guenther  <rguenther@suse.de>
+
+       * alias.c (get_alias_set): For INDIRECT_REFs, deal with
+       SSA_NAME pointers.
+
+2007-10-22  Seongbae Park <seongbae.park@gmail.com>
+           David S. Miller  <davem@davemloft.net>
+
+       * df-scan.c (df_get_call_refs): Mark global registers as both a
+       DF_REF_REG_USE and a non-clobber DF_REF_REG_DEF.
+
+2007-10-22  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/33834
+       PR tree-optimization/33835
+       * tree-vect-analyze.c (vect_analyze_operations): RELEVANT and LIVE
+       stmts need to be checked for success seperately.
+       * tree-vect-transform.c (vectorizable_call, vectorizable_conversion):
+       Remove the check that stmt is not LIVE.
+       (vectorizable_assignment, vectorizable_induction): Likewise.
+       (vectorizable_operation, vectorizable_type_demotion): Likewise.
+       (vectorizable_type_promotion, vectorizable_load, vectorizable_store):
+       Likewise.
+       (vectorizable_live_operation): Check that op is not NULL. 
+
+2007-10-22  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/invoke.texi (Optimization Options): In the summary, show
+       that the value for options -falign-jumps, -falign-labels,
+       -falign-loops, -falign-functions, -fsched-stalled-insns, and
+       -fsched-stalled-insns-dep is optional.  In the summary, show that
+       -fsched-stalled-insns takes an optional argument and that
+       -fparallelize-loops takes an argument.  Add opindex for several
+       optimization options, and fix typos in the opindex commands for
+       several others.  In the descriptions for -fsched-stalled-insns
+       and -fsched-stalled-insns-dep, show the options with and without
+       values.
+
+2007-10-22  Eric B. Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Remove ATmega603 which was never
+       produced.
+       * config/avr/avr.h (LINK_SPEC): Likewise.
+       (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+
+2007-10-22  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/33644
+       * cfgcleanup.c: Do not include dce.h.
+       * cfgrtl.c (delete_insn_chain_and_edges): Resurrect.
+       * combine.c (distribute_notes): Delete REG_LIBCALL_ID case.
+       * dce.c (something_changed): Delete.
+       (libcall_dead_p): New predicate.
+       (delete_unmarked_insns): Use it to delete dead libcalls.
+       Deal with REG_LIBCALL and REG_RETVAL notes.
+       (prescan_libcall_for_dce): New function.
+       (prescan_insns_for_dce): Use it to deal with libcalls.
+       (mark_reg_dependencies): Do nothing special for libcalls.
+       (dce_process_block): Likewise.
+       (fast_dce): Delete unused local variable.
+       (run_fast_dce): Do not return a value.
+       * dce.h (struct df): Delete.
+       (run_fast_dce): Adjust prototype.
+       * optabs.c (libcall_id): Delete.
+       (maybe_encapsulate_block): Do not emit REG_LIBCALL_ID notes.
+       (emit_no_conflict_block): Do not look for REG_LIBCALL_ID notes.
+       * reload1.c (reload): Delete REG_LIBCALL_ID case.
+       * rtl.h (delete_insn_chain_and_edges): Resurrect prototype.
+       * see.c (see_update_relevancy): Look for REG_LIBCALL and REG_RETVAL
+       notes instead of REG_LIBCALL_ID notes.
+       * reg-notes.def (LIBCALL_ID): Delete.
+       * Makefile.in (see.o): Add dce.h dependency.
+       (cfgcleanup.o): Remove dce.h dependency.
+
+2007-10-22  Michael Matz  <matz@suse.de>
+
+       PR tree-optimization/33855
+       * tree-ssa-phiopt.c (cond_store_replacement): Handle COMPLEX_TYPE
+       and VECTOR_TYPE.
+
+2007-10-22  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/33854
+       * tree-vect-analyze.c (vect_determine_vectorization_factor): Add
+       FLOAT_EXPR to the list of promotion operations. 
+
+2007-10-22  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/29473
+       PR target/29493
+       * config/i386/i386.c (output_pic_addr_const): Support Intel asm syntax.
+       (print_reg): Print register prefix only with AT&T asm syntax. 
+       Support pc_rtx for RIP register.
+       (print_operand_address): Use print_reg()'s pc_rtx support for RIP
+       relative addressing.  Always print segment register prefix with AT&T
+       asm syntax and never with Intel asm syntax.
+       (print_operand): Suppress 'XXX PTR' prefix for BLKmode operands. 
+       Fix prefix for 16-byte XFmode operands.
+       (output_addr_const_extra): Support Intel asm syntax.
+       (x86_file_start): Don't use register prefix with Intel asm syntax.
+       * config/i386/i386.md ("*zero_extendqihi2_movzbl"): Fix typo.
+       ("return_internal_long"): Fix Intel asm syntax output.
+       ("set_got_rex64"): Support Intel asm syntax.
+       ("set_rip_rex64"): Likewise.
+       ("set_got_offset_rex64"): Likewise.
+       ("*sibcall_1_rex64_v"): Print register prefix only with AT&T asm
+       syntax.
+       ("*tls_global_dynamic_64"): Likewise.
+       ("*tls_local_dynamic_base_64"): Likewise.
+       ("*load_tp_si")("*load_tp_di"): Likewise.
+       ("*add_tp_si")("*add_tp_di"): Likewise.
+       ("*tls_dynamic_lea_64"): Likewise.
+       ("*sibcall_value_1_rex64_v"): Likewise.
+       ("stack_tls_protect_set_si"): Likewise.
+       ("stack_tls_protect_set_di"): Likewise.
+       ("stack_tls_protect_test_si"): Likewise.
+       ("stack_tls_protect_test_di"): Likewise.
+       * config/i386/mmx.md ("*mov<mode>_internal_rex64"): Fix Intel asm
+       syntax output.
+       ("*movv2sf_internal_rex64"): Likewise.
+       * config/i386/cpuid.h (__cpuid): Support Intel asm syntax.
+       (__get_cpuid_max): Likewise.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips-protos.h (mips_regno_mode_ok_for_base_p): Give
+       the STRICT_P argument type "bool" rather than "int".
+       (mips_legitimate_address_p): Likewise.
+       (fp_register_operand, lo_operand): Delete.
+       (mips_subword): Give the HIGH_P argument type "bool" rather than "int".
+       (mips_emit_scc): Rename to...
+       (mips_expand_scc): ...this.
+       (gen_conditional_branch): Rename to...
+       (mips_expand_conditional_branch): ...this.
+       (gen_conditional_move): Rename to...
+       (mips_expand_conditional_move): ...this.
+       (mips_gen_conditional_trap): Rename to...
+       (mips_expand_conditional_trap): ...this and take an rtx code instead
+       of an operands array.
+       (mips_expand_call): Give the SIBCALL_P argument type "bool"
+       rather than "int".
+       (mips_emit_fcc_reload): Rename to...
+       (mips_expand_fcc_reload): ...this.
+       (init_cumulative_args): Rename to...
+       (mips_init_cumulative_args): ...this and remove the libname argument.
+       (function_arg_advance): Rename to...
+       (mips_function_arg_advance): ...this.
+       (function_arg): Rename to...
+       (mips_function_arg): ...this and use "rtx" instead of
+       "struct rtx_def *".
+       (function_arg_boundary): Rename to...
+       (mips_function_arg_boundary): ...this.
+       (mips_expand_unaligned_load): Rename to...
+       (mips_expand_ext_as_unaligned_load): ...this and give the WIDTH
+       and BITPOS arguments type "HOST_WIDE_INT".
+       (mips_expand_unaligned_store): Rename to...
+       (mips_expand_ins_as_unaligned_store): ...this and give the WIDTH
+       and BITPOS arguments type "HOST_WIDE_INT".
+       (override_options): Rename to...
+       (mips_override_options): ...this.
+       (print_operand): Rename to...
+       (mips_print_operand): ...this.
+       (print_operand_address): Rename to...
+       (mips_print_operand_address): ...this.
+       (mips_output_ascii): Remove the PREFIX argument.
+       (mips_expand_epilogue): Give the SIBCALL_P argument type "bool"
+       rather than "int".
+       (mips_can_use_return_insn): Return a "bool" rather than an "int".
+       (mips_function_value): Remove the FUNC argument.  Use "rtx" instead
+       of "struct rtx_def *".
+       (mips_secondary_reload_class): Give the IN_P argument type "bool"
+       rather than "int".
+       (build_mips16_call_stub): Delete.
+       (mips_store_data_bypass_p): Return a "bool" rather than an "int".
+       (mips_use_ins_ext_p): Give the second and third arguments type
+       "HOST_WIDE_INT" rather than "rtx".
+       * config/mips/mips.h: Update after the above changes.  Tweak comments
+       and formatting.
+       (SECONDARY_INPUT_RELOAD_CLASS): Pass a boolean IN_P argument.
+       (SECONDARY_OUTPUT_RELOAD_CLASS): Likewise.
+       (mips_print_operand_punct, mips_hard_regno_mode_ok): Change the
+       element type from "char" to "bool".
+       (mips_section_threshold, sym_lineno, set_noat, mips_branch_likely)
+       (mips_cpu_info_table): Delete.
+       * config/mips/mips.md: Update after the above changes.  Tweak some
+       formatting.
+       * config/mips/mips-ps-3d.md: Likewise.
+       * config/mips/mips.c: Tweak comments and formatting.
+       Use NULL-like macros rather than 0 in various places.
+       (mips_section_threshold): Rename to...
+       (mips_small_data_threshold): ...this and give it an unsigned type.
+       (num_source_filenames): Remove explicit initialization.
+       (sdb_label_count): Likewise.
+       (sym_lineno): Delete.
+       (set_noat): Make static.
+       (mips_branch_likely): Likewise, and give it type "bool".
+       (mips_isa_info): Rename to...
+       (mips_isa_option_info): ...this.
+       (mips_flag_delayed_branch): Rename to...
+       (mips_base_delayed_branch): ...this.
+       (mips_split_addresses): Delete.
+       (mips_print_operand_punct, mips_hard_regno_mode_ok): Change the
+       element type from "char" to "bool".
+       (mips_regno_to_class): Add an explicit array size.
+       (mips16_flipper): Change from type "int" to type "bool".
+       (mips_comp_type_attributes): Remove redundant FUNCTION_TYPE check.
+       (mips_tls_operand_p): Rename to...
+       (mips_tls_symbol_p): ...this.
+       (mips_global_symbol_p): Remove redundant "const".
+       (mips_offset_within_alignment_p): Simplify.
+       (mips_regno_mode_ok_for_base_p): Change the name of the last argument
+       to STRICT_P and give it type bool.
+       (mips_valid_base_register_p): Likewise.
+       (mips_classify_address): Likewise.
+       (mips_legitimate_address_p): Likewise.
+       (mips16_unextended_reference_p): Take the offset as an
+       "unsigned HOST_WIDE_INT" rather than an "rtx".  Simplify.
+       (mips_const_insns): Use IN_RANGE.
+       (mips_force_temporary): Remove an unnecessary copy_rtx.
+       (mips16_gp_pseudo_reg): Simplify.
+       (mips_split_symbol): Remove an unnecessary copy_rtx.
+       (mips_legitimize_tls_address): Only create registers if we need them.
+       (mips_legitimize_address): Use mips_split_plus.
+       (mips_move_integer): Swap DEST and TEMP arguments.  Rename local
+       variable COST to NUM_OPS.
+       (mips_legitimize_move): Use gen_lowpart.
+       (mips_rewrite_small_data): Rename the OP parameter to PATTERN.
+       (m16_check_op): Use IN_RANGE.
+       (mips_subword): Give the HIGH_P argument type "bool" rather than "int".
+       (mips_split_doubleword_move): Pass booleans to mips_subword.
+       (mips_output_move): Store the mode in a local variable.
+       Explicitly assert that this function does not deal with
+       MFLO and MFHI.  Use SMALL_OPERAND_UNSIGNED.  Make order of
+       cases more consistent.
+       (mips_relational_operand_ok_p): Rename to...
+       (mips_int_order_operand_ok_p): ...this.
+       (mips_canonicalize_comparison): Rename to...
+       (mips_canonicalize_int_order_test): ...this.
+       (mips_emit_int_relational): Rename to...
+       (mips_emit_int_order_test): ...this.  Store the mode in a local
+       variable.
+       (mips_reverse_fp_cond_p): Rename to...
+       (mips_reversed_fp_cond): ...this.
+       (mips_emit_compare): Make the order of the statements more consistent.
+       (mips_emit_scc): Rename to...
+       (mips_expand_scc): ...this.
+       (gen_conditional_branch): Rename to...
+       (mips_expand_conditional_branch): ...this.
+       (gen_conditional_move): Rename to...
+       (mips_expand_conditional_move): ...this.  Build the condition
+       separately from the main pattern.
+       (mips_gen_conditional_trap): Rename to...
+       (mips_expand_conditional_trap): ...this and take an rtx code instead
+       of an operands array.  Simplify.
+       (init_cumulative_args): Rename to...
+       (mips_init_cumulative_args): ...this.  Use memset rather than a
+       copy from a zeroed static.  Use prototype_p and stdarg_p.
+       (mips_arg_info): Rename to...
+       (mips_get_arg_info): ...this and put the INFO argument first.
+       (function_arg): Rename to...
+       (mips_function_arg): ...this and use "rtx" instead of
+       "struct rtx_def *".  Only split structures into chunks if 
+       TARGET_HARD_FLOAT, rather than checking !TARGET_SOFT_FLOAT on
+       a chunk-by-chunk basis.  Use SCALAR_FLOAT_TYPE_P instead of a
+       comparison with REAL_TYPE.  Rename local variable REG to REGNO
+       and make it unsigned.
+       (function_arg_advance): Rename to...
+       (mips_function_arg_advance): ...this.
+       (function_arg_boundary): Rename to...
+       (mips_function_arg_boundary): ...this.
+       (mips_pad_arg_upward): Use SCALAR_INT_MODE_P instead of a comparison
+       with MODE_INT.
+       (mips_fpr_return_fields): Use SCALAR_FLOAT_TYPE_P instead of a
+       comparison with REAL_TYPE.
+       (mips_function_value): Remove the FUNC argument.  Rename local
+       variable UNSIGNEDP to UNSIGNED_P.
+       (mips_return_in_memory): Use IN_RANGE.
+       (mips_setup_incoming_varargs): Pass a boolean rather than an int
+       to FUNCTION_ARG_ADVANCE.
+       (mips_gimplify_va_arg_expr): Rename local variable INDIRECT
+       to INDIRECT_P.  Remove a redundant mips_abi check.  Only calculate
+       SIZE and RSIZE if needed.
+       (mips16_stub): Rename FPRET to FP_RET_P and give it type "bool"
+       rather than "int".
+       (build_mips16_function_stub): Rename to...
+       (mips16_build_function_stub): ...this.
+       (build_mips16_call_stub): Rename to...
+       (mips16_build_call_stub): ...this.  Make static, and return a
+       "bool" rather than an "int".  Rename the ARG_SIZE argument to
+       ARGS_SIZE.  Rename the local variable FPRET to FP_RET_P and give
+       it type "bool".  Use "jr" rather than "j".  Use XNEW.  Simplify.
+       (mips_load_call_address): Give the SIBCALL_P argument type "bool"
+       rather than "int".
+       (mips_expand_call): Likewise.  Assert that MIPS16 calls via stubs
+       are not sibling ones.
+       (mips_emit_fcc_reload): Rename to...
+       (mips_expand_fcc_reload): ...this.
+       (mips_get_unaligned_mem): Give the WIDTH and BITPOS arguments type
+       "HOST_WIDE_INT".
+       (mips_expand_unaligned_load): Rename to...
+       (mips_expand_ext_as_unaligned_load): ...this and give the WIDTH
+       and BITPOS arguments type "HOST_WIDE_INT".  Remove redundant
+       SUBREG_BYTE check.
+       (mips_expand_unaligned_store): Rename to...
+       (mips_expand_ins_as_unaligned_store): ...this and give the WIDTH
+       and BITPOS arguments type "HOST_WIDE_INT".
+       (mips_use_ins_ext_p): Rename second and third arguments to WIDTH
+       and BITPOS and give them type "HOST_WIDE_INT" rather than "rtx".
+       Use IN_RANGE.
+       (mips_init_split_addresses): Replace with...
+       (mips_split_addresses_p): ...this new function.
+       (mips_init_relocs): Check mips_split_addresses_p () rather than
+       mips_split_addresses.  Always initialize mips_split_p with booleans.
+       (print_operand_reloc): Rename to...
+       (mips_print_operand_reloc): ...this.  Use a gcc_assert rather than
+       a fatal_error.
+       (print_operand): Rename to...
+       (mips_print_operand): ...this.
+       (print_operand_address): Rename to...
+       (mips_print_operand_address): ...this.  Use GP_REG_FIRST.
+       (mips_in_small_data_p): Simplify.
+       (mips_output_ascii): Remove the PREFIX argument and "register"
+       keywords.  Use the STRING parameter directly and cast to
+       "unsigned char".
+       (mips16e_collect_argument_save_p): Use IN_RANGE.
+       (mips_function_has_gp_insn): Simplify.
+       (mips_set_return_address): Use BITSET_P.
+       (mips_restore_gp): Use a separate statement to pick the base
+       register.
+       (mips_output_function_prologue): Use a local FRAME variable.
+       (mips_save_reg): Pass booleans to mips_subword.
+       (mips_expand_prologue): Use a local FRAME variable.  Use
+       cprestore_size to detect when .cprestore is needed.
+       (mips_restore_reg): Use GP_REG_FIRST.
+       (mips_expand_epilogue): Give the SIBCALL_P argument type "bool"
+       rather than "int".  Use local FRAME and REGNO variables.
+       (mips_can_use_return_insn): Return a "bool" rather than an "int".
+       (mips_secondary_reload_class): Give the IN_P argument type "bool"
+       rather than "int".
+       (mips_linked_madd_p): Rename arguments to OUT_INSN and IN_INSN.
+       (mips_store_data_bypass_p): Return a "bool" rather than an "int".
+       (vr4130_swap_insns_p): Rename local variables to DEP1_P and DEP2_P.
+       (mips_74k_agen_init): Assume INSN satisfies USEFUL_INSN_P.
+       (mips_variable_issue): Do nothing unless INSN satisfies USEFUL_INSN_P.
+       (builtin_description): Rename to...
+       (mips_builtin_description): ...this.
+       (mips_bdesc): Rename to...
+       (mips_ps_bdesc): ...this.
+       (sb1_bdesc): Rename to...
+       (mips_sb1_bdesc): ...this.
+       (dsp_bdesc): Rename to...
+       (mips_dsp_bdesc): ...this.
+       (dsp_32only_bdesc): Rename to...
+       (mips_dsp_32only_bdesc): ...this.
+       (bdesc_map): Rename to...
+       (mips_bdesc_map): ...this.
+       (bdesc_arrays): Rename to...
+       (mips_bdesc_arrays): ...this.
+       (mips_prepare_builtin_arg): Rename OP to OPNO and ARGNUM to ARGNO.
+       Tweak error message.
+       (mips_expand_builtin_direct): Rename HAS_TARGET to HAS_TARGET_P.
+       Rename local variables I and J to OPNO and ARGNO respectively.
+       Assert that the number of arguments is no more than the number of
+       input operands.
+       (mips_expand_builtin_compare): Use an array of arguments rather
+       than an array of operands.  Assert that the number of operands is
+       as expected.
+       (add_constant): Rename to...
+       (mips16_add_constant): ...this.  Use XNEW.
+       (dump_constants_1): Rename to...
+       (mips16_emit_constants_1): ...this.  Use ALL_SCALAR_FIXED_POINT_MODE_P.
+       (dump_constants): Rename to...
+       (mips16_emit_constants): ...this.
+       (mips_sim_wait_reg, mips_sim_record_set): Use END_REGNO.
+       (mips_set_mips16_mode): Don't call mips_init_split_addresses.
+       Assign mips16_p to was_mips16_p.
+       (mips_parse_cpu): Tweak warning message.
+       (override_options): Rename to...
+       (mips_override_options): ...this.  Move the mips_cost initialization
+       out of the "shared with GAS" block.  Quote option names in error
+       messages.
+       (mips_conditional_register_usage): Make local variable REGNO unsigned.
+       (mips_order_regs_for_local_alloc): Remove register keyword.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * system.h (IN_RANGE): Cast each argument individually.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_set_mips16_mode) Say sorry for hard-float
+       MIPS16 code unless using o32 or o64.  
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_cannot_change_mode_class): Don't check
+       for modes smaller than 4 bytes.
+       * config/mips/mips.md (*movhi_internal, *movqi_internal): Remove
+       FPR alternatives.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips-protos.h (mips_output_aligned_bss): Delete.
+       * config/mips/linux.h (BSS_SECTION_ASM_OP): Delete.
+       (ASM_OUTPUT_ALIGNED_BSS): Delete.
+       * config/mips/mips.c (mips_output_aligned_bss): Delete.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_function_ok_for_sibcall): Only forbid
+       sibling calls to "mips16" functions if the function satisfies
+       const_call_insn_operand.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_va_start): Fix types in calls
+       to build_int_cst.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_rtx_costs): Only recognize reciprocals
+       if ISA_HAS_FP4.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h (ISA_HAS_LDC1_SDC1): New macro.
+       * config/mips/mips.c (mips_split_64bit_move_p): Use ISA_HAS_LDC1_SDC1
+       instead of checking mips_isa.
+
+2007-10-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * doc/invoke.texi (-mpaired-single): Don't say that the option
+       requires 64-bit code.
+       * config/mips/mips-protos.h (mips_modes_tieable_p): Declare.
+       * config/mips/mips.h (ISA_HAS_PAIRED_SINGLE): New macro.
+       (ISA_HAS_NMADD_NMSUB): Add a mode argument.  Return true for
+       V2SF if ISA_MIPS32R2.
+       (MODES_TIEABLE_P): Use mips_modes_tieable_p.
+       * config/mips/mips.c (mips_rtx_costs): Pass a mode argument
+       to ISA_HAS_NMADD_NMSUB.
+       (mips_split_doubleword_move): Handle V2SF.
+       (mips_modes_tieable_p): New function.
+       (override_options): Report a warning rather than an error when
+       -mpaired-single is used on ISAs that don't support it; use
+       ISA_HAS_PAIRED_SINGLE to check that case.
+       * config/mips/mips.md (MOVE64): New mode iterator.  Replace DI
+       and DF move splitters with a single MOVE64 splitter, thereby adding
+       a V2SF splitter too.
+       (SPLITF): Add TARGET_DOUBLE_FLOAT conditions to DI and DF.
+       Add a TARGET_FLOAT64 condition to TF.  Add V2SF to the iterator.
+       (HALFMODE): Add V2SF.
+       (*nmadd<mode>, *nmadd<mode>_fastmath, *nmsub<mode>)
+       (*nmsub<mode>_fastmath): Add a mode argument to ISA_HAS_NMADD_NMSUB.
+       (movv2sf_hardfloat_64bit): Tweak ordering of conditions.
+       (movv2sf_hardfloat_32bit): New pattern.
+       (load_low<mode>, load_high<mode>, store_word<mode>): Remove
+       TARGET_DOUBLE_FLOAT conditions.
+
+2007-10-20  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/rs6000/linux-unwind.h (ppc_fallback_frame_state): Point
+       saved CR2 offset to low 32 bits of regs->ccr rather than the whole
+       64-bit register in 64-bit libgcc.
+
+2007-10-20  Eric B. Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Add at90pwm2b, at90pwm3b.
+       * config/avr/avr.h (LINK_SPEC): Likewise.
+       (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+
+2007-10-20  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * doc/invoke.texi (Warning Options): Move -w, -Werror, -Werror=
+       and -Wfatal-errors together.
+       
+2007-10-20  Alan Modra  <amodra@bigpond.net.au>
+
+       PR target/33812
+       * config/rs6000/rs6000.c (rs6000_emit_epilogue): Revert 2007-05-16
+       change for vrsave, ie restore after frame pop.
+
+2007-10-19  David S. Miller  <davem@davemloft.net>
+
+       * config/sparc/niagara2.md: Fix copyright notice.
+
+2007-10-19  Sebastian Pop  <sebastian.pop@amd.com>
+
+       PR tree-optimization/23820
+       PR tree-optimization/24309
+       PR tree-optimization/33766
+       * testsuite/gcc.dg/tree-ssa/pr23820.c: New.
+       * testsuite/gcc.dg/tree-ssa/pr24309.c: New.
+       * testsuite/gcc.dg/tree-ssa/pr33766.c: New.
+       * testsuite/gcc.dg/tree-ssa/ltrans-3.c: XFAILed.
+       * tree-loop-linear.c (perfect_loop_nest_depth): New.
+       (linear_transform_loops): Use perfect_loop_nest_depth.
+       * lambda-code.c (perfect_nest_p): Outer loops in perfect nests 
+       should have a single condition: their exit.
+
+2007-10-19  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33816
+       PR middle-end/32921
+       * stor-layout.c (layout_type): Assert that aggregates do not
+       have their alias sets set.
+       * alias.c (get_alias_set): Return alias set zero for incomplete
+       types, return the alias set of the element for incomplete array
+       types, but do not remember these.
+
+2007-10-19  Richard Guenther  <rguenther@suse.de>
+
+       Revert
+       2007-10-19  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32921
+       * tree.c (build_array_type): Do not re-layout unbound array
+       types.
+
+2007-10-19  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32921
+       * tree.c (build_array_type): Do not re-layout unbound array types.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_canonicalize_comparison):  Check
+       mips_relational_operand_ok_p before trying to rewrite the test.
+       Only calculate PLUS_ONE if needed.
+       (mips_emit_int_relational): Don't call mips_relational_operand_ok_p
+       here.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips16e_build_save_restore): Fix *OFFSET_PTR
+       calculation.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_call_tls_get_addr): Don't claim that
+       the call uses the incoming value of $2.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_call_tls_get_addr): Use gen_const_mem
+       rather then gen_rtx_MEM.
+       (mips_setup_incoming_varargs): Use gen_frame_mem rather than
+       gen_rtx_MEM.
+       (mips_set_return_address): Likewise.
+       (mips_restore_gp): Likewise.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (gpr_mode): Delete.
+       (mips16e_build_save_restore): Use word_mode and UNITS_PER_WORD
+       instead of gpr_mode.
+       (mips_for_each_saved_reg): Likewise.
+       (mips_expand_prologue, mips_expand_epilogue): Likewise.
+       (override_options): Don't initialize gpr_mode.
+       * config/mips/mips.md (eh_return): Use word_mode instead of gpr_mode.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_hard_regno_nregs): Put the UNITS_PER_WORD
+       case last.
+       (mips_class_max_nregs): Calculate the smallest consituent register
+       size and use that to determine an upper bound on the number of
+       registers.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips16_copy_fpr_return_value): New function,
+       split out from...
+       (mips_expand_epilogue): ...here.
+       (mips_mdebug_abi_name): New function, split out from...
+       (mips_file_start): ...here.
+       (mips_hard_regno_mode_ok_p): New function, split out from...
+       (override_options): ...here.
+       (mips_expand_builtin_1): New function, split out from...
+       (mips_expand_buitin): ...here.  Abort if we don't recognize
+       the function.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (build_mips16_function_stub): Load the
+       target address into $1 before transfering the arguments.
+       Don't use ".set noreorder".
+       (build_mips16_call_stub): Likewise.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_output_32bit_xfer): New function.
+       (mips_output_64bit_xfer): Likewise.
+       (mips16_fp_args): Rename to...
+       (mips_output_args_xfer): ...this and replace the FROM_FP_P argument
+       with a DIRECTION argument.  Use mips_output_32bit_xfer and
+       mips_output_64bit_xfer.
+       (build_mips16_function_stub): Update accordingly.
+       (mips16_fpret_double): Delete.
+       (build_mips16_call_stub): Update after above changes.
+       Use mips_output_32bit_xfer.  Use mips_output_64bit_xfer instead
+       of mips16_fpret_double.  Use GP_REG_RETURN.
+
+2007-10-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips16_fp_args): Remove the FILE argument and
+       use asm_out_file instead.
+       (build_mips16_function_stub): Likewise.
+       (build_mips16_call_stub, mips_output_function_prologue): Update
+       accordingly.
+
+2007-10-18  David S. Miller  <davem@davemloft.net>
+
+       Add Niagara-2 support.
+       * doc/invoke.texi: Document -m{cpu,tune}=niagara2.
+       * config.gcc: Add niagara2 to cpu and tune lists for sparc.
+       * config/sparc/sparc.md (sparc_cpu_attr): Add niagara2.
+       (include): Add inclusion of niagara2.md
+       * config/sparc/sparc.c (niagara2_costs): New.
+       (sparc_override_options): Add niagara2 entry to cpu_default[]
+       and cpu_table[].  Set align_functions to 32 on Niagara2.  Use
+       niagara2_costs when PROCESSOR_NIAGARA2.  Handle Niagara2 for
+       PARAM_SIMULTANEOUS_PREFETCHES and PARAM_L1_CACHE_LINE_SIZE.
+       (sparc_initialize_trampoline): Handle niagara2 like niagara.
+       (sparc64_initialize_trampoline): Likewise.
+       (sparc_use_sched_lookahead): Likewise.
+       (sparc_issue_rate): Likewise.
+       * config/sparc/sol2-bi.h: Handle TARGET_CPU_niagara2 and
+       mcpu=niagara2
+       * config/sparc/sparc.h (TARGET_CPU_niagara2): Define.
+       ({CPP,ASM}_CPU64_DEFAULT_SPEC): Set appropriately for
+       TARGET_CPU_niagara2.
+       (PROCESSOR_NIAGARA2): New.
+       (REGISTER_MOVE_COST): Handle PROCESSOR_NIAGARA2.
+       (BRANCH_COST): Likewise.
+       * config/sparc/linux64.h: Handle TARGET_CPU_niagara2.
+       * config/sparc/sol2.h: Likewise.
+       * config/sparc/niagara2.md: New file.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_frame_info): Remove gp_reg_size and
+       and fp_reg_size.
+       (mips_compute_frame_info): Remove associated code.
+       (mips16e_build_save_restore): Check num_fp instead of fp_reg_size.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips-protos.h (compute_frame_size): Delete.
+       * config/mips/mips.h: Update comments.
+       * config/mips/mips.c (mips_frame_info): Remove initialized.
+       (compute_frame_size): Rename to...
+       (mips_compute_frame_info): ...this and make static.  Remove the
+       SIZE argument and return no value.  Remove the setting of initialized.
+       Update rest of file accordingly.
+       (mips_set_return_address): Don't call compute_frame_size.
+       (mips_can_use_return_insn): Don't check df_regs_ever_live_p (31).
+       Don't call compute_frame_size.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips-protos.h (mips_frame_pointer_required): Declare.
+       * config/mips/mips.h (FRAME_POINTER_REQUIRED): Use
+       mips_hard_frame_pointer_required.
+       (CAN_ELIMINATE): Rely on FRAME_POINTER_REQUIRED to check for
+       large MIPS16 frames.
+       * config/mips/mips.c (mips_frame_pointer_required): New function.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_frame_info): Add arg_pointer_offset
+       and hard_frame_pointer_offset.
+       (mips_debugger_offset): Use hard_frame_pointer_offset.
+       (mips16e_collect_argument_save_p): Likewise.
+       (compute_frame_size): Initialize arg_pointer_offset and
+       hard_frame_pointer_offset.
+       (mips_initial_elimination_offset): Use them.
+       (mips_output_function_prologue): Use hard_frame_pointer_offset.
+       (mips_expand_prologue, mips_expand_epilogue): Likewise.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h (STARTING_FRAME_OFFSET): Remove rtl
+       profiling code.
+       * config/mips/mips.c (mips_frame_info): Give num_gp and num_fp type
+       "unsigned int" rather than "int" and put them with the other
+       register-related fields.  Put expanded comments above fields
+       rather than to their right.
+       (mips16e_mask_registers): Replace the GP_REG_SIZE_PTR argument
+       with a NUM_REGS_PTR argument.
+       (mips16e_save_restore_pattern_p): Update accordingly.
+       (compute_frame_size): Clarify frame diagram.  Rewrite.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips-ftypes.def: New file.
+       * config/mips/mips.c (MIPS_FTYPE_NAME1, MIPS_FTYPE_NAME2)
+       (MIPS_FTYPE_NAME3, MIPS_FTYPE_NAME4): New macros.
+       (mips_function_type): Redefine using mips-ftypes.def.
+       (dsp_bdesc): Use POINTER rather than PTR in the MIPS_*_FTYPE_* names.
+       (mips_builtin_vector_type): New function.
+       (MIPS_ATYPE_VOID, MIPS_ATYPE_INT, MIPS_ATYPE_POINTER, MIPS_ATYPE_SI)
+       (MIPS_ATYPE_USI, MIPS_ATYPE_DI, MIPS_ATYPE_SF, MIPS_ATYPE_DF)
+       (MIPS_ATYPE_V2SF, MIPS_ATYPE_V2HI, MIPS_ATYPE_V4QI, MIPS_FTYPE_ATYPES1)
+       (MIPS_FTYPE_ATYPES2, MIPS_FTYPE_ATYPES3, MIPS_FTYPE_ATYPES4): New
+       macros.
+       (mips_build_function_type): New function.
+       (mips_init_builtins): Use it to create types lazily.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h (set_volatile): Delete.
+       * config/mips/mips.c (set_volatile): Delete.
+       (mips_print_operand_punctuation): New function, split out from
+       print_operand.  Remove '%{', '%}', '%~', '%&' and '%!'.
+       Use the same character ordering in the code and the comments.
+       Use a recursive call to handle '*'.  Abort on unknown characters.
+       (mips_init_print_operand_punct): New function, split out from
+       override_options.
+       (mips_print_int_branch_condition): New function, split out from
+       print_operand.  Use GET_RTX_NAME.  Use output_operand_lossage
+       to report unexpected codes.
+       (mips_print_float_branch_condition): New function, split out from
+       print_operand.  Use output_operand_lossage to report unexpected codes.
+       (print_operand): Rework to use a case statement.  Use the
+       same letter ordering in the code and the comments.  Use
+       output_operand_lossage to report unexpected codes and
+       reverse_condition to handle inverted branch conditions.
+       (override_options): Use mips_init_print_operand_punct.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h: Move variable declarations to end of file and
+       enclose them all in #ifndef USED_FOR_TARGET.
+       * config/mips/mips.c: Reorder functions into more logical groups,
+       and so that callees appear before callers.  Put the targetm
+       initializer at the end of the file.  Remove forward static
+       declarations where possible.
+       (mips_init_builtins): Add "static" to definition.
+       (mips_expand_builtin, mips_mode_rep_extended): Likewise.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (TARGET_MIN_ANCHOR_OFFSET): Delete.
+       (TARGET_MAX_ANCHOR_OFFSET): Delete.
+       (mips_cannot_force_const_mem): Don't check TARGET_HAVE_TLS.
+       (mips_set_mips16_mode): Initialize min_anchor_offset and
+       max_anchor_offset directly to constants.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c: Delete trailing whitespace.
+
+2007-10-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_expand_call): Use FAKE_CALL_REGNO.
+       (mips_avoid_hazard): Allow multiple sets for HAZARD_DELAY,
+       and pick the first.
+       * config/mips/mips.md (load_call<mode>): Don't make the unspec
+       depend on FAKE_CALL_REGNO.  Set FAKE_CALL_REGNO.
+
+2007-10-18  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/linux-unwind.h (mips_fallback_frame_state): Use new
+       reg_offset variable to calculate register locations.
+
+2007-10-18  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa.c (uid_ssaname_map_eq): New function.
+       (uid_ssaname_map_has): Likewise.
+       (init_tree_ssa): Allocate default_defs as uid_ssaname map.
+       * tree-flow.h (struct gimple_df): Make default_defs a
+       uid_ssaname map.
+       * tree-dfa.c (gimple_default_def): Deal with it.
+       (set_default_def): Likewise.
+
+2007-10-18  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow.h (struct gimple_df): Make referenced_vars
+       a uid_decl_map.
+       (uid_decl_map_eq): Declare.
+       (uid_decl_map_hash): Likewise.
+       * tree-ssa.c (uid_decl_map_eq): New function.
+       (uid_decl_map_hash): Likewise.
+       (init_tree_ssa): Make referenced_vars a uid_decl_map.
+       * tree-flow-inline.h (first_referenced_var): Deal with
+       the referenced_vars representation change.
+       (next_referenced_var): Likewise.
+       * tree-dfa.c (referenced_var_lookup): Likewise.
+       (referenced_var_check_and_insert): Likewise.
+       (remove_referenced_var): Likewise.
+
+2007-10-18  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config/mips/mips.c (mips_dwarf_register_span): New.
+       (TARGET_DWARF_REGISTER_SPAN): Define.
+
+2007-10-18  Chen Liqin  <liqin@sunnorth.com.cn>
+
+       * config.gcc : update score-*-elf(extra_objs).
+       * config/score/mac.md : Remove.
+       * config/score/misc.md : Remove.
+       * config/score/score7.md : Remove.
+       * config/score/score-mdaux.h : Remove.
+       * config/score/score-mdaux.c : Remove.
+       * config/score/score-version.h : Remove.
+       * config/score/score-generic.md : New.
+       * config/score/score3.h : New.
+       * config/score/score3.c : New.
+       * config/score/score7.h : New.
+       * config/score/score7.c : New.
+       * config/score/mul-div.S : add flush_cache score3 support.
+       * config/score/elf.h : Fix some typos.
+       * config/score/score.md : merge score3 and score7 pattern.
+       * config/score/score.c : use to seperate which target it used.
+       * config/score/score.h : use to seperate the target macro.
+       * config/score/score.opt : remove -mmac option , add -mscore3,
+       -mscore3d and -march OPTION support.
+2007-10-17  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * cfgexpand.c (expand_stack_vars): Add checking to make sure
+       that the offset of a variable is not greater than the size
+       of the paritition.
+
+2007-10-17  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (avr_mcu_types): Add support for atmega48p, 
+       atmega88p, atmega168p and atmega328p devices.
+       * config/avr/avr.h (LINK_SPEC): (Ditto.).
+       (CRT_BINUTILS_SPECS): (Ditto.).
+       * config/avr/t-avr (MULTILIB_MATCHES): (Ditto.).
+
+2007-10-17  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * sched-ebb.c: Surround code with '#ifdef INSN_SCHEDULING'.
+       * ddg.c: Ditto.
+       * sched-deps.c: Ditto.  Remove nested #ifdef's INSN_SCHEDULING.
+       * sched-int.h: Surround declarations with '#ifdef INSN_SCHEDULING'.
+       (print_insn): Move declaration to ...
+       * rtl.h (print_insn): ... here.
+
+2007-10-17  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * config/m68k/m68k.h (m68k_sched_cpu, m68k_sched_attr_opx_type,
+       m68k_sched_attr_opy_type, m68k_sched_attr_size, m68k_sched_attr_op_mem,
+       m68k_sched_branch_type): Move declarations to ...
+       * config/m68/m68k-protos.h: ... here.
+
+2007-10-17  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * genattrtab.c (main): Rearrange output of insn-attrtab.c headers.
+
+2007-10-17  Eric B. Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Add attiny48.
+       * config/avr/avr.h (LINK_SPEC): Likewise.
+       (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+
+2007-10-17  Eric B. Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Add attiny43u.
+       * config/avr/avr.h (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+
+2007-10-17  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/33794
+       * reg-stack.c (move_for_stack_reg): Swap input argument of
+       UNSPEC_TAN insn to the top of the stack.
+
+2007-10-17  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32961
+       * config/i386/i386.c (ix86_expand_builtin) [IX86_BUILTIN_PSLLWI128,
+       IX86_BUILTIN_PSLLDI128, BUILTIN_PSLLQI128, IX86_BUILTIN_PSRAWI128,
+       IX86_BUILTIN_PSRADI128, IX86_BUILTIN_PSRLWI128,
+       IX86_BUILTIN_PSRLDI128, IX86_BUILTIN_PSRLQI128]: Do not require
+       immediate shift value.
+       * config/i386/emmintrin.h (_mm_slli_epi16, _mm_slli_epi32,
+       _mm_slli_epi64, _mm_srai_epi16, _mm_srai_epi32, _mm_srli_epi16,
+       _mm_srli_epi32, _mm_srli_epi64): Remove 'const' from count argument.
+       Remove macros for !__OPTIMIZE__ case.
+
+2007-10-17  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-structalias.c (rewrite_constraints): Don't test for
+       directness anymore.
+       (perform_var_substitution): Only DFS from real nodes. Don't test
+       for directness.
+       (unite_pointer_equivalences): Fix broken test.
+
+2007-10-17  Alan Modra  <amodra@bigpond.net.au>
+
+       * config/rs6000/rs6000.c (rs6000_emit_epilogue): Correct
+       altivec sp_offset.  Rearrange sp_offset assignments to
+       correspond to stack adjustments.  Use frame_reg_rtx for
+       SPE register restores.  Correct SPE stack adjustment.
+
+2007-10-17  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * builtins.c (gimplify_va_arg_expr): Use inform for help message.
+       * toplev.c (check_global_declaration_1): Use appropriate warning
+       option instead of unnamed warning.
+       * stor-layout.c (layout_decl): Likewise.
+       * c-typeck.c (build_conditional_expr): Likewise.
+       (build_compound_expr): Fix wrong comment.
+       (build_binary_op): Use appropriate warning option instead of
+       unnamed warning.
+       * cfgexpand.c (tree_expand_cfg): Likewise.
+       * tree-optimize.c (tree_rest_of_compilation): Likewise.
+       * tree-cfg.c (remove_useless_stmts_warn_notreached): Likewise.
+       (execute_warn_function_return): Likewise.
+       * stmt.c (warn_if_unused_value): Likewise.
+
+2007-10-16  Eric B. Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/avr.c (avr_mcu_types): Add at90pwm216, at90pwm316.
+       * config/avr/avr.h (LINK_SPEC): Likewise and remove regex for
+       similar devices.
+       (CRT_BINUTILS_SPECS): Likewsie.
+       * config/avr/t-avr (MULTILIB_MATCHES): Likewise.
+
+2007-10-16  Amruth Laxman  <amruth.laxman@nsn.com>
+
+       PR target/33594
+       * config/sparc/sparc.h (LOCAL_ALIGNMENT): Define.
+
+2007-10-16  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * dce.c (init_dce): Only initialize the obstacks for the fast pass.
+       (fini_dce): Only release them for the fast pass.
+       (end_ud_dce): Delete.
+       (rest_of_handle_ud_dce): Do not modify df_in_progress.
+       Call fini_dce instead of end_ud_dce.
+       (rest_of_handle_fast_dce): Do not modify df_in_progress.
+       (run_fast_df_dce): Reset df_in_progress to false on exit.
+
+2007-10-16  Paolo Bonzini  <bonzini@gnu.org>
+           Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * target.h (unspec_may_trap_p): New target hook.
+       * target-def.h (TARGET_UNSPEC_MAY_TRAP_P): New macro.
+       * targhooks.c (default_unspec_may_trap_p): Default implementation of
+       the hook.
+       * targhooks.h (default_unspec_may_trap_p): Declare it.
+       * doc/tm.texi (TARGET_UNSPEC_MAY_TRAP_P): Document new hook.
+       * rtlanal.c (may_trap_p_1): Use new hook.  Make global.
+       * rtl.h (may_trap_p_1): Declare.
+       
+       * config/ia64/ia64.c (ia64_unspec_may_trap_p): New function to
+       override default hook implementation.
+       (TARGET_UNSPEC_MAY_TRAP_P): Override default implementation of the
+       hook.
+
+2007-10-16  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * doc/invoke.texi (Wextra): Move it just after Wall, list the
+       options enabled by Wextra and mention Wuninitialized.
+       
+2007-10-15  Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/mips.h (LOCAL_ALIGNMENT): Define.
+
+2007-10-15  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/33136
+       * opts.c (decode_options): Don't enable flag_ipa_type_escape.
+
+2007-10-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR tree-optimization/33735
+       PR tree-optimization/33572
+       * tree-inline.c (update_ssa_across_abnormal_edges): Revert
+       2007-10-09's change.
+       * except.c (duplicate_eh_regions): Don't look for prev_try
+       beyond ERT_ALLOWED_EXCEPTIONS with an empty list.
+
+2007-10-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR middle-end/33706
+       * tree-inline.c (copy_bb): Use bsi_replace to replace a
+       __builtin_va_arg_pack-containing call stmt.
+
+2007-10-15  Razya Ladelsky  <razya@il.ibm.com>
+
+       * matrix-reorg.c (gate_matrix_reorg): Don't comment out whole
+       program flag.
+
+2007-10-15  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/33619
+       * tree-ssa-ter.c (is_replaceable_p): Return false for all
+       calls.
+
+2007-10-15  David Edelsohn  <edelsohn@gnu.org>
+
+       * config.gcc (powerpc-ibm-aix5*): Install altivec.h.
+
+2007-10-15  Richard Guenther  <rguenther@suse.de>
+
+       * fold-const.c (extract_array_ref): Remove.
+       (fold_comparison): Handle POINTER_PLUS_EXPR with the
+       generic address expression comparison folding.  Remove
+       the folding that used extract_array_ref.
+
+2007-10-15  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       PR target/33133
+       * haifa-sched.c (process_insn_forw_deps_be_in_spec): Check if
+       speculation type of insn can be changed before trying to do that.
+
+2007-10-15  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * dse.c (struct insn_info): Add 'frame_read' field.
+       (scan_insn): For the call to a const function, set frame_read if
+       reload has been run.
+       If the insn reads the frame, kill the frame related stores.
+       (scan_reads_nospill): Likewise.
+
+2007-10-14  Jason Merrill  <jason@redhat.com>
+
+       * tree-eh.c (optimize_double_finally): Don't assume that the
+       cleanup we're duplicating is only one statement.
+
+2007-10-14  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/fixed-bit.c, config/i386/cpuid.h, config/i386/i386.c,
+       config/i386/i386.md, config/i386/sse.md, function.c, jump.c,
+       modulo-sched.c, ra-conflict.c, toplev.c, tree-eh.c, tree-sra.c,
+       tree-ssa-dse.c, tree-vect-analyze.c, tree-vect-patterns.c,
+       tree-vect-transform.c: Fix comment typos.
+       * doc/extend.texi: Fix a typo.
+
+       * c-common.h: Remove the prototype for c_expand_body.
+       * c-tree.h: Remove the prototype for c_disregard_inline_limits.
+       * tree.h: Remove the prototype for fold_build_call_expr.
+
+       * c-objc-common.h (LANG_HOOKS_TREE_INLINING_CANNOT_INLINE_TREE_FN):
+       Remove.
+       * c-tree.h: Remove the prototype for c_cannot_inline_tree_fn.
+
+2007-10-13  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/aix53.h: New file.
+       * config/rs6000/aix{41,43,51,52}.h (TARGET_ALTIVEC): Define to 0.
+       (TARGET_ALTIVEC_ABI): Same.
+       * config/rs6000/aix.h (TARGET_ALTIVEC): Delete.
+       (TARGET_ALTIVEC_ABI): Delete.
+       * config.gcc (powerpc-ibm-aix5*): Rename to aix5.2.  Add new
+       stanza defaulting to aix5.3.
+
+2007-10-12  Nathan Froyd  <froydnj@codesourcery.com>
+
+       * config/i386/i386.md (SI_REG, DI_REG): New constants.
+       (strmov): Use defined constants.
+       (cmpstrnsi): Likewise.
+       * config/i386/i386.c (decide_alg): Use defined constants.
+       (ix86_expand_strlen): Likewise.
+
+2007-10-12  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * dse.c (find_shift_sequence): Reinstate "<= UNITS_PER_WORD" condition.
+       * var-tracking.c (micro_operation_def): Update comment on u.loc.
+       (mode_for_reg_attrs, var_lowpart): New functions.
+       (add_uses): Consider recording a lowpart of LOC for MO_USE.
+       (add_stores): Likewise MO_SET and MO_COPY.  If the source of a set
+       or copy is known, set LOC to the SET that performs the set, instead
+       of the destination.
+       (find_src_status, find_src_set_src): Remove LOC parameter.
+       Replace INSN with the source value.
+       (compute_bb_dataflow, emit_notes_in_bb): Check for a SET u.loc when
+       handling MO_SET and MO_COPY.  Update the calls to find_src_status
+       and find_src_set_src.
+
+2007-10-12  Nathan Froyd  <froydnj@codesourcery.com>
+
+       PR 11001
+       * config/i386/i386.md (strmov): Check for esi and edi usage.
+       * config/i386/i386.c (decide_alg): Check whether we can use a
+       rep prefix and adjust algorithm choice accordingly.
+       (ix86_expand_strlen): Check for eax, ecx, and edi usage.
+
+2007-10-12  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * config/c4x/c4x.md (mulqi3, mulhi3): Use optab_libfunc.
+
+2007-10-12  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * global.c (build_insn_chain): Formatting fixes.
+
+2007-10-12  Richard Guenther <rguenther@suse.de>
+
+       * tree-ssa-forwprop.c (forward_propagate_into_cond): For
+       combining both operands require either both have single uses
+       or combining to a constant.
+
+2007-10-12  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/26198
+       * tree-ssa-forwprop.c (can_propagate_from): Do not propagate from
+       a rhs with side-effects or which is a load.
+       (forward_propagate_into_cond): Also try combining both operands.
+
+2007-10-12  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/33742
+       * tree-vect-transform.c (vectorizable_operation): Return false
+       if get_vectype_for_scalar_type for scalar_dest can't be determined.
+       (vectorizable_call): Same for rhs_type and lhs_type.
+
+2007-10-12  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/33645
+       * tree-ssa-live.c (mark_all_vars_used): Add data argument,
+       pass it to walk_tree.
+       (mark_all_vars_used_1): Pass data through to mark_all_vars_used.
+       When calling set_is_used on a VAR_DECL, if data is not NULL and
+       its DECL_UID is in the bitmap, call mark_all_vars_used on its
+       DECL_INITIAL after clearing the bit in bitmap.
+       (remove_unused_locals): Adjust mark_all_vars_used callers.
+       Instead of removing unused global vars from unexpanded_var_list
+       immediately record them in bitmap, call mark_all_vars_used on
+       all used global vars from unexpanded_var_list and only purge
+       global vars that weren't found used even during that step.
+2007-10-11  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * gthr-posix.h (__gthread_active_init): Create detached instead of
+       joinable thread when testing whether threads are active on hppa-hpux.
+       * gthr-posix95.h (__gthread_active_init): Likewise.
+
+2007-10-11  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/33676
+       * global.c (build_insn_chain): Include insn that occur between
+       basic blocks.
+       
+2007-10-11  Tom Tromey  <tromey@redhat.com>
+
+       * gengtype-yacc.y: Delete.
+
+2007-10-11  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (AX_REG, DX_REG, CX_REG): New constants.
+       * config/i386/i386.c (ix86_function_arg_regno_p, function_arg_32,
+       function_value_32, function_value_64, function_value_ms_64,
+       setup_incoming_varargs_64, ix86_expand_prologue, ix86_expand_call,
+       legitimize_tls_address, x86_this_parameter, x86_output_mi_thunk):
+       Use new constants.
+
+2007-10-11  Richard Guenther  <rguenther@suse.de>
+
+       * gcse.c (hash_scan_set): If the next nonnote insn is in
+       a different basic block insert the set.
+
+2007-10-11  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33724
+       * tree-cfg.c (one_pointer_to_useless_type_conversion_p): New function.
+       (verify_gimple_expr): Use it to verify pointer-to types for
+       ADDR_EXPRs.
+
+2007-10-11  Richard Guenther  <rguenther@suse.de>
+
+       PR c/33726
+       * c-typeck.c (build_array_ref): Do not strip qualifiers from
+       the array element type.
+
+2007-10-11  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/33638
+       * dse.c (struct insn_info): Remove 'stack_read' field,
+       add 'stack_pointer_based' field.
+       (record_store): For a store with non-constant base, record
+       whether it is stack pointer based.
+       (scan_insn): For the call to a const function, remove stack
+       pointer based stores from the list of local active stores.
+       (scan_reads_nospill): Delete code dealing with const functions.
+
+2007-10-10  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * ra-conflict.c (partial_bitnum, max_bitnum): Change type of variables
+       to HOST_WIDE_INT.
+       (conflict_p, set_conflict, set_conflicts): Likewise.
+       * global.c (global_alloc): Likewise.
+       * ra.h: Update prototypes.
+
+2007-10-10  Wolfgang Gellerich  <gellerich@de.ibm.com>
+
+       * opth-gen.awk: Fixed generation of comment stating the origin
+         of options.h
+
+2007-10-10  Kazu Hirata  <kazu@codesourcery.com>
+
+       Revert:
+       2007-10-09  Kazu Hirata  <kazu@codesourcery.com>
+       * longlong.h (count_leading_zeros): Replace '{' and '}' with '%{'
+       and '%}', respectively.
+
+       Revert:
+       2007-10-09  Kazu Hirata  <kazu@codesourcery.com>
+       * config/m68k/m68k.c (print_operand): Handle '{' and '}'.
+       * config/m68k/m68k.h (PRINT_OPERAND_PUNCT_VALID_P): Accept '{'
+       and '}'.
+       * config/m68k/m68k.md: Replace '{' with '%{' where '{' is
+       meant to be output.
+
+       Revert:
+       2007-10-07  Kazu Hirata  <kazu@codesourcery.com>
+       * config/m68k/m68k.c, config/m68k/m68k.md: Use the assembly
+       syntax for ASSEMBLER_DIALECT.
+       * config/m68k/m68k.h (ASSEMBLER_DIALECT): New.
+
+2007-10-10  Revital Eres  <eres@il.ibm.com>
+
+       * modulo-sched.c (check_nodes_order): Dump the final order of
+       the nodes.
+       (get_sched_window): Add dump info.
+       (calculate_order_params): Dump order params of the nodes.
+
+2007-10-09  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/33669
+       * ra-conflict.c (record_one_conflict_between_regnos, 
+       set_conflicts_for_earlyclobber, global_conflicts): Improved logging.
+       (global_conflicts): Enhanced incorrect check.
+       
+2007-10-09  Geoffrey Keating  <geoffk@apple.com>
+
+       * dwarf2out.c (output_call_frame_info): FDEs are always emitted
+       if flag_exceptions is not set.
+       * config/darwin.c (darwin_emit_unwind_label): Rewrite to use
+       assemble_name rather than incorrectly emulating it.
+
+       * doc/extend.texi (Deprecated Features): Mention that <? and >? and
+       friends are removed from G++.
+
+2007-10-09  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * c-opts.c (c_common_handle_option): -Wnontemplate-friend,
+       -Wwrite-strings and -Wmultichar are enabled by default, so Wall
+       enabling them is redundant. Don't check two times for
+       c_dialect_cxx.
+       
+2007-10-09  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * ra-conflict.c (record_one_conflict_between_regnos): Revert
+       the last change.
+       (set_conflicts_for_earlyclobber): Likewise.
+       (global_conflicts): Likewise.
+
+2007-10-09  Kazu Hirata  <kazu@codesourcery.com>
+
+       * longlong.h (count_leading_zeros): Replace '{' and '}' with '%{'
+       and '%}', respectively.
+
+2007-10-09  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (print_operand): Handle '{' and '}'.
+       * config/m68k/m68k.h (PRINT_OPERAND_PUNCT_VALID_P): Accept '{'
+       and '}'.
+       * config/m68k/m68k.md: Replace '{' with '%{' where '{' is
+       meant to be output.
+
+2007-10-09  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33692
+       * gimplify.c (canonicalize_component_ref): Honor qualifiers
+       of referenced structure and component.
+
+2007-10-09  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/33669
+       * ra-conflict.c (record_one_conflict_between_regnos,
+       set_conflicts_for_earlyclobber, global_conflicts): Improved logging.
+       (global_conflicts): Removed incorrect check.
+
+2007-10-09  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR tree-optimization/33615
+       * tree-ssa-pre.c (compute_avail): Don't call make_values_for_stmt
+       if the statement might throw.  Fix formatting.
+
+2007-10-09  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR tree-optimization/33615
+       * tree-ssa-loop-im.c (movement_possibility): Return MOVE_IMPOSSIBLE
+       if the rhs might throw.
+
+2007-10-09  Jan Hubicka  <jh@suse.cz>
+
+       * invoke.texi (align-threshold, align-loop-iterations): Document.
+       * final.c: Include cfgloop.h, params.h
+       (compute_alignments): Dump decisions and compare them with loop
+       structure; honor given parameters.
+       (pass_compute_alignments): New dump file.
+       * params.def (PARAM_ALIGN_THRESHOLD, PARAM_ALIGN_LOOP_ITERATIONS): New.
+       * Makefile.in (final.o): Add dependency on cfgloop.h and params.h
+
+2007-10-09  James E. Wilson  <wilson@specifix.com>
+
+       PR tree-optimization/33655
+       PR middle-end/22156
+       * tree-sra.c (bitfield_overlaps_p): When fld->element is INTEGER_CST,
+       convert it to bitsizetype before size_binop call.
+
+2007-10-09  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR tree-optimization/33572
+       * tree-inline.c (update_ssa_across_abnormal_edges): Tolerate
+       the absence of a corresponding edge from the exit block.
+
+2007-10-09  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR middle-end/22156
+       * tree-sra.c (instantiate_element): Use BYTES_BIG_ENDIAN for
+       bit-field layout.
+       (sra_build_assignment): Likewise.  Set up mask depending on
+       precision, not type.
+       (sra_build_bf_assignment): Use BYTES_BIG_ENDIAN.  Don't overflow
+       computing bit masks.
+       (sra_build_elt_assignment): Don't view-convert from signed to
+       unsigned.
+       (sra_explode_bitfield_assignment): Use bit-field type if
+       possible.  Use BYTES_BIG_ENDIAN.
+
+2007-10-08  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR middle-end/22156
+       * tree-sra.c (scalarize_lsdt): Fix thinko in testing whether
+       the original stmt can throw.
+       (sra_build_bf_assignment): Fix type mismatch when applying negated
+       mask.
+
+2007-10-08  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/darwin.h (DARWIN_REGISTER_TARGET_PRAGMAS): Register
+       '#pragma mark' to be executed at preprocessing time.
+
+2007-10-08  Ollie Wild  <aaw@google.com>
+
+       * varasm.c (compare_constant): Removed call to
+       lang_hooks.expand_constant.
+       (copy_constants): Removed call to lang_hooks.expand_constant.
+       (compute_reloc_for_constant): Removed call to
+       lang_hooks.expand_constant.
+       (output_addressed_constants): Removed call to
+       lang_hooks.expand_constant.
+       (constructor_static_from_elts_p): Removed call to
+       lang_hooks.expand_constant.
+       (output_constant): Removed calls to lang_hooks.expand_constant.
+       * langhooks.h (struct lang_hooks): Removed field expand_constant.
+       * langhooks-def.h (lhd_return_tree): Removed.
+       (LANG_HOOKS_EXPAND_CONSTANT): Removed.
+       (LANG_HOOKS_INITIALIZER): Removed LANG_HOOKS_EXPAND_CONSTANT.
+       * langhooks.c (lhd_return_tree): Removed.
+
+2007-10-08  Mark Shinwell  <shinwell@codesourcery.com>
+
+       * combine.c (setup_incoming_promotions): Ensure that
+       arguments that have not undergone mode promotions do not
+       incorrectly get marked as being sign- or zero-extended.
+
+2007-10-08  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33693
+       PR middle-end/33695
+       PR middle-end/33697
+       * fold-const.c (fold_binary): Use correct types in folding
+       of a * (1 << b) to (a << b).  Likewise for ~A & ~B to ~(A | B)
+       and building of RROTATE_EXPR.
+
+2007-10-08  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33691
+       PR middle-end/33694
+       PR middle-end/33696
+       * fold-const.c (fold_binary): Use the correct types when
+       folding (A | CST1) & CST2 to (A & CST2) | (CST1 & CST2).
+       (fold_binary): Use the correct types when folding
+       (-A) - B to (-B) - A.
+       (fold_unary): Use the correct types when folding ~(X).
+
+2007-10-08  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * doc/invoke.texi (Wall): fix formatting issues.
+       
+2007-10-07  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * simplify-rtx.c (simplify_binary_operation_1): Canonicalize
+       truncated shift counts.
+
+2007-10-07  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c, config/m68k/m68k.md: Use the assembly
+       syntax for ASSEMBLER_DIALECT.
+       * config/m68k/m68k.h (ASSEMBLER_DIALECT): New.
+
+2007-10-06  Eric Botcazou  <ebotcazou@adacore.com>
+           Nathan Froyd  <froydnj@codesourcery.com>
+
+       * dwarf2out.c (dwarf2out_frame_init): Check for DWARF2_FRAME_INFO
+       when determining whether to record INCOMING_RETURN_ADDR_RTX.
+
+2007-10-06  Eric Botcazou  <ebotcazou@adacore.com>
+
+       Revert:
+       2007-02-12  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree.h (DECL_IGNORED_P): Document further effect for FUNCTION_DECL.
+       * cgraphunit.c (cgraph_expand_function): If DECL_IGNORED_P is set on
+       the function, temporarily point the debug interface to the null one.
+
+2007-10-06  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR tree-optimization/33655
+       PR middle-end/22156
+       * tree-sra.c (bitfield_overlaps_p): Handle array and complex elements.
+
+2007-10-06  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR tree-optimization/33572
+       * tree-cfg.c (verify_stmts): Check for missing PHI defs.
+       * tree-inline.c (update_ssa_across_eh_edges): Renamed to...
+       (update_ssa_across_abnormal_edges): ... this.  Set slots in the
+       return PHI node.
+       (copy_edges_for_bb): Handle nonlocal label edges.
+       (make_nonlocal_label_edges): Deleted.
+       (optimize_inline_calls): Don't call it.
+
+2007-10-05  Hans-Peter Nilsson  <hp@axis.com>
+
+       * gthr-single.h: Revert last change.
+
+2007-10-05  Michael Matz  <matz@suse.de>
+
+       PR middle-end/33667
+       * lower-subreg.c (decompose_multiword_subregs): Use
+       validate_unshare_change().
+
+2007-10-05  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * ra-conflict.c: Include "sparseset.h".
+       (conflicts): Change to HOST_WIDEST_FAST_INT.
+       (allocnos_live): Redefine variable as a sparseset.
+       (SET_ALLOCNO_LIVE, CLEAR_ALLOCNO_LIVE, GET_ALLOCNO_LIVE):
+       Delete macros.
+       (allocno_row_words): Removed global variable.
+       (partial_bitnum, max_bitnum, adjacency_pool, adjacency): New variables.
+       (CONFLICT_BITNUM, CONFLICT_BITNUM_FAST): New defines.
+       (conflict_p, set_conflict_p, set_conflicts_p): New functions.
+       (record_one_conflict_between_regnos): Cache allocno values and reuse.
+       Use set_conflict_p.
+       (record_one_conflict): Update uses of allocnos_live to use
+       the sparseset routines.  Use set_conflicts_p.
+       (mark_reg_store): Likewise.
+       (set_reg_in_live): Likewise.
+       (global_conflicts): Update uses of allocnos_live.
+       Use the new adjacency list to visit an allocno's neighbors
+       rather than iterating over all possible allocnos.
+       Call set_conflicts_p to setup conflicts rather than adding
+       them manually.
+       * global.c: Comments updated.  
+       (CONFLICTP): Delete define.
+       (regno_compare): New function.  Add prototype.
+       (global_alloc): Sort the allocno to regno mapping according to
+       which basic blocks the regnos are referenced in.  Modify the
+       conflict bit matrix to a compressed triangular bitmatrix.
+       Only allocate the conflict bit matrix and adjacency lists if
+       we are actually going to allocate something.
+       (expand_preferences): Use conflict_p.  Update uses of allocnos_live.
+       (prune_preferences): Use the FOR_EACH_CONFLICT macro to visit an
+       allocno's neighbors rather than iterating over all possible allocnos.
+       (mirror_conflicts): Removed function.
+       (dump_conflicts): Iterate over regnos rather than allocnos so
+       that all dump output will be sorted by regno number.
+       Use the FOR_EACH_CONFLICT macro.
+       * ra.h: Comments updated.
+       (conflicts): Update prototype to HOST_WIDEST_FAST_INT.
+       (partial_bitnum, max_bitnum, adjacency, adjacency_pool):
+       Add prototypes.
+       (ADJACENCY_VEC_LENGTH, FOR_EACH_CONFLICT): New defines.
+       (adjacency_list_d, adjacency_iterator_d): New types.
+       (add_neighbor, adjacency_iter_init, adjacency_iter_done,
+       adjacency_iter_next, regno_basic_block): New static inline functions.
+       (EXECUTE_IF_SET_IN_ALLOCNO_SET): Removed define.
+       (conflict_p): Add function prototype.
+       * sparseset.h, sparseset.c: New files.
+       * Makefile.in (OBJS-common): Add sparseset.o.
+       (sparseset.o): New rule.
+
+2007-10-05  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33666
+       * fold-const.c (fold_unary): Do not fold (long long)(int)ptr
+       to (long long)ptr.
+
+2007-10-05  Michael Matz  <matz@suse.de>
+
+       PR inline-asm/33600
+       * function.c (match_asm_constraints_1): Check for input
+       being used in the outputs.
+
+2007-10-05  Richard Guenther  <rguenther@suse.de>
+
+       * tree-cfg.c (verify_gimple_expr): Accept OBJ_TYPE_REF.
+
+2007-10-05  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR target/33635
+       * config/mips/mips.c (mips_register_move_cost): Rewrite to use
+       subset checks.  Make the cost of FPR -> FPR moves depend on
+       mips_mode_ok_for_mov_fmt_p.
+
+2007-10-04  Doug Kwan  <dougkwan@google.com>
+
+       * gthr-posix.h (__gthread_cond_broadcast, __gthread_cond_wait,
+       __gthread_cond_wait_recursive): Add to extend interface for POSIX
+       conditional variables. (__GTHREAD_HAS_COND): Macro defined to signify
+       support of conditional variables.
+       * gthr-posix95.h (__gthread_cond_broadcast, __gthread_cond_wait,
+       __gthread_cond_wait_recursive): Add to extend interface for POSIX
+       conditional variables. (__GTHREAD_HAS_COND): Macro defined to signify
+       support of conditional variables.
+       * gthr-single.h (__gthread_cond_broadcast, __gthread_cond_wait,
+       __gthread_cond_wait_recursive): Add to extend interface for POSIX
+       conditional variables.
+       * gthr.h: Update comments to document new interface.
+
+2007-10-04  Geoffrey Keating  <geoffk@apple.com>
+
+       * cgraphunit.c (cgraph_build_static_cdtor): Don't set DECL_IGNORED_P.
+
+2007-10-04  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (expand_epilogue): Don't set RTX_FRAME_RELATED_P.
+
+2007-10-04  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33641
+       * tree-cfg.c (verify_gimple_expr): Operand one of POINTER_PLUS_EXPR
+       does not need to be of INTEGER_TYPE.
+       (verify_gimple_2): New function split out from ...
+       (verify_gimple_1): ... here.  ICE if there was an error during
+       verification.
+
+2007-10-04  Michael Matz  <matz@suse.de>
+
+       PR rtl-optimization/33653
+       * dce.c (deletable_insn_p_1): Use volatile_refs_p().
+       * dse.c (scan_insn): Same.
+
+2007-10-04  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config.gcc: Remove USE_GAS for m68k targets.
+
+2007-10-04  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33627
+       * tree-gimple.h (canonicalize_cond_expr_cond): Declare.
+       * tree-gimple.c (canonicalize_cond_expr_cond): New function,
+       split out from ...
+       * tree-ssa-forwprop.c (combine_cond_expr_cond): ... here.
+       * tree-ssa-ifcombine.c (ifcombine_iforif): Use it.
+
+2007-10-04  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (commands_in_file, commands_in_prologues, 
+       commands_in_epilogues): Remove variables.
+       (avr_file_start): Remove unneded initializations of commands_in_file,
+       commands_in_prologues and commands_in_epilogues variables.
+       (avr_file_end): Remove dead code.
+
+2007-10-04  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_output_movem): Use the MOTOROLA if
+       MOTOROLA is to true.
+
+2007-10-03  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR target/33635
+       * config/mips/mips-protos.h (mips_split_64bit_move): Rename to...
+       (mips_split_doubleword_move): ...this.
+       * config/mips/mips.c (mips_subword): Extend to handle 64-bit words;
+       use natural endianness for multi-format FPR values.
+       (mips_split_64bit_move): Rename to...
+       (mips_split_doubleword_move): ...this and extend to 64-bit words.
+       Use move_doubleword_fpr* patterns for moves involving FPRs.
+       (mips_save_reg): Update the call to mips_split_64bit_move.
+       (mips_secondary_reload_class): Return NO_REGS for any reload of a
+       nonzero constant into an FPR if the constant can be forced to memory.
+       * config/mips/mips.md: Update the splitter calls to
+       mips_split_64bit_move.
+       (UNSPEC_LOAD_DF_LOW): Rename to...
+       (UNSPEC_LOAD_LOW): ...this.
+       (UNSPEC_LOAD_DF_HIGH): Rename to...
+       (UNSPEC_LOAD_HIGH): ...this.
+       (UNSPEC_STORE_DF_HIGH): Rename to...
+       (UNSPEC_STORE_WORD): ...this.
+       (SPLITF): New mode iterator.
+       (HALFMODE): New mode attribute.
+       (movtf): New expander.
+       (*movtf_internal): New define_insn_and_split.
+       (move_doubleword_fpr<mode>): New expander.
+       (load_df_low, load_df_high, store_df_high, mthc1, mfhc1): Replace
+       with...
+       (load_low<mode>, load_high<mode>, store_word<mode>, mthc1<mode>)
+       (mfhc1<mode>): ...these more general patterns.
+
+2007-10-03  Alexandre Oliva  <aoliva@redhat.com>
+
+       * cfgrtl.c (rtl_block_ends_with_call_p): Skip notes at the end.
+
+2007-10-03  Alexandre Oliva  <aoliva@redhat.com>
+
+       * gcse.c (hash_scan_set): Insert set in insn before note at
+       the end of basic block.
+
+2007-10-03  Sebastian Pop  <sebastian.pop@amd.com>
+
+       PR tree-optimization/33576
+       * testsuite/gcc.dg/tree-ssa/pr33576.c: New.
+       * tree-loop-linear.c (linear_transform_loops): Call remove_iv.
+       * lambda.h (lambda_loopnest_to_gcc_loopnest): New parameter.
+       (remove_iv): Declared.
+       * lambda-code.c (remove_iv): Not static.
+       (lambda_loopnest_to_gcc_loopnest): New parameter remove_ivs.
+       Don't remove ivs there, save ivs in the buffer.
+
+2007-10-03  Jason Merrill  <jason@redhat.com>
+
+       PR c++/15764
+       * tree-eh.c (same_handler_p): New fn.
+       (optimize_double_finally): New fn.
+       (refactor_eh_r): New fn.
+       (refactor_eh): New fn.
+       (pass_refactor_eh): New pass.
+       * tree-pass.h: Declare it.
+       * passes.c (init_optimization_passes): Add it.
+
+2007-10-03  Doug Kwan  <dougkwan@google.com>
+       Richard Guenther  <rguenther@suse.de>
+
+       PR debug/31899
+       * dwarf2out.c (reference_to_unused): Disable sanity checking,
+       be conservative instead.
+
+2007-10-03  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
+
+       PR fortran/26682
+       * doc/invoke.texi (-fwhole-program): Document that Fortran
+       doesn't support this option.
+
+2007-10-02  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       PR middle-end/33617
+       * expr.c (expand_expr_addr_expr_1): Pass CONSTRUCTORs to expand_expr.
+
+2007-10-02  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/mips.md (sync_compare_and_swap<mode>): Handle compare
+       against constant zero.
+       * config/mips/mips.h (MIPS_COMPARE_AND_SWAP):  Handle constant zero
+       operand.
+
+2007-09-02  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * ra-conflict.c: New file.
+       * ra.h: New file.
+       * reload.c (push_reload, find_dummy_reload): Change DF_RA_LIVE
+       usage to DF_LIVE usage.
+       (reload): Remove reference to df_get_live_top.
+       * rtlanal.c (subreg_nregs_with_regno): New function.  
+       * df-scan.c (df_def_record_1, df_uses_record): Add code to set
+       DF_REF_EXTRACT, DF_REF_STRICT_LOWER_PART, and DF_REF_SUBREG flags.
+       (df_has_eh_preds): Removed.
+       (df_bb_refs_collect, df_bb_refs_collect, df_bb_refs_collect,
+       df_exit_block_uses_collect): Changed call from df_has_eh_preds to
+       bb_has_eh_pred.
+       * global.c (allocno, max_allocno, conflicts, allocno_row_words,
+       reg_allocno, EXECUTE_IF_SET_IN_ALLOCNO_SET): Moved to ra.h
+       (SET_ALLOCNO_LIVE, CLEAR_ALLOCNO_LIVE): Moved to ra-conflicts.c.
+       (regs_set, record_one_conflict, record_conflicts, mark_reg_store,
+       mark_reg_clobber, mark_reg_conflicts, mark_reg_death): Deleted.
+       (global_alloc): Turn off rescanning insns after call to
+       global_conflicts and added call to set_preferences.
+       (global_conflicts): Moved to ra-alloc.c.
+       (set_preferences_1, set_preferences): New function.
+       (mirror_conflicts): Changed types for various variables.
+       (mark_elimination): Change DF_RA_LIVE
+       usage to DF_LIVE usage.
+       (build_insn_chain): Rewritten from scratch and made local.
+       (print_insn_chain, print_insn_chains): New functions.
+       (dump_conflicts): Do not print conflicts for fixed_regs.
+       (rest_of_handle_global_alloc): Turn off insn rescanning.
+       * hard-reg-set.h: Fixed comment.
+       * local-alloc.c (update_equiv_regs): Change DF_RA_LIVE
+       usage to DF_LIVE usage and delete refs to TOP sets.
+       (block_alloc): Mark regs as live if they are in the artificial
+       defs at top of block.
+       (find_stack_regs): New function.
+       (rest_of_handle_local_alloc): Changed urec problem to live
+       problem and do not turn off df rescanning.
+       * df.h (DF_UREC, DF_UREC_BB_INFO, DF_LIVE_TOP, DF_RA_LIVE_IN,
+       DF_RA_LIVE_TOP, DF_RA_LIVE_OUT, df_urec_bb_info, df_urec,
+       df_urec_add_problem, df_urec_get_bb_info, df_has_eh_preds): Removed.
+       (DF_CHAIN, DF_NOTE, DF_CHAIN): Renumbered.
+       (DF_REF_EXTRACT, DF_REF_STRICT_LOWER_PART, DF_REF_SUBREG): New
+       fields in df_ref_flags.  The rest have been renumbered.  
+       * init-regs.c (initialize_uninitialized_regs): Enhanced debugging
+       at -O1.
+       * rtl.h (subreg_nregs_with_regno): New function.
+       * df-problems.c: (df_get_live_out, df_get_live_in,
+       df_get_live_top): Removed reference to DF_RA_LIVE.
+       (df_lr_reset, df_lr_transfer_function, df_live_free_bb_info,
+       df_live_alloc, df_live_reset, df_live_local_finalize,
+       df_live_free): Make top set only if different from in set.
+       (df_lr_top_dump, df_live_top_dump): Only print top set if
+       different from in set.
+       (df_lr_bb_local_compute): Removed unnecessary check.
+       (df_urec_problem_data, df_urec_set_bb_info, df_urec_free_bb_info, 
+       df_urec_alloc, df_urec_mark_reg_change, earlyclobber_regclass, 
+       df_urec_check_earlyclobber, df_urec_mark_reg_use_for_earlyclobber,
+       df_urec_mark_reg_use_for_earlyclobber_1, df_urec_bb_local_compute,
+       df_urec_local_compute, df_urec_init, df_urec_local_finalize, 
+       df_urec_confluence_n, df_urec_transfer_function, df_urec_free, 
+       df_urec_top_dump, df_urec_bottom_dump, problem_UREC,
+       df_urec_add_problem): Removed.
+       (df_simulate_fixup_sets): Changed call from df_has_eh_preds to
+       bb_has_eh_pred. 
+       * Makefile.in (ra-conflict.o, ra.h): New dependencies.
+       * basic_block.h (bb_has_abnormal_pred): New function.
+       * reload1.c (compute_use_by_pseudos): Change DF_RA_LIVE
+       usage to DF_LIVE usage.
+       
+2007-10-02  Revital Eres  <eres@il.ibm.com>
+
+       * config/rs6000/predicates.md (easy_vector_constant): Return false
+       for 750CL paired vectors.
+       * config/rs6000/paired.md (movv2sf_paired): Fix move of easy
+       vector constant.
+       (vec_initv2sf): Add new description.
+       (vconcatsf): Likewise.
+       * config/rs6000/rs6000-protos.h: Declare paired_expand_vector_init.
+       * config/rs6000/rs6000.c (paired_expand_vector_init): New function.
+
+2007-10-01  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree-ssa-sink.c (sink_code_in_bb): Don't stop sinking after
+       sinking the last stmt in a BB.
+
+2007-10-01  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR middle-end/22156
+       * tree-sra.c (struct sra_elt): Add in_bitfld_block.
+       (sra_hash_tree): Handle BIT_FIELD_REFs.
+       (sra_elt_hash): Don't hash bitfld blocks.
+       (sra_elt_eq): Skip them in parent compares as well.  Handle
+       BIT_FIELD_REFs.
+       (build_element_name_1): Handle BIT_FIELD_REFs.
+       (instantiate_element): Propagate nowarn from parents.  Create
+       BIT_FIELD_REF for variables that are widened by scalarization.
+       Gimple-zero-initialize all bit-field variables that are not
+       part of parameters that are going to be scalarized on entry.
+       (instantiate_missing_elements_1): Return the sra_elt.
+       (canon_type_for_field): New.
+       (try_instantiate_multiple_fields): New.  Infer widest possible
+       access mode from decl or member type, but clip it at word
+       size, and only widen it if a field crosses an alignment boundary.
+       (instantiate_missing_elements): Use them.
+       (generate_one_element_ref): Handle BIT_FIELD_REFs.
+       (scalar_bitfield_p): New.
+       (sra_build_assignment): Optimize assignments from scalarizable
+       BIT_FIELD_REFs.  Use BITS_BIG_ENDIAN to determine shift counts.
+       (REPLDUP): New.
+       (sra_build_bf_assignment): New.  Optimize assignments to
+       scalarizable BIT_FIELD_REFs.
+       (sra_build_elt_assignment): New.  Optimize BIT_FIELD_REF
+       assignments to full variables.
+       (generate_copy_inout): Use the new macros and functions.
+       (generate_element_copy): Likewise.  Handle bitfld differences.
+       (generate_element_zero): Don't recurse for blocks.  Use
+       sra_build_elt_assignment.
+       (generate_one_element_init): Take elt instead of var.  Use
+       sra_build_elt_assignment.
+       (generate_element_init_1): Adjust.
+       (bitfield_overlap_info): New struct.
+       (bitfield_overlaps_p): New.
+       (sra_explode_bitfield_assignment): New.  Adjust widened
+       variables to account for endianness.
+       (sra_sync_for_bitfield_assignment): New.
+       (scalarize_use): Re-expand assignment to/from scalarized
+       BIT_FIELD_REFs.  Explode or sync needed members for
+       BIT_FIELD_REFs accesses or assignments.  Use REPLDUP.
+       (scalarize_copy): Use REPLDUP.
+       (scalarize_ldst): Move assert before dereference.  Adjust EH handling.
+       (dump_sra_elt_name): Handle BIT_FIELD_REFs.
+
+2007-10-01  Paolo Bonzini  <bonzini@gnu.org>
+
+       * simplify-rtx.c (comparison_result, simplify_relational_operation_1):
+       Rename CR_* constants to CMP_*.  Fix spacing.
+
+2007-10-01  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR other/33585
+       * Makefile.in (build_html_dir/gccinstall): gccinstall.texi needs
+       to be processed with the special script doc/install.texi2html.
+       
+2007-09-30  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * doc/invoke.texi (Wall): List the options enabled by Wall.
+       (Wstrict-aliasing): Add missing @option.
+       
+2007-09-30  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_split_64bit_move): Use gen_rtx_REG_offset
+       rather than gen_lowpart to change a register from DImode to DFmode.
+       (mips_cannot_change_mode_class): Only allow FPRs to change mode if
+       both FROM and TO are integer modes that are no bigger than 4 bytes.
+       (mips_mode_ok_for_mov_fmt_p): New function.
+       (mips_preferred_reload_class): Use it instead of FLOAT_MODE_P.
+       (mips_secondary_reload_class): Tweak formatting and comments.
+       Use reg_class_subset_p instead of direct comparisons with
+       classes.  Only allow direct FPR<->FPR moves for modes that
+       satisfy mips_mode_ok_for_mov_fmt_p.  Only allow loads and stores
+       for 4- and 8-byte types.  Handle reloads in which X is an FPR.
+       * config/mips/mips.md (*movdi_gp32_fp64): Remove f<-f alternative.
+       (*movdi_64bit): Likewise.
+       (*movsi_internal): Likewise.
+       (*movhi_internal): Likewise.
+       (*movqi_internal): Likewise.
+
+2007-09-30  Diego Novillo  <dnovillo@google.com>
+
+       PR 33593
+       * tree-ssa-ter.c (is_replaceable_p): Return false if STMT may
+       throw an exception.
+
+2007-09-30  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/33597
+       * tree-vect-analyze.c (vect_build_slp_tree): Check if optab handler
+       for LSHIFT_EXPR and RSHIFT_EXPR is available for vec_mode.
+
+2007-09-28  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_expand_move): Use can_create_pseudo_p ()
+       instead of variants of (!reload_in_progress && !reload_completed).
+       (x86_expand_vector_move): Ditto.
+
+2007-09-28  Ollie Wild  <aaw@google.com>
+
+       Revert
+       2007-09-27  Ollie Wild  <aaw@google.com>
+
+       * varasm.c (compare_constant): Removed call to
+       lang_hooks.expand_constant.
+       (copy_constants): Removed call to lang_hooks.expand_constant.
+       (compute_reloc_for_constant): Removed call to
+       lang_hooks.expand_constant.
+       (output_addressed_constants): Removed call to
+       lang_hooks.expand_constant.
+       (constructor_static_from_elts_p): Removed call to
+       lang_hooks.expand_constant.
+       (output_constant): Removed calls to lang_hooks.expand_constant.
+       * langhooks.h (struct lang_hooks): Removed field expand_constant.
+       * langhooks-def.h (lhd_return_tree): Removed.
+       (LANG_HOOKS_EXPAND_CONSTANT): Removed.
+       (LANG_HOOKS_INITIALIZER): Removed LANG_HOOKS_EXPAND_CONSTANT.
+       * langhooks.c (lhd_return_tree): Removed.
+
+2007-09-28  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR target/33347
+       * config/spu/spu.c (spu_expand_insv): Call copy_rtx on the second
+       argument to gen_selb.
+
+2007-09-28  Chao-ying Fu  <fu@mips.com>
+
+       * libgcc-std.ver: Add fixed-point routines to GCC_4.3.0 section.
+       * doc/libgcc.texi (Fixed-point fractional library routines):
+       Fix typos for neg and cmp functions.
+
+2007-09-28  Michael Matz  <matz@suse.de>
+
+       PR rtl-optimization/33552
+       * function.c (match_asm_constraints_1): Check for overlap in
+       inputs and replace all occurences.
+
+2007-09-28  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (override_options): Fix comment typo.
+
+2007-09-28  Jie Zhang  <jie.zhang@analog.com>
+
+       * config.gcc (bfin*-linux-uclibc*): Set extra_parts
+       to "crtbegin.o crtbeginS.o crtend.o crtendS.o".
+       * config/bfin/t-bfin-linux (crti.o): Don't build.
+       (crtn.o): Likewise.
+       (EXTRA_MULTILIB_PARTS): Remove crti.o and crtn.o.
+       * config/bfin/t-bfin-uclinux (crti.o): Don't build.
+       (crtn.o): Likewise.
+       (EXTRA_MULTILIB_PARTS): Remove crti.o and crtn.o.
+
+2007-09-27  Ollie Wild  <aaw@google.com>
+
+       * varasm.c (compare_constant): Removed call to
+       lang_hooks.expand_constant.
+       (copy_constants): Removed call to lang_hooks.expand_constant.
+       (compute_reloc_for_constant): Removed call to
+       lang_hooks.expand_constant.
+       (output_addressed_constants): Removed call to
+       lang_hooks.expand_constant.
+       (constructor_static_from_elts_p): Removed call to
+       lang_hooks.expand_constant.
+       (output_constant): Removed calls to lang_hooks.expand_constant.
+       * langhooks.h (struct lang_hooks): Removed field expand_constant.
+       * langhooks-def.h (lhd_return_tree): Removed.
+       (LANG_HOOKS_EXPAND_CONSTANT): Removed.
+       (LANG_HOOKS_INITIALIZER): Removed LANG_HOOKS_EXPAND_CONSTANT.
+       * langhooks.c (lhd_return_tree): Removed.
+
+2007-09-27  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR middle-end/33436
+       * expr.c (emit_group_load_1): Split constant double when destination
+       length is half source length.
+
+2007-09-27  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h (PTF_AVOID_BRANCHLIKELY): New macro.
+       (mips_cpu_info): Add tune_flags.
+       (GENERATE_BRANCHLIKELY): Remove TARGET_SR71K check.
+       * config/mips/mips.c (mips_cpu_info_table): Add tune_flags fields.
+       Remove end marker.
+       (override_options): Remove deprecation code.  Use branch-likely
+       instructions for optimize_size or if the tuning flags do not
+       suggest otherwise.  Tweak warning.
+       (mips_matching_cpu_name_p, mips_parse_cpu): Use ARRAY_SIZE.
+
+2007-09-27  Matthias Klose  <doko@ubuntu.com>
+
+       * config/i386/t-linux64 (MULTILIB_OSDIRNAMES): Use ../lib32 as the
+       multilib osdirname if it exists.
+       * config/rs6000/t-linux64 (MULTILIB_OSDIRNAMES): Likewise.
+
+2007-09-27  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/33565
+       * tree-ssa-loop-ch.c (copy_loop_headers): Set TREE_NO_WARNING on
+       assignments of comparisons.
+       * tree-ssa-sccvn.c (simplify_binary_expression): Add stmt
+       parameter.  Change caller.  Defer overflow warnings around call to
+       fold_binary.
+       * fold-const.c (fold_undefer_overflow_warnings): Don't warn if
+       TREE_NO_WARNING is set on the statement.
+       * tree-ssa-forwprop.c
+       (tree_ssa_forward_propagate_single_use_vars): Don't test
+       TREE_NO_WARNING when calling fold_undefer_overflow_warnings.
+       * tree-cfg.c (fold_cond_expr_cond): Likewise.
+
+2007-09-27  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/rs6000/rs6000.c (rs6000_legitimize_address): Do not
+       reduce offset by units of 0x10000 for SPE vector modes or modes
+       used with E500 double instructions.
+
+2007-09-04  Paolo Bonzini  <bonzini@gnu.org>
+
+       * simplify-rtx.c (comparison_result): New.
+       (simplify_const_relational_operation): Use it instead of the five
+       "equal|op[01]ltu?" variables; consequently remove redundant "else"s.
+       Improve bounds-checking optimizations; remove subsumed POPCOUNT
+       optimizations.  Extract nonzero_address_p optimizations into a
+       separate "if" together with optimizations where op1 is const0_rtx.
+       Optimize comparing an IOR with zero.  Simplify op0 RELOP op0 for
+       floating-point arguments too when appropriate.  Hoist test for ABS
+       outside the final switch statement.
+       * cse.c (fold_rtx): Don't look for an IOR equivalent of
+       folded_arg0 if we found a constant equivalent.  Remove
+       transformations done in simplify-rtx.c for "op0 RELOP op0".
+
+2007-09-27  Jakub Jelinek  <jakub@redhat.com>
+
+       * builtins.c (expand_builtin, expand_builtin_object_size,
+       expand_builtin_memory_chk, maybe_emit_chk_warning,
+       maybe_emit_sprintf_chk_warning): Use new %K format string specifier
+       for diagnostics.
+       * expr.c (expand_expr_real_1): Likewise.
+       * langhooks-def.h (struct diagnostic_info): Add forward decl.
+       (lhd_print_error_function): Add third argument.
+       * langhooks.h (struct diagnostic_info): Add forward decl.
+       (struct lang_hooks): Add third argument to print_error_function.
+       * diagnostic.h (diagnostic_info): Add abstract_origin field.
+       (diagnostic_last_function_changed, diagnostic_set_last_function): Add
+       second argument.
+       (diagnostic_report_current_function): Likewise.
+       * toplev.c (announce_function): Pass NULL as second argument to
+       diagnostic_set_last_function.
+       * diagnostic.c (diagnostic_report_current_function): Add second
+       argument, pass it as third argument to lang_hooks.print_error_function.
+       (default_diagnostic_starter): Pass DIAGNOSTIC as second argument
+       to diagnostic_report_current_function.
+       (diagnostic_report_diagnostic): Initialize diagnostic->abstract_origin
+       and message.abstract_origin.
+       (verbatim): Initialize abstract_origin.
+       * pretty-print.h (text_info): Add abstract_origin field.
+       * pretty-print.c (pp_base_format): Handle %K.
+       * langhooks.c (lhd_print_error_function): Add third argument.  If
+       diagnostic->abstract_origin, print virtual backtrace.
+       * c-format.c (gcc_diag_char_table, gcc_tdiag_char_table,
+       gcc_cdiag_char_table, gcc_cxxdiag_char_table): Support %K.
+       (init_dynamic_diag_info): Likewise.
+
+2007-09-26  David Daney  <ddaney@avtrex.com>
+
+       PR target/33479
+       * config/mips/mips.md (sync_compare_and_swap<mode>, sync_old_add<mode>,
+       sync_new_add<mode>, sync_old_<optab><mode>, sync_new_<optab><mode>,
+       sync_old_nand<mode>, sync_new_nand<mode>,
+       sync_lock_test_and_set<mode>): Fix '&' constraint modifiers.
+       Update length attributes.
+       (sync_add<mode>, sync_sub<mode>, sync_old_sub<mode>,
+       sync_new_sub<mode>, sync_<optab><mode>, sync_nand<mode>): Update
+       length attributes.
+       * config/mips/mips.h (MIPS_COMPARE_AND_SWAP, MIPS_SYNC_OP,
+       MIPS_SYNC_OLD_OP, MIPS_SYNC_NEW_OP, MIPS_SYNC_NAND,
+       MIPS_SYNC_OLD_NAND, MIPS_SYNC_NEW_NAND, MIPS_SYNC_EXCHANGE): Add
+       post-loop sync.
+
+2007-09-26  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33563
+       * tree-ssa-dse.c (get_use_of_stmt_lhs): Rename to ...
+       (get_kill_of_stmt_lhs): ... this.  Re-structure.  Handle
+       aggregate stores.
+       (dse_optimize_stmt): Call get_kill_of_stmt_lhs instead of
+       get_use_of_stmt_lhs.
+
+2007-09-26  Joseph Myers  <joseph@codesourcery.com>
+
+       PR c/25309
+       * c-common.c (complete_array_type): Diagnose too-large arrays and
+       set type to error_mark_node.
+
+2007-09-26  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/30375
+       PR tree-optimization/33560
+       * tree-ssa-dse.c (get_use_of_stmt_lhs): Give up on uses
+       with calls.
+
+       Revert
+       2006-05-22  Aldy Hernandez  <aldyh@redhat.com>
+
+       * tree-ssa-dse.c (aggregate_vardecl_d): New.
+       (dse_global_data): Add aggregate_vardecl field.
+       (dse_possible_dead_store_p): New.
+       Add prev_defvar variable.
+       Allow immediate uses and previous immediate uses to differ
+       if they are setting different parts of the whole.
+       (get_aggregate_vardecl): New.
+       (dse_record_partial_aggregate_store): New.
+       (dse_whole_aggregate_clobbered_p): New.
+       (dse_partial_kill_p): New.
+       Call dse_maybe_record_aggregate_store().
+       When checking whether a STMT and its USE_STMT refer to the
+       same memory address, check also for partial kills that clobber
+       the whole.
+       Move some variable definitions to the block where they are used.
+       (aggregate_vardecl_hash): New.
+       (aggregate_vardecl_eq): New.
+       (aggregate_vardecl_free): New.
+       (aggregate_whole_store_p): New.
+       (tree_ssa_dse): Initialize and free aggregate_vardecl.
+       Mark which aggregate stores we care about.
+
+2007-09-25  DJ Delorie  <dj@redhat.com>
+
+       PR target/33551
+       * config/m32c/m32c.c (m32c_immd_dbl_mov): Use INTVAL instead of XINT.
+
+2007-09-25  Michael Meissner  <michael.meissner@amd.com>
+
+       PR target/33524
+       * config/i386/i386.c (ix86_expand_sse5_unpack): Change to call
+       gen_sse5_pperm_sign_v4si_v2di and gen_sse5_pperm_zero_v4si_v2di
+       for vector int32 -> int64 conversions.  Don't write beyond the end
+       of the allocated vector for int32 -> int64 conversions.
+
+2007-09-25  Revital Eres  <eres@il.ibm.com>
+
+       * config/rs6000/paired.h (paired_sel): New.
+       * config/rs6000/rs6000.c (bdesc_3arg): Add selv2sf4.
+       (rs6000_expand_ternop_builtin): Pass zero const_double operand
+       when expanding selv2sf.
+       * config/rs6000/rs6000.h (rs6000_builtins): Add
+       PAIRED_BUILTIN_SELV2SF4.
+
+2007-09-25  Joseph Myers  <joseph@codesourcery.com>
+
+       PR c/32295
+       * c-typeck.c (default_conversion): Call require_complete_type
+       before perform_integral_promotions.
+       (build_unary_op): Call require_complete_type except for ADDR_EXPR.
+       (build_c_cast): Call require_complete_type except for casts to
+       void types.
+       (convert_for_assignment): Call require_complete_type.
+
+2007-09-25  Revital Eres  <eres@il.ibm.com>
+
+       * config/spu/spu.md: Fix doloop pattern.
+
+2007-09-25  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.c (expand_prologue_reg_save,
+       expand_epilogue_reg_restore): Code to save and restore I/M/B/L regs
+       and ASTAT moved here...
+       (expand_interrupt_handler_prologue, expand_interrupt_handler_epilogue):
+       ... from here.  New argument ALL; callers changed.
+       (n_regs_saved_by_prologue): Count ASTAT for plain saveall functions.
+       (bfin_expand_prologue, bfin_expand_epilogue): Deal with functions that
+       have the "saveall" attribute.
+
+2007-09-25  Hans-Peter Nilsson  <hp@bitrange.com>
+
+       * config/mmix/mmix.h (FUNCTION_INCOMING_ARG_REGNO_P): Don't define
+       bogus target macro.
+       (INCOMING_REGNO, OUTGOING_REGNO): Define.
+       * config/mmix/mmix.c (mmix_opposite_regno): New function.
+       * config/mmix/mmix-protos.h (mmix_opposite_regno): Prototype.
+
+       * config/mmix/mmix.md ("*cmpcc_folded"): In condition, gate
+       with REG_P tests before REGNO access.
+
+2007-09-24  DJ Delorie  <dj@redhat.com>
+
+       PR target/31482
+       * config/m32c/cond.md (stzx_reversed_<mode>): Add an output
+       constraint.
+       (movqicc_<code>_<mode>): Likewise.
+       (movhicc_<code>_<mode>): Likewise.
+
+2007-09-24  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/33184
+       * config/m32c/m32c.c (m32c_eh_return_data_regno): Leave an address
+       register for reload.
+
+2007-09-24  Danny Smith  <dannysmith@user.sourceforge.net>
+
+       PR c++/14688
+       * config/i386/i386.c (ix86_comp_type_attributes): Check
+       METHOD_TYPE too.
+
+2007-09-24  Roman Zippel <zippel@linux-m68k.org> 
+
+       * config/m68k/m68k.h (ASM_OUTPUT_ALIGN_WITH_NOP): New, use
+       "move.l %a4,%a4" to produce nops.
+       * config/m68k/m68k.c (override_options): Reset align options,
+       if neccessary align macro isn't avaible.
+
+2007-09-24  Roman Zippel <zippel@linux-m68k.org> 
+
+       config/m68k/linux.h (PREFERRED_STACK_BOUNDARY): New.
+
+2007-09-24  Roman Zippel <zippel@linux-m68k.org> 
+
+       * config/m68k/m68k.c (strict_low_part_peephole_ok): Don't leave
+       the basic block.
+       * config/m68k/m68k.md (movsi_m68k): Allow certain constant when
+       reload is completed.
+       (peephole pattern): Convert most of them to RTL peephole pattern.
+
+2007-09-24  Roman Zippel <zippel@linux-m68k.org> 
+
+       * config/m68k/m68k.c (notice_update_cc): Recognize fp compare
+       (moved from fp compare patterns).
+       * config/m68k/m68k.md (cmp<mode>, cmp<mode>_68881, cmp<mode>_cf):
+       Cleanup predicates to relieve reload.
+       (conditional_trap): Reject conditional trap with fp condition.
+       * config/m68k/predicates.md (fp_src_operand): New, reject
+       certain constants early.
+
+2007-09-24  Roman Zippel <zippel@linux-m68k.org>
+
+       * final.c (final_scan_insn): Remove accidentally duplicated code.
+
+2007-09-24  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * config.gcc (powerpc*-*-*): --with-cpu=cell is a 64bit CPU.
+       Allow --with-tune=cell and --with-cpu=cell.
+
+2007-09-24  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/rs6000-protos.h (rs6000_emit_swrsqrtsf): Declare.
+       * config/rs6000/rs6000.opt (swdiv): Change option to ...
+       (recip): this.
+       * config/rs6000/rs6000.c (rs6000_builtin_reciprocal): New
+       function.
+       (TARGET_BUILTIN_RECIPROCAL): Use it.
+       (rs6000_builtin_expand): Expand recip, recipf, and rsqrtf.
+       (rs6000_init_builtins): Initialize recip, recipf, and rsqrtf.
+       (rs6000_emit_swrsqrtsf): New.
+       * config/rs6000/rs6000.h (rs6000_builtins): Add recip, recipf, and
+       rsqrtf. 
+       * config/rs6000/rs6000.md (UNSPEC_RSQRT): Define.
+       (divsf3): Remove swdiv support.
+       (recipsf3): New.
+       (rsqrtsf2): New.
+       (rsqrt_internal1): New.
+       (divdf3): Remove swdiv support.
+       (reciptdf3): New.
+
+2007-09-24  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/33506
+       * langhooks.h (struct lang_hooks_for_types): Add type_hash_eq
+       field.
+       * langhooks-def.h (LANG_HOOKS_TYPE_HASH_EQ): Define.
+       (LANG_HOOKS_FOR_TYPES_INITIALIZER): Add LANG_HOOKS_TYPE_HASH_EQ.
+       * tree.c (type_hash_eq): For FUNCTION_TYPE use
+       lang_hooks.type.type_hash_eq in addition to generic tests.
+
+2007-09-24  Pranav Bhandarkar  <pranav.bhandarkar@celunite.com>
+       Ramana Radhakrishnan  <ramana@hercules.pun.celunite.com>
+
+       * tree-inline.h (eni_weights): Add field target_builtin_cost to
+       reflect the cost per call to a target specific builtin.
+       * tree-inline.c (estimate_num_insns_1): If it is a CALL_EXPR for a
+       call to a target specific builtin, then use target_builtin_call_cost.
+       (init_inline_once): Initialize target_builtin_call_cost field.
+
+2007-09-24  Kai Tietz  <kai.tietz@onevision.com>
+
+       PR middle-end/33472
+       * config/i386/i386.c (return_in_memory_ms_64): Handle return types for
+       complex types.
+
+2007-09-23  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * configure.ac (ld_vers): Support GNU linker version xx.xx.*
+       * configure: Regenerated.
+
+2007-09-23  Ollie Wild  <aaw@google.com>
+
+       * fold-const.c (fold_binary): Fold BIT_AND_EXPR's with a pointer
+       operand.
+       (get_pointer_modulus_and_residue): New function.
+
+2007-09-23  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (build_mips16_call_stub): On 64-bit targets,
+       combine an SC return value into a single register.
+
+2007-09-23  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * opth-gen.awk (target_flags_explicit): Declare.
+       * toplev.h (target_flags_explicit): Delete declaration.
+       * toplev.c (target_flags): Likewise.
+       * config/mips/mips.h (mips_llsc_setting, mips_llsc): Delete.
+       (GENERATE_SYNC, GENERATE_LL_SC): Redefine using target_explicit_flags.
+       Never return true for TARGET_MIPS16.
+       * config/mips/mips.c (mips_llsc): Delete.
+       (mips_handle_option): Remove -mllsc handling.
+       (mips_strip_unspec_address): Tweak comment.
+       * config/mips/mips.opt (mllsc): Use a target mask.
+
+2007-09-23  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * doc/tm.texi (POINTERS_EXTEND_UNSIGNED): Document extensions to
+       word_mode as well as Pmode.
+
+2007-09-23  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * function.c (assign_parm_setup_block): Explicitly convert BLKmode
+       parameters from word_mode to the subword type if such a truncation
+       is not a no-op.
+
+2007-09-23  Jakub Jelinek  <jakub@redhat.com>
+
+       * configure.ac (MAKEINFO): Handle makeinfo version 4.10 and above.
+       * configure: Regenerated.
+
+2007-09-23  Jan Hubicka  <jh@suse.cz>
+
+       * params.def (INLINE_CALL_COST): Set to 12.
+       * invoke.texi (inline-call-cost): Update default value.
+
+2007-09-23  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * config/alpha/alpha.md (movti): Use operand_subword for the split.
+
+2007-09-23  Ayal Zaks  <zaks@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * modulo-sched.c (doloop_register_get): Rewrite the loop which
+       checks whether the count_reg is found outside the control part.
+
+2007-09-23  Jakub Jelinek  <jakub@redhat.com>
+
+       * expr.c (expand_expr_real_1) <case CALL_EXPR>: Use get_callee_fndecl
+       instead of checking CALL_EXPR_FN directly to test for builtins.
+       If error or warning attributes are present, print
+       error resp. warning.
+       * c-common.c (handle_error_attribute): New function.
+       (c_common_attribute_table): Add error and warning
+       attributes.
+       * doc/extend.texi: Document error and warning attributes.
+
+       * tree.h (block_nonartificial_location): New prototype.
+       * tree.c (block_nonartificial_location): New function.
+       * dwarf2out.c (gen_subprogram_die): Add DW_AT_artificial
+       if artificial attribute is present on abstract inline decl.
+       * c-common.c (handle_artificial_attribute): New function.
+       (c_common_attribute_table): Add artificial attribute.
+       * final.c (override_filename, override_linenum): New variables.
+       (final_scan_insn): For DBX_DEBUG or SDB_DEBUG, set override_filename
+       and override_linenum if inside of a block inlined from
+       __attribute__((__artificial__)) function.
+       (notice_source_line): Honor override_filename and override_linenum.
+       * doc/extend.texi: Document __attribute__((__artificial__)).
+       * config/i386/emmintrin.h: Add __artificial__ attribute to
+       all __always_inline__ functions.
+       * config/i386/mmintrin.h: Likewise.
+       * config/i386/tmmintrin.h: Likewise.
+       * config/i386/mm3dnow.h: Likewise.
+       * config/i386/pmmintrin.h: Likewise.
+       * config/i386/ammintrin.h: Likewise.
+       * config/i386/xmmintrin.h: Likewise.
+       * config/i386/smmintrin.h: Likewise.
+       * config/i386/bmmintrin.h: Likewise.
+       * config/i386/mmintrin-common.h: Likewise.
+
+       PR middle-end/28755
+       * expr.c (expand_constructor): New function.
+       (expand_expr_real_1) <case CONSTRUCTOR>: Call it.
+       (expand_expr_real_1) <case ARRAY_REF>: Call it if VALUE is
+       CONSTRUCTOR.
+
+2007-09-23  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (dump_constants_1): Generalize to include
+       fractional and accumulator modes.
+
+2007-09-23  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h (ISA_HAS_DSP, ISA_HAS_DSPR2): New macros.
+       * config/mips/mips.c (mips_set_mips16_mode): Don't clear the DSP
+       flags for MIPS16.
+       (override_options): Check TARGET_HARD_FLOAT_ABI instead of
+       TARGET_HARD_FLOAT when testing whether -mpaired-single is
+       supported.
+       (mips_conditional_register_usage): Check ISA_HAS_DSP instead of
+       TARGET_DSP.
+       * config/mips/constraints.md (ka): Check ISA_HAS_DSPR2 instead of
+       TARGET_DSPR2.
+       * config/mips/mips.md (ANYF): Require TARGET_HARD_FLOAT for V2SF.
+       (mulv2sf3, movv2sf, movv2sf_hardfloat_64bit): Require
+       TARGET_HARD_FLOAT.
+       (<u>mulsidi3_32bit_internal, <u>msubsidi4, <u>maddsidi4): Check
+       ISA_HAS_DSPR2 instead of TARGET_HAS_DSPR2.
+       * config/mips/mips-dsp.md: Use ISA_HAS_DSP instead of TARGET_HAS_DSP
+       throughout.
+       * config/mips/mips-dspr2.md: Likewise ISA_HAS_DSPR2 and
+       TARGET_HAS_DSPR2.
+       * config/mips/mips-fixed.md: Use ISA_HAS_DSP and ISA_HAS_DSPR2
+       instead of TARGET_HAS_DSP and TARGET_HAS_DSPR2.
+       * config/mips/mips-ps-3d.md: Add TARGET_HARD_FLOAT to V2SF patterns.
+
+2007-09-22  Jason Merrill  <jason@redhat.com>
+
+       PR c++/19407
+       * attribs.c (lookup_attribute_spec): Split out...
+       (decl_attributes): From here.
+       * tree.h: Declare it.
+
+2007-09-22  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * doc/sourcebuild.texi: Document dg-add-options mips16_attribute.
+
+2007-09-22  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-inline.c (remap_type_1): Correctly chain variants.
+
+2007-09-22  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33146
+       * fold-const.c (fold_binary): Use the original tree for negating.
+       * tree.h (STRIP_SIGN_NOPS): Converting from or to pointer
+       also changes "sign".
+
+2007-09-22  Eric Botcazou  <ebotcazou@adacore.com>
+
+       PR target/32325
+       * except.c (finish_eh_generation): Call commit_edge_insertions if
+       there are insns queued on the entry edge.
+       * config/alpha/alpha.c (alpha_gp_save_rtx): Insert the insns on
+       the entry edge.
+
+2007-09-22  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * doc/sourcebuild.texi (dg-add-c99-runtime-options): Document.
+
+2007-09-19  Michael Meissner  <michael.meissner@amd.com>
+
+       * config/i386/i386.c: Delete trailing whitespace.
+       * config/i386/i386.h: Ditto.
+       * config/i386/bmmintrin.h: Ditto.
+       * config/i386/sync.md: Ditto.
+       * config/i386/ppro.md: Ditto.
+       * config/i386/mmx.md: Ditto.
+       * config/i386/constraints.md: Ditto.
+       * config/i386/sse.md: Ditto.
+       * config/i386/athlon.md: Ditto.
+       * config/i386/i386.md: Ditto.
+
+2007-09-21  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33508
+       * tree-ssa-alias.c (mark_aliases_call_clobbered): Avoid
+       quadratic loop by keeping a bitmap of variables we have
+       to clobber all subvariables for.
+       (set_initial_properties): Likewise.
+
+2007-09-21  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/t-sde (TARGET_LIBGCC2_CFLAGS): Delete.
+
+2007-09-20  Nigel Stephens  <nigel@mips.com>
+           Chao-ying Fu  <fu@mips.com>
+
+       * c-decl.c (finish_declspecs): When _Sat is used without
+       _Fract or _Accum, set the default type to cts_fract.
+       This avoids a warning of "type defaults to int".
+
+2007-09-20  Joseph Myers  <joseph@codesourcery.com>
+
+       * c-decl.c (check_bitfield_type_and_width): Don't allow _Bool
+       bit-fields wider than one bit.
+
+2007-09-20  Jakub Jelinek  <jakub@redhat.com>
+
+       PR debug/33316
+       * dwarf2out.c (modified_type_die): Handle TYPE_DECL with NULL
+       DECL_NAME.
+       * dbxout.c (dbxout_type): Likewise.
+
+       PR c/33238
+       PR c/27301
+       * gimplify.c (gimplify_vla_decl): New function.
+       (gimplify_decl_expr): Move VLA decl handling to gimplify_vla_decl.
+       Call it.
+       (gimplify_target_expr): Handle variable length TARGET_EXPRs.
+
+2007-09-20  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * doc/invoke.texi (-minterlink-mips16): Document.
+       * config/mips/mips.opt (minterlink-mips16): New option.
+       * config/mips/mips.c (mips_function_ok_for_sibcall): Handle
+       -minterlink-mips16
+
+2007-09-20  Joseph Myers  <joseph@codesourcery.com>
+
+       * doc/extend.texi (Attribute Syntax): Remove old speculative
+       future direction.
+
+2007-09-20  Mark Shinwell  <shinwell@codesourcery.com>
+
+       * combine.c: Include cgraph.h.
+       (setup_incoming_promotions): Rework to allow more aggressive
+       elimination of sign extensions when all call sites of the
+       current function are known to lie within the current unit.
+
+2007-09-20  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * dse.c (find_shift_sequence): No-op rework of control flow.
+
+2007-09-19  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (build_mips16_call_stub): Tidy.  Fix second
+       GPR for DCmode on 64-bit targets.  Remove redundant fallback.
+
+2007-09-19  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * cfgexpand.c (dump_stack_var_partition): Use the correct
+       index for the offset.
+
+2007-09-19  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/mips/sde.h: Switch to GPLv3.
+
+2007-09-19  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-sra.c (decide_block_copy): Decide if there are groups.
+
+2007-09-19  Roman Zippel <zippel@linux-m68k.org>
+
+       * config/m68k/m68k.c (output_move_himode): Remove jump table
+       recognition.
+       config/m68k/m68k.md (lea): Likewise.
+       * config/m68k/m68k.c (print_operand_address): Use simple pc
+       relative addressing.
+
+2007-09-19  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * doc/tm.texi (IS_ASM_LOGICAL_LINE_SEPARATOR): Document new argument.
+       * final.c (IS_ASM_LOGICAL_LINE_SEPARATOR): Provide two-argument
+       default definition.
+       (asm_insn_count): Pass template as second argument to it.
+       * config/avr/avr.h (IS_ASM_LOGICAL_LINE_SEPARATOR): Likewise.
+       * config/pa/pa.h (IS_ASM_LOGICAL_LINE_SEPARATOR): Likewise.
+       * config/stormy16/stormy16.h (IS_ASM_LOGICAL_LINE_SEPARATOR): Likewise.
+       * config/cris/cris.h (IS_ASM_LOGICAL_LINE_SEPARATOR): Likewise.
+       * config/sh/sh.c (IS_ASM_LOGICAL_LINE_SEPARATOR): Likewise.
+       (sh_insn_length_adjustment): Pass template as second argument to it.
+       * config/bfin/bfin.h (IS_ASM_LOGICAL_LINE_SEPARATOR): New macro.
+
+       * config/bfin/bfin.md (define_asm_attributes): New.
+
+2007-09-19  Jie Zhang  <jie.zhang@analog.com>
+
+       * config.gcc (bfin*-linux-uclibc*): Add ./linux-sysroot-suffix.h
+       to tm_file.
+       * config/bfin/print-sysroot-suffix.sh: New.
+       * config/bfin/t-bfin-elf (EXTRA_PARTS): Remove.
+       (MULTILIB_OPTIONS, MULTILIB_DIRNAMES, MULTILIB_MATCHES,
+       MULTILIB_EXCEPTIONS): Redefine with new multilibs.
+       * config/bfin/t-bfin-uclinux (EXTRA_PARTS): Remove.
+       (MULTILIB_OPTIONS, MULTILIB_DIRNAMES, MULTILIB_MATCHES,
+       MULTILIB_EXCEPTIONS): Redefine with new multilibs.
+       * config/bfin/t-bfin-linux (EXTRA_PARTS): Remove.
+       (MULTILIB_OPTIONS, MULTILIB_DIRNAMES, MULTILIB_MATCHES,
+       MULTILIB_EXCEPTIONS): Redefine with new multilibs.
+       (linux-sysroot-suffix.h): New target.
+       * config/bfin/bfin.opt (mcsync-anomaly): Use Var instead of Mask.
+       (mspecld-anomaly): Likewise.
+       * config/bfin/bfin-protos.h (enum bfin_cpu_type): Renamed from
+       (enum bfin_cpu): ... this. Add BFIN_CPU_BF522, BFIN_CPU_BF525,
+       BFIN_CPU_BF527, BFIN_CPU_BF538, BFIN_CPU_BF539, BFIN_CPU_BF542,
+       BFIN_CPU_BF544, BFIN_CPU_BF548, and BFIN_CPU_BF549.
+       (bfin_si_revision): Declare.
+       (bfin_workarounds): Declare.
+       (WA_SPECULATIVE_LOADS): Define.
+       (ENABLE_WA_SPECULATIVE_LOADS): Define.
+       (WA_SPECULATIVE_SYNCS): Define.
+       (ENABLE_WA_SPECULATIVE_SYNCS): Define.
+       * config/bfin/elf.h (STARTFILE_SPEC): Rename crt532.o to basiccrt.o.
+       (LIB_SPEC): Add %s to the linker scripts.
+       Use proper linker script for bf522, bf525, bf527,
+       bf538, bf539, bf542, bf544, bf548, and bf549.
+       * config/bfin/bfin.c (bfin_si_revision): Define.
+       (bfin_workarounds): Define.
+       (struct bfin_cpu): New.
+       (bfin_cpus): New.
+       (bfin_handle_option): Handle silicon revision part of -mcpu option.
+       (override_options): Set bfin_workarounds.
+       (length_for_loop): Replace TARGET_CSYNC_ANOMALY with
+       ENABLE_WA_SPECULATIVE_SYNCS, TARGET_SPECLD_ANOMALY with
+       ENABLE_WA_SPECULATIVE_LOADS.
+       (bfin_reorg): Likewise.
+       * config/bfin/bfin.h (TARGET_CPU_CPP_BUILTINS): Define
+       macros for bf522, bf525, bf527, bf538, bf539,
+       bf542, bf544, bf548, and bf549.
+       Define __SILICON_REVISION__ and __WORKAROUND_* macros if needed.
+       Don't define __ID_SHARED_LIB__ when -msep-data.
+       (TARGET_DEFAULT): Define as 0.
+       (DRIVER_SELF_SPECS): Add -mcpu=bf532 if no -mcpu option.
+       * doc/invoke.texi (Blackfin Options): Document silicon
+       revision part of -mcpu option and it now accepts bf522, bf525,
+       bf527, bf538, bf539, bf542, bf544, bf548, and bf549.
+
+2007-09-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * alias.c (memory_modified_1): Deconstify.
+       (memory_modified_in_insn_p): Don't use const_note_stores.
+       * rtl.h (const_note_stores): Delete.
+       * rtlanal.c (const_note_stores): Likewise.
+
+2007-09-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * dse.c (find_shift_sequence): Temporarily revert to forbidding
+       word shifts.
+
+2007-09-18  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/33388
+       PR target/33397
+       * config/fr30/fr30.md (addsi3): Check REG_P() before calling REGNO().
+       (addsi_small_int): Likewise.
+       (addsi_big_int): Use rtx_equal_p() instead of REGNO() comparison.
+       (one_cmplsi2): Likewise.
+       (negsi2): Delete.
+       (enter_func): Expand insn using hard_frame_pointer_rtx and
+       stack_pointer_rtx.
+       (*enter_func): New.
+       * config/fr30/fr30.c (fr30_expand_prologue): Check for
+       hard_frame_pointer_rtx instead of using REGNO() check.
+       Properly sign extend GEN_INT() argument.
+
+2007-09-18  Roman Zippel <zippel@linux-m68k.org>
+
+       * config/m68k/m68k.c (override_options): Remove USE_GAS,
+       use %. syntax.
+       (output_dbcc_and_branch, output_scc_di): Replace all jbcc
+       alternatives with just jcc.
+       * config/m68k/m68k.md (addsi_lshrsi_31, beq0_di, bne0_di,
+       bge0_di, blt0_di, bgtu, bltu, bgeu, bleu, bgtu_rev,
+       bltu_rev, bgeu_rev, bleu_rev, jump, dbne_hi, dbne_si,
+       dbge_hi, dbge_si): Likewise.
+
+2007-09-18  Roman Zippel <zippel@linux-m68k.org>
+
+       * config/m68k/m68k.md (beq, bne, bgt, blt, bge, ble, bordered,
+       bunordered, buneq, bunge, bungt, bunle, bunlt, bltgt, beq_rev,
+       bne_rev, bgt_rev, blt_rev, bge_rev, ble_rev, bordered_rev,
+       bunordered_rev, buneq_rev, bunge_rev, bungt_rev, bunle_rev,
+       bunlt_rev, bltgt_rev): Replace all fbcc with fjcc.
+
+2007-09-18  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * config/m68k/m68k-devices.def (51qe): New device.
+       * config/m68k/m68k.c (FL_FOR_isa_c): Remove division unit.  Add it
+       to all uses of FL_FOR_isa_c for compatibility.
+       (all_microarchs): Add cfv1 microarchitecture.
+       (m68k_handle_option): Handle m51qe option.
+       * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Handle 51QE.
+       (TUNE_CFV1): New macro.
+       (enum uarch_type): Add ucfv1.
+       * doc/invoke.texi: Document 51qe device and cfv1 microarchitecture.
+       
+2007-09-18  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31863
+       * tree-ssa-structalias.c (create_variable_info_for): Always
+       free the fieldstack.
+
+2007-09-18  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * opts.c (decode_options): Enable vectorization under -O3.
+
+2007-09-18  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33340
+       * tree-ssa-sccvn.c (set_ssa_val_to): Do not set values to
+       SSA_NAMEs that occur in abnormal PHI nodes.
+
+2007-09-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * tree-cfg.c (is_ctrl_altering_stmt, tree_block_ends_with_call_p):
+       Don't use const_get_call_expr_in.
+       * tree-gimple.c (const_get_call_expr_in): Delete.
+       * tree-gimple.h (const_get_call_expr_in): Likewise.
+
+2007-09-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * df-scan.c (df_notes_rescan): Do nothing if the instruction does
+       not yet have a basic block.
+       * dse.c (find_shift_sequence): Don't set DF_NO_INSN_RESCAN.
+
+2007-09-18  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_file_start): Add ".previous" directives
+       to both ".section"s.
+
+2007-09-17  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_output_mi_thunk): Use
+       mips_function_ok_for_sibcall and const_call_insn_operand
+       to determine if a direct sibcall is allowed.  Use
+       mips_classify_symbol to determine a global pointer is needed.
+
+2007-09-17  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.md (*clear_upper32): Use "W" as the memory operand.
+
+2007-09-17  Chao-ying Fu  <fu@mips.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/fixed-bit.h: New file.
+       * config/fixed-bit.c: New file.
+       * doc/libgcc.texi (Fixed-point fractional library routines): New node.
+
+2007-09-18  Jakub Jelinek  <jakub@redhat.com>
+
+       * c-format.h (format_kind_info): Add alloc_char field.
+       * c-format.c (scanf_flag_specs): Add 'm'.
+       (scanf_flag_pairs): Add 'a', 'm' pair.
+       (scan_char_table): Allow 'm' modifier for c, s, [, C and S.
+       (format_types_orig): Add alloc_char fields.
+       (check_format_info_main): Rename aflag to alloc_flag.
+       Handle fki->alloc_char. modifier after width and before length
+       modifiers.  Move FMT_FLAG_SCANF_A_KLUDGE handling before
+       length modifiers as well.
+       * config/sol2-c.c (solaris_format_types): Add alloc_char field.
+
+       PR middle-end/33423
+       * builtins.c (expand_builtin_memory_chk): Handle COMPOUND_EXPRs
+       returned by build_call_expr.
+
+2007-09-17  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-sra.c (maybe_lookup_element_for_expr) <COMPONENT_REF>: Return
+       NULL for variable-sized records too.
+       (sra_walk_expr) <COMPONENT_REF>: Stop at variable-sized records too.
+
+2007-09-17  Tom Tromey  <tromey@redhat.com>
+
+       * c-decl.c (pushdecl): Don't set DECL_LANG_SPECIFIC.
+       (c_builtin_function): Likewise.
+       (grokdeclarator): Likewise.
+
+2007-09-17  Zdenek Dvorak  <ook@ucw.cz>
+
+       PR rtl-optimization/26449
+       * loop-invariant.c (move_invariant_reg): Do not use force_operand.
+       (seq_insns_valid_p): Removed.
+
+2007-09-17  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-nomudflap.c (gate_mudflap): New static function.
+       (pass_mudflap_1): Use it as gate function.
+       (pass_mudflap_2): Likewise.
+
+2007-09-17  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/33348
+       PR target/33406
+       * loop-invariant.c (move_invariant_reg): Unshare sequence.
+
+2007-09-17  Victor Kaplansky  <victork@il.ibm.com>
+
+       PR tree-optimization/33319
+       * tree-vect-analyze.c (vect_same_range_drs): New.
+       (vect_vfa_range_equal): New.
+       (vect_is_duplicate_ddr): Removed.
+       (vect_mark_for_runtime_alias_test): Do not perform marking when
+       optimizing for size or max_param for alias checking is zero.
+       Move the function before vect_analyze_data_ref_dependence.
+       (vect_analyze_data_ref_dependence): Add call to
+       vect_mark_for_runtime_alias_test in two cases when dependence
+       is not clear.
+       (vect_analyze_data_ref_dependences): Do not call to
+       vect_mark_for_runtime_alias_test.
+       (vect_prune_runtime_alias_test_list): New.
+       (vect_analyze_loop): Add call to vect_prune_runtime_alias_test_list.
+       * tree-vect-transform.c (vect_estimate_min_profitable_iters):
+       Update vec_outside_cost.
+       (vect_vfa_segment_size): More compact code, use TYPE_SIZE_UNIT.
+       (vect_create_cond_for_alias_checks): Build the base address of data
+       reference from DR_GROUP_FIRST_DR.
+       (vect_loop_versioning): New.
+       (vect_transform_loop): Add a call to vect_loop_versioning.
+       Remove factored out code.
+
+2007-09-16  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR middle-end/33273
+       * expr.c (store_expr): Call adjust_address to change mode of dest_mem
+       to BLKmode.
+
+2007-09-16  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * dse.c (find_shift_sequence): Allow word as well as subword shifts.
+       Do the tentative shift expansion with the DF_NO_INSN_RESCAN flag set.
+       Fix the call to insn_rtx_cost.  Skip access sizes that require a
+       real truncation of the store register.  Use convert_move instead
+       of gen_lowpart when narrowing the result.
+       (replace_read): Use convert_move instead of gen_lowpart when
+       narrowing the store rhs.
+
+2007-09-16  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.md (SHORT): Fix long line.
+       (SUBDI): New mode iterator.  Extend the shift-and-truncate insns
+       to QImode and HImode.
+
+2007-09-16  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.h (POINTERS_EXTEND_UNSIGNED): Define.
+
+2007-09-15  Zdenek Dvorak  <ook@ucw.cz>
+
+       * tree-parloops.c: New file.
+       * tree-ssa-operands.h (free_stmt_operands): Declare.
+       * tree-ssa-loop-manip.c (split_loop_exit_edge): Return the new basic
+       block.
+       * tree-pass.h (pass_parallelize_loops): Declare.
+       * omp-low.c (expand_omp_parallel, expand_omp_for): Update SSA form for
+       virtual operands.
+       (build_omp_regions_1): Allow analysing just a single OMP region and
+       its subregions.
+       ( build_omp_regions_root, omp_expand_local): New functions.
+       (build_omp_regions): Add argument to build_omp_regions_1 call.
+       * builtins.def (DEF_GOMP_BUILTIN): Initialize OMP builtins when
+       autoparallelization is run.
+       * timevar.def (TV_TREE_PARALLELIZE_LOOPS): New.
+       * tree-ssa-loop.c (gate_tree_parallelize_loops, tree_parallelize_loops,
+       pass_parallelize_loops): New.
+       * common.opt (ftree-parallelize-loops): New.
+       * tree-flow.h (omp_expand_local, tree_duplicate_sese_tail,
+       parallelize_loops): Declare.
+       (add_phi_args_after_copy, split_loop_exit_edge): Declaration changed.
+       * Makefile.in (tree-parloops.o): Added.
+       * tree-cfg.c (add_phi_args_after_copy_edge, tree_duplicate_sese_tail):
+       New functions.
+       (add_phi_args_after_copy_bb): Use add_phi_args_after_copy_edge.
+       (add_phi_args_after_copy): Call add_phi_args_after_copy_edge for
+       one extra edge as well.
+       (tree_duplicate_sese_region): Add argument to add_phi_args_after_copy.
+       Use VEC_free to free doms vector.
+       (move_block_to_fn): Update loop info. Remove phi nodes for virtual
+       operands.  Recompute operand caches in the new function.
+       (move_sese_region_to_fn): Update loop info.
+       * passes.c (init_optimization_passes): Add pass_parallelize_loops.
+       * tree-ssa-operands.c (free_stmt_operands): New function.
+
+       * doc/passes.texi: Document autoparallelization.
+       * doc/invoke.texi (-ftree-parallelize-loops): New option.
+
+2007-09-15  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR target/33062
+       * pa.c (function_value): Use GET_MODE_BITSIZE instead of
+       TYPE_PRECISION.
+
+2007-09-15  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vect-transform.c (vect_get_vec_defs_for_stmt_copy): check if 
+       the VEC is not NULL.
+       (vectorizable_type_demotion, vectorizable_type_promotion): Check that 
+       get_vectype_for_scalar_type succeeded.
+       (vectorizable_conversion): Likewise.
+
+2007-09-14  Jan Hubicka  <jh@suse.cz>
+
+       * config/i386/i386.md (*floatdi<mode>2_i387): Guard against
+       TARGET_64BIT.
+
+2007-09-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/33438
+       * config/i386/i386.md (fmodxf3): Copy operands[2] to temporary
+       register when operands[2] equals operands[1].
+       (remainderxf3): Ditto.
+
+2007-09-14  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * doc/tm.texi (LIBGCC2_UNWIND_ATTRIBUTE): Document.
+       * unwind-generic.h (LIBGCC2_UNWIND_ATTRIBUTE): Define.
+       (_Unwind_RaiseException): Add LIBGCC2_UNWIND_ATTRIBUTE to declaration.
+       (_Unwind_ForcedUnwind): Likewise.
+       (_Unwind_Resume): Likewise.
+       (_Unwind_Resume_or_Rethrow): Likewise.
+       (_Unwind_Backtrace): Likewise.
+       (_Unwind_SjLj_RaiseException): Likewise.
+       (_Unwind_SjLj_ForcedUnwind): Likewise.
+       (_Unwind_SjLj_Resume): Likewise.
+       (_Unwind_SjLj_Resume_or_Rethrow): Likewise.
+       * unwind.inc (_Unwind_RaiseException): Add LIBGCC2_UNWIND_ATTRIBUTE
+       to definition.
+       (_Unwind_ForcedUnwind): Likewise.
+       (_Unwind_Resume): Likewise.
+       (_Unwind_Resume_or_Rethrow): Likewise.
+       (_Unwind_Backtrace): Likewise.
+       * unwind-compat.c (_Unwind_Backtrace): Likewise.
+       (_Unwind_ForcedUnwind): Likewise.
+       (_Unwind_RaiseException): Likewise.
+       (_Unwind_Resume): Likewise.
+       (_Unwind_Resume_or_Rethrow): Likewise.
+
+       * config/mips/mips.h (LIBGCC2_UNWIND_ATTRIBUTE): Define to force
+       nomips16 mode when IN_LIBGCC2 with hard float.
+
+2007-09-14  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/sdemtk.opt: Update to GPLv3.
+       * config/mips/sdemtk.h: Likewise.
+
+2007-09-14  Nigel Stephens  <nigel@mips.com>
+
+       * config.gcc (mips*-*-linux*): Recognise mipsisa32r2 and set
+       MIPS_ISA_DEFAULT appropriately.  Don't make soft-float the default
+       for mipsisa32-*-linux*.
+
+2007-09-14  Nigel Stephens  <nigel@mips.com>
+           David Ung  <davidu@mips.com>
+           Thiemo Seufer  <ths@mips.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (mips*-sde-elf*): Add support for the SDE C libraries.
+       * configure.ac: Add a mipssde threading type.
+       * configure: Regenerate.
+       * config/mips/sdemtk.h: New file.
+       * config/mips/t-sdemtk: Likewise.
+       * config/mips/sdemtk.opt: Likewise.
+       * gthr-mipssde.h: Likewise.
+       * config/mips/sde.h (FUNCTION_PROFILER): Move to config/mips/sdemtk.h.
+       * config/mips/mips.h (MIPS_SAVE_REG_FOR_PROFILING_P): New macro.
+       (MIPS_ICACHE_SYNC): New macro, split from ...
+       * config/mips/mips.md (clear_cache): ...here.
+       * config/mips/mips.c (mips_save_reg_p): Check
+       MIPS_SAVE_REG_FOR_PROFILING_P on profiled functions.
+       (build_mips16_function_stub): Use targetm.strip_name_encoding.
+       (build_mips16_call_stub): Likewise.
+
+2007-09-14  Richard Sandiford  <richard@codesourcery.com>
+
+       * Makefile.in (stmp-int-hdrs): Depend on fixinc_list.
+
+2007-09-14  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/32337
+       * config/ia64/ia64.c (find_gr_spill): Don't decrement
+       current_frame_info.n_local_regs.  Don't return emitted local regs.
+       (ia64_compute_frame_size): Improve unwind hack to put
+       RP, PFS, FP in that order by allowing some of the registers
+       been already emitted, as long as they are emitted to the
+       desired register.
+
+2007-09-14  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
+
+       * config/spu/vmx2spu.h (vec_extract, vec_insert, vec_lvlx,
+       vec_lvlxl, vec_lvrx, vec_lvrxl, vec_promote, vec_splats,
+       vec_stvlx, vec_stvlxl, vec_stvrx, vec_stvrxl): New intrinsics.
+
+2007-09-13  Eric Christopher  <echristo@apple.com>
+           Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * dse.c (find_shift_sequence): New function.
+       (replace_read): Add case to remove read if it requires shift.
+       * config/i386/i386.c (ix86_expand_prologue): Fixed typo in comment.
+       
+2007-09-13  Tom Tromey  <tromey@redhat.com>
+
+       * c-common.c (fname_as_string): Update.
+       * c-parser.c (c_parser) <lex_untranslated_string>: New field.
+       (c_lex_one_token): Update.  Add 'parser' argument.
+       (c_parser_simple_asm_expr): Update.
+       (c_parser_attributes): Update.
+       (c_parser_asm_statement): Update.
+       (c_parser_asm_operands): Update.
+       (c_parser_peek_token): Update.
+       (c_parser_peek_2nd_token): Update.
+       * c-lex.c (c_lex_string_translate): Remove.
+       (c_lex_return_raw_strings): Likewise.
+       (c_lex_with_flags): Added 'lex_flags' argument.
+       (lex_string): Added 'translate' argument.
+       * c-pragma.h (c_lex_with_flags): Update.
+       (c_lex_string_translate, c_lex_return_raw_strings): Remove.
+       (C_LEX_STRING_NO_TRANSLATE): New define.
+       (C_LEX_RAW_STRINGS): Likewise.
+
+2007-09-13  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       From Jie Zhang:
+       * config/bfin/bfin.c (enum bfin_builtins): Add BFIN_BUILTIN_ONES,
+       BFIN_BUILTIN_CPLX_MUL_16_S40, BFIN_BUILTIN_CPLX_MAC_16_S40,
+       BFIN_BUILTIN_CPLX_MSU_16_S40, and BFIN_BUILTIN_CPLX_SQU.
+       (bfin_init_builtins): Initialize __builtin_bfin_ones,
+       __builtin_bfin_min_fr1x16, __builtin_bfin_max_fr1x16,
+       __builtin_bfin_min_fr1x32, __builtin_bfin_max_fr1x32,
+       __builtin_bfin_cmplx_add, __builtin_bfin_cmplx_sub,
+       __builtin_bfin_cmplx_mul_s40, __builtin_bfin_cmplx_mac_s40,
+       __builtin_bfin_cmplx_msu_s40 and __builtin_bfin_csqu_fr16.
+       (bdesc_1arg): Add __builtin_bfin_ones.
+       (bfin_expand_builtin): Expand __builtin_bfin_cmplx_mul_s40,
+       __builtin_bfin_cmplx_mac_s40, __builtin_bfin_cmplx_msu_s40,
+       and __builtin_bfin_csqu_fr16.
+       * config/bfin/bfin.md (UNSPEC_ONES): New constant.
+       (ones): New define_insn.
+       (ssaddhi3_parts): New define_insn.
+       (sssubhi3_parts): New define_insn.
+       (flag_mulhi_parts): New define_insn.
+
+2007-09-13  Seongbae Park <seongbae.park@gmail.com>
+
+       * common.opt (femit-class-debug-always): Turn off by default.
+
+2007-09-13  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.md (reload_outpdi, reload_inpdi): New patterns.
+       * config/bfin/bfin.c (bfin_secondary_reload): Make sure we use them.
+
+2007-09-13  James E. Wilson  <wilson@specifix.com>
+
+       PR tree-optimization/33389
+       * tree-ssa-operands.c (append_vuse): If ann->in_vdef_list true,
+       then set build_loads before returning.
+
+2007-09-13  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+
+       * config/mips/mips.h (ASM_OUTPUT_REG_PUSH): Replace {d}subu with
+       {d}addiu and a negative immediate such that it works with MIPS16
+       instructions.
+       
+2007-09-13  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR bootstrap/33418
+       * configure.ac (ld_vers): Support Linux linker.
+       * configure: Regenerated.
+
+2007-09-13  Richard Sandiford  <richard@codesourcery.com>
+           Sandra Loosemore <sandra@codesourcery.com>
+
+       * config/mips/mips.h (SYMBOL_FLAG_MIPS16_FUNC): Delete.
+       (SYMBOL_REF_MIPS16_FUNC_P): Delete.
+       * config/mips/mips.c (mips_attribute_table): Turn mips16 and
+       nomips16 into decl attributes.
+       (TARGET_INSERT_ATTRIBUTES): Override.
+       (TARGET_MERGE_DECL_ATTRIBUTES): Likewise.
+       (TARGET_FUNCTION_ATTRIBUTE_INLINABLE_P): Always return true.
+       (mips_mips16_type_p, mips_nomips16_type_p): Delete in favor of...
+       (mips_mips16_decl_p, mips_nomips16_decl_p): ...these new functions.
+       (mips_comp_type_attributes): Remove mips16 and nomips16 handling.
+       (mips_use_mips16_mode_p): Reimplement as a function that takes
+       a decl and considers only decl attributes.  If the decl is nested
+       function, use its parent attributes.
+       (mips_function_ok_for_sibcall): Use mips_use_mips16_mode_p
+       instead of SYMBOL_REF_MIPS16_FUNC_P.
+       (mips_set_mips16_mode): Move call to sorry here from old
+       mips_use_mips16_mode_p.
+       (mflip_mips16_entry): New structure.
+       (mflip_mips16_htab): New variable.
+       (mflip_mips16_htab_hash, mflip_mips16_htab_eq): New functions.
+       (mflip_mips16_use_mips16_p, mips_insert_attributes): Likewise.
+       (mips_merge_decl_attributes): New function.
+       (mips_set_current_function): Reinstate call to mips_set_mips16_mode.
+       Use mips_use_mips16_mode_p.
+       (mips_output_mi_thunk): Use mips_use_mips16_mode_p instead of
+       SYMBOL_REF_MIPS16_FUNC_P.
+       (mips_encode_section_info): Don't set SYMBOL_FLAG_MIPS16_FUNC.
+
+2007-09-13  Richard Sandiford  <richard@codesourcery.com>
+
+       * c-parser.c (c_parser_struct_declaration): Check for a null return.
+
+2007-09-13  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
+
+       PR driver/33309
+       * gcc.c (xputenv): Make argument const, and use CONST_CAST.
+
+2007-09-12  Michael Meissner  <michael.meissner@amd.com>
+           Dwarakanath Rajagopal  <dwarak.rajagopal@amd.com>
+           Tony Linthicum  <tony.linthicum@amd.com>
+
+       * tree.h (function_args_iterator): New type to iterate over
+       function arguments.
+       (FOREACH_FUNCTION_ARGS_PTR): Iterator macros for iterating over
+       function arguments providing a pointer to the argument.
+       (FOREACH_FUNCTION_ARGS): Iterator macros for iterating over
+       function arguments providing the argument.
+       (function_args_iter_init): Inline function to initialize
+       function_args_iterator.
+       (function_args_iter_cond_ptr): Inline function to return the next
+       pointer to hold the argument.
+       (function_args_iter_cond): Inline function to return the next
+       argument.
+       (function_args_iter_cond_next): Advance the function args iterator.
+       (stdarg_p): New function, return true if variable argument function.
+       (prototype_p): New function, return true if function is prototyped.
+       (function_args_count): New function, count the number of arguments
+       of a function.
+
+       * tree.c (stdarg_p): New function, return true if variable
+       argument function.
+       (prototype_p): New function, return true if function is prototyped.
+
+       * 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 (m_AMD_MULTIPLE): Rename from
+       m_ATHLON_K8_AMDFAM10, and change all uses.
+       (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.
+       (bdesc_ptest): Change OPTION_MASK_ISA_SSE4_1 to
+       OPTION_MASK_ISA_ROUND for instructions that are shared between
+       SSE4.1 and SSE5.
+       (bdesc_2arg): Ditto.
+       (bdesc_sse_3arg): 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 (const_0_to_31_operand): New predicate
+       to match 0..31.
+       (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.
+
+2007-09-12  Janis Johnson  <janis187@us.ibm.com>
+
+       * config/dfp-bit.c (dfp_conversion_exception): New function.
+       (DFP_TO_DFP) Add new variants to use direct conversions in decNumber.
+       (DFP_TO_INT): Ditto.
+       (INT_TO_DFP): Ditto.
+       * config/dfp-bit.h (DEC_FLOAT_FROM_INT, DEC_FLOAT_TO_INT): New.
+
+2007-09-12  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/32338
+       * config/ia64/ia64.c (ia64_expand_epilogue): Emit blockage
+       before sp restoration even when total_size is 0, but
+       frame_pointer_needed.
+
+2007-09-12  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (machine_function): Add vararg_a7_copy.
+       (xtensa_copy_incoming_a7): Use start_sequence instead of
+       push_to_sequence.  Stash insns in vararg_a7_copy for builtin_saveregs.
+       (xtensa_builtin_saveregs): Place code from vararg_a7_copy at the start
+       of the saveregs sequence.
+
+2007-09-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * c-tree.h (grokfield): Add a "tree *" argument.
+       * c-decl.c (grokdeclarator): Take a pointer to the decl's attributes.
+       Chain nested decl attributes to it.  Don't call decl_attributes here.
+       (groktypename): Pass grokdeclarator a pointer to the attribute list.
+       (start_decl, grokparm, push_parm_decl, start_function): Likewise.
+       (grokfield): Take a pointer to the decl's attributes and pass
+       it to grokdeclarator.
+       * c-parser.c (c_parser_struct_declaration): Update the calls to
+       grokfield.  Call decl_attributes for anonymous struct and union
+       fields.
+
+2007-09-12  Jan Hubicka  <jh@suse.cz>
+
+       * c-objc-common.h (LANG_HOOKS_CALLGRAPH_EXPAND_FUNCTION): Kill.
+
+2007-09-12  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/32377
+       * tree-vect-analyze.c (vect_analyze_data_ref_dependence): Distinguish
+       between positive and negative dependence distance using DDR_REVERSED_P.
+
+2007-09-12  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/33373
+       * tree-vect-analyze (vect_determine_vectorization_factor): Call 
+       TREE_INT_CST_LOW when comparing TYPE_SIZE_UNIT. 
+
+2007-09-12  Jan Hubicka  <jh@suse.cz>
+
+       PR target/33393
+       * config/i386/i386.md (floatsisf2_mixed_memory, floatsisf2_sse_memory):
+       Disable for !SSE_MATH
+
+2007-09-12  Christian Bruel  <christian.bruel@st.com>
+
+       * sh.h (SH_DBX_REGISTER_NUMBER): Added fpscr, fixed sr/gbr regs.
+       * linux-unwind.h (SH_DWARF_FRAME_GBR): fixed. 
+       
+2007-09-12  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-vect-transform.c (vect_get_slp_defs): Don't build a vector
+       for oprnd1 if not required.
+       (vectorizable_operation): Use scalar operand in SLP in case of 
+       shift with scalar argument.
+
+2007-09-12  Ira Rosen  <irar@il.ibm.com>
+
+       * params.def (PARAM_MIN_VECT_LOOP_BOUND): Change default and
+       minimum to 1.
+
+2007-09-11  James E. Wilson  <wilson@specifix.com>
+
+       * defaults.h (DWARF2_UNWIND_INFO): Don't define if
+       TARGET_UNWIND_INFO is defined.
+       * config/ia64/ia64.h (INCOMING_RETURN_ADDR_RTX): Delete undef
+       after definition.
+
+2007-09-12  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.c (calc_live_regs): Use
+       current_function_saves_all_registers instead of
+       current_function_has_nonlocal_label.
+       (sh_allocate_initial_value): Likewise.
+       (sh_get_pr_initial_val): Likewise.
+       * config/sh/sh.h (SHMEDIA_REGS_STACK_ADJUST): Likewise.
+       * config/sh/sh.md (load_ra): Likewise.
+
+2007-09-12  Hans-Peter Nilsson  <hp@axis.com>
+
+       * config/cris/t-linux (LIMITS_H_TEST): Only define if not inhibit_libc.
+
+       PR target/33360
+       * config/cris/cris.c (cris_expand_pic_call_address): Fix typo in
+       GET_CODE (x) == CONST_INT to CONST_INT_P (x) transformation.
+
+2007-09-12  Sa Liu  <saliu@de.ibm.com>
+
+       * config/spu/spu.c (spu_emit_branch_or_set): Handle NaN values as
+       operands to DFmode GE or LE compares.
+
+2007-09-12  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.h (enum reg_class, REG_CLASS_CONTENTS,
+       REG_CLASS_NAMES): Add P0REGS.
+       (REGNO_REG_CLASS): Return it where appropriate.
+       (REG_CLASS_FROM_CONSTRAINT): Add 'qA'.
+       (CLASS_LIKELY_SPILLED_P): P0REGS is likely_spilled.
+       * doc/md.texi (Blackfin family): Document 'q' constraints.
+
+2007-09-11  Steve Kenton  <skenton@ou.edu>
+
+       * pa/linux-unwind.h: Guard with inhibit_libc.
+       * pa/hpux-unwind.h: Likewise.
+
+2007-09-11  David Daney  <ddaney@avtrex.com>
+
+       * doc/invoke.texi: Document new MIPS -mllsc and -mno-llsc options.
+       * doc/install.texi: Document new --with-llsc and --without-llsc
+       options.
+       * config.gcc: Handle --with-llsc and --without-llsc configure options.
+       * config/mips/mips.md (sync, memory_barrier): Wrap sync instrunction
+       in %| and %- operand codes.  Depend on GENERATE_SYNC instead of
+       ISA_HAS_SYNC.
+       (sync_compare_and_swap<mode>, sync_add<mode>, 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>): Depend on
+       GENERATE_LL_SC instead of ISA_HAS_LL_SC.
+       * config/mips/mips.opt (mllsc): New option.
+       * config/mips/mips.c (mips_llsc): Define variable.
+       (mips_handle_option): Handle mllsc option.
+       (override_options): Set mips_print_operand_punct for '|' and '-'.
+       (print_operand): Add new %| and %- operand codes.
+       * config/mips/mips.h (mips_llsc_setting): New enum type.
+       (mips_llsc): Declare.
+       (OPTION_DEFAULT_SPECS): Add llsc handling.
+       (GENERATE_SYNC): New macro.
+       (GENERATE_LL_SC): New macro.
+       (MIPS_COMPARE_AND_SWAP, MIPS_SYNC_OP, MIPS_SYNC_OLD_OP,
+       MIPS_SYNC_NEW_OP, MIPS_SYNC_NAND, MIPS_SYNC_OLD_NAND,
+       MIPS_SYNC_NEW_NAND, MIPS_SYNC_EXCHANGE): Wrap instructions
+       in %| and %- operand codes.
+
+2007-09-11  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-ssa-structalias.c (push_fields_onto_fieldstack): Deal with
+       TYPE_NONALIASED_COMPONENT like with DECL_NONADDRESSABLE_P.
+
+2007-09-11  Jason Merrill  <jason@redhat.com>
+
+       PR middle-end/27945
+       * stor-layout.c (layout_decl): Do pack variable size fields.    
+
+2007-09-11  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * config/m68k/predicates.md (movsi_const0_operand,
+       non_symbolic_call_operand): New predicates.
+
+       * config/m68k/constraints.md (Cs, Ci, C0, Cj, CQ, CW, CZ, CS, Ap, Ac):
+       New constraints.
+       * doc/md.texi (Constraints for Particular Machines: Motorola 680x0):
+       Document constraints N, O, P, R, S, T, Q, U, W, Cs, Ci, C0, Cj, CQ,
+       CW, CZ, CS, Ap and Ac.
+
+       * config/m68k/m68k.md (UNSPEC_IB): New constant.
+       (constraints.md): New include.
+       (cpu, type, type1, opx, opy, opx_type, opy_type, size, opx_access,
+       opx_mem, opy_mem, op_mem, guess, split): New attributes.
+       (movdf_internal): Name pattern.  Fix to use alternatives.  Add split.
+       Specify attributes.
+       (pushdi): Add split.
+       (tstsi_internal): Name pattern.  Fix to use alternatives.  Specify
+       attributes.  Split tstsi_internal_68020_cf from it.
+       (tstsi_internal_68020_cf): New pattern.
+       (tsthi_internal, tstqi_internal): Name pattern.  Specify attributes.
+       (tst<mode>_cf): Specify attributea.
+       (cmpsi_cf): Name pattern.  Specify attributes.
+       (cmp<mode>_68881, cmp<mode>_cf): Specify type attribute.
+       (pushexthisi_const): Fix to use alternatives.  Specify
+       attributes.
+       (movsi_const0): Split movsi_const0_68000_10 and movsi_const0_68040_60
+       from it.  Fix to use alternatives.  Specify attributes.
+       (movsi_const0_68040_10, movsi_const0_68040_60): New patterns.
+       (movsi_cf, movstrictqi_cf): Fix to use alternatives.  Specify
+       attributes.
+       (movsf_cf_soft): Specify attributes.
+       (movdf_cf_soft): Add split.
+       (pushasi, zero_extendhisi2_cf, zero_extendqisi2_cfv4,
+       cfv4_extendhisi2, 68k_extendhisi2, extendqihi2, cfv4_extendqisi2,
+       68k_extendqisi2, truncdfsf2_cf): Specify attributes.
+       (truncdfsf2_68881): Name pattern.  Specify attributes.
+       (floatsi<mode>2_cf, floathi<mode>2_68881, floathi<mode>2_cf,
+       floatqi<mode>2_68881, floatqi<mode>2_cf, ftrunc<mode>2_cf,
+       fix<mode>qi2_cf, fix<mode>hi2_cf, fix<mode>si2_cf, adddi_dishl32):
+       Specify attributes.
+       (addsi3_5200): Fix to use alternatives.  Specify attributes.
+       Add splits.
+       (add<mode>3_cf, subdi_dishl32): Specify attributes.
+       (subsi3): Add alternative for subq.l.  Specify attributes.
+       (sub<mode>3_cf, mulhi3, mulhisi3): Specify attributes.
+       (mulhisisi3_s, mulsi3_68020, mulsi3_cf): Name pattern.  Specify
+       attributes.
+       (umulhisi3): Specify attributes.
+       (mulhisisi3_z): Name pattern.  Specify attributes.
+       (fmul<mode>3_cf, div<mode>3_cf, negsi2_internal, negsi2_5200,
+       sqrt<mode>2_68881, clzsi2, one_cmplsi2_5200, subreghi1ashrdi_const32,
+       subregsi1ashrdi_const32, ashrsi3, subreg1lshrdi_const32, lshrsi3,
+       bsetmemqi): Specify attributes.
+       (bsetmemqi_ext): Name pattern.  Specify attributes.
+       (bclrmemqi): Specify attributes.
+       (bclrmemqi_ext, scc, sls): Name pattern.  Specify attributes.
+       (beq, bne, bgt, bgtu, blt, bltu, bge, bgeu, ble, bleu): Specify
+       attributes.
+       (beq2, bne2, bgt2, bgtu2, blt2, bltu2, bge2, bgeu2, ble2, bleu2): Name
+       pattern.  Specify attributes.
+       (jump): Specify attributes.
+       (tablejump_internal): Name pattern.  Specify attributes.
+       (call_value): Split into non_symbolic_call_value,
+       symbolic_call_value_jsr, symbolic_call_value_bsr.  Fix to use
+       alternatives.  Specify attributes.
+       (non_symbolic_call_value, symbolic_call_value_jsr,
+       symbolic_call_value_bsr): New patterns.
+       (nop, return, unlink, indirect_jump): Specify attributes.
+       (trap): Fix condition.  Specify attributes.
+       (ib): New pattern.
+
+       * config/m68k/m68k.c (m68k_symbolic_call_var): New variable.
+       (override_options): Initialize it.  Initialize m68k_sched_cpu.
+       (CONST_METHOD): Rename to M68K_CONST_METHOD, move to m68k.h.
+       (const_method): Make global, rename to m68k_const_method.
+       (const_int_cost, output_move_const_into_data_reg): Update.
+       (output_move_double): Parametrize to emit rtl code, rename to
+       handle_move_double.
+       (output_reg_adjust, emit_reg_adjust, output_compadr, output_movsi,
+       emit_movsi): New static functions.
+       (output_move_double): New function with semantics of old
+       output_move_double.
+       (m68k_emit_move_double): New function.
+       (m68k_sched_cpu): New variable.
+       (attr_op_type): New enum.
+       (sched_guess_p): New variable.
+       (sched_address_type, sched_operand_type, sched_attr_op_type):
+       New static functions.
+       (m68k_sched_attr_opx_type, m68k_sched_attr_opy_type,
+       m68k_sched_attr_size, m68k_sched_attr_op_mem): New functions.
+       (sched_branch_type): New static variable.
+       (m68k_sched_branch_type): New function.
+       * config/m68k/m68k.h (M68K_SYMBOLIC_CALL): New enum.
+       (m68k_symbolic_call_var): Declare.
+       (M68K_CONST_METHOD): Rename from CONST_METHOD.  Move here from m68k.c.
+       (m68k_const_method, m68k_emit_move_double, m68k_sched_cpu,
+       m68k_sched_attr_opx_type, m68k_sched_attr_opy_type,
+       m68k_sched_attr_size, m68k_sched_attr_op_mem, m68k_sched_branch_type):
+       Declare.
+
+2007-09-11  Jakub Jelinek  <jakub@redhat.com>
+
+       * builtins.def (BUILT_IN_VA_ARG_PACK_LEN): New builtin.
+       * builtins.c (expand_builtin) <case BUILT_IN_VA_ARG_PACK_LEN>: Issue
+       error if __builtin_va_arg_pack_len () wasn't optimized out during
+       inlining.
+       * tree-inline.c (copy_bb): Replace __builtin_va_arg_pack_len ()
+       with the number of inline's anonymous arguments.
+       * doc/extend.texi: Document __builtin_va_arg_pack_len ().
+
+2007-09-11  Zdenek Dvorak  <ook@ucw.cz>
+
+       * fold-const.c (extract_muldiv_1): Do not simplify var * c * c to var.
+
+2007-09-11  Jan Hubicka <jh@suse.cz>
+
+       * config/i386/i386.h (ix86_tune_indices): Add
+       X86_TUNE_INTER_UNIT_CONVERSIONS.
+       (TARGET_INTER_UNIT_CONVERSIONS): New.
+       * config/i386/i386.md (floatsi expanders): Remove redundant check
+       for SImode source; offload to memory when asked for.
+       (floatsisf2_mixed, floatsisf2_sse, floatsidf2_mixed, floatsidf2_sse
+       floatdisf2_mixed, floatsisf2_sse, floatsidf2_mixed, floatsidf2_sse):
+       Update conditions;
+       (floatsisf2_mixed_memory, floatsisf2_sse_memory,
+       floatsidf2_mixed_memory, floatsidf2_sse_memory
+       floatdisf2_mixed_memory, floatsisf2_sse_memory,
+       floatsidf2_mixed_memory, floatsidf2_sse_memory): New.
+
+2007-09-11  Jan Hubicka <jh@suse.cz>
+
+       * toplev.c (process_options): all frontends now do unit-at-a-time.
+       * cgraphunit.c: update comments.
+       (cgraph_expand_function): call passmanager dirrectly; emit thunks.
+       * c-decl.c (finish_function): use cgraph_add_new_function.
+       * function.c (expand_function_end): We are always unit-at-a-time.
+
+2007-09-11  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips_set_mips16_mode): Use separate anchor
+       settings for MIPS16.
+       (mips_use_anchors_for_symbol_p): Use default_use_anchors_for_symbol_p.
+
+2007-09-11  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips_symbol_insns_1): Allow LEAs of
+       SYMBOL_FORCE_TO_MEM constants.
+       (mips_rtx_costs): Give a cost of 1 to force_to_mem_operands.
+       (mips16_rewrite_pool_refs_info): New structure.
+       (mips16_rewrite_pool_constant): New function, split out from...
+       (mips16_rewrite_pool_refs): ...here.  Take a pointer to a
+       mips16_rewrite_pool_refs_info structure rather than a pointer
+       to a constant pool.  Force force_to_mem_operands into memory.
+       (mips16_lay_out_constants): Update call to mips16_rewrite_pool_refs.
+       * config/mips/predicates.md (force_to_mem_operand): New predicate.
+       * config/mips/constraints.md (kf): New constraint.
+       * config/mips/mips.md (*movdi_64bit_mips16): Add a d <- kf alternative.
+       (*movsi_mips16): Likewise.
+
+2007-09-11  Richard Sandiford  <richard@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+           David Ung  <davidu@mips.com>
+
+       * config/mips/mips.h (CONSTANT_POOL_COST): Move to...
+       * config/mips/mips.c: ...here and set to 4 for TARGET_MIPS16.
+       (mips16_constant_cost, mips_immediate_operand_p, mips_binary_cost)
+       (mips_fp_mult_cost, mips_fp_div_cost, mips_sign_extend_cost)
+       (mips_zero_extend_cost): New functions.
+       (mips_rtx_costs): Treat COMPARE constants as having zero cost.
+       Use the new functions.  Tweak many cost estimates, both here
+       and in the new subroutines.  Return false when the cost of the
+       operands has not been calculated.  Check for *clear_upper32.
+       Check for floating-point multiply-add, reciprocal and rsqrt
+       patterns.  Handle comparison and rotation codes.
+
+2007-09-11  Danny Smith  <dannysmith@users.sourceforge.net>
+
+       * config/i386/cygming.h (TARGET_STRIP_NAME_ENCODING): Don't
+       override default.
+       * config/i386/i386.c (get_dllimport_decl): Don't strip
+       FASTCALL_PREFIX.
+
+2007-09-10  Janis Johnson  <janis187@us.ibm.com>
+
+       PR c/30013
+       * config/dfp-bit.c: Don't skip TFmode conversions; move strto*
+       declarations to top.
+       (DFP_TO_BFP): Use for either XFmode or TFmode.
+       (BFP_TO_DFP): Use for either XFmode or TFmode; always use cast
+       of BFP_VIA_TYPE.
+       * config/dfp-bit.h: Include float.h.
+       (LONG_DOUBLE_HAS_XF_MODE, LONG_DOUBLE_HAS_TF_MODE): Define if long
+       double is one of these modes, rather than using LIBGCC_HAS_*F_MODE
+       which doesn't mean the same thing.
+       (BFP_KIND): Use 4 to mean TFmode.
+       (BFP_FMT): Specify the number of decimal digits based on the
+       number of mantissa digits.
+       (BFP_VIA_TYPE): Binary float type to use as cast for sprintf.
+       (BFP_TO_DFP, DFP_TO_BFP): Define names for TFmode variants.
+       (STR_TO_BFP): Use strtold for XFmode or TFmode.
+       (TFtype): Define if TFmode is supported.
+       * doc/libgcc.texi (Decimal float library routines): Document
+       TF conversion functions.
+
+2007-09-10  Chao-ying Fu  <fu@mips.com>
+
+       * config/mips/mips.c (mips_scalar_mode_supported_p): Declare.
+       (TARGET_SCALAR_MODE_SUPPORTED_P): Define.
+       (mips_emit_compare): Process fixed-point modes.
+       (mips_pad_arg_upward): Support fixed-point types.
+       (override_options): Allow fixed-point modes in accumulators.
+       (mips_pass_by_reference): Pass DQ, UDQ, DA, and UDA modes in registers.
+       (mips_vector_mode_supported_p): Support V2HQmode, V2UHQmode, V2HAmode,
+       V2UHAmode, V4QQmode, and V4UQQmode when TARGET_DSP.
+       (mips_scalar_mode_supported_p): New function to accept fixed-point
+       modes if the width is not greater than two BITS_PER_WORD.
+       * config/mips/mips.h (SHORT_FRACT_TYPE_SIZE, FRACT_TYPE_SIZE,
+       LONG_FRACT_TYPE_SIZE, LONG_LONG_FRACT_TYPE_SIZE,
+       SHORT_ACCUM_TYPE_SIZE, ACCUM_TYPE_SIZE, LONG_ACCUM_TYPE_SIZE,
+       LONG_LONG_ACCUM_TYPE_SIZE): Define.
+       * config/mips/mips.md ("d"): Update mode attribute for fixed-point
+       modes.
+       ("IMODE"): New mode attribute.
+       (mips-fixed.md): Include.
+       * config/mips/mips-modes.def: Create VECTOR_MODES for FRACT, UFRACT,
+       ACCUM, UACCUM.
+       * config/mips/mips-fixed.md: New file.
+
+2007-09-11  Ben Elliston  <bje@au.ibm.com>
+
+       * config/spu/spu.md: Formatting fixes.
+
+2007-09-10  Janis Johnson  <janis187@us.ibm.com>
+
+       * config/dfp-bit.c (dfp_unary_func): Delete.
+       (dfp_unary_op): Delete.
+       (dfp_binary_op): Use decFloat functions instead of decNumber
+       functions for binary operations.
+       (d32_binary_op): Convert 32-bit operands to 64 bits for evaluation.
+       (dnn_binary_op): Call dfp_binary_op with decFloat rather than
+       DFP_C_TYPE.
+       (dfp_compare_op): Use decFloat functions insteadof decNumber
+       functions for comparisons.
+       (d32_compare_op): Convert 32-bit operands to 64 bits for evaluation.
+       (dnn_binary_op): Call dfp_compare_op with decFloat rather than
+       DFP_C_TYPE.
+       (DFP_ADD, DFP_SUB, DFP_MULTIPLE, DFP_DIVIDE): Use macros for
+       call to dxx_binary_op and decFloat function.
+       (DFP_EQ, DFP_NE, DFP_LT, DFP_GT, DFP_LE, DFP_GE): Use macros for
+       calls to dxx_binary_op and decFloat function.
+       * config/dfp-bit.h: Include decFloat header files.
+       (decFloat, DFP_BINARY_OP, DFP_COMPARE_OP, DEC_FLOAT_ADD,
+       DEC_FLOAT_SUBTRACT, DEC_FLOAT_MULTIPLY, DEC_FLOAT_DIVIDE,
+       DEC_FLOAT_COMPARE, DEC_FLOAT_IS_ZERO, DEC_FLOAT_IS_NAN,
+       DEC_FLOAT_IS_SIGNED: Define for each of 3 operand widths.
+
+2007-09-10  Harsha Jagasia <harsha.jagasia@amd.com>
+           Jan Sjodin <jan.sjodin@amd.com>
+
+       * tree-vect-analyze.c (vect_analyze_operations): Change
+       comparison of loop iterations with threshold to less than
+       or equal to instead of less than. Reduce
+       min_scalar_loop_bound by one.
+       * tree-vect-transform.c (vect_estimate_min_profitable_iters): 
+       Change prologue and epilogue iterations estimate to vf/2,
+       when unknown at compile-time. Change versioning guard
+       cost to taken_branch_cost. If peeling for alignment is
+       unknown at compile-time, change peel guard costs to one
+       taken branch and one not-taken branch per peeled loop.
+       If peeling for alignment is known but number of scalar loop
+       iterations is unknown at compile-time, change peel guard
+       costs to one taken branch per peeled loop. Change the cost
+       model equation to consider vector iterations as the loop
+       iterations less the prologue and epilogue iterations.
+       Change outside vector cost check to less than or equal to
+       zero instead of equal to zero.
+       (vect_do_peeling_for_loop_bound): Reduce
+       min_scalar_loop_bound by one.
+       * tree-vectorizer.h: Add TARG_COND_TAKEN_BRANCH_COST and
+       TARG_COND_NOT_TAKEN_BRANCH_COST.        
+       * config/i386/i386.h (processor_costs): Add
+       scalar_stmt_cost, scalar_load_cost, scalar_store_cost,
+       vec_stmt_cost, vec_to_scalar_cost, scalar_to_vec_cost,
+       vec_align_load_cost, vect_unalign_load_cost,
+       vec_store_cost, cond_taken_branch_cost,
+       cond_not_taken_branch_cost.
+       Define macros for x86 costs.
+       * config/i386/i386.c:
+       (size_cost): Set scalar_stmt_cost, scalar_load_cost,
+       scalar_store_cost, vec_stmt_cost, vec_to_scalar_cost,
+       scalar_to_vec_cost, vec_align_load_cost, 
+       vect_unalign_load_cost, vec_store_cost,
+       cond_taken_branch_cost, cond_not_taken_branch_cost to one. 
+       (i386_cost, i486_cost, pentium_cost, pentiumpro_cost,
+       geode_cost, k6_cost, athlon_cost, pentium4_cost, nocona_cost, 
+       core2_cost, generic64_cost, generic32_cost): Set to default
+       untuned costs.
+       (k8_cost, amdfam10_cost): Costs for vectorization tuned.
+       (x86_builtin_vectorization_cost): New.
+
+2007-09-10  Janis Johnson  <janis187@us.ibm.com>
+           Ben Elliston  <bje@au.ibm.com>
+
+       * dfp.c: Include decimal128Local.h; 
+       (dfp_byte_swap): Remove.
+       (encode_decimal32, decode_decimal32): Don't handle endianness.
+       (encode_decimal64, decode_decimal64): Ditto.
+       (encode_decimal128, decode_decimal128): Ditto.
+       * config/dfp-bit.c (host_to_ieee32, ieee_to_host_32): Ditto.
+       (__swap64): Remove.
+       (host_to_ieee_64, ieee_to_host_64): Don't handle endianness.
+       (__swap128): Remove
+       (host_to_ieee_128, ieee_to_host_128): Don't handle endianness.
+       * Makefile.in (DECNUM_H): Add decimal128Local.h.
+
+2007-09-10  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/mips.md (UNSPEC_MEMORY_BARRIER): New entry in
+       define_constants.
+       (memory_barrier): Rewrote as an insn that clobbers memory.
+
+2007-09-10  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips_global_pointer): Check
+       call_really_used_regs instead of call_used_regs.
+       (mips_save_reg_p): Likewise.  Save all call-saved registers
+       if current_function_saves_all_registers.  Fix indentation.
+       No longer treat $18 as a special case.
+       (compute_frame_size): Guard FPR loop with TARGET_HARD_FLOAT.
+
+2007-09-10  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.h (MIPS_ARCH_FLOAT_SPEC): New macro.
+       * config/mips/mips.c (mips_cpu_info_table): Mention it in the
+       the introductory comment.
+       (MIPS_MARCH_CONTROLS_SOFT_FLOAT): Delete.
+       (override_options): Don't test for it.
+       * config/mips/sde.h (MIPS_MARCH_CONTROLS_SOFT_FLOAT): Delete.
+       (DRIVER_SELF_SPECS): Add MIPS_ARCH_FLOAT_SPEC.
+       * config/mips/vr.h: As for config/mips/sde.h.
+
+2007-09-10  Trevor Smigiel  <trevor_smigiel@playstation.sony.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * target.h (struct gcc_target.sched): New field: sms_res_mii.
+       (struct ddg): Define.
+       * target-def.h (TARGET_SCHED_SMS_RES_MII): Define.
+       (TARGET_SCHED): Add TARGET_SCHED_SMS_RES_MII.
+       * config/spu/spu.c: Include ddg.h.
+       (TARGET_SCHED_SMS_RES_MII): Define.
+       (spu_sms_res_mii): New function to calculate mii.
+       * modulo-sched (res_MII): Use it.
+       * doc/tm.texi: Document TARGET_SCHED_SMS_RES_MII.
+
+2007-09-10  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.c (s390_dump_pool): Create copy of constant
+       pool entries since they might hold values that must not be shared.
+
+2007-09-10 Robert Kidd <rkidd@crhc.uiuc.edu>
+
+       * bb-reorder.c (rest_of_handler_reorder_blocks): Removed call to
+       RTL level tracer pass.
+       * passes.c (init_optimization_passes): Move pass_tracer from
+       after pass_rtl_ifcvt to after pass_dce.
+       * tracer.c: Update copyright.
+       (layout_superblocks): Remove function.
+       (mark_bb_seen): New.
+       (bb_seen_p): New.
+       (count_insns): Change to estimate instructions in a Tree-SSA
+       statement.
+       (find_trace): Use bb_seen_p.
+       (tail_duplicate): Use bb_seen_p.  Call add_phi_args_after_copy
+       after duplicate_block.
+       (tracer): Change prototype to match that of a pass execute
+       callback.
+       (gate_tracer): Rename from gate_handle_tracer.
+       (rest_of_handle_tracer): Remove function.
+       * rtl.h: Remove prototype for tracer.
+       * testsuite/gcc.dg/tree-prof/tracer-1.c: New.
+
+2007-09-10  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/33369
+       * config/i386/sse.md (ashr<mode>3): Change op2 mode to SImode.
+       Use 'N' operand constraint for op2.
+       (lshr<mode>3): Ditto.
+       (ashl<mode>3): Ditto.
+       (vec_shl_<mode>): Use const_0_to_255_mul_8_operand predicate for op2.
+       (vec_shr_<mode>): Ditto.
+       * config/i386/i386.c (ix86_expand_builtin) [IX86_BUILTIN_PSLL?128,
+       IX86_BUILTIN_PSRA*?128, IX86_BUILTIN_PSRL?128]: Convert op1 to SImode.
+
+2007-09-10  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md ("fixuns_trunc<BFP:mode><GPR:mode>2"):
+       Change mode macro in the last real_2expN parameter to uppercase.
+
+2007-09-10  Michael Matz  <matz@suse.de>
+
+       * tree-pass.h (pass_cselim): Declare new pass.
+       * passes.c (init_optimization_passes): Link in pass_cselim.
+       * tree-ssa-phiopt.c (tree_ssa_phiopt_worker): Renamed from
+       tree_ssa_phiopt; add do_store_elim parameter, handle it by calling
+       cond_store_replacement.
+       (condstoretemp): New static variable.
+       (cond_store_replacement): New function.
+       (tree_ssa_phiopt, tree_ssa_cs_elim): New wrappers around
+       tree_ssa_phiopt_worker.
+       (struct name_to_bb): New.
+       (get_non_trapping, name_to_bb_hash, name_to_bb_eq, add_or_mark_expr,
+       nt_init_block, nt_fini_block): New static functions.
+       (seen_ssa_names, nontrap_set): New static variables.
+       (gate_cselim, pass_cselim): Define new pass.
+       * common.opt (ftree-cselim): New flag.
+       * toplev.c (process_options): Set flag_tree_cselim if required.
+
+2007-09-10  Hans-Peter Nilsson  <hp@axis.com>
+
+       * simplify-rtx.c (simplify_relational_operation_1): For recent
+       canonicalization, don't recurse if op1 equals both PLUS arguments.
+
+2007-09-09  David Daney  <ddaney@avtrex.com>
+
+       * optabs.c (expand_sync_operation):  Use plus insn if minus
+       CONST_INT_P(val).
+       (expand_sync_fetch_operation):  Ditto.
+
+2007-09-09  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.md (*floatsisf2_mixed_vector): Use cvtdq2ps instead
+       of cvtpq2ps.
+       (*floatsisf2_sse_vector): Likewise.
+
+2007-09-09  Krister Walfridsson  <cato@df.lth.se>
+
+       * config/netbsd.h (HANDLE_PRAGMA_PACK_PUSH_POP): Define to 1.
+
+2007-09-09  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.h (ix86_tune_indices): Rename
+       X86_USE_VECTOR_CONVERTS to X86_TUNE_USE_VECTOR_CONVERTS.
+       (TARGET_USE_VECTOR_CONVERTS): Updated.
+       * config/i386/i386.c: Likewise.
+
+2007-09-09  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens <nigel@mips.com>
+
+       * doc/invoke.texi (Overall Options):  Add .sx file extension
+       as a synonym for .S.
+       * cppspec.c (known_suffixes): Likewise.
+       * gcc.c (default_compilers): Likewise.
+
+2007-09-09  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/30315
+       * config/i386/i386.h (CANONICALIZE_COMPARISON): Delete.
+       * simplify-rtx.c (simplify_relational_operation_1): Add the
+       canonicalization from i386.h.
+       * doc/md.texi (Canonicalization of Instructions): Document it.
+
+2007-09-09  Jan Hubicka  <jh@suse.cz>
+           Dwarakanath Rajagopal <dwarak.rajagopal@amd.com>
+
+       * config/i386/i386.h (ix86_tune_indices): Add X86_USE_VECTOR_CONVERTS.
+       (TARGET_USE_VECTOR_CONVERTS): New.
+       * config/i386/i386.md: New post-reload splitters for converting
+       SF to DF and DF to SF.
+       (floatsi* expander): Special case vector conversions.
+       (floatsisf2_mixed_vector, floatsisf2_sse_vector_nointernunit,
+       floatsisf2_sse_vector_internunit, floatsisf2_sse_vector,
+       floatsidf2_mixed_vector, floatsidf2_sse_vector): New.
+       (floatsisf2_mixed, floatsisf2_sse, floatsidf2_mixed, floatsidf2_sse):
+       Disable when doing vector converts.
+       (floatsi<mode>2_i387): Disable when
+       * config/i386/sse.md (vec_dupv2df): Export.
+       * config/i386/i386.c (ix86_tune_features): Enable SSE conversions.
+
+2007-09-09  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-operands.c (add_virtual_operand): Only mark
+       stores as has_volatile_ops if alias information is not available.
+
+2007-09-09  Revital Eres  <eres@il.ibm.com>
+
+       * doc/contrib.texi: Add myself.
+
+2007-09-09  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-vectorizer.h (stmt_vinfo_set_inside_of_loop_cost,
+       stmt_vinfo_set_outside_of_loop_cost): New functions.
+       * tree-vect-transform.c (vect_get_cost_fields): Remove.
+       (vect_model_simple_cost): Call
+       stmt_vinfo_set_inside/outside_of_loop_cost to set the relevant cost
+       field instead of calling vect_get_cost_fields.
+       (vect_model_store_cost, vect_model_load_cost): Likewise.
+
+2007-09-09  Revital Eres  <eres@il.ibm.com>
+
+       * config/rs6000/rs6000.c (paired_init_builtins): Add const
+       declaration to bdesc_paired_preds variable.
+       (paired_expand_builtin): Likewise.
+
+2007-09-09  Revital Eres  <eres@il.ibm.com>
+
+       * dbgcnt.def (sms_sched_loop): New counter.
+       * modulo-sched.c: Use sms_sched_loop instead of
+       MAX_SMS_LOOP_NUMBER to determine the maximum number of loops to
+       perform swing modulo scheduling on.  Include dbgcnt.h.
+       * Makefile.in: Add DBGCNT_H to modulo-sched.o.
+       * params.def: Remove PARAM_MAX_SMS_LOOP_NUMBER.
+
+2007-09-09  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (X87MODEF12, SSEMODEF): Remove mode iterators.
+       Substitute all uses with ...
+       (MODEF): New mode iterator.
+
+       (fix_trunc<mode>_fisttp_i387_1): Remove operand constraints
+       from pre-regalloc define_insn_and_split splitter pattern.
+       (*fix_trunc<mode>_i387_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.
+
+       (prologue): Use (const_int 0) as never generated filler insn.
+       (epilogue): Ditto.
+       (sibcall_epilogue): Ditto.
+       (eh_return_si): Ditto.
+       (eh_return_di): Ditto.
+
+       (add<mode>3): Rename from adddf3 and addsf3.  Macroize expander
+       using MODEF mode iterator.
+       (sub<mode>3): Rename from subdf3 and subsf3.  Macroize expander
+       using MODEF mode iterator.
+       (mul<mode>3): Rename from muldf3 and mulsf3.  Macroize expander
+       using MODEF mode iterator.
+       (nearbyint<mode>2): Rename from nearbyintdf2 and nearbyintsf2.
+       Macroize expander using MODEF mode iterator.
+
+       (zero_extendsidi2): Remove operand constraints from expander.
+       (smuldi3_highpart): Ditto.
+       (indirect_jump): Ditto.
+       (tablejump): Ditto.
+       (rsqrtsf2): Ditto.
+       * config/i386/sse.md (storentv4sf): Ditto.
+       (storentv2df): Ditto.
+       (storentv2di): Ditto.
+       (storentsi): Ditto.
+       (sse2_cvtpd2ps): Ditto.
+       (vec_interleave_highv16qi): Ditto.
+       (vec_interleave_lowv16qi): Ditto.
+       (vec_interleave_highv8hi): Ditto.
+       (vec_interleave_lowv8hi): Ditto.
+       (vec_interleave_highv4si): Ditto.
+       (vec_interleave_lowv4si): Ditto.
+       (vec_interleave_highv2di): Ditto.
+       (vec_interleave_lowv2di): Ditto.
+       (sse2_maskmovdqu): Ditto.
+       * config/i386/mmx.md (mmx_maskmovq): Ditto.
+
+2007-09-09  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-vectorizer.h (enum vect_def_type): Start enumeration from 1.
+       (struct _slp_tree, struct _slp_instance): Define new data structures
+       along macros for their access.
+       (struct _loop_vec_info): Define new fields: strided_stores,
+       slp_instances, and slp_unrolling_factor along macros for their access.
+       (enum slp_vect_type): New.
+       (struct _stmt_vec_info): Define new field, slp_type, and macros for
+       its access.
+       (STMT_VINFO_STRIDED_ACCESS): New macro.
+       (vect_free_slp_tree): Declare.
+       (vectorizable_load): Add an argument of type slp_tree.
+       (vectorizable_store, vectorizable_operation, vectorizable_conversion,
+       vectorizable_assignment): Likewise.
+       (vect_model_simple_cost, vect_model_store_cost, vect_model_load_cost):
+       Declare (make extern).
+       * tree-vectorizer.c (new_stmt_vec_info): Initialize the new field.
+       (new_loop_vec_info): Likewise.
+       (destroy_loop_vec_info): Free memory allocated for SLP structures.
+       * tree-vect-analyze.c: Include recog.h.
+       (vect_update_slp_costs_according_to_vf): New.
+       (vect_analyze_operations): Add argument for calls to vectorizable_ ()
+       functions. For not pure SLP stmts with strided access check that the
+       group size is power of 2. Update the vectorization factor according to
+       SLP. Call vect_update_slp_costs_according_to_vf.
+       (vect_analyze_group_access): New.
+       (vect_analyze_data_ref_access): Call vect_analyze_group_access.
+       (vect_free_slp_tree): New functions.
+       (vect_get_and_check_slp_defs, vect_build_slp_tree, vect_print_slp_tree,
+       vect_mark_slp_stmts, vect_analyze_slp_instance, vect_analyze_slp,
+       vect_make_slp_decision, vect_detect_hybrid_slp_stmts,
+       vect_detect_hybrid_slp): Likewise.
+       (vect_analyze_loop): Call vect_analyze_slp, vect_make_slp_decision
+       and vect_detect_hybrid_slp.
+       * tree-vect-transform.c (vect_estimate_min_profitable_iters): Take
+       SLP costs into account.
+       (vect_get_cost_fields): New function.
+       (vect_model_simple_cost): Make extern, add SLP parameter and handle
+       SLP.
+       (vect_model_store_cost, vect_model_load_cost): Likewise.
+       (vect_get_constant_vectors): New function.
+       (vect_get_slp_vect_defs, vect_get_slp_defs,
+       vect_get_vec_defs_for_stmt_copy, vect_get_vec_defs_for_stmt_copy,
+       vect_get_vec_defs): Likewise.
+       (vectorizable_reduction): Don't handle SLP for now.
+       (vectorizable_call): Don't handle SLP for now. Add argument to
+       vect_model_simple_cost.
+       (vectorizable_conversion): Handle SLP (call vect_get_vec_defs to
+       get SLPed and vectorized defs). Fix indentation and spacing.
+       (vectorizable_assignment): Handle SLP.
+       (vectorizable_induction): Don't handle SLP for now.
+       (vectorizable_operation): Likewise.
+       (vectorizable_type_demotion): Add argument to
+       vect_model_simple_cost.
+       (vectorizable_type_promotion): Likewise.
+       (vectorizable_store, vectorizable_load): Handle SLP.
+       (vectorizable_condition): Don't handle SLP for now.
+       (vect_transform_stmt): Add a new argument for SLP. Check that there is
+       no SLP transformation required for unsupported cases. Add SLP
+       argument for supported cases.
+       (vect_remove_stores): New function.
+       (vect_schedule_slp_instance, vect_schedule_slp): Likewise.
+       (vect_transform_loop): Schedule SLP instances.
+       * Makefile.in: (tree-vect-analyze.o): Depend on recog.h.
+
+2007-09-09  Andrew Haley  <aph@redhat.com>
+
+       * optabs.c (sign_expand_binop): Set libcall_gen = NULL in the fake
+       signed optab.
+
+2007-09-09  Hans-Peter Nilsson  <hp@axis.com>
+
+       Divide REG_LABEL notes into REG_LABEL_OPERAND and REG_LABEL_TARGET.
+       * doc/rtl.texi (Insns): Specify when a label_ref makes a jump_insn.
+       Similar for what label_refs can go in the JUMP_TARGET field.  Split
+       REG_LABEL documentation into REG_LABEL_TARGET and REG_LABEL_OPERAND.
+       * reload.c (find_reloads): Generate REG_LABEL_OPERAND, not
+       REG_LABEL when replacing an operand with a LABEL_REF for a
+       non-jump insn.
+       (subst_reloads): When replacing a LABEL_REG with a register,
+       instead of generating a REG_LABEL note, assert that there already
+       is one or that the label is a known target for the insn.
+       * rtlanal.c (computed_jump_p): Instead of looking for a REG_LABEL
+       note, check the JUMP_LABEL field.  Remove "else" after return.
+       * reorg.c (emit_delay_sequence): Replace case for REG_LABEL with
+       cases for REG_LABEL_OPERAND and REG_LABEL_TARGET.
+       (fill_slots_from_thread): Handle both REG_LABEL_OPERAND and
+       REG_LABEL_TARGET notes, including the JUMP_TARGET field on JUMP_P
+       insns.  Iterate over all notes; don't assume there's only one.
+       * cse.c (recorded_label_ref): Adjust comment to refer to
+       REG_LABEL_OPERAND.
+       (cse_extended_basic_block): Do LABEL_REF check for all INSN_P
+       insns, not just NONJUMP_INSN_P.
+       (check_for_label_ref): For JUMP_P insns, check that the LABEL_REF
+       isn't a jump target.
+       * jump.c (rebuild_jump_labels): Adjust head comment.
+       (init_label_info): Ditto.  Remove REG_LABEL_OPERAND notes only;
+       don't reset REG_LABEL_TARGET notes, including the JUMP_LABEL field.
+       (mark_all_labels): For JUMP_P insns without a target, check if the
+       the target is noted on the previous nonjump insn.
+       (mark_jump_label_1): New function, guts from mark_jump_label.
+       <case IF_THEN_ELSE>: Handle first operand as a non-target when
+       marking jump target labels.
+       <case LABEL_REF>: Adjust for whether to generate a
+       REG_LABEL_TARGET or a REG_LABEL_OPERAND note.
+       For 'E' format rtl, iterate in descending element order.
+       (delete_related_insns): Handle both REG_LABEL_TARGET and
+       REG_LABEL_OPERAND notes.  For JUMP_P insns with labels with zero
+       reference count, delete and fallthrough.  Move finding-next-
+       non-deleted insn last in the function.  Look at all INSN_P insns
+       for REG_LABEL_OPERAND notes.
+       (redirect_jump_2): Assert that OLABEL equals the old JUMP_LABEL of
+       JUMP.
+       * print-rtl.c (print_rtx): For JUMP_P insns and a non-NULL
+       JUMP_LABEL, output the INSN_UID of it.
+       * gcse.c: Adjust comments as appropriate to say REG_LABEL_OPERAND
+       and/or REG_LABEL_TARGET.
+       (add_label_notes): Only add REG_LABEL_OPERAND notes.  Put in line
+       with jump.c copy by only adding notes for labels actually
+       referenced in the insn.
+       * emit-rtl.c (try_split): Don't assume only NONJUMP_INSN_P need
+       usage count increment; handle all INSN_P trial insns.
+       (emit_copy_of_insn_after): Change to not copy REG_LABEL_OPERAND
+       notes.
+       * rtl.h (struct rtx_def) <volatil>: Adjust to mention
+       REG_LABEL_TARGET and REG_LABEL_OPERAND.
+       (LABEL_REF_NONLOCAL_P): Allow REG_LABEL_TARGET and
+       REG_LABEL_OPERAND.
+       * combine.c (distribute_notes): Adjust for REG_LABEL_TARGET on
+       JUMP_P insns and REG_LABEL_OPERAND everywhere.
+       * sched-rgn.c (is_cfg_nonregular): Check for REG_LABEL_OPERANDS
+       on all INSN_P insns.
+       * reg-notes.def (LABEL_TARGET, LABEL_OPERAND): Split from LABEL.
+       * cfgrtl.c (delete_insn): Adjust to handle REG_LABEL_TARGET and
+       REG_LABEL_OPERAND notes.
+       * reload1.c (calculate_needs_all_insns): Adjust comments.
+       (set_label_offsets): Adjust to look for REG_LABEL_OPERAND notes.
+       * config/alpha/alpha.md (split for load of an address into a
+       four-insn sequence on Unicos/Mk): Adjust to use
+       REG_LABEL_OPERAND.
+       * config/sh/sh.md (sh_reorg, final_prescan_insn): Ditto.
+
+2007-09-09  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+
+       Revert:
+       2007-09-05  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+       * regrename.c (copyprop_hardreg_forward_1): New variable next. Use
+       FOR_BB_INSNS_SAFE instead of for loop.
+       * cse.c (cse_extended_basic_block): Likewise.
+       * postreload.c (reload_cse_regs_1): New variable next. Make sure
+       that the for loop does not invoke NEXT_INSN on a deleted insn.
+       * function.c (instantiate_virtual_regs): Likewise.
+       * lower-subreg.c (remove_retval_note): Likewise.
+       (decompose_multiword_subregs): Use FOR_BB_INSNS_SAFE instead of
+       FOR_BB_INSNS.
+       * emit-rtl.c (remove_insn): Set NEXT_INSN and PREV_INSN to NULL on
+       a deleted insn.
+       * cfgrtl.c (delete_insn): Set JUMP_LABEL to NULL on a deleted
+       insn, if it's a jump.
+       (try_redirect_by_replacing_jump): New variable jump_p. Call
+       tablejump_p before delete_insn_chain.
+       * reload1.c (reload): New variable next. Make sure that the for
+       loop does not invoke NEXT_INSN on a deleted insn.
+       (fixup_eh_region_note): Make the loop terminate if i becomes NULL.
+       (delete_output_reload): New variable prev. Make sure the the for
+       loops do not invoke PREV_INSN on a deleted insn.
+
+2007-09-08  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa/constraints.md: Remove 'X' from unused letters comment.
+
+2007-09-08  Richard Guenther  <rguenther@suse.de>
+
+       * tree-tailcall.c (find_tail_calls): If we don't have aliases
+       computed check stmt_ann->references_memory instead of counting
+       virtual operands.
+2007-09-08  Segher Boessenkool  <segher@kernel.crashing.org>
+
+       * cse.c (fold_rtx): Use validate_unshare_change() instead of
+       validate_change() in one more case.
+
+2007-09-08  Zdenek Dvorak  <ook@ucw.cz>
+
+       PR tree-optimization/32283
+       * tree-ssa-loop-ivopts.c (may_eliminate_iv): Use
+       estimated_loop_iterations.
+       (determine_use_iv_cost_condition): Decrease cost of expressions
+       used in iv elimination.
+
+2007-09-08  Richard Guenther  <rguenther@suse.de>
+
+       * tree-cfg.c (verify_gimple_expr): Avoid building new
+       pointer types, use TYPE_POINTER_TO if available instead.
+
+2007-09-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/33329
+       PR rtl-optimization/26449
+       * config/i386/sse.md (mulv4si3): Do not expand sse2 sequence.
+       (*sse2_mulv4si3): New define_insn_and_split pattern. Split insn in
+       split1 pass.
+       (mulv16qi3): Implement as define_insn_and_split pattern instead of
+       define_expand.  Split insn in split1 pass.
+       (mulv2di3): Ditto.
+
+2007-09-08  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/33301
+       * tree-vect-analyze (analyze_operations): Look at the type of the rhs
+       when relevant.
+
+2007-09-07  Zdenek Dvorak  <ook@ucw.cz>
+
+       PR tree-optimization/32183
+       * Makefile.in (tree-ssa-reassoc.o): Also depend on $(CFGLOOP_H).
+
+       * tree-ssa-reassoc.c: Include cfgloop.h.
+       (is_reassociable_op): Add a loop argument and return true only
+       for inside loop.
+       (linearize_expr): Updated.
+       (should_break_up_subtract): Likewise.
+       (linearize_expr_tree): Likewise.
+       (init_reassoc): Call loop_optimizer_init with
+       AVOID_CFG_MODIFICATIONS.  Remove calculate_dominance_info call
+       with CDI_DOMINATORS.
+       (fini_reassoc): Call loop_optimizer_finalize.
+
+2007-09-07  Sterling Augustine  <sterling@tensilica.com>
+
+       * config/xtensa/lib2funcs.S (__xtensa_sync_caches): Use an ISYNC even
+       if there is no i-cache.
+
+2007-09-07  Richard Guenther  <rguenther@suse.de>
+
+       Reapply
+       2007-09-06  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/32586
+       * tree-ssa-sccvn.c (simplify_binary_expression): Avoid
+       folding if nothing changed.
+       (simplify_unary_expression): New function.  Do tree combining
+       on conversion like codes.
+       (try_to_simplify): Call it.
+
+2007-09-07  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR target/33286
+       * gthr-posix.h (__gthread_active_p): Add implementation for hppa-hpux.
+       (__gthread_active,__gthread_start, __gthread_active_init): New.
+       * gthr-posix95.h: Likewise.
+
+2007-09-07  Roman Zippel <zippel@linux-m68k.org>
+
+       * function.h (struct function): Rename calls_unwind_init
+       to saves_all_registers.
+       (current_function_saves_all_registers): Renamed from
+       current_function_calls_unwind_init.
+       * reload1.c (reload): Set current_function_saves_all_registers.
+       * except.c (expand_builtin_unwind_init): Likewise.
+       * config/m68k/m68k.c (m68k_save_reg): Use
+       current_function_saves_all_registers to save pic register.
+
+2007-09-07  Janis Johnson  <janis187@us.ibm.com>
+
+       config/m68k/m68k.c (floating_exact_log2): Update call to real_2expN.
+       config/s390/s390.md (fixuns_trunc<BFP:mode><GPR:mode>2): Ditto.
+
+       Reapply reverted changes:
+
+       2007-09-06  Jan Hubicka  <jh@suse.cz>
+       * config/i386.c (ix86_expand_lround, ix86_expand_round): Update call
+       of real_2expN.
+
+       2007-09-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.md (fixuns_truncdfsi2, fixuns_truncdfdi2)
+       (fixuns_truncsfsi2, fixuns_truncsfdi2): Update calls to real_2expN.
+
+       2007-09-05  Janis Johnson  <janis187@us.ibm.com>
+
+       * optabs.c (expand_float): Convert unsigned integer as signed only
+       if it provides sufficient accuracy; add mode argument to real_2expN.
+       (expand_fix): Fix comment typos; extend binary float into mode
+       wider than destination for converion to unsigned integer; add mode
+       argument to real_2expN.
+       * real.c (real_2expN): Add mode argument to special-case decimal
+       float values.
+       * real.h (real_2expN): Ditto.
+       * fixed-value.c (check_real_for_fixed_mode): Add mode argument to
+       real_2expN.
+       (fixed_from_string): Ditto.
+       (fixed_to_decimal): Ditto.
+       (fixed_convert_from_real): Ditto.
+       (real_convert_from_fixed): Ditto.
+       * config/rs6000/rs6000.md (FP): Include DD and TD modes.
+       * config/rs6000/dfp.md (extendddtd2, adddd3, addtd3, subdd3, subtd3,
+       muldd3, multd3, divdd3, divtd3, cmpdd_internal1, cmptd_internal1,
+       floatditd2, ftruncdd2, fixdddi2, ftrunctd2, fixddi2): New.
+
+2007-09-07  Diego Novillo  <dnovillo@google.com>
+
+       * tree-flow.h (const_block_stmt_iterator): Remove.
+       Update all users to use block_stmt_iterator.
+       * tree-iterator.h (const_tree_stmt_iterator): Remove.
+       Update all users to use tree_stmt_iterator.
+
+2007-09-07  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * config/mips/mips.c (mips_set_current_function): Temporarily
+       make this a no-op to fix bootstrap errors, pending rewrite.
+
+2007-09-07  Jan Hubicka  <jh@suse.cz>
+
+       * reorg.c (dbr_schedule): Move code removing placeholder USEs later
+       in the pass.
+
+2007-09-07  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/33299
+       * tree-vect-transform.c (vect_create_epilog_for_reduction): Update
+       uses for all relevant loop-exit phis, not just the first.
+
+2007-09-07  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33330
+       * tree-ssa-operands.c (access_can_touch_variable): An access
+       of the form (*p)[0] can touch a variable of same size.
+
+2007-09-07  Jan Hubicka  <jh@suse.cz>
+
+       * passes.c (init_optimization_passes): Add simple dce and addressable
+       passes.
+       * tree-ssa.c (execute_update_addresses_taken): New function.
+       (pass_update_address_taken): New.
+       * tree-ssa-dse.c (execute_simple_dse): New function.
+       (pass_simple_dse): New.
+       * tree-pass.h (pass_simple_dse, pass_update_address_taken): Declare.
+
+2007-09-07  Tobias Burnus  <burnus@net-b.de>
+
+       PR middle-end/33321
+       * doc/invoke.texi: Fix -Wstrict-overflow= table.
+
+2007-09-07  Richard Guenther  <rguenther@suse.de>
+
+       Revert
+       2007-09-06  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/32586
+       * tree-ssa-sccvn.c (simplify_binary_expression): Avoid
+       folding if nothing changed.
+       (simplify_unary_expression): New function.  Do tree combining
+       on conversion like codes.
+       (try_to_simplify): Call it.
+
+2007-09-07  Richard Guenther  <rguenther@suse.de>
+           Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/32821
+       * tree_if_conv.c (combine_blocks): Use alloc_stmt_list instead of
+       NULL in the call to set_bb_stmt_list.
+
+2007-09-07  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (build_mips16_call_stub): Emit all direct
+       float calls here, rather than leaving some to the caller.
+       Use call_internal_direct and call_value_internal_direct.
+       * config/mips/mips.md (call_internal_direct): New pattern.
+       (call_value_internal_direct): Likewise.
+
+2007-09-07  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips_base_move_loop_invariants): New variable.
+       (mips_set_mips16_mode): Restore flag_move_loop_invariants, then set
+       to 0 for MIPS16.
+       (override_options): Set mips_base_move_loop_invariants.
+
+2007-09-07  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.opt (mcode-readable=): Move to keep list
+       alphabetical.
+
+2007-09-07  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi: Document the MIPS -mlocal-sdata, -mextern-sdata
+       and -mgpopt options.  Adjust the -G documentation to match.
+       * config/mips/mips.opt (mextern-data, mgpopt, mlocal-data): New.
+       * config/mips/mips.c (mips_rtx_constant_in_small_data_p): New
+       function, split out from mips_classify_symbol.  Return false for
+       !TARGET_LOCAL_SDATA.
+       (mips_classify_symbol): Call mips_rtx_constant_in_small_data_p.
+       Only use GP-relative accesses for non-pool symbols if TARGET_GPOPT.
+       (override_options): Check whether the -mgpopt setting is consistent
+       with the other flags.
+       (symbolic_expression_p): Delete.
+       (mips_select_rtx_section): Use mips_rtx_constant_in_small_data_p
+       and default_elf_select_rtx_section.
+       (mips_in_small_data_p): Honor section attributes for MIPS16 too.
+       Return false for local data unless TARGET_LOCAL_SDATA.  Likewise
+       external data and TARGET_EXTERN_SDATA.
+
+2007-09-07  Tobias Burnus  <burnus@net-b.de>
+
+       PR fortran/33303
+       * doc/cpp.texi (Common Predefined Macros): Add __GFORTRAN__.
+
+2007-09-05  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+
+       * regrename.c (copyprop_hardreg_forward_1): New variable next. Use
+       FOR_BB_INSNS_SAFE instead of for loop.
+       * cse.c (cse_extended_basic_block): Likewise.
+       * postreload.c (reload_cse_regs_1): New variable next. Make sure
+       that the for loop does not invoke NEXT_INSN on a deleted insn.
+       * function.c (instantiate_virtual_regs): Likewise.
+       * lower-subreg.c (remove_retval_note): Likewise.
+       (decompose_multiword_subregs): Use FOR_BB_INSNS_SAFE instead of
+       FOR_BB_INSNS.
+       * emit-rtl.c (remove_insn): Set NEXT_INSN and PREV_INSN to NULL on
+       a deleted insn.
+       * cfgrtl.c (delete_insn): Set JUMP_LABEL to NULL on a deleted
+       insn, if it's a jump.
+       (try_redirect_by_replacing_jump): New variable jump_p. Call
+       tablejump_p before delete_insn_chain.
+       * reload1.c (reload): New variable next. Make sure that the for
+       loop does not invoke NEXT_INSN on a deleted insn.
+       (fixup_eh_region_note): Make the loop terminate if i becomes NULL.
+       (delete_output_reload): New variable prev. Make sure the the for
+       loops do not invoke PREV_INSN on a deleted insn.
+
+2007-09-06  Zdenek Dvorak  <ook@ucw.cz>
+
+       * cgraphbuild.c (rebuild_cgraph_edges): Export.
+       * cgraph.h (rebuild_cgraph_edges): Declare.
+       * tree-pass.h (pass_expand_omp_ssa): New.
+       * omp-low.c (find_omp_clause): Export.
+       (copy_var_decl): Split from omp_copy_decl_2.
+       (build_omp_barrier): Return the call to emit instead of emitting
+       it directly.
+       (lower_rec_input_clauses, expand_omp_single): Gimplify the result of
+       build_omp_barrier.
+       (extract_omp_for_data, expand_parallel_call, expand_omp_parallel,
+       expand_omp_for_generic, expand_omp_for_static_nochunk,
+       expand_omp_for_static_chunk, expand_omp_for, expand_omp_sections):
+       Adapted to work on SSA form.
+       (execute_expand_omp): Do not invalidate dominance information.
+       (gate_expand_omp): Do not run with -fopenmp-ssa flag.
+       (gate_expand_omp_ssa, pass_expand_omp_ssa): New.
+       * gimplify.c (gimplify_omp_for): Ensure that the control variable is
+       a gimple_reg.
+       (force_gimple_operand): Allow gimplifying code expressions without
+       value.
+       * tree-predcom.c (mark_virtual_ops_for_renaming): Handle phi nodes.
+       * common.opt (fopenmp-ssa): New.
+       * tree-flow.h (find_omp_clause, copy_var_decl): Declare.
+       * Makefile.in (tree-cfg.o): Add TREE_INLINE_H dependency.
+       * tree-cfg.c: Include tree-inline.h.
+       (struct move_stmt_d): Replace vars_to_remove by vars_map field.
+       (replace_by_duplicate_decl, replace_ssa_name,
+       mark_virtual_ops_in_region): New functions.
+       (move_stmt_r, move_block_to_fn, move_sese_region_to_fn): Adapted
+       to work on SSA form.
+       * passes.c (init_optimization_passes): Add pass_expand_omp_ssa pass.
+       * tree-ssa-operands.c (get_expr_operands): Handle operands of OMP
+       constructs.
+
+2007-09-06  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+
+       * tree-loop-linear.c: Include obstack.h.
+       (linear_transform_loops): New obstack lambda_obstack.
+       Initialize it, pass it to gcc_loopnest_to_lambda_loopnest,
+       lambda_loopnest_transform, lambda_loopnest_to_gcc_loopnest calls
+       and free afterwards.
+       * lambda.h (struct obstack): New forward declaration.
+       (lambda_linear_expression_new): New parameter of type struct
+       obstack *.
+       (lambda_loopnest_new): Likewise.
+       (lambda_loopnest_transform): Likewise.
+       (lambda_body_vector_new): Likewise.
+       (lambda_body_vector_compute_new): Likewise.
+       (gcc_loopnest_to_lambda_loopnest): Likewise.
+       (lambda_loopnest_to_gcc_loopnest): Likewise.
+       * lambda-code.c: Include obstack.h.
+       (lambda_lattice_new): New parameter lambda_obstack.  Use it for
+       allocation of ret.
+       (lambda_body_vector_new): Likewise.
+       (lambda_linear_expression_new): Likewise.
+       (lambda_lattice_new): Likewise.
+       (lambda_loopnest_new): Likewise.  Additionally use obstack to
+       allocate LN_LOOPS(ret).
+       (lambda_lattice_compute_base): New parameter lambda_obstack.  Pass
+       it to lambda_lattice_new.
+       (lambda_body_vector_compute_new): New parameter lambda_obstack.
+       Pass it to lambda_body_vector_new.
+       (lambda_lattice_compute_base): New paramater lambda_obstack.  Pass
+       it to lambda_lattice_new.
+       (compute_nest_using_fourier_motzkin): New parameter lambda_obstack.
+       Pass it to lambda_loopnest_new, lambda_linear_expression_new.
+       (lambda_compute_target_space): Likewise.
+       (lambda_compute_auxillary_space): New parameter lambda_obstack.
+       Pass it to lambda_lattice_compute_base and
+       compute_nest_using_fourieer_motzkin.
+       (lambda_loopnest_transform): New parameter lambda_obstack.  Pass
+       it to lambda_lattice_compute_base, lambda_lattice_auxillary_space
+       and lambda_lattice_compute_target_space.
+       (gcc_tree_to_linear_expression): Nex parameter lambda_obstack.
+       Pass it to lambda_linear_expression_new.
+       (gcc_loop_to_lambda_loop): New parameter lambda_obstack.  Pass it
+       to gcc_tree_to_linear_expression.
+       (gcc_loopnest_to_lambda_loopnest): New parameter lambda_obstack.
+       Pass it to gcc_loop_to_lambda_loop and lambda_loopnest_new.
+       (lambda_loopnest_to_gcc_loopnest): New parameter lambda_obstack.
+       Pass it to lambda_body_vector_new and
+       lambda_body_vector_compute_new.
+       * Makefile.in (tree-loop-linear.o): Add $(OBSTACK_H) dependency.
+       (lambda-code.o): Likewise.
+
+2007-09-06  Chao-ying Fu  <fu@mips.com>
+
+       * ginclude/stdfix.h: New file.
+       * Makefile.in (USER_H): Add $(srcdir)/ginclude/stdfix.h.
+       (convert.o): Add dependence on fixed-value.h.
+       * c-convert.c (convert): Support FIXED_POINT_TYPE.
+       * c-cppbuiltin.c (builtin_define_fixed_point_constants): New function
+       to define fixed-point constants.
+       (c_cpp_builtins): Define fixed-point constants.
+       * convert.c (fixed-value.h): New include.
+       (convert_to_real): Update comment to include fixed-point.
+       Support FIXED_POINT_TYPE.
+       (convert_to_integer): Update comment to include fixed-point.
+       Support FIXED_POINT_TYPE.
+       (convert_to_complex): Support FIXED_POINT_TYPE.
+       (convert_to_fixed): New function.
+       * convert.h (convert_to_fixed): Declare.
+       * genopinit.c: Add comment about $Q for only fixed-point modes.
+       (optabs): Add fract_optab, fractuns_optab, satfract_optab,
+       satfractuns_optab, add_optab, ssadd_optab, usadd_optab, sub_optab,
+       sssub_optab, ussub_optab, smul_optab, ssmul_optab, usmul_optab,
+       ssmadd_widen_optab, usmadd_widen_optab, ssdiv_optab, udiv_optab,
+       usdiv_optab, ssashl_optab, usashl_optab, neg_optab, ssneg_optab,
+       usneg_optab for fixed-point modes.
+       (gen_insn): Add force_fixed to track the $Q format for all fixed-point
+       modes.
+       * optabs.c (optab_for_tree_code): For *DIV_EXPR, LSHIFT_EXPR,
+       PLUS_EXPR, MINUS_EXPR, MULT_EXPR, NEGATE_EXPR, return signed or
+       unsigned saturation optabs, when type is saturating.
+       (shift_optab_p): Return true for SS_ASHIFT or US_ASHIFT.
+       (expand_fixed_convert): New function.
+       (gen_fixed_libfunc, gen_signed_fixed_libfunc,
+       gen_unsigned_fixed_libfunc, gen_int_fp_fixed_libfunc,
+       gen_int_fp_signed_fixed_libfunc, gen_int_fixed_libfunc,
+       gen_int_signed_fixed_libfunc, gen_int_unsigned_fixed_libfunc,
+       gen_fract_conv_libfunc, gen_fractuns_conv_libfunc,
+       gen_satfract_conv_libfunc, gen_satfractuns_conv_libfunc): New
+       functions.
+       (init_optabs): Initialize ssadd_optab, usadd_optab, sssub_optab,
+       ussub_optab, ssmul_optab, usmul_optab, ssmadd_widen_optab,
+       usmadd_widen_optab, ssmsub_widen_optab, usmsub_widen_optab,
+       ssdiv_optab, usdiv_optab, ssashl_optab, usashl_optab, ssneg_optab,
+       usneg_optab, fract_optab, fractuns_optab, satfract_optab,
+       satfractuns_optab.
+       Initialize fixed-point libraries, including add, ssadd, usadd, sub,
+       sssub, ussub, mul, ssmul, usmul, div, ssdiv, udiv, usdiv, ashl,
+       ssashl, usashl, ashr, lshr, neg, ssneg, usneg, cmp, fract, satfract,
+       fractuns, satfractuns.
+       * optabs.h (enum optab_index): Add OTI_ssadd, OTI_usadd, OTI_sssub,
+       OTI_ussub, OTI_ssmul, OTI_usmul, OTI_ssdiv, OTI_usdiv, OTI_ssneg,
+       OTI_usneg, OTI_ssashl, OTI_usashl, OTI_ssmadd_widen, OTI_usmadd_widen,
+       OTI_ssmsub_widen,  OTI_usmsub_widen.
+       (ssadd_optab, usadd_optab, sssub_optab, ussub_optab, ssmul_optab,
+       usmul_optab, ssdiv_optab, usdiv_optab, ssneg_optab, usneg_optab,
+       ssashl_optab, usashl_optab, ssmadd_widen_optab, usmadd_widen_optab,
+       umsub_widen_optab, usmsub_widen_optab): Define.
+       (enum convert_optab_index): Add COI_fract, COI_fractuns, COI_satfract,
+       COI_satfractuns.
+       (fract_optab, fractuns_optab, satfract_optab, satfractuns_optab):
+       Define.
+       (expand_fixed_convert): Declare.
+       * expr.c (convert_move): Support the move of fixed-point modes.
+       (emit_move_insn_1): Handle fixed-point mode to move via integer.
+       (categorize_ctor_elements_1): Handle FIXED_CST.
+       (count_type_elements): Handle FIXED_POINT_TYPE.
+       (expand_expr_real_1): For VECTOR_CST, check MODE_VECTOR_FRACT,
+       MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM, MODE_VECTOR_UACCUM.
+       Support FIXED_CST.
+       For PLUS_EXPR and MINUS_EXPR, support saturating and non-saturating
+       multiply and add/subtract for fixed-point types.
+       For MULT_EXPR, *DIV_EXPR, *SHIFT_EXPR, if the mode if a fixed-point
+       mode, we jump to binop directly.
+       Support FIXED_CONVERT_EXPR.
+       (do_store_flag): Check FIXED_CST to put a constant second.
+       (vector_mode_valid_p): Handle MODE_VECTOR_FRACT,
+       MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM, MODE_VECTOR_UACCUM.
+       (const_vector_from_tree): Support FIXED_CST.
+       * doc/extend.texi (Fixed-Point): New node.
+       * doc/md.texi (ssadd, usadd, sssub, ussub, ssmul, usmul, ssdiv, usdiv,
+       ssmadd, usmadd, ssmsub, usmsub, ssashl, usashl, ssneg, usneg, fract,
+       satfract, fractuns, satfractuns): Document them.
+
+2007-09-07  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.h (PREFERRED_RELOAD_CLASS): Don't reload autoinc
+       addresses into I registers.
+
+2007-09-06  Jan Hubicka  <jh@suse.cz>
+           Andreas Tobler  <a.tobler@schweiz.org>
+
+       * config/darwin.c (machopic_indirect_data_reference): Avoid invalid
+       sharing.
+       (machopic_legitimize_pic_address): Likewise.
+
+2007-09-06  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+           Jan Hubicka  <jh@suse.cz>
+
+       * config/spu/spu.md (floatsidf2): Use convert_optab_libfunc
+       instead of ufloat_optab->handlers directly.
+       (floatdidf2): Likewise.
+
+2007-09-06  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * config/mips/mips.c:  Include diagnostic.h.
+       (mips_set_current_function): Check errorcount and sorrycount 
+       before generating RTL.
+
+2007-09-06  Richard Sandiford  <richard@codesourcery.com>
+
+       PR target/33256
+       * config/mips/mips.c (mips_classify_symbolic_expression): New function.
+       (mips_classify_address): Use it instead of mips_symbolic_constant_p.
+       (print_operand_reloc): Likewise.
+
+2007-09-06  Janis Johnson  <janis187@us.ibm.com>
+
+       Revert:
+
+       2007-09-06  Jan Hubicka  <jh@suse.cz>
+       * config/i386/i386.c (ix86_expand_lround, ix86_expand_round):
+       Update call of real_2expN.
+
+       2007-09-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.md (fixuns_truncdfsi2, fixuns_truncdfdi2)
+       (fixuns_truncsfsi2, fixuns_truncsfdi2): Update calls to real_2expN.
+
+       2007-09-05  Janis Johnson  <janis187@us.ibm.com>
+
+       * optabs.c (expand_float): Convert unsigned integer as signed only
+       if it provides sufficient accuracy; add mode argument to real_2expN.
+       (expand_fix): Fix comment typos; extend binary float into mode
+       wider than destination for converion to unsigned integer; add mode
+       argument to real_2expN.
+       * real.c (real_2expN): Add mode argument to special-case decimal
+       float values.
+       * real.h (real_2expN): Ditto.
+       * fixed-value.c (check_real_for_fixed_mode): Add mode argument to
+       real_2expN.
+       (fixed_from_string): Ditto.
+       (fixed_to_decimal): Ditto.
+       (fixed_convert_from_real): Ditto.
+       (real_convert_from_fixed): Ditto.
+       * config/rs6000/rs6000.md (FP): Include DD and TD modes.
+       * config/rs6000/dfp.md (extendddtd2, adddd3, addtd3, subdd3, subtd3,
+       muldd3, multd3, divdd3, divtd3, cmpdd_internal1, cmptd_internal1,
+       floatditd2, ftruncdd2, fixdddi2, ftrunctd2, fixddi2): New.
+
+2007-09-06  Tom Tromey  <tromey@redhat.com>
+
+       * tree-cfg.c (remove_bb): Only warn if line is non-zero.
+       * c-pch.c (c_common_read_pch): Restore current location after
+       reading PCH file.
+       * tree.c (expand_location): Update.
+       (expr_filename): Changed return type.  Unified the two cases.
+       (expr_lineno): Likewise.
+       (annotate_with_file_line): Don't use EXPR_LINENO and EXPR_FILENAME
+       as lvalues.
+       * toplev.c (line_table): Changed type.
+       (general_init): Update.
+       (realloc_for_line_map): New function.
+       (general_init): Allocate line_table using GC.
+       * fix-header.c (line_table): Changed type.
+       (read_scan_file): Update.
+       (read_scan_file): Update.
+       * c-ppoutput.c (maybe_print_line): Update.
+       (print_line): Update.
+       (cb_line_change): Update.
+       (cb_define): Update.
+       (pp_file_change): Update.
+       * c-opts.c (c_common_init_options): Update.
+       (finish_options): Update.
+       (push_command_line_include): Update.
+       * c-lex.c (cb_line_change): Update.
+       (cb_def_pragma): Update.
+       (cb_define): Update.
+       (cb_undef): Update.
+       (c_lex_with_flags): Use cpp_get_token_with_location.
+       * input.h (line_table): Changed type.
+       (location_from_locus): New macro.
+       * tree.h (EXPR_FILENAME): No longer an lvalue.
+       (EXPR_LINENO): Likewise.
+       (expr_locus, set_expr_locus): Declare separately for
+       USE_MAPPED_LOCATION.
+       (expr_filename, expr_lineno): Changed return type.
+       * gimplify.c (tree_to_gimple_tuple): Use SET_EXPR_LOCUS.
+       * cfgexpand.c (expand_gimple_cond_expr): Use location_from_locus.
+       (expand_gimple_basic_block): Likewise.
+       * final.c (final_scan_insn): Use expanded_location.
+
+2007-09-06  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/32586
+       * tree-ssa-sccvn.c (simplify_binary_expression): Avoid
+       folding if nothing changed.
+       (simplify_unary_expression): New function.  Do tree combining
+       on conversion like codes.
+       (try_to_simplify): Call it.
+       * builtins.c (fold_builtin_cexp): Fold the built expressions.
+       * fold-const.c (fold_unary): Test result of get_callee_fndecl().
+
+2007-09-06  Jan Hubicka  <jh@suse.cz>
+
+       PR target/33318
+       * cse.c (fold_rtx): Avoid invalid sharing.
+
+2007-09-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.md (fixuns_truncdfsi2, fixuns_truncdfdi2)
+       (fixuns_truncsfsi2, fixuns_truncsfdi2): Update calls to real_2expN.
+
+2007-09-06  Revital Eres  <eres@il.ibm.com>
+
+       * config/rs6000/rs6000.c (rs6000_legitimate_offset_address_p):
+       Fix offsettable memory reference for 750CL.
+
+2007-09-06  Pat Haugen  <pthaugen@us.ibm.com>
+
+       * reload.c (find_reloads_address_1): Try to preserve original
+       base/index regclass of operands.
+       * regrename.c (scan_rtx_address): Likewise.
+       (replace_oldest_value_addr): Likewise.
+
+2007-09-06  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33302
+       * domwalk.c (walk_dominator_tree): The exit block is
+       interesting even if it is not reachable.
+
+2007-09-06  Richard Sandiford  <richard@codesourcery.com>
+
+       PR middle-end/33306
+       * optabs.c (avoid_expensive_constant): Do nothing if MODE is VOIDmode.
+
+2007-09-06  Basile Starynkevitch  <basile@starynkevitch.net>
+
+       * cfg.c (dump_bb_info, dump_edge_info): Added cfun test for 
+       robustness.
+
+2007-09-05  Ian Lance Taylor  <iant@google.com>
+
+       * tree-pretty-print.c (dump_decl_name): Cast LABEL_DECL_UID to int
+       when printing.
+       (dump_generic_node): Likewise.
+       * print-rtl.c (print_decl_name): Likewise.
+       * print-tree.c (print_node_brief): Likewise.
+       (print_node): Likewise.
+       * Makefile.in (RTL_BASE_H): Add alias.h.
+       (TREE_H): Likewise.
+
+2007-09-06  Jesper Nilsson  <jesper.nilsson@axis.com>
+
+       * longlong.h [__CRIS_arch_version >= 8] (count_trailing_zeros):
+       Defined.
+       * config/cris/cris.md (ctzsi2, cris_swap_bits): Implemented.
+       * config/cris/cris.h (CTZ_DEFINED_VALUE_AT_ZERO): Defined.
+
+2007-09-06  Jie Zhang  <jie.zhang@analog.com>
+
+       * config.gcc (tm_file): Add linux.h for bfin*-uclinux*.
+       (tm_defines): Define UCLIBC_DEFAULT to 1.
+       (extra_options): Add linux.opt.
+       * config/bfin/linux.h (CPLUSPLUS_CPP_SPEC): Don't define.
+       (CRT_CALL_STATIC_FUNCTION): Likewise.
+       (NO_IMPLICIT_EXTERN_C): Likewise.
+       (TARGET_OS_CPP_BUILTINS): Define as LINUX_TARGET_OS_CPP_BUILTINS.
+       * config/bfin/elf.h (OBJECT_FORMAT_ELF): Don't define.
+       * config/bfin/uclinux.h (CPLUSPLUS_CPP_SPEC): Don't define.
+       (ENDFILE_SPEC): Don't define.
+       (LIB_SPEC): Likewise.
+       (CRT_CALL_STATIC_FUNCTION): Likewise.
+       (NO_IMPLICIT_EXTERN_C): Likewise.
+       (LINUX_TARGET_OS_CPP_BUILTINS): Likewise.
+       (TARGET_OS_CPP_BUILTINS): Define as LINUX_TARGET_OS_CPP_BUILTINS.
+
+2007-09-06  Jan Hubicka  <jh@suse.cz>
+
+       * config/i386/i386.c (ix86_expand_lround, ix86_expand_round):
+       Update call of real_2expN.
+
+2007-09-06  Jan Hubicka  <jh@suse.cz>
+
+       * opts.c (common_handle_option): Enable inlining functions for
+       -fprofile-generate.
+
+2007-09-06  Jakub Jelinek  <jakub@redhat.com>
+
+       * builtin-attrs.def (ATTR_NONNULL_3): New.
+       (DEF_FORMAT_ATTRIBUTE): Use just ATTR_NONNULL_##FA instead of
+       ATTR_NOTHROW_NONNULL_##FA.
+       (DEF_FORMAT_ATTRIBUTE_NOTHROW, DEF_FORMAT_ATTRIBUTE_BOTH): New macros.
+       (ATTR_FORMAT_PRINTF_NOTHROW_2_0, ATTR_PRINTF_NOTHROW_2_3,
+       ATTR_FORMAT_PRINTF_NOTHROW_3_0, ATTR_FORMAT_PRINTF_NOTHROW_3_4,
+       ATTR_FORMAT_PRINTF_NOTHROW_4_0, ATTR_PRINTF_NOTHROW_4_5,
+       ATTR_FORMAT_PRINTF_NOTHROW_5_0, ATTR_FORMAT_PRINTF_NOTHROW_5_6,
+       ATTR_FORMAT_SCANF_NOTHROW_2_0, ATTR_FORMAT_SCANF_NOTHROW_2_3,
+       ATTR_FORMAT_STRFTIME_NOTHROW_3_0, ATTR_FORMAT_STRFMON_NOTHROW_3_4):
+       New.
+       (ATTR_FORMAT_PRINTF_4_0, ATTR_PRINTF_4_5, ATTR_FORMAT_PRINTF_5_0,
+       ATTR_FORMAT_PRINTF_5_6, ATTR_FORMAT_STRFTIME_3_0,
+       ATTR_FORMAT_NOTHROW_3_4): Remove.
+       * builtins.def (snprintf, sprintf, sscanf, vsnprintf, vsprintf,
+       vsscanf, strfmon, strftime, __snprintf_chk, __sprintf_chk,
+       __vsnprintf_chk, __vsprintf_chk): Use ATTR_FORMAT_*_NOTHROW_*
+       instead of ATTR_FORMAT_*_*.
+
+2007-09-06  Hans-Peter Nilsson  <hp@axis.com>
+
+       * config/cris/cris.c (cris_emit_movem_store): Call copy_rtx on
+       parts re-used for REG_FRAME_RELATED_EXPR.
+
+2007-09-05  Janis Johnson  <janis187@us.ibm.com>
+
+       * optabs.c (expand_float): Convert unsigned integer as signed only
+       if it provides sufficient accuracy; add mode argument to real_2expN.
+       (expand_fix): Fix comment typos; extend binary float into mode
+       wider than destination for converion to unsigned integer; add mode
+       argument to real_2expN.
+       * real.c (real_2expN): Add mode argument to special-case decimal
+       float values.
+       * real.h (real_2expN): Ditto.
+       * fixed-value.c (check_real_for_fixed_mode): Add mode argument to
+       real_2expN.
+       (fixed_from_string): Ditto.
+       (fixed_to_decimal): Ditto.
+       (fixed_convert_from_real): Ditto.
+       (real_convert_from_fixed): Ditto.
+       * config/rs6000/rs6000.md (FP): Include DD and TD modes.
+       * config/rs6000/dfp.md (extendddtd2, adddd3, addtd3, subdd3, subtd3,
+       muldd3, multd3, divdd3, divtd3, cmpdd_internal1, cmptd_internal1,
+       floatditd2, ftruncdd2, fixdddi2, ftrunctd2, fixddi2): New.
+
+2007-09-05  Ian Lance Taylor  <iant@google.com>
+
+       * init-regs.c (initialize_uninitialized_regs): Call
+       emit_insn_before rather than add_insn_before.
+
+2007-09-05  Jakub Jelinek  <jakub@redhat.com>
+
+       * builtins.def (BUILT_IN_VA_ARG_PACK): New built-in.
+       * tree.h (CALL_EXPR_VA_ARG_PACK): Define.
+       * tree-inline.h (copy_body_data): Add call_expr field.
+       * tree-inline.c (expand_call_inline): Initialize call_expr.
+       (copy_bb): Append anonymous inline fn arguments to arguments
+       when inlining a CALL_EXPR_VA_ARG_PACK call.
+       * builtins.c (expand_builtin): Issue an error if
+       BUILT_IN_VA_ARG_PACK is seen during expand.
+       (fold_call_expr, fold_builtin_call_array): Don't fold
+       CALL_EXPR_VA_ARG_PACK CALL_EXPRs or calls with
+       __builtin_va_arg_pack () call as last argument.
+       * gimplify.c (gimplify_call_expr): If last argument to a vararg
+       function is __builtin_va_arg_pack (), decrease number of call
+       arguments and instead set CALL_EXPR_VA_ARG_PACK on the CALL_EXPR.
+       * expr.c (expand_expr_real_1): Issue an error if
+       CALL_EXPR_VA_ARG_PACK CALL_EXPR is seen during expand.
+       * tree-pretty-print.c (dump_generic_node): Handle printing
+       CALL_EXPR_VA_ARG_PACK bit on CALL_EXPRs.
+       * doc/extend.texi (__builtin_va_arg_pack): Document.
+
+2007-09-05  Adam Nemet  <anemet@caviumnetworks.com>
+
+       PR tree-optimization/21513
+       * builtins.c (build_builtin_expect_predicate): New function.
+       (fold_builtin_expect): Add argument for expected value.
+       Distribute __builtin_expect over short-circuiting operations.
+       Fold nested builtin_expects.
+       (fold_builtin_2): Adjust call to fold_builtin_expect.
+
+2007-09-05  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR web/32965
+       PR tree-optimization/13756
+       * doc/invoke.texi (Options That Control Optimization): Document
+       -ftree-dse.
+
+2007-09-05  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/cpuid.h: New file.
+       * config/i386/driver-i386.c: Include cpuid.h.
+       (describe_cache): Shrink size and line strings to 100 bytes.
+       (detect_caches_amd): Return "" for unsupported max_ext_level.
+       Use __cpuid function.
+       (detect_caches_intel): Return "" for unsupported max_level.
+       Use __cpuid function.
+       (host_detect_local_cpu): Change feature flag variables to
+       unsigned int.  Initialize only extended feature flag variables.
+       Use __get_cpuid_max to determine max supported cpuid level.
+       Use __cpuid function to determine supported features.  Fix
+       calculation of family id.  Remove is_amd and check signature
+       directly.  Check for Geode signature.  Handle family 4 id.
+       [PROCESSOR_GENERIC32]: New default for unknown family id.  Move
+       cpu discovery code to lower part of the function.
+       [PROCESSOR_PENTIUM, PROCESSOR_K6, PROCESSOR_ATHLON]: Do not tune
+       for sub-architecture.
+       [PROCESSOR_PENTIUMPRO]: Simplify cpu discovery code.
+       [PROCESSOR_K8]: Add k8-sse3 architecture.
+       [PROCESSOR_NOCONA]: Remove.
+       [PROCESSOR_GENERIC64]: Ditto.
+       * config/i386/x-i386 (driver-i386.o): Depend on cpuid.h.
+       * config/i386/crtfastmath.c: Include cpuid.h.  Use __get_cpuid
+       to check for SSE and FXSAVE support.
+       * config/i386/t-crtfm (crtfastmath.o): Depend on cpuid.h.
+       Add -minline-all-stringops.
+       * config.gcc (i[34567]86-*-*): Add cpuid.h to extra_headers.
+       (x86_64-*-*): Ditto.
+
+2007-09-05  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/linux-unwind.h: New file.
+       * config/bfin/linux.h (MD_UNWIND_SUPPORT): Define.
+       * config/bfin/uclinux.h (MD_UNWIND_SUPPORT): Define.
+
+2007-09-05  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+
+       * Makefile.in (stmt.o): Add alloc-pool.h dependency.
+       * stmt.c: Include alloc-pool.h.
+       (struct case_node): Remove GTY marker.
+       (add_case_node): New parameter case_node_pool.  Use it for
+       allocation of r.
+       (expand_case): New allocation pool case_node_pool.  Initialize it,
+       pass to add_case_node and free it.
+
+2007-09-05  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+           Nigel Stephens <nigel@mips.com>
+
+       Add mips16/nomips16 function attributes and -mflip-mips16 option
+       for testing mixed-mode compilation.
+
+       * config/mips/mips.opt (mflip-mips16): New.
+
+       * config/mips/mips.h (SYMBOL_FLAG_MIPS16_FUNC): Define.
+       (SYMBOL_FLAG_MIPS16_FUNC_P): Define.
+
+       * config/mips/mips.c (mips_base_target_flags): New.
+       (mips_base_mips16): New.
+       (mips_base_schedule_insns): New.
+       (mips_base_reorder_blocks_and_partition): New.
+       (mips_base_align_loops): New.
+       (mips_base_align_jumps): New.
+       (mips_base_align_functions): New.
+       (mips16_flipper): New.
+       (mips_attribute_table): Add "mips16" and "nomips16" entries.
+       (TARGET_SET_CURRENT_FUNCTION): Define.
+       (mips_mips16_type_p, mips_nomips16_type_p): New.
+       (mips_comp_type_attributes): Check mips16/nomips16 attributes.
+       (mips_function_ok_for_sibcall): Make it deal with functions with
+       mips16 attributes.
+       (mips_init_split_addresses): New, split out from override_options.
+       (mips_init_relocs): New, split out from override_options.
+       (was_mips16_p): New.
+       (mips_set_mips16_mode): New, split out from override_options.
+       (mips_set_current_function): New.
+       (override_options): Add sorry for unsupported mips16/pic
+       combination.  Remove error for mips16/dsp combination.  Save
+       base option settings.  
+       (mips_file_start): Move mips16 mode setting output from here....
+       (mips_output_function_prologue): ....to here.
+       (mips_output_mi_thunk): Check for mips16 function.
+       (build_mips16_function_stub): Don't set .mips16 here.
+       (build_mips16_call_stub): Likewise.
+       (mips_expand_builtin): Error in mips16 mode.
+       (mips_use_mips16_mode_p): New.
+       (mips_encode_section_info): Check for mips16 function, and set
+       SYMBOL_REF_FLAGS accordingly.
+
+       * doc/extend.texi (Function Attributes): Document new
+       mips16/nomips16 attributes.
+       * doc/invoke.texi (Option Summary): Add -mflip-mips16.
+       (MIPS Options): Document -mflip-mips16.
+
+2007-09-05  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * config/mips/mips.c (mips_legitimize_tls_address): Call sorry
+       if we encounter TLS address in MIPS16 mode.
+       (mips_legitimize_const_move): Check cannot_force_const_mem for
+       the (const (plus symbol offset)) case; this forces invalid TLS
+       address in MIPS16 mode to be caught by the above call to sorry.
+       (override_options): Don't reset targetm.have_tls in MIPS16 mode,
+       because that now enables emutls, which is not ABI compatible
+       with native TLS in non-MIPS16 mode.
+
+2007-09-05  Sandra Loosemore  <sandra@codesourcery.com>
+
+       Add target hook invoked when cfun changes.
+
+       * doc/tm.texi (TARGET_SET_CURRENT_FUNCTION): Document.
+       * target.h (struct gcc_target): Add set_current_function.
+       * target-def.h (TARGET_SET_CURRENT_FUNCTION): Define.
+       (TARGET_INITIALIZER): Add initializer for set_current_function.
+       * tree.h (push_struct_function): New.
+       * tree-inline.h (push_cfun, pop_cfun): Move declarations to...
+       * function.h: Here.
+       (set_cfun): Declare.
+       * tree-inline.c (cfun_stack, push_cfun, pop_cfun): Moved to...
+       * function.c: Here.
+       (push_function_context_to): Use allocate_struct_function
+       to create null context, not init_dummy_function_start.  Use set_cfun.
+       (pop_function_context_from): Use set_cfun.
+       (in_dummy_function): New.
+       (invoke_set_current_function_hook): New.
+       (set_cfun): New.
+       (push_cfun, pop_cfun): Use set_cfun.
+       (push_struct_function): New.
+       (allocate_struct_function): Call invoke_set_current_function_hook
+       before returning.
+       (prepare_function_start): Don't set cfun here.  Remove unused
+       argument; fix all callers.
+       (init_dummy_function_start): Fiddle with in_dummy_function.  Call
+       push_struct_function.
+       (init_function_start): Set cfun here.
+       (expand_dummy_function_end): Fiddle with in_dummy_function.  Pop cfun.
+       * omp-low.c (create_omp_child_function): Use push_struct_function
+       and pop_cfun to save/restore state.
+       (expand_omp_parallel): Remove unused saved_cfun variable.
+       * cgraphunit.c (ipa_passes): Use set_cfun.
+       * gimple-low.c (record_vars_into): Use push_cfun/pop_cfun here.
+       * dwarf2out.c (dwarf2out_abstract_function): Likewise.
+       * matrix-reorg.c (transform_allocation_sites): Likewise.
+       (matrix_reorg): Use set_cfun.
+       * gimplify.c (gimplify_function_tree): Use push_cfun/pop_cfun here.
+       * tree-optimize.c (tree_rest_of_compilation): Remove one redundant
+       assignment to cfun; use set_cfun for the other.
+       * tree-cfg.c (move_sese_region_to_fn): Use set_cfun.
+       (dump_function_to_file): Use push_cfun/pop_cfun here.
+       * c-decl.c (finish_function): Use set_cfun.
+
+2007-09-05  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * regrename.c (rerename_optimize): Use deferred rescanning and
+       insert explicit calls to rescan insns when changed.
+       
+2007-09-05  Jan Hubicka  <jh@suse.cz>
+
+       * optabs.c (libfunc_entry): Change optab to integer.
+       (hash_libfunc, convert_optab_libfunc, optab_libfunc,
+       set_optab_libfunc, set_conv_libfunc): Use optable indexes instead
+       of pointers for hashing.
+
+2007-09-05  Jan Hubicka  <jh@suse.cz>
+
+       * regrename.c (pass_regrename, pass_cprop_hardreg): Add RTL sharing
+       verifier.
+       * fwprop.c (pass_rtl_fwprop, pass_rtl_fwprop_add): Likewise.
+       * see.c (pass_see): Likewise.
+       * tracer.c (pass_tracer): Likewise.
+       * postreload-gcse.c (pass_gcse2): Likewise.
+       * postreload.c (pass_postreload_cse): Likewise.
+       * mode-switching.c (pass_mode_switching): Likewise.
+       * modulo-sched.c (pass_sms): Likewise.
+       * cse.c (cse_insn): Likewise.
+       * web.c (pass_web): Likweise.
+       * combine-stack-adj.c (pass_stack_adjustments): Likewise.
+       * dce.c (pass_ud_rtl_dce, pass_fast_rtl_dce): Likewise.
+       * loop-init.c (pass_rtl_loop_init): Likewise.
+       (pass_rtl_loop_done, pass_rtl_move_loop_, pass_rtl_unswitch,
+       pass_rtl_unroll_and, pass_rtl_doloop): Likewise.
+       * global.c (pass_global_alloc): Likewise.
+       * ifcvt.c (pass_rtl_ifcvt, pass_if_after_combine,
+       pass_if_after_reload): Likewise.
+       * reload.c (pass_peephole2, pass_split_for_shoren_branches): Likewise.
+       * dse.c (pass_rtl_dse1, pass_rtl_dse2): Likewise.
+       * regmove.c (pass_regmove): Likewise.
+       * function.c (pass_thread_prologugues_epilogues): Likewise.
+       * gcse.c (pass_gcse): Likewise.
+       * rtl-factoring.c (pass_rtl_seqabstr): Likewise.
+       * lower-subreg.c (pass_lower_subreg2): Likewise.
+       * bt-load.c (pass_branch_target_load): Likewise.
+       * emit-rtl.c (pass_unshare_all_rtl): Likewise.
+       * cfgcleanup.c (pass_jump, pass_jump2): Likewise.
+       * combine.c (pass_combine): Likewise.
+       * bb-reorder.c (pass_duplicate_comp, pass_reorder_blocks): Likewise.
+       (pass_partition_blocks): Likewise.
+       * var-tracking.c (pass_variable_track): Likewise.
+       * reg-stack.c (pass_stack_regs_run): Likewise.
+       * sched-rgn.c (pass_sched, pass_sched2): Likewise.
+       * passes.c (pass_postreload): Likewise.
+       (execute_function_todo): Add TODO_verify_rtl_sharing handling code.
+       * tree-pass.h (TODO_verify_rtl_sharing): New.
+       (TODO_update_ssa, TODO_update_ssa_no_phi, TODO_update_ssa_full_phi,
+       TODO_update_ssa_only_virtuals, TODO_remove_unused_locals,
+       TODO_set_props, TODO_df_finish, TODO_df_verify,
+       TODO_mark_first_instance, TODO_rebuild_alias): Renumber.
+
+2007-09-05  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * fold-const.c (all_ones_mask_p, sign_bit_p, simple_operand_p,
+       fold_real_zero_addition_p, reorder_operands_p,
+       div_if_zero_remainder, fold_undefer_overflow_warnings,
+       int_binop_types_match_p, fold_convert_const_int_from_int,
+       fold_convert_const_int_from_real,
+       fold_convert_const_int_from_fixed,
+       fold_convert_const_real_from_real,
+       fold_convert_const_real_from_fixed,
+       fold_convert_const_fixed_from_fixed,
+       fold_convert_const_fixed_from_int,
+       fold_convert_const_fixed_from_real, maybe_lvalue_p,
+       fold_checksum_tree, fold_check_failed, print_fold_checksum,
+       debug_fold_checksum, multiple_of_p): Constify.
+       * tree-flow-inline.h (get_lineno): Likewise.
+       * tree-flow.h (get_lineno): Likewise.
+       * tree-object-size.c (compute_object_offset, addr_object_size,
+       alloc_object_size, pass_through_call): Likewise.
+       * tree-pretty-print.c (op_symbol, print_call_name,
+       print_struct_decl, do_niy): Likewise.
+       * tree.h (fold_undefer_overflow_warnings, multiple_of_p,
+       debug_fold_checksum): Likewise.
+
+2007-09-04  Steven Bosscher  <steven@gcc.gnu.org>
+
+       PR middle-end/33029
+       * lower-subreg.c (resolve_clobber): If we remove a REG_LIBCALL
+       note, remove the associated REG_RETVAL note.
+
+2007-09-04  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * config.gcc (powerpc*-*-*): Install
+       spu2vmx.h, vec_types.h, and si2vmx.h headers.
+       * config/rs6000/spu2vmx.h: New header.
+       * config/rs6000/si2vmx.h: New header.
+       * config/rs6000/vec_types.h: New header.
+
+2007-09-05  Ben Elliston  <bje@au.ibm.com>
+
+       * varasm.c (initializer_constant_valid_p): Fix comment typo.
+
+2007-09-05  Ben Elliston  <bje@au.ibm.com>
+
+       * config/rs6000/ppu_intrinsics.h (__ldarx): Use `Z' constraint,
+       not `m' for *ptrp.
+       (__stdcx): Make asm volatile.
+       (__stwcx, __stdcx): Return only 0 or 1.
+
+2007-09-05  Jan Hubicka  <jh@suse.cz>
+
+       Revert:
+
+       2007-09-04  Jan Hubicka  <jh@suse.cz>
+       * tree-tailcall.c (eliminate_tail_call): Expect unrenamed return value.
+
+       2007-09-04  Richard Guenther  <rguenther@suse.de>
+       * tree-ssa-operands.c (add_virtual_operand): Only mark
+       stores as has_volatile_ops if alias information is not available.
+
+2007-09-05  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/rs6000/tramp.asm: Include config.h.
+       Check __PIC__ or __pic__ macro instead of SHARED.
+
+       PR rtl-optimization/32300
+       * see.c (see_copy_insn): New function.
+       (see_def_extension_not_merged, see_merge_one_use_extension,
+       see_merge_one_def_extension): Use it.  Avoid changing
+       PREV_INSN/NEXT_INSN chains directly, insted emit insns
+       into sequences.  Call df_insn_delete on temporary insns
+       that won't be emitted into the insn stream.
+       (rest_of_handle_see): Turn off DF_DEFER_INSN_RESCAN
+       and run df_process_deferred_rescans () before run_fast_dce.
+
+       PR tree-optimization/33017
+       * tree-data-ref.c (split_constant_offset) <case SSA_NAME>: Don't
+       recurse for pure or const function calls.
+
+2007-09-04  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+
+       * c-format.c: Include alloc-pool.h.
+       (check_format_info_main): New argument fwt_alloc.  Use allocation
+       pool instead of GC.  Remove GC deallocation code.
+       (check_format_arg): Create allocation pool, pass it to
+       check_format_info_main and free it afterwards.
+       * Makefile.in (c-format.o): Add alloc-pool.h dependency.
+
+2007-09-05  Ben Elliston  <bje@au.ibm.com>
+
+       * config/rs6000/ppu_intrinsics.h (__protected_stream_count):
+       Rename count macro arugment for clarity.
+       (__protected_unlimited_stream_set): Pass UG=1 to __dcbt_TH1000.
+       (__protected_stream_set): Likewise, pass 0.
+
+2007-09-04  Jan Hubicka  <jh@suse.cz>
+
+       * tree-tailcall.c (eliminate_tail_call): Expect unrenamed return value.
+
+2007-09-04  Jan Hubicka  <jh@suse.cz>
+
+       * invoke.texi (-finline-small-functions): Document.
+       * ipa-inline.c (cgraph_default_inline_p): Do not use DECL_INLINE
+       when deciding what is inlinable.
+       (cgraph_decide_recursive_inlining): Handle flag_inline_functions.
+       (cgraph_decide_inlining_of_small_function): Handle new flags.
+       (cgraph_decide_inlining_incrementally): Likewise.
+       * opts.c (decode_options): Enable flag_inline_small_functions at -O2
+       * common.opt (finline-small-functions): New.
+       * Makefile.in (build/gengtype.o-warn): Work around PR29478
+
+2007-09-04  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-operands.c (add_virtual_operand): Only mark
+       stores as has_volatile_ops if alias information is not available.
+
+2007-09-04  Andrew Haley  <aph@redhat.com>
+
+       * config/arm/libgcc-bpabi.ver: Add _Unwind_Backtrace as GCC_4.3.0.
+
+2007-09-04  Andrew Haley  <aph@redhat.com>
+
+       * config/arm/libunwind.S (UNWIND_WRAPPER _Unwind_Backtrace): New.
+       * config/arm/unwind-arm.h (__gnu_Unwind_Backtrace): New.
+       * config/arm/unwind-arm.c (__gnu_Unwind_Backtrace): New.
+
+2007-09-04  Emmanuel Thome  <Emmanuel.Thome@inria.fr>
+
+       PR c++/14178
+       * common.opt: Mention ABI version 2 in comment.
+
+2007-09-04  Jan Hubicka  <jh@suse.cz>
+
+       * optabs.c (debug_optab_libfunc): Update; make available to gdb.
+       (libfunc_entry): New structure.
+       (libfunc_hash): New hashtable.
+       (hash_libfunc): New function.
+       (eq_libfunc): New function.
+       (convert_optab_libfunc): New function.
+       (optab_libfunc): New function.
+       (expand_binop, sign_expand_binop, expand_twoval_binop_libfunc,
+       expand_unop, prepare_cmp_insn, prepare_float_insn, gen_add2_insn,
+       expand_float, expand_fix, new_optab, new_convert_optab):
+        Update for new libfunc API.
+       (init_libfunc, init_integral_libfuncs,
+       init_floating_libfuncs, init_interclass_conv_libfuncs
+       init_intraclass_conv_libfuncs): Remove; reorganize all logic to:
+       (gen_libfunc, gen_int_libfunc, gen_fp_libfunc, gen_int_fp_libfunc,
+       gen_intv_fp_libfunc, gen_interclass_conv_libfunc,
+       gen_int_to_fp_conv_libfunc, gen_ufloat_conv_libfunc,
+       gen_int_to_fp_nondecimal_conv_libfunc, gen_fp_to_int_conv_libfunc,
+       gen_intraclass_conv_libfunc, gen_trunc_conv_libfunc,
+       gen_extend_conv_libfunc): New.
+       (init_one_libfunc): Revamp for hashtables.
+       (set_conv_libfunc): Likewise.
+       (init_optabs): Initialize hashtable; use lazy initialization where
+       possible.
+       * optabs.h (optab_handlers): Move out of GGC.
+       (optab, convert_optab): Move out of GGC; add lazy gen info.
+       (code_to_optab, convert_optab_table, optab_table): Move out of GGC.
+       (optab_libfunc, convert_optab_libfunc): New.
+       * builtins.c (expand_builtin_powi): Update for new API.
+       * expr.c (convert_move): Likewise.
+       * expmed.c (expand_divmod): Likewise.
+
+2007-09-04  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config/rs6000/rs6000.c (rs6000_stack_info): Allocate space for the
+       GOT pointer only if there is a constant pool.  Use the allocated space
+       for SPE also.
+
+2007-09-04  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config/rs6000/linux-unwind.h (ppc_fallback_frame_state): Correct
+       typo for AltiVec.
+
+2007-09-04  Revital Eres  <eres@il.ibm.com>
+           Richard Guenther  <rguenther@suse.de>
+           R. Clint Whaley  <whaley@cs.utsa.edu>
+
+       * doc/invoke.texi (-fassociative-math, -freciprocal-math):
+       Document new flags.
+       * tree-tailcall.c (process_assignment): Use -fassociative-math
+       when reodering operands of floating-point type.
+       * fold-const.c (fold_comparison, fold_binary): Use
+       -fassociative-math and -freciprocal-math instead of
+       -funsafe-math-optimization flag.
+       * toplev.h (set_unsafe_math_optimizations_flags): Declare function.
+       * tree-ssa-math-opts.c (gate_cse_reciprocals): Use
+       -freciprocal-math instead of -funsafe-math-optimizations.
+       * opts.c (set_fast_math_flags): Set -freciprocal-math and
+       -fassociative-math when -ffast-math is set.
+       (set_unsafe_math_optimizations_flags): New Function
+       to set -freciprocal-math and -fassociative-math when
+       -funsafe-math-optimizations is set.
+       (common_handle_option): Call it.
+       * tree-vectorizer.c (vect_is_simple_reduction): Use
+       -fassociative-math when doing reduction on floats.
+       * loop-unroll.c (analyze_insn_to_expand_var): Use
+       -fassociative-math when expanding an accumulator of type float.
+       * simplify-rtx.c (simplify_binary_operation_1): Use
+       -fassociative-math and -freciprocal-math when reordeing operands
+       of floating-point type.
+       * combine.c (combine_simplify_rtx): Likewise.
+       * tree-ssa-reassoc.c (break_up_subtract_bb, reassociate_bb):
+       Likewise.
+       * common.opt (-fassociative-math, -freciprocal-math): New flags.
+
+2007-09-04  Paolo Carlini  <pcarlini@suse.de>
+
+       PR c++/18608
+       * doc/install.texi (--enable-__cxa_atexit): Fix typo.
+
+2007-09-04  Jan Hubicka  <jh@suse.cz>
+
+       * regrename.c(copyprop_hardreg_forward_1): Unshare when doing copyprop.
+
+2007-09-04  Jan Hubicka  <jh@suse.cz>
+
+       * regrename.c (build_def_use): Don't share RTL between MATCH_OPERATOR
+       and corresponding MATCH_DUP.
+
+2007-09-04  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/33187
+       * combine.c (subst): Do not try to simplify X if it represents load
+       of FP constant from the constant pool via float extension.
+
+2007-09-04  Ben Elliston  <bje@au.ibm.com>
+
+       * c-opts.c: Include "tm_p.h".
+       * Makefile.in (c-opts.o): Add $(TM_P_H) as a dependency.
+
+2007-09-04  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33291
+       * tree-pretty-print.c (dump_generic_node): Dump all
+       qualifiers for pointer types, not only first.  Dump
+       qualifiers for aggregate types as well.
+       * tree-ssa-ccp.c (maybe_fold_offset_to_array_ref): Always
+       use the canonical type for building ARRAY_REFs.
+       * gimplify.c (canonicalize_addr_expr): Clean up.  The
+       correct validness check is compatibility of the pointer
+       types.  Always use the canonical type for building
+       ARRAY_REFs and ADDR_EXPRs.
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr): Revert
+       change that disabled propagation of ADDR_EXPRs into statements
+       with volatile ops.
+
+2007-09-03  Zack Weinberg  <zack@codesourcery.com>
+
+       * config/arm/arm.md (mulsidi3, umulsidi3, mulsi3_highpart)
+       (umulsi3_highpart): Make into expanders; existing insns are
+       now named *[insn]_nov6.  Add stars to existing [insn]_v6
+       counterparts' names.
+
+2007-09-03  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * Makefile.in (DRIVER_DEFINES, gcc.o, gccspec.o, protoize.o)
+       (unprotoize.o): Remove SHLIB_MULTILIB.
+
+2007-09-03  Eric Weddington  <eweddington@cso.atmel.com>
+
+       * doc/extend.texi: Document progmem attribute for AVR.
+
+2007-09-03  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/28902
+       * config/avr/avr.h (TARGET_VTABLE_ENTRY_ALIGN): Define.
+
+2007-09-03  Zack Weinberg  <zack@codesourcery.com>
+
+       * optabs.c (expand_ffs): Initialize val and defined_at_zero
+       to avoid warnings.
+
+       * optabs.c: Remove unnecessary forward declarations.
+       (expand_unop_direct): New, broken out of expand_unop.
+       (expand_doubleword_clz): New.
+       (expand_ctz): Move above expand_ffs.  Use
+       start_sequence, end_sequence, add_equal_note, and
+       expand_unop_direct.  Add more commentary.
+       (expand_ffs): Try both ctz optab and expand_ctz.
+       Generate a test and branch if the hardware doesn't give us
+       a useful value for input zero.  Style improvements similar to
+       expand_ctz.
+
+       * config/arm/arm.md (ffssi2, ctzsi2): Delete.
+
+2007-09-03  Zack Weinberg  <zack@codesourcery.com>
+
+       * config.gcc: Delete stanza for arm-semi-aof and
+       armel-semi-aof targets.
+       * config/arm/arm-protos.h
+       * config/arm/arm.c
+       * config/arm/arm.h: Delete all #ifdef AOF_ASSEMBLER blocks;
+       make all #ifndef AOF_ASSEMBLER blocks unconditional.  Also
+       delete aof_pic_label and remove mention of AOF in comments.
+       * config/arm/arm.md: Delete patterns used only for AOF assembly.
+       * config/arm/aof.h
+       * config/arm/semiaof.h
+       * config/arm/t-semi: Delete file.
+
+2007-09-03  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * system.h (CONST_CAST2, CONST_CAST_TREE, CONST_CAST_RTX,
+       CONST_CAST_BB): New macros for type-specific casts.
+       (CONST_CAST): Add a TYPE parameter and define it in terms of
+       CONST_CAST2.
+
+       * c-decl.c (c_make_fname_decl): Supply a TYPE for CONST_CAST.
+       * c-lex.c (cb_ident, lex_string): Likewise,
+       * c-typeck.c (free_all_tagged_tu_seen_up_to): Likewise,
+       * config/i386/i386.c (ix86_function_regparm,
+       ix86_function_sseregparm): Use CONST_CAST_TREE.
+       * config/mmix/mmix.c (mmix_encode_section_info): Supply a TYPE for
+       CONST_CAST.
+       * gcc.c (set_spec, read_specs, for_each_path, execute, do_spec_1,
+       give_switch, set_multilib_dir): Likewise,
+       * gengtype-parse.c (string_seq, typedef_name): Likewise,
+       * gimple-low.c (block_may_fallthru): Use CONST_CAST_TREE.
+       * jump.c (reversed_comparison_code_parts): Use CONST_CAST_RTX.
+       * passes.c (execute_one_pass): Supply a TYPE for CONST_CAST.
+       * prefix.c (update_path): Likewise,
+       * pretty-print.c (pp_base_destroy_prefix): Likewise,
+       * rtlanal.c (keep_with_call_p): Use CONST_CAST_RTX.
+       * tree-cfg.c (tree_can_merge_blocks_p,
+       tree_block_ends_with_condjump_p): Use CONST_CAST_BB.
+       * tree-eh.c (lookup_stmt_eh_region_fn): USe CONST_CAST_TREE.
+       * tree.c (build_string): Supply a TYPE for CONST_CAST.
+       (attribute_list_contained): Use CONST_CAST_TREE.
+
+2007-09-03  Krister Walfridsson  <cato@df.lth.se>
+
+       * config/netbsd-elf.h (USE_LD_AS_NEEDED): Define.
+
+2007-09-03  Richard Sandiford  <richard@codesourcery.com>
+
+       PR middle-end/33290
+       * optabs.c (avoid_expensive_constant): Canonicalize CONST_INTs
+       before forcing them into a register.
+
+2007-09-03  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.md (fetchop_bit): Use define_code_iterator
+       rather than define_code_macro.
+
+2007-09-03  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
+
+       * gcc.c (xputenv): New function.
+       (putenv_from_prefixes): Use xputenv instead of putenv.
+       (process_command): Use xputenv instead of putenv.
+       (set_collect_gcc_options): Use xputenv instead of putenv.
+       (main): Use xputenv instead of putenv.
+
+2007-09-03  Jesper Nilsson  <jesper.nilsson@axis.com>
+
+       * config/cris/cris.h (TARGET_HAS_SWAP): Defined to describe
+       availability of swap instruction.
+       * config/cris/cris.md (bswapsi2): Implement using swap instruction.
+
+2007-09-03  Revital Eres  <eres@il.ibm.com>
+
+       * doc/invoke.texi (-fmodulo-sched-allow-regmoves): Update
+       Documentation.
+
+2007-09-03  Vladimir Yanovsky  <yanov@il.ibm.com>
+           Ayal Zaks  <zaks@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * modulo-sched.c (ps_insert_empty_row, verify_partial_schedule,
+       compute_split_row): New functions.
+       (ps_unschedule_node): Remove.
+       (normalize_sched_times): Iterate over the already scheduled
+       insns instead of the number of nodes.
+       (MAX_SPLIT_NUM): New definition.
+       (sms_schedule_by_order): Change the scheduling heuristic to
+       avoid useless increases of initiation interval ii.
+       (get_sched_window): Add dump printouts.
+
+2007-09-02  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/mips.md (UNSPEC_COMPARE_AND_SWAP, UNSPEC_SYNC_OLD_OP,
+       UNSPEC_SYNC_NEW_OP, UNSPEC_SYNC_EXCHANGE): New define_constants.
+       (optab, insn): Add more attributes.
+       (fetchop_bit): New code macro.
+       (immediate_insn): New code macro attribute.
+       (sync): Change condition to ISA_HAS_SYNC.
+       (rdhwr): Change predicate for operand 0 to register_operand.
+       (memory_barrier): New expand.
+       (sync_compare_and_swap<mode>, sync_add<mode>, 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>): New insns.
+       * config/mips/mips.h (ISA_HAS_SYNC, ISA_HAS_LL_SC): New ISA predicates.
+       (MIPS_COMPARE_AND_SWAP, MIPS_SYNC_OP, MIPS_SYNC_OLD_OP,
+       MIPS_SYNC_NEW_OP, MIPS_SYNC_NAND, MIPS_SYNC_OLD_NAND,
+       MIPS_SYNC_NEW_NAND, MIPS_SYNC_EXCHANGE): New Macros.
+       
+2007-09-03  Jesper Nilsson  <jesper.nilsson@axis.com>
+           Hans-Peter Nilsson  <hp@axis.com>
+
+       * config/cris/cris.h (TARGET_HAS_LZ, CLZ_DEFINED_VALUE_AT_ZERO):
+       Defined to describe availability and behavior of CLZ.
+       * config/cris/cris.md (clzsi2): Implement using lz instruction.
+       * config/cris/cris.opt: Tweak comment for "-metrax4".
+       * config/cris/arit.c (LZ): When defined, define as __builtin_clz.
+       * longlong.h [__CRIS__ && __CRIS_arch_version >= 3]
+       (count_leading_zeros): Define.
+
+2007-09-01  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+
+       * ggc-page.c (ggc_pch_read): Call validate_free_objects.
+
+2007-09-02  Joseph Myers  <joseph@codesourcery.com>
+
+       PR c/29237
+       PR middle-end/33272
+       * c-decl.c (grokdeclarator): Apply qualifiers to type of parameter
+       decayed from array.
+
+2007-09-01  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/arm/arm.c, config/rs6000/ppu_intrinsics.h,
+       config/spu/spu.c, df-scan.c, fixed-value.c, fold-const.c,
+       ginclude/tgmath.h, haifa-sched.c, optabs.c, recog.c,
+       sched-deps.c, sched-int.h, system.h, target.h,
+       tree-ssa-live.c, tree-vect-transform.c, tree-vectorizer.c,
+       tree.def: Fix comment typos.
+
+2007-09-01  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (TARGET_DEFAULT_TARGET_FLAGS): Remove.
+       (override_options): Turn on -mstrict-align on non-ColdFire
+       targets.
+       * config/m68k/m68k.h (BIGGEST_ALIGNMENT): Update a comment.
+
+2007-09-01  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * c-common.c (const_strip_array_types): Delete.
+       * c-common.h (const_strip_array_types): Likewise.
+       * emit-rtl.c (const_next_insn, const_previous_insn,
+       const_next_nonnote_insn, const_prev_nonnote_insn,
+       const_next_real_insn, const_prev_real_insn,
+       const_next_active_insn, const_prev_active_insn, const_next_label,
+       const_prev_label): Delete.
+       * gimple-low.c (block_may_fallthru): Use expr_last.
+       * jump.c (reversed_comparison_code_parts): Use prev_nonnote_insn.
+       * rtl.h (const_previous_insn, const_next_insn,
+       const_prev_nonnote_insn, const_next_nonnote_insn,
+       const_prev_real_insn, const_next_real_insn,
+       const_prev_active_insn, const_next_active_insn, const_prev_label,
+       const_next_label): Delete.
+       * rtlanal.c (keep_with_call_p): Use next_nonnote_insn.
+       * system.h (CONST_CAST): Update comment.
+       * tree-cfg.c (tree_can_merge_blocks_p): Use last_stmt.
+       (const_first_stmt, const_last_stmt): Delete.
+       (tree_block_ends_with_condjump_p): Use last_stmt.
+       * tree-flow.h (const_first_stmt, const_last_stmt): Delete.
+       * tree-iterator.c (const_expr_first, const_expr_last,
+       const_expr_only): Delete.
+       * tree.c (const_lookup_attribute): Likewise.
+       (attribute_list_contained): Use lookup_attribute.
+       * tree.h (const_lookup_attribute, const_expr_first,
+       const_expr_last, const_expr_only): Delete.
+
+2007-09-01  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-alias.c (create_name_tags): Use TYPE_VOLATILE
+       instead of TREE_THIS_VOLATILE.
+       * tree-ssa-operands.c (add_virtual_operand): Do not set
+       has_volatile_ops.  Do not check s_ann for NULL.
+       (get_indirect_ref_operands): Likewise.
+       (get_expr_operands): Likewise.  For all reference trees
+       set has_volatile_ops based on TREE_THIS_VOLATILE.  Also
+       check base of reference for TREE_THIS_VOLATILE.
+
+2007-09-01  Richard Guenther  <rguenther@suse.de>
+
+       * tree-cfg.c (verify_gimple_expr): Fix check for conversions
+       between integral types.  Also allow conversions between
+       pointer types.
+
+2007-08-31  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * optabs.c (prepare_float_lib_cmp): Use
+       libgcc_cmp_return_mode instead of word_mode.
+       * config/dfp-bit.h: Likewise.
+       * config/fp-bit.h: Likewise.
+       * config/spu/spu.c (spu_libgcc_cmp_return_mode):
+       New function.
+       (spu_libgcc_shift_count_mode): New function.
+       (TARGET_LIBGCC_CMP_RETURN_MODE): Define.
+       (TARGET_LIBGCC_SHIFT_COUNT_MODE): Define.
+
+2007-08-31  Joseph Myers  <joseph@codesourcery.com>
+
+       * tree-pretty-print.c: Include output.h.
+       (dump_decl_name, dump_generic_node): Use %wd with pp_printf, not
+       HOST_WIDE_INT_PRINT_DEC.
+       * Makefile.in (tree-pretty-print.o): Add dependency on output.h.
+
+2007-08-31  Zdenek Dvorak  <ook@ucw.cz>
+
+       PR rtl-optimization/33224
+       * loop-iv.c (latch_dominating_def): Check that the definition belongs
+       to the analysed region.
+
+2007-08-31  Richard Guenther  <rguenther@suse.de>
+
+       * function.c (allocate_struct_function): Do not set
+       current_function_returns_pointer.
+       * function.h (struct var_refs_queue): Remove.
+       (struct simple_obstack_stack): Likewise.
+       (struct function): Remove fixup_var_refs_queue member.
+       Remove returns_pointer flag.
+       (current_function_returns_pointer): Remove define.
+
+2007-08-31  Nick Clifton  <nickc@redhat.com>
+
+       * tree-ssa-coalesce.c (compare_pairs): Use the elements as
+       secondary keys in order to obtain a stable sort.
+
+2007-08-31  Nick Clifton  <nickc@redhat.com>
+
+       PR target/33132
+       * config/m32r/constraints.md: Add W constraint for integer zero.
+       * config/m32r/m32r.md (get_pc): Use W and i constraints.
+       Fix length calculation by using alternatives.
+
+2007-08-31  Richard Sandiford  <richard@codesourcery.com>
+
+       * optabs.c (shift_optab_p, commutative_optab_p): New functions,
+       split out from expand_binop.
+       (avoid_expensive_constant): New function.
+       (expand_binop_directly): Remove commutative_op argument and
+       (expand_binop_directly): Remove commutative_op argument and
+       call cummutative_optab_p instead.  Do not change op0 or op1
+       when swapping xop0 and xop1.  Apply avoid_expensive_constant
+       to each argument after potential swapping.  Enforce the
+       canonical order of commutative operands.
+       (expand_binop): Use shift_optab_p and commutative_optab_p.
+       Update the calls to expand_binop_directly.  Only force constants
+       into registers when widening an operation.  Only swap operands
+       once a direct expansion has been rejected.
+       (expand_twoval_binop): Only force constants into registers when
+       using a direct expansion.
+
+2007-08-31  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * sched-deps.c (update_dep): Mark arguments with ATTRIBUTE_UNUSED.
+       (sched_analyze_insn): Don't postprocess speculative dependencies when
+       target has no scheduling.
+       * tree-vect-transform.c (vect_estimate_min_profitable_iters): Fix
+       'uninitialized' warning.
+
+2007-08-31  Richard Guenther  <rguenther@suse.de>
+
+       * tree.c (build_complex_type): Always set TYPE_NAME for
+       comples types.
+
+2007-08-31  Olivier Hainque  <hainque@adacore.com>
+
+       * config/rs6000/xcoff.h (XCOFF_CSECT_DEFAULT_ALIGNMENT_STR): New
+       internal macro. Default alignment factor for csect directives, chosen
+       to match what BIGGEST_ALIGNMENT allows.
+       (DATA_SECTION_ASM_OP): Use it.
+       * config/rs6000/rs6000.c
+       (rs6000_xcoff_output_readonly_section_asm_op):
+       Use XCOFF_CSECT_DEFAULT_ALIGNMENT_STR.
+       (rs6000_xcoff_output_readwrite_section_asm_op): Likewise.
+       
+2007-08-31  Olivier Hainque  <hainque@adacore.com>
+
+       * dbxout.c (dbxout_block): Move declaration within the first
+       #if defined (DBX_DEBUGGING_INFO) block.  Rearrange another such
+       block to include the definition, together with the associated
+       helpers.
+
+2007-08-31  David Edelsohn  <edelsohn@gnu.org>
+           Revital Eres  <eres@il.ibm.com>
+
+       * doc/invoke.texi (-mpaired): Document flag.
+       * config.gcc: Include paired.h in powerpc extra_headers and
+       750cl.h in powerpc-*-linux*paired*.
+       * config/rs6000/rs6000.opt (-mpaired): New flag.
+       * config/rs6000/rs6000.c (paired_init_builtins,
+       paired_expand_builtin, paired_expand_lv_builtin,
+       paired_expand_stv_builtin, paired_expand_predicate_builtin):
+       New functions to support the paired single builtin functions.
+       (rs6000_hard_regno_mode_ok): Handle PAIRED_VECTOR_MODE.
+       (def_builtin, bdesc_3arg, bdesc_2arg, bdesc_1arg): Add paired
+       single builtins.
+       (bdesc_paired_preds): New structure for paired predicate
+       instructions.
+       (rs6000_expand_builtin): Expand paired single builtins.
+       (rs6000_init_builtins): Init paired single builtins.
+       (rs6000_common_init_builtins): Add v2sf_ftype_v2sf_v2sf_v2sf.
+       Rename v2sf_ftype_v2sf_v2sf to v2sf_ftype_v2sf_v2sf_spe
+       and v2sf_ftype_v2sf_spe to v2sf_ftype_v2sf.  Add new types
+       v2sf_ftype_v2sf_v2sf and v2sf_ftype_v2sf.
+       (rs6000_vector_mode_supported_p): Support paired vector mode.
+       * config/rs6000/rs6000.h: (UNITS_PER_PAIRED_WORD,
+       PAIRED_VECTOR_MODE, PAIRED_SIMD_REGNO_P, TARGET_PAIRED_FLOAT):
+       New.
+       (LOCAL_ALIGNMENT): Handle PAIRED_VECTOR_MODE.
+       (DATA_ALIGNMENT): Likewise.
+       (UNITS_PER_SIMD_WORD): Handle PAIRED_VECTOR_MODE.
+       (rs6000_builtins): Add PAIRED builtins.
+       * config/rs6000/rs6000.md: Include paired.md.
+       * config/rs6000/paired.h: New.
+       * config/rs6000/paired.md: New.
+       * config/rs6000/750cl.h: New.
+       * config/rs6000/spe.md: Recognize movv2sf instruction for 750cl.
+
+2007-08-30  Ollie Wild  <aaw@google.com>
+
+       * c-opts.c (c_common_handle_option): Support -fno-directives-only.
+       * gcc.c (default_compilers): Add -fno-directives-only to
+       @assembler-with-cpp.
+
+2007-08-30  Sandra Loosemore  <sandra@codesourcery.com>
+
+       PR middle-end/33211
+
+       * regclass.c (initial_fixed_regs): Revert previous change and make
+       it const again.
+       (initial_call_used_regs): Likewise.
+       (initial_call_really_used_regs): Delete, reverting previous addition.
+       (initial_reg_names): Likewise.
+       (init_reg_sets): Revert previous change.
+       (saved_fixed_regs): New.
+       (saved_call_used_regs): New.
+       (saved_call_really_used_regs): New.
+       (saved_reg_names): New.
+       (save_register_info): New.
+       (restore_register_info): New.
+       (init_reg_sets_1): Replace reset of register info with call to
+       restore_register_info.
+       * rtl.h (save_register_info): Declare.
+       * toplev.c (backend_init): Call save_register_info.
+
+2007-08-30  Laurynas Biveinis  <laurynas.biveinis@gmail.com>
+
+       * tree-ssa-propagate.c (set_rhs): Remove the copied annotation
+       from the original statement.
+
+2007-08-30  Chao-ying Fu  <fu@mips.com>
+
+       * c-lex.c (interpret_fixed): Declare.
+       (interpret_float): Process _Fract and _Accum.
+       (interpret_fixed): New function.
+       * final.c (output_addr_const): Process CONST_FIXED.
+       * simplify-rtx.c (simplify_const_unary_operation): Handle US_NEG.
+       (simplify_binary_operation_1): Handle US_ASHIFT, SS_MULT, US_MULT,
+       SS_DIV, US_DIV.
+       (simplify_const_binary_operation): Handle SS_MULT, US_MULT, SS_DIV,
+       US_DIV, US_ASHIFT.
+       (simplify_immed_subreg): Support CONST_FIXED.
+       Process MODE_FRACT, MODE_UFRACT, MODE_ACCUM, MODE_UACCUM.
+       (simplify_subreg): Support CONST_FIXED.
+
+2007-08-30  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * config/rs6000/ppu_intrinsics.h: New file.
+       * config.gcc (powerpc*-*-* <extra_headers>): Install
+       ppu_intrinsics.h.
+
+2007-08-30  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * cfg.c (dump_flow_info): Change to also print entry and exit
+       block info.
+       * print-rtl.c (print_rtl_single): Allow to print rtl with
+       -fdump-unnumbered.
+       
+2007-08-30  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * df-core.h (df_dump_region): New function.
+       * df.h (df_dump_region): New function.
+       * loop-invariant.c (find_defs): Add call to df_dump_region.
+       * loop-iv.c (iv_analysis_loop_init): Changed call from df_dump to
+       df_dump_region.
+       
+2007-08-30  Jakub Jelinek  <jakub@redhat.com>
+
+       PR target/33168
+       * config/rs6000/rs6000.c (rs6000_elf_in_small_data_p): Return
+       true if any of the compare_section_name calls returned true,
+       rather than if any returned false.
+
+2007-08-30  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/33199
+       * tree-ssa-structalias.c (handle_lhs_call): New function.
+       (find_func_aliases): In non-IPA mode make sure that for
+       calls that return a pointer we add a constraint for the
+       result to point to anything.
+
+2007-08-30  Richard Guenther  <rguenther@suse.de>
+
+       * doc/invoke.texi (-mveclibabi): Document new target option.
+       * config/i386/i386.opt (-mveclibabi): New target option.
+       * config/i386/i386.c (ix86_veclib_handler): Handler for
+       vectorization library support.
+       (override_options): Handle the -mveclibabi option, initialize
+       the vectorization library handler.
+       (ix86_builtin_vectorized_function): As fallback call the
+       vectorization library handler, if set.
+       (ix86_veclibabi_acml): New static function for ACML ABI style
+       vectorization support.
+
+2007-08-30  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/rs6000/rs6000.c (rs6000_emit_sync): For QI or HI mode
+       used_m, even if it is 32-bit aligned, adjust used_m MEM to have
+       SImode and update m.  Don't run gen_lowpart_common on arbitrary
+       memory address, force it to register first.
+
+       PR middle-end/32758
+       * dce.c (dce_process_block): Don't delete setters of
+       artificially used registers.
+
+2007-08-30  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
+
+       * config/s390/s390.md ("*add<mode>3_alc_carry1_cc",
+       "*add<mode>3_alc_carry1_cconly", "*add<mode>3_alc_carry2_cc",
+       "*add<mode>3_alc_carry2_cconly"): New insn definitions.
+
+2007-08-30  Ulrich Weigand  <Ulrich.Weigand@de.ibm.com>
+
+       * config/s390/s390.c (s390_expand_addcc): Emit canonical alc
+       pattern.
+       * config/s390/s390.md ("*add<mode>3_alc_cc", "*add<mode>3_alc",
+       "addti3", "*adddi3_31z", "*scond<mode>"): Make alc pattern canonical.
+
+2007-08-29  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * system.h: Activate -Wcast-qual as warning-only.
+
+2007-08-29  Paolo Bonzini  <bonzini@gnu.org>
+
+       PR target/33168
+       * config/rs6000/rs6000.c (compare_section_name): New function.
+       (rs6000_elf_in_small_data_p): Compare section prefixes instead
+       of full name.
+
+2007-08-29  Olivier Hainque  <hainque@adacore.com>
+
+       * xcoffout.c: #include debug.h.
+       * Makefile.in (xcoffout.o): Add debug.h dependency.
+
+2007-08-29  Uros Bizjak  <ubizjak@gmail.com>
+
+       * simplify-rtx.c (simplify_binary_operation_1) [VEC_SELECT]:
+       Change CONST_VECTOR_ELT to XVECEXP in elem calculation.
+
+2007-08-29  Richard Guenther  <rguenther@suse.de>
+
+       * tree-pretty-print.c (dump_generic_node): Print
+       label DECL_UID as D.%u.
+       * tree-dfa.c (dump_variable): Print DECL_UID as D.%u.
+
+2007-08-29  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
+
+       * builtin-types.def (BT_FN_PTR_PTR_SIZE): New type.
+       * builtins.def (BUILT_IN_REALLOC): New builtin.
+
+2007-08-29  Douglas Gregor  <doug.gregor@gmail.com>
+
+       PR c++/33194
+       * tree.c (build_type_attribute_qual_variant): Set canonical types
+       on the final, unqualified attribute variant before building the
+       qualified version.
+
+2007-08-29  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin.c (bfin_expand_builtin): Fix the argument
+       order of __builtin_bfin_cmplx_mac and __builtin_bfin_cmplx_msu.
+
+2007-08-29  Jie Zhang  <jie.zhang@analog.com>
+
+       Revert
+       2007-08-29  Jie Zhang  <jie.zhang@analog.com>
+       * config/bfin/bfin.md (composev2hi): Put operands into vector
+       with correct order.
+
+2007-08-29  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin.md (composev2hi): Put operands into vector
+       with correct order.
+
+2007-08-29  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin.c (bfin_expand_call): Inline PLT with l1_text
+       attribute when appropriate.
+       (bfin_handle_l1_text_attribute): New.
+       (bfin_handle_l1_data_attribute): New.
+       (bfin_attribute_table): Add attributes: l1_text, l1_data,
+       l1_data_A and l1_data_B.
+       * doc/extend.texi (node Function Attributes): Document l1_text
+       function attribute.
+       (Variable Attributes): Add Blackfin subsection. Document l1_data,
+       l1_data_A and l1_data_B variable attributes.
+
+2007-08-28  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin.opt (minline-plt): Add.
+       * config/bfin/bfin.c (bfin_expand_call): Inline PLT when emit
+       call to global functions.
+       * doc/invoke.texi (Option Summary): Mention -minline-plt.
+       (Blackfin Options): Document -minline-plt.
+
+2007-08-28  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_get_function_kind): Assert we're never
+       given a non-function.
+       (m68k_ok_for_sibcall_p): Only sibcall functions of the same kind.
+
+2007-08-28  DJ Delorie  <dj@redhat.com>
+
+       * config/sh/sh.c (sh_gimplify_va_arg_expr): Fix sh2a support.
+
+2007-08-28  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * system.h (CONST_CAST): Avoid union for gcc-4.0.x.
+
+2007-08-28  Richard Guenther  <rguenther@suse.de>
+
+       * tree.h (struct tree_function_decl): Increase size of
+       function_code bitfield.
+
+2007-08-28  Nathan Sidwell  <nathan@codesourcery.com>
+           Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/linux.h
+       (M68K_HONOR_TARGET_STRICT_ALIGNMENT): Redefine as 0.
+       * config/m68k/m68k.c (TARGET_RETURN_IN_MEMORY): New.
+       (m68k_return_in_memory): New.
+       * config/m68k/m68k.h (M68K_HONOR_TARGET_STRICT_ALIGNMENT):
+       New.
+
+2007-08-28  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32661
+       * simplify-rtx.c (simplify_binary_operation_1) [VEC_SELECT]:
+       Simplify nested VEC_SELECT (with optional VEC_CONCAT operator as
+       operand) when top VEC_SELECT extracts scalar element.
+       * config/i386/sse.md (*vec_extract_v4si_mem): New pattern.
+       (*vec_extract_v4sf_mem): Ditto.
+
+2007-08-28  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/32370
+       * passes.c (init_optimization_passes): Move pass_df_finish
+       after pass_postreload sublist.
+
+       PR rtl-optimization/33148
+       * simplify-rtx.c (simplify_unary_operation_1): Only optimize
+       (neg (lt X 0)) if X has scalar int mode.
+
+       PR debug/32914
+       * dwarf2out.c (rtl_for_decl_init): If vector decl has CONSTRUCTOR
+       initializer, use build_vector_from_ctor if possible to create
+       VECTOR_CST out of it.  If vector initializer is not VECTOR_CST
+       even after this, return NULL.
+
+2007-08-28  Gabriel Dos Reis  <gdr@integrable-solutions.net>
+
+       * c-pretty-print.c (pp_c_constant): Handle COMPLEX_CST.
+
+2007-08-28  Richard Guenther  <rguenther@suse.de>
+
+       * tree.h (DECL_DISREGARD_INLINE_LIMITS): New.
+       (struct tree_function_decl): Make function_code a bitfield.
+       Add disregard_inline_limits flag.
+       * cgraphunit.c (cgraph_process_new_functions): Check
+       DECL_DISREGARD_INLINE_LIMITS instead of disregard_inline_limits_p.
+       (cgraph_preserve_function_body_p): Likewise.
+       * ipa-inline.c (compute_inline_parameters): Likewise.
+       * c-decl.c (finish_function): Set DECL_DISREGARD_INLINE_LIMITS
+       for GNU C extern inline functions.
+       (merge_decls): Merge DECL_DISREGARD_INLINE_LIMITS.
+       * tree-inline.c (disregard_inline_limits_p): Remove.
+       * tree-inline.h (disregard_inline_limits_p): Likewise.
+       * c-common.c (handle_always_inline_attribute): Set
+       DECL_DISREGARD_INLINE_LIMITS.
+       * langhooks.c (add_builtin_function): Verify the function code
+       fits in the bitfield.
+
+2007-08-28  Mircea Namolaru  <namolaru@il.ibm.com>
+           Vladimir Yanovsky  <yanov@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+           Andrey Belevantsev  <abel@ispras.ru>
+
+       * config/spu/spu.md: Recognize doloop pattern when -fmodulo-sched
+       is set.
+       * modulo-sched.c: Add documentation regarding do-loop.
+       (doloop_register_get): Change number of arguments to support
+       the new do-loop pattern and check whether COUNT_REG has no other
+       occurences in the loop besides in the control part.
+       (duplicate_insns_of_cycles): Do not duplicate the insn which
+       changes count_reg as it is already adjusted.
+       (generate_prolog_epilog): New argument to support the new
+       do-loop pattern.  Change the subtract instruction to use
+       expand_simple_binop.  Call duplicate_insns_of_cycles with new
+       argument.
+       (sms_schedule): Call doloop_register_get and
+       generate_prolog_epilog with new argument.  Do not handle loops
+       with single sets insns with subreg in their lhs.
+       * loop-doloop.c (doloop_optimize): Support for another do-loop
+       pattern.
+       (doloop_condition_get): Gets an instruction instead of a pattern
+       and change the return condition when the do-loop pattern is
+       not parallel.
+       * ddg.c (create_ddg_dep_from_intra_loop_link): Handle only reg
+       deps when considering to not create edges.
+
+2007-08-27  Alexandre Oliva  <aoliva@redhat.com>
+
+       * doc/extend.texi (gnu_inline funtion attribute): Document C++
+       behavior.
+
+2007-08-27  Jason Merrill  <jason@redhat.com>
+
+       PR c++/31337
+       * gimplify.c (gimplify_modify_expr): Discard the assignment of 
+       zero-sized types after calling gimplify_modify_expr_rhs.
+
+2007-08-27  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * regclass.c (init_reg_autoinc): Fix typo.
+
+2007-08-27  Daniel Berlin  <dberlin@dberlin.org>
+       
+       Fix PR tree-optimization/33173
+       * tree-ssa-alias.c (find_used_portions): Fix reversed test.
+
+2007-08-27  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/31385
+       * config/i386/i386.h (VALID_DFP_MODE_P): New.
+       * config/i386/i386.c (ix86_hard_regno_mode_ok): Allow DFP in
+       GPR.
+
+2007-08-27  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+           Nigel Stephens <nigel@mips.com>
+
+       Separate target-specific initialization from general
+       back-end initialization.
+
+       * toplev.c (init_alignments): New, split out from...
+       (process_options): ...here.
+       (backend_init_target): New, split out from...
+       (backend_init): ...here.
+       (lang_dependent_init_target): New, split out from...
+       (lang_dependent_init): ...here.
+       (target_reinit): New.
+       * toplev.h (target_reinit): Declare.
+       * expr.c (init_expr_target): Renamed from init_expr_once, since it
+       now can be called more than once.  Update comments.
+       * expr.h (init_expr_target): Likewise.
+       * alias.c (init_alias_target): Renamed from init_alias_once, since it
+       now can be called more than once.  Explicitly zero
+       static_reg_base_value.
+       * emit-rtl.c (init_emit_regs): New, split out from...
+       (init_emit_once): Here.
+       * regclass.c (initial_fixed_regs, initial_call_used_regs): Make
+       non-const, so that changes from command-line arguments can overwrite
+       values provided by the static initializers.
+       (initial_call_really_used_regs): New, used similarly to the above.
+       (initial_reg_names): Likewise.
+       (last_mode_for_init_move_cost): Promoted function-local static to
+       file-scope static to make it accessible outside init_move_cost.
+       (init_reg_sets): Do not initialize fixed_regs and call_used_regs yet.
+       Do not initialize inv_reg_alloc_order yet, either.  Do initialize
+       reg_names since it is needed for parsing command-line options.
+       (init_move_cost): Use last_mode_for_init_move_cost instead of
+       function-local static.
+       (init_reg_sets_1): Initialize fixed_regs, call_used_regs, and
+       call_really_used_regs now.  Reinitialize reg_names.  Also
+       initialize inv_reg_alloc_order.  Zero reg_class_subunion and
+       reg_class_superunion.  Clear losing_caller_save_reg_set.
+       Preserve global registers if called more than once.  Reset
+       move cost, may_move_in_cost, may_move_out_cost, and
+       last_mode_for_init_move_cost.
+       (init_reg_modes_target): Renamed from init_reg_modes_once, since it
+       can now be invoked more than once.  Update comments.
+       (init_regs): Update comments.
+       (fix_register): Update initial_fixed_regs, initial_call_used_regs,
+       and initial_call_really_used_regs, instead of the non-initial 
+       variables.  This allows us to save the command-line register settings
+       after target reinitialization.
+       (init_reg_autoinc): Zero forbidden_inc_dec_classes.
+       * rtl.h (init_emit_regs): Declare.
+       (init_reg_modes_target, init_alias_target): Renamed as described
+       above.
+       * reload1.c (init_reload): Update comments.
+       * optabs.c (init_optabs): Likewise.
+       * cfgloopanal.c (init_set_costs): Explicitly zero target_avail_regs.
+       
+2007-08-26  Chao-ying Fu  <fu@mips.com>
+
+       * rtl.h (XCNMPFV): Preserve const-ness of parameters through use of
+       __typeof().
+
+2007-08-26  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * alias.c (memory_modified_1, memory_modified_in_insn_p):
+       Constify.
+       * basic-block.h (tree_predicted_by_p, rtl_predicted_by_p):
+       Likewise.
+       * bb-reorder.c (copy_bb_p): Likewise.
+       * cfghooks.c (can_remove_branch_p, can_merge_blocks_p,
+       predicted_by_p, can_duplicate_block_p, block_ends_with_call_p,
+       block_ends_with_condjump_p): Likewise.
+       * cfghooks.h (can_remove_branch_p, can_merge_blocks_p,
+       predicted_by_p, can_duplicate_block_p, block_ends_with_call_p,
+       block_ends_with_condjump_p): Likewise.
+       * cfglayout.c (cfg_layout_can_duplicate_bb_p): Likewise.
+       * cfgrtl.c (can_delete_note_p, can_delete_label_p,
+       rtl_can_merge_blocks, cfg_layout_can_merge_blocks_p,
+       rtl_block_ends_with_call_p, rtl_block_ends_with_condjump_p,
+       need_fake_edge_p, rtl_can_remove_branch_p): Likewise.
+       * dbxout.c (dbx_debug_hooks, xcoff_debug_hooks): Use
+       debug_true_const_tree instad of debug_true_tree.
+       * debug.c (do_nothing_debug_hooks): Likewise.
+       * debug.h (ignore_block, debug_true_const_tree): Constify.
+       * dwarf2out.c (stack_adjust_offset, clobbers_queued_reg_save,
+       dwarf2out_ignore_block, is_pseudo_reg, is_tagged_type,
+       decl_ultimate_origin, block_ultimate_origin, lookup_decl_loc,
+       same_dw_val_p, add_ranges, is_subrange_type, type_is_enum,
+       dbx_reg_number, is_based_loc, field_type,
+       simple_type_align_in_bits, simple_decl_align_in_bits,
+       simple_type_size_in_bits, field_byte_offset, insert_float,
+       type_tag, member_declared_type, is_redundant_typedef,
+       secname_for_decl, is_inlined_entry_point): Likewise.
+       * emit-rtl.c (const_next_insn, const_previous_insn,
+       const_next_nonnote_insn, const_prev_nonnote_insn,
+       const_next_real_insn, const_prev_real_insn,
+       const_next_active_insn, const_prev_active_insn, const_next_label,
+       const_prev_label): Likewise.
+       * except.h (lookup_stmt_eh_region_fn, lookup_stmt_eh_region):
+       Likewise.
+       * haifa-sched.c (may_trap_exp, haifa_classify_insn,
+       find_set_reg_weight, no_real_insns_p, find_set_reg_weight,
+       sched_insn_is_legitimate_for_speculation_p): Likewise.
+       * jump.c (reversed_comparison_code_parts,
+       reversed_comparison_code, reversed_comparison, condjump_label):
+       Likewise.
+       * predict.c (rtl_predicted_by_p, tree_predicted_by_p): Likewise.
+       * reg-stack.c (stack_regs_mentioned_p, stack_regs_mentioned):
+       Likewise.
+       * rtl.h (const_previous_insn, const_next_insn,
+       const_prev_nonnote_insn, const_next_nonnote_insn,
+       const_prev_real_insn, const_next_real_insn,
+       const_prev_active_insn, const_next_active_insn, const_prev_label,
+       const_next_label, modified_between_p, modified_in_p,
+       const_note_storeskeep_with_call_p, condjump_label,
+       reversed_comparison, reversed_comparison_code,
+       reversed_comparison_code_parts, memory_modified_in_insn_p,
+       stack_regs_mentioned): Likewise.
+       * rtlanal.c (modified_between_p, modified_in_p, const_note_stores,
+       keep_with_call_p): Likewise.
+       * sched-deps.c (deps_may_trap_p, sched_get_condition,
+       conditions_mutex_p, sched_insns_conditions_mutex_psd_next_list,
+       sd_lists_size, sd_lists_empty_p): Likewise.
+       * sched-int.h (sched_insns_conditions_mutex_p,
+       haifa_classify_insn, no_real_insns_p,
+       sched_insn_is_legitimate_for_speculation_p, sd_next_list,
+       sd_lists_size, sd_lists_empty_p): Likewise.
+       * sdbout.c (sdb_debug_hooks): Likewise.
+       * tree-cfg.c (tree_can_merge_blocks_p, is_ctrl_altering_stmt,
+       stmt_ends_bb_p, tree_can_remove_branch_p, tree_can_duplicate_bb_p,
+       -tree_block_ends_with_call_p, tree_block_ends_with_condjump_p):
+       Likewise.
+       * tree-eh.c (lookup_stmt_eh_region_fn, lookup_stmt_eh_region,
+       tree_can_throw_internal): Likewise.
+       * tree-flow-inline.h (phi_nodes): Likewise.
+       * tree-flow.h (phi_nodesstmt_ends_bb_p, is_ctrl_altering_stmt,
+       tree_can_throw_internal, lookup_stmt_eh_region): Likewise.
+       * tree-gimple.c (const_get_call_expr_in): Likewise.
+       * tree-gimple.h (const_get_call_expr_in): Likewise.
+       * tree.c (const_lookup_attribute, attribute_list_equal,
+       attribute_list_contained): Likewise.
+       * tree.h (attribute_list_equal, attribute_list_contained,
+       const_lookup_attribute): Likewise.
+       * vmsdbgout.c (vmsdbgout_ignore_block): Likewise.
+
+2007-08-26  Bernhard Fischer  <aldot@gcc.gnu.org>
+
+       * tree-ssa-sccvn.c, tree-ssa-sccvn.h, tree-vn.c,
+       tree-ssa-pre.c: Remove unnecessary trailing whitespace.
+
+2007-08-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/32991
+       * config/alpha/constraints.md: Delete "svn:mime-type" property
+       with svn propdel "svn:mime-type".
+
+2007-08-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR middle-end/33181
+       * ifcvt.c (noce_get_alt_condition): Make sure that the previous
+       non NOTE insn doesn't cross basic block.
+       (noce_try_abs): Likewise.
+       (noce_process_if_block): Likewise.
+
+2007-08-26  David Edelsohn  <edelsohn@gnu.org>
+
+       PR target/33151
+       * config/rs6000/predicates.md (offsettable_mem_operand): Memory
+       operand without auto-inc-dec.
+       * config/rs6000/rs6000.md (floatsidf2_internal): Use
+       offsettable_mem_operand.
+       (floatunssidf2_internal): Same.
+       (fix_truncdfsi2_internal): Same.
+       (floatsidf_ppc64): Same.
+       (floatunssidf_ppc64): Same.
+       (fix_trunctfsi2_internal): Same.
+
+2007-08-26  Bernhard Fischer  <aldot@gcc.gnu.org>
+
+       PR bootstrap/30620
+       * Makefile.in (libbackend.o): Add gcov-iov.h dependency and
+       pass defines needed for version.c.
+
+2007-08-25  Joseph Myers  <joseph@codesourcery.com>
+
+       * configure.ac (--debug-prefix-map check): Change assembler
+       version presumed to have feature to 2.18.
+       * configure: Regenerate.
+
+2007-08-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * c-common.c (vector_types_convertible_p,
+       decl_with_nonnull_addr_p, c_promoting_integer_type_p,
+       self_promoting_args_p): Constify.
+       * c-common.h (has_c_linkage, decl_with_nonnull_addr_p,
+       c_promoting_integer_type_p, self_promoting_args_p,
+       anon_aggr_type_p, vector_types_convertible_p): Likewise.
+       * c-decl.c (anon_aggr_type_p): Likewise.
+       * * c-dump.c (dump_stmt): Likewise.
+       * c-objc-common.c (has_c_linkage): Likewise.
+       * c-tree.h (same_translation_unit_p): Likewise.
+       * c-typeck.c (null_pointer_constant_p,
+       tagged_types_tu_compatible_p, function_types_compatible_p,
+       type_lists_compatible_p, lvalue_or_else, lvalue_p,
+       comptypes_internal, struct tagged_tu_seen_cache,
+       same_translation_unit_p, alloc_tagged_tu_seen_cache,
+       c_size_in_bytes): Likewise.
+       * ggc-common.c (compare_ptr_data, hash_descriptor, eq_descriptor,
+       hash_ptr, eq_ptr): Likewise.
+       * langhooks-def.h (lhd_decl_ok_for_sibcall,
+       LANG_HOOKS_OMP_PRIVATIZE_BY_REFERENCE): Likewise.
+       * langhooks.c (lhd_decl_ok_for_sibcall): Likewise.
+       * langhooks.h (ok_for_sibcall, omp_privatize_by_reference):
+       Likewise.
+       * optabs.c (optab_for_tree_code): Likewise.
+       * optabs.h (optab_for_tree_code): Likewise.
+       * rtl.h (simplify_rtx): Likewise.
+       * simplify-rtx.c (simplify_rtx): Likewise.
+       * tree-dump.c (queue, queue_and_dump_index, queue_and_dump_type,
+       dump_flag, dump_node): Likewise.
+       * tree-dump.h (struct dump_info, dump_stmt, queue_and_dump_index,
+       queue_and_dump_type, dump_flag): Likewise.
+       * tree-flow.h (vect_can_force_dr_alignment_p): Likewise.
+       * tree-pass.h (dump_node): Likewise.
+       * tree-vectorizer.c (vect_can_force_dr_alignment_p,
+       supportable_narrowing_operation): Likewise.
+       * tree-vectorizer.h (vect_can_force_dr_alignment_p,
+       supportable_narrowing_operation): Likewise.
+       * tree-vrp.c (needs_overflow_infinity, supports_overflow_infinity,
+       is_negative_overflow_infinity, is_positive_overflow_infinity,
+       is_overflow_infinity, vrp_val_is_max, vrp_val_is_min,
+       nonnull_arg_p, get_value_range, vrp_operand_equal_p,
+       update_value_range, add_equivalence, ssa_name_nonnegative_p,
+       ssa_name_nonzero_p, fp_predicate): Likewise.
+       * tree.c (auto_var_in_fn_p, empty_body_p): Likewise.
+       * tree.h (empty_body_p, auto_var_in_fn_p, ssa_name_nonzero_p,
+       ssa_name_nonnegative_p): Likewise.
+
+2007-08-25  Hans Kester  <hans.kester@ellips.nl>
+
+       * config.gcc : Add x86_64-elf target.
+
+2007-08-25  Jakub Jelinek  <jakub@redhat.com>
+
+       * expr.c (store_expr): Fix order of store_by_pieces arguments.
+
+2007-08-24  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens <nigel@mips.com>
+
+       PR target/11787
+
+       * doc/tm.texi (SET_RATIO, SET_BY_PIECES_P): Document new macros.
+       (STORE_BY_PIECES_P): No longer applies to __builtin_memset.
+       * expr.c (SET_BY_PIECES_P): Define.
+       (can_store_by_pieces, store_by_pieces): Add MEMSETP argument; use
+       it to decide whether to use SET_BY_PIECES_P or STORE_BY_PIECES_P.
+       (store_expr): Pass MEMSETP argument to can_store_by_pieces and
+       store_by_pieces.
+       * expr.h (SET_RATIO): Define.
+       (can_store_by_pieces, store_by_pieces): Update prototypes.
+       * builtins.c (expand_builtin_memcpy): Pass MEMSETP argument to
+       can_store_by_pieces/store_by_pieces.
+       (expand_builtin_memcpy_args): Likewise.
+       (expand_builtin_strncpy): Likewise.
+       (expand_builtin_memset_args): Likewise.  Also remove special case
+       for optimize_size so that can_store_by_pieces/SET_BY_PIECES_P can
+       decide what to do instead.
+       * value-prof.c (tree_stringops_transform): Pass MEMSETP argument
+       to can_store_by_pieces.
+
+       * config/sh/sh.h (SET_BY_PIECES_P): Clone from STORE_BY_PIECES_P.
+       * config/s390/s390.h (SET_BY_PIECES_P): Likewise.
+
+       * config/mips/mips.opt (mmemcpy): Change from Var to Mask.
+       * config/mips/mips.c (override_options): Make -Os default to -mmemcpy.
+       * config/mips/mips.h (MIPS_CALL_RATIO): Define.
+       (MOVE_RATIO, CLEAR_RATIO, SET_RATIO): Define.
+       (STORE_BY_PIECES_P): Define.
+
+2007-08-24  Tom Tromey  <tromey@redhat.com>
+
+       * varpool.c (varpool_last_needed_node): Fix comment typo.
+       * c-decl.c (duplicate_decls): Fix comment typo.
+       (clone_underlying_type): Update comment.
+
+2007-08-24  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * config/alpha/alpha.c (alpha_mangle_type, decl_has_samegp,
+       alpha_in_small_data_p, alpha_split_complex_arg,
+       alpha_stdarg_optimize_hook, TARGET_ASM_CAN_OUTPUT_MI_THUNK):
+       Constify.
+       * config/arm/arm-protos.h (arm_mangle_type): Likewise.
+       * config/arm/arm.c (arm_comp_type_attributes, arm_mangle_type):
+       Likewise.
+       * config/bfin/bfin.c (funkind, bfin_comp_type_attributes,
+       TARGET_ASM_CAN_OUTPUT_MI_THUNK): Likewise.
+       * config/darwin-protos.h (darwin_binds_local_p): Likewise.
+       * config/darwin.c (darwin_binds_local_p): Likewise.
+       * config/frv/frv.c (frv_string_begins_with, frv_in_small_data_p):
+       Likewise.
+       * config/i386/i386-protos.h (i386_pe_binds_local_p,
+       i386_pe_valid_dllimport_attribute_p): Likewise.
+       * config/i386/i386.c (ix86_function_regparm,
+       ix86_comp_type_attributes, ix86_ms_bitfield_layout_p,
+       x86_can_output_mi_thunk, ix86_mangle_type,
+       TARGET_USE_BLOCKS_FOR_CONSTANT_P): Likewise.
+       * config/i386/winnt.c (i386_pe_valid_dllimport_attribute_p,
+       i386_pe_binds_local_p): Likewise.
+       * config/ia64/ia64.c
+       (ia64_first_cycle_multipass_dfa_lookahead_guard_spec,
+       ia64_needs_block_p, ia64_in_small_data_p, ia64_mangle_type,
+       ia64_invalid_conversion, ia64_invalid_unary_op,
+       ia64_invalid_binary_op, TARGET_ASM_CAN_OUTPUT_MI_THUNK):
+       Likewise.
+       * config/m32c/m32c.c (m32c_comp_type_attributes): Likewise.
+       * config/m32r/m32r.c (m32r_in_small_data_p): Likewise.
+       * config/m68k/m68k.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK): Likewise.
+       * config/mips/mips.c (mips_use_blocks_for_constant_p,
+       mips_in_small_data_p, mips_use_anchors_for_symbol_p,
+       mips_comp_type_attributes, TARGET_ASM_CAN_OUTPUT_MI_THUNK,
+       mips_near_type_p, mips_far_type_p, mips_global_symbol_p,
+       mips_symbol_binds_local_p, mips_classify_symbol): Likewise.
+       * config/pa/pa.c (pa_commutative_p): Likewise.
+       * config/rs6000/rs6000-protos.h (rs6000_elf_in_small_data_p):
+       Likewise.
+       * config/rs6000/rs6000.c (rs6000_invalid_within_doloop,
+       rs6000_ms_bitfield_layout_p, rs6000_mangle_type,
+       rs6000_use_blocks_for_constant_p,
+       rs6000_vector_alignment_reachable, rs6000_is_opaque_type,
+       invalid_arg_for_unprototyped_fn, TARGET_ASM_CAN_OUTPUT_MI_THUNK,
+       TARGET_SPLIT_COMPLEX_ARG, rs6000_elf_in_small_data_p): Likewise.
+       * config/s390/s390.c (s390_mangle_type,
+       TARGET_ASM_CAN_OUTPUT_MI_THUNK, TARGET_INVALID_WITHIN_DOLOOP):
+       Likewise.
+       * config/score/score.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK,
+       th_in_small_data_p): Likewise.
+       * config/sh/sh.c (sh_ms_bitfield_layout_p,
+       sh_dwarf_calling_convention, TARGET_ASM_CAN_OUTPUT_MI_THUNK):
+       Likewise.
+       * config/sparc/sparc.c (sparc_can_output_mi_thunk,
+       sparc_mangle_type): Likewise.
+       * config/spu/spu.c (spu_vector_alignment_reachable): Likewise.
+       * config/xtensa/xtensa.c (TARGET_SPLIT_COMPLEX_ARG): Likewise.
+       * emit-rtl.c (const_fixed_htab_hash, const_fixed_htab_eq):
+       Likewise.
+       * hooks.c (hook_bool_mode_const_rtx_false,
+       hook_bool_mode_const_rtx_true,
+       hook_bool_const_tree_hwi_hwi_const_tree_false,
+       hook_bool_const_tree_hwi_hwi_const_tree_true,
+       hook_int_const_tree_0, hook_int_const_tree_const_tree_1,
+       hook_constcharptr_const_tree_null,
+       hook_constcharptr_const_rtx_null,
+       hook_constcharptr_const_tree_const_tree_null,
+       hook_constcharptr_int_const_tree_null,
+       hook_constcharptr_int_const_tree_const_tree_null): New.
+       (hook_bool_mode_rtx_false, hook_bool_mode_rtx_true,
+       hook_bool_tree_hwi_hwi_tree_false,
+       hook_bool_tree_hwi_hwi_tree_true, hook_int_tree_0,
+       hook_int_tree_tree_1, hook_constcharptr_tree_null,
+       hook_constcharptr_rtx_null, hook_constcharptr_tree_tree_null,
+       hook_constcharptr_int_tree_null,
+       hook_constcharptr_int_tree_tree_null): Delete.
+       (default_can_output_mi_thunk_no_vcall): Constify.
+       * hooks.h (hook_bool_mode_rtx_false, hook_bool_mode_rtx_true,
+       hook_bool_tree_hwi_hwi_tree_false,
+       hook_bool_tree_hwi_hwi_tree_true, hook_int_tree_0,
+       hook_int_tree_tree_1, hook_constcharptr_tree_null,
+       hook_constcharptr_rtx_null, hook_constcharptr_tree_tree_null,
+       hook_constcharptr_int_tree_null,
+       hook_constcharptr_int_tree_tree_null): Delete.
+       (hook_bool_mode_const_rtx_false, hook_bool_mode_const_rtx_true,
+       hook_bool_const_tree_hwi_hwi_const_tree_false,
+       hook_bool_const_tree_hwi_hwi_const_tree_true,
+       hook_int_const_tree_0, hook_int_const_tree_const_tree_1,
+       hook_constcharptr_const_tree_null,
+       hook_constcharptr_const_rtx_null,
+       hook_constcharptr_const_tree_const_tree_null,
+       hook_constcharptr_int_const_tree_null,
+       hook_constcharptr_int_const_tree_const_tree_null): New.
+       (default_can_output_mi_thunk_no_vcall): Constify.
+       * integrate.c (function_attribute_inlinable_p): Likewise.
+       * integrate.h (function_attribute_inlinable_p): Likewise.
+       * jump.c (rtx_renumbered_equal_p): Likewise.
+       * output.h (decl_readonly_section, categorize_decl_for_section,
+       default_use_anchors_for_symbol_p, default_binds_local_p,
+       default_binds_local_p_1): Likewise.
+       * rtl.h (rtx_renumbered_equal_p, decl_default_tls_model):
+       Likewise.
+       * target-def.h (TARGET_ASM_CAN_OUTPUT_MI_THUNK,
+       TARGET_VALID_DLLIMPORT_ATTRIBUTE_P, TARGET_VECTOR_OPAQUE_P,
+       TARGET_COMMUTATIVE_P, TARGET_USE_BLOCKS_FOR_CONSTANT_P,
+       TARGET_COMP_TYPE_ATTRIBUTES,
+       TARGET_FUNCTION_ATTRIBUTE_INLINABLE_P,
+       TARGET_MS_BITFIELD_LAYOUT_P, TARGET_MANGLE_TYPE,
+       TARGET_IN_SMALL_DATA_P, TARGET_INVALID_CONVERSION,
+       TARGET_INVALID_UNARY_OP, TARGET_INVALID_BINARY_OP,
+       TARGET_DWARF_CALLING_CONVENTION): Likewise.
+       * target.h (can_output_mi_thunk, needs_block_p,
+       first_cycle_multipass_dfa_lookahead_guard_spec,
+       vector_alignment_reachable, comp_type_attributes,
+       function_attribute_inlinable_p, ms_bitfield_layout_p, mangle_type,
+       commutative_p, use_blocks_for_constant_p,
+       use_anchors_for_symbol_p, in_small_data_p, binds_local_p,
+       vector_opaque_p, dwarf_calling_convention, stdarg_optimize_hook,
+       invalid_within_doloop, valid_dllimport_attribute_p,
+       split_complex_arg, invalid_arg_for_unprototyped_fn,
+       invalid_conversion, invalid_unary_op, invalid_binary_op):
+       Likewise.
+       * targhooks.c (default_invalid_within_doloop,
+       hook_invalid_arg_for_unprototyped_fn,
+       default_builtin_vector_alignment_reachable): Likewise.
+       (hook_bool_rtx_commutative_p): Delete.
+       (hook_bool_const_rtx_commutative_p): New.
+       * targhooks.h (default_invalid_within_doloop,
+       default_builtin_vector_alignment_reachable,
+       hook_invalid_arg_for_unprototyped_fn): Constify.
+       (hook_bool_rtx_commutative_p): Delete.
+       (hook_bool_const_rtx_commutative_p): New.
+       * varasm.c (bss_initializer_p, decl_default_tls_model,
+       categorize_decl_for_section, decl_readonly_section,
+       default_use_anchors_for_symbol_p, default_binds_local_p,
+       default_binds_local_p_1): Constify.
+
+2007-08-24  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin.h (TARGET_CPU_CPP_BUILTINS): Define
+       __NO_BUILTIN if -fno-builtin.
+
+2007-08-24  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin.c (print_operand): Report error instead of
+       ICE for wrong operand.
+
+2007-08-24  Michael Matz  <matz@suse.de>
+
+       * Makefile.in (GTFILES_H): Use $(patsubst) instead of $(subst).
+
+2007-08-24  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33166
+       * tree-ssa.c (useless_type_conversion_p): Split into a
+       recursive and a non-recursive part.
+       (useless_type_conversion_p_1): New function.
+       * tree-ssa-ccp.c (fold_stmt_r): Make sure that the result
+       from maybe_fold_offset_to_reference is trivially convertible
+       to the desired type before doing the simplification.
+
+2007-08-24  Jakub Jelinek  <jakub@redhat.com>
+
+       * expr.c (store_expr): Optimize initialization of an array
+       with STRING_CST.
+       * expr.h (builtin_strncpy_read_str): New prototype.
+       * builtins.c (builtin_strncpy_read_str): Remove prototype.
+       No longer static.
+
+2007-08-24  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/33157
+       * ifcvt.c (noce_find_if_block): Do not clear if_info.cond_earliest
+       field when initializing if_info structure.
+
+2007-08-24  Richard Guenther  <rguenther@suse.de>
+
+       * Makefile.in (tree-inline.o): Add $(TARGET_H) and $(INTEGRATE_H)
+       dependencies.
+       * c-objc-common.c (c_cannot_inline_tree_fn): Remove.
+       * langhooks.c (lhd_tree_inlining_cannot_inline_tree_fn): Likewise.
+       * tree-inline.c (inlinable_function_p): Fold in common parts of
+       the cannot_inline_tree_fn langhook.
+       * langhooks-def.h (lhd_tree_inlining_cannot_inline_tree_fn): Remove.
+       (LANG_HOOKS_TREE_INLINING_CANNOT_INLINE_TREE_FN): Likewise.
+       (LANG_HOOKS_TREE_INLINING_INITIALIZER): Remove initializer for
+       cannot_inline_tree_fn langhook.
+       * langhooks.h (struct lang_hooks_for_tree_inlining): Remove
+       cannot_inline_tree_fn member.
+
+2007-08-24  Richard Guenther  <rguenther@suse.de>
+
+       * expr.c (get_inner_reference): Do computation of bitoffset
+       from offset in a way we can detect overflow reliably.
+
+2007-08-24  Jie Zhang  <jie.zhang@analog.com>
+
+       * crtstuff.c (USE_PT_GNU_EH_FRAME): Don't define for uClibc.
+
+2007-08-24  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin.opt (mfast-fp): Add.
+       * config/bfin/linux.h (LINK_GCC_C_SEQUENCE_SPEC): Let
+       libbffastfp override libgcc if -mfast-fp.
+       * config/bfin/bfin.h (LINK_GCC_C_SEQUENCE_SPEC): Likewise.
+       * doc/invoke.texi (Option Summary): Mention -mfast-fp.
+       (Blackfin Options): Document -mfast-fp.
+
+2007-08-24  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/32573
+       PR middle-end/32946
+       * tree-data-ref.c (initialize_data_dependence_relation): Clear
+       DDR_SUBSCRIPTS, DDR_DIR_VECTS and DDR_DIST_VECTS at the beginning.
+       (finalize_ddr_dependent): Clear DDR_SUBSCRIPTS after freeing it.
+       (build_classic_dist_vector): Return false rather than true if
+       DDR_ARE_DEPENDENT is non-NULL at the beginning.  Return false
+       if either subscript_dependence_tester_1 or build_classic_dist_vector_1
+       returned false.  Don't call save_dist_v before calling
+       build_classic_dist_vector_1.
+       (free_dependence_relation): Don't guard freeing DDR_SUBSCRIPTS
+       with NULL DDR_ARE_DEPENDENT.  Also free DDR_DIST_VECTS and/or
+       DDR_DIR_VECTS vectors.
+
+2007-08-23  Brian Sidebotham  <brian.sidebotham@gmail.com>
+
+       * configure.ac (leb128): Modify sed statement to work with any
+       binutils version string.
+       * configure: Regenerate
+
+2007-08-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * config/arc/arc-protos.h arc_select_cc_mode, gen_compare_reg):
+       Wrap in RTX_CODE macro guard.
+       * config/arm/pe.c (arm_dllexport_p, arm_dllimport_p,
+       arm_dllexport_name_p, arm_dllimport_name_p, arm_mark_dllexport,
+       arm_mark_dllimport, arm_pe_encode_section_info,
+       arm_pe_unique_section): Use ISO-C function declarations.
+       * config/c4x/c4x-c.c (c4x_parse_pragma, c4x_pr_CODE_SECTION,
+       c4x_pr_DATA_SECTION, c4x_pr_FUNC_IS_PURE,
+       c4x_pr_FUNC_NEVER_RETURNS, c4x_pr_INTERRUPT, c4x_pr_ignored):
+       Likewise.
+       * config/iq2000/iq2000.h (ASM_OUTPUT_SKIP): Fix format warning.
+       * config/m68hc11/m68hc11.h (ASM_OUTPUT_EXTERNAL): Undef before
+       defining.
+       * config/mips/mips.h (ASM_DECLARE_OBJECT_NAME): Fix format
+       warnings.
+       * config/mn10300/mn10300.h (OUTPUT_ADDR_CONST_EXTRA): Likewise.
+       * config/pdp11/pdp11.c (pdp11_output_function_epilogue): Likewise.
+       (register_move_cost): Use ISO-C function declarations.
+       * config/pdp11/pdp11.h (PRINT_OPERAND): Fix format warnings.
+       * config/score/score-protos.h (score_declare_object): Add
+       ATTRIBUTE_PRINTF_4.
+       * config/score/score.h (ASM_DECLARE_OBJECT_NAME): Fix format
+       warnings.
+       * final.c (profile_function): Avoid empty if-bodies.
+       
+       
+       * calls.c (must_pass_in_stack_var_size,
+       must_pass_in_stack_var_size_or_pad): Constify.
+       * config/alpha/alpha-protos.h (function_value): Likewise.
+       * config/alpha/alpha.c (alpha_return_in_memory,
+       alpha_pass_by_reference, function_value,
+       unicosmk_must_pass_in_stack, TARGET_PROMOTE_FUNCTION_ARGS,
+       TARGET_PROMOTE_FUNCTION_RETURN, TARGET_PROMOTE_PROTOTYPES):
+       Likewise.
+       * config/arc/arc.c (arc_return_in_memory, arc_pass_by_reference,
+       TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN,
+       TARGET_PROMOTE_PROTOTYPES): Likewise.
+       * config/arm/arm-protos.h (arm_return_in_memory,
+       arm_pad_arg_upward, arm_function_value): Likewise.
+       * config/arm/arm.c (arm_pass_by_reference,
+       arm_promote_prototypes, arm_return_in_msb, arm_must_pass_in_stack,
+       TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN,
+       arm_function_value, arm_return_in_memory, arm_pad_arg_upward):
+       Likewise.
+       * config/arm/arm.h (ARM_DECLARE_FUNCTION_NAME): Likewise.
+       * config/avr/avr-protos.h (avr_function_value): Likewise.
+       * config/avr/avr.c (avr_return_in_memory,
+       gas_output_limited_string, gas_output_ascii, avr_function_value,
+       avr_return_in_memory): Likewise.
+       * config/bfin/bfin-protos.h (bfin_return_in_memory): Likewise.
+       * config/bfin/bfin.c (bfin_pass_by_reference,
+       bfin_return_in_memory, TARGET_PROMOTE_PROTOTYPES,
+       TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN):
+       Likewise.
+       * config/cris/cris.c (cris_pass_by_reference,
+       TARGET_PROMOTE_FUNCTION_ARGS): Likewise.
+       * config/crx/crx.c (crx_return_in_memory): Likewise.
+       * config/darwin.c (function_base, machopic_function_base_name):
+       Likewise.
+       * config/fr30/fr30.c (fr30_must_pass_in_stack,
+       TARGET_PROMOTE_PROTOTYPES): Likewise.
+       * config/frv/frv.c (frv_must_pass_in_stack): Likewise.
+       * config/h8300/h8300.c (h8300_return_in_memory): Likewise.
+       * config/i386/i386-protos.h (ix86_return_in_memory,
+       ix86_sol10_return_in_memory): Likewise.
+       * config/i386/i386.c (ix86_function_value,
+       ix86_function_sseregparm, ix86_must_pass_in_stack,
+       type_natural_mode, classify_argument, examine_argument,
+       construct_container, ix86_pass_by_reference, function_value_32,
+       function_value_64, ix86_function_value_1, return_in_memory_32,
+       return_in_memory_64, return_in_memory_ms_64,
+       ix86_return_in_memory, ix86_sol10_return_in_memory,
+       TARGET_PROMOTE_PROTOTYPES): Likewise.
+       * config/ia64/ia64-protos.h (ia64_function_value,
+       ia64_hpux_function_arg_padding): Likewise.
+       * config/ia64/ia64.c (hfa_element_mode, ia64_return_in_memory,
+       ia64_function_value, bundle_state_hash, bundle_state_eq_p,
+       ia64_hpux_function_arg_padding): Likewise.
+       * config/iq2000/iq2000-protos.h (function_arg,
+       iq2000_function_value): Likewise.
+       * config/iq2000/iq2000.c (iq2000_return_in_memory,
+       iq2000_pass_by_reference, TARGET_PROMOTE_FUNCTION_ARGS,
+       TARGET_PROMOTE_FUNCTION_RETURN, TARGET_PROMOTE_PROTOTYPES,
+       function_arg, iq2000_function_value): Likewise.
+       * config/m32c/m32c-protos.h (m32c_function_value,
+       m32c_promote_function_return): Likewise.
+       * config/m32c/m32c.c (m32c_pass_by_reference,
+       m32c_promote_prototypes, m32c_promote_function_return,
+       m32c_function_value): Likewise.
+       * config/m32r/m32r.c (m32r_return_in_memory,
+       m32r_pass_by_reference, TARGET_PROMOTE_PROTOTYPES,
+       m32r_in_small_data_p): Likewise.
+       * config/m68hc11/m68hc11-protos.h (m68hc11_function_arg_padding):
+       Likewise.
+       * config/m68hc11/m68hc11.c (m68hc11_return_in_memory,
+       m68hc11_function_arg_padding): Likewise.
+       * config/m68k/m68k-protos.h (m68k_function_value): Likewise.
+       * config/m68k/m68k.c (TARGET_PROMOTE_PROTOTYPES,
+       m68k_function_value): Likewise.
+       * config/mcore/mcore-protos.h (mcore_num_arg_regs,
+       mcore_function_value): Likewise.
+       * config/mcore/mcore.c (handle_structs_in_regs,
+       mcore_return_in_memory, TARGET_PROMOTE_FUNCTION_ARGS,
+       TARGET_PROMOTE_FUNCTION_RETURN, TARGET_PROMOTE_PROTOTYPES,
+       mcore_num_arg_regs, mcore_function_value): Likewise.
+       * config/mips/mips-protos.h (mips_pad_arg_upward,
+       mips_function_value): Likewise.
+       * config/mips/mips.c (mips_fpr_return_fields, mips_return_in_msb,
+       mips_return_in_memory, mips_pass_by_reference, mips_callee_copies,
+       TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN,
+       TARGET_PROMOTE_PROTOTYPES, mips_pad_arg_upward,
+       mips_function_value): Likewise.
+       * config/mmix/mmix-protos.h (mmix_function_outgoing_value):
+       Likewise.
+       * config/mmix/mmix.c (mmix_pass_by_reference,
+       TARGET_PROMOTE_FUNCTION_ARGS, mmix_function_outgoing_value,
+       mmix_encode_section_info): Likewise.
+       * config/mn10300/mn10300-protos.h (mn10300_function_value):
+       Likewise.
+       * config/mn10300/mn10300.c (mn10300_return_in_memory,
+       mn10300_pass_by_reference, TARGET_PROMOTE_PROTOTYPES,
+       mn10300_function_value): Likewise.
+       * config/mt/mt-protos.h (mt_function_value): Likewise.
+       * config/mt/mt.c (mt_pass_by_reference, mt_function_value,
+       mt_pass_in_stack, TARGET_PROMOTE_PROTOTYPES): Likewise.
+       * config/pa/pa-protos.h (function_arg_padding, function_value,
+       pa_return_in_memory): Likewise.
+       * config/pa/pa.c (pa_pass_by_reference,
+       TARGET_PROMOTE_FUNCTION_RETURN, TARGET_PROMOTE_PROTOTYPES,
+       function_arg_padding, function_value, pa_return_in_memory):
+       Likewise.
+       * config/pdp11/pdp11.c (pdp11_return_in_memory): Likewise.
+       * config/rs6000/rs6000-protos.h (rs6000_function_value,
+       function_arg_padding): Likewise.
+       * config/rs6000/rs6000.c (rs6000_return_in_memory,
+       rs6000_darwin64_record_arg_recurse, rs6000_darwin64_record_arg,
+       rs6000_pass_by_reference, rs6000_must_pass_in_stack,
+       TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN,
+       function_arg_padding, altivec_expand_dst_builtin,
+       altivec_expand_builtin, rs6000_expand_builtin, spe_init_builtins,
+       altivec_init_builtins, rs6000_common_init_builtins,
+       rs6000_function_value): Likewise.
+       * s390/s390-protos.h (s390_function_value): Likewise.
+       * config/s390/s390.c (s390_function_arg_size,
+       s390_pass_by_reference, s390_return_in_memory,
+       s390_function_value, TARGET_PROMOTE_FUNCTION_ARGS,
+       TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
+       * config/score/score-protos.h (score_function_value): Likewise.
+       * config/score/score.c (score_arg_partial_bytes,
+       TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN,
+       TARGET_PROMOTE_PROTOTYPES, score_return_in_memory,
+       score_pass_by_reference, score_add_offset, score_function_value):
+       Likewise.
+       * config/sh/sh-protos.h (sh_attr_renesas_p,
+       sh_promote_prototypes): Likewise.
+       * config/sh/sh.c (sh_return_in_memory, sh_pass_by_reference,
+       sh_callee_copies, sh_promote_prototypes, shcompact_byref,
+       sh_attr_renesas_p): Likewise.
+       * config/sparc/sparc-protos.h (function_value,
+       function_arg_padding): Likewise.
+       * config/sparc/sparc.c (sparc_promote_prototypes,
+       sparc_return_in_memory, sparc_pass_by_reference,
+       TARGET_PROMOTE_FUNCTION_ARGS, TARGET_PROMOTE_FUNCTION_RETURN,
+       function_arg_record_value_2, function_arg_record_value_1,
+       function_arg_record_value, function_arg_record_value,
+       function_arg_padding, function_value): Likewise.
+       * config/spu/spu-protos.h (spu_function_value): Likewise.
+       * config/spu/spu.c (spu_pass_by_reference, spu_return_in_memory,
+       spu_function_value): Likewise.
+       * config/stormy16/stormy16-protos.h (xstormy16_function_value):
+       Likewise.
+       * config/stormy16/stormy16.c (xstormy16_return_in_memory,
+       xstormy16_function_value, TARGET_PROMOTE_FUNCTION_ARGS,
+       TARGET_PROMOTE_FUNCTION_RETURN, TARGET_PROMOTE_PROTOTYPES):
+       Likewise.
+       * config/v850/v850.c (v850_return_in_memory,
+       v850_pass_by_reference, TARGET_PROMOTE_PROTOTYPES): Likewise.
+       * config/vax/vax.c (TARGET_PROMOTE_PROTOTYPES): Likewise.
+       * config/xtensa/xtensa.c (xtensa_return_in_msb,
+       xtensa_return_in_memory, TARGET_PROMOTE_FUNCTION_ARGS,
+       TARGET_PROMOTE_FUNCTION_RETURN, TARGET_PROMOTE_PROTOTYPES):
+       Likewise.
+       * explow.c (promote_mode, hard_function_value): Likewise.
+       * expr.h (hard_function_value, promote_mode): Likewise.
+       * function.c (aggregate_value_p): Likewise.
+       * hooks.c (hook_bool_const_tree_true): New.
+       * hooks.h (hook_bool_const_tree_true): New.
+       * sdbout.c (SET_KNOWN_TYPE_TAG, plain_type_1): Constify.
+       * target-def.h (TARGET_PROMOTE_FUNCTION_ARGS,
+       TARGET_PROMOTE_FUNCTION_RETURN, TARGET_PROMOTE_PROTOTYPES,
+       TARGET_RETURN_IN_MSB): Likewise.
+       * target.h (promote_function_args, promote_function_return,
+       promote_prototypes, return_in_memory, return_in_msb,
+       pass_by_reference, must_pass_in_stack, callee_copies,
+       function_value): Likewise.
+       * targhooks.c (default_return_in_memory,
+       hook_pass_by_reference_must_pass_in_stack,
+       hook_callee_copies_named,
+       hook_bool_CUMULATIVE_ARGS_mode_tree_bool_false,
+       hook_bool_CUMULATIVE_ARGS_mode_tree_bool_true,
+       default_function_value): Likewise. 
+       * targhooks.h (default_return_in_memory,
+       hook_pass_by_reference_must_pass_in_stack,
+       hook_callee_copies_named,
+       hook_bool_CUMULATIVE_ARGS_mode_tree_bool_false,
+       hook_bool_CUMULATIVE_ARGS_mode_tree_bool_true,
+       default_function_value): Likewise.
+       * tree-ssa-structalias.c (const_equiv_class_label_t): New.
+       (equiv_class_label_hash, equiv_class_label_eq): Constify.
+       * tree-vectorizer.c (bb_in_loop_p): Likewise.
+       * tree.c (needs_to_live_in_memory): Likewise.
+       * tree.h (struct tree_type, needs_to_live_in_memory,
+       aggregate_value_p, must_pass_in_stack_var_size,
+       must_pass_in_stack_var_size_or_pad): Likewise.
+       * vmsdbgout.c (write_debug_addr, write_debug_delta4,
+       write_debug_string, ASM_OUTPUT_DEBUG_STRING, write_rtnbeg,
+       lookup_filename): Likewise.
+
+2007-08-23  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/17390
+       * config/i386/i386.c (ix86_expand_fp_compare): Expand fp comparison to
+       fake fcomi i387 instruction for !TARGET_CMOVE.
+       (ix86_expand_branch): Expand natural sequence with one jump for
+       all targets, not only TARGET_CMOVE.
+       * config/i386/i386.md (*cmpfp_0_cc): New define_insn_and_split
+       pattern to implement fake fcomi sequence.  Split instruction after
+       reload to correct compare sequences.
+       (*cmpfp_xf_cc): Ditto.
+       (*cmpfp_<mode>_cc): Ditto.
+       (*cmpfp_u_cc): Ditto.
+       (*cmpfp_<mode>_cc): Ditto.
+
+2007-08-23  Richard Guenther  <rguenther@suse.de>
+
+       * tree-pretty-print.c (dump_generic_node): Annotate
+       GIMPLE_MODIFY_STMTs with volatile ops with "{v}".
+
+2007-08-23  Richard Guenther  <rguenther@suse.de>
+
+       * builtins.c (expand_builtin_mathfn): Wrap argument in
+       save_expr directly instead of re-building the call.
+       (expand_builtin_mathfn_2): Likewise.
+       (expand_builtin_mathfn_3): Likewise.
+       (expand_builtin_interclass_mathfn): Likewise.
+       (expand_builtin_int_roundingfn): Set arg.
+       (expand_builtin_int_roundingfn_2): Likewise.
+
+2007-08-23  Paolo Bonzini  <bonzini@gnu.org>
+
+       * config/i386/sse.md (*sse_and<mode>3, *sse_ior<mode>3,
+       *sse_nand<mode>3, *sse_xor<mode>3): New.
+
+2007-08-23  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (PRINT_OPERAND_PUNCT_VALID_P): Add ';' code.
+       * config/i386/i386.c (print_operand): Handle ';' code.  Output
+       semicolon for TARGET_MACHO.
+       * config/i386/sync.md (*sync_compare_and_swap<mode>): Use '%;' to
+       emit semicolon after 'lock' prefix.
+       (sync_double_compare_and_swap<mode>): Ditto.
+       (*sync_double_compare_and_swapdi_pic): Ditto.
+       (*sync_compare_and_swap_cc<mode>): Ditto.
+       (sync_double_compare_and_swap_cc<mode>): Ditto.
+       (*sync_double_compare_and_swap_ccdi_pic): Ditto.
+       (sync_old_add<mode>): Ditto.
+       (sync_add<mode>): Ditto.
+       (sync_sub<mode>): Ditto.
+       (sync_ior<mode>): Ditto.
+       (sync_and<mode>): Ditto.
+       (sync_xor<mode>): Ditto.
+
+2007-08-22  Chao-ying Fu  <fu@mips.com>
+
+       * rtl.c (rtx_code_size): Check CONST_FIXED to calcualte correct sizes
+       in DEF_RTL_EXPR.
+       (copy_rtx): Handle CONST_FIXED.
+       (rtx_equal_p): Likewise.
+       * rtl.h (fixed_value.h): New include.
+       (rtx_def): Add a new field of fixed_value to u.
+       (XCNMPFV): Define for accessing fixed_value.
+       (CONST_FIXED_VALUE, CONST_FIXED_VALUE_HIGH, CONST_FIXED_VALUE_LOW):
+       Define.
+       * rtl.def (CONST_FIXED): New constant.
+       (SS_MULT, US_MULT, SS_DIV, US_DIV, FRACT_CONVERT,
+       UNSIGNED_FRACT_CONVERT, SAT_FRACT, UNSIGNED_SAT_FRACT, US_NEG,
+       US_ASHIFT): New codes.
+       * doc/rtl.texi (Expressions): Document const_fixed, us_neg, ss_mult,
+       us_mult, ss_div, us_div, us_ashift, fract_convert, sat_fract,
+       unsigned_fract_convert, unsigned_sat_fract): Document them.
+       * varasm.c (assemble_integer): Extend to support fixed-point constants
+       by using different machine classes.
+       (decode_addr_const): Handle FIXED_CST.
+       (const_hash_1): Likewise.
+       (compare_constant): Likewise.
+       (copy_constant): Likewise.
+       (const_rtx_hash_1): Handle CONST_FIXED.
+       (output_constant_pool_2): Handle MODE_FRACT, MODE_UFRACT, MODE_ACCUM,
+       MODE_UACCUM, MODE_VECTOR_FRACT, MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM,
+       MODE_VECTOR_UACCUM.
+       (initializer_constant_valid_p): Handle FIXED_CST.
+       (output_constant): Support FIXED_POINT_TYPE.
+       * gengenrtl.c (excluded_rtx): Check CONST_FIXED to exclude.
+       * cse.c (hash_rtx): Support CONST_FIXED.
+       (exp_equiv_p): Likewise.
+       (cannon_reg): Likewise.
+       (fold_rtx): Likewise.
+       (equiv_constant): Likewise.
+       (cse_process_notes_1): Likewise.
+       (count_reg_usage): Likewise.
+       * cselib.c (entry_and_rtx_equal_p): Check CONST_FIXED.
+       (rtx_equal_for_cselib_p): Handle CONST_FIXED.
+       (wrap_constant): Check CONST_FIXED.
+       (cselib_hash_rtx): Support CONST_FIXED.
+       (cselib_subst_to_values): Likewise.
+       * df-scan.c (df_uses_record): Likewise.
+       * gcse.c (want_to_gcse_p): Likewise.
+       (oprs_unchanged_p): Likewise.
+       (oprs_not_set_p): Likewise.
+       (compute_transp): Likewise.
+       (extract_mentioned_regs_helper): Likewise.
+       * genemit.c (gen_exp): Likewise.
+       * local-alloc.c (equiv_init_varies_p): Likewise.
+       (contains_replace_regs): Likewise.
+       (memref_referenced_p): Likewise.
+       * loop-invariant.c (check_maybe_invariant): Likewise.
+       (hash_invariant_expr_1): Likewise.
+       (invariant_expr_equal_p): Likewise.
+       * postreload-gcse.c (oprs_unchanged_p): Likewise.
+       * regclass.c (reg_scan_mark_refs): Likewise.
+       * regrename.c (scan_rtx): Likewise.
+       * resource.c (mark_referenced_resources): Likewise.
+       (mark_set_resources): Likewise.
+       * rtlanal.c (rtx_unstable_p): Likewise.
+       (rtx_varies_p): Likewise.
+       (count_occurrences): Likewise.
+       (reg_mentioned_p): Likewise.
+       (modified_between_p): Likewise.
+       (modified_in_p): Likewise.
+       (volatile_insn_p): Likewise.
+       (volatile_refs_p): Likewise.
+       (side_effects_p): Likewise.
+       (may_trap_p_1): Likewise.
+       (inequality_comparisons_p): Likewise.
+       (computed_jump_p_1): Likewise.
+       (commutative_operand_precedence): Likewise.
+       * sched-deps.c (sched_analyze_2): Likewise.
+       * sched-vis.c (print_value): Likewise.
+       * reload.c (operands_match_p): Likewise.
+       (subst_reg_equivs): Likewise.
+       * reload1.c (eliminate_regs_1): Likewise.
+       (elimination_effects): Likewise.
+       (scan_paradoxical_subregs): Likewise.
+       * alias.c (rtx_equal_for_memref_p): Likewise.
+       * Makefile.in (RTL_BASE_H): Add fixed-value.h.
+       * emit-rtl.c (const_fixed_htab): New hash table.
+       (const_fixed_htab_hash, const_fixed_htab_eq, lookup_const_fixed):
+       Declare.
+       (const_fixed_htab_hash, const_fixed_htab_eq, lookup_const_fixed,
+       const_fixed_from_fixed_value): New functions.
+       (verify_rtx_sharing): Handle CONST_FIXED.
+       (copy_rtx_if_shared_1): Likewise.
+       (reset_used_flags): Likewise.
+       (set_used_flags): Likewise.
+       (copy_insn_1): Likewise.
+       (init_emit_once): Create const_fixed_htab.
+       Store fixed-point scalar and vector zero and one to const_tiny_rtx.
+
+2007-08-22  Zdenek Dvorak  <ook@ucw.cz>
+
+       PR tree-optimization/32949
+       * tree-ssa-loop-niter.c (scev_probably_wraps_p): Test nowrap_type_p
+       before failing for ivs with non-constant step.
+
+2007-08-22  Hans-Peter Nilsson  <hp@axis.com>
+
+       * doc/md.texi (Iterators): Renamed from Macros.  All contents
+       changed to reflect rename of respectively define_code_macro and
+       define_mode_macro to define_code_iterator and define_mode_iterator.
+       (Mode Iterators, Code Iterators): Similar.
+       * read-rtl.c (struct iterator_group, struct iterator_traverse_data)
+       (uses_mode_iterator_p, apply_mode_iterator, uses_code_iterator_p)
+       (apply_iterator_to_string, uses_iterator_p, apply_iterator_traverse)
+       (initialize_iterators, find_iterator, check_code_iterator)
+       (map_attr_string, apply_mode_maps, apply_iterator_to_rtx, add_mapping)
+       (read_mapping, read_rtx_1): Similar.
+       * config/alpha/sync.md, config/alpha/alpha.md, config/frv/frv.md,
+       config/s390/s390.md, config/m32c/blkmov.md, config/m32c/m32c.md,
+       config/spu/spu.md, config/sparc/sparc.md, config/sparc/sync.md,
+       config/i386/i386.md, config/i386/mmx.md, config/i386/sse.md,
+       config/i386/sync.md, config/crx/crx.md, config/xtensa/xtensa.md,
+       config/cris/cris.c, config/cris/cris.md, config/ia64/sync.md,
+       config/ia64/div.md, config/ia64/vect.md, config/ia64/ia64.md,
+       config/m68k/m68k.md, config/rs6000/spe.md, config/rs6000/altivec.md,
+       config/rs6000/sync.md, config/rs6000/rs6000.md,
+       config/arm/vec-common.md, config/arm/neon.md, config/arm/iwmmxt.md,
+       config/arm/arm.md, config/mips/mips-dsp.md, config/mips/mips.md,
+       config/vax/vax.md, config/bfin/bfin.md: Similar.
+
+2007-08-22  David Daney  <ddaney@avtrex.com>
+
+       * doc/install.texi (Testing): Mention testing on a simulator.
+
+2007-08-22  Janis Johnson  <janis187@us.ibm.com>
+
+       * config/dfp-bit.c (DFP_TO_DFP): Check for overflow.
+
+       * doc/libgcc.texi (Decimal float library routines): Fix formatting
+       and rearrange floating point conversion functions into different
+       categories.
+
+2007-08-22  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * target.h (struct gcc_target.sched: dfa_pre_advance_cycle,
+       dfa_post_advance_cycle): New scheduler hooks.
+       * target-def.h (TARGET_SCHED_DFA_PRE_ADVANCE_CYCLE,
+       TARGET_SCHED_DFA_POST_ADVANCE_CYCLE): New macros to initialize
+       new hooks.
+       (TARGET_SCHED): Use them.
+       * doc/tm.texi (TARGET_SCHED_DFA_PRE_ADVANCE_CYCLE,
+       TARGET_SCHED_DFA_POST_ADVANCE_CYCLE): Document new hooks.
+       * haifa-sched.c (advance_one_cycle): Invoke new hooks.
+
+       * genautomata.c (insn_has_dfa_reservation_p): New DFA interface
+       function to facilitate debugging.
+       (INSN_HAS_DFA_RESERVATION_P_FUNC_NAME): New macro.
+       (output_insn_has_dfa_reservation_p): New static function to output
+       insn_has_dfa_reservation_p ().
+       (write_automata): Use it.
+       * genattr.c (main): Output declaration for
+       insn_has_dfa_reservation_p ().
+
+2007-08-22  Christian Bruel  <christian.bruel@st.com>  
+           Richard Guenther <rguenther@suse.de>
+       
+       * fold-const.c (fold_binary): Optimize A-A if -ffinite-math-only.
+       * simplify_rtx (simplify_binary_operation_1): Likewise.
+               
+2007-08-22  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR rtl-optimization/32557
+       * df-problems.c (df_note_bb_compute): Use mws->start_regno instead
+       of REGNO (mws->mw_reg).
+
+2007-08-22  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33007
+       * builtins.c (expand_builtin_int_roundingfn): Replace call
+       argument wrapped with SAVE_EXPR directly.
+       (expand_builtin_int_roundingfn_2): Likewise.
+
+2007-08-22  Richard Guenther  <rguenther@suse.de>
+
+       * tree-inline.c (inlinable_function_p): Restore disregarding
+       inline limits for GNU extern inline functions.
+
+2007-08-22  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32563
+       * tree.c (host_integerp): Treat sizetype as signed as it is
+       sign-extended.
+
+2007-08-21  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/33134
+       * tree-vrp.c (adjust_range_with_scev): Call
+       set_value_range_to_value.
+
+2007-08-21  Aldy Hernandez  <aldyh@redhat.com>
+
+       * value-prof.h (gimple_remove_histogram_value): Remove duplicate
+       prototype.
+       
+2007-08-21  Aldy Hernandez  <aldyh@redhat.com>
+
+       * tree-flow-inline.h (next_imm_use_stmt): Remove unecessary
+       whitespace.
+
+2007-08-21  Nathan Froyd  <froydnj@codesourcery.com>
+
+       * config/rs6000/rs6000.c (expand_block_clear): Add TARGET_SPE
+       cases to set eight bytes at a time.
+       (expand_block_move): Likewise.
+       
+2007-08-21  Jakub Jelinek  <jakub@redhat.com>
+
+       PR debug/32610
+       * dwarf2out.c (gen_decl_die): Don't call
+       gen_tagged_type_instantiation_die if decl doesn't have tagged type.
+
+2007-08-21  Paul Brook  <paul@codesourcery.com>
+           Nathan Sidwell  <nathan@codesourcery.com>
+           Mark Mitchell  <mark@codesourcery.com>
+           Joseph Myers  <joseph@codesourcery.com>
+
+       * configure.ac: Add --with-pkgversion and --with-bugurl.
+       * configure: Regenerate.
+       * doc/install.texi: Document them.
+       * version.c (version_string): Remove VERSUFFIX.
+       (VERSUFFIX): Remove.
+       (pkgversion_string): New.
+       (bug_report_url): Do not hard-code initializer.
+       * version.h (pkgversion_string): Declare.
+       * Makefile.in (PKGVERSION_s, BUGURL_s, PKGVERSION, BUGURL_TEXI):
+       Define.
+       (version.o): Define PKGVERSION and BUGURL.
+       (gcc-vers.texi): Define VERSION_PACKAGE and BUGURL.
+       (%.pod): Define BUGURL.
+       * gcc.c (process_command, main): Use pkgversion_string.
+       * toplev.c (compile_file, print_version): Likewise.
+       * protoize.c (main): Likewise.
+       * gcov.c (print_version): Likewise.  Update copyright date.
+       * gcov-dump.c (print_version): Likewise.  Update copyright date.
+       * mips-tdump.c (main): Likewise.  Update copyright date.
+       * mips-tfile.c (main): Likewise.  Update copyright date.
+       * doc/include/gcc-common.texi: Include VERSION_PACKAGE as subtitle.
+       * doc/bugreport.texi: Use BUGURL for bug-reporting instructions;
+       shorten description.
+       * doc/gcc.texi: Include VERSION_PACKAGE in version description.
+       * doc/gccint.texi: Likewise.
+       * doc/invoke.texi: Use BUGURL for bug-reporting instructions.
+       Update copyright date.
+
+2007-08-21  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_expand_clear): Use FLAGS_REG.
+       (ix86_expand_strlensi_unroll_1): Ditto.
+       (ix86_expand_branch): Use FLAGS_REG and FPSR_REG.
+       (ix86_expand_carry_flag_compare): Update comment.
+
+2007-08-21  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/32912
+       * fold-const.c (fold_unary): Optimize BIT_NOT_EXPR of VECTOR_CST.
+       (fold_binary): Handle vectors in X | ~X and X ^ ~X optimizations.
+
+2007-08-21  Richard Guenther  <rguenther@suse.de>
+
+       * fold-const.c (fold_binary): Revert removing of index +p PTR folding.
+
+2007-08-21  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/33122
+       * fold-const.c (fold_binary): Remove index +p PTR folding.
+       Fix types of POINTER_PLUS_EXPR generated by folding of
+       (PTR +p B) +p A.
+
+2007-08-20  Chao-ying Fu  <fu@mips.com>
+
+       * c-common.h (enum rid): Add new enumeration values of RID_SAT,
+       RID_FRACT, and RID_ACCUM.  RID_SAT needs to be inserted before
+       RID_ONEWAY, so that it can be checked in declspecs_add_type.
+       (c_common_fixed_point_type_for_size): Declare.
+       * c-parser.c (reswords): Add _Fract, _Accum, and _Sat.
+       (c_token_starts_typename): Handle RID_FRACT, RID_ACCUM, and RID_SAT.
+       (c_token_starts_declspecs): Likewise.
+       (c_parser_declspecs): Likewise.
+       (c_parser_attributes): Likewise.
+       * c-tree.h (enum c_typespec_keyword): Add cts_fract and cts_accum.
+       (c_declspecs): Add saturating_p.
+       * c-decl.c (build_null_declspecs): Initialize saturating_p.
+       (declspecs_add_type): Avoid using complex with _Fract, _Accum, or
+       _Sat.  Handle RID_SAT.
+       Avoid using void, bool, char, int, float, double, _Decimal32,
+       _Decimal64, _Decimal128, and complex with _Sat.
+       Handle RID_FRACT and RID_ACCUM.
+       Make sure _Sat is used with _Fract or _Accum.
+       (finish_declspecs): Handle cts_fract and cts_accum.
+       * c-common.c (fixed-value.h): New include.
+       (constant_expression_warning): Handle FIXED_CST.
+       (overflow_warning): Likewise.
+       (warnings_for_convert_and_check): Likewise.
+       (c_common_fixed_point_type_for_size): New.
+       (c_common_type_for_mode): Handle fixed-point modes to
+       return various saturating/non-saturating, signed/unsigned types.
+       (c_common_signed_or_unsigned_type): Support fixed-point types.
+       (shorten_compare): Check fixed-point zero.
+       Handle FIXED_POINT_TYPE.
+       (c_common_truthvalue_conversion): Handle FIXED_CST.
+       Handle FIXED_POINT_TYPE.
+       (c_common_nodes_and_builtins): Record builtin types for fixed-point
+       types.
+       (handle_mode_attribute): Handle fixed-point modes.  Need to check
+       if the signness of base type and fixed-point modes are consistent.
+       (handle_vector_size_attribute): Handle fixed-point modes.
+       (same_scalar_type_ignoring_signedness): Handle FIXED_POINT_TYPE.
+       (warn_for_div_by_zero): Check fixed-point zero.
+       * c-typeck.c (c_common_type): Check FIXED_POINT_TYPE.  Build
+       a common fixed-point type based on fbit, ibit, sign, and saturation.
+       (build_unary_op): Allow FIXED_POINT_TYPE for CONVERT_EXPR,
+       NEGATE_EXPR, TRUTH_NOT_EXPR, PREINCREMENT_EXPR, POSTINCREMENT_EXPR,
+       PREDECREMENT_EXPR, and POSTDECREMENT_EXPR.
+       (convert_for_assignment): Support FIXED_POINT_TYPE.
+       (digest_init): Handle FIXED_POINT_TYPE.
+       (build_binary_op): Support FIXED_POINT_TYPE in *_DIV_EXPR,
+       TRUTH_ANDIF_EXPR, TRUTH_ORIF_EXPR, TRUTH_AND_EXPR, TRUTH_OR_EXPR,
+       TRUTH_XOR_EXPR, RSHIFT_EXPR, LSHIFT_EXPR, EQ_EXPR, NE_EXPR, LE_EXPR,
+       GE_EXPR, LT_EXPR, GT_EXPR.
+       * target-def.h (TARGET_FIXED_POINT_SUPPORTED_P): New.
+       (TARGET_INITIALIZER): Add TARGET_FIXED_POINT_SUPPORTED_P.
+       * target.h (gcc_target): Add fixed_point_supported_p.
+       * targhooks.c (default_scalar_mode_supported_p): Handle MODE_FRACT,
+       MODE_UFRACT, MODE_ACCUM, and MODE_UACCUM.
+       (default_fixed_point_supported_p): Define.
+       * targhooks.h (default_fixed_point_supported_p): Declare.
+       * doc/tm.texi (TARGET_FIXED_POINT_SUPPORTED_P): Add.
+       * doc/install.texi (Configuration): Add --enable-fixed-point.
+       * configure.ac (--enable-fixed-point): New to enable fixed-point
+       arithmetic extension to C.  For mips targets, we enable it by default.
+       * configure, config.in: Regenerate.
+
+2007-08-20  Pawel Sikora  <pluto@pld-linux.org>
+
+       * doc/invoke.texi (-Wnon-virtual-dtor): Update documentation.
+
+2007-08-20  David Edelsohn  <edelsohn@gnu.org>
+
+       * dwarf2out.c (text_section_used): Move declaration outside ifdef
+       DWARF2_DEBUGGING_INFO.
+       (cold_text_section_used): Same.
+       (cold_text_section): Same.
+
+2007-08-20  Richard Guenther  <rguenther@suse.de>
+
+       * c-typeck.c (convert_for_assignment): Use the type of
+       the member for the initialization.
+
+2007-08-20  Richard Guenther  <rguenther@suse.de>
+
+       * c-objc-common.c (c_disregard_inline_limits): Remove.
+       * c-objc-common.h (c_disregard_inline_limits): Likewise.
+       * cgraphunit.c (cgraph_process_new_functions): Call
+       disregard_inline_limits_p.
+       (cgraph_preserve_function_body_p): Likewise.
+       * ipa-inline.c (compute_inline_parameters): Likewise.
+       * langhooks-def.h (lhd_tree_inlining_disregard_inline_limits):
+       Remove.
+       (LANG_HOOKS_TREE_INLINING_DISREGARD_INLINE_LIMITS): Remove.
+       (LANG_HOOKS_TREE_INLINING_INITIALIZER): Remove initializer for
+       disregard_inline_limits langhook.
+       * langhooks.c (lhd_tree_inlining_disregard_inline_limits):
+       Remove.
+       * langhooks.h (lang_hooks_for_tree_inlining): Remove
+       disregard_inline_limits langhook.
+       * tree-inline.c (disregard_inline_limits_p): New function.
+       * tree-inline.h (disregard_inline_limits_p): Declare.
+
+2007-08-20  Richard Guenther  <rguenther@suse.de>
+
+       * langhooks-def.h (lhd_tree_inlining_auto_var_in_fn_p): Remove.
+       (LANG_HOOKS_TREE_INLINING_AUTO_VAR_IN_FN_P): Likewise.
+       (LANG_HOOKS_TREE_INLINING_INITIALIZER): Remove initializer for
+       auto_var_in_fn_p langhook.
+       * langhooks.c (lhd_tree_inlining_auto_var_in_fn_p): Rename and
+       move ...
+       * tree.c (auto_var_in_fn_p): ... here.
+       (find_var_from_fn): Call auto_var_in_fn_p directly.
+       * langhooks.h (lang_hooks_for_tree_inlining): Remove
+       auto_var_in_fn_p langhook.
+       * tree-inline.c (remap_decls): Call auto_var_in_fn_p directly.
+       (copy_body_r): Likewise.
+       (self_inlining_addr_expr): Likewise.
+       * tree.h (auto_var_in_fn_p): Declare.
+
+2007-08-20  Richard Guenther  <rguenther@suse.de>
+
+       * tree.c (WALK_SUBTREE): Call walk_tree_1.
+       (walk_type_fields): Take lh parameter.
+       (walk_tree): Rename to ...
+       (walk_tree_1): ... this.  Do not call the walk_subtrees
+       langhook but the now passed callback.  Pass lh on recursion.
+       (walk_tree_without_duplicates): Rename to ...
+       (walk_tree_without_duplicates_1): ... this.  Take lh parameter
+       and call walk_tree_1.
+       * tree.h (walk_tree_lh): New typedef.
+       (walk_tree_1): Declare.
+       (walk_tree_without_duplicates_1): Likewise.
+       (walk_tree): New define to walk_tree_1 with NULL lh parameter.
+       (walk_tree_without_duplicates): New define to
+       walk_tree_without_duplicates_1 with NULL lh parameter.
+       * langhooks.c (lhd_tree_inlining_walk_subtrees): Remove.
+       * langhooks.h (lang_hooks_for_tree_inlining): Remove walk_subtrees
+       langhook.
+       * langhooks-def.h (lhd_tree_inlining_walk_subtrees): Remove.
+       (LANG_HOOKS_TREE_INLINING_WALK_SUBTREES): Likewise.
+       (LANG_HOOKS_TREE_INLINING_INITIALIZER): Remove walk_subtrees
+       initializer.
+
+2007-08-20  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/30564
+       * tree-inline.c (optimize_inline_calls): Move the cgraph checking
+       code in front of the compacting of basic blocks.
+       Move the folding of statements inbetween the cgraph checking
+       and compacting of basic blocks.
+
+2007-08-19  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+          Serge Belyshev  <belyshev@depni.sinp.msu.ru>
+
+       PR target/32522
+       * config/alpha/alpha.c (va_list_skip_additions): Check for
+       POINTER_PLUS_EXPR in addition to PLUS_EXPR.
+       (alpha_stdarg_optimize_hook): Look for POINTER_PLUS_EXPR instead of
+       PLUS_EXPR when checking ap.__base.
+       (alpha_va_start): Create POINTER_PLUS_EXPR instead of PLUS_EXPR
+       when doing addition on pointer types.  Use size_int instead of
+       build_int_cst.
+       (alpha_gimplify_va_arg_1): Likewise, but use sizetype instead of
+       ptr_type in the second operand.
+
+2007-08-19  Andrew Pinski  <pinskia@gmail.com>
+
+       PR target/33115
+       * config/i386/darwin.h (CC1_SPEC): Add %(cc1_cpu) in front.
+
+2007-08-19  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/32940
+       * cfgexpand.c  (expand_one_register_var): Mark pointer
+       DECL_ARTIFICIAL as REG_POINTER also.
+       * stmt.c (expand_decl): Likewise.
+
+2007-08-19  Daniel Berlin  <dberlin@dberlin.org>
+
+       Fix PR 32772
+       Fix PR 32716
+       Fix PR 32328
+       Fix PR 32303
+
+       * tree-flow.h (struct stmt_ann_d): Remove makes_clobbering_call.
+       * tree-ssa-alias.c (init_transitive_clobber_worklist): Add
+       on_worklist argument and avoid adding things to worklist multiple
+       times.
+       (add_to_worklist): Ditto.
+       (mark_aliases_call_clobbered): Mark entire structure clobbered if
+       single SFT is clobbered.
+       (set_initial_properties): Ditto.
+       (compute_call_clobbered): Update for changes to function
+       arguments.
+       (create_overlap_variables_for): Always create SFT for offset 0.
+       (create_structure_vars): Handle PHI's, since we are in SSA form at
+       this point.
+       * tree-ssa-loop-ivopts.c (get_ref_tag): Don't return subvars.
+       * tree-ssa-operands.c (access_can_touch_variable): Don't handle
+       TARGET_MEM_REF.
+       (add_vars_for_offset): Figure out aliases from access + points-to.
+       (add_virtual_operand): Use add_vars-for_offset.
+       (get_tmr_operands): Update for NMT changes, rewrite to be correct.
+       (add_call_clobber_ops): Remove makes_clobbering_call set.
+       (get_expr_operands): Always pass through the INDIRECT_REF
+       reference.
+       * tree-ssa-structalias.c (struct constraint_graph): Remove
+       variables member.
+       Add pe, pe_rep, pointer_label, loc_label, pointed_by, points_to,
+       address_taken, pt_used, number_incoming.
+       (FIRST_ADDR_NODE): Removed.
+       (merge_graph_nodes): Remove broken code for the moment.
+       (init_graph): New function.
+       (build_pred_graph): Remove code to init_graph.
+       Add location equivalence support.
+       (struct scc_info): Rename roots to deleted.
+       (scc_visit): Ditto.
+       (init_scc_info): Ditto
+       (init_topo_info): Use graph->size.
+       (compute_topo_order): Ditto.
+       (do_da_constraint): Removed.
+       (do_sd_constraint): Remove calls to find().
+       set_union_with_increment should always get 0 as last arg here.
+       (do_complex_constraint): Replace do_da_constraint with assert.
+       Stop calling find.
+       (struct equiv_class_label): New.
+       (pointer_equiv_class_table): Ditto.
+       (location_equiv_class_table): Ditto.
+       (equiv_class_label_hash): Ditto.
+       (equiv_class_label_eq): Ditto
+       (equiv_class_lookup): Ditto.
+       (equiv_class_ladd): Ditto.
+       (pointer_equiv_class): Ditto.
+       (location_equiv_class): Ditto.
+       (condense_visit): Rename and rewrite from label_visit to do only
+       SCC related stuff for HU.
+       (label_visit): Do HU work for HU.
+       (perform_var_substitution): Update to do HU and location
+       equivalence.
+       (free_var_substitution_info): Update to free HU and location
+       equivalence structures.  */
+       (find_equivalent_node): Update for pointer but not location
+       equivalence.
+       (unite_pointer_equivalences): New function.
+       (move_complex_constraints): Rewrite to only do moving.
+       (rewrite_constraints): Split out of move_complex_constraints.
+       (solve_graph): Use graph->size.
+       (process_constraint_1): Add from_call argument, use it.
+       Split *a = &b into two constraints.
+       (process_constraint): Use new process_constraint_1.
+       (get_constraint_for_component_ref): Handle bitmaxsize == -1 case.
+       (get_constraint_for): Handle non-pointer integers properly.
+       Remove code that used to handle structures.
+       (handle_ptr_arith): Fix a few bugs in pointer arithmetic handling
+       with unknown addends.
+       (handle_rhs_call): New function.
+       (find_func_aliases): Use handle_rhs_call.
+       (set_uids_in_ptset): Add an assert.
+       (set_used_smts): Fix bug in not considering unified vars.
+       (compute_tbaa_pruning): Stop initing useless iteration_obstack.
+       (compute_points_to_sets): Update for other function changes.
+       (delete_points_to_sets): Ditto.
+       (ipa_pta_execute): Ditto.
+       (pass_ipa_pta): We need to update SSA after ipa_pta.
+       
+2007-08-19  Jan Hubicka  <jh@suse.cz>
+
+       * config/i386/i386.md: Replace "rim" and "mri" constraints by "g".
+
+2007-08-19  Joseph Myers  <joseph@codesourcery.com>
+
+       * dwarf2out.c (text_section_used, cold_text_section_used,
+       cold_text_section, dwarf2out_note_section_used): New.
+       (dwarf2out_init): Initialize cold_text_section.
+       (dwarf2out_switch_text_section, dwarf2out_begin_function): Call
+       dwarf2out_note_section_used.
+       (size_of_aranges): Only count entry for text section if it was
+       used.  Count entry for cold text section if it was used.
+       (output_aranges): Only output entries for text section and cold
+       text section if they were used.
+
+2007-08-19  Andrew Pinski  <pinskia@gmail.com>
+
+       * tree-pretty-print.c (debug_generic_expr): Add a comment about
+       the function.
+       (debug_generic_stmt): Likewise.
+       (debug_tree_chain): Likewise.
+
+2007-08-19  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-data-refs.c (split_constant_offset): Expose.
+       * tree-data-refs.h (split_constant_offset): Add declaration.
+
+       * tree-vectorizer.h (dr_alignment_support): Renamed
+       dr_unaligned_software_pipeline to dr_explicit_realign_optimized.
+       Added a new value dr_explicit_realign.
+       (_stmt_vec_info): Added new fields: dr_base_address, dr_init,
+       dr_offset, dr_step, and dr_aligned_to, along with new access
+       functions for these fields: STMT_VINFO_DR_BASE_ADDRESS,
+       STMT_VINFO_DR_INIT, STMT_VINFO_DR_OFFSET, STMT_VINFO_DR_STEP, and
+       STMT_VINFO_DR_ALIGNED_TO.
+
+       * tree-vectorizer.c (vect_supportable_dr_alignment): Add
+       documentation.
+       In case of outer-loop vectorization with non-fixed misalignment - use
+       the dr_explicit_realign scheme instead of the optimized realignment
+       scheme.
+       (new_stmt_vec_info): Initialize new fields.
+
+       * tree-vect-analyze.c (vect_compute_data_ref_alignment): Handle the
+       'nested_in_vect_loop' case. Change verbosity level.
+       (vect_analyze_data_ref_access): Handle the 'nested_in_vect_loop' case.
+       Don't fail on zero step in the outer-loop for loads.
+       (vect_analyze_data_refs): Call split_constant_offset to calculate
+       base, offset and init relative to the outer-loop.
+
+       * tree-vect-transform.c (vect_create_data_ref_ptr): Replace the unused
+       BSI function argument with a new function argument - at_loop.
+       Simplify the condition that determines STEP. Takes additional argument
+       INV_P. Support outer-loop vectorization (handle the
+       nested_in_vect_loop case), including zero step in the outer-loop. Call
+       vect_create_addr_base_for_vector_ref with additional argument.
+       (vect_create_addr_base_for_vector_ref): Takes additional argument LOOP.
+       Updated function documentation. Handle the 'nested_in_vect_loop' case.
+       Fixed and simplified calculation of step.
+       (vectorizable_store): Call vect_create_data_ref_ptr with loop instead
+       of bsi, and with additional argument. Call bump_vector_ptr with
+       additional argument. Fix typos. Handle the 'nested_in_vect_loop' case.
+       (vect_setup_realignment): Takes additional arguments INIT_ADDR and
+       DR_ALIGNMENT_SUPPORT. Returns another value AT_LOOP. Handle the case
+       when the realignment setup needs to take place inside the loop.
+       Support the dr_explicit_realign scheme. Allow generating the optimized
+       realignment scheme for outer-loop vectorization. Added documentation.
+       (vectorizable_load): Support the dr_explicit_realign scheme. Handle
+       the 'nested_in_vect_loop' case, including loads that are invariant in
+       the outer-loop and the realignment schemes. Handle the case when the
+       realignment setup needs to take place inside the loop. Call
+       vect_setup_realignment with additional arguments.  Call
+       vect_create_data_ref_ptr with additional argument and with loop instead
+       of bsi. Fix 80-column overflow. Fix typos. Rename PHI_STMT to PHI.
+       (vect_gen_niters_for_prolog_loop): Call
+       vect_create_addr_base_for_vector_ref with additional arguments.
+       (vect_create_cond_for_align_checks): Likewise.
+       (bump_vector_ptr): Updated to support the new dr_explicit_realign
+       scheme: takes additional argument bump; argument ptr_incr is now
+       optional; updated documentation.
+       (vect_init_vector): Takes additional argument (bsi). Use it, if
+       available, to insert the vector initialization.
+       (get_initial_def_for_induction): Pass additional argument in call to
+       vect_init_vector.
+       (vect_get_vec_def_for_operand): Likewise.
+       (vect_setup_realignment): Likewise.
+       (vectorizable_load): Likewise.
+
+2007-08-19  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vectorizer.h (vect_is_simple_reduction): Takes a loop_vec_info
+       as argument instead of struct loop.
+       (nested_in_vect_loop_p): New function.
+       (vect_relevant): Add enum values vect_used_in_outer_by_reduction and
+       vect_used_in_outer.
+       (is_loop_header_bb_p): New. Used to differentiate loop-header phis
+       from other phis in the loop.
+       (destroy_loop_vec_info): Add additional argument to declaration.
+
+       * tree-vectorizer.c (supportable_widening_operation): Also check if
+       nested_in_vect_loop_p (don't allow changing the order in this case).
+       (vect_is_simple_reduction): Takes a loop_vec_info as argument instead
+       of struct loop. Call nested_in_vect_loop_p and don't require
+       flag_unsafe_math_optimizations if it returns true.
+       (new_stmt_vec_info): When setting def_type for phis differentiate 
+       loop-header phis from other phis.
+       (bb_in_loop_p): New function.
+       (new_loop_vec_info): Inner-loop phis already have a stmt_vinfo, so
+       just update their loop_vinfo.  Order of BB traversal now matters -
+       call dfs_enumerate_from with bb_in_loop_p.
+       (destroy_loop_vec_info): Takes additional argument to control whether
+       stmt_vinfo of the loop stmts should be destroyed as well.
+       (vect_is_simple_reduction): Allow the "non-reduction" use of a
+       reduction stmt to be defines by a non loop-header phi.
+       (vectorize_loops): Call destroy_loop_vec_info with additional argument.
+
+       * tree-vect-transform.c (vectorizable_reduction): Call
+       nested_in_vect_loop_p. Check for multitypes in the inner-loop.
+       (vectorizable_call): Likewise.
+       (vectorizable_conversion): Likewise.
+       (vectorizable_operation): Likewise.
+       (vectorizable_type_promotion): Likewise.
+       (vectorizable_type_demotion): Likewise.
+       (vectorizable_store): Likewise.
+       (vectorizable_live_operation): Likewise.
+       (vectorizable_reduction): Likewise. Also pass loop_info to
+       vect_is_simple_reduction instead of loop.
+       (vect_init_vector): Call nested_in_vect_loop_p.
+       (get_initial_def_for_reduction): Likewise.
+       (vect_create_epilog_for_reduction): Likewise.
+       (vect_init_vector): Check which loop to work with, in case there's an
+       inner-loop.
+       (get_initial_def_for_inducion): Extend to handle outer-loop
+       vectorization. Fix indentation.
+       (vect_get_vec_def_for_operand): Support phis in the case vect_loop_def.
+       In the case vect_induction_def get the vector def from the induction
+       phi node, instead of calling get_initial_def_for_inducion.
+       (get_initial_def_for_reduction): Extend to handle outer-loop 
+       vectorization.
+       (vect_create_epilog_for_reduction): Extend to handle outer-loop
+       vectorization.
+       (vect_transform_loop): Change assert to just skip this case.  Add a
+       dump printout.
+       (vect_finish_stmt_generation): Add a couple asserts.
+
+       (vect_estimate_min_profitable_iters): Multiply
+       cost of inner-loop stmts (in outer-loop vectorization) by estimated
+       inner-loop bound.
+       (vect_model_reduction_cost): Don't add reduction epilogue cost in case
+       this is an inner-loop reduction in outer-loop vectorization.
+
+       * tree-vect-analyze.c (vect_analyze_scalar_cycles_1): New function.
+       Same code as what used to be vect_analyze_scalar_cycles, only with
+       additional argument loop, and loop_info passed to
+       vect_is_simple_reduction instead of loop.
+       (vect_analyze_scalar_cycles): Code factored out into
+       vect_analyze_scalar_cycles_1. Call it for each relevant loop-nest.
+       Updated documentation.
+       (analyze_operations): Check for inner-loop loop-closed exit-phis during
+       outer-loop vectorization that are live or not used in the outerloop,
+       cause this requires special handling.
+       (vect_enhance_data_refs_alignment): Don't consider versioning for
+       nested-loops.
+       (vect_analyze_data_refs): Check that there are no datarefs in the
+       inner-loop.
+       (vect_mark_stmts_to_be_vectorized): Also consider vect_used_in_outer
+       and vect_used_in_outer_by_reduction cases.
+       (process_use): Also consider the case of outer-loop stmt defining an
+       inner-loop stmt and vice versa.
+       (vect_analyze_loop_1): New function.
+       (vect_analyze_loop_form): Extend, to allow a restricted form of nested
+       loops.  Call vect_analyze_loop_1.
+       (vect_analyze_loop): Skip (inner-)loops within outer-loops that have
+       been vectorized.  Call destroy_loop_vec_info with additional argument.
+
+       * tree-vect-patterns.c (vect_recog_widen_sum_pattern): Don't allow
+       in the inner-loop when doing outer-loop vectorization. Add
+       documentation and printout.
+       (vect_recog_dot_prod_pattern): Likewise. Also add check for
+       GIMPLE_MODIFY_STMT (in case we encounter a phi in the loop).
+
+2007-08-18  Andrew Pinski  <pinskia@gmail.com>
+
+       * tree-affine.h (print_aff): New prototype.
+       (debug_aff): Likewise.
+       * tree-affine.c (print_aff): New function.
+       (debug_aff): Likewise.
+
+2007-08-18  Paul Brook  <paul@codesourcery.com>
+           Joseph Myers  <joseph@codesourcery.com>
+
+       * common.opt (-fdebug-prefix-map=): New option.
+       * opts.c: Include debug.h.
+       (common_handle_option): Handle -fdebug-prefix-map.
+       * final.c: Include ggc.h.
+       (struct debug_prefix_map, debug_prefix_maps, add_debug_prefix_map,
+       remap_debug_filename): New.
+       * Makefile.in (final.o, opts.o): Update dependencies.
+       * debug.h (remap_debug_filename, add_debug_prefix_map): Declare.
+       * configure.ac: Check for assembler --debug-prefix-map support.
+       * configure, config.in: Regenerate.
+       * gcc.c (ASM_MAP): Define conditional on HAVE_AS_DEBUG_PREFIX_MAP.
+       (ASM_DEBUG_SPEC): Include ASM_MAP.
+       * doc/install.texi (--with-debug-prefix-map): Document.
+       * doc/invoke.texi (-fdebug-prefix-map): Document.
+       * dbxout.c (dbxout_init, dbxout_start_source_file,
+       dbxout_source_file): Call remap_debug_filename.
+       * dwarf2out.c (add_comp_dir_attribute, maybe_emit_file,
+       dwarf2out_start_source_file, dwarf2out_finish): Call
+       remap_debug_filename.
+       (file_table_relative_p): Do not check d->emitted_number.
+       * toplev.c (output_file_directive): Call remap_debug_filename.
+       * vmsdbgout.c (write_srccorr): Call remap_debug_filename.
+       * xcoffout.c (xcoffout_source_file): Call remap_debug_filename.
+
+2007-08-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * loop-invariant.c (find_invariants_to_move): Add missing macro
+       argument.
+
+2007-08-17  Tom Tromey  <tromey@redhat.com>
+
+       * tree.h (struct tree_label_decl): Removed old "java" fields.
+
+2007-08-17  Richard Sandiford  <richard@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/sde.h (DRIVER_SELF_SPECS): Add commas.
+       Treat -mno-data-in-code and -mcode-xonly as aliases for
+       -mcode-readable=no and -mcode-readable=pcrel respectively.
+       * config/mips/t-sde (TARGET_LIBGCC2_CFLAGS): Add -mcode-xonly.
+       (MULTILIB_OPTIONS): Add -mcode-readable=no multilibs.
+       (MULTILIB_DIRNAMES): Update accordingly.
+
+2007-08-17  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * Makefile.in (version.o): Depend on $(REVISION) only if
+       REVISION_s is defined.
+
+2007-08-17  Sa Liu  <saliu@de.ibm.com>
+           Ulrich Weigand  <uweigand@de.ibm.com>
+
+       PR middle-end/32970
+       * tree.c (reconstruct_complex_type): For a pointer to a vector,
+       use build_qualified_type to retain qualifiers of the base type.
+
+2007-08-17  Chen Liqin  <liqin@sunnorth.com.cn>
+
+       * config/score/score.md : Update pattern tablejump.
+       * config/score/score.c : Update score_initialize_trampoline 
+       function.
+       * config/score/score.h (TRAMPOLINE_TEMPLATE): Added macro.
+       (TRAMPOLINE_INSNS, TRAMPOLINE_SIZE) Update macro.
+       * doc/contrib.texi: Add my entry.
+
+2007-08-16  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * Makefile.in (REVISION): New.
+       (REVISION_c): New.
+       (REVISION_s): New.
+       (version.o): Also depend on $(REVISION). Add
+       -DREVISION=$(REVISION_s).
+
+       * version.c (version_string): Add REVISION.
+
+2007-08-16  Seongbae Park <seongbae.park@gmail.com>
+
+       * tree-eh.c (lower_try_finally_onedest): Reset the locus
+       of GOTO that's relocated to a different block.
+
+2007-08-16  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * c-common.c (const_strip_array_types): New.
+       * c-common.h (lang_missing_noreturn_ok_p): Delete.
+       (const_strip_array_types): New.
+       * c-objc-common.c (c_disregard_inline_limits,
+       c_warn_unused_global_decl): Constify.
+       * c-tree.h (c_disregard_inline_limits, c_warn_unused_global_decl,
+       c_vla_type_p, c_incomplete_type_error): Likewise.
+       * c-typeck.c (c_incomplete_type_error, c_vla_type_p): Likewise.
+       * hooks.c (hook_bool_const_tree_false): New.
+       * hooks.h (hook_bool_const_tree_false): Likewise.
+       * langhooks-def.h (lhd_warn_unused_global_decl,
+       lhd_incomplete_type_error, lhd_expr_size,
+       lhd_tree_inlining_disregard_inline_limits,
+       lhd_tree_inlining_auto_var_in_fn_p, lhd_tree_dump_type_quals,
+       LANG_HOOKS_GENERIC_TYPE_P, LANG_HOOKS_TYPE_MAX_SIZE): Constify.
+       * langhooks.c (lhd_warn_unused_global_decl,
+       lhd_incomplete_type_error,
+       lhd_tree_inlining_disregard_inline_limits,
+       lhd_tree_inlining_auto_var_in_fn_p, lhd_tree_dump_type_quals,
+       lhd_expr_size): Likewise.
+       * langhooks.h (lang_hooks_for_tree_inlining,
+       lang_hooks_for_tree_dump, lang_hooks_for_types,
+       lang_hooks_for_decls, lang_hooks): Likewise.
+       * pointer-set.c (pointer_set_t, pointer_set_create,
+       pointer_set_contains, insert_aux, pointer_set_insert,
+       pointer_set_traverse, pointer_map_t, pointer_map_create,
+       pointer_map_contains, pointer_map_insert, pointer_map_traverse):
+       Likewise.
+       * pointer-set.h (pointer_set_contains, pointer_set_insert,
+       pointer_set_traverse, pointer_map_contains, pointer_map_insert,
+       pointer_map_traverse): Likewise.
+       * predict.c (assert_is_empty): Likewise.
+       * tree-affine.c (free_name_expansion): Likewise.
+       * tree-cfg.c (edge_to_cases_cleanup): Likewise.
+       * tree.c (size_in_bytes, max_int_size_in_bytes): Likewise.
+       * tree.h (size_in_bytes, max_int_size_in_bytes): Likewise.
+
+2007-08-16  Victor Kaplansky <victork@il.ibm.com>
+
+       * tree-vectorizer.c (new_loop_vec_info): Initialize new 
+       field.
+       (destroy_loop_vec_info): Add call to VEC_free.
+       * tree-vectorizer.h (may_alias_ddrs): Define.
+       (LOOP_VINFO_MAY_ALIAS_DDRS): Define.
+       * tree-vect-analyze.c (vect_analyze_data_ref_dependence):
+       Change reporting to dump.
+       (vect_is_duplicate_ddr): New.
+       (vect_mark_for_runtime_alias_test): New.
+       (vect_analyze_data_ref_dependences) Add call to
+       vect_mark_for_runtime_alias_test.
+       (vect_enhance_data_refs_alignment): Define local variable
+       vect_versioning_for_alias_required, don't perform
+       peeling for alignment if versioning for alias is
+       required.
+       (vect_enhance_data_refs_alignment): Use
+       PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS instead of
+       PARAM_VECT_MAX_VERSION_CHECKS.
+       * tree-vect-transform.c
+       (vect_create_cond_for_alias_checks): New.
+       (vect_transform_loop): Add call to
+       vect_create_cond_for_alias_checks.
+       (vect_vfa_segment_size): New.
+       * params.def (PARAM_VECT_MAX_VERSION_FOR_ALIGNMENT_CHECKS):
+       Rename.
+       (PARAM_VECT_MAX_VERSION_FOR_ALIAS_CHECKS): Define.
+       * doc/invoke.texi
+       (vect-max-version-for-alignment-checks): Document.
+       (vect-max-version-for-alias-checks): Document.
+       (vect-max-version-checks): Remove.
+
+2007-08-16  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (*rep_movdi_rex64): Emit "rep" prefix on
+       the same line as the instruction for all asm dialects.
+       (*rep_movsi): Ditto.
+       (*rep_movsi_rex64): Ditto.
+       (*rep_movqi): Ditto.
+       (*rep_movqi_rex64): Ditto.
+       (*rep_stosdi_rex64): Ditto.
+       (*rep_stossi): Ditto.
+       (*rep_stossi_rex64): Ditto.
+       (*rep_stosqi): Ditto.
+       (*rep_stosqi_rex64): Ditto.
+       (*cmpstrnqi_nz_1): Ditto.
+       (*cmpstrnqi_nz_rex_1): Ditto.
+       (*cmpstrnqi_1): Ditto.
+       (*cmpstrnqi_rex_1): Ditto.
+       (*strlenqi_1): Ditto.
+       (*strlenqi_rex_1): Ditto.
+       * config/i386/sync.md (*sync_compare_and_swap<mode>): Emit "lock"
+       prefix on the same line as the instruction for all asm dialects.
+       (sync_double_compare_and_swap<mode>): Ditto.
+       (*sync_double_compare_and_swapdi_pic): Ditto.
+       (*sync_compare_and_swap_cc<mode>): Ditto.
+       (sync_double_compare_and_swap_cc<mode>): Ditto.
+       (*sync_double_compare_and_swap_ccdi_pic): Ditto.
+       (sync_old_add<mode>): Ditto.
+       (sync_add<mode>): Ditto.
+       (sync_sub<mode>): Ditto.
+       (sync_ior<mode>): Ditto.
+       (sync_and<mode>): Ditto.
+       (sync_xor<mode>): Ditto.
+
+2007-08-16  Richard Sandiford  <richard@codesourcery.com>
+
+       PR middle-end/32897
+       * reload.c (find_reloads): Check that the memory returned by
+       find_reloads_toplev was not the result of forcing a constant
+       to memory.
+       (find_reloads_toplev): Always use simplify_gen_subreg to get
+       the subreg of a constant.  If the result is also a constant,
+       but not a legitimate one, force it into the constant pool
+       and reload its address.
+
+2007-08-15  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/rs6000.c (rs6000_rtx_costs): Add CLZ, CTZ, and
+       POPCOUNT.
+
+2007-08-15  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config/rs6000/rs6000.c (rs6000_file_start): Output a .gnu_attribute
+       directive for the current vector ABI.
+
+2007-08-15  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/32963
+       * caller-save.c (reg_save_code): Set invalide status on restore code.
+       
+2007-08-15  Diego Novillo  <dnovillo@google.com>
+
+       * tree-ssa-alias.c (compute_memory_partitions): Use
+       alias_bitmap_obstack to allocate bitmaps.
+       (reset_alias_info): Factor out of init_alias_info.
+       Mark all name tags not associated to an SSA name for renaming.
+       (init_alias_info): Call it.
+       (create_name_tags): Tidy.  Add comments.
+       (dump_points_to_info_for): Do not call get_mem_sym_stats_for.
+
+2007-08-15  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * config/mips/mips.c (vr4130_swap_insns_p): Use new interface to
+       scheduler dependencies.
+
+2007-08-15  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * config/i386/i386.md (subsi3_carry_zext): Remove "m" constraint for
+       "register_operand".
+       (*iorsi_1_zext): Likewise.
+       (*iorsi_1_zext_imm): Likewise.
+       * config/i386/sse.md: (*sse4_1_extractps): Use "nonimmediate_operand"
+       with "rm"/"xm" constraint.
+       (sse2_vmsqrtv2df2): Likewise.
+
+2007-08-15  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/33074
+       * emit-rtl.c (try_split): Use INSN_LIST instead of EXPR_LIST for
+       REG_LIBCALL note.
+
+2007-08-14  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-pass.h (PROP_pta): Removed.
+       (TODO_rebuild_alias): New.
+       (pass_may_alias): Removed.
+       * tree-ssa-ccp.c (execute_fold_all_builtins): Only rebuild
+       aliasing if we changed something.
+       * tree-ssa-alias.c (compute_may_aliases): Make non-static.  Update
+       SSA internally.
+       (pass_may_alias): Removed.
+       (create_structure_vars): Return TODO_rebuild_alias.
+       * tree-ssa-pre.c (do_pre): Return TODO_rebuild_alias.
+       * tree-sra.c (tree_sra): Only rebuild aliasing if something
+       changed.
+       (tree_sra_early): We never affect aliasing right now.
+       * tree-flow.h (compute_may_aliases): New prototype.
+       * passes.c: Remove pass_may_alias from the passes.
+       (execute_function_todo): Support TODO_rebuild_alias.    
+
+2007-08-14  Kai Tietz  <kai.tietz@onevision.com>
+
+       * config/i386/i386.c (legitimize_address): Move dllimported variable
+       check infront of legitimizing pic address of CONST symbols.
+
+2007-08-14  Steve Ellcey  <sje@cup.hp.com>
+
+       PR tree-optimization/32941
+       * tree-eh.c (struct leh_tf_state): Add goto_queue_map field.
+       (goto_queue_cmp): Remove.
+       (find_goto_replacement): Change search method.
+       (maybe_record_in_goto_queue): Add assert.
+       (lower_try_finally): Remove qsort call, add pointer_map_destroy call.
+       * Makefile.in (tree-eh.o): Add pointer-set.h dependency.
+
+2007-08-14  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * alias.c (component_uses_parent_alias_set): Constify.
+       * alias.h (component_uses_parent_alias_set): Likewise.
+       * cfgrtl.c (print_rtl_with_bb): Likewise.
+       * double-int.c (tree_to_double_int, double_int_fits_to_tree_p,
+       mpz_get_double_int): Likewise.
+       * double-int.h (double_int_fits_to_tree_p, tree_to_double_int,
+       mpz_get_double_int): Likewise.
+       * expr.c (is_aligning_offset, undefined_operand_subword_p,
+       mostly_zeros_p, all_zeros_p, safe_from_p, is_aligning_offset):
+       Likewise.
+       * expr.h (safe_from_p): Likewise.
+       * gimple-low.c (try_catch_may_fallthru, block_may_fallthru):
+       Likewise.
+       * gimplify.c (should_carry_locus_p, zero_sized_field_decl,
+       zero_sized_type, goa_lhs_expr_p): Likewise.
+       * omp-low.c (is_variable_sized, use_pointer_for_field): Likewise.
+       * rtl.h (print_rtl_with_bb): Likewise.
+       * sched-vis.c (print_exp, print_value, print_pattern): Likewise.
+       * tree-cfg.c (const_first_stmt, const_last_stmt): New.
+       * tree-flow-inline.h (bb_stmt_list): Constify.
+       (cbsi_start, cbsi_last, cbsi_end_p, cbsi_next, cbsi_prev,
+       cbsi_stmt): New.
+       * tree-flow.h (const_block_stmt_iterator, cbsi_start, cbsi_last,
+       const_first_stmt, const_last_stmt): New.
+       (block_may_fallthru, empty_block_p): Constify.
+       * tree-iterator.c (EXPR_FIRST_BODY, EXPR_LAST_BODY,
+       EXPR_ONLY_BODY): New.
+       (expr_first, expr_last, expr_only): Use macro for body.
+       (const_expr_first, const_expr_last, const_expr_only): New.
+       * tree-iterator.h (const_tree_stmt_iterator, ctsi_start,
+       ctsi_last, ctsi_end_p, ctsi_one_before_end_p, ctsi_next,
+       ctsi_prev, ctsi_stmt): New.
+       * tree-scalar-evolution.c (get_loop_exit_condition): Constify.
+       * tree-scalar-evolution.h (get_loop_exit_condition): Likewise.
+       * tree-ssa-loop-niter.c (loop_only_exit_p,
+       derive_constant_upper_bound): Likewise.
+       * tree-ssa-phiopt.c (empty_block_p): Likewise.
+       * tree-ssa-threadupdate.c (redirection_block_p): Likewise.
+       * tree-vectorizer.c (slpeel_can_duplicate_loop_p): Likewise.
+       * tree-vectorizer.h (slpeel_can_duplicate_loop_p): Likewise.
+       * tree-vrp.c (vrp_bitmap_equal_p): Likewise.
+       * tree.c (get_type_static_bounds): Likewise.
+       * tree.h (const_expr_first, const_expr_last, const_expr_only): New.
+       (get_type_static_bounds): Constify.
+
+2007-08-14  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/30315
+       * config/i386/i386.h (CANONICALIZE_COMPARISON): New.
+       * config/i386/i386.md (plusminus)(addsub)(SWI): New.
+       (*<addsub><mode>3_cc_overflow): New.
+       (*add<mode>3_cconly_overflow): New.
+       (*sub<mode>3_cconly_overflow): New.
+       (*<addsub>si3_zext_cc_overflow): New.
+       * config/i386/predicates.md (fcmov_comparison_operator): Accept
+       CCCmode for LTU, GTU, LEU and GEU.
+       (ix86_comparison_operator): Likewise.
+       (ix86_carry_flag_operator): Carry flag is set if LTU or GTU in CCCmode.
+       * config/i386/i386.c (put_condition_code): Support CCCmode.
+       (ix86_cc_mode): Use CCCmode when testing for overflow of PLUS
+       or MINUS expressions.
+
+2007-08-14  Andrew Pinski  <pinskia@gmail.com>
+
+       PR c/30428
+       * c-typeck.c (build_binary_op): Disallow vector float types with
+       BIT_IOR_EXPR, BIT_AND_EXPR, and BIT_XOR_EXPR.
+
+2007-08-14  Maxim Kuvyrkov  <maxim@codesourcery.com>
+
+       * sched-int.h (struct _dep): Rename field 'kind' to 'type'.
+       (DEP_KIND): Rename to DEP_TYPE.  Update all uses.
+       (dep_def): New typedef.
+       (init_dep_1, sd_debug_dep): Declare functions.
+       (DEP_LINK_KIND): Rename to DEP_LINK_TYPE.
+       (debug_dep_links): Remove.
+       (struct _deps_list): New field 'n_links'.
+       (DEPS_LIST_N_LINKS): New macro.
+       (FOR_EACH_DEP_LINK): Remove.
+       (create_deps_list, free_deps_list, delete_deps_list): Remove
+       declaration.
+       (deps_list_empty_p, debug_deps_list, add_back_dep_to_deps_list): Ditto.
+       (find_link_by_pro_in_deps_list, find_link_by_con_in_deps_list): Ditto.
+       (copy_deps_list_change_con, move_dep_link): Ditto.
+       (struct haifa_insn_data): Split field 'back_deps' into 'hard_back_deps'
+       and 'spec_back_deps'.  New field 'resolved_forw_deps'.  Remove field
+       'dep_count'.
+       (INSN_BACK_DEPS): Remove.
+       (INSN_HARD_BACK_DEPS, INSN_SPEC_BACK_DEPS, INSN_RESOLVED_FORW_DEPS):
+       New macros.
+       (INSN_DEP_COUNT): Remove.
+       (enum DEPS_ADJUST_RESULT): Add new constant DEP_NODEP.  Fix comments.
+       (spec_info, haifa_recovery_block_was_added_during_scheduling_p):
+       Declare global variables.
+       (deps_pools_are_empty_p, sched_free_deps): Declare functions.
+       (add_forw_dep, compute_forward_dependences): Remove declarations.
+       (add_or_update_back_dep, add_or_update_back_forw_dep): Ditto.
+       (add_back_forw_dep, delete_back_forw_dep): Ditto.
+       (debug_ds, sched_insn_is_legitimate_for_speculation_p): Declare
+       functions.
+       (SD_LIST_NONE, SD_LIST_HARD_BACK, SD_LIST_SPEC_BACK, SD_LIST_FORW):
+       New constants.
+       (SD_LIST_RES_BACK, SD_LIST_RES_FORW, SD_LIST_BACK): Ditto.
+       (sd_list_types_def): New typedef.
+       (sd_next_list): Declare function.
+       (struct _sd_iterator): New type.
+       (sd_iterator_def): New typedef.
+       (sd_iterator_start, sd_iterator_cond, sd_iterator_next): New inline
+       functions.
+       (FOR_EACH_DEP): New cycle wrapper.
+       (sd_lists_size, sd_lists_empty_p, sd_init_insn, sd_finish_insn):
+       Declare functions.
+       (sd_find_dep_between, sd_add_dep, sd_add_or_update_dep): Ditto.
+       (sd_resolve_dep, sd_copy_back_deps, sd_delete_dep, sd_debug_lists):
+       Ditto.
+
+       * sched-deps.c (init_dep_1): Make global.
+       (DUMP_DEP_PRO, DUMP_DEP_CON, DUMP_DEP_STATUS, DUMP_DEP_ALL): New
+       constants.
+       (dump_dep): New static function.
+       (dump_dep_flags): New static variable.
+       (sd_debug_dep): New function.
+       (add_to_deps_list, remove_from_deps_list): Update 'n_links' field of
+       the list.
+       (move_dep_link): Use remove_from_deps_list (), instead of
+       detach_dep_link ().
+       (dep_links_consistent_p, dump_dep_links, debug_dep_links): Remove.
+       (dep_link_is_detached_p): New static function.
+       (deps_obstack, dl_obstack, dn_obstack): Remove.  Use dn_pool, dl_pool
+       instead.
+       (dn_pool, dl_pool): New alloc_pools.
+       (dn_pool_diff, dl_pool_diff): New static variables.
+       (create_dep_node, delete_dep_node): New static function.
+       (create_deps_list): Make it static.  Use alloc_pool 'dl_pool'.
+       (deps_list_empty_p): Make it static.  Use 'n_links' field.
+       (deps_pools_are_empty_p): New static function.
+       (alloc_deps_list, delete_deps_list): Remove.
+       (dump_deps_list, debug_deps_list, add_back_dep_to_deps_list): Remove.
+       (find_link_by_pro_in_deps_list, find_link_by_con_in_deps_list): Ditto.
+       (copy_deps_list_change_con): Remove.  Use sd_copy_back_deps () instead.
+       (forward_dependency_cache): Remove.
+       (maybe_add_or_update_back_dep_1, add_or_update_back_dep_1): Remove
+       'back' from the names.  Change signature to use dep_t instead of
+       equivalent quad.
+       (add_back_dep): Ditto.  Make global.
+       (check_dep_status): Rename to check_dep ().
+       (sd_next_list, sd_lists_size, sd_lists_empty_p, sd_init_insn):
+       New functions.
+       (sd_finish_insn): Ditto.
+       (sd_find_dep_between_no_cache): New static function.
+       (sd_find_dep_between): New function.
+       (ask_dependency_caches, set_dependency_caches): New static functions.
+       (update_dependency_caches, change_spec_dep_to_hard, update_dep): Ditto.
+       (add_or_update_dep_1): Separate pieces of functionality into
+       ask_dependency_caches (), update_dependency_caches (),
+       change_spec_dep_to_hard (), update_dep ().
+       (get_back_and_forw_lists): New static function.
+       (sd_add_dep): Separate setting of dependency caches into
+       set_dependency_caches ().
+       (sd_add_or_update_dep, sd_resolve_dep, sd_copy_back_deps):
+       New functions.
+       (sd_delete_dep): Ditto.
+       (DUMP_LISTS_SIZE, DUMP_LISTS_DEPS, DUMP_LISTS_ALL): New constants.
+       (dump_lists): New static function.
+       (sd_debug_lists): New debug function.
+       (delete_all_dependences, fixup_sched_groups): Update to use
+       sd_* infrastructure.
+       (sched_analyze_2): Create data-speculative dependency only if
+       data-speculation is enabled.
+       (sched_analyze_insn): If insn cannot be speculative, make all its
+       dependencies non-speculative.
+       (sched_analyze): Use sd_init_insn ().
+       (add_forw_dep, compute_forward_dependencies): Remove.
+       (delete_dep_nodes_in_back_deps): New static function.
+       (sched_free_deps): New function.
+       (init_dependency_caches): Init alloc_pools.
+       (extend_depedency_caches): Update after removing of
+       forward_dependency_cache.
+       (free_dependency_caches): Ditto.  Free alloc_pools.
+       (adjust_add_sorted_back_dep, adjust_back_add_forw_dep): Remove.
+       (delete_forw_dep, add_or_update_back_dep, add_or_update_back_forw_dep):
+       Ditto.
+       (add_back_forw_dep, delete_back_forw_dep): Ditto.
+       (add_dependence): Use init_dep ().
+       (get_dep_weak_1): New static function.
+       (get_dep_weak): Move logic to get_dep_weak_1 ().
+       (dump_ds): New static function moved from haifa-sched.c:
+       debug_spec_status ().
+       (debug_ds): New debug function.
+       (check_dep_status): Rename to check_dep ().  Update to check whole
+       dependencies.
+
+       * haifa-sched.c (spec_info): Make global.
+       (added_recovery_block_p): Rename to
+       'haifa_recovery_block_was_added_during_current_schedule_block_p'.
+       (haifa_recovery_block_was_added_during_scheduling_p): New variable.
+       (dep_cost, priority, rank_for_schedule, schedule_insn): Update
+       to use new interfaces.
+       (ok_for_early_queue_removal): Ditto.
+       (schedule_block): Initialize logical uids of insns emitted by the
+       target.
+       (sched_init): Initialize new variable.
+       (fix_inter_tick, try_ready, fix_tick_ready): Update to use new
+       interfaces.
+       (extend_global): Initialize insn data.
+       (init_h_i_d): Remove code that is now handled in sd_init_insn ().
+       (process_insn_forw_deps_be_in_spec): Change signature.  Update to use
+       new interfaces.
+       (add_to_speculative_block): Update to use new interfaces.
+       (create_recovery_block): Set new variables.
+       (create_check_block_twin, fix_recovery_deps): Update to use new
+       interfaces.
+       (sched_insn_is_legitimate_for_speculation_p): New function.
+       (speculate_insn): Move checking logic to
+       sched_insn_is_legitimate_for_speculation_p ().
+       (sched_remove_insn): Finalize sched-deps information of instruction.
+       (clear_priorities, add_jump_dependencies): Update to use new
+       interfaces.
+       (debug_spec_status): Rename to dump_ds () and move to sched-deps.c.
+       
+       * sched-rgn.c (set_spec_fed, find_conditional_protection): Update
+       to use new interfaces.
+       (is_conditionally_protected, is_pfree, is_prisky) Ditto.
+       (new_ready): Try to use control speculation only if it is available.
+       (add_branch_dependences): Update to use new interfaces.
+       (compute_block_backward_dependences): Rename to
+       compute_block_dependences ().  Call
+       targetm.sched.dependencies_evaluation_hook ().
+       (free_block_dependencies): New static function.
+       (debug_dependencies): Update to use new interfaces.
+       (schedule_region): Remove separate computation of forward dependencies.
+       Move call of targetm.sched.dependencies_evaluation_hook () to
+       compute_block_dependences ().  Free dependencies at the end of
+       scheduling the region.
+
+       * sched-ebb.c (earliest_block_with_similiar_load): Update to use
+       new interfaces.
+       (add_deps_for_risky_insns): Ditto.
+       (schedule_ebb): Remove separate computation of forward dependencies.
+       Free dependencies at the end of scheduling the ebb.
+
+       * ddg.c (create_ddg_dependence): Update to use new interfaces.
+       (build_intra_loop_deps): Ditto.  Remove separate computation of
+       forward dependencies.  Free sched-deps dependencies.
+
+       * config/ia64/ia64.c (ia64_dependencies_evaluation_hook): Update
+       to use new interfaces.
+       (ia64_dfa_new_cycle, ia64_gen_check): Ditto.
+
+       * config/rs6000/rs6000.c (rs6000_is_costly_dependence): Update to use
+       new interfaces.
+       (is_costly_group): Ditto.
+
+2007-08-14  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * alias.c (rtx_equal_for_memref_p): Constify.
+       * basic-block.h (const_edge, const_basic_block): New.
+       (reg_set_to_hard_reg_set, dfs_enumerate_from, single_succ_p,
+       single_pred_p, single_succ_edge, single_pred_edge, single_succ,
+       single_pred, maybe_hot_bb_p, probably_cold_bb_p,
+       probably_never_executed_bb_p, edge_probability_reliable_p,
+       br_prob_note_reliable_p, forwarder_block_p, flow_nodes_print,
+       inside_basic_block_p, control_flow_insn_p, dominated_by_p):
+       Likewise.
+       * bb-reorder.c (better_edge_p, push_to_next_round_p): Likewise.
+       * bt-load.c (basic_block_freq, insn_sets_btr_p, can_move_up):
+       Likewise.
+       * cfganal.c (flow_active_insn_p, forwarder_block_p,
+       flow_nodes_print, dfs_enumerate_from): Likewise.
+       * cfgbuild.c (count_basic_blocks, inside_basic_block_p,
+       control_flow_insn_p, count_basic_blocks): Likewise.
+       * cfgloop.c (flow_bb_inside_loop_p, glb_enum_p,
+       get_loop_body_with_size, loop_exit_edge_p): Likewise.
+       * cfgloop.h (flow_bb_inside_loop_p, num_loop_insns,
+       average_num_loop_insns, loop_exit_edge_p,
+       just_once_each_iteration_p, can_duplicate_loop_p): Likewise.
+       * cfgloopanal.c (just_once_each_iteration_p, num_loop_insns,
+       average_num_loop_insns, seq_cost): Likewise.
+       * cfgloopmanip.c (rpe_enum_p, can_duplicate_loop_p): Likewise.
+       * dominance.c (dominated_by_p): Likewise.
+       * emit-rtl.c (validate_subreg): Likewise.
+       * except.c (can_throw_internal, can_throw_external): Likewise.
+       * except.h (can_throw_internal, can_throw_external): Likewise.
+       * gcse.c (gcse_constant_p, oprs_unchanged_p, oprs_anticipatable_p,
+       oprs_available_p, hash_expr, expr_equiv_p, oprs_not_set_p,
+       compute_transp, load_killed_in_block_p, reg_killed_on_edge,
+       simple_mem, store_ops_ok, load_kills_store, find_loads,
+       store_killed_in_insn, store_killed_after, store_killed_before,
+       gcse_mem_operand, implicit_set_cond_p, store_killed_in_pat):
+       Likewise.
+       * ifcvt.c (count_bb_insns, cheap_bb_rtx_cost_p, noce_operand_ok,
+       noce_mem_write_may_trap_or_fault_p): Likewise.
+       * pointer-set.c (pointer_set_contains, pointer_map_contains):
+       Likewise.
+       * pointer-set.h (pointer_set_contains, pointer_map_contains):
+       Likewise.
+       * predict.c (can_predict_insn_p, maybe_hot_bb_p,
+       probably_cold_bb_p, probably_never_executed_bb_p,
+       edge_probability_reliable_p, br_prob_note_reliable_p,
+       can_predict_insn_p): Likewise.
+       * regclass.c (reg_set_to_hard_reg_set): Likewise.
+       * resource.c (return_insn_p): Likewise.
+       * rtl.h (reg_set_between_p, reg_set_p, validate_subreg):
+       Likewise.
+       * rtlanal.c (reg_set_between_p, reg_set_p): Likewise.
+       * tracer.c (count_insns, ignore_bb_p, better_p): Likewise.
+       * tree-cfg.c (verify_gimple_unary_expr, verify_gimple_binary_expr,
+       verify_gimple_modify_stmt): Likewise.
+       * tree-chrec.c (is_not_constant_evolution,
+       is_multivariate_chrec_rec, is_multivariate_chrec,
+       chrec_contains_symbols, chrec_contains_undetermined,
+       tree_contains_chrecs, evolution_function_is_affine_multivariate_p,
+       evolution_function_is_univariate_p, avoid_arithmetics_in_type_p,
+       eq_evolutions_p, scev_direction): Likewise.
+       * tree-chrec.h (automatically_generated_chrec_p, tree_is_chrec,
+       eq_evolutions_p, is_multivariate_chrec, chrec_contains_symbols,
+       chrec_contains_symbols_defined_in_loop,
+       chrec_contains_undetermined, tree_contains_chrecs,
+       evolution_function_is_affine_multivariate_p,
+       evolution_function_is_univariate_p, chrec_zerop,
+       evolution_function_is_constant_p, evolution_function_is_affine_p,
+       evolution_function_is_affine_or_constant_p,
+       tree_does_not_contain_chrecs, chrec_type): Likewise.
+       * tree-data-ref.c (tree_fold_divides_p,
+       object_address_invariant_in_loop_p, dr_may_alias_p,
+       ziv_subscript_p, siv_subscript_p, gcd_of_steps_may_divide_p,
+       same_access_functions, constant_access_functions,
+       access_functions_are_affine_or_constant_p, find_vertex_for_stmt):
+       Likewise.
+       * tree-flow.h (scev_direction): Likewise.
+       * tree-gimple.c (is_gimple_stmt): Likewise.
+       * tree-outof-ssa.c (identical_copies_p, identical_stmt_lists_p):
+       Likewise.
+       * tree-pretty-print.c (op_prio): Likewise.
+       * tree-scalar-evolution.c (chrec_contains_symbols_defined_in_loop,
+       analyzable_condition, backedge_phi_arg_p): Likewise.
+       * tree-scalar-evolution.h (get_chrec_loop): Likewise.
+       * tree-ssa-operands.c (get_name_decl, operand_build_cmp): Likewise.
+       * tree-ssa-threadupdate.c (dbds_continue_enumeration_p):
+       Likewise.
+
+2007-08-13  Dan Hipschman  <dsh@google.com>
+
+       PR c/32953
+       * c-format.c (check_format_arg): Move check for zero-length
+       format strings below the check for unterminated strings.
+
+2007-08-13  Andrew Pinski  <pinskia@gmail.com>
+
+       PR C/30427
+       * c-typeck.c (build_unary_op <case BIT_NOT_EXPR>): Reject vector float
+       types.
+
+2007-08-13  Nick Clifton  <nickc@redhat.com>
+
+       * config/arm/arm_neon.h: Revert GPLv3 patch to this file.
+
+2007-08-12  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
+
+       PR fortran/32860
+       * c-format.c (gcc_gfc_length_specs): New array.
+       (gcc_gfc_char_table): Add unsigned specifier, and references to
+       the l length modifier.
+       (format_types_orig): Use the new gcc_gfc_length_specs.
+
+2007-08-12  Sa Liu  <saliu@de.ibm.com>
+
+       * emit-rtl.c (try_split): Relink the insns with REG_LIBCALL note
+       and with REG_RETVAL note after split.
+
+2007-08-11  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/mips.c (mips_sched_reorder): Mark cycle parameter
+       as ATTRIBUTE_UNUSED.
+
+2007-08-11  David Edelsohn  <edelsohn@gnu.org>
+           Segher Boessenkool  <segher@kernel.crashing.org>
+
+       * config/rs6000/rs6000.h (CC1_CPU_SPEC): Define as empty string if
+       HAVE_LOCAL_CPU_DETECT not defined.
+
+2007-08-11  Jan Hubicka  <jh@suse.cz>
+
+       * cgraphunit.c (record_cdtor_fn): Declare all cdtors always inlined.
+       (cgraph_process_new_functions): Honor previous value of
+       disregard_inline_limits.
+       * ipa-inline.c (compute_inline_parameters): Likewise.
+
+2007-08-11  Ian Lance Taylor  <iant@google.com>
+
+       * alias.h (alias_set_type): Define new type.
+       (ALIAS_SET_MEMORY_BARRIER): Use it.
+       * rtl.h: Include alias.h.
+       (struct mem_attrs): Use alias_set_type.
+       * tree.h: Include alias.h
+       (struct tree_type): Use alias_set_type.
+       (struct tree_struct_field_tag): Likewise.
+       (struct tree_decl_common): Likewise.
+       * alias.c (struct alias_set_entry): Use alias_set_type.
+       (get_alias_set_entry, alias_set_subset_of): Likewise.
+       (alias_sets_conflict_p): Likewise.
+       (alias_sets_must_conflict_p): Likewise.
+       (objects_must_conflict_p): Likewise.
+       (get_alias_set, new_alias_set): Likewise.
+       (record_alias_subset, record_component_aliases): Likewise.
+       (varargs_set, frame_set): Change to alias_set_type.
+       (get_varargs_alias_set): Use alias_set_type.
+       (get_frame_alias_set): Likewise.
+       * builtins.c (setjmp_alias_set): Change to alias_set_type.
+       * dse.c (struct store_info): Use alias_set_type.
+       (struct read_info, struct clear_alias_mode_holder): Likewise.
+       (clear_alias_set_lookup, canon_address): Likewise.
+       (record_store, check_mem_read_rtx): Likewise.
+       (dse_record_singleton_alias_set): Likewise.
+       (dse_invalidate_singleton_alias_set): Likewise.
+       * emit-rtl.c (get_mem_attrs): Likewise.
+       (set_mem_attributes_minus_bitpos): Likewise.
+       (set_mem_alias_set): Likewise.
+       * expr.c (store_constructor_field, store_field): Likewise.
+       * gimplify.c (struct gimplify_init_ctor_preeval_data): Likewise.
+       * langhooks.c (lhd_get_alias_set): Likewise.
+       * langhooks-def.h (lhd_get_alias_set): Likewise.
+       * reload1.c (alter_reg): Likewise.
+       * tree-flow.h (struct fieldoff): Likewise.
+       * tree-ssa-alias.c (struct alias_map_d): Likewise.
+       (may_alias_p, get_smt_for, create_sft): Likewise.
+       * tree-ssa-alias-warnings.c (nonstandard_alias_types_p): Likewise.
+       * tree-ssa-structalias.c (set_uids_in_ptset): Likewise.
+       (merge_smts_into): Likewise.
+       * varasm.c (const_alias_set): Likewise.
+       * c-common.c (strict_aliasing_warning): Likewise.
+       (c_common_get_alias_set): Likewise.
+       * dse.h (dse_record_singleton_alias_set): Update declaration.
+       (dse_invalidate_singleton_alias_set): Likewise.
+       * emit-rtl.h (set_mem_alias_set): Likewise.
+       * c-common.h (c_common_get_alias_set): Likewise.
+       * print-rtl.c (print_rtx): Cast MEM_ALIAS_SET when printing it.
+       * print-tree.c (print_node): Likewise.
+       * config/alpha/alpha.c (alpha_sr_alias_set): Change to
+       alias_set_type.
+       (alpha_setup_incoming_varargs): Use alias_set_type.
+       * config/i386/i386.c (setup_incoming_varargs_64): Use
+       alias_set_type.
+       (setup_incoming_varargs_ms_64): Likewise.
+       (ix86_GOT_alias_set): Likewise.
+       * config/mn10300/mn10300.c (mn10300_builtin_saveregs): Likewise.
+       * config/rs6000/rs6000.c (setup_incoming_varargs): Likewise.
+       (set): Change to alias_set_type.
+       (get_TOC_alias_set): Use alias_set_type.
+       * config/rs6000/rs6000-protos.h (get_TOC_alias_set): Update
+       declaration.
+       * config/sh/sh.c (sh_builtin_saveregs): Use alias_set_type.
+       * config/sparc/sparc.c (sparc_sr_alias_set): Change to
+       alias_set_type.
+       (struct_value_alias_set): Likewise.
+       * Makefile.in (GTFILES): Add $(srcdir)/alias.h.
+
+2007-08-11  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/vxworks-dummy.h (TARGET_VXWORKS): Define.
+       * config/vxworks.h (TARGET_VXWORKS): Override.
+       * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Don't define
+       "mips" if TARGET_VXWORKS.
+
+2007-08-11  Richard Sandiford  <richard@codesourcery.com>
+
+       * calls.c (avoid_likely_spilled_reg): New function.
+       (expand_call): Use it.
+
+2007-08-11  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * c-typeck.c (build_c_cast): Add OPT_Wcast_qual to warnings.
+
+2007-08-10  Adam Nemet  <anemet@caviumnetworks.com>
+
+       * config/mips/predicates.md (const_call_insn_operand): Invoke
+       SYMBOL_REF_LONG_CALL_P only on SYMBOL_REFs.
+
+2007-08-10  David Edelsohn  <edelsohn@gnu.org>
+
+       PR target/33042
+       * config/rs6000/driver-rs6000.c: Include link.h.
+       Use ElfW instead of wordsize-specif typedef.
+
+2007-08-10  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * system.h (CONST_CAST): New.
+       * c-decl.c (c_make_fname_decl): Use it.
+       * c-lex.c (cb_ident, lex_string): Likewise.
+       * c-typeck.c (free_all_tagged_tu_seen_up_to): Likewise.
+       * gcc.c (set_spec, read_specs, for_each_path, execute, do_spec_1,
+       give_switch, set_multilib_dir): Likewise.
+       * gengtype-parse.c (string_seq, typedef_name): Likewise.
+       * passes.c (execute_one_pass): Likewise.
+       * prefix.c (update_path): Likewise.
+       * pretty-print.c (pp_base_destroy_prefix): Likewise.
+       * tree.c (build_string): Likewise.
+
+2007-08-10  Aldy Hernandez  <aldyh@redhat.com>
+
+       * tree-flow-inline.h (is_exec_stmt): Remove.
+       (is_label_stmt): Remove.
+       * tree-flow.h: Remove prototypes for is_exec_stmt, get_filename, and
+       is_label_stmt.
+
+2007-08-10  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * lower-subreg.c (resolve_shift_zext): Don't adjust
+       src_reg_num for wordmode operands.
+
+2007-08-10  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+
+       * config/mips/mips.c (TARGET_SCHED_INIT): Define.
+       (TARGET_SCHED_REORDER2): Define.
+       (mips_maybe_swap_ready): New.
+       (mips_last_74k_agen_insn): New.
+       (mips_74k_agen_init): New.
+       (mips_74k_agen_reorder): New function to group loads and stores
+       in the ready queue.
+       (mips_sched_init): New.  
+       (mips_sched_reorder): Don't do initialization here.  Call
+       mips_74k_agen_reorder.
+       (mips_variable_issue): Call mips_74k_agen_init.
+
+2007-08-10  Aldy Hernandez  <aldyh@redhat.com>
+
+       * tree-flow-inline.h (get_filename): Remove.
+
+2007-08-10  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h (mips_address_insns): Add a boolean
+       argument.
+       (mips_fetch_insns): Delete in favor of...
+       (mips_load_store_insns): ...this new function.
+       * config/mips/mips.c (mips_address_insns): Add a boolean argument
+       to say whether multiword moves _might_ be split.
+       (mips_fetch_insns): Delete in favor of...
+       (mips_load_store_insns): ...this new function.
+       (mips_rtx_costs): Update the call to mips_address_insns.
+       (mips_address_cost): Likewise.
+       * config/mips/mips.md (length): Use mips_load_store_insns instead
+       of mips_fetch_insns.
+       * config/mips/constraints.md (R): Use mips_address_insns rather
+       than mips_fetch_insns.  Assume that the move never needs to be split.
+
+2007-08-09  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * config/mips/mips.opt (mhard-float, msoft-float): Make these
+       control TARGET_HARD_FLOAT_ABI and TARGET_SOFT_FLOAT_ABI, rather
+       than TARGET_HARD_FLOAT and TARGET_SOFT_FLOAT.  
+       * config/mips/mips.h (mips16_hard_float): Delete.
+       (TARGET_HARD_FLOAT_ABI, TARGET_SOFT_FLOAT_ABI): Delete these
+       definitions, and replace with....
+       (TARGET_HARD_FLOAT, TARGET_SOFT_FLOAT): Define.
+       * config/mips/mips.c (mips16_hard_float): Delete.  Replace
+       all references with (TARGET_MIPS16 && TARGET_HARD_FLOAT_ABI).
+       (MIPS_MARCH_CONTROLS_SOFT_FLOAT): Update comments.
+       (override_options): Replace MASK_SOFT_FLOAT references with
+       MASK_SOFT_FLOAT_ABI.  Delete twiddling with MASK_SOFT_FLOAT
+       and mips16_hard_float when TARGET_MIPS16.
+       
+2007-08-09  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR c/32796
+       * c-typeck.c (build_binary_op): Check for non pointer types before
+       calling int_fits_type_p.
+
+2007-08-09  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/32813
+       * fold-const.c (omit_one_operand): Return only the ommitted expression
+       if the result is an empty statement.
+       (pedantic_omit_one_operand): Likewise.
+
+2007-08-09  Daniel Berlin  <dberlin@dberlin.org>
+
+       * c-typeck.c (readonly_error): Improve error for assignment.
+       
+       * c-pretty-print.c (pp_c_additive_expression): Handle pointer-plus
+       expression. 
+       (pp_c_expression): Ditto.
+
+2007-08-09  Simon Baldwin  <simonb@google.com>
+
+       * simplify-rtx.c (simplify_binary_operation_1): Removed erroneous
+       break that was preventing simplify_associative_operation() for xor.
+
+2007-08-09  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * doc/tm.texi (CLZ_DEFINED_VALUE_AT_ZERO, CTZ_DEFINED_VALUE_AT_ZERO):
+       Document change in interpretation of value from boolean to
+       tri-state integer.
+       * optabs.c (expand_ffs, expand_ctz): New functions to compute
+       ffs and ctz using clz.
+       (expand_unop): Call them.
+       * config/rs6000/rs6000.h (CLZ_DEFINED_VALUE_AT_ZERO): Fix its
+       result value.
+       (CTZ_DEFINED_VALUE_AT_ZERO): Likewise.
+       * config/mips/mips.h (CLZ_DEFINED_VALUE_AT_ZERO): Likewise, to
+       enable the new ffs expansion on this target.
+
+2007-08-09  Jan Hubicka  <jh@suse.cz>
+
+       * optabs.c (expand_widen_pattern_expr): Use optabs accestors.
+       (expand_ternary_op): Likewise.
+       (expand_vec_shift_expr): Likewise.
+       (expand_binop_directly): Likewise.
+       (expand_binop): Likewise.
+       (sign_expand_binop): Likewise.
+       (expand_twoval_unop): Likewise.
+       (expand_twoval_binop): Likewise.
+       (expand_twoval_binop_libfunc): Likewise.
+       (widen_clz): Likewise.
+       (widen_bswap): Likewise.
+       (expand_parity): Likewise.
+       (expand_unop): Likewise.
+       (expand_abs_nojump): Likewise.
+       (expand_copysign): Likewise.
+       (emit_no_conflict_block): Likewise.
+       (emit_libcall_block): Likewise.
+       (can_compare_p): Likewise.
+       (prepare_cmp_insn): Likewise.
+       (emit_cmp_and_jump_insn_1): Likewise.
+       (prepare_float_lib_cmp): Likewise.
+       (emit_conditional_add): Likewise.
+       (gen_add2_insn): Likewise.
+       (have_add2_insn): Likewise.
+       (gen_sub2_insn): Likewise.
+       (have_sub2_insn): Likewise.
+       (can_extend_p): Likewise.
+       (can_fix_p): Likewise.
+       (can_float_p): Likewise.
+       (expand_float): Likewise.
+       (expand_fix): Likewise.
+       (expand_sfix_optab): Likewise.
+       (new_optab): Likewise.
+       (new_convert_optab): Likewise.
+       (init_libfuncs): Likewise.
+       (init_interclass_conv_libfuncs): Likewise.
+       (init_intraclass_conv_libfuncs): Likewise.
+       (set_conv_libfunc): Likewise.
+       (init_optabs): Likewise.
+       (debug_optab_libfuncs): Likewise.
+       (gen_cond_trap): Likewise.
+       * optabs.h (optab_handler, convert_optab_hanlder): New.
+       * genopinit.c: Update optabs generation table.
+       * reload.c (find_reloads_address_1): Use optabs accestors.
+       * builtins.c (expand_builtin_mathfn): Likewise.
+       (expand_builtin_mathfn_2): Likewise.
+       (expand_builtin_mathfn_3): Likewise.
+       (expand_builtin_interclass_mathfn): Likewise.
+       (expand_builtin_sincos): Likewise.
+       (expand_builtin_cexpi): Likewise.
+       (expand_builtin_powi): Likewise.
+       (expand_builtin_strlen): Likewise.
+       * dojump.c (do_jump): Likewise.
+       * expr.c (convert_move): Likewise.
+       (move_by_pieces): Likewise.
+       (move_by_pieces_ninsns): Likewise.
+       (can_store_by_pieces): Likewise.
+       (store_by_pieces_1): Likewise.
+       (emit_move_via_integer): Likewise.
+       (emit_move_complex): Likewise.
+       (emit_move_ccmode): Likewise.
+       (emit_move_insn_1): Likewise.
+       (emit_single_push_insn): Likewise.
+       (store_constructor): Likewise.
+       (expand_expr_real_1): Likewise.
+       (do_store_flag): Likewise.
+       * ada/misc.c (gnat_compute_largest_alignment): Likewise.
+       (enumerate_modes): Likewise.
+       * tree-vectorizer.c (vect_supportable_dr_alignment): Likewise.
+       (supportable_widening_operation): Likewise.
+       (supportable_narrowing_operation): Likewise.
+       * expmed.c (store_bit_field_1): Likewise.
+       (extract_bit_field_1): Likewise.
+       (expand_mult_highpart_optab): Likewise.
+       (expand_smod_pow2): Likewise.
+       (expand_divmod): Likewise.
+       (emit_store_flag): Likewise.
+       * tree-vect-patterns.c
+       (vect_pattern_recog_1): Likewise.
+       * tree-ssa-loop-prefetch.c
+       (nontemporal_store_p): Likewise.
+       * tree-vect-transform.c (vect_model_reduction_cost): Likewise.
+       (vect_create_epilog_for_reduction): Likewise.
+       (vectorizable_reduction): Likewise.
+       (vectorizable_operation): Likewise.
+       (vect_strided_store_supported): Likewise.
+       (vectorizable_store): Likewise.
+       (vect_strided_load_supported): Likewise.
+       (vectorizable_load): Likewise.
+       * combine.c (simplify_comparison): Likewise.
+       * tree-vect-generic.c
+       (type_for_widest_vector_mode): Likewise.
+       (expand_vector_operations_1): Likewise.
+       * config/spu/spu.c (spu_expand_mov): Likewise.
+       (spu_emit_vector_compare): Likewise.
+       * config/rs6000/rs6000.c
+       (rs6000_emit_vector_compare): Likewise.
+       * stmt.c (add_case_node): Likewise.
+       * reload1.c (gen_reload):
+
+2007-08-09  Michael Matz  <matz@suse.de>
+
+       * tree.h (fixed_zerop): Declare as taking a const_tree.
+       * tree.c (fixed_zerop): Take a const_tree.
+
+2007-08-09  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-vect-transform.c (vectorizable_store): Remove call to
+       copy_virtual_operands() and call mark_symbols_for_renaming() for
+       the created vector store.
+       (vect_setup_realignment): Don't call copy_virtual_operands() and
+       update_vuses_to_preheader(). 
+       (vectorizable_load): Don't call copy_virtual_operands(). 
+       (update_vuses_to_preheader): Remove.
+
+2007-08-08  Chao-ying Fu  <fu@mips.com>
+
+       * tree.def (FIXED_POINT_TYPE): New type.
+       (FIXED_CST): New constant.
+       (FIXED_CONVERT_EXPR): New expr.
+       * doc/c-tree.texi (Types): Document FIXED_POINT_TYPE.
+       (Expressions): Document FIXED_CST and FIXED_CONVERT_EXPR.
+       * tree.h (struct tree_base): Add saturating_flag.
+       Remove one bit of spare for saturating_flag.
+       (NUMERICAL_TYPE_CHECK): Support FIXED_POINT_TYPE.
+       (NON_SAT_FIXED_POINT_TYPE_P, SAT_FIXED_POINT_TYPE_P,
+       FIXED_POINT_TYPE_P): Define.
+       (TYPE_SATURATING): Define.
+       (TREE_FIXED_CST_PTR, TREE_FIXED_CST): Define.
+       (struct tree_fixed_cst): New.
+       (TYPE_IBIT, TYPE_FBIT): Define.
+       (tree_node): Add fixed_cst.
+       (enum tree_index): Add new enumeration values of
+       TI_SAT_SFRACT_TYPE, TI_SAT_FRACT_TYPE, TI_SAT_LFRACT_TYPE,
+       TI_SAT_LLFRACT_TYPE, TI_SAT_USFRACT_TYPE, TI_SAT_UFRACT_TYPE,
+       TI_SAT_ULFRACT_TYPE, TI_SAT_ULLFRACT_TYPE, TI_SFRACT_TYPE,
+       TI_FRACT_TYPE, TI_LFRACT_TYPE, TI_LLFRACT_TYPE, TI_USFRACT_TYPE,
+       TI_UFRACT_TYPE, TI_ULFRACT_TYPE, TI_ULLFRACT_TYPE,
+       TI_SAT_SACCUM_TYPE, TI_SAT_ACCUM_TYPE, TI_SAT_LACCUM_TYPE,
+       TI_SAT_LLACCUM_TYPE, TI_SAT_USACCUM_TYPE, TI_SAT_UACCUM_TYPE,
+       TI_SAT_ULACCUM_TYPE, TI_SAT_ULLACCUM_TYPE, TI_SACCUM_TYPE,
+       TI_ACCUM_TYPE, TI_LACCUM_TYPE, TI_LLACCUM_TYPE, TI_USACCUM_TYPE,
+       TI_UACCUM_TYPE, TI_ULACCUM_TYPE, TI_ULLACCUM_TYPE,
+       TI_QQ_TYPE, TI_HQ_TYPE,_TYPE, TI_SQ_TYPE, TI_DQ_TYPE, TI_TQ_TYPE,
+       TI_UQQ_TYPE, TI_UHQ_TYPE, TI_USQ_TYPE, TI_UDQ_TYPE, TI_UTQ_TYPE,
+       TI_SAT_QQ_TYPE, TI_SAT_HQ_TYPE, TI_SAT_SQ_TYPE, TI_SAT_DQ_TYPE,
+       TI_SAT_TQ_TYPE, TI_SAT_UQQ_TYPE, TI_SAT_UHQ_TYPE, TI_SAT_USQ_TYPE,
+       TI_SAT_UDQ_TYPE, TI_SAT_UTQ_TYPE, TI_HA_TYPE, TI_SA_TYPE, TI_DA_TYPE,
+       TI_TA_TYPE, TI_UHA_TYPE, TI_USA_TYPE, TI_UDA_TYPE, TI_UTA_TYPE,
+       TI_SAT_HA_TYPE, TI_SAT_SA_TYPE, TI_SAT_DA_TYPE, TI_SAT_TA_TYPE,
+       TI_SAT_UHA_TYPE, TI_SAT_USA_TYPE, TI_SAT_UDA_TYPE, TI_SAT_UTA_TYPE.
+       (sat_short_fract_type_node, sat_fract_type_node,
+       sat_long_fract_type_node, sat_long_long_fract_type_node,
+       sat_unsigned_short_fract_type_node, sat_unsigned_fract_type_node,
+       sat_unsigned_long_fract_type_node,
+       sat_unsigned_long_long_fract_type_node, short_fract_type_node,
+       fract_type_node, long_fract_type_node, long_long_fract_type_node,
+       unsigned_short_fract_type_node, unsigned_fract_type_node,
+       unsigned_long_fract_type_node, unsigned_long_long_fract_type_node,
+       sat_short_accum_type_node, sat_accum_type_node,
+       sat_long_accum_type_node, sat_long_long_accum_type_node,
+       sat_unsigned_short_accum_type_node, sat_unsigned_accum_type_node,
+       sat_unsigned_long_accum_type_node,
+       sat_unsigned_long_long_accum_type_node, short_accum_type_node,
+       accum_type_node, long_accum_type_node, long_long_accum_type_node,
+       unsigned_short_accum_type_node, unsigned_accum_type_node,
+       unsigned_long_accum_type_node, unsigned_long_long_accum_type_node,
+       qq_type_node, hq_type_node, sq_type_node, dq_type_node, tq_type_node,
+       uqq_type_node, uhq_type_node, usq_type_node, udq_type_node,
+       utq_type_node, sat_qq_type_node, sat_hq_type_node, sat_sq_type_node,
+       sat_dq_type_node, sat_tq_type_node, sat_uqq_type_node,
+       sat_uhq_type_node, sat_usq_type_node, sat_udq_type_node,
+       sat_utq_type_node, ha_type_node, sa_type_node, da_type_node,
+       ta_type_node, uha_type_node, usa_type_node, uda_type_node,
+       uta_type_node, sat_ha_type_node, sat_sa_type_node, sat_da_type_node,
+       sat_ta_type_node, sat_uha_type_node, sat_usa_type_node,
+       sat_uda_type_node, sat_uta_type_node): New macro.
+       (make_fract_type, make_accum_type): Declare.
+       (make_signed_fract_type, make_unsigned_fract_type,
+       make_sat_signed_fract_type, make_sat_unsigned_fract_type,
+       make_signed_accum_type, make_unsigned_accum_type,
+       make_sat_signed_accum_type, make_sat_unsigned_accum_type,
+       make_or_reuse_signed_fract_type, make_or_reuse_unsigned_fract_type,
+       make_or_reuse_sat_signed_fract_type,
+       make_or_reuse_sat_unsigned_fract_type, make_or_reuse_signed_accum_type,
+       make_or_reuse_unsigned_accum_type, make_or_reuse_sat_signed_accum_type,
+       make_or_reuse_sat_unsigned_accum_type): New macro.
+       (fixed_zerop): Declare.
+       * defaults.h (SHORT_FRACT_TYPE_SIZE, FRACT_TYPE_SIZE,
+       LONG_FRACT_TYPE_SIZE, LONG_LONG_FRACT_TYPE_SIZE,
+       SHORT_ACCUM_TYPE_SIZE, ACCUM_TYPE_SIZE, LONG_ACCUM_TYPE_SIZE,
+       LONG_LONG_ACCUM_TYPE_SIZE): Define.
+       * treestruct.def: Add TS_FIXED_CST.
+       * Makefile.in (c-pretty-print.o): Add dependence on fixed-value.h.
+       (tree.o): Likewise.
+       (tree-dump.o): Likewise.
+       (print-tree.o): Likewise.
+       (tree-pretty-print.o): Likewise.
+       (fold-const.o): Likewise.
+       * tree-complex.c (some_nonzerop): Handle FIXED_CST.
+       * tree-gimple.c (is_gimple_formal_tmp_rhs): Handle FIXED_CST.
+       (is_gimple_min_invariant): Handle FIXED_CST.
+       * stor-layout.c (int_mode_for_mode): Handle MODE_FRACT, MODE_UFRACT,
+       MODE_ACCUM, MODE_UACCUM, MODE_VECTOR_FRACT, MODE_VECTOR_UFRACT,
+       MODE_VECTOR_ACCUM, MODE_VECTOR_UACCUM.
+       (layout_type): Handle FIXED_POINT_TYPE.
+       (make_fract_type, make_accum_type): New functions.
+       * tree-browser.c (browse_tree): Handle FIXED_POINT_TYPE.
+       * tree-dump.c (fixed-value.h): New include.
+       (dump_fixed): New function.
+       (dequeue_and_dump): Handle FIXED_POINT_TYPE and FIXED_CST.
+       * tree-inline.c (remap_type_1): Handle FIXED_POINT_TYPE.
+       (estimate_num_insns_1): Handle FIXED_CST and FIXED_CONVERT_EXPR.
+       * tree-pretty-print.c (fixed-value.h): New include.
+       (dump_generic_node): Handle FIXED_POINT_TYPE, FIXED_CST, and
+       FIXED_CONVERT_EXPR.
+       * tree-scalar-evolution.c (get_scalar_evolution): Handle FIXED_CST.
+       * tree-ssa-loop-im.c (for_each_index): Handle FIXED_CST.
+       * tree-ssa-pre.c (poolify_tree): Handle FIXED_CST.
+       * tree-ssa-reassoc.c (break_up_subtract_bb): We can do reassociation
+       for non-saturating fixed-point types.
+       (reassociate_bb): Likewise.
+       * emit-rtl.c (fixed-value.h): New include.
+       (fconst0, fconst1): New array.
+       (init_emit_once): Initialize fconst0 and fconst1 for fixed-point modes.
+       * tree-vect-generic.c expand_vector_operation): Support
+       MODE_VECTOR_FRACT, MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM, and
+       MODE_VECTOR_UACCUM.
+       (type_for_widest_vector_mode): Add one parameter for the 
+       saturating flag.
+       Check scalar FRACT, UFRACT, ACCUM, and UACCUM mode to select their
+       vector mode.
+       Pass the satp parameter to type_for_mode for fixed-point types.
+       (expand_vector_operations_1): Pass the saturating flag to
+       type_for_widest_vector_mode.
+       Support MODE_VECTOR_FRACT, MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM,
+       and MODE_VECTOR_UACCUM.
+       * tree-vect-transform.c (vect_is_simple_cond): Support FIXED_CST.
+       (vectorizable_condition): Likewise.
+       * tree.c (fixed-value.h): New include.
+       (tree_code_size): Support FIXED_CST.
+       (build_fixed): New function.
+       (build_one_cst): Support FIXED_POINT_TYPE for accum types.
+       (fixed_zerop): New function.
+       (tree_node_structure): Support FIXED_CST.
+       (type_contains_placeholder_1): Support FIXED_POINT_TYPE.
+       (build_type_attribute_qual_variant): Handle FIXED_POINT_TYPE.
+       (type_hash_eq): Handle FIXED_POINT_TYPE.
+       (simple_cst_equal): Support FIXED_CST.
+       (iterative_hash_expr): Handle FIXED_CST.
+       (get_unwidened): Make sure type is not FIXED_POINT_TYPE.
+       (get_narrower): Likewise.
+       (variably_modified_type_p): Handle FIXED_POINT_TYPE.
+       (make_or_reuse_fract_type, make_or_reuse_accum_type): New functions.
+       (build_common_tree_nodes_2): Use MAKE_FIXED_TYPE_NODE_FAMILY and
+       MAKE_FIXED_MODE_NODE macros to initialize fixed-point type
+       nodes.
+       (build_vector_type_for_mode): Handle MODE_VECTOR_FRACT,
+       MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM, MODE_VECTOR_UACCUM.
+       (initializer_zerop): Support FIXED_CST.
+       (walk_tree): Handle FIXED_CST and FIXED_POINT_TYPE.
+       * dwarf2out.c (base_type_die): Use DW_ATE_signed_fixed or
+       DW_ATE_unsigned_fixed to describe FIXED_POINT_TYPE.
+       (is_base_type): Handle FIXED_POINT_TYPE.
+       (add_type_attribute): Handle FIXED_POINT_TYPE.
+       (gen_type_die_with_usage): Handle FIXED_POINT_TYPE.
+       * print-tree.c (fixed-value.h): New include.
+       (print_node_brief): Support FIXED_CST.
+       (print_node): Support FIXED_POINT_TYPE and FIXED_CST.
+       * c-pretty-print.c (fixed-value.h): New include.
+       (pp_c_type_specifier): Handle FIXED_POINT_TYPE.  Need to pass
+       TYPE_SATURATING to c_common_type_for_mode for fixed-point modes.
+       (pp_c_direct_abstract_declarator): Handle FIXED_POINT_TYPE.
+       Support fixed-point types for inner items in VECTOR_TYPE.
+       (pp_c_direct_declarator): Likewise.
+       (pp_c_declarator): Likewise.
+       (pp_c_fixed_constant): New function.
+       (pp_c_constant): Handle FIXED_CST.
+       (pp_c_primary_expression): Likewise.
+       (pp_c_expression): Likewise.
+       * fold-const.c (fixed-value.h): New include.
+       (negate_expr_p): Return true for FIXED_CST.
+       (fold_negate_expr): Support FIXED_CST.
+       (split_tree): Support FIXED_CST.
+       (const_binop): Support FIXED_CST.
+       (fold_convert_const_int_from_fixed): New function to convert from
+       fixed to int.
+       (fold_convert_const_real_from_fixed): New function to convert from
+       fixed to real.
+       (fold_convert_const_fixed_from_fixed): New function to convert from
+       fixed to another fixed.
+       (fold_convert_const_fixed_from_int): New function to convert from
+       int to fixed.
+       (fold_convert_const_fixed_from_real): New function to convert from
+       real to fixed.
+       (fold_convert_const): Support conversions from fixed to int, from
+       fixed to real, from fixed to fixed, from int to fixed, and from real
+       to fixed.
+       (fold_convert): Support FIXED_CST and FIXED_POINT_TYPE.
+       (operand_equal_p): Support FIXED_CST.
+       (make_range): For fixed-point modes, we need to pass the
+       saturating flag as the 2nd parameter.
+       (tree_swap_operands_p): Handle FIXED_CST.
+       (fold_plusminus_mult_expr): For fract modes, we cannot generate
+       constant 1.
+       (fold_unary): Support FIXED_CONVERT_EXPR.
+       (fold_binary): Handle FIXED_CST.
+       Make sure the type is not saturating, before associating operations.
+       Ex: A + B + C, A * B * C, (A1 * C1) +/- (A2 * C2).
+       (tree_expr_nonnegative_warnv_p): Handle FIXED_CST.
+       (fold_negate_const): Support FIXED_CST.
+       (fold_relational_const): Support FIXED_CST.
+       * gimplify.c (omp_firstprivatize_type_sizes): Handle FIXED_POINT_TYPE.
+       (gimplify_expr): Handle FIXED_CST.
+       (gimplify_type_sizes): Handle FIXED_POINT_TYPE.
+       * ipa-prop.c (ipa_callsite_compute_param): Support FIXED_CST.
+       * ipa-type-escape.c (type_to_consider): Handle FIXED_POINT_TYPE.
+       * doc/tm.texi (Type Layout): Document SHORT_FRACT_TYPE_SIZE,
+       FRACT_TYPE_SIZE, LONG_FRACT_TYPE_SIZE, LONG_LONG_FRACT_TYPE_SIZE,
+       SHORT_ACCUM_TYPE_SIZE, ACCUM_TYPE_SIZE, LONG_ACCUM_TYPE_SIZE,
+       LONG_LONG_ACCUM_TYPE_SIZE.
+       * dbxout.c (dbxout_type): Handle FIXED_POINT_TYPE.
+       * c-aux-info.c (gen_type): Handle FIXED_POINT_TYPE.
+       * tree-sra.c (is_sra_scalar_type): Support FIXED_POINT_TYPE.
+       * expmed.c (extract_bit_field): Support MODE_FRACT, MODE_UFRACT,
+       MODE_ACCUM, and MODE_UACCUM.
+       * tree-vectorizer.c (vect_is_simple_reduction): Check for saturating
+       fixed-point types to disable reduction.
+       * explow.c (promote_mode): Support FIXED_POINT_TYPE.
+
+2007-08-08  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/x-rs6000: New file.
+       * config/rs6000/darwin.h (CC1_SPEC): Add cc1_cpu.
+       * config/rs6000/rs6000.h (EXTRA_SPECS): Add cc1_cpu.
+       (EXTRA_SPEC_FUNCTIONS): Define.
+       (HAVE_LOCAL_CPU_DETECT): Define.
+       (CC1_CPU_SPEC): Define.
+       * config/rs6000/driver-rs6000.c: New file.
+       * config/rs6000/aix.h (CC1_SPEC): Define.
+       * config/rs6000/sysv4.h (CC1_SPEC): Add cc1_cpu.
+       * config.host: Add x-rs6000 to host_xmake_file if host and target
+       are rs6000 or powerpc.
+
+2007-08-08  Paolo Bonzini <paolo.bonzini@lu.unisi.ch>
+
+       * config/i386/t-crtstuff (CRTSTUFF_T_CFLAGS): Use +=.
+
+2007-08-08  Richard Sandiford  <richard@codesourcery.com>
+           Sandra Loosemore  <sandra@codesourcery.com>
+           Chao-ying Fu  <fu@mips.com>
+           Nigel Stephens  <nigel@mips.com>
+           David Ung  <davidu@mips.com>
+
+       * doc/invoke.texi (-mcode-readable): Document.
+       * config/mips/mips.opt (mcode-readable): New option.
+       * config/mips/mips-protos.h (SYMBOL_32_HIGH): New symbol type.
+       * config/mips/mips.h (mips_code_readable_setting): New enum.
+       (mips_code_readable): Declare.
+       (TARGET_MIPS16_TEXT_LOADS, TARGET_MIPS16_PCREL_LOADS): New macros.
+       (TARGET_MIPS16_SHORT_JUMP_TABLES): New macro.
+       (JUMP_TABLES_IN_TEXT_SECTION): Use it.
+       (CASE_VECTOR_MODE, CASE_VECTOR_PC_RELATIVE): Likewise.  Remove
+       boiler-plate comments.
+       (ASM_OUTPUT_ADDR_DIFF_ELT): Use TARGET_MIPS16_SHORT_JUMP_TABLES.
+       * config/mips/mips.c (mips_code_readable): New variable.
+       (mips_classify_symbol): Only return SYMBOL_PC_RELATIVE for
+       MIPS16 labels if TARGET_MIPS16_SHORT_JUMP_TABLES.  Use both the
+       context and -mcode-readable setting to restrict the use of
+       SYMBOL_PC_RELATIVE for MIPS16 constant pool references.
+       Only return TARGET_FORCE_TO_MEM if PC-relative loads are allowed.
+       (mips_symbolic_constant_p): Handle SYMBOL_32_HIGH.
+       (mips_blocks_for_constant_p): Only return false for
+       TARGET_MIPS16_PCREL_LOADS.
+       (mips_symbol_insns_1): Treat HIGHs as 2 extended instructions
+       for MIPS16.  Handle SYMBOL_32_HIGH.
+       (mips_const_insns): Allow HIGHs for MIPS16 too.
+       (mips_unspec_address_offset): New function, split out from...
+       (mips_unspec_address): ...here.
+       (mips_output_move): Handle MIPS16 HIGH moves.  Use "li" to load
+       16-bit symbolic constants.  Assert approropiate conditions for
+       using the "la" and "dla" macros.
+       (mips_handle_option): Handle -mcode-readable=.
+       (override_options): Use %hi/%lo relocations for TARGET_MIPS16 too.
+       Set up mips_lo_relocs[SYMBOL_32_HIGH].
+       (mips_strip_unspec_address): New function, split out from...
+       (print_operand_reloc): ...here.
+       (print_operand): Pass constants through mips_strip_unspec_address.
+       (print_operand_address): Likewise.
+       (mips_output_mi_thunk): Remove guard of mips16_lay_out_constants.
+       (mips_select_rtx_section): Remove MIPS16 handling.
+       (mips16_gp_pseudo_reg): Check currently_expanding_to_rtl.
+       (mips16_rewrite_pool_refs): Wrap the labels in an address UNSPEC.
+       (mips16_lay_out_constants): Do nothing unless
+       TARGET_MIPS16_PCREL_LOADS.
+       (mips_avoid_hazards): Remove guard of mips16_lay_out_constants.
+       * config/mips/mips.md: Split HIGHs for MIPS16.
+       (tablejump): Use TARGET_MIPS16_SHORT_JUMP_TABLES.
+
+2007-08-08  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h (mips_emit_move): Declare.
+       * config/mips/mips.c (mips_emit_move): New function.
+       (mips_force_temporary): Use mips_emit_move instead of emit_move_insn.
+       (mips_legitimize_const_move): Likewise.
+       (mips_legitimize_move): Likewise.
+       (mips_split_64bit_move): Likewise.
+       (mips_restore_gp): Likewise.
+       (mips_load_call_address): Likewise.
+       (mips_emit_fcc_reload): Likewise.
+       (mips_set_return_address): Likewise.
+       (mips_block_move_straight): Likewise.
+       (mips_block_move_loop): Likewise.
+       (mips_setup_incoming_varargs): Likewise.
+       (mips_save_reg): Likewise.
+       (mips_expand_prologue): Likewise.
+       (mips_restore_reg): Likewise.
+       (mips_expand_epilogue): Likewise.
+       (mips_output_mi_thunk): Likewise.
+       (build_mips16_call_stub): Likewise.
+       (mips_builtin_branch_and_move): Likewise.
+       * config/mips/mips.h (INITIALIZE_TRAMPOLINE): Likewise.
+       * config/mips/mips.md (fixuns_truncdfsi2): Likewise.
+       (fixuns_truncdfdi2): Likewise.
+       (fixuns_truncsfsi2): Likewise.
+       (fixuns_truncsfdi2): Likewise.
+       (loadgp_absolute): Likewise.
+       (builtin_setjmp_setup): Likewise.
+       (builtin_longjmp): Likewise.
+       (untyped_call): Likewise.
+
+2007-08-08  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h (mips_split_symbol): Add a mode and
+       an "rtx *" argument.  Return a bool.
+       * config/mips/mips.c (mips_split_symbol): Accept arbitrary source
+       values and return true if they can be split.  Take the same kind of
+       mode argument as mips_symbol_insns.  Add a "lo_sum_out" parameter
+       and store the lo_sum there if nonnull.  Use the symbol type to
+       determine whether a $gp or HIGH is needed.
+       (mips_legitimize_address): Update call to mips_split_symbol and
+       simplify accordingly.
+       (mips_legitimize_const_move): Likewise.
+       * config/mips/mips.md: In the combine define_split,
+       check mips_split_symbol instead of splittable_symbolic_operand.
+       Update use of mips_split_symbol in the generator code.
+       * config/mips/predicates.md (splittable_symbolic_operand): Delete.
+
+2007-08-08  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips_symbolic_address_p): Delete.
+       (mips_symbol_insns_1): New function, split out from...
+       (mips_symbol_insns): ...here.  Take a mode argument.  Treat loads
+       and stores separately from load addresses.
+       (mips_classify_address): Replace uses of mips_symbolic_address_p
+       with uses of mips_symbol_insns.
+       (mips_address_insns): Update calls to mips_symbol_insns.
+       (mips_const_insns): Likewise.
+       (mips_legitimize_address): Likewise.
+
+2007-08-08  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h (SYMBOL_FORCE_TO_MEM): New symbol type.
+       * config/mips/mips.c (mips_classify_symbol): Skip TARGET_ABICALLS
+       block for locally-binding symbols if TARGET_ABSOLUTE_ABICALLS.
+       Return SYMBOL_FORCE_TO_MEM instead of SYMBOL_ABSOLUTE for
+       non-call contexts if TARGET_MIPS16.
+       (mips_symbolic_constant_p): Handle SYMBOL_FORCE_TO_MEM.
+       (mips_symbolic_address_p): Likewise.  Remove special TARGET_MIPS16
+       code for SYMBOL_ABSOLUTE.
+       (mips_symbol_insns): Likewise.
+
+2007-08-08  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h (mips_symbol_context): New enumeration.
+       * config/mips/mips.c (mips_classify_symbol): Take a context argument.
+       (mips_symbolic_constant_p): Likewise.  Update the call to
+       mips_classify_symbol.
+       (mips_classify_address): Update the calls to mips_symbolic_constant_p.
+       (mips_const_insns): Likewise.  Update the call to mips_classify_symbol.
+       (mips_legitimize_address): Update the call to mips_symbolic_constant_p.
+       (print_operand_reloc): Add a context argument.  Update the call to
+       mips_symbolic_constant_p.
+       (print_operand): Update the calls to print_operand_reloc.
+       (print_operand_address): Use print_operand_reloc rather than
+       print_operand.
+       (mips_rewrite_small_data_p): Add a context argument.  Update the call
+       to mips_symbolic_constant_p.
+       (mips_small_data_pattern_1): Make DATA the containing mem.
+       Update the call to mips_rewrite_small_data_p.
+       (mips_rewrite_small_data_1): Likewise.
+       (mips_use_anchors_for_symbol_p): Update the call to
+       mips_symbolic_constant_p.
+       * config/mips/predicates.md (const_call_insn_operand): Likewise.
+       (splittable_symbolic_operand): Likewise.
+       (move_operand): Likewise.
+       (absolute_symbolic_operand): Likewise.
+       (got_disp_operand): Likewise.
+       (got_page_ofst_operand): Likewise.
+
+2007-08-08  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h (SYMBOL_GENERAL): Rename to...
+       (SYMBOL_ABSOLUTE): ...this.
+       (SYMBOL_SMALL_DATA): Rename to...
+       (SYMBOL_GP_RELATIVE): ...this.
+       (SYMBOL_CONSTANT_POOL): Rename to...
+       (SYMBOL_PC_RELATIVE): ...this.
+       * config/mips/mips.c (mips_classify_symbol, mips_symbolic_constant_p)
+       (mips_symbolic_address_p, mips_symbol_insns, override_options)
+       (mips_rewrite_small_data_p, mips_use_anchors_for_symbol_p): Update
+       after above changes.
+       * config/mips/predicates.md (const_call_insn_operand): Likewise.
+       (general_symbolic_operand): Rename to...
+       (absolute_symbolic_operand): ...this.
+       * config/mips/mips.md: Update after above changes.
+
+2007-08-08  Vladimir Yanovsky  <yanov@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * ddg.c (print_ddg): Add dump information.
+       * modulo-sched.c (print_node_sched_params): Add parameter and
+       verbosity.
+       (calculate_maxii): Remove function.
+       (undo_generate_reg_moves): Likewise.
+       (undo_permute_partial_schedule): Likewise.
+       (kernel_number_of_cycles): Likewise.
+       (MAXII_FACTOR): New definition to calculate the upper bound of II.
+       (sms_schedule): Use it.  Remove profitability checks.
+       (sms_schedule_by_order): Fix order of nodes within the cycle.
+
+2007-08-08  Samuel Thibault  <samuel.thibault@ens-lyon.org>
+
+       * config/i386/gnu.h (STARTFILE_SPEC): Use gcrt0.o in profile mode, add
+       -profile option, add pie support.
+       (ENDFILE_SPEC): New spec.
+       * config/gnu.h (LIB_SPEC): Add -profile option.
+
+2007-08-08  Samuel Thibault  <samuel.thibault@ens-lyon.org>
+
+       * config/i386/gnu.h (CPP_SPEC): Add -pthread option.
+       * config/gnu.h (LIB_SPEC): Likewise.
+
+2007-08-07  Yaz Saito  <saito@google.com>
+           Ian Lance Taylor  <iant@google.com>
+
+       * common.opt (finstrument-functions-exclude-function-list): New
+       option.
+       (finstrument-functions-exclude-file-list): New option.
+       * opts.c (char_p): Define and DEF_VEC.
+       (flag_instrument_functions_exclude_functions): New static
+       variable.
+       (flag_instrument_functions_exclude_files): New static variable.
+       (add_instrument_functions_exclude_list): New static function.
+       (flag_instrument_functions_exclude_p): New function.
+       (common_handle_option): Handle new options.
+       * flags.h (flag_instrument_functions_exclude_p): Declare.
+       * gimplify.c (gimplify_function_tree): Call
+       flag_instrument_functions_exclude_p.
+       * doc/invoke.texi (Option Summary): Mention new options.
+       (Code Gen Options): Document new options.
+
+2007-08-07  Ian Lance Taylor  <iant@google.com>
+
+       PR rtl-optimization/32776
+       * lower-subreg.c (resolve_clobber): Call resolve_reg_notes.
+       (resolve_use): Likewise.
+       (decompose_multiword_subregs): Remove "changed" local variable.
+
+2007-08-07  Carlos O'Donell  <carlos@codesourcery.com>
+
+       * configure.ac: Define HAVE_GNU_AS if $gas_flag is yes.
+       * configure: Regenerate.
+       * config.in: Regenerate.
+       * gcc.c [HAVE_GNU_AS]: Add "%{v} %{w:-W} %{I*} " to asm_options
+       spec string.
+
+2007-08-07  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (resolve_clobber): If the clobber has a LIBCALL
+       note, just delete the insn.
+
+2007-08-07  Andreas Schwab  <schwab@suse.de>
+
+       PR bootstrap/32973
+       * gengtype-lex.l: Ignore backslash/newline pair while scanning a
+       struct definition.
+
+2007-08-07  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * lower-subreg.c (resolve_subreg_use): Remove assertion.
+       (find_decomposable_shift_zext, resolve_shift_zext): New functions.
+       (decompose_multiword_subregs): Use the functions above to decompose
+       multiword shifts and zero-extends.
+
+2007-08-07  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * doc/sourcebuild.texi (Test Directives): Fix "compile" and
+       "assemble" descriptions which were swapped.
+
+2007-08-06  Chao-ying Fu  <fu@mips.com>
+
+       * fixed-value.h: New file.
+       * fixed-value.c: New file.
+       * Makefile.in (OBJS-common): Add fixed-value.o.
+       (fixed-value.o): New rule.
+       (GTFILES): Add fixed-value.h.
+       * double-int.c (double_int_scmp): We should use unsigned HOST_WIDE_INT
+       to compare a.low and b.low.
+       * gengtype.c (main): Handle FIXED_VALUE_TYPE type as scalar typedef.
+
+2007-08-06  H.J. Lu  <hongjiu.lu@intel.com>
+           Daniel Jacobowitz  <dan@codesourcery.com>
+
+       PR target/31868
+       * config.gcc (x86_64-*-freebsd*): Add i386/t-crtstuff to
+       tmake_file.
+       (x86_64-*-netbsd*): Likewise.
+       (x86_64-*-linux*): Likewise.
+       (x86_64-*-kfreebsd*-gnu): Likewise.
+       (x86_64-*-knetbsd*-gnu): Likewise.
+       (i[34567]86-*-solaris2.1[0-9]*): Likewise.
+
+       * config/i386/t-linux64 (CRTSTUFF_T_CFLAGS): Removed.
+
+       * config/i386/t-crtstuff (CRTSTUFF_T_CFLAGS): Update comments.
+       Add -fno-asynchronous-unwind-tables.
+
+       * config/t-freebsd (CRTSTUFF_T_CFLAGS_S): Add $(CRTSTUFF_T_CFLAGS).
+       * config/t-libc-ok (CRTSTUFF_T_CFLAGS_S): Likewise.
+       * config/t-lynx (CRTSTUFF_T_CFLAGS_S): Likewise.
+       * config/t-netbsd (CRTSTUFF_T_CFLAGS_S): Likewise.
+       * config/t-svr4 (CRTSTUFF_T_CFLAGS_S): Likewise.
+
+2007-08-06  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/ia64.c (ia64_c_mode_for_suffix): New.
+       (TARGET_C_MODE_FOR_SUFFIX): New.
+
+2007-08-06  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/div.md (m2subrf4_cond): Change 'g' to 'G'.
+
+2007-08-06  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/ia64.h (MODES_TIEABLE_P): Fix typo.
+
+2007-08-06  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.md: Check TARGET_ macros and optimize_size
+       before checking function returns in conditional expressions.
+
+2007-08-06  Alfred Minarik  <a.minarik@aon.at>
+
+       PR pch/13676
+       * doc/invoke.texi: Add .hp, .hxx, .hpp, .h, .HPP, .tcc as c++ header.
+
+2008-08-05  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/32988
+       * tree.c (build2_stat): Instead of checking for INTEGER_TYPE, check
+       for INTEGRAL_TYPE_P.
+
+2008-08-05  Paolo Bonzini  <bonzini@gnu.org>
+
+       * configure.ac: Remove --enable-checking=df from default settings.
+       * tree-pass.h (TODO_df_verify): New.  Shift TODO_mark_first_instance.
+       * df-core.c (df_finish_pass) [ENABLE_CHECKING]: Schedule verification
+       if the parameter is true.
+       (df_analyze) [!ENABLE_DF_CHECKING]: Also do verification if the
+       DF_VERIFY_SCHEDULED flag is true.
+       * df.h (enum df_changeable_flags): Add DF_VERIFY_SCHEDULED.
+       (df_finish_pass): Adjust prototype.
+       * passes.c (execute_todo): Schedule verification if TODO_df_verify is
+       true.
+
+       * see.c (pass_see): Add TODO_df_verify.
+       * loop-init.c (pass_rtl_move_loop_invariants): Add TODO_df_verify.
+       * global.c (rest_of_handle_global_alloc): Schedule verification
+       after the pass.
+       * local-alloc.c (rest_of_handle_local_alloc): Schedule verification
+       before the pass.
+       * function.c (pass_thread_prologue_and_epilogue): Add TODO_df_verify.
+       * gcse.c (rest_of_handle_gcse): Adjust call to df_finish_pass.
+       * loop-iv.c (iv_analysis_done): Schedule verification after the pass.
+
+       * config/sh/sh.c (sh_output_mi_thunk): Remove dead code.
+       * config/ia64/ia64.c (ia64_reorg): Adjust call to df_finish_pass.
+       * config/bfin/bfin.c (bfin_reorg): Adjust call to df_finish_pass.
+
+2007-08-05  Vladimir Yanovsky  <yanov@il.ibm.com>
+           Revital Eres <eres@il.ibm.com>
+
+       * doc/invoke.texi (-fmodulo-sched-allow-regmoves): Document new
+       flag.
+       * ddg.c (create_ddg_dependence): Rename to...
+       (create_ddg_dep_from_intra_loop_link): This.  Do not check
+       for interloop edges.  Do not create anti dependence edge when
+       a true dependence edge exists in the opposite direction and
+       -fmodulo-sched-allow-regmoves is set.
+       (build_intra_loop_deps): Call create_ddg_dep_from_intra_loop_link.
+       (add_cross_iteration_register_deps): Create anti dependence edge
+       when -fno-modulo-sched-allow-regmoves is set.
+       * common.opt (-fmodulo-sched-allow-regmoves): New flag.
+
+2007-08-04  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/arm/arm.md (movsi): Add braces.
+
+2007-08-04  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/32780
+       * fold-const.c (fold_binary <case MINUS_EXPR>): Fix the type of
+       operands for the folding of "A - (A & B)" into "~B & A"; cast them
+       to type.
+
+2007-08-03  Zdenek Dvorak  <ook@ucw.cz>
+
+       * tree-ssa-threadupdate.c (thread_through_all_blocks): Use loops'
+       state accessor functions.
+       * cfgloopmanip.c (remove_path, create_preheaders,
+       force_single_succ_latches, fix_loop_structure): Ditto.
+       * tree-ssa-loop-manip.c (rewrite_into_loop_closed_ssa,
+       tree_duplicate_loop_to_header_edge): Ditto.
+       * cfgloopanal.c (mark_irreducible_loops): Ditto.
+       * loop-init.c (loop_optimizer_init, loop_optimizer_finalize):
+       Ditto.
+       * tree-cfgcleanup.c (cleanup_tree_cfg_noloop, repair_loop_structures,
+       cleanup_tree_cfg): Ditto.
+       * tree-cfg.c (tree_merge_blocks): Ditto.
+       * cfgloop.c (rescan_loop_exit, record_loop_exits,
+       release_recorded_exits, get_loop_exit_edges, verify_loop_structure,
+       loop_preheader_edge, single_exit): Ditto.
+       (flow_loops_find): Do not clear loops->state.
+       * cfgloop.h (loops_state_satisfies_p, loops_state_set,
+       loops_state_clear): New functions.
+
+2007-08-03  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/32399
+       * tree-ssa-address.c (add_to_parts): Use POINTER_PLUS_EXPR
+       when adding to the base and convert ELT to sizetype instead of type.
+
+2007-08-03  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/32304
+       * ipa-reference.c (has_proper_scope_for_analysis): Return false when
+       the decl's type has TYPE_NEEDS_CONSTRUCTING set.
+
+2007-08-03  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/32935
+       * fold-convert.c (fold_negate_expr <NOP_EXPR>): Convert back to the
+        correct type the negate expression.
+
+2007-08-03  Jan Hubicka  <jh@suse.cz>
+
+       * config/i386/i386.c (setup_incoming_varargs_64): Tolerate 64bit
+       preferred stack boundary.
+
+2007-08-03  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/rs6000.c (struct processor_cost): Change
+       l1_cache_lines to l1_cache_size.  Add l2_cache_size.
+       (*_cost): Convert l1 cache information to kilobytes.  Add l2 cache
+       information.
+       (rios1_costs, rios2_cost): Correct cache line size.
+       (rs6000_override_options): Set l2-cache-size parameter.
+
+2007-08-03  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+           Diego Novillo  <dnovillo@google.com>
+
+       PR 31521
+       * tree-vrp.c (simplify_div_or_mod_using_ranges): Also simplify
+       if the range includes 0.
+
+2007-08-03  Ben Elliston  <bje@au.ibm.com>
+
+       * config/spu/spu.md (dftsv, dftsv_celledp): Attach the appropriate
+       mode to unspec expressions to silence a warning from the generator
+       programs.
+       
+2007-08-02  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/constraints.md ("U"): Make constraint vector only.
+
+2007-08-02  Nathan Froyd  <froydnj@codesourcery.com>
+
+       PR middle-end/25446
+       * c-objc-common.c (c_cannot_inline_tree_fn): Check for an
+       always_inline attribute on the function decl.
+
+2007-08-02  Nathan Froyd  <froydnj@codesourcery.com>
+
+       PR middle-end/25445
+       * varasm.c (default_binds_local_p_1): Consult flag_whole_program
+       if we are compiling with -fPIC.
+
+2007-08-02  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * longlong.h [__mips__] (count_leading_zeros, COUNT_LEADING_ZEROS_0):
+       Define for MIPS32 and MIPS64.
+
+2007-08-02  Nick Clifton  <nickc@redhat.com>
+
+       * config/host-hpux.c: 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/alpha/predicates.md, config/alpha/vms-ld.c,
+       config/alpha/linux.h, config/alpha/alpha.opt,
+       config/alpha/linux-elf.h, config/alpha/vms.h, config/alpha/elf.h,
+       config/alpha/vms-unwind.h, config/alpha/ev4.md,
+       config/alpha/ev6.md, config/alpha/alpha.c, config/alpha/vms-cc.c,
+       config/alpha/alpha.h, config/alpha/sync.md,
+       config/alpha/openbsd.h, config/alpha/alpha.md,
+       config/alpha/alpha-modes.def, config/alpha/ev5.md,
+       config/alpha/alpha-protos.h, config/alpha/freebsd.h,
+       config/alpha/osf5.h, config/alpha/netbsd.h, config/alpha/vms64.h,
+       config/alpha/constraints.md, config/alpha/osf.h,
+       config/alpha/xm-vms.h, config/alpha/unicosmk.h, config/linux.h,
+       config/frv/predicates.md, config/frv/frv.h, config/frv/linux.h,
+       config/frv/frv.md, config/frv/frv.opt, config/frv/frv-modes.def,
+       config/frv/frv-asm.h, config/frv/frv-protos.h,
+       config/frv/frv-abi.h, config/frv/frv.c, config/s390/tpf.h,
+       config/s390/s390.c, config/s390/predicates.md, config/s390/s390.h,
+       config/s390/linux.h, config/s390/tpf.md, config/s390/tpf.opt,
+       config/s390/2064.md, config/s390/2084.md, config/s390/s390.md,
+       config/s390/s390.opt, config/s390/s390-modes.def,
+       config/s390/fixdfdi.h, config/s390/constraints.md,
+       config/s390/s390-protos.h, config/s390/s390x.h, config/elfos.h,
+       config/dbxcoff.h, config/m32c/predicates.md, config/m32c/cond.md,
+       config/m32c/m32c.c, config/m32c/minmax.md, config/m32c/blkmov.md,
+       config/m32c/m32c-pragma.c, config/m32c/m32c.h,
+       config/m32c/prologue.md, config/m32c/m32c.abi,
+       config/m32c/muldiv.md, config/m32c/bitops.md, config/m32c/mov.md,
+       config/m32c/addsub.md, config/m32c/m32c.md, config/m32c/m32c.opt,
+       config/m32c/t-m32c, config/m32c/m32c-modes.def,
+       config/m32c/jump.md, config/m32c/shift.md,
+       config/m32c/m32c-protos.h, config/libgloss.h,
+       config/spu/spu-protos.h, config/spu/predicates.md,
+       config/spu/spu-builtins.h, config/spu/spu.c,
+       config/spu/spu-builtins.def, config/spu/spu-builtins.md,
+       config/spu/spu.h, config/spu/spu-elf.h, config/spu/constraints.md,
+       config/spu/spu.md, config/spu/spu-c.c, config/spu/spu.opt,
+       config/spu/spu-modes.def, config/spu/t-spu-elf, config/interix.h,
+       config/sparc/hypersparc.md, config/sparc/predicates.md,
+       config/sparc/linux.h, config/sparc/sp64-elf.h,
+       config/sparc/supersparc.md, config/sparc/cypress.md,
+       config/sparc/openbsd1-64.h, config/sparc/openbsd64.h,
+       config/sparc/niagara.md, config/sparc/sparc.md,
+       config/sparc/long-double-switch.opt, config/sparc/ultra3.md,
+       config/sparc/sparc.opt, config/sparc/sync.md,
+       config/sparc/sp-elf.h, config/sparc/sparc-protos.h,
+       config/sparc/ultra1_2.md, config/sparc/biarch64.h,
+       config/sparc/sparc.c, config/sparc/little-endian.opt,
+       config/sparc/sysv4-only.h, config/sparc/sparc.h,
+       config/sparc/linux64.h, config/sparc/freebsd.h,
+       config/sparc/sol2.h, config/sparc/rtemself.h,
+       config/sparc/netbsd-elf.h, config/sparc/vxworks.h,
+       config/sparc/sparc-modes.def, config/sparc/sparclet.md,
+       config/sparc/sysv4.h, config/vx-common.h, config/netbsd-aout.h,
+       config/flat.h, config/m32r/m32r.md, config/m32r/predicates.md,
+       config/m32r/little.h, config/m32r/m32r.c, config/m32r/m32r.opt,
+       config/m32r/linux.h, config/m32r/constraints.md,
+       config/m32r/m32r.h, config/m32r/m32r-protos.h, config/vxworks.opt,
+       config/darwin-c.c, config/darwin.opt, config/i386/i386.h,
+       config/i386/cygming.h, config/i386/linux.h, config/i386/cygwin.h,
+       config/i386/i386.md, config/i386/netware-crt0.c,
+       config/i386/sco5.h, config/i386/mmx.md, config/i386/vx-common.h,
+       config/i386/kaos-i386.h, config/i386/winnt-stubs.c,
+       config/i386/netbsd64.h, config/i386/djgpp.h, config/i386/gas.h,
+       config/i386/sol2.h, config/i386/constraints.md,
+       config/i386/netware-libgcc.c, config/i386/sysv5.h,
+       config/i386/predicates.md, config/i386/geode.md,
+       config/i386/x86-64.h, config/i386/kfreebsd-gnu.h,
+       config/i386/freebsd64.h, config/i386/vxworksae.h,
+       config/i386/pentium.md, config/i386/lynx.h, config/i386/i386elf.h,
+       config/i386/rtemself.h, config/i386/netbsd-elf.h,
+       config/i386/ppro.md, config/i386/k6.md, config/i386/netware.c,
+       config/i386/netware.h, config/i386/i386-modes.def,
+       config/i386/sysv4-cpp.h, config/i386/i386-interix.h,
+       config/i386/cygwin1.c, config/i386/djgpp.opt, config/i386/uwin.h,
+       config/i386/unix.h, config/i386/ptx4-i.h, config/i386/xm-djgpp.h,
+       config/i386/att.h, config/i386/winnt.c, config/i386/beos-elf.h,
+       config/i386/sol2-10.h, config/i386/darwin64.h, config/i386/sse.md,
+       config/i386/i386.opt, config/i386/bsd.h, config/i386/cygming.opt,
+       config/i386/xm-mingw32.h, config/i386/linux64.h,
+       config/i386/openbsdelf.h, config/i386/xm-cygwin.h,
+       config/i386/sco5.opt, config/i386/darwin.h, config/i386/mingw32.h,
+       config/i386/winnt-cxx.c, config/i386/i386-interix3.h,
+       config/i386/nwld.c, config/i386/nwld.h, config/i386/host-cygwin.c,
+       config/i386/cygwin2.c, config/i386/i386-protos.h,
+       config/i386/sync.md, config/i386/openbsd.h,
+       config/i386/host-mingw32.c, config/i386/i386-aout.h,
+       config/i386/nto.h, config/i386/biarch64.h,
+       config/i386/i386-coff.h, config/i386/freebsd.h,
+       config/i386/driver-i386.c, config/i386/knetbsd-gnu.h,
+       config/i386/host-i386-darwin.c, config/i386/vxworks.h,
+       config/i386/crtdll.h, config/i386/i386.c, config/i386/sysv4.h,
+       config/darwin-protos.h, config/linux.opt, config/sol2.c,
+       config/sol2.h, config/sh/symbian.c, config/sh/sh-protos.h,
+       config/sh/linux.h, config/sh/elf.h, config/sh/superh.h,
+       config/sh/sh4.md, config/sh/coff.h, config/sh/newlib.h,
+       config/sh/embed-elf.h, config/sh/symbian-pre.h, config/sh/rtems.h,
+       config/sh/kaos-sh.h, config/sh/sh4a.md, config/sh/constraints.md,
+       config/sh/sh64.h, config/sh/sh.opt, config/sh/symbian-post.h,
+       config/sh/sh-c.c, config/sh/predicates.md, config/sh/sh.c,
+       config/sh/sh.h, config/sh/shmedia.md, config/sh/sh-modes.def,
+       config/sh/little.h, config/sh/sh1.md, config/sh/sh4-300.md,
+       config/sh/superh64.h, config/sh/rtemself.h,
+       config/sh/netbsd-elf.h, config/sh/sh.md, config/sh/vxworks.h,
+       config/usegas.h, config/svr3.h, config/pdp11/pdp11-protos.h,
+       config/pdp11/2bsd.h, config/pdp11/pdp11.md, config/pdp11/pdp11.c,
+       config/pdp11/pdp11.opt, config/pdp11/pdp11-modes.def,
+       config/pdp11/pdp11.h, config/avr/rtems.h, config/avr/avr-protos.h,
+       config/avr/predicates.md, config/avr/constraints.md,
+       config/avr/avr.md, config/avr/avr.c, config/avr/avr.opt,
+       config/avr/avr.h, config/sol2-protos.h, config/dbxelf.h,
+       config/lynx.opt, config/crx/crx.h, config/crx/crx-protos.h,
+       config/crx/crx.md, config/crx/crx.c, config/crx/crx.opt,
+       config/c4x/c4x-c.c, config/c4x/c4x.c, config/c4x/c4x.opt,
+       config/c4x/c4x-modes.def, config/c4x/rtems.h,
+       config/c4x/predicates.md, config/c4x/c4x.h,
+       config/c4x/c4x-protos.h, config/c4x/c4x.md, config/kfreebsd-gnu.h,
+       config/xtensa/predicates.md, config/xtensa/xtensa.c,
+       config/xtensa/linux.h, config/xtensa/xtensa.h,
+       config/xtensa/elf.h, config/xtensa/xtensa.md,
+       config/xtensa/xtensa.opt, config/xtensa/constraints.md,
+       config/xtensa/xtensa-protos.h, config/dbx.h,
+       config/stormy16/predicates.md, config/stormy16/stormy16.md,
+       config/stormy16/stormy16.c, config/stormy16/stormy16.opt,
+       config/stormy16/stormy16.h, config/stormy16/stormy16-protos.h,
+       config/host-solaris.c, config/fr30/fr30.h,
+       config/fr30/predicates.md, config/fr30/fr30-protos.h,
+       config/fr30/fr30.md, config/fr30/fr30.c, config/fr30/fr30.opt,
+       config/vxworksae.h, config/sol2-c.c, config/lynx.h,
+       config/m68hc11/m68hc11-protos.h, config/m68hc11/predicates.md,
+       config/m68hc11/m68hc11.md, config/m68hc11/m68hc11.c,
+       config/m68hc11/m68hc11.opt, config/m68hc11/m68hc11.h,
+       config/m68hc11/m68hc12.h, config/openbsd-oldgas.h,
+       config/host-linux.c, config/interix3.h, config/cris/cris.c,
+       config/cris/predicates.md, config/cris/linux.h,
+       config/cris/cris.h, config/cris/aout.h, config/cris/cris.md,
+       config/cris/linux.opt, config/cris/cris.opt, config/cris/elf.opt,
+       config/cris/aout.opt, config/cris/cris-protos.h,
+       config/vxworks-dummy.h, config/netbsd.h, config/netbsd-elf.h,
+       config/iq2000/iq2000.h, config/iq2000/predicates.md,
+       config/iq2000/iq2000-protos.h, config/iq2000/iq2000.md,
+       config/iq2000/iq2000.c, config/iq2000/iq2000.opt,
+       config/host-darwin.c, config/mt/mt.md, config/mt/mt.c,
+       config/mt/mt.opt, config/mt/t-mt, config/mt/mt.h,
+       config/mt/mt-protos.h, config/svr4.h, config/host-darwin.h,
+       config/chorus.h, config/mn10300/mn10300.c,
+       config/mn10300/mn10300.opt, config/mn10300/predicates.md,
+       config/mn10300/mn10300.h, config/mn10300/linux.h,
+       config/mn10300/constraints.md, config/mn10300/mn10300-protos.h,
+       config/mn10300/mn10300.md, config/ia64/predicates.md,
+       config/ia64/itanium1.md, config/ia64/unwind-ia64.h,
+       config/ia64/ia64-c.c, config/ia64/sync.md, config/ia64/ia64.c,
+       config/ia64/itanium2.md, config/ia64/ia64.h, config/ia64/vect.md,
+       config/ia64/freebsd.h, config/ia64/ia64.md,
+       config/ia64/ia64-modes.def, config/ia64/constraints.md,
+       config/ia64/hpux.h, config/ia64/ia64-protos.h, config/windiss.h,
+       config/gofast.h, config/rtems.h, config/sol2-10.h,
+       config/m68k/predicates.md, config/m68k/m68k.md,
+       config/m68k/linux.h, config/m68k/m68k-modes.def,
+       config/m68k/print-sysroot-suffix.sh, config/m68k/m68k-protos.h,
+       config/m68k/coff.h, config/m68k/m68k-none.h, config/m68k/ieee.opt,
+       config/m68k/openbsd.h, config/m68k/m68k-aout.h,
+       config/m68k/m68k.opt, config/m68k/m68020-elf.h,
+       config/m68k/m68kelf.h, config/m68k/m68k-devices.def,
+       config/m68k/uclinux-oldabi.h, config/m68k/m68k.c,
+       config/m68k/constraints.md, config/m68k/rtemself.h,
+       config/m68k/netbsd-elf.h, config/m68k/m68k.h,
+       config/m68k/uclinux.h, config/rs6000/power4.md,
+       config/rs6000/host-darwin.c, config/rs6000/6xx.md,
+       config/rs6000/linux.h, config/rs6000/eabi.h,
+       config/rs6000/aix41.opt, config/rs6000/xcoff.h,
+       config/rs6000/secureplt.h, config/rs6000/linuxspe.h,
+       config/rs6000/eabialtivec.h, config/rs6000/8540.md,
+       config/rs6000/darwin8.h, config/rs6000/kaos-ppc.h,
+       config/rs6000/windiss.h, config/rs6000/603.md,
+       config/rs6000/aix41.h, config/rs6000/cell.md,
+       config/rs6000/mpc.md, config/rs6000/aix43.h, config/rs6000/beos.h,
+       config/rs6000/gnu.h, config/rs6000/rtems.h, config/rs6000/aix.opt,
+       config/rs6000/darwin.md, config/rs6000/darwin64.h,
+       config/rs6000/default64.h, config/rs6000/7xx.md,
+       config/rs6000/darwin.opt, config/rs6000/spe.md,
+       config/rs6000/rs6000.opt, config/rs6000/rs6000-c.c,
+       config/rs6000/rios2.md, config/rs6000/linuxaltivec.h,
+       config/rs6000/7450.md, config/rs6000/linux64.h,
+       config/rs6000/constraints.md, config/rs6000/440.md,
+       config/rs6000/darwin.h, config/rs6000/host-ppc64-darwin.c,
+       config/rs6000/rs6000.c, config/rs6000/aix52.h,
+       config/rs6000/rs6000.h, config/rs6000/power6.md,
+       config/rs6000/predicates.md, config/rs6000/altivec.md,
+       config/rs6000/aix64.opt, config/rs6000/rios1.md,
+       config/rs6000/rs6000-modes.def, config/rs6000/rs64.md,
+       config/rs6000/eabisim.h, config/rs6000/sysv4le.h,
+       config/rs6000/darwin7.h, config/rs6000/dfp.md,
+       config/rs6000/linux64.opt, config/rs6000/sync.md,
+       config/rs6000/vxworksae.h, config/rs6000/power5.md,
+       config/rs6000/lynx.h, config/rs6000/biarch64.h,
+       config/rs6000/rs6000.md, config/rs6000/sysv4.opt,
+       config/rs6000/eabispe.h, config/rs6000/e500.h,
+       config/rs6000/freebsd.h, config/rs6000/rs6000-protos.h,
+       config/rs6000/netbsd.h, config/rs6000/e500-double.h,
+       config/rs6000/aix.h, config/rs6000/vxworks.h,
+       config/rs6000/40x.md, config/rs6000/aix51.h,
+       config/rs6000/sysv4.h, config/arc/arc-protos.h, config/arc/arc.md,
+       config/arc/arc.c, config/arc/arc.opt, config/arc/arc-modes.def,
+       config/arc/arc.h, config/mcore/mcore-elf.h,
+       config/mcore/mcore-protos.h, config/mcore/predicates.md,
+       config/mcore/mcore.md, config/mcore/mcore.c,
+       config/mcore/mcore.opt, config/mcore/mcore.h,
+       config/mcore/mcore-pe.h, config/darwin.c, config/freebsd-nthr.h,
+       config/score/predicates.md, config/score/score-version.h,
+       config/score/score-protos.h, config/score/misc.md,
+       config/score/elf.h, config/score/score.c, config/score/mac.md,
+       config/score/score7.md, config/score/score.h,
+       config/score/score-conv.h, config/score/score-mdaux.c,
+       config/score/score.md, config/score/score.opt,
+       config/score/score-modes.def, config/score/score-mdaux.h,
+       config/score/mul-div.S, config/arm/uclinux-elf.h,
+       config/arm/semi.h, config/arm/ecos-elf.h, config/arm/arm1020e.md,
+       config/arm/symbian.h, config/arm/linux-elf.h,
+       config/arm/arm1026ejs.md, config/arm/arm1136jfs.md,
+       config/arm/elf.h, config/arm/aout.h, config/arm/arm.c,
+       config/arm/thumb2.md, config/arm/vec-common.md, config/arm/coff.h,
+       config/arm/strongarm-pe.h, config/arm/arm.h,
+       config/arm/cortex-a8-neon.md, config/arm/semiaof.h,
+       config/arm/cortex-a8.md, config/arm/uclinux-eabi.h,
+       config/arm/arm-modes.def, config/arm/linux-eabi.h,
+       config/arm/rtems-elf.h, config/arm/neon-schedgen.ml,
+       config/arm/arm-cores.def, config/arm/arm-protos.h,
+       config/arm/vfp.md, config/arm/aof.h, config/arm/linux-gas.h,
+       config/arm/wince-pe.h, config/arm/neon.md,
+       config/arm/constraints.md, config/arm/neon.ml,
+       config/arm/xscale-elf.h, config/arm/strongarm-coff.h,
+       config/arm/arm.opt, config/arm/arm926ejs.md,
+       config/arm/predicates.md, config/arm/iwmmxt.md,
+       config/arm/arm_neon.h, config/arm/unknown-elf.h,
+       config/arm/kaos-arm.h, config/arm/bpabi.h, config/arm/pe.opt,
+       config/arm/neon-testgen.ml, config/arm/arm.md,
+       config/arm/xscale-coff.h, config/arm/pe.c,
+       config/arm/arm-generic.md, config/arm/pe.h,
+       config/arm/kaos-strongarm.h, config/arm/freebsd.h,
+       config/arm/neon-docgen.ml, config/arm/netbsd.h, config/arm/fpa.md,
+       config/arm/strongarm-elf.h, config/arm/cirrus.md,
+       config/arm/netbsd-elf.h, config/arm/vxworks.h,
+       config/arm/neon-gen.ml, config/kaos.h, config/darwin-driver.c,
+       config/pa/predicates.md, config/pa/pa64-hpux.h,
+       config/pa/pa-hpux.opt, config/pa/som.h, config/pa/pa-hpux1010.opt,
+       config/pa/pa-hpux1111.opt, config/pa/pa-pro-end.h,
+       config/pa/elf.h, config/pa/fptr.c, config/pa/pa64-linux.h,
+       config/pa/pa.md, config/pa/pa.opt, config/pa/pa-hpux.h,
+       config/pa/pa-hpux10.h, config/pa/pa-hpux11.h,
+       config/pa/pa-hpux1010.h, config/pa/pa-protos.h,
+       config/pa/pa-osf.h, config/pa/pa-hpux1111.h, config/pa/pa-64.h,
+       config/pa/milli64.S, config/pa/pa.c, config/pa/pa-linux.h,
+       config/pa/pa.h, config/pa/pa32-linux.h, config/pa/pa64-hpux.opt,
+       config/pa/pa64-regs.h, config/pa/pa-modes.def,
+       config/pa/constraints.md, config/darwin9.h, config/mips/4100.md,
+       config/mips/linux.h, config/mips/elfoabi.h, config/mips/elf.h,
+       config/mips/sdb.h, config/mips/windiss.h, config/mips/rtems.h,
+       config/mips/3000.md, config/mips/iris5.h, config/mips/5000.md,
+       config/mips/7000.md, config/mips/9000.md, config/mips/4600.md,
+       config/mips/linux64.h, config/mips/elforion.h,
+       config/mips/constraints.md, config/mips/generic.md,
+       config/mips/predicates.md, config/mips/4300.md,
+       config/mips/mips-ps-3d.md, config/mips/iris.h, config/mips/24k.md,
+       config/mips/mips.md, config/mips/mips.opt, config/mips/4k.md,
+       config/mips/5k.md, config/mips/vr4120-div.S,
+       config/mips/openbsd.h, config/mips/iris6.h, config/mips/4000.md,
+       config/mips/mips-protos.h, config/mips/6000.md,
+       config/mips/mips.c, config/mips/mips.h, config/mips/r3900.h,
+       config/mips/74k.md, config/mips/netbsd.h, config/mips/vxworks.h,
+       config/mips/mips-modes.def, config/mips/vr.h,
+       config/soft-fp/t-softfp, config/openbsd.h, config/ptx4.h,
+       config/freebsd-spec.h, config/vax/vax.c, config/vax/openbsd.h,
+       config/vax/vax.h, config/vax/elf.h, config/vax/vax.md,
+       config/vax/bsd.h, config/vax/vax.opt, config/vax/vax-modes.def,
+       config/vax/openbsd1.h, config/vax/netbsd.h,
+       config/vax/vax-protos.h, config/vax/netbsd-elf.h,
+       config/vax/vaxv.h, config/vax/ultrix.h, config/freebsd.h,
+       config/h8300/rtems.h, config/h8300/predicates.md,
+       config/h8300/h8300.c, config/h8300/h8300.h, config/h8300/elf.h,
+       config/h8300/h8300.md, config/h8300/h8300.opt,
+       config/h8300/coff.h, config/h8300/h8300-protos.h,
+       config/v850/v850.md, config/v850/predicates.md,
+       config/v850/v850-c.c, config/v850/v850.c, config/v850/v850.opt,
+       config/v850/v850.h, config/v850/v850-protos.h, config/vxworks.c,
+       config/knetbsd-gnu.h, config/sol2-6.h, config/vxworks.h,
+       config/mmix/mmix.h, config/mmix/predicates.md,
+       config/mmix/mmix-protos.h, config/mmix/mmix.md,
+       config/mmix/mmix.c, config/mmix/mmix.opt,
+       config/mmix/mmix-modes.def, config/bfin/bfin.opt,
+       config/bfin/rtems.h, config/bfin/bfin-modes.def,
+       config/bfin/predicates.md, config/bfin/bfin-protos.h,
+       config/bfin/bfin.c, config/bfin/bfin.h, config/bfin/bfin.md:
+       Likewise.
+
+2007-08-02  Richard Sandiford  <richard@codesourcery.com>
+
+       * emit-rtl.c (reset_used_decls): Rename to...
+       (set_used_decls): ...this.  Set the used flag rather than clearing it.
+       (unshare_all_rtl_again): Update accordingly.  Set flags on argument
+       DECL_RTLs rather than resetting them.
+
+2007-08-02  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md ("*xordi3_cconly"): Change xr to xg.
+
+2007-08-01  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * reload.c (find_reloads_address_part): Pass correct MEMREFLOC
+       argument to find_reloads_address.
+
+2007-08-01  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       PR tree-optimization/32919
+       * tree-ssa-sccvn.c (visit_phi): Do not visit abnormal PHIs.
+       * tree-ssa-coalesce.c (ssa_conflicts_dump): New.
+       (coalesce_ssa_name): Call it.
+
+2007-08-01  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+
+       * config/mips/mips16.S (__mips16_unordsf2, __mips16_floatunsisf): New.
+       (__mips16_unorddf2, __mips16_floatunsidf): New.
+       * config/mips/mips.c (mips_init_libfuncs): Add optab entries for
+       above functions.
+       * config/mips/t-libgcc-mips16 (LIB1ASMFUNCS): Add new functions.
+
+2007-08-01  Zdenek Dvorak  <ook@ucw.cz>
+
+       * tree-pretty-print.c (dump_generic_node): Dump OMP_SECTIONS_SWITCH.
+       Display new operands of OMP_SECTIONS and OMP_CONTINUE.
+       * tree.h (OMP_SECTIONS_CONTROL): New macro.
+       (OMP_DIRECTIVE_P): Add OMP_SECTIONS_SWITCH.
+       * omp-low.c (get_ws_args_for, determine_parallel_type,
+       expand_omp_for_generic, expand_omp_for_static_nochunk,
+       expand_omp_for_static_chunk, expand_omp_for, expand_omp_sections):
+       Work with more precise CFG.
+       (build_omp_regions_1): Handle OMP_SECTIONS_SWITCH.
+       (lower_omp_sections): Emit OMP_SECTIONS_SWITCH.  Add arguments to
+       OMP_CONTINUE.
+       * tree-gimple.c (is_gimple_stmt): Handle OMP_SECTIONS_SWITCH.
+       * gimple-low.c (lower_stmt): Ditto.
+       * tree-inline.c (estimate_num_insns_1): Ditto.
+       * tree.def (OMP_SECTIONS, OMP_CONTINUE): Added new operands.
+       (OMP_SECTIONS_SWITCH): New.
+       * tree-cfgcleanup.c (cleanup_omp_return): New.
+       (cleanup_tree_cfg_bb): Call cleanup_omp_return.
+       * tree-cfg.c (make_edges): Create back edges for OMP_CONTINUE
+       and exit edge for OMP_FOR.  Handle OMP_SECTIONS_SWITCH.
+       (tree_redirect_edge_and_branch): Handle omp constructs.
+
+       * fortran/trans-openmp.c (gfc_trans_omp_sections): Build OMP_SECTIONS
+       with three arguments.
+
+2007-08-01  Zdenek Dvorak  <ook@ucw.cz>
+
+       * tree-cfg.c (tree_merge_blocks): Preserve loop exit phi nodes only
+       in loop closed ssa.
+
+2007-08-01  Zdenek Dvorak  <ook@ucw.cz>
+
+       * tree-ssa-threadupdate.c (thread_through_all_blocks): Record that
+       the loop structures may need fixing.
+       * tree-cfgcleanup.c (cleanup_tree_cfg_noloop, repair_loop_structures):
+       New functions.
+       (cleanup_tree_cfg_loop): Removed.
+       (cleanup_tree_cfg): If loops need fixing, call repair_loop_structures.
+       * tree-predcom.c (tree_predictive_commoning): Return TODO_cleanup_cfg
+       instead of running cleanup_tree_cfg_loop.
+       * cfgloop.h (LOOPS_NEED_FIXUP): New constant.
+       * tree-flow.h (cleanup_tree_cfg_loop): Declaration removed.
+       (tree_predictive_commoning): Declaration changed.
+       * passes.c (execute_function_todo): Do not use cleanup_tree_cfg_loop.
+
+2007-08-01  Zdenek Dvorak  <ook@ucw.cz>
+
+       * doc/invoke.texi (l1-cache-size): Update documentation.
+       (l2-cache-size): Document.
+       * params.h (L2_CACHE_SIZE): New macro.
+       * tree-ssa-loop-prefetch.c (L1_CACHE_SIZE_BYTES): Reflect
+       that L1_CACHE_SIZE is in kB now.
+       (L2_CACHE_SIZE_BYTES): New macro.
+       (tree_ssa_prefetch_arrays): Show size in kB.
+       * config/i386/i386.h (struct processor_costs): Add l1_cache_size
+       and l2_cache_size fields.
+       * config/i386/driver-i386.c (describe_cache): Detect cache size
+       in kB.
+       * config/i386/i386.c (size_cost, i386_cost, i486_cost,pentium_cost,
+       pentiumpro_cost, geode_cost, k6_cost, athlon_cost, k8_cost,
+       amdfam10_cost, pentium4_cost, nocona_cost, core2_cost,
+       generic64_cost, generic32_cost): Add l1_cache_size and l2_cache_size.
+       (override_options): Set l1-cache-size and l2-cache-size to default
+       values if not specified otherwise.
+       * params.def (PARAM_L1_CACHE_SIZE): Change to set in kB.
+       (PARAM_L2_CACHE_SIZE): New.
+
+2007-08-01  Nigel Stephens  <nigel@mips.com>
+           David Ung  <davidu@mips.com>
+           Thiemo Seufer  <ths@mips.com>
+           Chris Dearman  <chris@mips.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (mips*-sde-elf*): New stanza.
+       (mipsisa32-*-elf*, mipsisa32el-*-elf*, mipsisa32r2-*-elf*)
+       (mipsisa32r2el-*-elf*, mipsisa64-*-elf*, mipsisa64el-*-elf*)
+       (mipsisa64sb1-*-elf*, mipsisa64sb1el-*-elf*, mips-*-elf*)
+       (mipsel-*-elf*, mips64-*-elf*, mips64el-*-elf*, mips64orion-*-elf*)
+       (mips64orionel-*-elf*, mips*-*-rtems*, mips-wrs-windiss)
+       (mipstx39-*-elf*, mipstx39el-*-elf*): Add mips/t-libgcc-mips16
+       to tmake_file.
+       * config/mips/sde.h: New file.
+       * config/mips/t-libgcc-mips16: Likewise.
+       * config/mips/t-sde: Likewise.
+       * config/mips/linux.h (TARGET_OS_CPP_BUILTINS): Remove settings
+       of _ABIN32, _ABI64, _ABIO32, _MIPS_SIM, _MIPS_SZLONG, _MIPS_SZPTR,
+       _MIPS_FPSET and _MIPS_SZINT.
+       * config/mips/iris.h (TARGET_OS_CPP_BUILTINS): Likewise.
+       * config/mips/elfoabi.h (DRIVER_SELF_SPECS): Remove separate
+       insertion of a default -mips option.  Use MIPS_32BIT_OPTION_SPEC.
+       * config/mips/t-isa3264 (LIB1ASMSRC, LIB1ASMFUNCS): Delete.
+       * config/mips/t-r3900 (LIB1ASMSRC, LIB1ASMFUNCS): Likewise.
+       * config/mips/t-elf (LIB1ASMSRC, LIB1ASMFUNCS): Likewise.
+       * config/mips/mips.h (TARGET_CPU_CPP_BUITINS): Define _ABIO32,
+       _ABIN32, _ABI64, _ABIO64, _MIPS_SIM, _MIPS_SZINT, _MIPS_SZLONG,
+       _MIPS_SZPTR and _MIPS_FPSET.
+       (MIPS_ISA_LEVEL_SPEC): Inject the default -mips option if no
+       architecture is specified.
+       (MIPS_32BIT_OPTION_SPEC): New macro.
+
+2007-07-31  Dan Hipschman  <dsh@google.com>
+
+       * gcc.c (end_going_arg): New function.
+       (do_spec_2): Use it.
+       (do_spec_1): Use it.
+
+2007-07-31  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * ddg.c (add_cross_iteration_register_deps): Declare bb_info
+       only if ENABLE_CHECKING is defined.
+
+2007-07-31  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * df.h (DF_RU, DF_RU_BB_INFO, df_ru_bb_info, df_ru,
+       df_ru_add_problem, df_ru_get_bb_info): Removed.
+       (DF_RD, DF_UREC, DF_CHAIN, DF_NOTE): Renumbered.
+       * df-problems.c (df_ru_problem_data, df_ru_set_bb_info,
+       df_ru_free_bb_info, df_ru_alloc,
+       df_ru_bb_local_compute_process_def,
+       df_ru_bb_local_compute_process_use, df_ru_bb_local_compute,
+       df_ru_local_compute, df_ru_init_solution, df_ru_confluence_n,
+       df_ru_transfer_function, df_ru_free, df_ru_start_dump,
+       df_ru_top_dump, df_ru_bottom_dump, df_problem problem_RU,
+       df_ru_add_problem): Removed.
+
+2007-07-31  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR target/32847
+       * pa.md (casesi32): Use match_scratch.  Revise insn condition.
+       (casesi32p, casesi64p): Likewise.
+       (casesi): Adjust for above.
+
+2007-07-31  Richard Sandiford  <richard@codesourcery.com>
+
+       * mode-switching.c (create_pre_exit): Don't search past calls.
+
+2007-07-31  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * config/mips/mips.h (ISA_HAS_SYNCI): Add !TARGET_MIPS16 test.
+
+2007-07-31  Revital Eres  <eres@il.ibm.com>
+
+       * ddg.c (add_deps_for_def): Rename to...
+       (add_cross_iteration_register_deps): This.  Change implementation
+       to use only reaching def and def-use chains to construct the
+       inter loop dependencies.
+       (add_deps_for_use): Remove function.
+       (build_inter_loop_deps): Call add_cross_iteration_register_deps
+       function to build the inter loop dependencies.
+       * modulo-sched.c (sms_schedule): Build only
+       reaching def and def-use chains for the propose of the ddg
+       construction.
+
+2007-07-31  Julian Brown  <julian@codesourcery.com>
+
+       * config/arm/neon.md (vec_set<mode>_internal, vec_setv2di_internal):
+       New define_insns. Use correct RTL.
+       (vec_set<mode>): Write as expander.
+
+2007-07-31  Razya Ladelsky  <razya@il.ibm.com>
+
+       * matrix-reorg.c (analyze_matrix_allocation_site): Avoid referring 
+       to an unallocated space.
+
+2007-07-30  Jan Sjodin  <jan.sjodin@amd.com>
+
+       * tree-data-ref.c
+       (split_constant_offset): Enable split_constant_offset to extract
+       constants from other statements.
+       * tree-vect-transform.c
+       (vect_create_addr_base_for_vector_ref): Generate data_ref_base
+       to a temp var. Force base_offset to be simple.
+
+2007-07-30  Seongbae Park <seongbae.park@gmail.com>
+
+       * df-scan.c (df_scan_verify): Remove artificial limit on
+       the number of blocks for verification.
+       * df-problems.c (df_lr_bb_local_compute, df_simulate_find_defs,
+       df_simulate_defs): Avoid unnecessary insn checking for defs.
+
+2007-07-29  Mark Mitchell  <mark@codesourcery.com>
+
+       * config/m68k/lb1sf68.asm (FUNC): New macro.
+       (__mulsi3): Use it.
+       (__udivsi3): Likewise.
+       (__divsi3): Likewise.
+       (__umodsi3): Likewise.
+       (__modsi3): Likewise.
+       (__subdf3): Likewise.
+       (__adddf3): Likewise.
+       (__muldf3): Likewise.
+       (__divdf3): Likewise.
+       (__negdf2): Likewise.
+       (__cmpdf2): Likewise.
+       (__subsf3): Likewise.
+       (__addsf3): Likewise.
+       (__mulsf3): Likewise.
+       (__divsf3): Likewise.
+       (__negsf2): Likewise.
+       (__cmpsf2): Likewise.
+       (__eqdf2): Likewise.
+       (__nedf2): Likewise.
+       (__gtdf2): Likewise.
+       (__gedf2): Likewise.
+       (__ltdf2): Likewise.
+       (__ledf2): Likewise.
+       (__eqsf2): Likewise.
+       (__nesf2): Likewise.
+       (__gtsf2): Likewise.
+       (__gesf2): Likewise.
+       (__ltsf2): Likewise.
+       (__lesf2): Likewise.
+
+2007-07-30  Ollie Wild  <aaw@google.com>
+
+       * c-ppoutput.c (print_lines_directives_only): New function.
+       (scan_translation_unit_directives_only): New function.
+       (preprocess_file): Add call to scan_translation_unit_directives_only.
+       * c-opts.c (c_common_handle_option): Add OPT_fdirectives_only.
+       (sanitize_cpp_opts): Add default flag_dump_macros setting for
+       -fdirectives-only.  Add errors for -fdirectives-only conflict with
+       -Wunused-macros and -traditional.
+       (finish_options): Add builtin macro initialization for
+       -fdirectives-only + -fpreprocessed.
+       * c.opt (fdirectives-only): New.
+       * doc/cppopts.texi (fdirectives-only): New.
+
+2007-07-30  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * alias.c (record_set, memory_modified_1): Constify.
+       * bt-load.c (note_btr_set): Likewise.
+       * caller-save.c (mark_set_regs, add_stored_regs): Likewise.
+       * combine.c (set_nonzero_bits_and_sign_copies,
+       expand_field_assignment, record_dead_and_set_regs_1,
+       use_crosses_set_p, reg_dead_at_p_1, can_combine_p,
+       likely_spilled_retval_1): Likewise.
+       * config/frv/frv.c (frv_registers_update_1, frv_io_check_address,
+       frv_io_handle_set): Likewise.
+       * config/mips/mips.c (mips_sim_record_set,
+       vr4130_true_reg_dependence_p_1): Likewise.
+       * config/mt/mt.c (insn_dependent_p_1): Likewise.
+       * config/s390/s390.c (s390_reg_clobbered_rtx): Likewise.
+       * config/sh/sh.c (flow_dependent_p_1): Likewise.
+       * cselib.c (cselib_invalidate_rtx_note_stores): Likewise.
+       * dce.c (mark_nonreg_stores_1, mark_nonreg_stores_2): Likewise.
+       * ddg.c (mark_mem_store): Likewise.
+       * df-problems.c (df_urec_mark_reg_change): Likewise.
+       * function.c (update_epilogue_consts): Likewise.
+       * gcse.c (record_set_info, record_last_set_info,
+       mems_conflict_for_gcse_p, canon_list_insert, reg_set_info,
+       reg_clear_last_set): Likewise.
+       * global.c (mark_reg_store, mark_reg_clobber, reg_becomes_live):
+       Likewise.
+       * jump.c (reversed_comparison_code_parts): Likewise.
+       * local-alloc.c (validate_equiv_mem_from_store, no_equiv,
+       reg_is_set): Likewise.
+       * loop-iv.c (mark_altered): Likewise.
+       * mode-switching.c (reg_becomes_live): Likewise.
+       * optabs.c (no_conflict_move_test): Likewise.
+       * postreload-gcse.c (record_last_set_info, find_mem_conflicts):
+       Likewise.
+       * postreload.c (reload_combine_note_store, move2add_note_store):
+       Likewise.
+       * regmove.c (flags_set_1): Likewise.
+       * regrename.c (note_sets, kill_clobbered_value, kill_set_value):
+       Likewise.
+       * reload1.c (mark_not_eliminable, forget_old_reloads_1):
+       Likewise. 
+       * resource.c (update_live_status): Likewise.
+       * rtl.h (set_of, note_stores): Likewise.
+       * rtlanal.c (set_of_1, parms_set, struct set_of_data, set_of,
+       note_stores, parms_set): Likewise.
+       * sched-rgn.c (sets_likely_spilled_1): Likewise.
+       * stack-ptr-mod.c (notice_stack_pointer_modification_1):
+       Likewise. 
+       * var-tracking.c (count_stores, add_stores): Likewise.
+
+2007-07-30  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * alias.c (mems_in_disjoint_alias_sets_p,
+       fixed_scalar_and_varying_struct_p, aliases_everything_p,
+       nonoverlapping_component_refs_p, nonoverlapping_memrefs_p,
+       write_dependence_p, mems_in_disjoint_alias_sets_p,
+       read_dependence, true_dependence, canon_true_dependence,
+       anti_dependence, output_dependence): Constify.
+       * combine.c (extended_count): Likewise.
+       * cse.c (cse_rtx_varies_p, hash_rtx, exp_equiv_p): Likewise.
+       * cselib.c (get_value_hash, references_value_p,
+       cselib_reg_set_mode, cselib_rtx_varies_p): Likewise.
+       * cselib.h (cselib_reg_set_mode, references_value_p): Likewise.
+       * emit-rtl.c (mem_expr_equal_p, active_insn_p): Likewise.
+       * function.c (contains, prologue_epilogue_contains,
+       sibcall_epilogue_contains): Likewise. 
+       * jump.c (simplejump_p, condjump_p, condjump_in_parallel_p,
+       pc_set, any_uncondjump_p, any_condjump_p, onlyjump_p,
+       only_sets_cc0_p, sets_cc0_p, rtx_renumbered_equal_p, true_regnum,
+       reg_or_subregno): Likewise.
+       * recog.c (asm_noperands): Likewise.
+       * reload1.c (function_invariant_p): Likewise.
+       * rtl.h (mem_expr_equal_p, active_insn_p, rtx_varies_p,
+       rtx_addr_varies_p, asm_noperands, exp_equiv_p, hash_rtx,
+       condjump_p, any_condjump_p, any_uncondjump_p, pc_set,
+       simplejump_p, onlyjump_p, only_sets_cc0_p, sets_cc0_p,
+       true_regnum, reg_or_subregno, condjump_in_parallel_p,
+       extended_count, prologue_epilogue_contains,
+       sibcall_epilogue_contains, function_invariant_p, true_dependence,
+       canon_true_dependence, read_dependence, anti_dependence,
+       output_dependence): Likewise.
+       * rtlanal.c (rtx_varies_p, rtx_addr_varies_p): Likewise.
+
+2007-07-30  Julian Brown  <julian@codesourcery.com>
+
+       * config/arm/neon.md (V_ext): New mode attribute.
+       (neon_vget_lane<mode>): Replace with define_expand.
+       (neon_vget_lane<mode>_sext_internal)
+       (neon_vget_lane<mode>_zext_internal): New define_insns for double
+       and quad precision vectors.
+       (neon_vget_lanedi): Add bounds check. Remove dead comment.
+       * config/arm/neon.ml (get_lane): Make 32-bit get-lane intrinsics
+       have typeless 32-bit result.
+
+2007-07-30  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR tree-opt/32527
+       * tree-affine.h (aff_tree): The type of rest is sizetype for types
+       of pointers.
+       * tree-affine.c (aff_combination_scale): If type is a pointer type,
+       use sizetype for rest.
+       (aff_combination_add_elt): Likewise. Don't specialize pointer types.
+       (aff_combination_convert): Don't convert rest for pointer types.
+
+2007-07-28  Daniel Berlin  <dberlin@dberlin.org>
+
+       * Makefile.in (tree-ssa-alias.o): Add alloc-pool.h
+
+       * tree-ssa-alias.c: Add alloc-pool.h.
+       (init_alias_info): Free alias_bitmap_obstack.
+       (delete_alias_info): Call delete_mem_ref_stats.
+       (get_mem_sym_stats_for): Use alloc_pool.
+       (init_mem_ref_stats): Do not delete mem_ref_stats here.
+       (delete_mem_sym_stats): Removed.
+       
+2007-07-29  Sebastian Pop  <sebpop@gmail.com>
+
+       * tree-data-ref.c (add_multivariate_self_dist): Parametric access
+       functions cannot be represented as classical distance vectors.
+
+2007-07-29  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * attribs.c (hash_attr, eq_attr, init_attributes): Constify.
+       * builtins.c (validate_arg, builtin_mathfn_code,
+       validate_arglist): Likewise.
+       * calls.c (call_expr_flags): Likewise.
+       * combine.c (reg_nonzero_bits_for_combine,
+       reg_num_sign_bit_copies_for_combine, get_last_value,
+       reg_truncated_to_mode): Likewise.
+       * emit-rtl.c (subreg_lowpart_p): Likewise.
+       * expr.c (highest_pow2_factor_for_target,
+       categorize_ctor_elements_1, categorize_ctor_elements,
+       count_type_elements, contains_packed_reference,
+       highest_pow2_factor, highest_pow2_factor_for_target): Likewise.
+       * fold-const.c (may_negate_without_overflow_p, int_const_binop,
+       fold_convertible_p, operand_equal_p, tree_swap_operands_p,
+       native_encode_int, native_encode_real, native_encode_complex,
+       native_encode_vector, native_encode_expr, native_interpret_int,
+       native_interpret_real, native_interpret_complex,
+       native_interpret_vector, native_interpret_expr): Likewise.
+       * function.c (use_register_for_decl): Likewise.
+       * gimplify.c (get_name): Likewise.
+       * langhooks-def.h (lhd_return_null_const_tree): New.
+       (LANG_HOOKS_GET_CALLEE_FNDECL): Use it.
+       * langhooks.c (lhd_return_null_const_tree): New.
+       * langhooks.h (lang_get_callee_fndecl): Constify.
+       * output.h (constructor_static_from_elts_p): Likewise.
+       * rtl-factoring.c (gen_symbol_ref_rtx_for_label): Likewise.
+       * rtl.h (nonzero_bits, num_sign_bit_copies, truncated_to_mode,
+       subreg_lowpart_p, noop_move_p, struct rtl_hooks): Likewise.
+       * rtlanal.c (cached_nonzero_bits, nonzero_bits1,
+       cached_num_sign_bit_copies, num_sign_bit_copies1, noop_move_p,
+       nonzero_bits, num_sign_bit_copies, truncated_to_mode): Likewise.
+       * rtlhooks-def.h (reg_nonzero_bits_general,
+       reg_num_sign_bit_copies_general, reg_truncated_to_mode_general):
+       Likewise. 
+       * rtlhooks.c (reg_num_sign_bit_copies_general,
+       reg_nonzero_bits_general, reg_truncated_to_mode_general):
+       Likewise. 
+       * stmt.c (warn_if_unused_value, is_body_block): Likewise.
+       * stor-layout.c (mode_for_size_tree): Likewise.
+       * tree-ssa-loop-im.c (memref_eq): Likewise.
+       * tree-ssa-loop-ivopts.c (tree_int_cst_sign_bit): Likewise.
+       * tree.c (contains_placeholder_p, type_list_equal,
+       simple_cst_equal, get_callee_fndecl, operand_equal_for_phi_arg_p):
+       Likewise. 
+       * tree.h (tree_int_cst_sign_bit, may_negate_without_overflow_p,
+       mode_for_size_tree, categorize_ctor_elements, count_type_elements,
+       contains_placeholder_p, contains_packed_reference,
+       get_callee_fndecl, operand_equal_for_phi_arg_p,
+       warn_if_unused_value, is_body_block, native_encode_expr,
+       native_interpret_expr, fold_convertible_p, operand_equal_p,
+       int_const_binop, tree_swap_operands_p, builtin_mathfn_code,
+       validate_arglist, simple_cst_equal, type_list_equal,
+       use_register_for_decl, call_expr_flags, get_name,
+       highest_pow2_factor): Likewise.
+       (const_call_expr_arg_iterator_d,
+       init_const_call_expr_arg_iterator, next_const_call_expr_arg,
+       first_const_call_expr_arg, more_const_call_expr_args_p,
+       FOR_EACH_CONST_CALL_EXPR_ARG): New.
+       * varasm.c (constructor_static_from_elts_p): Constify.
+
+2007-07-28  Kazu Hirata  <kazu@codesourcery.com>
+
+       * cfglayout.c, config/arm/arm.c, config/arm/cortex-a8.md,
+       config/arm/neon-schedgen.ml, config/arm/neon.ml,
+       config/arm/vec-common.md, config/ia64/div.md, cselib.c,
+       df-core.c, df.h, dominance.c, optabs.c, opts.c, reg-stack.c,
+       regstat.c, target.h, tree-ssa-live.c, tree-ssa-pre.c,
+       tree-vect-transform.c, tree.def: Fix comment typos.  Follow
+       spelling conventions.
+       * doc/invoke.texi: Follow spelling conventions.
+
+2007-07-29  Vladimir Yanovsky  <yanov@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * modulo-sched.c (sms_schedule): Avoid loops which includes
+       auto-increment instructions.
+
+2007-07-28  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32920
+       * fold-const.c (fold_cond_expr_with_comparison): Convert
+       operand zero of MIN/MAX_EXPR to correct type.
+
+2007-07-28  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * calls.c (special_function_p, setjmp_call_p, alloca_call_p,
+       flags_from_decl_or_type): Constify.
+       * gcc.c (do_spec_1): Likewise.
+       * print-tree.c (dump_addr, print_node_brief): Likewise.
+       * tree-cfg.c (stmt_starts_bb_p, is_ctrl_stmt, computed_goto_p,
+       simple_goto_p, tree_can_make_abnormal_goto, stmt_starts_bb_p,
+       tree_purge_all_dead_eh_edges): Likewise.
+       * tree-flow.h (is_ctrl_stmt, computed_goto_p, simple_goto_p,
+       tree_can_make_abnormal_goto, tree_purge_all_dead_eh_edges):
+       Likewise. 
+       * tree.c (expr_location, expr_has_location, expr_locus,
+       expr_filename, expr_lineno, get_inner_array_type,
+       fields_compatible_p): Likewise.
+       * tree.h (get_inner_array_type, fields_compatible_p,
+       expr_location, expr_has_location, expr_locus, expr_filename,
+       expr_lineno, dump_addr, print_node_brief, flags_from_decl_or_type,
+       setjmp_call_p, alloca_call_p): Likewise.
+
+2007-07-28  Daniel Berlin  <dberlin@dberlin.org>
+
+       * timevar.def: Add TV_CALL_CLOBBER, TV_FLOW_SENSITIVE,
+       TV_FLOW_INSENSITIVE.
+
+       * tree-ssa-alias.c (compute_call_clobbered): Push/pop
+       TV_CALL_CLOBBER.
+       (compute_flow_sensitive_aliasing): Ditto for TV_FLOW_SENSITIVE.
+       (compute_flow_insensitive_aliasing): Ditto for
+       TV_FLOW_INSENSITIVE.    
+
+2007-07-27  Jan Hubicka  <jh@suse.cz>
+
+       * config/i386/i386.c (register_move_cost): Remove accidentally
+       comitted #if 0 block.
+
+       * attribs.c: Include hashtab.h
+       (attribute_hash): New.
+       (substring): New structure.
+       (extract_attribute_substring, substring_hash, hash_attr, eq_attr):
+       New function.
+       (init_attributes): Initialize attribute hash.
+       (decl_attributes): Use attribute hash.
+       * Makefile.in (attribs.c): Depend on hashtab.h.
+
+2007-07-27  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/vect.md (vec_initv2si): Remove bad BIG_ENDIAN test.
+
+2007-07-27  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi (mdsp, mdspr2): Document the __mips_dsp,
+       __mips_dspr2 and __mips_dsp_rev macros.
+       * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Define __mips_dsp_rev.
+
+2007-07-27  Douglas Gregor  <doug.gregor@gmail.com>
+       
+       * c-common.h (enum rid): Add RID_DECLTYPE, update RID_LAST_CXX0X.
+
+2007-07-26  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/32749
+       
+       * df-problems.c (df_create_unused_note): Removed do_not_gen parm
+       and the updating of the live and do_not_gen sets.
+       (df_note_bb_compute): Added updating of live and do_not_gen sets
+       for regular defs so that the case of clobber inside conditional
+       call is processed correctly.
+       
+2007-07-27  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * config/rs6000/rs6000.c (rs6000_gimplify_va_arg): Generate the
+       operands with compatible type.
+
+2007-07-27  Richard Sandiford  <richard@codesourcery.com>
+
+       * expr.h (store_bit_field): Don't return a value.
+       * expmed.c (check_predicate_volatile_ok): New function.
+       (store_bit_field_1): New function, extracted from store_bit_field.
+       Take a fallback_p argument and return true if the operation succeeded.
+       Only use store_fixed_bit_field if fallback_p.  Don't recompute
+       mode_for_extraction; use op_mode instead.  Try forcing memories
+       into registers if the insv expander fails.
+       (store_bit_field): Use store_bit_field_1 with fallback_p true.
+       Don't return a value.
+       (convert_extracted_bit_field): New function, extracted from
+       store_bit_field.
+       (extract_bit_field_1): Likewise.  Take a fallback_p argument
+       and return NULL if the operation succeeded.  Only use
+       extract_fixed_bit_field if fallback_p.  Only calculate one
+       extraction mode.  Combine code for extv and extzv.  Try forcing
+       memories into registers if the ext(z)v expander fails.
+       (extract_bit_field): Use extract_bit_field_1 with fallback_p true.
+
+2007-07-27  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * df.h (df_mw_hardreg): Turn df_ref_type and df_ref_flags
+       into bitfields.
+       (df_ref): Likewise.  Put regno with other integer fields.
+
+2007-07-27  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * df.h (df_mw_hardreg): Remove "loc" field.
+       * df-scan.c (df_ref_record): Don't set it.  Remove redundant
+       local variable.
+       * df-problems.c (df_whole_mw_reg_unused_p): New function,
+       split out from df_set_unused_notes_for_mw.  Return false for
+       partial references.  Assert that mw_reg is a REG when returning true.
+       (df_set_unused_notes_for_mw): Use it.  Use mw_reg instead of *loc.
+       (df_whole_mw_reg_dead_p): New function, split out from
+       df_set_dead_notes_for_mw.  Return false for partial references.
+       Assert that mw_reg is a REG when returning true.
+       (df_set_dead_notes_for_mw): Use it.  Use mw_reg instead of *loc.
+       Remove redundant bitmap check.
+
+2007-07-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/ia64/t-ia64 ($(T)crtbegin.o): Removed.
+       ($(T)crtend.o): Likwise.
+       ($(T)crtbeginS.o): Likwise.
+       ($(T)crtendS.o): Likwise.
+       ($(T)crtfastmath.o): Likwise.
+
+2007-07-26  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * dominance.c (dom_computed, n_bbs_in_dom_tree): Removed.
+       * function.h (dom_computed, n_bbs_in_dom_tree): New macros.
+       * basic-block.h (struct control_flow_graph): Added x_dom_computed
+       and x_n_bbs_in_dom_tree fields.
+
+2007-07-26  Steve Ellcey  <sje@cup.hp.com>
+
+       PR tree-optimization/32087
+       * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop):
+       Do not call scale_bbs_frequencies_int with prob of zero.
+
+2007-07-26  Julian Brown  <julian@codesourcery.com>
+
+       * config/arm/arm-protos.h (neon_lane_bounds, neon_const_bounds)
+       (neon_element_bits): Add prototypes.
+       * config/arm/arm.c (bounds_check, neon_lane_bounds)
+       (neon_const_bounds, neon_element_bits): New functions.
+       * config/arm/neon.md (neon_vget_lane<mode>, neon_vget_lanedi)
+       (neon_vget_lanev2di, neon_vset_lane<mode>, neon_vset_lanedi)
+       (neon_vset_lanev2di, neon_vdup_lane<mode>, neon_vdup_lanedi)
+       (neon_vdup_lanev2di, neon_vcvt_n<mode>, neon_vmul_lane<mode>)
+       (neon_vmull_lane<mode>, neon_vqdmull_lane<mode>)
+       (neon_vqdmulh_lane<mode>, neon_vmla_lane<mode>)
+       (neon_vmlal_lane<mode>, neon_vqdmlal_lane<mode>)
+       (neon_vmls_lane<mode>, neon_vmlsl_lane<mode>)
+       (neon_vqdmlsl_lane<mode>, neon_vext<mode>, neon_vshr_n<mode>)
+       (neon_vshrn_n<mode>, neon_vqshrn_n<mode>, neon_vqshrun_n<mode>)
+       (neon_vshl_n<mode>, neon_vshl_n<mode>, neon_vqshl_n<mode>)
+       (neon_vqshlu_n<mode>, neon_vshll_n<mode>, neon_vsra_n<mode>)
+       (neon_vsri_n<mode>, neon_vsli_n<mode>): Add bounds checks.
+
+2007-07-26  Nathan Froyd  <froydnj@codesourcery.com>
+
+       * config/vxworks.h (VXWORKS_LINK_SPEC): Fix typo.
+       (HAVE_AS_GNU_ATTRIBUTE): Undefine.
+
+2007-07-26  Mark Shinwell  <shinwell@codesourcery.com>
+           Julian Brown  <julian@codesourcery.com>
+
+       * config/arm/arm.c (arm_mac_accumulator_is_mul_result): New.
+       * config/arm/arm-protos.h (arm_mac_accumulator_is_mul_result): New.
+       * config/arm/cortex-a8.md: New.
+       * config/arm/cortex-a8-neon.md: New.
+       * config/arm/neon-schedgen.ml: New.
+       * config/arm/neon.md (vqh_mnem): New.
+       (neon_type): New.
+       (Is_float_mode): New.
+       (Scalar_mul_8_16): New.
+       (Is_d_reg): New.
+       (V_mode_nunits): New.
+       (All instruction patterns): Annotate with neon_type attribute
+       values.
+       * config/arm/arm.md: Include cortex-a8.md.
+       (insn): Add smmla, umaal, smlald, smlsld, clz, mrs, msr and xtab
+       values.
+       Annotate instruction patterns accordingly.
+       (generic_sched): Do not use generic scheduling for Cortex-A8.
+       (generic_vfp): Do not use generic VFP scheduling for Cortex-A8.
+
+2007-07-26  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * fold-const.c (fold_read_from_constant_string): Use
+       build_int_cst_type.
+       * tree-ssa-ccp.c (fold_const_aggregate_ref): Likewise.
+
+2007-07-26  Nick Clifton  <nickc@redhat.com>
+
+       * tree-ssa-operands.h: 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.
+       * tree-vrp.c, regrename.c, attribs.c, loop-unswitch.c,
+       sched-ebb.c, fwprop.c, tree-loop-linear.c, dwarf2asm.c,
+       tree-into-ssa.c, dwarf2asm.h, tree-ssa-loop-im.c, sbitmap.c,
+       targhooks.c, tree-dump.c, tree-complex.c, sbitmap.h, targhooks.h,
+       tree-dump.h, regstat.c, see.c, machmode.h, hooks.c, cgraphbuild.c,
+       hooks.h, genrecog.c, tree-ssa-threadupdate.c, gen-protos.c,
+       flags.h, rtlhooks.c, gencheck.c, tree-ssa-loop-niter.c,
+       opts-common.c, dbgcnt.def, tree-pretty-print.c, tracer.c,
+       gengtype.c, mkconfig.sh, gengtype.h, tree-ssa-loop-unswitch.c,
+       cgraph.c, c-lex.c, cgraph.h, libfuncs.h, cfgloopmanip.c,
+       rtl-error.c, optabs.c, postreload-gcse.c, tree-ssa-loop-manip.c,
+       optabs.h, genmddeps.c, defaults.h, postreload.c, value-prof.c,
+       tree-ssa-loop-ch.c, tree-tailcall.c, gengenrtl.c, value-prof.h,
+       genopinit.c, tree.c, tree.h, reload.c, tree-pass.h, ipa-cp.c,
+       reload.h, bitmap.c, bitmap.h, tree-scalar-evolution.c,
+       c-config-lang.in, tree-scalar-evolution.h, target.h, cppspec.c,
+       rtlanal.c, ddg.c, lambda-mat.c, mips-tdump.c, ddg.h,
+       tree-phinodes.c, mips-tfile.c, pointer-set.c, pointer-set.h,
+       diagnostic.c, final.c, diagnostic.h, builtins.c, genoutput.c,
+       gcc.c, lists.c, tree-ssa-alias-warnings.c, gcc.h, cfghooks.c,
+       input.h, gensupport.c, fold-const.c, cfghooks.h, insn-notes.def,
+       gensupport.h, builtin-attrs.def, sync-builtins.def, params.c,
+       cfgloopanal.c, params.h, graphds.c, omp-low.c, tree-ssa-dse.c,
+       graphds.h, gcov.c, cfg.c, genextract.c, ipa-reference.c,
+       genautomata.c, tree-ssa-uncprop.c, auto-inc-dec.c, toplev.c,
+       tree-gimple.c, ipa-reference.h, vmsdbgout.c, errors.c, toplev.h,
+       reorg.c, tree-gimple.h, tree-chrec.c, pretty-print.c, errors.h,
+       real.c, tree-chrec.h, pretty-print.h, debug.c, real.h, genemit.c,
+       omega.c, c-cppbuiltin.c, genmultilib, debug.h, omega.h,
+       tree-ssa-sccvn.c, genconfig.c, tree-ssa-sccvn.h, cgraphunit.c,
+       regs.h, df-scan.c, vec.c, hosthooks-def.h, vec.h,
+       tree-ssa-copyrename.c, scan.c, builtin-types.def, tree-ssa-ccp.c,
+       scan.h, mode-classes.def, haifa-sched.c, dominance.c, dojump.c,
+       double-int.c, gcov-io.c, dbxout.c, builtins.def, double-int.h,
+       dbxout.h, tree-ssa-loop-ivopts.c, df-core.c, mode-switching.c,
+       gengtype-lex.l, tree-nomudflap.c, modulo-sched.c, c-objc-common.c,
+       hosthooks.h, c-objc-common.h, caller-save.c, graph.c,
+       ipa-pure-const.c, graph.h, c-format.c, cse.c, fix-header.c,
+       c-format.h, web.c, tree-stdarg.c, genpeep.c, tree-stdarg.h,
+       tree-ssa-math-opts.c, xcoffout.c, tree-ssa-dom.c, tree-nrv.c,
+       xcoffout.h, tree-ssa-propagate.c, ipa-utils.c,
+       tree-ssa-propagate.h, tree-ssa-alias.c, loop-init.c, ipa-utils.h,
+       gimple-low.c, rtl.def, c-tree.h, tree-ssa-sink.c, ipa-inline.c,
+       mkmap-symver.awk, machmode.def, c-pch.c, cfganal.c, global.c,
+       alloc-pool.c, c-semantics.c, alloc-pool.h, jump.c, ifcvt.c,
+       dwarf2out.c, expr.c, cfgbuild.c, tree-browser.c, dwarf2out.h,
+       expr.h, longlong.h, opts.c, gcov-iov.c, opts.h, dwarf2.h,
+       genattrtab.c, genconditions.c, genattr.c, optc-gen.awk,
+       timevar.def, tree-ssa-loop-ivcanon.c, hard-reg-set.h, predict.c,
+       tree-ssa-loop.c, host-default.c, predict.h, recog.c, dbgcnt.c,
+       recog.h, dbgcnt.h, c-aux-info.c, tree-ssa-address.c, timevar.c,
+       dse.c, lcm.c, tree-ssa-ifcombine.c, timevar.h, dse.h,
+       matrix-reorg.c, tree-vn.c, treestruct.def, fp-test.c, c-decl.c,
+       tree-eh.c, c-errors.c, c-pretty-print.c, regmove.c,
+       lambda-trans.c, c-pretty-print.h, et-forest.c, et-forest.h,
+       ebitmap.c, configure.ac, local-alloc.c, function.c, langhooks.c,
+       ebitmap.h, cppdefault.c, tree-vectorizer.c, function.h,
+       langhooks.h, print-rtl.c, cppdefault.h, df.h, tree-vectorizer.h,
+       sdbout.c, stor-layout.c, sdbout.h, rtlhooks-def.h, read-rtl.c,
+       gcse.c, ipa-type-escape.c, vmsdbg.h, alias.c, gengtype-parse.c,
+       ipa-type-escape.h, domwalk.c, alias.h, tree-if-conv.c, profile.c,
+       init-regs.c, domwalk.h, ipa.c, gccbug.in, tree-data-ref.c,
+       loop-unroll.c, tree-data-ref.h, tree-flow-inline.h, tree-affine.c,
+       mkmap-flat.awk, tree-affine.h, tree-vect-analyze.c, c.opt, ggc.h,
+       opt-gather.awk, c-typeck.c, gimplify.c, coretypes.h, exec-tool.in,
+       insn-addr.h, tree-ssa-phiopt.c, c-pragma.c, c-pragma.h, calls.c,
+       tree-ssa-coalesce.c, genmodes.c, loop-doloop.c, predict.def,
+       dwarf.h, tree.def, rtl-factoring.c, lower-subreg.c, expmed.c,
+       bt-load.c, ggc-common.c, genflags.c, tree-dfa.c, except.c,
+       coverage.c, except.h, emit-rtl.c, cfgexpand.c, coverage.h,
+       stringpool.c, cselib.c, emit-rtl.h, tree-cfgcleanup.c, c-opts.c,
+       cselib.h, cfgcleanup.c, simplify-rtx.c, tree-ssa-pre.c, explow.c,
+       tree-ssa-live.c, tree-sra.c, tree-ssa-live.h, tree-predcom.c,
+       loop-invariant.c, genpreds.c, protoize.c, opth-gen.awk, c-dump.c,
+       lambda.h, loop-iv.c, tree-mudflap.c, ipa-prop.c, print-tree.c,
+       tree-mudflap.h, tree-ssa-copy.c, ipa-prop.h, cfglayout.c,
+       tree-ssa-forwprop.c, c-convert.c, cfglayout.h, common.opt,
+       ggc-zone.c, ggc-page.c, c-omp.c, tree-ssa-dce.c, gencodes.c,
+       varasm.c, tree-vect-patterns.c, libada-mk.in, tree-ssa-ter.c,
+       sched-deps.c, tree-nested.c, c-ppoutput.c, tree-ssa.c,
+       target-def.h, tree-ssa-loop-prefetch.c, lambda-code.c,
+       omp-builtins.def, rtl.c, regclass.c, stab.def, intl.c, rtl.h,
+       intl.h, tree-inline.c, conditions.h, tree-inline.h, integrate.c,
+       sched-int.h, tree-iterator.c, integrate.h, tree-iterator.h,
+       genchecksum.c, tree-optimize.c, output.h, tree-vect-transform.c,
+       tree-object-size.c, combine.c, tree-outof-ssa.c, addresses.h,
+       bb-reorder.c, stack-ptr-mod.c, resource.c, var-tracking.c,
+       cfgloop.c, system.h, resource.h, ggc-none.c, tree-profile.c,
+       cfgloop.h, c-gimplify.c, c-common.c, opt-functions.awk,
+       tree-vect-generic.c, tree-flow.h, df-problems.c, scan-decls.c,
+       c-common.h, config.gcc, reg-stack.c, tlink.c, main.c, stub-objc.c,
+       fixproto, config.host, Makefile.in, gccspec.c, sched-rgn.c,
+       vecprim.h, basic-block.h, tree-ssa-structalias.c,
+       tree-ssa-structalias.h, c-common.def, sched-vis.c, tree-cfg.c,
+       passes.c, genconstants.c, c-incpath.c, c-incpath.h,
+       struct-equiv.c, c-parser.c, tree-ssa-reassoc.c, varray.c, sreal.c,
+       varray.h, dfp.c, sreal.h, combine-stack-adj.c, dfp.h,
+       reg-notes.def, cfgrtl.c, config.build, varpool.c, gengtype-yacc.y,
+       stmt.c, dce.c, tree-browser.def, prefix.c, statistics.h,
+       params.def, dce.h, c-lang.c, gcov-dump.c, prefix.h,
+       tree-ssanames.c, collect2.c, collect2.h, tree-ssa-threadedge.c,
+       convert.c, convert.h, langhooks-def.h, reload1.c,
+       tree-ssa-operands.c: Likewise.
+
+2007-07-26  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-live.c: Include debug.h and flags.h.
+       (mark_scope_block_unused): New function.
+       (remove_unused_scope_block_p): New function.
+       (remove_unused_locals): Remove unused blocks too.
+
+2007-07-25  Ian Lance Taylor  <iant@google.com>
+
+       * combine.c (combine_max_regno): Remove.  Remove all uses.
+       (struct reg_stat_struct): Rename from struct reg_stat.
+       (reg_stat_type): Define, and declare VECs.
+       (reg_stat): Change from pointer to VEC.  Change all uses.
+       (combine_split_insns): New static function.
+       (try_combine, find_split_point): Call it instead of split_insns.
+
+2007-07-25  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * cfghooks.c (split_block): Fix the information about loop latch.
+
+2007-07-25  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * cfgloopmanip.c (fix_loop_structure): Call force_single_succ_latches.
+
+2007-07-25  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-threadupdate.c (create_edge_and_update_destination_phis):
+       Scan the new edge for loop exit info.
+
+2007-07-25  Andreas Tobler  <a.tobler@schweiz.org>
+
+       * config/darwin.c: Include debug.h.
+
+2007-07-25  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/32218
+       * tree-vect-patterns.c (vect_pattern_recog_1): Check for valid type.
+
+2007-07-25  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/ia64.h (HARD_REGNO_NREGS): Handle RFmode.
+       (HARD_REGNO_MODE_OK): Ditto.
+       (MODES_TIEABLE_P): Ditto.
+       (HARD_REGNO_CALLER_SAVE_MODE): Ditto.
+       (CLASS_MAX_NREGS): Ditto.
+       * config/ia64/ia64.c (ia64_print_operand_address): Add R format.
+       * config/ia64/ia64.md (divsf3_internal_thr): Removed.
+       (divdf3_internal_thr): Removed.
+       * config/ia64/div.md: New file.
+       * config/ia64/constraints.md: Add H constraint.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * sbitmap.c (sbitmap_verify_popcount, sbitmap_alloc_with_popcount,
+       sbitmap_copy, sbitmap_copy_n, sbitmap_equal, sbitmap_empty_p,
+       sbitmap_union_of_diff_cg, sbitmap_union_of_diff, sbitmap_not,
+       sbitmap_difference, sbitmap_any_common_bits, sbitmap_a_and_b_cg,
+       sbitmap_a_and_b, sbitmap_a_xor_b_cg, sbitmap_a_xor_b,
+       sbitmap_a_or_b_cg, sbitmap_a_or_b, sbitmap_a_subset_b_p,
+       sbitmap_a_or_b_and_c_cg, sbitmap_a_or_b_and_c,
+       sbitmap_a_and_b_or_c_cg, sbitmap_a_and_b_or_c,
+       sbitmap_first_set_bit, sbitmap_last_set_bit, dump_sbitmap,
+       dump_sbitmap_file, debug_sbitmap, popcount_table,
+       sbitmap_popcount): Constify.
+       * sbitmap.h (const_sbitmap, const_sbitmap_ptr): New.
+       (sbitmap_iterator, sbitmap_iter_init, dump_sbitmap,
+       dump_sbitmap_file, sbitmap_copy, sbitmap_copy_n, sbitmap_equal,
+       sbitmap_empty_p, sbitmap_union_of_diff, sbitmap_union_of_diff_cg,
+       sbitmap_difference, sbitmap_not, sbitmap_a_or_b_and_c,
+       sbitmap_a_or_b_and_c_cg, sbitmap_a_and_b_or_c,
+       sbitmap_a_and_b_or_c_cg, sbitmap_any_common_bits, sbitmap_a_and_b,
+       sbitmap_a_and_b_cg, sbitmap_a_or_b, sbitmap_a_or_b_cg,
+       sbitmap_a_xor_b, sbitmap_a_xor_b_cg, sbitmap_a_subset_b_p,
+       sbitmap_first_set_bit, sbitmap_last_set_bit, debug_sbitmap,
+       sbitmap_popcount, sbitmap_verify_popcount): Constify.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * bitmap.c (hash_descriptor, eq_descriptor, bitmap_element_zerop,
+       bitmap_copy, bitmap_clear_bit, popcount_table, bitmap_count_bits,
+       bitmap_first_set_bit, bitmap_and, bitmap_and_into,
+       bitmap_elt_copy, bitmap_and_compl, bitmap_and_compl_into,
+       bitmap_compl_and_into, bitmap_elt_ior, bitmap_ior,
+       bitmap_ior_into, bitmap_xor, bitmap_xor_into, bitmap_equal_p,
+       bitmap_intersect_p, bitmap_intersect_compl_p,
+       bitmap_ior_and_compl, bitmap_ior_and_compl_into,
+       debug_bitmap_file, debug_bitmap, bitmap_print, bitmap_hash):
+       Constify.
+       * bitmap.h (bitmap_copy, bitmap_equal_p, bitmap_intersect_p,
+       bitmap_intersect_compl_p, bitmap_count_bits, bitmap_and,
+       bitmap_and_into, bitmap_and_compl, bitmap_and_compl_into,
+       bitmap_compl_and_into, bitmap_ior, bitmap_ior_into, bitmap_xor,
+       bitmap_xor_into, bitmap_ior_and_compl, bitmap_ior_and_compl_into,
+       debug_bitmap, debug_bitmap_file, bitmap_print,
+       bitmap_first_set_bit, bitmap_hash, bmp_iter_set_init,
+       bmp_iter_and_init, bmp_iter_and_compl_init): Likewise.
+
+2007-07-25  Daniel Berlin  <dberlin@dberlin.org>
+
+       * config/darwin.c (darwin_override_options): Additional fix for
+       debug info formats that don't support var tracking.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * cselib.c (entry_and_rtx_equal_p): Constify.
+       * gengtype.c (output_mangled_typename, write_types, write_local):
+       Likewise.
+       * gengtype.h (const_type_p): New.
+       * see.c (eq_descriptor_extension, hash_descriptor_extension):
+       Constify.
+       * tlink.c (scan_linker_output): De-constify.
+       * tree-ssa-loop-im.c (memref_eq): Constify.
+       * tree-ssa-structalias.c (const_shared_bitmap_info_t): New.
+       (shared_bitmap_hash, shared_bitmap_eq): Constify.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * c-common.c (fname_as_string, c_type_hash): Constify.
+       * c-typeck.c (free_all_tagged_tu_seen_up_to): Likewise.
+       * cgraph.c (edge_hash, edge_eq): Likewise.
+       * dwarf2out.c (decl_die_table_eq, decl_loc_table_eq): Likewise.
+       * emit-rtl.c (mem_attrs_htab_eq, reg_attrs_htab_hash,
+       reg_attrs_htab_eq): Likewise.
+       * except.c (t2r_eq, t2r_hash, ttypes_filter_eq, ehl_hash, ehl_eq):
+       Likewise.
+       * genautomata.c (const_reserv_sets_t, const_unit_decl_t,
+       const_decl_t, const_state_t, const_automata_list_el_t): New.
+       (first_out_arc, DECL_UNIT, DECL_BYPASS, DECL_AUTOMATON, DECL_EXCL,
+       DECL_PRESENCE, DECL_ABSENCE, DECL_RESERV, DECL_INSN_RESERV,
+       automaton_decl_hash, automaton_decl_eq_p, insn_decl_hash,
+       insn_decl_eq_p, decl_hash, decl_eq_p, alt_state_cmp,
+       reserv_sets_cmp, reserv_sets_eq, state_hash, state_eq_p,
+       automata_list_hash, automata_list_eq_p, compare_states_for_equiv,
+       compare_max_occ_cycle_nums, out_state_arcs_num,
+       compare_transition_els_num, units_cmp, state_reservs_cmp):
+       Constify.
+       * genmodes.c (cmp_modes): Likewise.
+       * ggc-common.c (saving_htab_hash, saving_htab_eq): Likewise.
+       * gimplify.c (compare_case_labels): Likewise.
+       * ipa-type-escape.c (get_name_of_type, type_brand_s): Likewise.
+       * loop-unroll.c (si_info_hash, ve_info_hash): Likewise.
+       * matrix-reorg.c (mtt_info_hash): Likewise.
+       * postreload-gcse.c (hash_expr_for_htab, expr_equiv_p): Likewise.
+       * rtl-factoring.c (const_p_hash_bucket, const_p_hash_elem): New.
+       (htab_hash_bucket, htab_hash_elem): Constify.
+       * tree-browser.c (TB_parent_eq): Likewise.
+       * tree-scalar-evolution.c (hash_scev_info): Likewise.
+       * tree-ssa-alias.c (sort_tags_by_id): Likewise.
+       * tree-ssa-coalesce.c (const_coalesce_pair_p): New.
+       (coalesce_pair_map_hash, coalesce_pair_map_eq, compare_pairs):
+       Constify.
+       * tree-ssa-dom.c (avail_expr_hash, avail_expr_eq): Likewise.
+       * tree-ssa-pre.c (const_expr_pred_trans_t): New.
+       (expr_pred_trans_hash, expr_pred_trans_eq): Constify.
+       * tree-ssa-sccvn.c (const_vn_binary_op_t, const_vn_unary_op_t,
+       const_vn_phi_t, const_vn_reference_op_t, const_vn_reference_t):
+       New.
+       (vn_reference_op_eq, vn_reference_hash, vn_reference_eq,
+       vn_unary_op_hash, vn_unary_op_eq, vn_binary_op_hash,
+       vn_binary_op_eq, vn_phi_hash, vn_phi_eq): Constify.
+       * tree-ssa-threadupdate.c (redirection_data_hash,
+       redirection_data_eq): Likewise. 
+       * tree-ssa-uncprop.c (equiv_hash, equiv_eq): Likewise.
+       * tree-ssa.c (var_ann_eq): Likewise.
+       * tree-vrp.c (compare_case_labels): Likewise.
+       * tree.c (int_cst_hash_hash, int_cst_hash_eq,
+       tree_map_base_marked_p, type_hash_marked_p, tree_check_failed,
+       tree_not_check_failed, tree_class_check_failed,
+       tree_range_check_failed, tree_not_class_check_failed,
+       omp_clause_check_failed, omp_clause_range_check_failed,
+       tree_contains_struct_check_failed, tree_operand_check_failed):
+       Likewise. 
+       * tree.h (tree_contains_struct_check_failed, tree_check_failed,
+       tree_not_check_failed, tree_class_check_failed,
+       tree_range_check_failed, tree_not_class_check_failed,
+       tree_operand_check_failed, omp_clause_operand_check_failed,
+       tree_operand_length): Likewise. 
+       * var-tracking.c (const_variable): New.
+       (variable_htab_hash, variable_htab_eq): Constify.
+       * varasm.c (const_desc_hash): Likewise.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * expr.c (handled_component_p): Constify.
+       * fold-const.c (fit_double_type): Likewise.
+       * real.h (real_value_from_int_cst): Likewise.
+       * tree-flow-inline.h (gimple_in_ssa_p,
+       gimple_aliases_computed_p, gimple_addressable_vars,
+       gimple_call_clobbered_vars, gimple_referenced_vars,
+       gimple_global_var, gimple_nonlocal_all, gimple_var_anns,
+       end_htab_p, end_referenced_vars_p, var_ann, function_ann,
+       may_aliases, end_readonly_imm_use_p, has_zero_uses,
+       has_single_use, single_imm_use, num_imm_uses, is_exec_stmt,
+       is_label_stmt, is_global_var, phi_ssa_name_p,
+       factoring_name_p, is_call_clobbered, tree_common_ann,
+       op_iter_done, end_imm_use_stmt_p, end_imm_use_on_stmt_p,
+       unmodifiable_var_p, array_ref_contains_indirect_ref,
+       ref_contains_array_ref, lookup_subvars_for_var,
+       var_can_have_subvars, overlap_subvar, gimple_ssa_operands,
+       gimple_mem_ref_stats): Likewise.
+       * tree-flow.h (tree_common_ann, var_ann, function_ann,
+       may_aliases, is_exec_stmt, is_label_stmt,
+       ref_contains_array_ref, array_ref_contains_indirect_ref,
+       var_can_have_subvars, overlap_subvar, is_call_clobbered,
+       unmodifiable_var_p): Likewise.
+       * tree-gimple.c (is_gimple_min_invariant): Likewise.
+       * tree-gimple.h (is_gimple_min_invariant): Likewise. 
+       * tree.c (type_hash_list, attribute_hash_list, tree_size,
+       cst_and_fits_in_hwi, real_value_from_int_cst,
+       build_real_from_int_cst, integer_zerop, integer_onep,
+       integer_all_onesp, integer_pow2p, integer_nonzerop, tree_log2,
+       tree_floor_log2, real_zerop, real_onep, real_twop,
+       real_minus_onep, really_constant_p, purpose_member, chain_member,
+       list_length, fields_length, int_size_in_bytes, bit_position,
+       int_bit_position, byte_position, int_byte_position, expr_align,
+       array_type_nelts, tree_node_structure,
+       type_contains_placeholder_1, iterative_hash_pointer,
+       is_attribute_with_length_p, is_attribute_p, check_qualified_type,
+       tree_map_base_eq, type_hash_list, type_hash_eq,
+       attribute_hash_list, type_num_arguments, tree_int_cst_equal,
+       tree_int_cst_lt, tree_int_cst_compare, host_integerp,
+       tree_low_cst, tree_int_cst_msb, tree_int_cst_sgn,
+       simple_cst_list_equal, compare_tree_int, iterative_hash_expr,
+       int_fits_type_p, get_containing_scope, decl_function_context,
+       decl_type_context, omp_clause_operand_check_failed,
+       initializer_zerop, int_cst_value, num_ending_zeros): Likewise.
+       * tree.h (omp_clause_operand_check_failed, tree_size,
+       build_real_from_int_cst, array_type_nelts, purpose_member,
+       tree_int_cst_equal, tree_int_cst_lt, tree_int_cst_compare,
+       host_integerp, tree_low_cst, tree_int_cst_msb, tree_int_cst_sgn,
+       is_attribute_p, check_qualified_type, expr_align,
+       int_size_in_bytes, bit_position, int_bit_position, byte_position,
+       int_byte_position, list_length, fields_length, initializer_zerop,
+       integer_zerop, integer_onep, integer_all_onesp, integer_pow2p,
+       integer_nonzerop, cst_and_fits_in_hwi, num_ending_zeros,
+       tree_node_structure, handled_component_p, get_containing_scope,
+       decl_function_context, decl_type_context, real_zerop,
+       type_num_arguments, fit_double_type, really_constant_p,
+       int_fits_type_p, tree_log2, tree_floor_log2, iterative_hash_expr,
+       compare_tree_int, chain_member, simple_cst_list_equal, real_onep,
+       real_twop, real_minus_onep, int_cst_value): Likewise.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * cfglayout.c (insn_scope, insn_line): Constify.
+       * emit-rtl.c (const_int_htab_hash, const_int_htab_eq,
+       const_double_htab_hash, const_double_htab_eq,
+       mem_attrs_htab_hash): Likewise.
+       * loop-iv.c (biv_eq): Likewise.
+       * print-rtl.c (print_rtx, print_decl_name, print_mem_expr,
+       print_inline_rtx, debug_rtx, debug_rtx_list, debug_rtx_range,
+       debug_rtx_find, print_rtl, print_rtl_single, print_simple_rtl):
+       Likewise. 
+       * rtl-error.c (location_for_asm, diagnostic_for_asm,
+       error_for_asm, warning_for_asm, _fatal_insn,
+       _fatal_insn_not_found): Likewise. 
+       * rtl.c (rtx_size, shared_const_p, shallow_copy_rtx_stat,
+       rtx_equal_p, rtl_check_failed_bounds, rtl_check_failed_type1,
+       rtl_check_failed_type2, rtl_check_failed_code1,
+       rtl_check_failed_code2, rtl_check_failed_code_mode,
+       rtvec_check_failed_bounds, rtl_check_failed_flag): Likewise.
+       * rtl.h (rtl_check_failed_bounds, rtl_check_failed_type1,
+       rtl_check_failed_type2, rtl_check_failed_code1,
+       rtl_check_failed_code2, rtl_check_failed_code_mode,
+       rtvec_check_failed_bounds, rtl_check_failed_flag, LABEL_KIND,
+       SET_LABEL_KIND, rhs_regno, subreg_lsb, subreg_regno, subreg_nregs,
+       shared_const_p, rtx_size, shallow_copy_rtx_stat, rtx_equal_p,
+       get_pool_mode, insn_line, insn_file, simplify_replace_rtx,
+       mode_signbit_p, rtx_addr_can_trap_p, nonzero_address_p,
+       rtx_unstable_p, get_integer_term, get_related_value,
+       offset_within_block_p, reg_mentioned_p, count_occurrences,
+       reg_referenced_p, reg_used_between_p, no_labels_between_p,
+       single_set_2, multiple_sets, set_noop_p, refers_to_regno_p,
+       reg_overlap_mentioned_p, dead_or_set_p, dead_or_set_regno_p,
+       find_reg_note, find_regno_note, find_reg_equal_equiv_note,
+       find_constant_src, find_reg_fusage, find_regno_fusage,
+       pure_call_p, remove_note, side_effects_p, volatile_refs_p,
+       volatile_insn_p, may_trap_p, may_trap_after_code_motion_p,
+       may_trap_or_fault_p, inequality_comparisons_p, tablejump_p,
+       computed_jump_p, auto_inc_p, in_expr_list_p,
+       remove_node_from_expr_list, loc_mentioned_in_p,
+       label_is_jump_target_p, reversed_comparison_code_parts,
+       debug_rtx, debug_rtx_list, debug_rtx_range, debug_rtx_find,
+       print_mem_expr, print_rtl, print_simple_rtl, print_rtl_single,
+       print_inline_rtx): Likewise.
+       * rtlanal.c (covers_regno_p, covers_regno_no_parallel_p,
+       computed_jump_p_1, nonzero_bits1, rtx_unstable_p,
+       rtx_addr_can_trap_p_1, rtx_addr_can_trap_p, nonzero_address_p,
+       get_integer_term, get_related_value, offset_within_block_p,
+       count_occurrences, reg_mentioned_p, no_labels_between_p,
+       reg_used_between_p, reg_referenced_p, single_set_2,
+       multiple_sets, set_noop_p, refers_to_regno_p,
+       reg_overlap_mentioned_p, dead_or_set_p,
+       covers_regno_no_parallel_p, covers_regno_p,
+       dead_or_set_regno_p, find_reg_note, find_regno_note,
+       find_reg_equal_equiv_note, find_constant_src, find_reg_fusage,
+       find_regno_fusage, pure_call_p, remove_note, in_expr_list_p,
+       remove_node_from_expr_list, volatile_insn_p, volatile_refs_p,
+       side_effects_p, may_trap_p_1, may_trap_p,
+       may_trap_after_code_motion_p, may_trap_or_fault_p,
+       inequality_comparisons_p, tablejump_p, computed_jump_p_1,
+       computed_jump_p, auto_inc_p, loc_mentioned_in_p, subreg_lsb,
+       subreg_regno, subreg_nregs, label_is_jump_target_p): Likewise.
+       * simplify-rtx.c (neg_const_int, plus_minus_operand_p,
+       mode_signbit_p, simplify_replace_rtx, plus_minus_operand_p):
+       Likewise. 
+       * toplev.h (_fatal_insn_not_found, _fatal_insn, error_for_asm,
+       warning_for_asm): Likewise.
+       * tree.h (print_rtl): Likewise.
+       * varasm.c (get_pool_mode): Likewise.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * c-lex.c (c_lex_with_flags, lex_string): Constify.
+       * c-ppoutput.c (print_line, pp_dir_change): Likewise.
+       * c-typeck.c (free_all_tagged_tu_seen_up_to): Likewise.
+       * cfg.c (bb_copy_original_hash, bb_copy_original_eq): Likewise.
+       * cfgloop.c (loop_exit_hash, loop_exit_eq): Likewise.
+       * ddg.c (compare_sccs): Likewise.
+       * df-scan.c (df_ref_compare, df_mw_compare): Likewise.
+       * dfp.c (decimal_real_from_string, decimal_to_decnumber,
+       decimal_to_binary, decimal_do_compare, decimal_real_to_decimal,
+       decimal_do_fix_trunc, decimal_real_to_integer,
+       decimal_real_to_integer2, decimal_real_maxval): Likewise.
+       * dse.c (const_group_info_t): New.
+       (invariant_group_base_eq, invariant_group_base_hash): Constify.
+       * dwarf2out.c (const_dw_die_ref): New.
+       (decl_die_table_hash, decl_die_table_eq, file_info_cmp): Constify.
+       * tree-browser.c (TB_parent_eq): Likewise.
+       * unwind-dw2-fde.c (__register_frame_info_bases,
+       __deregister_frame_info_bases, fde_unencoded_compare, fde_split,
+       add_fdes, linear_search_fdes, binary_search_unencoded_fdes):
+       Likewise.
+       * unwind-dw2-fde.h (get_cie, next_fde): Likewise.
+       * unwind-dw2.c (uw_frame_state_for): Likewise.
+       * value-prof.c (histogram_hash, histogram_eq): Likewise.
+       * value-prof.h (const_histogram_value): New.
+
+2007-07-25  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (machine_function): Add
+       initialized_mips16_gp_pseudo_p.
+       (mips16_gp_pseudo_reg): Do not emit the initialization of
+       mips16_gp_pseudo_rtx when being called from the gimple cost-
+       calculation routines; emit it on the first use outside those
+       routines.
+
+2007-07-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * coretypes.h (const_bitmap, const_rtx, const_rtvec, const_tree):
+       New.
+       
+       * rtl.h (RTL_CHECK1, RTL_CHECK2, RTL_CHECKC1, RTL_CHECKC2,
+       RTVEC_ELT, XWINT, XCWINT, XCMWINT, XCNMPRV, BLOCK_SYMBOL_CHECK,
+       RTL_FLAG_CHECK1, RTL_FLAG_CHECK2, RTL_FLAG_CHECK3,
+       RTL_FLAG_CHECK4, RTL_FLAG_CHECK5, RTL_FLAG_CHECK6,
+       RTL_FLAG_CHECK7, RTL_FLAG_CHECK8, LABEL_KIND, SET_LABEL_KIND):
+       Preserve const-ness of parameters through use of __typeof(),
+       also constify and tidy.
+       
+       * tree.h (TREE_CHECK, TREE_NOT_CHECK, TREE_CHECK2,
+       TREE_NOT_CHECK2, TREE_CHECK3, TREE_NOT_CHECK3, TREE_CHECK4,
+       NON_TREE_CHECK4, TREE_CHECK5, TREE_NOT_CHECK5,
+       CONTAINS_STRUCT_CHECK, TREE_CLASS_CHECK, TREE_RANGE_CHECK,
+       OMP_CLAUSE_SUBCODE_CHECK, OMP_CLAUSE_RANGE_CHECK, EXPR_CHECK,
+       GIMPLE_STMT_CHECK, NON_TYPE_CHECK, TREE_VEC_ELT_CHECK,
+       PHI_NODE_ELT_CHECK, OMP_CLAUSE_ELT_CHECK, TREE_OPERAND_CHECK,
+       TREE_OPERAND_CHECK_CODE, GIMPLE_STMT_OPERAND_CHECK,
+       TREE_RTL_OPERAND_CHECK, TREE_CHAIN, TREE_TYPE): Likewise.
+
+2007-07-25  Julian Brown  <julian@codesourcery.com>
+           Mark Shinwell  <shinwell@codesourcery.com>
+
+       * config/alpha/alpha.c (alpha_mangle_fundamental_type): Rename to...
+       (alpha_mangle_type): This.
+       (TARGET_MANGLE_FUNDAMENTAL_TYPE): Don't define.
+       (TARGET_MANGLE_TYPE): Define this instead.
+       * config/arm/arm-protos.h (arm_mangle_type): Add prototype.
+       * config/arm/arm.c (TARGET_MANGLE_TYPE): Define target hook.
+       (arm_init_neon_builtins): Fix comment.
+       (arm_mangle_map_entry): New.
+       (arm_mangle_map): New.
+       (arm_mangle_type): New.
+       * config/i386/i386.c (ix86_mangle_fundamental_type): Rename to...
+       (ix86_mangle_type): This. Use TYPE_MAIN_VARIANT and restrict
+       mangled types to VOID_TYPE, BOOLEAN_TYPE, INTEGER_TYPE, REAL_TYPE.
+       (TARGET_MANGLE_FUNDAMENTAL_TYPE): Don't define.
+       (TARGET_MANGLE_TYPE): Define this instead.
+       * config/ia64/ia64.c (ia64_mangle_fundamental_type): Rename to...
+       (ia64_mangle_type): This. Use TYPE_MAIN_VARIANT  and restrict
+       mangled types to VOID_TYPE, BOOLEAN_TYPE, INTEGER_TYPE, REAL_TYPE.
+       (TARGET_MANGLE_FUNDAMENTAL_TYPE): Don't define.
+       (TARGET_MANGLE_TYPE): Define this instead.
+       * config/rs6000/rs6000.c (rs6000_mangle_fundamental_type): Rename
+       to...
+       (rs6000_mangle_type): This. Use TYPE_MAIN_VARIANT.
+       (TARGET_MANGLE_FUNDAMENTAL_TYPE): Don't define.
+       (TARGET_MANGLE_TYPE): Define this instead.
+       * config/s390/s390.c (s390_mangle_fundamental_type): Rename to...
+       (s390_mangle_type): This.
+       (TARGET_MANGLE_FUNDAMENTAL_TYPE): Don't define.
+       (TARGET_MANGLE_TYPE): Define this instead.
+       * config/sparc/sparc.c (sparc_mangle_fundamental_type): Rename to...
+       (sparc_mangle_type): This.
+       (TARGET_MANGLE_FUNDAMENTAL_TYPE): Don't define.
+       (TARGET_MANGLE_TYPE): Define this instead.
+       * cp/mangle.c (write_type): Call mangle_type target hook on all
+       types before mangling.  Use original type, not main variant, as
+       argument.
+       * target-def.h (TARGET_MANGLE_FUNDAMENTAL_TYPE): Rename hook to...
+       (TARGET_MANGLE_TYPE): This.
+       * target.h (gcc_target): Rename mangle_fundamental_type to
+       mangle_type.
+       * doc/tm.texi (TARGET_MANGLE_FUNDAMENTAL_TYPE): Rename section to...
+       (TARGET_MANGLE_TYPE): This. Note slightly different semantics.
+
+2007-07-25  Julian Brown  <julian@codesourcery.com>
+           Paul Brook  <paul@codesourcery.com>
+           Joseph Myers  <joseph@codesourcery.com>
+           Mark Shinwell  <shinwell@codesourcery.com>
+
+       * Makefile.in (TEXI_GCC_FILES): Add arm-neon-intrinsics.texi.
+       * config.gcc (arm*-*-*): Add arm_neon.h to extra headers.
+       (with_fpu): Allow --with-fpu=neon.
+       * config/arm/aof.h (ADDITIONAL_REGISTER_NAMES): Add Q0-Q15.
+       * config/arm/aout.h (ADDITIONAL_REGISTER_NAMES): Add Q0-Q15.
+       * config/arm/arm-modes.def (EI, OI, CI, XI): New modes.
+       * config/arm/arm-protos.h (neon_immediate_valid_for_move)
+       (neon_immediate_valid_for_logic, neon_output_logic_immediate)
+       (neon_pairwise_reduce, neon_expand_vector_init, neon_reinterpret)
+       (neon_emit_pair_result_insn, neon_disambiguate_copy)
+       (neon_vector_mem_operand, neon_struct_mem_operand, output_move_quad)
+       (output_move_neon): Add prototypes.
+       * config/arm/arm.c (FL_NEON): New flag for NEON processor capability.
+       (all_fpus): Add FPUTYPE_NEON.
+       (fp_model_for_fpu): Add NEON field.
+       (arm_return_in_memory): Return vectors <= 16 bytes in ARM registers.
+       (arm_arg_partial_bytes): Allow NEON vectors to be passed partially
+       in registers.
+       (arm_legitimate_address_p): Don't support fancy addressing for NEON
+       structure moves.
+       (thumb2_legitimate_address_p): Likewise.
+       (neon_valid_immediate): Recognize and prepare constants suitable for
+       NEON instructions.
+       (neon_immediate_valid_for_move): New function. Recognize and prepare
+       immediates for NEON move instructions.
+       (neon_immediate_valid_for_logic): New function. Recognize and
+       prepare immediates for NEON logic instructions.
+       (neon_output_logic_immediate): New function. Create asm string
+       suitable for outputting immediate logic instructions.
+       (neon_pairwise_reduce): New function. Implement reduction using
+       pairwise operations.
+       (neon_expand_vector_init): New function. Expand a (possibly
+       non-constant) vector initialization.
+       (neon_vector_mem_operand): New function. Memory operands supported
+       for quad-word loads/stores to/from ARM or NEON registers. Don't
+       allow base+offset addressing for core regs.
+       (neon_struct_mem_operand): New function. Valid mems for NEON
+       structure moves.
+       (coproc_secondary_reload_class): Enable NEON registers to be loaded
+       from neon_vector_mem_operand addresses without a secondary register.
+       (add_minipool_forward_ref): Handle >8-byte minipool entries.
+       (add_minipool_backward_ref): Likewise.
+       (dump_minipool): Likewise.
+       (push_minipool_fix): Likewise.
+       (output_move_quad): New function. Output quad-word moves, loads and
+       stores using ARM registers.
+       (output_move_vfp): Add support for vectors in VFP (NEON) D
+       registers.
+       (output_move_neon): Output a NEON load/store to/from a quadword
+       register.
+       (arm_print_operand): Implement new codes:
+       - 'c' for unadorned integers (without a # sign).
+       - 'J', 'K' for reg+2/reg+3, reg+3/reg+2 in little/big-endian
+       mode.
+       - 'e', 'f' for the low and high D parts of a NEON Q register.
+       - 'q' outputs a NEON Q register.
+       - 'h' outputs ranges of D registers for VLDM/VSTM etc.
+       - 'T' prints NEON opcode features from a coded bitmask.
+       - 'F' is similar to T, but signed/unsigned codes both print as
+       'i'.
+       - 't' is similar to T, but 'u' is printed instead of 'p'.
+       - 'O' prints 'r' if NEON instruction should perform rounding (as
+       specified by bitmask), else prints nothing.
+       - '#' is a punctuation character to stop operand numbers from
+       running together with following digits in the assembler
+       strings for instructions (when using mode attributes).
+       (arm_assemble_integer): Handle extra NEON vector modes. Permute
+       constant vectors in big-endian mode, where necessary.
+       (arm_hard_regno_mode_ok): Allow vectors in VFP/NEON registers.
+       Handle EI, OI, CI, XI modes.
+       (ashlv4hi3, ashlv2si3, lshrv4hi3, lshrv2si3, ashrv4hi3)
+       (ashrv2si3): Rename IWMMXT2_BUILTINs to...
+       (ashlv4hi3_iwmmxt, ashlv2si3_iwmmxt, lshrv4hi3_iwmmxt)
+       (lshrv2si3_iwmmxt, ashrv4hi3_iwmmxt, ashrv2si3_iwmmxt): New names.
+       (neon_builtin_type_bits): Add enumeration, one bit for each vector
+       type.
+       (v8qi_UP, v4hi_UP, v2si_UP, v2sf_UP, di_UP, v16qi_UP, v8hi_UP)
+       (v4si_UP, v4sf_UP, v2di_UP, ti_UP, ei_UP, oi_UP, UP): Define macros
+       to turn v8qi, etc. into bits defined above.
+       (neon_itype): New enumeration. Classifications of NEON builtins.
+       (neon_builtin_datum): Define struct. Contains information about
+       a single builtin (with multiple modes).
+       (CF): Define helper macro for...
+       (VAR1...VAR10): Define builtins with a type, name and 1-10 different
+       modes.
+       (neon_builtin_data): New array. Define information about builtins
+       for use during initialization/expansion.
+       (arm_init_neon_builtins): New function.
+       (arm_init_builtins): Call arm_init_neon_builtins if TARGET_NEON is
+       true.
+       (neon_builtin_compare): New function.
+       (locate_neon_builtin_icode): New function. Find an insn code for a
+       builtin given a function code for that builtin. Also return type of
+       builtin (NEON_BINOP, NEON_UNOP etc.).
+       (builtin_arg): New enumeration. Types of arguments for builtins.
+       (arm_expand_neon_args): New function. Expand a generic NEON builtin.
+       Takes a variable argument list of builtin_arg types, terminated by
+       NEON_ARG_STOP.
+       (arm_expand_neon_builtin): New function. Expand a NEON builtin.
+       (neon_reinterpret): New function. Expand NEON reinterpret intrinsic.
+       (neon_emit_pair_result_insn): New function. Support returning pairs
+       of vectors via a pointer.
+       (neon_disambiguate_copy): New function. Set up operands for a
+       multi-word copy such that registers do not get clobbered.
+       (arm_expand_builtin): Call arm_expand_neon_builtin if fcode >=
+       ARM_BUILTIN_NEON_BASE.
+       (arm_file_start): Set float-abi attribute for NEON.
+       (arm_vector_mode_supported_p): Enable NEON vector modes.
+       (arm_mangle_map_entry): New.
+       (arm_mangle_map): New.
+       (arm_mangle_vector_type): New.
+       * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Define __ARM_NEON__
+       when appropriate.
+       (TARGET_NEON): New macro. Target supports NEON.
+       (fputype): Add FPUTYPE_NEON.
+       (UNITS_PER_SIMD_WORD): Define. Allow quad-word registers to be used
+       for vectorization based on command-line arg.
+       (NEON_REGNO_OK_FOR_NREGS): Define.
+       (VALID_NEON_DREG_MODE, VALID_NEON_QREG_MODE)
+       (VALID_NEON_STRUCT_MODE): Define.
+       (PRINT_OPERAND_PUNCT_VALID_P): '#' is valid punctuation.
+       (arm_builtins): Add ARM_BUILTIN_NEON_BASE.
+       * config/arm/arm.md (VUNSPEC_POOL_16): Insert constant for unspec.
+       (consttable_16): Add pattern for outputting 16-byte minipool
+       entries.
+       (movv2si, movv4hi, movv8qi): Remove blank expanders (redefined in
+       vec-common.md).
+       (vec-common.md, neon.md): Include md files.
+       * config/arm/arm.opt (mvectorize-with-neon-quad): Add option.
+       * config/arm/constraints.md (constraint "Dn", "Dl", "DL"): Define.
+       (memory_constraint "Ut", "Un", "Us"): Define.
+       * config/arm/iwmmxt.md (VMMX, VSHFT): New mode macros.
+       (MMX_char): New mode attribute.
+       (addv8qi3, addv4hi3, addv2si3): Remove. Replace with...
+       (*add<mode>3_iwmmxt): New insn pattern.
+       (subv8qi3, subv4hi3, subv2si3): Remove. Replace with...
+       (*sub<mode>3_iwmmxt): New insn pattern.
+       (mulv4hi3): Rename to...
+       (*mulv4hi3_iwmmxt): This.
+       (smaxv8qi3, smaxv4hi3, smaxv2si3, umaxv8qi3, umaxv4hi3)
+       (umaxv2si3, sminv8qi3, sminv4hi3, sminv2si3, uminv8qi3)
+       (uminv4hi3, uminv2si3): Remove. Replace with...
+       (*smax<mode>3_iwmmxt, *umax<mode>3_iwmmxt, *smin<mode>3_iwmmxt)
+       (*umin<mode>3_iwmmxt): These.
+       (ashrv4hi3, ashrv2si3, ashrdi3_iwmmxt): Replace with...
+       (ashr<mode>3_iwmmxt): This new pattern.
+       (lshrv4hi3, lshrv2si3, lshrdi3_iwmmxt): Replace with...
+       (lshr<mode>3_iwmmxt): This new pattern.
+       (ashlv4hi3, ashlv2si3, ashldi3_iwmmxt): Replace with...
+       (ashl<mode>3_iwmmxt): This new pattern.
+       * config/arm/neon-docgen.ml: New file. Generate documentation for
+       intrinsics.
+       * config/arm/neon-gen.ml: New file. Generate arm_neon.h header.
+       * config/arm/arm_neon.h: New (autogenerated).
+       * config/arm/neon-testgen.ml: New file. Generate NEON tests
+       automatically.
+       * config/arm/neon.md: New file. Define NEON instructions.
+       * config/arm/neon.ml: New file. Abstract description of NEON
+       instructions, used to generate arm_neon.h header, documentation and
+       tests.
+       * config/arm/t-arm (MD_INCLUDES): Add vec-common.md, neon.md.
+       * vec-common.md: New file. Shared parts for iWMMXt and NEON vector
+       support.
+       * doc/extend.texi (ARM Built-in Functions): Rename and remove
+       extraneous comma.
+       (ARM NEON Intrinsics): New subsection.
+       * doc/arm-neon-intrinsics.texi: New (autogenerated).
+
+2007-07-25  Danny Smith   <dannysmith@users.sourceforge.net>
+
+       * config/i386/i386-protos.h (i386_pe_asm_file_end): Remove
+       prototype.
+
+2007-07-24  Jan Hubicka  <jh@suse.cz>
+
+       * regclass.c (move_table): New type.
+       (move_cost, may_move_in_cost, may_move_out_cost): Use it.
+       (init_move_cost): Break out from ...
+       (init_reg_sets_1): ... here; simplify computation of
+       have_regs-of_mode and contains_reg_of_mode.
+       (record_reg_classes): Unswitch internal loops.
+       (copy_cost): Trigger lazy initialization of move cost
+       (record_address_regs): Likewise.
+
+2007-07-24  Daniel Berlin  <dberlin@dberlin.org>
+
+       * config/darwin.c (darwin_override_options): Don't force on
+       flag_var_tracking_uninit when no debug info is requested.
+
+2007-07-25  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * cfgloop.c (init_loops_structure): New function.
+       (flow_loops_find): Create root of the loop tree unconditionally.
+
+2007-07-24  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * tree-ssa-ccp.c (fold_const_aggregate_ref): Use fold_convert.
+
+2007-07-24  Jan Hubicka  <jh@suse.cz>
+
+       * caller-save.c: Include ggc.h, gt-caller-save.h
+       (reg_save_code, reg_restore_code): Rename to ...
+       (cached_reg_save_code, cached_reg_restore_code): ... those.
+       (savepat, restpat, test_reg, test_mem, saveinsn, restinsn): New.
+       (reg_save_code, reg_restore_code): New functions.
+       (init_caller_save): Do not intialize
+       reg_save_code/reg_restore_code tables.
+       * Makefile.in: (gt-caller-save.h): New.
+
+2007-07-24  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * tree-ssa-ifcombine.c (ifcombine_ifandif): Use a ONE operand
+       with the mode of the original operand instead of
+       integer_one_node.
+
+2007-07-23  Jan Hubicka  <jH@suse.cz>
+
+       * config/i386/i386.c (ix86_secondary_memory_needed): Break out to...
+       (inline_secondary_memory_needed): ... here.
+       (ix86_memory_move_cost): Break out to ...
+       (inline_memory_move_cost): ... here; add support for IN value of 2 for
+       maximum of input and output; fix handling of Q_REGS on 64bit.
+       (ix86_secondary_memory_needed): Microoptimize.
+
+2007-07-23  Sebastian Pop  <sebpop@gmail.com>
+
+       * tree-data-ref.c (find_vertex_for_stmt, create_rdg_edge_for_ddr,
+       create_rdg_edges_for_scalar, create_rdg_edges, create_rdg_vertices,
+       stmts_from_loop, known_dependences_p, build_rdg): New.
+       * tree-data-ref.h: Depends on graphds.h.
+       (rdg_vertex, RDGV_STMT, rdg_dep_type, rdg_edge, RDGE_TYPE): New.
+       (build_rdg): Declared.
+       * Makefile.in (TREE_DATA_REF_H): Depends on graphds.h.
+
+2007-07-23  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-propagate.c (valid_gimple_expression_p): Match up with
+       ccp_min_invariant.
+
+2007-07-23  Peter Bergner  <bergner@vnet.ibm.com>
+           Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/PR28690
+       * optabs.c (expand_binop): (emit_cmp_and_jump_insns): Allow
+       EQ compares.
+       * rtlanal.c (commutative_operand_precedence): Prefer both REG_POINTER
+       and MEM_POINTER operands over REG and MEM operands.
+       (swap_commutative_operands_p): Change return value to bool.
+       * rtl.h: Update the corresponding prototype.
+       * tree-ssa-address.c (gen_addr_rtx): Use simplify_gen_binary
+       instead of gen_rtx_PLUS.
+       * simplify-rtx.c (simplify_plus_minus_op_data_cmp): Change return
+       value to bool.  Change function arguments to rtx's and update code
+       to match.
+       (simplify_plus_minus): Update the simplify_plus_minus_op_data_cmp
+       calls to match the new declaration.
+       * simplify-rtx.c (simplify_associative_operation): Don't
+       reorder simplify_binary_operation arguments.
+
+2007-07-23  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (override_options): Use mips_costs to derive
+       the default branch cost.
+       * config/mips/mips.h (BRANCH_COST): Use mips_branch_cost rather
+       than mips_costs.
+       * config/mips/mips.opt (mbranch-cost=): New option.
+       * doc/invoke.texi (-mbranch-cost): Document new MIPS option.
+
+2007-07-23  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.h (GR_REG_CLASS_P, COP_REG_CLASS_P): Delete.
+       (SECONDARY_MEMORY_NEEDED): Delete commented-out definition.
+       * config/mips/mips.c (mips_register_move_cost): Use reg_class_subset_p
+       instead of GR_REG_CLASS_P and COP_REG_CLASS_P.
+
+2007-07-23  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/constraints.md (ks): New constraint.
+       * config/mips/mips.md (*add<mode>3_sp1, *add<mode>3_sp2): Fold into...
+       (*add<mode>3_mips16): ...here.
+
+2007-07-21  Uros Bizjak  <ubizjak@gmail.com>
+
+       * optabs.h (enum optab_index): Add new OTI_signbit.
+       (signbit_optab): Define corresponding macro.
+       (enum insn_code signbit_optab[]): Remove array.
+       * optabs.c (init_optabs): Initialize signbit_optab using init_optab.
+       (expand_copysign_absneg): If back end provides signbit insn, use it
+       instead of bit operations on floating point argument.
+       * builtins.c (enum insn_code signbit_optab[]): Remove array.
+       (expand_builtin_signbit): Check signbit_optab->handlers[].insn_code
+       for availability of signbit insn.
+
+       * config/i386/i386.md (signbit<mode>2): New insn pattern to implement
+       signbitf, signbit and signbitl built-ins as inline x87 intrinsics when
+       SSE mode is not active.
+       (isinf<mode>2): Disable for mfpmath=sse,387.
+
+2007-07-22  Ben Elliston  <bje@au.ibm.com>
+
+       * regclass.c (invalid_mode_change_p): Attach ATTRIBUTE_UNUSED to
+       `class' parameter.
+       * struct-equiv.c (note_local_live): Likewise for `y_regno'.
+
+2007-07-20  Richard Guenther  <rguenther@suse.de>
+
+       * tree-cfg.c (verify_expr): COND_EXPRs can have any
+       integral typed condition.
+       * tree-ssa.c (useless_type_conversion_p): Do not preserve
+       booleanness.  Only preserve conversions from a non-base
+       type to a base type, not in general between types with
+       different TYPE_MIN_VALUE or TYPE_MAX_VALUE.
+       * tree.def (COND_EXPR): Document that the condition
+       can be of any integral type.
+
+2007-07-20  Nigel Stephens  <nigel@mips.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.h (mips_dwarf_regno): Declare.
+       (DBX_REGISTER_NUMBER): Remove redundant brackets.
+       (HI_REGNUM, LO_REGNUM): Define in an endian-dependent way.
+       (AC1HI_REGNUM, AC1LO_REGNUM, AC2HI_REGNUM, AC2LO_REGNUM)
+       (AC3HI_REGNUM, AC3LO_REGNUM, ACC_HI_REG_P): Delete.
+       (reg_class): Rename HI_REG to MD0_REG and LO_REG to MD1_REG.
+       (REG_CLASS_NAMES): Update accordingly.
+       * config/mips/mips.c (mips_dwarf_regno): New array.
+       (mips_regno_to_class): Rename HI_REG to MD0_REG and LO_REG to MD1_REG.
+       (mips_subword): Remove special handling for accumulator registers.
+       (override_options): Initiailize mips_dwarf_regno.  Remove use
+       of ACC_HI_REG_P.
+       (mips_swap_registers): New function.
+       (mips_conditional_register_usage): Swap accumulator registers
+       around if TARGET_LITTLE_ENDIAN.
+       (mips_cannot_change_mode_class): Remove special treatment of ACC_REGS.
+       * config/mips/constraints.md (h, l): Use the endianness to choose
+       between MD0_REG and MD1_REG.
+       * config/mips/mips.md (*mfhilo_<mode>_macc): Use a fixed-string,
+       alternative-dependent template.
+
+2007-07-20  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/arm/arm.md (movsi): Use can_create_pseudo_p instead of
+       no_new_pseudos.
+
+2007-07-20  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * function.c (thread_prologue_and_epilogue_insns): Fix exit
+       predecessor fallthru flags.
+
+2007-07-20  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-niter.c (assert_loop_rolls_lt): Convert the operands
+       of compare to the same type.
+       * cfgloopmanip.c (add_loop): Update information about loop exits.
+       (loop_version): Remove the innermost loop requirement.
+       * tree-ssa-loop-manip.c (determine_exit_conditions): Convert bounds
+       to sizetype for pointers.
+
+2007-07-18  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * Makefile.in (D32PBIT_FUNCS): Add _sd_to_tf and _tf_to_sd.
+       (D64PBIT_FUNCS): Add _dd_to_tf and _tf_to_dd.
+       (D128PBIT_FUNCS): Add _td_to_tf and _tf_to_td.
+
+       * config/dfp-bit.c: Empty for TFmode conversions.
+
+2007-07-18  Caroline Tice  <ctice@apple.com>
+       
+       * var-tracking.c (find_src_status): Check for  COND_EXEC insns
+       and handle them correctly; check that src is not NULL before
+       trying to use it.
+       (find_src_set_src): Likewise.
+       
+2007-07-18  Bob Wilson  <bob.wilson@acm.org>
+       
+       * config/xtensa/xtensa.c (xtensa_expand_mask_and_shift): New.
+       (struct alignment_context, init_alignment_context): New.
+       (xtensa_expand_compare_and_swap, xtensa_expand_atomic): New.
+       * config/xtensa/xtensa.h (XCHAL_HAVE_RELEASE_SYNC): Add default.
+       (XCHAL_HAVE_S32C1I): Likewise.
+       (TARGET_RELEASE_SYNC, TARGET_S32C1I): New.
+       * config/xtensa/xtensa.md (UNSPECV_MEMW): New constant.
+       (UNSPECV_S32RI, UNSPECV_S32C1I): Likewise.
+       (ATOMIC, HQI): New macros.
+       (memory_barrier, *memory_barrier): New.
+       (sync_lock_releasesi): New.
+       (sync_compare_and_swapsi, sync_compare_and_swap<mode>): New.
+       (sync_lock_test_and_set<mode>): New.
+       (sync_<atomic><mode>): New.
+       (sync_old_<atomic><mode>, sync_new_<atomic><mode>): New.
+       * config/xtensa/xtensa-protos.h (xtensa_expand_compare_and_swap): New.
+       (xtensa_expand_atomic): New.
+       
+2007-07-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR target/30652
+
+       * builtins.c (expand_builtin_interclass_mathfn): Provide a generic
+       transformation for builtin ISNORMAL.
+       (expand_builtin): Handle BUILT_IN_ISNORMAL.
+       * builtins.def (BUILT_IN_ISNORMAL): New.
+       * doc/extend.texi: Document isnormal.
+
+2007-07-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR target/30652
+
+       * builtins.c (expand_builtin_interclass_mathfn): Allow for missing
+       optabs infrastructure.  Provide generic implementation for
+       FINITE/ISFINITE.
+       (expand_builtin): Handle FINITE/ISFINITE.
+       (fold_builtin_classify): Make ISFINITE canonical instead of FINITE.
+       (fold_builtin_1): Likewise.
+
+       * builtins.def (BUILT_IN_ISFINITE): New.
+
+       * doc/extend.texi: Document isfinite.
+
+2007-07-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR target/30652
+       PR middle-end/20558
+
+       * builtins.c (expand_builtin_interclass_mathfn): Provide a
+       generic fallback for isinf.
+       * c-cppbuiltin.c (builtin_define_float_constants): Move FP max
+       calculation code ...
+       * real.c (get_max_float): ... to here.
+       * real.h (get_max_float): New.
+
+2007-07-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR middle-end/32668
+
+       * builtin-attrs.def (ATTR_TYPEGENERIC,
+       ATTR_CONST_NOTHROW_TYPEGENERIC): New.
+
+       * builtins.def (BUILT_IN_ISINF, BUILT_IN_ISNAN,
+       BUILT_IN_ISGREATER, BUILT_IN_ISGREATEREQUAL, BUILT_IN_ISLESS,
+       BUILT_IN_ISLESSEQUAL, BUILT_IN_ISLESSGREATER,
+       BUILT_IN_ISUNORDERED): Use ATTR_CONST_NOTHROW_TYPEGENERIC.
+
+       * c-common.c (handle_type_generic_attribute): New.
+       (c_common_attribute_table): Add "type generic".
+
+       * c-typeck.c (convert_arguments): Handle "type generic" functions.
+
+2007-07-18  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-sccvn.c (try_to_simplify): Use valid_gimple_expression
+       * tree-ssa-propagate (valid_gimple_expression): Handle ADDR_EXPR
+       properly.
+
+2007-07-18  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/32808
+       * config/cris/cris.c (cris_print_index): Don't use XEXP before
+       checking that the operand is an expression.
+
+2007-07-19  Christoph von Wittich  <Christoph_vW@reactos.org>
+           Danny Smith  <dannysmith@users.sourceforge.net>
+
+       PR/other 30335
+       * config/i386/host-mingw32.c (mingw32_gt_pch_use_address): Put
+       file mapping object in local namespace if Windows version later
+       than NT4
+
+2007-07-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/arm/arm-protos.h (arm_cannot_force_const_mem): Declare.
+       * config/arm/arm.c (TARGET_CANNOT_FORCE_CONST_MEM): Redefine to
+       arm_cannot_force_const_mem.
+       (arm_cannot_force_const_mem): New function.
+       * config/arm/arm.h (ARM_OFFSETS_MUST_BE_WITHIN_SECTIONS_P): New macro.
+       (LEGITIMATE_CONSTANT_P): Test arm_cannot_force_const_mem instead
+       of arm_tls_referenced_p.
+       * config/arm/arm.md (movsi): Split out-of-section constants when
+       ARM_OFFSETS_MUST_BE_WITHIN_SECTIONS_P.
+       * config/arm/vxworks.h (ARM_OFFSETS_MUST_BE_WITHIN_SECTIONS_P): Define.
+
+2007-07-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.md (clear_cache): Treat the size argument as Pmode.
+
+2007-07-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.md (*extendqihi2): Convert the destination
+       to SImode.
+
+2007-07-17  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * config/pa/fptr.c: Update license header.
+       * config/pa/milli64.S: Likewise.
+
+2007-07-17  Nick Clifton  <nickc@redhat.com>
+
+       * COPYING_v3: New file.  Contains version 3 of the GNU General
+       Public License.
+       * COPYING.LIB_v3: New file.  Contains version 3 of the GNU
+       Lesser General Public License.
+       * doc/include/gpl_v3.texi: New file.  Contains version 3 of
+       the GNU General Public License.
+
+2007-07-17  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR rtl-optimization/32773
+       * cfglayout.c (force_one_exit_fallthru): New function.
+       (cfg_layout_finalize): Use it.
+
+2007-07-16  Richard Guenther  <rguenther@suse.de>
+           Uros Bizjak  <ubizjak@gmail.com>
+
+       * tree-if-conv.c (find_phi_replacement_condition): Unshare "*cond"
+       before forcing it to gimple operand.
+
+2007-07-16  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+
+       * config/mips/mips.h (TUNE_24K): Define.
+       (TUNE_MACC_CHAINS): Add TUNE_24K.
+       * config/mips/mips.md: (*mul_acc_si, *mul_sub_si): Change type to
+       imadd.
+       * config/mips/74k.md (r74k_int_mult): Split madd/msub to ..
+       (r74k_int_madd): .. this new reservation.
+       (define_bypass): Fixed bypasses for r74k_int_madd to use
+       mips_linked_madd_p.
+       * config/mips/24k.md (define_bypass): Define new
+       r24k_int_mul3->r24k_int_madd bypass using mips_linked_madd_p.
+
+2007-07-16  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/mips.md: Include 20kc.md.
+       * config/mips/20kc.md: New file.
+       * config/mips/mips.c (mips_rtx_cost_data): Fill in 20Kc costs.
+       (mips_adjust_cost): Tweak for 20Kc.
+       (mips_issue_rate): Likewise.
+       * config/mips/mips.h (TUNE_20KC): Define.
+
+2007-07-16  David Edelsohn  <edelsohn@gnu.og>
+
+       * config/rs6000/rs6000.c (struct processor_cost): Add
+       cache_line_size, l1_cache_lines, and simultaneous_prefetches
+       fields.
+       (*_cost): Add cache information.
+       (rs6000_override_options): Set cache parameters.
+
+2007-07-16  Rainer Orth  <ro@TechFak.Uni-Bielefeld.DE>
+
+       PR bootstrap/3456
+       * config.gcc (mips-sgi-irix[56]*): Enable pthread support.
+       * doc/install.texi (mips-sgi-irix6): pthread support works now.
+
+2007-07-16  Paul Brook  <paul@codesourcery.com>
+
+       PR target/32753
+       * config/arm/cirrus.md (cirrus_arm_movsi_insn): Remove dead insn.
+       (cirrus_thumb2_movsi_insn): Ditto.
+
+2007-07-15  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/rs6000/darwin-fallback.c (interpret_libc): Change
+       CR2_REGNO to R_CR2.
+
+2007-07-15  Andrew Haley  <aph@redhat.com>
+
+       * unwind-sjlj.c (_Unwind_GetIPInfo): Check for context->fc != NULL
+       before looking in the context.
+
+2007-07-15  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR middle-end/32398
+       PR middle-end/32769
+       * pa-protos.h (pa_eh_return_handler_rtx): Declare.
+       * pa.c (pa_extra_live_on_entry, rp_saved): Declare.
+       (TARGET_EXTRA_LIVE_ON_ENTRY): Define.
+       (pa_output_function_prologue): Use rp_saved and
+       current_function_is_leaf to generate .CALLINFO statement.
+       (hppa_expand_prologue): Set rp_saved.
+       (hppa_expand_epilogue): Use rp_saved.
+       (pa_extra_live_on_entry, pa_eh_return_handler_rtx): New functions.
+       * pa.h (EH_RETURN_HANDLER_RTX): Use pa_eh_return_handler_rtx.
+
+2007-07-14  Dirk Mueller  <dmueller@suse.de>
+
+       * omega.c (coalesce): Fix memory leak on early exit.
+       * matrix-reorg.c (check_allocation_function): Likewise.
+       * tree-vect-transform.c (vect_get_new_vect_var): free result
+       of concat().
+       * bb-reorder.c (find_rarely_executed_basic_blocks_and_crossing_edges):
+       pass pointer to edge vector
+       (partition_hot_cold_basic_blocks): Fix memory leak.
+       * collect2.c (prefix_from_string): Free temporary storage.
+       * reload1.c (fixup_abnormal_edges): Free sbitmap.
+
+2007-07-14  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.h (DO_GLOBAL_CTORS_BODY): Add void to prototype.
+       (DO_GLOBAL_DTORS_BODY): Likewise.
+
+2007-07-14  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/mips.c (mips_classify_symbol): Don't return
+       SYMBOL_SMALL_DATA for constant pool addresses if
+       TARGET_EMBEDDED_DATA is true.
+
+2007-07-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (init_mmx_sse_builtins): Define all builtins
+       except __builtin_ia32_emms, __builtin_ia32_ldmxcsr,
+       __builtin_ia32_stmxcsr, __builtin_ia32_maskmovq, __builtin_ia32_loadups,
+       __builtin_ia32_storeups, __builtin_ia32_loadhps, __builtin_ia32_loadlps,
+       __builtin_ia32_storehps, __builtin_ia32_storelps,
+       __builtin_ia32_movntps, __builtin_ia32_movntq, __builtin_ia32_sfence,
+       __builtin_ia32_femms, __builtin_ia32_maskmovdqu, __builtin_ia32_loadupd,
+       __builtin_ia32_storeupd, __builtin_ia32_loadhpd, __builtin_ia32_loadlpd,
+       __builtin_ia32_movnti, __builtin_ia32_movntpd, __builtin_ia32_movntdq,
+       __builtin_ia32_clflush, __builtin_ia32_lfence, __builtin_ia32_mfence,
+       __builtin_ia32_loaddqu, __builtin_ia32_storedqu, __builtin_ia32_monitor,
+       __builtin_ia32_mwait, __builtin_ia32_lddqu, __builtin_ia32_movntdqa,
+       __builtin_ia32_movntsd and __builtin_ia32_movntss as const builtins
+       using def_builtin_const.
+
+2007-07-14  Eric Botcazou  <ebotcazou@adacore.com>
+
+       PR tree-optimization/32705
+       * tree-ssa-sccvn.c (set_ssa_val_to): Accept VN_TOP as value number.
+       (simplify_binary_expression): Use SSA_VAL consistently.
+
+2007-07-13  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/spe.md (SPE_ACC_REGNO): Delete definition.
+       (SPEFSCR_REGNO): Delete definition.
+       * config/rs6000/rs6000.c: LINK_REGISTER_REGNUM -> LR_REGNO.
+       COUNT_REGISTER_REGNUM -> CTR_REGNO.
+       * config/rs6000/rs6000.h: Do not define *_REGNO.
+       LINK_REGISTER_REGNUM -> LR_REGNO.
+       COUNT_REGISTER_REGNUM -> CTR_REGNO.
+       * config/rs6000/predicates.md: LINK_REGISTER_REGNUM ->  LR_REGNO.
+       COUNT_REGISTER_REGNUM -> CTR_REGNO.
+       * config/rs6000/linux-unwind.h: Define R_LR, R_CR2, R_VR0,
+       R_VRSAVE, R_VSCR. Use them.
+       * config/rs6000/darwin-fallback.c: Define R_LR, R_CTR, R_CR2,
+       R_XER, R_VR0, R_VRSAVE, R_VSCR, R_SPEFSCR.  Use them.
+       * config/rs6000/rs6000.md: Define REGNO constants.  Use them.
+       * config/rs6000/aix.h: Define R_LR.  Use it.
+       
+2007-07-13  Caroline Tice  <ctice@apple.com>
+       
+       * toplev.c (process_options): Turn flag_var_tracking_uninit off when
+       flag_var_tracking is explicitly turned off (i.e. when variable
+       tracking is not feasible); otherwise, turn flag_var_tracking on when
+       flag_var_tracking_uninit is on.
+       * rtl.def (VAR_LOCATION): Add a new integer subfield to VAR_LOCATION
+       note definitions, to allow recording of initialization status in the
+       notes.
+       * dwarf2out.c (dwarf_stack_op_name): Add case for DW_OP_GNU_uninit.
+       (add_var_loc_to_decl): Add comparison of NOTE_VAR_LOCATION_STATUS to
+       determine if two note locations are equal.
+       (output_loc_list): Don't output list entries whose start & end labels
+       are the same.
+       (reg_loc_descriptor): Add parameter for initialization status; pass it
+       to other loc descriptor functions.
+       (one_reg_loc_descriptor): Add parameter for initialization status;
+       check its value and add DW_OP_GNU_uninit to returned loc descr if
+       appropriate.
+       (multiple_reg_loc_descriptor): Add parameter for initialization
+       status;
+       pass init status argument to other loc descriptor functions; check
+       value of intialization parameter and add DW_OP_GNU_uninit to returned
+       loc descr if appropriate.
+       (based_loc_descr): Add parameter for initialization status; add new
+       variable for return value; check value of initialization parameter and
+       add DW_OP_GNU_uninit to returned loc descr if appropriate.
+       (concatn_mem_loc_descriptor): Add parameter for initialization status;
+       pass init status argument to other loc descriptor functions; check
+       value of intialization parameter and add DW_OP_GNU_uninit to returned
+       loc descr if appropriate.
+       (mem_loc_descriptor): Likewise.
+       (concat_loc_descriptor): Likewise.
+       (concatn_loc_descriptor): Likewise.
+       (loc_descriptor): Add parameter for initialization status; pass it as
+       argument to other loc descriptor function calls.
+       (loc_descriptor_from_tree_1): Add appropriate initialization status
+       to loc descriptor function calls.
+       (add_location_or_const_value_attribute): Get initialization status
+       from VAR_LOCATION note; add initialization status to loc descriptor
+       function calls.
+       * dwarf2.h (enum dwarf_location_atom): New op, DW_OP_GNU_uninit.
+       * print-rtl.c (print_rtx): When printing a VAR_LOCATION note, if
+       status is uninitialized, add "[uninint]" to output.
+       * common.opt (fvar-tracking-uninit): New option, similar to
+       fvar-tracking, to turn on tracking of uninitialized variables; creates
+       a new global flag, flag_var_tracking_uninit.
+       * rtl.h (NOTE_VAR_LOCATION_STATUS): New macro for accessing new field.
+       (enum var_init_status): New type, for var initialization status field.
+       * var-tracking.c (struct location_chain_def): Two new fields, init,
+       for initialization status, and set_src for the assignment value expr.
+       (unshare_variable): New parameter for initialization status;
+       initialize new init and set_src fields.
+       (var_reg_set): New parameters for initialization status and value;
+       pass them to set_variable_part.
+       (var_mem_set): Likewise.
+       (get_init_value): New function.
+       (var_reg_delete_and_set): New initialization status & value
+       parameters; add call to get_init_value if status is unknown; pass new
+       parameters to clobber_variable_part and var_reg_set.
+       (var_mem_delete_and_set): Likewise.
+       (var_reg_delete): Pass null set_src value to clobber_variable_part.
+       (var_mem_delete): Likewise.
+       (variable_union): Pass status to unshare_variable; initialize new init
+       and set_src fields. If flag_var_tracking_uninit is not set, force
+       status to initialized.
+       (add_stores): Store insn, rather than NEXT_INSN(insn), so it can be
+       used later to get the set_src value.
+       (find_src_status): New function.
+       (find_src_set_src): New function.
+       (compute_bb_dataflow): Pass init status to calls to var_reg_set,
+       var_mem_set, var_reg_delete_and_set and var_mem_delete_and_set; for
+       MO_SET, get set_src value and pass it to var_reg_delete_and_set
+       and var_mem_delete_and_set.
+       (dump_variable): Print out "[uninit]" if appropriate.
+       (set_variable_part): Add new initialization and set_src parameters;
+       pass status to unshare_variable; set node->init and node- >set_src
+       fields and modify slot in hash table appropriately; save the init and
+       set_src values if appropriate and assign to the new node.
+       (clobber_variable_part): New set_src parameter; if two nodes have
+       same variable and same location but different set_src (assignment)
+       values, clobber old node.
+       (delete_variable_part): Pass init status to unshare_variable.
+       (emit_note_insn_var_location): Add initialized var; assign var's init
+       status to new 'initialized'; pass new init status field to calls to
+       gen_rtx_VAR_LOCATION. If flag_var_tracking_uninit is not set, force
+       status to initialized.
+       (emit_notes_in_bb): Pass initialization status to calls to
+       var_reg_set, var_mem_set, var_reg_delete_and_set and
+       var_mem_delete_and_set; for MO_SET, get set_src value and pass it to
+       var_reg_delete_and_set and var_mem_delete_and_set; call
+       emit_notes_for_changes on NEXT_INSN(insn) rather than on insn, to
+       make up for change in add_stores.
+       (vt_add_function_parameters): Add status to calls to
+       set_variable_part.
+       * config/darwin.c (darwin_override_options): Turn on uninitialized
+       tracking automatically, if var_tracking is on and the system is
+       10.5 or higher.
+       
+2007-07-13  Sa Liu  <saliu@de.ibm.com>
+
+       * config.gcc: Add options for arch and tune on SPU.
+       * config/spu/predicates.md: Add constant operands 0 and 1.
+       * config/spu/spu-builtins.def: Add builtins for double precision 
+       floating point comparison: si_dfceq, si_dfcmeq, si_dfcgt, si_dfcmgt, 
+       si_dftsv, spu_cmpeq_13, spu_cmpabseq_1, spu_cmpgt_13, spu_cmpabsgt_1,
+       spu_testsv.
+       * config/spu/spu-c.c: Define __SPU_EDP__ when builtins invoked with 
+       a CELLEDP target.
+       * config/spu/spu-protos.h: Add new function prototypes. 
+       * config/spu/spu.c (spu_override_options): Check options -march and
+       -mtune.
+       (spu_comp_icode): Add comparison code for DFmode and vector mode.
+       (spu_emit_branch_or_set): Use the new code for DFmode and vector 
+       mode comparison.
+       (spu_const_from_int): New.  Create a vector constant from 4 ints.
+       (get_vec_cmp_insn): New.  Get insn index of vector compare instruction.
+       (spu_emit_vector_compare): New.  Emit vector compare.
+       (spu_emit_vector_cond_expr): New.  Emit vector conditional expression.
+       * config/spu/spu.h: Add options -march and -mtune.  Define processor
+       types PROCESSOR_CELL and PROCESSOR_CELLEDP.  Define macro
+       CANONICALIZE_COMPARISON.
+       * config/spu/spu.md: Add new insns for double precision compare
+       and double precision vector compare.  Add vcond and smax/smin patterns
+       to enable DFmode vector conditional expression.
+       * config/spu/spu.opt: Add options -march and -mtune.
+       * config/spu/spu_internals.h: Add builtins for CELLEDP target:
+       si_dfceq, si_dfcmeq, si_dfcgt, si_dfcmgt, si_dftsv.  Add builtin for
+       both CELL and CELLEDP targets: spu_testsv.
+       * config/spu/spu_intrinsics.h: Add flag mnemonics for test special 
+       values.
+
+2007-07-13  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/32721
+       * tree-ssa-ccp.c (maybe_fold_stmt_indirect): Preserve
+       TREE_THIS_VOLATILE on the folded reference.
+       * tree-ssa-operands.c (get_expr_operands): Set has_volatile_ops
+       if the array reference has TREE_THIS_VOLATILE set.
+
+2007-07-13  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR other/32188
+       * doc/libgcc.texi: Update DFP intrinsics for DPD and BID.
+
+2007-07-13  Andreas Schwab  <schwab@suse.de>
+
+       * gengtype-lex.l: Allow declarations to be indented.
+
+2007-07-12  Geoffrey Keating  <geoffk@apple.com>
+
+       * ginclude/tgmath.h: New.
+       * config.gcc: Use GCC's tgmath.h on non-glibc systems.
+       * doc/sourcebuild.texi (Headers): Document use_gcc_tgmath.
+       * configure.ac (STMP_FIXPROTO): Honor use_gcc_tgmath.
+       * configure: Regenerate.
+
+2007-07-13  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/linux-unwind.h (sh_fallback_frame_state): Use
+       correct index when setting register save state for xd
+       registers.
+
+2007-07-13  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.c (mark_use): Remove.
+
+2007-07-12  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/arm.c (thumb1_compute_save_reg_mask): Make sure scratch
+       reg does not overlap return value.
+
+2007-07-12  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-pre.c (get_expression_vuses): Move out side-effect.
+       (set_expression_vuses): Ditto.
+       (init_pre): Initialize expression_vuses.
+
+2007-07-12  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * config/i386/sse.md (storentdf, storentsf): New.
+
+2007-07-12  Geoffrey Keating  <geoffk@apple.com>
+
+       * builtins.c (get_pointer_alignment): Honor DECL_ALIGN on a
+       FUNCTION_DECL.
+       * tree.c (build_decl_stat): Move code from here...
+       (make_node_stat): ... to here.  Don't uselessly clear DECL_USER_ALIGN.
+       (expr_align): Honor DECL_ALIGN on a FUNCTION_DECL.  Add comment
+       about using DECL_ALIGN of LABEL_DECL and CONST_DECL.
+       * tree.h (DECL_USER_ALIGN): Fix misplaced comment.
+       * varasm.c (assemble_start_function): Use DECL_ALIGN instead of
+       FUNCTION_BOUNDARY.
+
+2007-07-12  Dorit Nuzman  <dorit@il.ibm.com>
+           Devang Patel  <dpatel@apple.com>
+
+       PR tree-optimization/25413
+       * targhooks.c (default_builtin_vector_alignment_reachable): New.
+       * targhooks.h (default_builtin_vector_alignment_reachable): New.
+       * tree.h (contains_packed_reference): New.
+       * expr.c (contains_packed_reference): New.
+       * tree-vect-analyze.c (vector_alignment_reachable_p): New.
+       (vect_enhance_data_refs_alignment): Call
+       vector_alignment_reachable_p.
+       * target.h (vector_alignment_reachable): New builtin.
+       * target-def.h (TARGET_VECTOR_ALIGNMENT_REACHABLE): New.
+       * config/rs6000/rs6000.c (rs6000_vector_alignment_reachable): New.
+       (TARGET_VECTOR_ALIGNMENT_REACHABLE): Define.
+
+2007-07-12  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * target.h (builtin_vectorization_cost): Add new target builtin.
+       * target-def.h (TARGET_VECTORIZE_BUILTIN_VECTORIZATION_COST): New.
+       * tree-vectorizer.h (TARG_SCALAR_STMT_COST): New.
+       (TARG_SCALAR_LOAD_COST, TARG_SCALAR_STORE_COST): New.
+       * tree-vect-analyze.c (vect_analyze_slp_instance): Initisliaze
+       uninitialized variables.
+       * tree-vect-transform.c (cost_for_stmt): New function.
+       (vect_estimate_min_profitable_iters): Call cost_for_stmt instead of
+       using cost 1 for all scalar stmts. Be less conservative when
+       estimating the number of prologue/epulogue iterations. Call
+       targetm.vectorize.builtin_vectorization_cost. Return
+       min_profitable_iters-1.
+       (vect_model_reduction_cost): Use TARG_SCALAR_TO_VEC_COST for
+       initialization cost instead of TARG_VEC_STMT_COST. Use
+       TARG_VEC_TO_SCALAR_COST instead of TARG_VEC_STMT_COST for reduction
+       epilogue code. Fix epilogue cost computation.
+       * config/spu/spu.c (spu_builtin_vectorization_cost): New.
+       (TARGET_VECTORIZE_BUILTIN_VECTORIZATION_COST): Implement.
+       * config/spu/spu.h (TARG_COND_BRANCH_COST, TARG_SCALAR_STMT_COST):
+       (TARG_SCALAR_LOAD_COST, TARG_SCALAR_STORE_COST, TARG_VEC_STMT_COST):
+       (TARG_VEC_TO_SCALAR_COST, TARG_SCALAR_TO_VEC, TARG_VEC_LOAD_COST):
+       (TARG_VEC_UNALIGNED_LOAD_COST, TARG_VEC_STORE_COST): Define.
+
+2007-07-12  Richard Guenther  <rguenther@suse.de>
+
+       * gimplify.c (gimplify_conversion): Make sure that the result
+       from maybe_fold_offset_to_reference is trivially convertible
+       to the desired type before doing the simplification.
+       (gimplify_expr): Likewise.
+       * fold-const.c (fold_binary): Use the correct types for
+       building the simplified expression.
+
+2007-07-12  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR rtl-optimization/32729
+       * cfghooks.c (can_duplicate_block_p): Do not forbid duplicating blocks
+       that fallthru to exit.
+
+2007-07-12  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.md (symGOTOFF2reg): Add missing parenthesis.
+       (symDTPOFF2reg): Likewise.
+
+2007-07-11  Daniel Berlin  <dberlin@dberlin.org>
+
+       PR tree-optimization/32663
+       
+       * tree.h (VALUE_HANDLE_VUSES): Remove.
+       (struct tree_value_handle): Remove vuses.
+
+       * tree-vn.c (create_value_handle_for_expr): Don't set
+       VALUE_HANDLE_VUSES. 
+
+       * tree-ssa-pre.c (expression_vuses): New.
+       (alloc_expression_id): Set up expression_vuses.
+       (get_expression_vuses): New.
+       (set_expression_vuses): Ditto.
+       (clear_expression_ids): Modify for expression_vuses.
+       (phi_translate_1): Ditto.
+       (phi_translate_set): Ditto.
+       (value_dies_in_block_x): Ditto
+       (valid_in_sets): Ditto.
+       (add_to_sets): Ditto.
+       (find_existing_value_expr): Ditto.
+       (create_value_handle_for_expr): Ditto.
+       (make_values_for_stmt): Ditto.
+       (vuse_equiv): Remove.
+
+2007-07-11  Alexandre Oliva  <aoliva@redhat.com>
+
+       * Makefile.in (mostlyclean): Remove object files.
+
+2007-07-11  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * toplev.c (no_new_pseudos): Deleted.
+       * rtl.h (no_new_pseudos): Deleted.
+       * tree-pass.h (pass_no_new_pseudos): Deleted. 
+       * passes.c (pass_no_new_pseudos): Deleted.
+       * final.c (rest_of_clean_state): Removed no_new_pseudos.
+       (rest_of_no_new_pseudos, pass_no_new_pseudos): Deleted.
+       * struct-equiv.c (rtx_equiv_p): Replaced no_new_pseudos with 
+       reload_completed.
+       * cfgcleanup.c (try_crossjump_to_edge): Ditto. 
+       * rtlhooks.c (gen_lowpart_general): Ditto.
+       * optabs.c (prepare_operand): Ditto.
+       * mode-switching.c (rest_of_handle_mode_switching): Deleted set of
+       no_new_pseudos.
+       * modulo-sched.c (rest_of_handle_sms): Ditto.
+       * see.c (rest_of_handle_see): Ditto.
+       * ifcvt.c (if_convert): Ditto.
+       (gate_handle_if_after_combine): Replaced no_new_pseudos with 
+       reload_completed.
+       * init-regs.c (gate_initialize_regs): Deleted set of
+       no_new_pseudos.
+       * lower-subreg.c (decompose_multiword_subregs): Ditto. 
+       * bb-reorder.c (rest_of_handle_partition_blocks): Ditto.
+       * doc/md.texi: Changed no_new_pseudos to can_create_pseudo_p.
+       
+2007-07-11  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32661
+       * config/i386/sse.md (*sse2_storeq_rex64): Handle 64bit mem->reg moves.
+       (*vec_extractv2di_1_sse2): Disable for TARGET_64BIT.
+       (*vec_extractv2di_1_rex64): New insn pattern.
+
+2007-07-11  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/linux-unwind.h (mips_fallback_frame_state): Rewrite
+       return address calculation.  Substitute DWARF_ALT_FRAME_RETURN_COLUMN
+       for SIGNAL_UNWIND_RETURN_COLUMN.
+       * config/mips/mips.h (SIGNAL_UNWIND_RETURN_COLUMN): Remove.
+       (DWARF_FRAME_REGNUM): Rewrite.
+       (DWARF_ALT_FRAME_RETURN_COLUMN) Define.
+
+2007-07-11  Nick Clifton  <nickc@redhat.com>
+
+       * config/m32r/m32r.h (INITIALIZE_TRAMPOLINE): Revert previous
+       delta and use gen_int_mode in place of GET_INT instead.
+
+2007-07-11  Uros Bizjak  <ubizjak@gmail.com>
+
+       * reg-stack.c (struct tree_opt_pass pass_stack_regs): Nullify name
+       and letter field.
+
+2007-07-11  Douglas Gregor  <doug.gregor@gmail.com>
+
+       * params.def (PARAM_VERIFY_CANONICAL_TYPES): Remove.
+       (PARAM_USE_CANONICAL_TYPES): New; decides whether to use canonical 
+       types or not.
+       * params.h (VERIFY_CANONICAL_TYPES): Remove.
+       (USE_CANONICAL_TYPES): New.
+       * doc/invoke.texi (verify-canonical-types): Remove.
+       (use-canonical-types): Add.
+
+2007-07-11  Ulrich Weigand  <uweigand@de.ibm.com>
+
+       * config/spu/spu.c (spu_optimization_options): Remove setting of
+       parameter PARAM_MAX_COMPLETELY_PEEL_TIMES.
+       (spu_override_options): Move it here.
+
+2007-07-11  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.h (MIPS_ISA_LEVEL_SPEC): Handle -m4ksc and -m4ksd.
+       * config/mips/mips.c (mips_cpu_info_table): Mention
+       MIPS_ISA_LEVEL_SPEC in the comment.
+
+2007-07-11  Eric Botcazou  <ebotcazou@adacore.com>
+
+       PR tree-optimization/32713
+       * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle REAL_CST.
+
+2007-07-11  Paolo Carlini  <pcarlini@suse.de>
+
+       PR middle-end/30482
+       * c-opts.c (c_common_post_options): Do not change flag_complex_method
+       conditional to flag_isoc99.
+       (c_common_init_options): Do it here, unconditionally.
+
+2007-07-11  Eric Botcazou  <ebotcazou@adacore.com>
+
+       PR tree-optimization/32589
+       * doc/tree-ssa.texi (Rough GIMPLE Grammar): Add missing rule.
+       * tree-gimple.c (is_gimple_min_invariant): Clarify head comment.
+       * tree-ssa-propagate.c (valid_gimple_expression_p): New
+       predicate, extracted from...
+       (set_rhs): ...here.  Call it for the expression on entry.
+       * tree-ssa-propagate.h (valid_gimple_expression_p): Declare.
+       * tree-ssa-sccvn.c: Include tree-ssa-propagate.h.
+       (simplify_binary_expression): Use valid_gimple_expression_p
+       to validate the simplification.
+       * Makefile.in (tree-ssa-sccvn.o): Depends on tree-ssa-propagate.h.
+
+2007-07-11  Danny Smith  <dannysmith@users.sourceforge.net>
+
+       * config/i386/cygming.h (PREFERRED_DEBUGGING_TYPE): Define to
+       DWARF2_DEBUG on 32 bit target too.
+       (DWARF2_UNWIND_INFO): Reorganize 64-bit vs 32-bit definition. 
+
+2007-07-11  Nick Clifton  <nickc@redhat.com>
+
+       * config/m32r/m32r.h (INITIALIZE_TRAMPOLINE): Provide alternative
+       version for 64-bit hosts.
+
+2007-07-10  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/mips.h (ISA_HAS_SYNCI): New target capability
+       predicate.
+       (INITIALIZE_TRAMPOLINE): Emit clear_cache insn instead of  library
+       call.
+       * config/mips/mips.c (mips_expand_synci_loop): New function.
+       * config/mips/mips.md (UNSPEC_CLEAR_HAZARD): New constant.
+       (UNSPEC_RDHWR): Same.
+       (UNSPEC_SYNCI): Same.
+       (UNSPEC_SYNC): Same.
+       (clear_cache): New expand.
+       (sync): New insn.
+       (synci): Same.
+       (rdhwr): Same.
+       (clear_hazard): Same.
+       * config/mips/mips-protos.h (mips_expand_synci_loop): Declare
+       function.
+       * testsuite/gcc.target/mips/clear-cache-1.c: New test.
+       * testsuite/gcc.target/mips/clear-cache-2.c: New test.
+
+2007-07-10  Ian Lance Taylor  <iant@google.com>
+
+       * emit-rtl.c (gen_reg_rtx): Check can_create_pseudo_p rather than
+       no_new_pseudos.
+
+2007-07-10  David Daney  <ddaney@avtrex.com>
+
+       * builtins.def (BUILT_IN_CLEAR_CACHE): New builtin.
+       * builtins.c (expand_builtin___clear_cache): New function.
+       (expand_builtin): Call expand_builtin___clear_cache for
+       BUILT_IN_CLEAR_CACHE case.
+       * doc/extend.texi (__builtin___clear_cache): Document new builtin.
+       * doc/md.texi (clear_cache): Document new instruction pattern.
+       * testsuite/gcc.dg/builtins-64.c: New test.
+
+2007-07-11  Hans-Peter Nilsson  <hp@axis.com>
+
+       * config/cris/cris.md ("movsi"): Fix typo in last change.
+
+2007-07-09  Geoffrey Keating  <geoffk@apple.com>
+
+       PR 32617
+       * c-common.c (c_alignof_expr): Look at DECL_ALIGN of
+       FUNCTION_DECLs.
+       (handle_aligned_attribute): Allow use on FUNCTION_DECLs.
+       * varasm.c (assemble_start_function): Honor DECL_ALIGN
+       for FUNCTION_DECLs.  Don't use align_functions_log if
+       DECL_USER_ALIGN.
+       * print-tree.c (print_node): Print DECL_ALIGN and DECL_USER_ALIGN
+       even for FUNCTION_DECLs.
+       * c-decl.c (merge_decls): Propagate DECL_ALIGN even for
+       FUNCTION_DECLs.
+       * tree.h (DECL_ALIGN): Update for new location of 'align'.
+       (DECL_FUNCTION_CODE): Update for new location and name of
+       'function_code'.
+       (DECL_OFFSET_ALIGN): Update for new location of 'off_align'.
+       (struct tree_decl_common): Move 'align' and 'off_align' out
+       of union, ensure they're still on a 32-bit boundary.  Remove
+       other fields in union 'u1'.
+       (struct tree_function_decl): Add field 'function_code' replacing
+       'u1.f' in tree_decl_common.
+       * tree.c (build_decl_stat): Set initial value of DECL_ALIGN.
+       * doc/extend.texi (Function Attributes): Add 'aligned' attribute.
+       (Variable Attributes): Cross-reference 'aligned' attribute
+       to Function Attributes.
+       * flags.h (force_align_functions_log): Delete.
+       * toplev.c (force_align_functions_log): Delete.
+
+2007-07-10  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32708
+       * config/i386/sse.md (vec_concatv2di): Disable for TARGET_64BIT.
+       (*vec_concatv2di_rex): New insn pattern.
+
+2007-07-10  Rainer Orth  <ro@TechFak.Uni-Bielefeld.DE>
+
+       PR target/32538
+       * config/mips/iris6.h (LIBGCC_SPEC): Add libm.
+
+2007-07-10  Ian Lance Taylor  <iant@google.com>
+
+       Replace no_new_pseudos in backends.
+       * rtl.h (can_create_pseudo_p): Define.
+       * config/darwin.c (machopic_indirect_data_reference): Use
+       can_create_pseudo_p () instead of no_new_pseudos.
+       (machopic_indirect_data_reference): Likewise.
+       (machopic_legitimize_pic_address): Likewise.
+       * config/alpha/alpha.c (alpha_legitimize_address): Likewise.
+       (alpha_emit_set_const_1): Likewise.
+       (alpha_emit_set_const): Likewise.
+       (alpha_emit_conditional_move): Likewise.
+       (alpha_split_conditional_move): Likewise.
+       * config/alpha/alpha.md (various splitters): Likewise.
+       (movti): Likewise.
+       * config/arm/arm.c (legitimize_pic_address): Likewise.
+       (arm_load_pic_register): Likewise.
+       * config/arm/arm.md (addsi3, subsi3, andsi3, iorsi3): Likewise.
+       (movdi, movsi, movhi, movqi, movsf, movdf): Likewise.
+       * config/bfin/bfin.c (legitimize_pic_address): Likewise.
+       * config/cris/cris.c (cris_expand_pic_call_address): Likewise.
+       * config/cris/cris.md (movsi): Likewise.
+       * config/frv/frv.md (symGOT2reg_hilo): Likewise.
+       (symGOTOFF2reg_hilo): Likewise.
+       (symGPREL2reg, symGPREL2reg_hilo): Likewise.
+       * config/h8300/h8300.md (insv, extzv): Likewise.
+       * config/i386/i386.c (ix86_expand_move): Likewise.
+       (ix86_expand_vector_move): Likewise.
+       (ix86_prepare_fp_compare_args): Likewise.
+       (ix86_expand_carry_flag_compare): Likewise.
+       * config/i386/i386.md (tls_dynamic_gnu2_32): Likewise.
+       (tls_dynamic_gnu2_combine_32): Likewise.
+       (tls_dynamic_gnu2_64, tls_dynamic_gnu2_combine_64): Likewise.
+       * config/ia64/ia64.c (ia64_expand_move): Likewise.
+       (ia64_expand_movxf_movrf): Likewise.
+       * config/m32c/m32c.c (m32c_prepare_move): Likewise.
+       (m32c_split_move): Likewise.
+       (m32c_expand_insv): Likewise.
+       * config/m68k/m68k.md (movsi): Likewise.
+       * config/mips/mips.c (mips_force_temporary): Likewise.
+       (mips_split_symbol): Likewise.
+       (mips_move_integer): Likewise.
+       (mips_legitimize_const_move): Likewise.
+       * config/mn10300/mn10300.md (movsi): Likewise.
+       * config/pa/pa.c (emit_move_sequence): Likewise.
+       * config/rs6000/rs6000.c (rs6000_emit_move): Likewise.
+       (rs6000_got_register): Likewise.
+       (create_TOC_reference): Likewise.
+       (rs6000_machopic_legitimize_pic_address): Likewise.
+       * config/rs6000/rs6000.md (add<mode>3): Likewise.
+       (various splitters): Likewise.
+       (iorsi3, xorsi3, iordi3, xordi3): Likewise.
+       (movsi_got): Likewise.
+       * config/s390/s390.c (emit_symbolic_move): Likewise.
+       * config/s390/s390.md (movhi, movqi): Likewise.
+       (load_multiple, store_multiple): Likewise.
+       * config/score/score.c (score_force_temporary): Likewise.
+       * config/sh/sh.c (prepare_move_operands): Likewise.
+       (prepare_cbranch_operands): Likewise.
+       (emit_fpu_switch): Likewise.
+       (fpscr_set_from_mem): Likewise.
+       * config/sh/sh.md (movdicc, movsicc, movsicc_umin): Likewise.
+       (adddi3, subsi3): Likewise.
+       (various splitters): Likewise.
+       (divsi_inv_fp_combine): Likewise.
+       (symGOT_load, symGOTOFF2reg, symDTPOFF2reg): Likewise.
+       (seq, slt, sle, sgt, sge, sgtu, sltu, sleu, sgeu): Likewise.
+       (sne): Likewise.
+       * config/sh/predicates.md (xor_operand): Likewise.
+       * config/sparc/sparc.c (legitimize_tls_address): Likewise.
+       * config/sparc/sparc.md (movsi_pic_label_ref): Likewise.
+       (movdi_pic_label_ref): Likewise.
+       * config/spu/spu.c (spu_split_immediate): Likewise.
+       * config/alpha/alpha.md (various splitters): Remove test
+       !no_new_pseudos || reload_completed.
+       * config/ia64/ia64.c (ia64_output_mi_thunk): Don't set
+       no_new_pseudos.
+       * config/m68k/m68k.c (m68k_output_mi_thunk): Likewise.
+       * config/mips/mips.c (mips_output_mi_thunk): Likewise.
+       * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Likewise.
+       * config/score/score.c (th_output_mi_thunk): Likewise.
+       * config/sh/sh.c (sh_output_mi_thunk): Likewise.
+       * config/sparc/sparc.c (sparc_output_mi_thunk): Likewise.
+
+2007-07-10  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR rtl-optimization/32664
+       * mode-switching.c (create_pre_exit): Skip barrier insns.
+
+2007-07-10  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-scalar-evolution.c (scev_const_prop): Add arguments to
+       force_gimple_operand_bsi.
+       * tree-ssa-loop-ivopts.c (rewrite_use_nonlinear_expr,
+       rewrite_use_compare): Ditto.
+       * tree-ssa-address.c (gimplify_mem_ref_parts, create_mem_ref):
+       Ditto.
+       * tree-ssa-ifcombine.c (ifcombine_ifandif): Ditto.
+       * tree-ssa-loop-prefetch.c (issue_prefetch_ref): Ditto.
+       * lambda-code.c (replace_uses_equiv_to_x_with_y): Ditto.
+       * tree-profile.c (prepare_instrumented_value,
+       tree_gen_interval_profiler, tree_gen_pow2_profiler,
+       tree_gen_one_value_profiler, tree_gen_ic_profiler,
+       tree_gen_ic_func_profiler, tree_gen_average_profiler,
+       tree_gen_ior_profiler): Ditto.
+       * tree-ssa-reassoc.c (negate_value): Ditto.
+       * matrix-reorg.c (transform_access_sites, transform_allocation_sites):
+       Use force_gimple_operand_bsi.
+       * tree-vect-transform.c (vect_update_ivs_after_vectorizer): Ditto.
+       * tree-if-conv.c (add_to_dst_predicate_list,
+       find_phi_replacement_condition): Ditto.
+       * gimplify.c (force_gimple_operand_bsi): Add before and m arguments.
+       Call mark_symbols_for_renaming for new statements.
+       * tree-flow.h (force_gimple_operand_bsi): Declaration changed.
+
+2007-07-10  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * cfghooks.c (remove_edge): New function.
+       (redirect_edge_and_branch, remove_branch, merge_blocks): Updated
+       loop exit rescans.
+       * cfghooks.h (remove_edge): Declare.
+       * cfg.c (remove_edge): Renamed to remove_edge_raw.
+       * basic-block.h (remove_edge): Declaration changed to remove_edge_raw.
+
+2007-07-09  Wolfgang Gellerich  <gellerich@de.ibm.com>
+
+       * optabs.h: Added declaration for signbit_optab.  
+       * optabs.c: (init_optabs): Added initialization for signbit_optab.
+       * genoptinit.c (optabs): Added entry for signbit insns.  
+       * builtins.c (expand_builtin_signbit): Added code to use a signbit
+       insn, if available.  
+       * config/s390/s390.h (S390_TDC_SIGNBIT_SET): New constant.  
+       * config/s390/s390.md (signbit<mode>2): New expander.  
+
+2007-07-09  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32698
+       * fold-const.c (fold_plusminus_mult_expr): Move constant
+       arguments second to allow decomposing.
+
+2007-07-09  Alexandre Oliva  <aoliva@oliva.athome.lsd.ic.unicamp.br>
+
+       Revert:
+       2007-07-06  Alexandre Oliva  <aoliva@redhat.com>
+       PR debug/23551
+       * tree-ssa-copyrename.c (copy_rename_partition_coalesce):
+       Disregard DECL_FROM_INLINE.
+
+2007-07-09  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/27855
+       * doc/invoke.texi: Add ftree-reassoc flag.
+       * common.opt (ftree-reassoc): New flag.
+       * tree-ssa-reassoc.c (gate_tree_ssa_reassoc): New static function.
+       (struct tree_opt_pass pass_reassoc): Use gate_tree_ssa_reassoc.
+
+2007-07-09  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/32681
+       * tree-if-conv.c (find_phi_replacement_condition): Use the condition
+       saved in second_edge->aux when first_bb is a loop header.
+
+2007-07-09  Jan HUbicka  <jh@suse.cz>
+
+       * cse.c (cse_insn): Avoid invalid sharing on trial replacement.
+
+2007-07-09  Richard Guenther  <rguenther@suse.de>
+
+       * c-decl.c (start_function): Do not promote return type.
+
+2007-07-08  Daniel Franke  <franke.daniel@gmail.com>
+
+       * function.c (do_warn_unused_parameter): Do not warn if
+       TREE_NO_WARNING is set.
+
+2007-07-08  Andreas Schwab  <schwab@suse.de>
+
+       * doc/invoke.texi (DEC Alpha/VMS Options): Fix typo.
+
+2007-07-08  Sandra Loosemore  <sandra@codesourcery.com>
+
+       Revert this patch:
+       2007-07-06  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * c-opts.c (c_common_handle_option): Make DOLLARS_IN_IDENTIFIERS
+       apply to assembly language, too.
+       * doc/tm.texi (DOLLARS_IN_IDENTIFIERS): Update.
+
+2007-07-07  Daniel Berlin  <dberlin@dberlin.org>
+
+       Revert (note the sccvn portions are *not* reverted)
+       2007-07-06  Daniel Berlin  <dberlin@dberlin.org>
+
+       Fix PR tree-optimization/23488
+
+       * tree-vn.c (set_value_handle): Use decl_vh_map for decl value
+       handles.
+       * tree-flow-inline.h (get_value_handle): Ditto.
+       * tree-ssa-pre.c (decl_vh_map): New.
+       (decl_node_pool): New.
+       (can_value_number_operation): Support DECL_P.
+       (can_PRE_operation): Ditto.
+       (create_expression_by_pieces): Ditto.
+       (find_existing_value_expr): Modify to differnetiate between
+       addressing and top level.
+       (create_value_handle_for_expr): Handle DECL's.
+       (poolify_tree): Ditto.
+       (make_values_for_phi): Don't insert into PHI_GEN during FRE.
+       (make_values_for_stmt): Handle DECL's properly.
+       (init_pre): Reorg to not init useless things during FRE.
+       (fini_pre): Ditto.
+       * tree-flow.h: Include pointer-set.h.
+       (decl_vh_map): Declare.
+       * Makefile.in (TREE_FLOW_H): Add pointer-set.h
+
+2007-07-07 Eric Weddington  <eweddington@cso.atmel.com>
+
+       * config/avr/constraints.md (define_memory_constraint "Q"): Fix
+       the constraint description.
+       * doc/md.texi: Update documentation of AVR constraints.
+
+2007-07-07  Kazu Hirata  <kazu@codesourcery.com>
+
+       * auto-inc-dec.c, config/arm/arm.c,
+       config/m32r/constraints.md, config/mips/mips.md,
+       config/rs6000/rs6000.c, cselib.c, dce.c, df-core.c,
+       df-problems.c, df-scan.c, df.h, dse.c, gimplify.c,
+       tree-if-conv.c, tree-ssa-sccvn.c, tree-ssa.c: Fix comment
+       typos.  Follow spelling conventions.
+       * doc/invoke.texi, doc/rtl.texi: Fix typos.
+
+       * cfgrtl.c (delete_insn_chain_and_edges): Remove.
+       * rtl.h: Remove the prototype for delete_insn_chain_and_edges.
+
+       * tree-ssa-operands.c (realloc_vop, realloc_vdef,
+       realloc_vuse): Remove.
+       * tree-ssa-operands.h: Remove the prototype for realloc_vdef
+       and realloc_vuse.
+
+2007-07-06  Daniel Berlin  <dberlin@dberlin.org>
+
+       Fix PR tree-optimization/23488
+
+       * tree-ssa-sccvn.c (expr_has_constants): Handle tcc_declaration.
+       (try_to_simplify): Ditto.
+       (visit_use): Ditto.
+       * tree-vn.c (set_value_handle): Use decl_vh_map for decl value
+       handles.
+       * tree-flow-inline.h (get_value_handle): Ditto.
+       * tree-ssa-pre.c (decl_vh_map): New.
+       (decl_node_pool): New.
+       (can_value_number_operation): Support DECL_P.
+       (can_PRE_operation): Ditto.
+       (create_expression_by_pieces): Ditto.
+       (find_existing_value_expr): Modify to differnetiate between
+       addressing and top level.
+       (create_value_handle_for_expr): Handle DECL's.
+       (poolify_tree): Ditto.
+       (make_values_for_phi): Don't insert into PHI_GEN during FRE.
+       (make_values_for_stmt): Handle DECL's properly.
+       (init_pre): Reorg to not init useless things during FRE.
+       (fini_pre): Ditto.
+       * tree-flow.h: Include pointer-set.h.
+       (decl_vh_map): Declare.
+       * Makefile.in (TREE_FLOW_H): Add pointer-set.h
+               
+2007-07-06  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * c-opts.c (c_common_handle_option): Make DOLLARS_IN_IDENTIFIERS
+       apply to assembly language, too.
+       * doc/tm.texi (DOLLARS_IN_IDENTIFIERS): Update.
+
+2007-07-06  Ian Lance Taylor  <iant@google.com>
+           Zack Weinberg  <zackw@panix.com>
+
+       PR middle-end/32441
+       * builtins.c (std_expand_builtin_va_start): Don't use make_tree.
+
+2007-07-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/sh/sh.md (*prefetch_i4): Disable for TARGET_VXWORKS_RTP.
+       (prefetch): Likewise if "pref" would be used.
+
+2007-07-06  Josh Conner  <jconner@apple.com>
+
+       PR middle-end/32602
+       PR middle-end/32603
+       * calls.c (store_one_arg): Handle arguments which are partially
+       on the stack when detecting argument overlap.
+
+2007-07-06  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * reload1.c (choose_reload_regs): Set reload_spill_index for regs
+       chosen during find_reloads.
+
+2007-07-06  Richard Guenther  <rguenther@suse.de>
+
+       * gimplify.c (gimplify_call_expr): Prefer DECL_ARGUMENTS over
+       TYPE_ARG_TYPES for verification of argument types.  Use
+       DECL_ARG_TYPE instead of the PARM_DECL type.  Take excess
+       parameters as variable arguments.
+
+2007-07-06  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * libgcc2.h (word_type): Type definition removed.
+       (cmp_return_type, shift_count_type): Type definitions added.
+       (__lshrdi3, __ashldi3, __ashrdi3): word_type of second parameter
+       replaced with shift_count_type.
+       (__cmpdi2, __ucmpdi2): word_type of return type replaced with
+       cmp_return_type.
+       * libgcc2.c (__udivmoddi4, __moddi3): Type of local variable c
+       changed from word_type to Wtype.
+       (__lshrdi3, __ashldi3, __ashrdi3): word_type of second parameter
+       replaced with shift_count_type.
+       (__cmpdi2, __ucmpdi2): word_type of return type replaced with
+       cmp_return_type.
+       * c-common.c (handle_mode_attribute): Handling for libgcc_cmp_return
+       and libgcc_shift_count attribute added.
+       * target-def.h (TARGET_LIBGCC_CMP_RETURN_MODE,
+       TARGET_LIBGCC_SHIFT_COUNT_MODE): New target hooks defined.
+       (TARGET_INITIALIZER): New target hooks added.
+       * targhooks.c (default_libgcc_cmp_return_mode,
+       default_libgcc_shift_count_mode): Default implementations for the new
+       target hooks added.
+       * targhooks.h (default_libgcc_cmp_return_mode,
+       default_libgcc_shift_count_mode): Function prototypes added.
+       * target.h (struct gcc_target): Fields for the new target hooks added.
+       * optabs.c (expand_binop): Use shift_count_mode when expanding shift
+       as library call.
+       (prepare_cmp_insn): Use cmp_return_mode when expanding comparison as
+       library call.
+
+       * doc/tm.texi (TARGET_LIBGCC_CMP_RETURN_MODE,
+       TARGET_LIBGCC_SHIFT_COUNT_MODE): Documentation added.
+
+       * config/s390/s390.c (s390_libgcc_cmp_return_mode,
+       s390_libgcc_shift_count_mode): Functions added.
+       (TARGET_LIBGCC_CMP_RETURN_MODE, TARGET_LIBGCC_SHIFT_COUNT_MODE):
+       Target hooks defined.
+
+2007-07-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (compute_frame_size): Restore the original
+       gp_sp_offset for !GENERATE_MIPS16E_SAVE_RESTORE and remove the
+       fp_size term from the GENERATE_MIPS16E_SAVE_RESTORE calculation.
+       Document why the difference is needed.
+
+2007-07-06  Richard Guenther  <rguenther@suse.de>
+
+       * c-common.c (boolean_increment): Use correctly typed
+       constant.
+
+2007-07-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips16e_save_restore_pattern_p): Check that
+       the topmost argument register is not also included in the save mask.
+       (mips16e_collect_argument_save_p): Take a pointer to the argument
+       register, rather than a pointer to the number of arguments.
+       (mips16e_collect_argument_saves): Only include argument saves
+       that aren't in the register mask.
+
+2007-07-06  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR rtl-optimization/32450
+       * function.c (thread_prologue_and_epilogue_insns): Emit blockage insn
+       to ensure that instructions are not moved into the prologue when
+       profiling is on.  Remove unused prologue_end variable.
+       (expand_function_end): Emit blockage insn instead of ASM_INPUT rtx
+       as a scheduling barrier.
+
+2007-07-06  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR debug/23551
+       * tree-ssa-copyrename.c (copy_rename_partition_coalesce):
+       Disregard DECL_FROM_INLINE.
+
+2007-07-05  Adam Nemet  <anemet@caviumnetworks.com>
+
+       * rtlanal.c (num_sign_bit_copies1): Improve cases of ANDing or
+       IORing with a constant.
+
+2007-07-05  Seongbae Park  <seongbae.park@gmail.com>
+
+       PR rtl-optimization/32475
+       * df-scan.c (df_def_record_1): Add a use of the stack pointer
+       for every definition of the stack pointer.
+
+2007-07-05  Richard Earnshaw  <rearnsha@arm.com>
+
+       * arm.c (vfp3_const_double_index): Copy signed results of
+       REAL_VALUE_TO_INT into unsigned vars.
+
+2007-07-05  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32639
+       * alias.c (get_alias_set): Tread METHOD_TYPE the same as
+       FUNCTION_TYPE.
+       * tree-ssa.c (useless_type_conversion_p): Check canonical
+       types early.
+
+2007-07-05 Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.md (zero_extendqihi2, zero_extendqisi2, 
+       zero_extendhisi2): Change to define_insn_and_split. 
+       (zero_extendqidi2, zero_extendhidi2, zero_extendsidi2): New.
+
+2007-07-05  Paolo Bonzini  <bonzini@gnu.org>
+
+       * function.c (match_asm_constraints_1, rest_of_match_asm_constraints,
+       pass_match_asm_constraints): New.
+       * passes.c (init_optimization_passes): Add new pass.
+       * stmt.c (expand_asm_operands): Set cfun->has_asm_statement.
+       * function.h (struct function): Add has_asm_statement bit.
+       (current_function_has_asm_statement): New.
+       * tree-pass.h (pass_match_asm_constraints): New.
+
+2007-07-05  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * config/mips/mips.c (mips_file_start): Avoid declaration
+       after code.
+
+2007-07-05  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * optabs.c (expand_binop_directly): Fix signed/unsigned comparison.
+
+2007-07-05  Uros Bizjak  <ubizjak@gmail.com>
+
+       * rtl.def (NOTE): Change print format string to print
+       operand 5 as a note insn name.
+
+2007-07-05  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+
+       * config/mips/mips.c (mips_cpu_info): Add 4ksc and 4ksd processors.
+       * doc/invoke.texi: (MIPS Options): Document them.
+
+2007-07-05  Sandra Loosemore  <sandra@codesourcery.com>
+           David Ung  <davidu@mips.com>
+
+       Add support for SmartMIPS ASE.
+
+       * optabs.c (expand_binop_directly): New, broken out from...
+       (expand_binop): Here.  Make it try rotating in the other
+       direction even when the second operand isn't constant.
+       * config/mips/mips.md (*lwxs): New.
+       * config/mips/mips.opt (msmartmips): New.
+       * config/mips/mips.c (mips_lwxs_address_p): New.
+       (mips_rtx_costs): Make it recognize scaled indexed addressing.
+       * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Define
+       __mips_smartmips when compiling for TARGET_SMARTMIPS.
+       (ISA_HAS_ROR): Define for TARGET_SMARTMIPS.
+       (ISA_HAS_LWXS): New.
+       (ASM_SPEC): Add -msmartmips/-mno-smartmips.
+       * doc/invoke.texi (MIPS Options): Document -msmartmips/-mno-smartmips.
+       * testsuite/gcc.target/mips/smartmips-lwxs.c: New test case.
+       * testsuite/gcc.target/mips/smartmips-ror-1.c: New test case.
+       * testsuite/gcc.target/mips/smartmips-ror-2.c: New test case.
+       * testsuite/gcc.target/mips/smartmips-ror-3.c: New test case.
+       * testsuite/gcc.target/mips/smartmips-ror-4.c: New test case.
+
+2007-07-05  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vectorizer.c (new_loop_vec_info): Initialize
+       LOOP_VINFO_COST_MODEL_MIN_ITERS.
+       * tree-vectorizer.h (_loop_vec_info): Added new filed
+       min_profitable_iters.
+       (LOOP_VINFO_COST_MODEL_MIN_ITERS): New access macro to above new field.
+       (TARG_SCALAR_TO_VEC_COST): Define cost of scalar to vector operation.
+       * tree-vect-analyze.c (vect_analyze_operations): Set
+       LOOP_VINFO_COST_MODEL_MIN_ITERS.
+       * tree-vect-transform.c (vect_estimate_min_profitable_iters): Use
+       VEC_length to determine if there are any LOOP_VINFO_MAY_MISALIGN_STMTS.
+       Fix calculation of peel_iters_prologue. Move consideration of epilogue
+       and prologue cost to after they are computed.
+       (vect_model_induction_cost): Use TARG_SCALAR_TO_VEC_COST instead of
+       TARG_VEC_STMT_COST.
+       (vect_model_simple_cost): Takes additional argument dt. Consider cost
+       of creating vectors from scalars according to dt.
+       (vect_model_store_cost): Likewise.
+       (vectorizable_call): Use dt array instead of scalar dt. Call
+       vect_model_simple_cost with additional argument dt.
+       (vectorizable_assignment): Likewise.
+       (vectorizable_operation): Likewise.
+       (vectorizable_type_demotion): Likewise.
+       (vectorizable_type_promotion): Likewise.
+       (vectorizable_store): Use dt array instead of scalar dt. Call
+       vect_model_store_cost with additional argument dt.
+       (vect_do_peeling_for_loop_bound): Don't call
+       vect_estimate_min_profitable_iters. Instead, lookup
+       LOOP_VINFO_COST_MODEL_MIN_ITERS. Don't always print
+       "may not be profitable".
+
+2007-07-05  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR testsuite/32014
+       * config/rs6000/altivec.md (UNSPEC_VUPKHS_V4SF, UNSPEC_VUPKLS_V4SF):
+       (UNSPEC_VUPKHU_V4SF, UNSPEC_VUPKLU_V4SF): New.
+       (vec_unpacks_float_hi_v8hi, vec_unpacks_float_lo_v8hi): New patterns.
+       (vec_unpacku_float_hi_v8hi, vec_unpacku_float_lo_v8hi): New patterns. 
+
+2007-07-05  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * config/i386/i386.c (ix86_address_cost): Do not consider more complex
+       addressing modes cheaper.
+
+2007-07-05  Alexandre Oliva  <aoliva@redhat.com>
+
+       * dwarf2out.c (dw_ranges_by_label_ref): New typedef.
+       (dw_ranges_struct): Rename block_num to num.  Adjust.
+       (dw_ranges_by_label_struct): New.
+       (ranges_by_label, ranges_by_label_allocated,
+       ranges_by_label_in_use): New variables.
+       (add_ranges_num): Factored most of the code out of...
+       (add_ranges): ... this one.  Rewrite in terms of the former.
+       (add_ranges_by_labels): New.
+       (output_ranges): Output by-label ranges.
+       (dwarf2out_finish): Output range for multiple-section
+       compile_unit.  Output standard DW_AT_low_pc in addition to
+       unexpected DW_AT_entry_pc.
+
+2007-07-04  Daniel Berlin  <dberlin@dberlin.org>
+
+       PR tree-optimization/32604
+       PR tree-optimization/32606
+
+       * tree-ssa-pre.c (bb_bitmap_sets): Removed antic_safe_loads.
+       (compute_antic_safe): Removed.
+       (ANTIC_SAFE_LOADS): Ditto.
+       (compute_antic_aux): Don't print ANTIC_SAFE_LOADS.
+       (execute_pre): Don't call compute_antic_safe.
+       (vuse_equiv): New function.
+       (make_values_for_stmt): Use it
+       * tree-ssa-sccvn.c (set_ssa_val_to): Remove assert, since it is
+       not always true.
+
+2007-07-04 Anatoly Sokolov <aesok@post.ru>
+
+       PR target/31331
+       * config/avr/avr.c (avr_naked_function_p): Handle receiving a type
+       rather than a decl. 
+       (avr_attribute_table): Make "naked" attribute apply to function types
+       rather than to decls.
+       (avr_handle_fntype_attribute): New function.
+
+2007-07-04  Joseph Myers  <joseph@codesourcery.com>
+
+       * target-def.h (TARGET_INITIALIZER): Remove trailing whitespace
+       after \.
+
+2007-07-04  David Ung  <davidu@mips.com>
+           Joseph Myers  <joseph@codesourcery.com>
+
+       * config/mips/mips.md (type): Add logical, signext and move.
+       (one_cmpl<mode>2, *and<mode>3, *and<mode>3_mips16, *ior<mode>3,
+       *ior<mode>3_mips16, two unnamed insns after *ior<mode>3_mips16,
+       *nor<mode>3, "Combiner patterns to optimize truncate/zero_extend
+       combinations", *zero_extend<SHORT:mode><GPR:mode>2,
+       *zero_extendqihi2, *extend<SHORT:mode><GPR:mode>2_mips16e,
+       *extend<SHORT:mode><GPR:mode>2_se<SHORT:size>, *movdi_64bit,
+       *movdi_64bit_mips16, *movsi_internal, *movsi_mips16, movcc,
+       *movhi_internal, *movhi_mips16, *movqi_internal, *movqi_mips16,
+       *movsf_hardfloat, *movsf_softfloat, *movsf_mips16,
+       *movdf_hardfloat_64bit, *movdf_hardfloat_32bit,
+       movv2sf_hardfloat_64bit): Use the new types.
+       (*movdi_32bit, *movdi_gp32_fp64, *movdi_32bit_mips16,
+       *movdf_softfloat, *movdf_mips16): Use "multi".
+       (extendqihi2): Replace with a define_expand.
+       (*extendqihi2_mips16e, *extendqihi2, *extendqihi2_seb): New.
+       Based on extend<SHORT:mode><GPR:mode>2 patterns.
+       * config/mips/74k.md (r74k_int_logical): New reservation and
+       bypasses.
+       (r74k_int_arith): Remove "slt".
+       * config/mips/24k.md, config/mips/4130.md, config/mips/4k.md,
+       config/mips/5400.md, config/mips/5500.md, config/mips/5k.md,
+       config/mips/7000.md, config/mips/9000.md, config/mips/generic.md,
+       config/mips/sb1.md, config/mips/sr71k.md: Add new types to
+       reservations for "arith".
+
+2007-07-04  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa.c (useless_type_conversion_p): Add handling for
+       scalar float and vector types.  Only call the types_compatible_p
+       langhook for aggregate types as last resort.  Follow the
+       rules.
+
+2007-07-04  Richard Guenther  <rguenther@suse.de>
+
+       * tree-inline.c (estimate_num_insns_1): Treat CONVERT_EXPR
+       the same as NOP_EXPR.
+
+2007-07-04  Nick Clifton  <nickc@redhat.com>
+
+       * target.h (struct gcc_target): Add target_help field.
+       * target-def.h (TARGET_HELP): New.
+       (TARGET_INITIALIZER): Use TARGET_HELP.
+       * opts.c (command_handle_option): Invoke target_help function, if
+       defined, when the user has specified --target-help on the command
+       line.
+       * doc/invoke.texi: Mention that --target-help might print
+       additional information.
+       * doc/tm.texi: Document TARGET_HELP hook.
+
+       * arm.c (TARGET_HELP): Override default definition.
+       (arm_target_help): New - display a wrapped list of cores and
+       architectures supported.
+
+2007-07-04  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * config/v850/v850.c (expand_prologue): Make sure
+       GEN_INT() argument is sign extended rather than zero extended.
+       (expand_epilogue): Likewise.
+       (output_move_double): Delete.
+       * config/v850/v850-protos.h (output_move_double): Delete.
+       * config/v850/v850.md (movdi): Delete.
+       (*movdi_internal): Delete.
+       (movdf): Delete.
+       (*movdf_internal): Delete.
+
+2007-07-04  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/sh/vxworks.h (SUBTARGET_OVERRIDE_OPTIONS): Reject -mrelax
+       unless compiling RTP PIC.
+
+2007-07-04  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/32482
+       * tree-ssa-ifcombine.c (recognize_single_bit_test): Use the
+       original ssa name if we didn't find a shift expression.
+       Fix shift constant for bit zero test.
+
+2007-07-04  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/sh/lib1funcs.asm (ic_invalidate): Align constant pool.
+
+2007-07-04  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (arm-wrs-vxworks): Don't include svr4.h.
+       * config/vxworks.h (PTRDIFF_TYPE, SIZE_TYPE, TARGET_POSIX_IO): Define.
+       * config/arm/vxworks.h (ASM_SPEC): Delete.
+       (SUBTARGET_EXTRA_ASM_SPEC): Define.
+
+2007-07-04  Sebastian Pop  <sebpop@gmail.com>
+
+       * tree-data-ref.h (data_dependence_relation): New flag reversed_p.
+       (DDR_REVERSED_P): New.
+       * tree-data-ref.c (initialize_data_dependence_relation,
+       build_classic_dist_vector): Set DDR_REVERSED_P.
+
+2007-07-04  Sebastian Pop  <sebpop@gmail.com>
+
+       PR middle-end/32457
+       * tree-data-ref.c (analyze_siv_subscript_cst_affine,
+       compute_overlap_steps_for_affine_1_2, analyze_subscript_affine_affine,
+       init_omega_for_ddr_1): Use non conservative number of iterations
+       estimations.
+       (analyze_subscript_affine_affine): Use HOST_WIDE_INT instead of int.
+       (analyze_siv_subscript): Remove FIXME and reinitialization of 
+       last_conflicts to chrec_dont_know.
+       * testsuite/gfortran.dg/vect/pr32457.f90: New.
+
+2007-07-04  Douglas Gregor  <doug.gregor@gmail.com>
+
+       * tree.c (maybe_canonicalize_argtypes): Improve description.
+
+2007-07-04  Douglas Gregor  <doug.gregor@gmail.com>
+
+       * tree.c (maybe_canonicalize_argtypes): New.
+       (build_function_type): Set canonical type.
+       (build_method_type_directly): Ditto.
+       (reconstruct_complex_type): Rebuild the METHOD_TYPE node
+       properly.
+
+2007-07-03  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * tree-ssa-loop-ivopts.c (strip_offset_1): Treat POINTER_PLUS_EXPR
+       like PLUS_EXPR.
+       (rewrite_use_nonlinear_expr): Likewise.
+
+2007-07-03  Seongbae Park  <seongbae.park@gmail.com>
+
+       * rtl.def (UNSPEC, USE, CLOBBER): More comments.
+
+2007-07-04  Ben Elliston  <bje@au.ibm.com>
+
+       * dwarf2out.c: Move DWARF2 abbreviation glossary closer to the top
+       of this file.
+
+       * c-objc-common.c (c_types_compatible_p): Fix indentation.
+
+       * doc/tm.texi (Run-time Target): Capitalise "CPU".
+       (Exception Handling): Likewise.
+
+2007-07-03  Jan Hubicka  <jh@suse.cz>
+
+       * ifcvt.c (find_cond_trap): Avoid invalid RTL sharing.
+
+2007-07-03  Eric Christopher  <echristo@apple.com>
+
+       * doc/cppopts.texi: Add conflicting option note to -dM.
+       * doc/invoke.texi: Add note about possible conflicts with
+       -E for -dCHARS and note that -dM will not produce
+       any results if there is no machine dependent reorg.
+       
+2007-07-03  Geoffrey Keating  <geoffk@apple.com>
+
+       * tree.h (DECL_ALIGN): Back out previous change.
+
+2007-07-03  Joseph Myers  <joseph@codesourcery.com>
+
+       * configure.ac: Test for .dtprelword support on MIPS.
+       * configure, config.in: Regenerate.
+       * config/mips/mips.c (mips_output_dwarf_dtprel): New.
+       (TARGET_ASM_OUTPUT_DWARF_DTPREL): Define.
+
+2007-07-03  Julian Brown  <julian@codesourcery.com>
+
+       * config.gcc (with_fpu): Allow --with-fpu=vfp3.
+       * config/arm/aout.h (REGISTER_NAMES): Add D16-D31.
+       * config/arm/aof.h (REGISTER_NAMES): Add D16-D31.
+       * config/arm/arm.c (FL_VFPV3): New flag for VFPv3 processor
+       capability.
+       (all_fpus): Add FPUTYPE_VFP3.
+       (fp_model_for_fpu): Add VFPv3 field.
+       (arm_rtx_costs_1): Give cost to VFPv3 constants.
+       (vfp3_const_double_index): New function. Return integer index of
+       VFPv3 constant suitable for fconst[sd] insns, or -1 if constant
+       isn't suitable.
+       (vfp3_const_double_rtx): New function. True if VFPv3 is enabled
+       and argument represents a valid RTX for a VFPv3 constant.
+       (vfp_output_fldmd): Split fldmd with > 16 registers in the list into
+       two instructions.
+       (vfp_emit_fstmd): Similar, for fstmd.
+       (arm_print_operand): Implement new code 'G' for VFPv3 floating-point
+       constants, represented as integer indices.
+       (arm_hard_regno_mode_ok): Use VFP_REGNO_OK_FOR_SINGLE,
+       VFP_REGNO_OK_FOR_DOUBLE macros.
+       (arm_regno_class): Handle VFPv3 d0-d7, low, high register split.
+       (arm_file_start): Set float-abi attribute for VFPv3, and output
+       correct ".fpu" assembler directive.
+       (arm_dbx_register_numbering): Add FIXME.
+       * config/arm/arm.h (TARGET_VFP3): New macro. Target supports VFPv3.
+       (fputype): Add FPUTYPE_VFP3.
+       (FIXED_REGISTERS): Add 32 registers for D16-D31.
+       (CALL_USED_REGISTERS): Likewise.
+       (CONDITIONAL_REGISTER_USAGE): Add note about conditional definition
+       of LAST_VFP_REGNUM. Make D16-D31 caller-saved, if present.
+       (LAST_VFP_REGNUM): Extend available VFP registers for VFPv3.
+       (D7_VFP_REGNUM): New.
+       (LAST_LO_VFP_REGNUM, FIRST_HI_VFP_REGNUM, LAST_HI_VFP_REGNUM)
+       (VFP_REGNO_OK_FOR_SINGLE, VFP_REGNO_OK_FOR_SINGLE)
+       (VFP_REGNO_OK_FOR_DOUBLE): Define new macros.
+       (FIRST_PSEUDO_REGISTER): Shift up to 128 to accommodate VFPv3.
+       (REG_ALLOC_ORDER): Adjust for VFPv3.
+       (reg_class): Add VFP_D0_D7_REGS, VFP_LO_REGS, VFP_HI_REGS.
+       (REG_CLASS_NAMES): Add entries corresponding to VFP_D0_D7_REGS,
+       VFP_LO_REGS, VFP_HI_REGS.
+       (REG_CLASS_CONTENTS): Likewise. Extend contents for VFP_REGS.
+       (IS_VFP_CLASS): Define macro.
+       (SECONDARY_OUTPUT_RELOAD_CLASS, SECONDARY_INPUT_RELOAD_CLASS): Use
+       IS_VFP_CLASS.
+       (REGISTER_MOVE_COST): Likewise.
+       * config/arm/arm-protos.h (vfp3_const_double_rtx): Add prototype.
+       * config/arm/vfp.md (VFPCC_REGNUM): Redefine as 127.
+       (*arm_movsi_vfp, *thumb2_movsi_vfp, *movsfcc_vfp)
+       (*thumb2_movsfcc_vfp, *abssf2_vfp, *negsf2_vfp, *addsf3_vfp)
+       (*subsf3_vfp, *divsf_vfp, *mulsf_vfp, *mulsf3negsf_vfp)
+       (*mulsf3addsf_vfp, *mulsf3subsf_vfp, *mulsf3negsfaddsf_vfp)
+       (*extendsfdf2_vfp, *truncdfsf2_vfp, *truncsisf2_vfp)
+       (*truncsidf2_vfp, fixuns_truncsfsi2, fixuns_truncdfsi2)
+       (*floatsisf2_vfp, *floatsidf2_vfp, floatunssisf2)
+       (floatunssidf2, *sqrtsf2_vfp, *cmpsf_split_vfp)
+       (*cmpsf_trap_split_vfp, *cmpsf_vfp, *cmpsf_trap_vfp): Use 't'
+       where appropriate for single-word registers.
+       (*movsf_vfp, *thumb2_movsf_vfp, *movdf_vfp, *thumb2_movdf_vfp):
+       As above. Fix type attributes.
+       * config/arm/constraints.md (register_contraint "t"): Define.
+       (register_constraint "w"): Change to D0-D15, or D0-D31 for
+       VFPv3/NEON.
+       (register_constraint "x"): Define.
+       (constraint "Dv"): Define.
+
+2007-07-03  Geoffrey Keating  <geoffk@apple.com>
+
+       * tree.h (DECL_ALIGN): Prevent use on a FUNCTION_DECL.
+
+2007-07-03  Tom Tromey  <tromey@redhat.com>
+
+       * c-parser.c (objc_pq_context): Removed.
+       (objc_need_raw_identifier): Likewise.
+       (c_parser) <objc_pq_context>: New field.
+       <objc_need_raw_identifier>: Likewise.
+       (OBJC_NEED_RAW_IDENTIFIER): Removed.
+       (c_lex_one_token): Update.
+       (c_parser_objc_protocol_definition): Update.
+       (c_parser_objc_method_definition): Update.
+       (c_parser_objc_methodproto): Update.
+       (c_parser_declspecs): Update.
+
+2007-07-03  David Ung  <davidu@mips.com>
+
+       * config/mips/mips.c (mips_issue_rate): Return 4 for 74K processors.
+
+2007-07-03  David Ung  <davidu@mips.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi: Document -march=74kf3_2.
+       * config/mips/mips.h (PROCESSOR_74KF3_2): New processor_type.
+       (TUNE_74K): Check for it.
+       * config/mips/mips.c (mips_cpu_info): Add 74kf3_2.
+       (mips_rtx_cost_data): Add an entry for PROCESSOR_74KF3_2.
+       * config/mips/mips.md (cpu): Add 74kf3_2.
+       * config/mips/74k.md (r74k_int_logical, r74k_int_arith, r74k_int_nop)
+       (r74k_int_cmove, r74k_int_mult, r74k_int_mul3, r74k_int_mfhilo)
+       (r74k_int_mthilo, r74k_int_div, r74k_int_call, r74k_int_jump)
+       (r74k_int_load, r74k_int_store, r74k_unknown, r74k_multi): Add
+       74kf3_2 to the CPU list.
+       (r74kf3_2_fadd, r74kf3_2_fmove, r74kf3_2_fload, r74kf3_2_fstore)
+       (r74kf3_2_fmul_sf, r74kf3_2_fmul_df, r74kf3_2_fdiv_sf)
+       (r74kf3_2_fdiv_df, r74kf3_2_frsqrt_sf, r74kf3_2_frsqrt_df)
+       (r74kf3_2_fcmp, r74kf3_2_fcvt, r74kf3_2_fxfer_to_c1)
+       (r74kf3_2_fxfer_from_c1): New insn reservations.
+
+2007-07-03  Richard Sandiford  <richard@codesourcery.com>
+           David Ung  <davidu@mips.com>
+
+       * doc/invoke.texi: Replace -march=24kf with -march=24kf2_1 and
+       -march=24kx with -march=24kf1_1.  Likewise 24ke[fx], 34k[fx]
+       and 74k[fx].  Document aliases for the new options.
+       * config/mips/mips.h (PROCESSOR_24KF): Rename to...
+       (PROCESSOR_24KF2_1): ...this.
+       (PROCESSOR_24KX): Rename to...
+       (PROCESSOR_24KF1_1): ...this.
+       (PROCESSOR_74KF): Rename to...
+       (PROCESSOR_74KF2_1): ...this.
+       (PROCESSOR_74KX): Rename to...
+       (PROCESSOR_74KF1_1): ...this.
+       (TUNE_74K): Update PROCESSOR_* names.
+       * config/mips/mips.c (mips_cpu_info): Add 24kf2_1 as a synonym
+       for 24kf.  Add 24kf1_1 and 24kfx as synonyms for 24kx.  Likewise
+       the 24ke*, 34k* and 74k* processors.  Update PROCESSOR_* names.
+       (mips_rtx_cost_data): Update processor names in comments.
+       (mips_issue_rate): Update PROCESSOR_* names.
+       * config/mips/mips.md (cpu): Rename 24kf to 24kf2_1, 24kx to
+       24kf1_1, 74kf to 74kf2_1 and 74kx to 74kf1_1.
+       * config/mips/24k.md: Rename FPU-related r24k_* insn reservations
+       to r24kf2_1_*.  Rename r24kx_* insn reservations to r24kf1_1_*.
+       Update cpu attribute names.
+       (r24k_fpu_iss): Rename this reservation to...
+       (r24kf2_1_fpu_iss): ...this and update all uses.
+       (r24kx_fpu_iss): Rename this reservation to...
+       (r24kf1_1_fpu_iss): ...this and update all uses.
+       * config/mips/74k.md: Rename FPU-related r74kf_* insn reservations
+       to r74kf2_1_*.  Rename r74kx_* insn reservations to r74kf1_1_*.
+       Update cpu attribute names.
+
+2007-07-01  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/m32r/constraints.md: New file.
+       * config/m32r/m32r.c: Include tm-constrs.h.
+       (small_data_operand): Use satisfies_constraint_* instead of macro.
+       (addr24_operand, gen_compare): Likewise.
+       * config/m32r/m32r.h (REG_CLASS_FROM_LETTER): Remove.
+       (INT8_P, UPPER16_P, UINT32_P, UINT5_P, INVERTED_SIGNED_8BIT,
+       CONST_OK_FOR_LETTER_P, CONST_DOUBLE_OK_FOR_LETTER_P,
+       EXTRA_CONSTRAINT): Likewise.
+       * config/m32r/m32r.md: Include constraints.md.
+       (*movsi_insn): Use satisfies_constraint_* instead of macro.
+       (andsi3, iorsi3, xorsi3, seq_insn+1, sne): Likewise.
+       * config/m32r/predicates.md (conditional_move_operand): Likewise.
+       (two_insn_const_operand, int8_operand, uint16_operand,
+       reg_or_int16_operand, reg_or_uint16_operand,
+       reg_or_cmp_int16_operand, cmp_int16_operand,
+       seth_add3_operand): Likewise.
+
+2007-07-03  Eric Christopher  <echristo@gmail.com>
+
+       * libgcc2.h: Conditionally declare __bswapsi2 and
+       __bswapdi2.
+       
+2007-07-03  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * ddg.c (check_sccs): Define only if ENABLE_CHECKING is
+       defined.
+
+2007-07-03  Rainer Orth  <ro@TechFak.Uni-Bielefeld.DE>
+
+       PR target/28307
+       * gthr-posix.h [SUPPORTS_WEAK && GTHREAD_USE_WEAK]
+       (__gthrw_pragma): Provide default definition.
+       (__gthrw2): Use it.
+       * gthr-posix.c (__gthrw_pragma): Define.
+
+2007-07-03  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-sccvn.c (set_ssa_val_to): Check for operand_equal_p
+       before declaring inequality.
+
+2007-07-03  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * combine.c (recog_for_combine): Log the success or failure of
+         matching new insn patterns against the machine description in
+         detailed dumps.
+
+2007-07-03  Revital Eres  <eres@il.ibm.com>
+
+       * ddg.c (print_sccs): New function.
+       (check_sccs): New function.
+       (create_ddg_all_sccs): Use it.
+       * ddg.h (print_sccs): Declare.
+       * modulo-sched.c (sms_order_nodes): Call print_sccs.
+
+2007-07-03  Uros Bizjak  <ubizjak@gmail.com>
+
+       * targhooks.h (default_mode_for_suffix): New function declaration.
+       * targhooks.c (default_mode_for_suffix): New default target hook.
+       * target.h (struct c): New structure in the targetm struct.
+       (mode_for_suffix): New target hook as part of struct c.
+       target-def.h (TARGET_C_MODE_FOR_SUFFIX): Define as
+       default_mode_for_suffix.
+       (TARGET_C): New define.
+       * c-lex.c: Include "target.h".
+       (interpret_float): Use targetm.c.mode_for_suffix to determine
+       the mode for a given non-standard suffix.
+       Makefile.in (c-lex.o): Depend on $(TARGET_H).
+
+       * config/i386/i386.c (ix86_c_mode_for_suffix): New static function.
+       (TARGET_C_MODE_FOR_SUFFIX): Define to ix86_c_mode_for_suffix.
+
+       * doc/extend.texi (Floating Types): New node.  Document __float80 and
+       __float128 types.  Document 'w', 'W', 'q' and 'Q' suffixes.
+
+2007-07-03  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/32506
+       * config/sh/sh.md (udivsi3_i1_media): Use target_reg_operand
+       predicate instead of target_operand.
+       (divsi3_i1_media, divsi3_media_2): Likewise.
+
+2007-07-02  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree.h (alias_sets_might_conflict_p): Rename into
+       alias_sets_must_conflict_p.
+       * alias.c (alias_sets_might_conflict_p): Likewise.
+       (alias_sets_conflict_p): Use it.
+       (objects_must_conflict_p): Likewise.
+       * c-common.c (strict_aliasing_warning): Adjust.
+
+2007-07-02  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * rtlhooks.c (gen_lowpart_if_possible): Check for
+       invalid subreg before calling gen_lowpart_SUBREG.
+
+2007-07-02  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/darwin9.h: Add copyright notice.
+       (LINK_COMMAND_SPEC): Add comment.
+       (DARWIN_LIBSYSTEM_HAS_UNWIND): Define.
+       * config/rs6000/darwin.h (MD_UNWIND_SUPPORT): Conditionalise on
+       DARWIN_LIBSYSTEM_HAS_UNWIND.
+
+2007-07-02  Jakub Jelinek  <jakub@redhat.com>
+
+       PR libgomp/32468
+       * omp-low.c (check_combined_parallel): New function.
+       (lower_omp_parallel): Call it via walk_stmts, set
+       OMP_PARALLEL_COMBINED if appropriate.
+       (determine_parallel_type): If OMP_FOR resp. OMP_SECTIONS
+       isn't the only statement in WS_ENTRY_BB or OMP_RETURN
+       the only one in PAR_EXIT_BB and not OMP_PARALLEL_COMBINED,
+       don't consider it as combined parallel.
+
+2007-07-02  Richard Sandiford  <richard@codesourcery.com>
+
+       * configure.ac (gcc_gxx_include_dir): Use $(libsubdir_to_prefix).
+       (gcc_tooldir): Likewise.
+       * configure: Regenerate.
+       * Makefile.in (libsubdir_to_prefix): New variable, based on the
+       old configure.ac gcc_tooldir setting.
+       (prefix_to_exec_prefix): New variable.
+       (DRIVER_DEFINES): Use $(libsubdir_to_prefix)$(prefix_to_exec_prefix)
+       rather than $(unlibsubdir)/../ to derive TOOLDIR_BASE_PREFIX.
+
+2007-07-02  Daniel Berlin  <dberlin@dberlin.org>
+
+       Fix PR tree-optimization/32583
+       Fix PR tree-optimization/32584
+       * tree-ssa-pre.c (phi_translate): Always pass seen bitmap.
+       (phi_translate_set): Use phi_translate directly now.
+       (make_values_for_stmt): Don't value number RHS if we already know
+       it is constant.
+
+2007-07-02  Steve Ellcey  <sje@cup.hp.com>
+           Jim Wilson <wilson@specifix.com>
+
+       PR target/31684
+       * haifa-sched.c (add_to_speculative_block): Change copy_rtx to
+       copy_insn.
+
+2007-07-02  Sandra Loosemore  <sandra@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/mips-protos.h (mips16e_save_restore_info): New struct.
+       (mips16e_output_save_restore): Declare.
+       (mips16e_save_restore_pattern_p): Likewise.
+       * config/mips/mips.h (GENERATE_MIPS16E_SAVE_RESTORE): New macro.
+       * config/mips/mips.c (MIPS_MAX_FIRST_STACK_STEP): Return 0x7f8
+       for GENERATE_MIPS16E_SAVE_RESTORE.  Return 0x400 for TARGET_MIPS16
+       && !GENERATE_MIPS16E_SAVE_RESTORE && !TARGET_64BIT.
+       (BITSET_P): New global macro, extracted from...
+       (mips_for_each_saved_reg): ...here.
+       (mips16e_save_restore_info): New struct.
+       (mips16e_s2_s8_regs, mips16e_a0_a3_regs): New variables.
+       (mips16e_save_restore_regs): New variable.
+       (mips_split_plus, mips16e_find_first_register): New functions.
+       (mips16e_mask_registers): New function.
+       (compute_frame_size): Expand the commentary before the function.
+       Enforce the MIPS16e save and restore register range restrictions.
+       Pad the general register save area at the low end.
+       (mips16e_save_restore_reg, mips16e_build_save_restore)
+       (mips16e_save_restore_pattern_p, mips16e_add_register_range)
+       (mips16e_output_save_restore, mips16e_collect_propagate_value)
+       (mips16e_collect_argument_save, mips16e_collect_argument_saves):
+       New functions.
+       (mips_expand_prologue, mips_expand_epilogue): Handle
+       GENERATE_MIPS16E_SAVE_RESTORE.
+       * config/mips/mips.md (*mips16e_save_restore): New pattern.
+
+2007-07-02  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/31966
+       PR tree-optimization/32533
+       * tree-if-conv.c (add_to_dst_predicate_list): Use "edge", not
+       "basic_block" description as its third argument.  Update function
+       calls to get destination bb from "edge" argument.  Save "cond" into
+       aux field of the edge.  Update prototype for changed arguments.
+       (if_convertible_loop_p): Clear aux field of incoming edges if bb
+       contains phi node.
+       (find_phi_replacement_condition): Operate on incoming edges, not
+       on predecessor blocks.  If there is a condition saved in the
+       incoming edge aux field, AND it with incoming bb predicate.
+       Return source bb of the first edge.
+       (clean_predicate_lists): Clean aux field of outgoing node edges.
+       (tree_if_conversion): Do not initialize cond variable. Move
+       variable declaration into the loop.
+       (replace_phi_with_cond_gimple_modify_stmt): Remove unneded
+       initializations of new_stmt, arg0 and arg1 variables.
+
+2007-07-02  Jakub Jelinek  <jakub@redhat.com>
+
+       * tree-nrv.c (dest_safe_for_nrv_p): Grok any handled_component_p,
+       SSA_NAMEs, RESULT_DECLs and PARM_DECLs.
+
+2007-07-02  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa.c (useless_type_conversion_p): Document
+       future intent as defining the middle-end type system.
+       Re-structure to call langhook last, group by type class,
+       mark questionable parts.
+
+2007-07-02  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow.h (types_compatible_p): Declare.
+       * tree-ssa.c (types_compatible_p): New function.
+       * ipa-type-escape.c (discover_unique_type): Use
+       types_compatible_p instead of lang_hooks.types_compatible_p.
+       * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Likewise.
+       * tree-vn.c (expressions_equal_p): Likewise.
+       * tree.c (fields_compatible_p): Likewise.
+       * tree-ssa-dom.c (avail_expr_eq): Likewise.
+       (cprop_operand): Use useless_type_conversion_p instead of
+       lang_hooks.types_compatible_p.
+       * tree-inline.c (setup_one_parameter): Likewise.
+       (declare_return_variable): Likewise.
+       * tree-nrv.c (tree_nrv): Likewise.
+       * tree-ssa-ccp.c (maybe_fold_offset_to_array_ref): Likewise.
+       (maybe_fold_offset_to_component_ref): Likewise.
+       (maybe_fold_offset_to_reference): Likewise.
+       * tree-ssa-copy.c (may_propagate_copy): Likewise.
+       (merge_alias_info): Likewise.
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Likewise.
+       * tree-ssa-phiopt.c (conditional_replacement): Likewise.
+       * tree-ssa-reassoc.c (optimize_ops_list): Likewise.
+       * tree-tailcall.c (find_tail_calls): Likewise.
+       * tree-vect-generic.c (expand_vector_operations_1): Likewise.
+       * gimplify.c (canonicalize_addr_expr): Likewise.
+       (fold_indirect_ref_rhs): Likewise.
+       (gimplify_addr_expr): Likewise.  Swap parameters to cpt_same_type.
+       (cpt_same_type): Likewise.
+       (check_pointer_types_r): Swap parameters to cpt_same_type
+       where appropriate.
+       * fold-const.c (fold_convert): Revert fix for PR15988.
+       * tree-inline.c (setup_one_parameter): Instead fix it here by
+       using fold_build1 instead of fold_convert and checking for
+       error_mark_node.  Convert only if the conversion is necessary.
+
+2007-07-02  Joseph Myers  <joseph@codesourcery.com>
+
+       * configure.ac: Check for .gnu_attribute on Power.
+       * configure: Regenerate.
+       * config/rs6000/rs6000.c (rs6000_file_start): If supported, output
+       attribute for floating-point ABI.
+
+2007-07-02  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/32230
+       PR tree-optimization/32477
+       * tree-vect-analyze.c (vect_analyze_data_refs): Fail if base 
+       address is a constant.
+
+2007-07-02  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (mipsisa32-*-elf*, mipsisa32el-*-elf*)
+       (mipsisa32r2-*-elf*, mipsisa32r2el-*-elf*)
+       (mipsisa64-*-elf*, mipsisa64el-*-elf*): Combine top-level
+       stanzas.  Use the first part of the triplet to set MIPS_ISA_DEFAULT.
+       Remove redundant setting of MASK_FLOAT64 and MASK_64BIT for the
+       64-bit targets.  Add support for *-elfoabi*.
+       * config/mips/t-isa3264 (MULTILIB_OPTIONS, MULTILIB_DIRNAMES): Use
+       different settings if $(tm_defines) does not select the EABI.
+       (MULTILIB_EXCLUSIONS): Define in those circumstances.
+       * config/mips/mips.h (MIPS_ISA_LEVEL_OPTION_SPEC): New macro.
+       (MIPS_ARCH_OPTION_SPEC): Likewise.
+       (MIPS_ISA_LEVEL_SPEC): Likewise.
+       (OPTION_DEFAULT_SPECS): Use MIPS_ARCH_OPTION_SPEC.
+       * config/mips/elfoabi.h: New file.
+
+2007-07-02  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow.h (tree_ssa_useless_type_conversion_1): Rename to ...
+       (useless_type_conversion_p): ... this.
+       * tree-ssa.c (tree_ssa_useless_type_conversion_1): Rename to ...
+       (useless_type_conversion_p): ... this.
+       * builtins.c (fold_builtin_memory_op): Rename
+       tree_ssa_useless_type_conversion_1 to useless_type_conversion_p.
+       * tree-cfg.c (verify_expr): Likewise.
+       * tree-ssa-address.c (tree_ssa_useless_type_conversion_1): Likewise.
+       * tree-ssa-ccp.c (ccp_fold): Likewise.
+       * tree-ssa-copy.c (may_propagate_copy): Likewise.
+       * tree-ssa-dom.c (eliminate_redundant_computations): Likewise.
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Likewise.
+       * tree-ssa-loop-niter.c (refine_bounds_using_guard): Likewise.
+       * tree-ssa-pre.c (eliminate): Likewise.
+       * tree-ssa.c (delete_tree_ssa): Likewise.
+       (tree_ssa_useless_type_conversion): Likewise.
+       * tree.c (build2_stat): Likewise.
+
+2007-07-01  Daniel Berlin  <dberlin@dberlin.org>
+
+       Fix PR tree-optimization/32571
+       * tree-ssa-sccvn.c (visit_use): Shortcut copies to avoid
+       simplifying them.
+
+2007-07-01  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-sccvn.c (copy_reference_ops_from_ref): Handle constants
+       and other expected operations explicitly, change default to
+       gcc_unreachable. 
+
+2007-07-01  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config/arm/arm.c (arm_cannot_copy_insn_p): Do not expect a
+       PARALLEL.
+       * config/arm/arm.md (pic_add_dot_plus_four, pic_add_dot_plus_eight)
+       (tls_load_dot_plus_eight): Move the label number into the unspec.
+       * config/arm/thumb2.md (pic_load_dot_plus_four): Likewise.
+
+2007-07-01  Andreas Schwab  <schwab@suse.de>
+
+       * dwarf2out.c (initial_return_save): Define only if used.
+
+2007-07-01  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       Unreverting Richard's Revert of:
+
+       2007-06-27  Richard Sandiford  <richard@codesourcery.com>
+
+       * dce.c (deletable_insn_p_1): New function, split out from...
+       (deletable_insn_p): ...here.  Only treat bare USEs and CLOBBERs
+       specially, not those inside PARALLELs.  Remove BODY argument
+       and adjust recursive call accordingly.
+       (prescan_insns_for_dce): Update call to delete_insn_p.
+
+2007-07-01  Vladimir Yanovsky  <yanov@il.ibm.com>
+           Revital Eres  <eres@il.ibm.com>
+
+       * ddg.c (create_ddg_all_sccs): Fix missed
+       initialization of scc_nodes.
+
+2007-07-01  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/32559
+       * fold-const.c (fold-binary) [PLUS_EXPR]: Convert ~X + X to 1 or
+       X + ~X to 1 only for INTEGRAL_TYPE_P type.
+
+2007-06-30  Joseph Myers  <joseph@codesourcery.com>
+
+       * configure.ac: Check for .gnu_attribute on MIPS.
+       * configure, config.in: Regenerate.
+       * config/mips/mips.c (mips_file_start): If supported, output
+       attribute for floating-point ABI.
+
+2007-06-30  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32433
+       * config/i386/i386.md (ffssi2): Expand as ffs_cmove for TARGET_CMOVE.
+       (ffs_cmove): New expander to expand using ctz pattern.
+       (*ffs_cmove): Remove pattern.
+       (*ffs_no_cmove): Enable only for !TARGET_CMOVE.
+       (ffsdi2): Expand using ctz pattern.
+       (*ffs_rex64): Remove pattern.
+
+2007-06-30  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR rtl-optimization/32296
+       * pa.md (return): Delete pattern.
+       (return_internal): Remove "(const_int 1)" from pattern.
+       (epilogue): Use return_internal pattern for trivial returns.
+       * pa-protos.h (hppa_can_use_return_insn_p): Delete declaration.
+       * pa.c (hppa_can_use_return_insn_p): Delete function.  Include "df.h".
+
+2007-06-30  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-pre.c (is_exception_related): New function
+       (can_value_number_operation): Use it.
+
+2007-06-30  Daniel Berlin  <dberlin@dberlin.org>
+       
+       Fix PR tree-optimization/32540
+       Fix PR tree-optimization/31651
+
+       * tree-ssa-sccvn.c: New file.
+
+       * tree-ssa-sccvn.h: Ditto.
+       
+       * tree-vn.c: Include tree-ssa-sccvn.h
+       (val_expr_paid_d): Removed.
+       (value_table): Ditto.
+       (vn_compute): Ditto.
+       (val_expr_pair_hash): Ditto.
+       (val_expr_pair_expr_eq): Ditto.
+       (copy_vuses_from_stmt): Ditto.
+       (vn_delete): Ditto.
+       (vn_init): Ditto.
+       (shared_vuses_from_stmt): Ditto.
+       (print_creation_to_file): Moved up.
+       (sort_vuses): Ditto.
+       (sort_vuses_heap): Ditto.
+       (set_value_handle): Make non-static.
+       (make_value_handle): Ditto.
+       (vn_add): Rewritten to use sccvn lookups.
+       (vn_add_with_vuses): Ditto.
+       (vn_lookup): Ditto (and second argument removed).
+       (vn_lookup_with_vuses): Ditto.
+       (vn_lookup_or_add): Ditto (and second argument removed);
+       (vn_lookup_or_add_with_vuses): Ditto.
+       (vn_lookup_with_stmt): New.
+       (vn_lookup_or_add_with_stmt): Ditto.
+       (create_value_handle_for_expr): Ditto.
+
+       * tree-ssa-pre.c: Include tree-ssa-sccvn.h.
+       (seen_during_translate): New function.
+       (phi_trans_lookup): Use iterative_hash_expr, not vn_compute.
+       (phi_trans_add): Ditto.
+       (constant_expr_p): FIELD_DECL is always constant.
+       (phi_translate_1): Renamed from phi_translate, add seen bitmap.
+       Use constant_expr_p.
+       Avoid infinite recursion on mutually valued expressions.
+       Change callers of vn_lookup_or_add.
+       (phi_translate): New function.
+       (compute_antic_safe): Allow phi nodes.
+       (create_component_ref_by_pieces): Update for FIELD_DECL change.
+       (find_or_generate_expression): Rewrite slightly.
+       (create_expression_by_pieces): Updated for vn_lookup_or_add
+       change.
+       Update VN_INFO for new names.
+       (insert_into_preds_of_block): Update for new names.
+       (add_to_exp_gen): New function.
+       (add_to_sets): Use vn_lookup_or_add_with_stmt.
+       (find_existing_value_expr): Rewrite to changed vn_lookup.
+       (create_value_expr_from): Ditto, and use add_to_exp_gen.
+       (try_look_through_load): Removed.
+       (try_combine_conversion): Ditto.
+       (get_sccvn_value): New function.
+       (make_values_for_phi): Ditto.
+       (make_values_for_stmt): Ditto.
+       (compute_avail): Rewritten for vn_lookup_or_add changes and to use
+       SCCVN.
+       (init_pre): Update for SCCVN changes.
+       (fini_pre): Ditto.
+       (execute_pre): Ditto.
+
+       * tree-flow.h (make_value_handle): Declare.
+       (set_value_handle): Ditto.
+       (sort_vuses_heap): Ditto.
+       (vn_lookup_or_add_with_stmt): Ditto.
+       (vn_lookup_with_stmt): Ditto.
+       (vn_compute): Remove.
+       (vn_init): Ditto.
+       (vn_delete): Ditto.
+       (vn_lookup): Update arguments.
+
+       * Makefile.in (tree-ssa-pre.o): Add tree-ssa-sccvn.h
+       (tree-vn.o): Ditto.
+       (tree-ssa-sccvn.o): New.
+       (OBJS-common): Add tree-ssa-sccvn.o
+       
+2007-06-30  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c/4076
+       * c-typeck.c (build_external_ref): Don't mark as used if called
+       from itself.
+       * calls.c (rtx_for_function_call): Likewise.
+       
+2007-06-30  Richard Sandiford  <richard@codesourcery.com>
+
+       Revert:
+
+       2007-06-27  Richard Sandiford  <richard@codesourcery.com>
+
+       * dce.c (deletable_insn_p_1): New function, split out from...
+       (deletable_insn_p): ...here.  Only treat bare USEs and CLOBBERs
+       specially, not those inside PARALLELs.  Remove BODY argument
+       and adjust recursive call accordingly.
+       (prescan_insns_for_dce): Update call to delete_insn_p.
+
+2007-06-30  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * combine.c (combine_validate_cost): New parameter NEWOTHERPAT.
+       (try_combine): Move potential calls to undo_all() so they happen
+       before we commit to using the combined insns.
+
+2007-06-30  Jan Hubicka  <jh@suse.cz>
+
+       * loop-unroll.c (unroll_loop_runtime_iterations): Unshare newly emit
+       code.
+
+2007-06-30  Thomas Neumann  <tneumann@users.sourceforge.net>
+
+       * ipa.c (cgraph_postorder): Cast according to the coding conventions.
+       (cgraph_remove_unreachable_nodes): Likewise.
+       * ipa-cp.c (ipcp_propagate_stage): Use BOTTOM instead of integer 0.
+       * ipa-inline.c (update_caller_keys): Cast according to the coding
+       conventions.
+       (cgraph_decide_recursive_inlining): Likewise.
+       (cgraph_decide_inlining_of_small_function): Likewise.
+       (try_inline): Likewise.
+       (cgraph_decide_inlining_incrementally): Likewise.
+       * ipa-pure-const.c (get_function_state): Likewise.
+       (scan_function): Likewise.
+       (analyze_function): Likewise.
+       (static_execute): Likewise.
+       * ipa-reference.c (scan_for_static_refs): Likewise.
+       (merge_callee_local_info): Likewise.
+       (analyze_function): Use type safe memory macros.
+       (static_execute): Likewise. Cast according to the coding conventions.
+       * ipa-type-escape.c (scan_for_regs): Cast according to the coding
+       conventions.
+       * ipa-utils.c (searchc): Likewise. Avoid using C++ keywords as variable
+       names.
+       (ipa_utils_reduced_inorder): Likewise. Use type safe memory macros.
+       * ipa-utils.h (struct ipa_dfa_info): Avoid using C++ keywords as
+       variable names.
+
+2007-06-29  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/30024
+       * emit-rtl.c (init_emit_once): Intilize const_tiny_rtx[0]
+       for complex modes (both int and real).
+
+2007-06-29  Jan Hubicka  <jh@suse.cz>
+
+       * cse.c: Rever accidentally comitted TODO_verify_rtl_sharing change.
+
+2007-06-29  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/32372
+       * cse.c (cse_insn): Avoid invalid sharing in between register note and
+       the insn pattern.
+
+2007-06-29  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/32335
+       * config/avr/avr.c: Include dataflow header file.
+       (expand_prologue): Adjust for prologue insn change.
+       * config/avr/avr.md (call_prologue_saves): Only modify REG_SP once
+       inside a insn.
+
+2007-06-29  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32493
+       * gimplify.c (gimplify_call_expr): Ignore variable argument parts
+       during type verification.
+
+2007-06-29  Jan Hubicka  <jh@suse.cz>
+
+       * recog.c (validate_change_rtx_1): Unshare TO argument.
+
+2007-06-29  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/24659
+       * tree-vect-transform.c (vectorizable_call): Handle
+       (nunits_in == nunits_out / 2) and (nunits_out == nunits_in / 2) cases.
+
+       * config/i386/sse.md (vec_pack_sfix_v2df): New expander.
+       * config/i386/i386.c (enum ix86_builtins)
+       [IX86_BUILTIN_VEC_PACK_SFIX]: New constant.
+       (struct bdesc_2arg) [__builtin_ia32_vec_pack_sfix]: New builtin
+       description.
+       (ix86_init_mmx_sse_builtins): Define all builtins with 2 arguments as
+       const using def_builtin_const.
+       (ix86_expand_binop_builtin): Remove bogus assert() that insn wants
+       input operands in the same modes as the result.
+       (ix86_builtin_vectorized_function): Handle BUILT_IN_LRINT.
+
+2007-06-29  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * df-problems.c (df_set_unused_notes_for_mw): Fix formatting.
+       (df_set_dead_notes_for_mw): Likewise.
+
+2007-06-29  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * c-common.c (pointer_int_sum): Do the negation in sizetype.
+
+2007-06-28  DJ Delorie  <dj@redhat.com>
+
+       * config/m32c/m32c.h (OVERRIDE_OPTIONS): Omit unneeded semicolon.
+
+2007-06-28  Geoffrey Keating  <geoffk@apple.com>
+
+       * doc/invoke.texi (C++ Dialect Options): Document
+       fvisibility-ms-compat.
+       * c.opt (fvisibility-ms-compat): New.
+
+2007-06-28  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR tree-opt/32417
+       * tree-affine.c (aff_combination_add_elt): Handle
+       pointer addition specially.
+
+2007-06-28  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/rs6000/rs6000.c (rs6000_function_ok_for_sibcall): Ensure
+       decl is non-external for AIX ABI.
+
+2007-06-28  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/predicates.md (current_file_function_operand):
+       Ensure the symbol is non-external for AIX ABI.
+
+2007-06-28  Nick Clifton  <nickc@redhat.com>
+
+       * common.opt (fipa-matrix-reorg): Add Optimization attribute.
+       (fdce, fdse, fpredictive-commoning): Likewise.
+
+2007-06-28 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
+
+       PR other/31400
+       * gcc.c (process_command): Recognize the new -static-libgfortran
+       option.
+
+2007-06-27  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/32418
+       * config/m32c/m32c.c (m32c_eh_return_stackadj_rtx): Dataflow fix:
+       Use a call clobbered hard reg instead of a pseudo reg.
+
+2007-06-27  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.md (load_gbr): Use correct operand constraint.
+
+2007-06-27  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/32479
+       * config/sh/sh.md (udivsi3): Don't wrap the sequence with
+       REG_LIBCALL and REG_RETVAL notes.
+       (divsi3, mulsi3): Likewise.
+       (mulhisi3): Likewise.  Use emit_libcall_block.
+       (umulhisi3, smulsi3_highpart, umulsi3_highpart_i): Likewise.
+
+2007-06-27  Seongbae Park  <seongbae.park@gmail.com>
+
+       PR rtl-optimization/32481
+       * combine.c (adjust_for_new_dest): Rescan the changed insn.
+
+2007-06-27  Richard Sandiford  <richard@codesourcery.com>
+
+       * dce.c (deletable_insn_p_1): New function, split out from...
+       (deletable_insn_p): ...here.  Only treat bare USEs and CLOBBERs
+       specially, not those inside PARALLELs.  Remove BODY argument
+       and adjust recursive call accordingly.
+       (prescan_insns_for_dce): Update call to delete_insn_p.
+
+2007-06-27  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32492
+       * tree.h (fold_convertible_p): Declare.
+       * fold-const.c (fold_convertible_p): New function.
+       * gimplify.c (gimplify_call_expr): Use fold_convertible_p
+       instead of lang_hooks.types_compatible_p.
+
+2007-06-26  Jan Hubicka  <jh@suse.cz>
+
+       * fwprop.c (try_fwprop_subst): Use validate_unshare_change.
+       * postreload.c (reload_cse_simplify_set): Instead of copying the rtx
+       early use validate_unshare_change.
+       (reload_combine): Likewise.
+       * recog.c (change_t): New field unshare.
+       (validate_change_1): Rename from validate_change; add argument unshare.
+       (validate_change): Turn into wrapper of validate_change_1; update
+       prototype for bools.
+       (validate_unshare_change): New.
+       (confirm_change_group): Unshare changes if asked for; avoid unnecesary
+       calls of df_insn_rescan.
+       * recog.h (validate_change): Replace ints by bools.
+       (validate_unshare_change): Declare.
+
+2007-06-26  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * tree.def (VEC_WIDEN_MULT_LO_EXPR): Corrected string name.
+       
+2007-06-26  Steve Ellcey  <sje@cup.hp.com>
+
+       * builtins.c (expand_builtin_next_arg): Change Pmode to ptr_mode.
+
+2007-06-25  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-inline.c (cgraph_mark_inline): Assert that we never inline
+       uninlinable call.
+       (cgraph_decide_inlining_of_small_function, cgraph_decide_inlining,
+       cgraph_decide_inlining_incrementally): Move uninlinability checks to
+       places other call site specific checks are performed.
+
+2007-06-25  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR tree-opt/32421
+       * tree-vect-transform.c (vectorizable_operation): Convert
+       POINTER_PLUS_EXPR over to PLUS_EXPR.
+
+2007-06-25  Chao-ying Fu  <fu@mips.com>
+
+       * doc/rtl.texi (Machine Modes): Document QQ, HQ, SQ, DQ, TQ,
+       UQQ, UHQ, USQ, UDQ, UTQ, HA, SA, DA, TA, UHA, USA, UDA, and UTAmodes.
+       Document MODE_FRACT, MODE_UFRACT, MODE_ACCUM, MODE_UACCUM.
+       Document GET_MODE_IBIT, and GET_MODE_FBIT.
+
+       * machmode.h (VECTOR_MODE_P): Test MODE_VECTOR_FRACT,
+       MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM, MODE_VECTOR_UACCUM.
+       (SCALAR_FRACT_MODE_P, SCALAR_UFRACT_MODE_P, ALL_SCALAR_FRACT_MODE_P,
+       SCALAR_ACCUM_MODE_P, SCALAR_UACCUM_MODE_P, ALL_SCALAR_ACCUM_MODE_P,
+       SIGNED_SCALAR_FIXED_POINT_MODE_P, UNSIGNED_SCALAR_FIXED_POINT_MODE_P,
+       ALL_SCALAR_FIXED_POINT_MODE_P, FRACT_MODE_P, UFRACT_MODE_P,
+       ALL_FRACT_MODE_P, ACCUM_MODE_P, UACCUM_MODE_P, ALL_ACCUM_MODE_P,
+       SIGNED_FIXED_POINT_MODE_P, UNSIGNED_FIXED_POINT_MODE_P,
+       ALL_FIXED_POINT_MODE_P): New define.
+       (CLASS_HAS_WIDER_MODES_P): Test MODE_FRACT, MODE_UFRACT, MODE_ACCUM,
+       MODE_UACCUM.
+       (GET_MODE_IBIT, GET_MODE_FBIT): New define.
+
+       * mode-classes.def (MODE_FRACT, MODE_UFRACT, MODE_ACCUM, MODE_UACCUM,
+       MODE_VECTOR_FRACT, MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM,
+       MODE_VECTOR_UACCUM): New mode classes.
+
+       * machmode.def: Document FRACT_MODE, UFRACT_MODE, ACCUM_MODE,
+       UACCUM_MODE, ADJUST_IBIT, and ADJUST_FBIT.
+       Add QQ, HQ, SQ, DQ, TQ, UQQ, UHQ, USQ, UDQ, UTQ, HA, SA, DA, TA, UHA,
+       USA, UDA, and UTA.
+
+       * genmodes.c (struct mode_data): Add ibit and fbit fields.
+       (blank_mode): Initialize ibit and fbit.
+       (adj_ibit, adj_fbit): New to adjust ibit and fbit.
+       (vector_class): Handle MODE_FRACT, MODE_UFRACT, MODE_ACCUM,
+       MODE_UACCUM.
+       (new_adjust): Change required_class to required_class_from and
+       required_class_to for testing within a range.
+       (complete_mode): Handle MODE_FRACT, MODE_UFRACT, MODE_ACCUM,
+       MODE_UACCUM, MODE_VECTOR_FRACT, MODE_VECTOR_UFRACT, MODE_VECTOR_ACCUM,
+       MODE_VECTOR_UACCUM.
+       (FRACT_MODE, UFRACT_MODE, ACCUM_MODE, UACCUM_MODE): New define.
+       (make_fixed_point_mode): New.
+       (_ADD_ADJUST): Change C to C1 and C2.
+       (ADJUST_BYTESIZE, ADJUST_ALIGNMENT, ADJUST_FLOAT_FORMAT): Change to
+       use a range for machine classes.
+       (ADJUST_IBIT, ADJUST_FBIT): New.
+       (emit_insn_modes_h): Output defines of CONST_MODE_IBIT and
+       CONST_MODE_FBIT.
+       (emit_mode_adjustments): Handle MODE_VECTOR_FRACT, MODE_VECTOR_UFRACT,
+       MODE_VECTOR_ACCUM, MODE_VECTOR_UACCUM.
+       Emit adjustment for ibit and fbit.
+       (emit_mode_ibit, emit_mode_fbit): New.
+       (emit_insn_modes_c): Add emit_mode_ibit and emit_mode_fbit.
+
+2007-06-25  Nathan Froyd  <froydnj@codesourcery.com>
+
+       * config/rs6000/spe.md (*frob_ti_tf_2): Specify an input_operand
+       as the source of the set.
+
+2007-06-25  Roman Zippel <zippel@linux-m68k.org>
+
+       * config/m68k/m68k.h (DATA_REGNO_P, ADDRESS_REGNO_P, INT_REGNO_P,
+       FP_REGNO_P): Use IN_RANGE.
+       (REGNO_OK_FOR_DATA_P, REGNO_OK_FOR_FP_P): Remove.
+       (REGNO_OK_FOR_INDEX_NONSTRICT_P, REGNO_OK_FOR_BASE_NONSTRICT_P): New.
+       (DATA_REG_P): Use DATA_REGNO_P.
+       (FP_REG_P): Use FP_REGNO_P.
+       (ADDRESS_REG_P): Use ADDRESS_REGNO_P.
+       * config/m68k/m68k.c (m68k_legitimate_base_reg_p): Use
+       REGNO_OK_FOR_INDEX_NONSTRICT_P, REGNO_OK_FOR_BASE_NONSTRICT_P.
+
+2007-06-24  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/30563
+       * cgraphunit.c (cgraph_analyze_function): Fix ordering problem.
+
+2007-06-24  Sebastian Pop  <sebpop@gmail.com>
+
+       PR middle-end/32461
+       * fold-const.c (fold_binary): Strip nops of operand 0
+       of BIT_NOT_EXPR before calling operand_equal_p.
+       * testsuite/gcc.dg/tree-ssa/pr32461-1.c: New.
+       * testsuite/gcc.dg/tree-ssa/pr32461-2.c: New.
+
+2007-06-23  Mark Mitchell  <mark@codesourcery.com>
+
+       * doc/extend.texi: Document that dllimport and dllexport imply
+       default visibility.
+       * tree.c (handle_dll_attribute): Set DECL_VISIBILITY on the
+       imported or exported declaration, including type declarations.
+       * c-common.c (handle_visibility_attribute): Check for conflicts
+       with dllimport/dllexport.
+       (c_determine_visibility): Handle dllimport/dllexport as an
+       explicit visibility atttribute.
+
+2007-06-23  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/16876
+       PR middle-end/29478
+       * tree.h (CALL_CANNOT_INLINE_P): New macro to access static_flag
+       for CALL_EXPRs.
+       * tree-inline.c (initialize_inlined_parameters): Do not call
+       lang_hooks.tree_inlining.convert_parm_for_inlining.
+       * cgraphbuild.c (initialize_inline_failed): Set inline failed
+       reason for mismatched types.
+       * gimplify.c (gimplify_call_expr): Verify the call expression
+       arguments match the called function type signature.  Otherwise
+       mark the call expression to be not considered for inlining
+       using CALL_CANNOT_INLINE_P flag.
+       * ipa-inline.c (cgraph_mark_inline): Honor CALL_CANNOT_INLINE_P on the
+       edges call expression.
+       (cgraph_decide_inlining_of_small_function): Likewise.
+       (cgraph_decide_inlining): Likewise.
+       * c-objc-common.h (LANG_HOOKS_TREE_INLINING_CONVERT_PARM_FOR_INLINING):
+       Remove define.
+       * c-tree.h (c_convert_parm_for_inlining): Remove declaration.
+       * c-typeck.c (c_convert_parm_for_inlining): Remove.
+       * langhooks-def.h (lhd_tree_inlining_convert_parm_for_inlining):
+       Remove declaration.
+       (LANG_HOOKS_TREE_INLINING_CONVERT_PARM_FOR_INLINING): Remove define.
+       * langhooks.c (lhd_tree_inlining_convert_parm_for_inlining):
+       Remove.
+       * langhooks.h (struct lang_hooks_for_tree_inlining): Remove
+       convert_parm_for_inlining member.
+
+2007-06-23  Richard Earnshaw  <rearnsha@arm.com>
+
+       PR target/31152
+       * arm.md (negscc): Match the correct operand for optimized LT0 test.
+       Remove optimization for GT.
+
+2007-06-23  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/32437
+       * dce.c (deletable_insn_p): Add extra parameter and recurse if insn
+       is a PARALLEL.
+       (prescan_insns_for_dce): Add extra parameter.
+       
+2007-06-23  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/31541
+       * gimplify.c (mark_addressable): New function.
+       (gimplify_modify_expr_rhs, gimplify_addr_expr, gimplify_expr): Use it.
+
+2007-06-22  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/32374
+       * expr.c (store_constructor): Do not clobber non-zeroed memory. 
+
+2007-06-22  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32413
+       * config/i386/i386.c (ix86_register_move_cost): Rise the cost of
+       moves between MMX/SSE registers to at least 8 units to prevent
+       ICE caused by non-tieable SI/HI/QImodes in SSE registers. 
+
+2007-06-22  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (override_options): Correct x86_sahf
+       setting condition.
+
+2007-06-21  David Daney  <ddaney@avtrex.com>
+
+       PR target/32406
+       * config/mips/mips.md (define_constants): Rename UNSPEC_EH_RECEIVER
+       to UNSPEC_NONLOCAL_GOTO_RECEIVER globally.
+       (exception_receiver): Renamed to ...
+       (nonlocal_goto_receiver): ... this.
+
+2007-06-22  Roman Zippel <zippel@linux-m68k.org>
+
+       * df-scan.c (df_read_modify_subreg_p): Use REGMODE_NATURAL_SIZE.
+       (df_def_record_1): Set (DF_REF_READ_WRITE | DF_REF_PARTIAL) for
+       partial register accesses.
+
+2007-06-21  Adam Nemet  <anemet@caviumnetworks.com>
+
+       * fold-const.c (debug_fold_checksum): Move it under
+       ENABLE_FOLD_CHECKING.
+
+2007-06-21  Sebastian Pop  <sebpop@gmail.com>
+
+       PR middle-end/20623
+       * tree.h (debug_fold_checksum): Declared.
+       * fold-const.c (build_fold_addr_expr_with_type_1): New.
+       (build_fold_addr_expr_with_type, build_fold_addr_expr): Use 
+       build_fold_addr_expr_with_type_1.
+       (fold_addr_expr, debug_fold_checksum): New.
+       (fold_checksum_tree): Don't fold TREE_CHAIN of an SSA_NAME.
+       (fold_unary, fold_comparison, split_address_to_core_and_offset):
+       Use fold_addr_expr.
+       
+2007-06-21  Sebastian Pop  <sebpop@gmail.com>
+
+       PR tree-optimization/19590
+       * tree-vrp.c (adjust_range_with_scev): Set the range when the result
+       of scev is a constant.
+
+2007-06-21  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * df-problems.c (df_note_bb_compute): Made computation of live
+       info consistent with df_lr.
+
+2007-06-21  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/32453
+       * tree-vrp.c (extract_range_from_assert): Build POINTER_PLUS_EXPR
+       for pointer anti-range.
+
+2007-06-21  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c (processor_target_table): Increase maximum
+       skip from 7 byte to 10 byte for Pentium Pro, Core 2 Duo and
+       default 64bit.
+
+       * config/i386/linux.h (ASM_OUTPUT_MAX_SKIP_ALIGN): Ensure 8
+       byte alignment if > 8 byte alignment is preferred.
+       * config/i386/x86-64.h (ASM_OUTPUT_MAX_SKIP_ALIGN): Likewise.
+
+2007-06-21  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/31866
+       * tree-ssa-coalesce.c (create_outofssa_var_map): Do nothing
+       if ASM_EXPR's input is not a SSA_NAME.
+
+       PR middle-end/32362
+       * omp-low.c (lookup_decl_in_outer_ctx): Don't ICE if t is NULL,
+       but decl is a global var, instead return decl.
+       * gimplify.c (gimplify_adjust_omp_clauses_1): Add shared clauses
+       even for is_global_var decls, if they are private in some outer
+       context.
+
+2007-06-21  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/32451
+       * tree-ssa-threadupdate.c (thread_single_edge): Fixup edge flags.
+
+2007-06-21  Christian Bruel  <christian.bruel@st.com>
+
+       * config/sh/sh-protos.h (sh_loads_bankedreg_p): Declare.
+       * config/sh/sh.c (sh_loads_bankedreg_p): New function.
+       (push_regs): Changed saving order or banked registers.
+       (sh_expand_epilogue): Likewise.
+       * config/sh/sh.h (BANKED_REGISTER_P): New macro.
+       (FIRST_BANKED_REG): Likewise.
+       (LAST_BANKED_REG): Likewise.
+       * config/sh/sh.md (banked) New attribute.
+       (in_delay_slot): Check banked attribute.
+       
+2007-06-20  Sebastian Pop  <sebpop@gmail.com>
+
+       PR tree-optimization/32075
+       * tree-data-ref.c (subscript_dependence_tester_1, 
+       analyze_miv_subscript, analyze_overlapping_iterations,
+       add_distance_for_zero_overlaps, build_classic_dist_vector,
+       subscript_dependence_tester_1, analyze_overlapping_iterations,
+       subscript_dependence_tester, access_functions_are_affine_or_constant_p,
+       compute_affine_dependence, compute_all_dependences): Pass loop_nest 
+       to evolution_function_is_affine_multivariate_p.
+
+2007-06-20  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * df-scan.c (df_get_call_refs): Be prepared for MEMs inside CLOBBERs.
+
+2007-06-20  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/32335
+       * config/m32c/m32c.c (m32c_emit_epilogue): Use new HImode epilogue
+       for TARGET_A16.
+       * config/m32c/prologue.md (epilogue_exitd_16): New.
+       (epilogue_reit_16): New.
+       (epilogue_exitd): Rename to epilogue_exitd_24.
+       (epilogue_reit): Rename to epilogue_reit_24.
+
+2007-06-20  Seongbae Park  <seongbae.park@gmail.com>
+           Maxim Kuvyrkov  <mkuvyrkov@ispras.ru>
+
+       * dbgcnt.def (global_alloc_at_func, global_alloc_at_reg):
+       New counters.
+       * haifa-sched.c (queue_to_ready): Don't requeue next insn
+       if dbg_cnt (sched_insn) reaches the limit.
+       (choose_ready): New parameter INSN_PTR and new return value.
+       (schedule_block): Handle dbg_cnt (sched_insn). Handle
+       the new return value from choose_ready.
+       * global.c (global_aloc): New dbgcnt global_alloc_at_reg.
+       (rest_of_handle_global_alloc): New global_alloc_at_func.
+
+2007-06-20  Adam Nemet  <anemet@caviumnetworks.com>
+
+       PR tree-optimization/25737
+       * tree.h (struct tree_struct_field_tag): Add new field alias_set.
+       (SFT_NONADDRESSABLE_P, SFT_ALIAS_SET): New macros.
+       * tree-flow.h (struct fieldoff): Add new field alias_set.
+       * tree-ssa-structalias.c (push_fields_onto_fieldstack): Add new
+       argument addressable_type.  Set alias_set of fieldoff.
+       * tree-ssa-alias.c (create_sft): Add new argument alias_set.
+       (create_overlap_variables_for): Pass alias_set from fieldoff to
+       create_sft.
+       * alias.c (get_alias_set): Use alias_set from SFT if set.
+
+2007-06-20  Hui-May Chang  <hm.chang@apple.com>
+
+       * config/i386/darwin.h (ASM_OUTPUT_COMMON): Print the size
+       of a variable as an unsigned HOST_WIDE_INT integer.
+
+2007-06-20  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR rtl-optimization/32405
+       * loop-iv.c (iv_get_reaching_def): Fail for partial defs.
+
+2007-06-20  Jakub Jelinek  <jakub@redhat.com>
+
+       * Makefile.in (omega.o): Depend on $(DIAGNOSTIC_H).
+
+       PR middle-end/31959
+       * builtins.c: Include diagnostic.h.
+       (expand_builtin_expect): Make gcc_assert more permissive.
+       * Makefile.in (builtins.o): Depend on $(DIAGNOSTIC_H).
+
+       PR inline-asm/32109
+       * gimplify.c (gimplify_asm_expr): Issue error if type is addressable
+       and !allows_mem.
+
+       PR middle-end/32285
+       * calls.c (precompute_arguments): Also precompute CALL_EXPR arguments
+       if ACCUMULATE_OUTGOING_ARGS.
+
+2007-06-19  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       * config/m68hc11/m68hc11.c: Include dataflow header file.
+       (m68hc11_reorg): Port to dataflow.
+
+2007-06-19  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * df.h (DF_FIRST_OPTIONAL_PROBLEM): Removed.
+       (struct df_problem.free_blocks_on_set_blocks): New field.
+       (struct dataflow.optional_p): New field.
+       (df_bb_regno_last_use_find, df_insn_regno_def_p): Removed.
+       (df_live_set_all_dirty): New function.
+       * df-scan.c (df_scan_alloc): Initialize optional_p.
+       (problem_SCAN): Initialize free_blocks_on_set_blocks.
+       * df-core.c (df_set_blocks): Removed use of
+       DF_FIRST_OPTIONAL_PROBLEM.  Now uses
+       df_problem.free_blocks_on_set_blocks to determine which blocks are
+       recycled.
+       (df_remove_problem): Removed use of DF_FIRST_OPTIONAL_PROBLEM.
+       (df_finish_pass): Removed use of DF_FIRST_OPTIONAL_PROBLEM.  Now
+       uses dataflow.optional_p to determine if problem should be
+       deleted.
+       (rest_of_handle_df_initialize): Only start live problem if 
+       -02 or above.
+       (df_bb_regno_last_use_find, df_insn_regno_def_p): Removed.
+       * df-problems.c (df_ru_alloc, df_rd_alloc, df_lr_alloc,
+       df_live_alloc, df_urec_alloc, df_note_alloc): set optional_p.
+       (problem_RU, problem_RD, problem_LR, problem_UREC, problem_CHAIN,
+       problem_NOTE): Initialize free_blocks_on_set_blocks.
+       (df_lr_bb_local_compute): Recompute luids if df_live problem is
+       not active.
+       (df_live_set_all_dirty, df_note_alloc): New function.
+       * regrename.c (merge_overlapping_regs): Change DF_LIVE_* to
+       df_get_live_*.
+       * sched_ebb.c (compute_jump_reg_dependencies): Ditto.
+       * postreload.c (reload_combine): Ditto.
+       * cse.c (cse_extended_basic_block): Ditto.
+       * regmove.c (mark_flags_life_zones): Ditto.
+       * rtlfactoring.c (split_blocks_after_seqs, split_pattern_seq,
+       erase_matching_seqs): Ditto.
+       * bt-load.c (compute_defs_uses_and_gen): Ditto.
+       * integrate (allocate_initial_values): Ditto.
+       * combine.c (reg_dead_at_p): Ditto.
+       * resource.c (mark_target_live_regs): Ditto.
+       * sched-rgn.c (check_live_1, update_live_1): Ditto.
+       * config/sh/sh.c (find_r0_life_regions): Ditto.
+       * global.c (rest_of_handle_global_alloc): Only add back df_live
+       for -O > 1.
+       * local-alloc.c (rest_of_handle_local_alloc): Only remove
+       df_live for -O > 1.
+       * ifcvt.c (dead_or_predicable): Change DF_LIVE_* to
+       df_get_live_*.
+       (if_convert): Make sure df_live is there at -O == 1.
+       (pass_if_after_combine): Cleanup flags.
+       * init-regs.c (initialize_uninitialized_regs): Make sure df_live
+       is there at -O == 1.
+       
+2007-06-19  Seongbae Park  <seongbae.park@gmail.com>
+
+       * config/arm/arm.c (arm_get_frame_offsets): Set
+       offsets->locals_base to avoid negative stack size.
+       (thumb1_expand_prologue): Assert on negative stack size.
+
+2007-06-19  Sebastian Pop  <sebpop@gmail.com>
+
+       PR tree-optimization/32367
+       * tree-chrec.h (build_polynomial_chrec): Verify that the left hand side 
+       of the chrec has no evolution in that loop.
+       * testsuite/gcc.dg/tree-ssa/pr32367.c: New.
+
+2007-06-19  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c: Include "df.h".
+       (xtensa_builtin_saveregs): Use adjust_address instead of
+       change_address.
+       (xtensa_va_start): Invoke make_tree with sizetype for
+       expand_builtin_saveregs and then convert the result to a pointer.
+       Use POINTER_PLUS_EXPR.  Use size_int instead of build_int_cst.
+       (xtensa_gimplify_va_arg_expr): Use size_int instead of build_int_cst.
+       Subtract argument size from index value as integers and then use
+       POINTER_PLUS_EXPR to add the result to the array address.
+       
+2007-06-19  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/32335
+       * config/m32c/m32c.c: Include dataflow header file.
+       (m32c_emit_prologue): Adjust for prologue insn change.
+       * config/m32c/prologue.md (prologue_enter_16): Only modify SP_REGNO
+       once inside a PARALLEL. Assume frame size passed in operand 0
+       includes space to save the fb register.
+       (prologue_enter_24): Likewise.
+       (epilogue_exitd): Only modify SP_REGNO once inside a PARALLEL.
+
+2007-06-19  David Daney  <ddaney@avtrex.com
+
+       PR target/32313
+       * config/mips/mips.md (cprestore): Mark $gp as used.
+
+2007-06-19  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/32369
+       * config/frv/frv.c (frv_ifcvt_modify_tests): Dataflow merge fix.
+       (frv_ifcvt_modify_insn): Likewise.
+
+2007-06-19  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-structalias.c (handle_ptr_arith): Make sure to
+       only handle positive offsets that fit in a HOST_WIDE_INT.
+
+2007-06-19  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_emit_swsqrtsf): Filter out infinity
+       result of rsqrt insn for zero input argument to avoid NaN.
+
+2007-06-19  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/31950
+       * tree-ssa-alias-warnings.c (ffan_walker): Punt on MTAGs.
+
+2007-06-19  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/32353
+       * tree-ssa-structalias.c (set_uids_in_ptset): Also handle RESULT_DECL.
+
+2007-06-19  Nick Clifton  <nickc@redhat.com>
+
+       * config/m32r/linux.h (LIB_SPEC): Always imply -lpthread for -pthread.
+
+2007-06-18  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32389
+       * config/i386/i386.h (enum ix86_stack_slot): Add SLOT_VIRTUAL.
+       * config/i386/i386.c (assign_386_stack_local): Assert that
+       SLOT_VIRTUAL is valid only before virtual regs are instantiated.
+       (ix86_expand_builtin) [IX86_BUILTIN_LDMXCSR, IX86_BUILTIN_STMXCSR]:
+       Use SLOT_VIRTUAL stack slot instead of SLOT_TEMP.
+       * config/i386/i386.md (truncdfsf2, truncxf<mode>2): Ditto.
+
+2007-06-18  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/ia64.h (LIBGCC2_TF_CEXT): New.
+
+2007-06-18  Seongbae Park  <seongbae.park@gmail.com>
+
+       PR rtl-optimization/32321
+       * gcse.c (replace_store_insn): Update the note before
+       calling emit_insn_after.
+
+2007-06-18  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/32355
+       * gcse (rest_of_handle_gcse): Add call to df_finish_pass after
+       cse_main.
+       * df-problems.c (df_note_bb_compute): Fix dumping info.
+       
+2007-06-18  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_expand_epilogue): Emit a return
+       insn with emit_jump_insn.
+
+2007-06-18  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/32383
+       * targhooks.c (default_builtin_reciprocal): Add new bool argument.
+       * targhooks.h (default_builtin_reciprocal): Update prototype.
+       * target.h (struct gcc_target): Update builtin_reciprocal.
+       * doc/tm.texi (TARGET_BUILTIN_RECIPROCAL): Update description.
+       * tree-ssa-math-opts (execute_cse_reciprocals): Skip statements
+       where arg1 is not SSA_NAME.  Pass true to targetm.builtin_reciprocal
+       when fndecl is in BUILT_IN_MD class.
+       (execute_convert_to_rsqrt): Ditto.
+
+       * config/i386/i386.c (ix86_builtin_reciprocal): Update for new bool
+       argument.  Convert IX86_BUILTIN_SQRTPS code only when md_fn is true.
+       Convert BUILT_IN_SQRTF code only  when md_fn is false.
+
+2007-06-18  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * bt-load.c (move_btr_def): Fix the order of arguments
+       to validate_replace_rtx.
+
+2007-06-18  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/m68k-devices.def: Add 54450..54455.
+
+2007-06-17  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR rtl-optimization/32366
+       * simplify-rtx.c (simplify_unary_operation_1) [FLOAT_TRUNCATE,
+       FLOAT_EXTEND]: Prevent non-scalar modes from entering
+       significand_size.
+
+2007-06-17  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       PR middle-end/32349
+       * modulo-sched (generate_reg_moves): Added rescan parameter and if
+       this is true, rescan insn being modified.
+       (sms_schedule): Added rescan parameter.
+       (rest_of_handle_sms): Moved freeing of dominance info to before
+       getting out of cfg_layout.
+       
+2007-06-17  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/m68k.h (ISA_HAS_FF1, ISA_HAS_MVS_MVZ): New.
+       * config/m68k/m68k.md: Use ISA_HAS_FF1 and ISA_HAS_MVS_MVZ as
+       appropriate.
+
+       * config/m68k/m68k.c (all_isas): Remove FL_CF_FPU and
+       FL_CF_EMAC from the entry for isac.
+
+       * config/m68k/predicates.md (const_call_operand): Adjust comment.
+       (const_sibcall_operand): New.
+       (sibcall_operand): Use it.
+       * config/m68k/m68k.c (FL_FOR_isa_c): Not ISA_B compatible.
+       (m68k_isas): ISAC does not imply FPU or EMAC.
+       (override_options): Add ISA_C logic for symbolic jump & call.
+
+2007-06-17  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * config/sparc/sparc.c (sparc_vis_init_builtins): Retrieve the
+       return mode from the builtin itself.
+       (sparc_fold_builtin): Fix cast of zero constant.
+
+2007-06-16  Uros Bizjak  <ubizjak@gmail.com>
+
+       * targhooks.c (default_builtin_reciprocal): New default target hook.
+       * targhooks.h (default_builtin_reciprocal): Add prototype.
+       * hooks.c (hook_tree_tree_bool_null): Remove hook.
+       * hooks.h (hook_tree_tree_bool_null): Remove prototype.
+       * target-def.h (TARGET_BUILTIN_RECIPROCAL): Define as
+       default_builtin_reciprocal.
+
+2007-06-16  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/31723
+       * hooks.c (hook_tree_tree_bool_null): New hook.
+       * hooks.h (hook_tree_tree_bool_null): Add prototype.
+       * tree-pass.h (pass_convert_to_rsqrt): Declare.
+       * passes.c (init_optimization_passes): Add pass_convert_to_rsqrt.
+       * tree-ssa-math-opts.c (execute_cse_reciprocals): Scan for a/func(b)
+       and convert it to reciprocal a*rfunc(b).
+       (execute_convert_to_rsqrt): New function.
+       (gate_convert_to_rsqrt): New function.
+       (pass_convert_to_rsqrt): New pass definition.
+       * target.h (struct gcc_target): Add builtin_reciprocal.
+       * target-def.h (TARGET_BUILTIN_RECIPROCAL): New define.
+       (TARGET_INITIALIZER): Initialize builtin_reciprocal with
+       TARGET_BUILTIN_RECIPROCAL.
+       * doc/tm.texi (TARGET_BUILTIN_RECIPROCAL): Document.
+
+       * config/i386/i386.h (TARGET_RECIP): New define.
+       * config/i386/i386.md (divsf3): Expand by calling ix86_emit_swdivsf
+       for TARGET_SSE_MATH and TARGET_RECIP when flag_finite_math_only and
+       flag_unsafe_math_optimizations are set, flag_trapping_math is unset
+       and not optimizing for size.
+       (*rcpsf2_sse): New insn pattern.
+       (*rsqrtsf2_sse): Ditto.
+       (rsqrtsf2): New expander.  Expand by calling ix86_emit_swsqrtsf
+       for TARGET_SSE_MATH and TARGET_RECIP when flag_finite_math_only and
+       flag_unsafe_math_optimizations are set, flag_trapping_math is unset
+       and not optimizing for size.
+       (sqrt<mode>2): Expand SFmode operands by calling ix86_emit_swsqrtsf
+       for TARGET_SSE_MATH and TARGET_RECIP when flag_finite_math_only and
+       flag_unsafe_math_optimizations are set, flag_trapping_math is unset
+       and not optimizing for size.
+       * config/i386/sse.md (divv4sf): Expand by calling ix86_emit_swdivsf
+       for TARGET_SSE_MATH and TARGET_RECIP when flag_finite_math_only and
+       flag_unsafe_math_optimizations are set, flag_trapping_math is unset
+       and not optimizing for size.
+       (*sse_rsqrtv4sf2): Do not export.
+       (sqrtv4sf2): Ditto.
+       (sse_rsqrtv4sf2): New expander.  Expand by calling ix86_emit_swsqrtsf
+       for TARGET_SSE_MATH and TARGET_RECIP when flag_finite_math_only and
+       flag_unsafe_math_optimizations are set, flag_trapping_math is unset
+       and not optimizing for size.
+       (sqrtv4sf2): Ditto.
+       * config/i386/i386.opt (mrecip): New option.
+       * config/i386/i386-protos.h (ix86_emit_swdivsf): Declare.
+       (ix86_emit_swsqrtsf): Ditto.
+       * config/i386/i386.c (IX86_BUILTIN_RSQRTF): New constant.
+       (ix86_init_mmx_sse_builtins): __builtin_ia32_rsqrtf: New
+       builtin definition.
+       (ix86_expand_builtin): Expand IX86_BUILTIN_RSQRTF using
+       ix86_expand_unop1_builtin.
+       (ix86_emit_swdivsf): New function.
+       (ix86_emit_swsqrtsf): Ditto.
+       (ix86_builtin_reciprocal): New function.
+       (TARGET_BUILTIN_RECIPROCAL): Use it.
+       (ix86_vectorize_builtin_conversion): Rename from
+       ix86_builtin_conversion.
+       (TARGET_VECTORIZE_BUILTIN_CONVERSION): Use renamed function.
+       * doc/invoke.texi (Machine Dependent Options): Add -mrecip to
+       "i386 and x86_64 Options" section.
+       (Intel 386 and AMD x86_64 Options): Document -mrecip.
+
+2007-06-15  Andrew Pinski <andrew_pinski@playstation.sony.com>
+           Zdenek Dvorak <dvorakz@suse.cz>
+           Richard Guenther  <rguenther@suse.de>
+           Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * tree-vrp.c (compare_values_warnv): Convert val2 to
+       the type of val1.
+       (extract_range_from_assert): Create
+       POINTER_PLUS_EXPR for pointer types.
+       (extract_range_from_binary_expr): Handle
+       only POINTER_PLUS_EXPR, MIN_EXPR, and MAX_EXPR
+       for pointer types.
+       * doc/c-tree.texi (POINTER_PLUS_EXPR): Document.
+       * tree-ssa-loop-niter.c (split_to_var_and_offset): Handle
+       POINTER_PLUS_EXPR as PLUS_EXPR.
+       (number_of_iterations_lt_to_ne):
+       For pointer types, use sizetype when
+       creating MINUS_EXPR/PLUS_EXPRs.
+       (assert_loop_rolls_lt): For pointer types, use sizetype when
+       creating MINUS_EXPR/PLUS_EXPRs.
+       (number_of_iterations_le): Likewise.
+       (expand_simple_operations): POINTER_PLUS_EXPR are simple also.
+       (derive_constant_upper_bound): Handle POINTER_PLUS_EXPR just
+       like PLUS_EXPR and MINUS_EXPR.
+       * tree-pretty-print.c (dump_generic_node): Handle
+       POINTER_PLUS_EXPR.
+       (op_prio): Likewise.
+       (op_symbol_1): Likewise.
+       * optabs.c (optab_for_tree_code): Likewise.
+       * tree-ssa-loop-manip.c (create_iv): Handle pointer base
+       specially.
+       * tree-tailcall.c (process_assignment): Mention
+       POINTER_PLUS_EXPR in a TODO comment.
+       * tree.c (build2_stat): Assert when trying to use PLUS_EXPR or 
+       MINUS_EXPR with a pointer. Also assert for POINTER_PLUS_EXPR
+       not used with a pointer and an integer type.
+       * tree-scalar-evolution.c (add_to_evolution_1): Convert the
+       increment using chrec_convert_rhs instead of chrec_convert.
+       (follow_ssa_edge_in_rhs): Handle POINTER_PLUS_EXPR like
+       PLUS_EXPR except for the right hand side's type will be
+       sizetype.
+       (interpret_rhs_modify_stmt): Handle POINTER_PLUS_EXPR.
+       (fold_used_pointer_cast): Kill.
+       (pointer_offset_p): Kill.
+       (fold_used_pointer): Kill.
+       (pointer_used_p): Kill.
+       (analyze_scalar_evolution_1 <case GIMPLE_MODIFY_STMT>): Don't
+       call fold_used_pointer.
+       (instantiate_parameters_1): Convert the increment
+       using chrec_convert_rhs instead of chrec_convert.
+       Handle POINTER_PLUS_EXPR as PLUS_EXPR.
+       * builtins.c (get_pointer_alignment): Handle POINTER_PLUS_EXPR
+       instead of PLUS_EXPR.
+       (expand_builtin_strcat): Create a POINTER_PLUS_EXPR instead of
+       PLUS_EXPR for pointers.
+       (std_gimplify_va_arg_expr): Likewise.
+       (fold_builtin_memory_op): Likewise.
+       (fold_builtin_strstr): Likewise.
+       (fold_builtin_strchr): Likewise.
+       (fold_builtin_strrchr): Likewise.
+       (fold_builtin_strpbrk): Likewise.
+       (expand_builtin_memory_chk): Likewise.
+       (fold_builtin_memory_chk): Likewise.
+       (std_expand_builtin_va_start): Use
+       sizetype for the call to make_tree and then convert
+       to the pointer type.
+       (fold_builtin_memchr): Use POINTER_PLUS_EXPR
+       instead of PLUS_EXPR for adding to a pointer.
+       (std_gimplify_va_arg_expr): Use fold_build2 for
+       the creating of POINTER_PLUS_EXPR.  For the BIT_AND_EXPR, cast
+       the operands to sizetype first and then cast the BIT_AND_EXPR
+       back to the pointer type.
+       * fold-const.c (build_range_check): Handle pointer types
+       specially.
+       (extract_array_ref): Look for POINTER_PLUS_EXPR instead
+       of PLUS_EXPR's. Make sure the offset is converted to
+       sizetype.
+       (try_move_mult_to_index): Strip the NOPs from the offset.
+       Remove code argument and replace all uses with PLUS_EXPR.
+       (fold_to_nonsharp_ineq_using_bound): Handle pointer types
+       specially. Don't use a pointer type for MINUS_EXPR.
+       (fold_unary): Handle for (T1)(X op Y),
+       only p+ as that is the only as that can be handled for
+       binary operators now.
+       (fold_binary <case POINTER_PLUS_EXPR>): Add folding of
+       POINTER_PLUS_EXPR.
+       <case PLUS_EXPR>: Add folding of PTR+INT into
+       PTR p+ INT.
+       Don't call try_move_mult_to_index.
+       <case MINUS_EXPR>: Fold (PTR0 p+ A) - (PTR1 p+ B)
+       into (PTR0 - PTR1) + (A - B). Fold (PTR0 p+ A) - PTR1 into
+       (PTR0 - PTR1) + A iff (PTR0 - PTR1) simplifies.
+       Don't call try_move_mult_to_index.
+       (tree_expr_nonnegative_warnv_p): Handle POINTER_PLUS_EXPR.
+       (tree_expr_nonzero_p): Likewise.
+       (fold_indirect_ref_1): Look at POINTER_PLUS_EXPR instead
+       of PLUS_EXPR for the complex expression folding.
+       * tree-chrec.c (chrec_fold_plus_poly_poly): If the
+       first chrec is a pointer type, then the second should
+       be sizetype and not the first's type.
+       For POINTER_PLUS_EXPR, use a different right hand side type.
+       Handle POINTER_PLUS_EXPR like PLUS_EXPR.
+       (chrec_fold_plus_1): For POINTER_PLUS_EXPR, use a
+       different right hand side type.
+       Handle POINTER_PLUS_EXPR like PLUS_EXPR.
+       (chrec_fold_plus): For pointer types, use POINTER_PLUS_EXPR
+       instead of PLUS_EXPR.
+       When either operand is zero, convert the other operand.
+       (chrec_apply): Use chrec_convert_rhs
+       on the argument x instead of chrec_convert.
+       (reset_evolution_in_loop): For pointer types, the new_evol
+       should be sizetype.
+       (convert_affine_scev): For POINTER_PLUS_EXPR, use a
+       different right hand side type.
+       Handle POINTER_PLUS_EXPR like PLUS_EXPR.
+       (chrec_convert_rhs): New function.
+       (chrec_convert_aggressive): For POINTER_PLUS_EXPR, use a
+       different right hand side type.
+       Handle POINTER_PLUS_EXPR like PLUS_EXPR.
+       * tree-chrec.h (chrec_convert_rhs): New prototype.
+       (build_polynomial_chrec): For pointer types, the right hand
+       * tree-ssa-ccp.c (maybe_fold_stmt_indirect): Look for
+       POINTER_PLUS_EXPR instead of PLUS_EXPR's.
+       Remove subtraction case as it is always addition now.
+       Make sure the offset is converted to sizetype.
+       (fold_stmt_r): Don't handle PLUS_EXPR/MINUS_EXPR specially.
+       Handle POINTER_PLUS_EXPR like PLUS_EXPR was handled before.
+       * tree-ssa-loop-ivopts.c (determine_base_object): Abort for 
+       PLUS_EXPR in pointer type.
+       Handle POINTER_PLUS_EXPR.
+       (tree_to_aff_combination): Likewise.
+       (force_expr_to_var_cost): Likewise.
+       (force_expr_to_var_cost): Likewise. Create a POINTER_PLUS_EXPR
+       instead of PLUS_EXPR for pointers.
+       * c-format.c (check_format_arg): Handle POINTER_PLUS_EXPR
+       instead of PLUS_EXPR of pointer types.
+       * tree-stdarg.c (va_list_counter_bump): Handle POINTER_PLUS_EXPR
+       as PLUS_EXPR.
+       (check_va_list_escapes): Likewise.
+       (check_all_va_list_escapes): Likewise.
+       * dwarf2out.c (loc_descriptor_from_tree_1):
+       Handle POINT_PLUS_EXPR as a PLUS_EXPR.
+       * expr.c (expand_expr_real_1): Handle POINTER_PLUS_EXPR.
+       (string_constant): Likewise.
+       * tree-ssa-address.c (tree_mem_ref_addr): When adding
+       the offset to the base, use POINTER_PLUS_EXPR.
+       (add_to_parts): Convert the index to sizetype.
+       (create_mem_ref): Create A POINTER_PLUS_EXPR for the one case.
+       * matrix-reorg.c (collect_data_for_malloc_call): Stmt
+       will now only be either INDIRECT_REF and POINTER_PLUS_EXPR.
+       Offset only holds something for PLUS_EXPR.
+       (ssa_accessed_in_tree): Handle POINTER_PLUS_EXPR just as
+       a PLUS_EXPR.
+       (analyze_transpose): POINTER_PLUS_EXPR will only show up now
+       and not PLUS_EXPR.
+       (analyze_accesses_for_modify_stmt): Likewise.
+       Remove comment about the type being integral type as it is
+       wrong now.
+       (can_calculate_expr_before_stmt): Handle POINTER_PLUS_EXPR as
+       PLUS_EXPR.
+       (transform_access_sites): POINTER_PLUS_EXPR will only show up now
+       and not PLUS_EXPR.
+       Correct the type which the artimentic is done in (is now
+       sizetype).
+       Reindent one loop.
+       * tree-data-ref.c (split_constant_offset): Handle
+       POINTER_PLUS_EXPR
+       * tree-affine.c (tree_to_aff_combination): Likewise.
+       * c-typeck.c (build_unary_op): For pointers create the increment
+       as a sizetype. Create a POINTER_PLUS_EXPR instead of PLUS_EXPR
+       for pointers.
+       * gimplify.c (gimplify_self_mod_expr): Create a
+       POINTER_PLUS_EXPR instead of PLUS_EXPR for pointers.
+       (gimplify_omp_atomic_fetch_op): Handle POINTER_PLUS_EXPR.
+       * tree.def (POINTER_PLUS_EXPR): New tree code.
+       * tree-predcom.c (ref_at_iteration): If we have a pointer
+       type do the multiplication in sizetype.
+       * tree-mudflap.c (mf_xform_derefs_1): Create a
+       POINTER_PLUS_EXPR instead of PLUS_EXPR for pointers.
+       * tree-ssa-forwprop.c 
+       (forward_propagate_addr_into_variable_array_index):
+       Don't expect there to be a cast for the index as that
+       does not exist anymore.
+       (forward_propagate_addr_expr_1): Check for POINTER_PLUS_EXPR
+       instead of PLUS_EXPR.
+       Don't check for the first operand of the POINTER_PLUS_EXPR
+       was the index as it cannot be.
+       Call forward_propagate_addr_into_variable_array_index with
+       the SSA_NAME instead of the statement.
+       * varasm.c (const_hash_1): Handle POINTER_PLUS_EXPR.
+       (compare_constant): Likewise.
+       (copy_constant): Likewise.
+       (compute_reloc_for_constant): Likewise.
+       (output_addressed_constants): Likewise.
+       (initializer_constant_valid_p): Likewise.
+       * tree-ssa.c (tree_ssa_useless_type_conversion_1):
+       Convert the MIN/MAX of the inner type to the outer
+       type before comparing them.
+       * tree-ssa-loop-prefetch.c (idx_analyze_ref): Handle
+       POINTER_PLUS_EXPR instead of PLUS_EXPR.
+       (issue_prefetch_ref): Create a POINTER_PLUS_EXPR instead
+       of PLUS_EXPR for pointers.
+       * tree-inline.c (estimate_num_insns_1): Handle
+       POINTER_PLUS_EXPR.
+       * tree-vect-transform.c (vect_create_addr_base_for_vector_ref): 
+       Create a POINTER_PLUS_EXPR instead of PLUS_EXPR for pointers.
+       (bump_vector_ptr): Create a POINTER_PLUS_EXPR
+       instead of PLUS_EXPR for the pointer increment statement.
+       (vect_update_ivs_after_vectorizer): For pointer types, create
+       POINTER_PLUS_EXPR instead of PLUS_EXPR and also create
+       MULT_EXPR in sizetype.
+       (vect_gen_niters_for_prolog_loop): Add a cast when creating
+       byte_misalign.
+       * tree-object-size.c (plus_expr_object_size): Handle
+       POINTER_PLUS_EXPR instead of PLUS_EXPR.  Removing all the extra
+       code which is trying to figure out which side is a pointer and 
+       is the index.
+       (check_for_plus_in_loops_1): Likewise.
+       (check_for_plus_in_loops): Likewise.
+       * c-common.c (pointer_int_sum): Create a
+       POINTER_PLUS_EXPR instead of PLUS_EXPR for pointers.
+       * tree-ssa-structalias.c (handle_ptr_arith): Handle
+       only POINTER_PLUS_EXPR.  Removing all the extra
+       code which is trying to figure out which side is a pointer and 
+       is the index.
+       * tree-cfg.c (verify_expr): Add extra checking for pointers and
+       PLUS_EXPR and MINUS_EXPR.
+       Also add checking to make sure the operands of POINTER_PLUS_EXPR
+       are correct.
+       * config/frv/frv.c (frv_expand_builtin_va_start): Use sizetype
+       with make_tree, instead of a pointer type.
+       * config/s390/s390.c (s390_va_start): Use POINTER_PLUS_EXPR
+       for pointers instead of PLUS_EXPR.
+       (s390_gimplify_va_arg): Likewise.
+       * config/spu/spu.c (spu_va_start): Create POINTER_PLUS_EXPR
+       instead of PLUS_EXPR when doing addition on pointer
+       types.  Use sizetype for the second operand.
+       (spu_gimplify_va_arg_expr): Likewise.
+       * config/sparc/sparc.c (sparc_gimplify_va_arg): Use 
+       POINTER_PLUS_EXPR instead of PLUS_EXPR when the operand was
+       a pointer.  Don't create a BIT_AND_EXPR for pointer types.
+       * config/i386/i386.c (ix86_va_start): Use POINTER_PLUS_EXPR
+       for the pointer addition and also use size_int/sizetype
+       for the offset.
+       (ix86_gimplify_va_arg): Likewise.
+       Perform BIT_AND_EXPR on sizetype arguments.
+       * config/sh/sh.c (sh_va_start): Call make_tree with sizetype
+       and convert its result to a pointer type.  Use POINTER_PLUS_EXPR
+       for the pointer additions and also use size_int for the offsets.
+       (sh_gimplify_va_arg_expr): Use POINTER_PLUS_EXPR for the pointer
+       additions and also use size_int for the offsets.  Perform
+       BIT_AND_EXPR on sizetype arguments.
+       * config/ia64/ia64.c (ia64_gimplify_va_arg): Use
+       POINTER_PLUS_EXPR for pointers and create the
+       BIT_AND_EXPR in sizetype.
+       * config/rs6000/rs6000.c (rs6000_va_start): Use POINTER_PLUS_EXPR
+       instead of PLUS_EXPR for pointer addition.
+       (rs6000_va_start): Likewise.
+       Also use sizetype for the offset.
+       * config/pa/pa.c (reloc_needed): Handle POINTER_PLUS_EXPR
+       as PLUS_EXPR/MINUS_EXPR.
+       (hppa_gimplify_va_arg_expr): Don't create MINUS_EXPR or
+       PLUS_EXPR for pointers, instead use POINTER_PLUS_EXPR.
+       Don't use BIT_AND_EXPR on a pointer type, convert the
+       expression to sizetype first.
+       * config/mips/mips.c (mips_va_start): Use POINTER_PLUS_EXPR
+       for pointers.
+       (mips_gimplify_va_arg_expr): Likewise.
+       Don't create BIT_AND_EXPR in a pointer type.
+
+2007-06-15  Eric Christopher  <echristo@apple.com>
+
+       * config.gcc (i?86-*-darwin*): Add t-crtfm and t-crtpc.
+       (x86_64-*-darwin*): Ditto.
+       * config/i386/darwin.h (CRTEND_SPEC): New. Add support
+       for above.
+
+2007-06-15  Matthew Wilcox <matthew@wil.cx>
+
+       * doc/extend.texi: Document behavior of __attribute__((aligned))
+       on typedefs.
+
+2007-06-15  Mark Mitchell  <mark@codesourcery.com>
+
+       * rtlanal.c (note_stores): Improve documentation.
+
+2007-06-15  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/elf.h (ASM_GENERATE_INTERNAL_LABEL,
+       LOCAL_LABEL_PREFIX): Delete.
+       * config/bfin/bfin.c (TARGET_ASM_INTERNAL_LABEL): Delete.
+       (bfin_internal_label): Delete.
+
+2007-06-15  Uros Bizjak  <ubizjak@gmail.com>
+
+       * libgcc2.c (CEXT): When compiling L_multc3 and L_divtc3,
+       define to "l" if LIBGCC_LONG_DOUBLE_SIZE == 128,
+       otherwise define to LIBGCC2_TF_CEXT.
+       * config/i386/linux64.h (LIBGCC2_HAS_TF_MODE): New define.
+       (LIBGCC_TF_CEXT): Ditto.
+       (TF_SIZE): Ditto.
+
+2007-06-14  Seongbae Park  <seongbae.park@gmail.com>
+
+       PR rtl-optimization/32339
+       * df-scan.c (df_uses_record): Don't modify flags but just add to
+       it for df_ref_record.
+
+2007-06-14  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * tree-mudflap.c: Fix whitespace issues.
+
+2007-06-15  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (ASM_DOT, ASM_DOTW, ASM_DOTL): Remove.
+
+2007-06-14  Eric Christopher  <echristo@apple.com>
+
+       * config/i386/sse.md (movdi_to_sse): Rewrite body.
+       (movv4sf): Use gcc_unreachable instead of abort.
+
+2007-06-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32268
+       * config/i386/sfp-machine.h (CMPtype): New define.
+       (mach stubs): Use CMPtype instead of int as a return type.
+
+2007-06-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/soft-fp/eqdf2.c, config/soft-fp/eqsf2.c,
+       config/soft-fp/eqtf2.c, config/soft-fp/gedf2.c,
+       config/soft-fp/gesf2.c, config/soft-fp/getf2.c,
+       config/soft-fp/ledf2.c, config/soft-fp/lesf2.c,
+       config/soft-fp/letf2.c, config/soft-fp/unorddf2.c,
+       config/soft-fp/unordsf2.c, config/soft-fp/unordtf2.c,
+       config/soft-fp/soft-fp.h: Update from glibc CVS.
+
+2007-06-14  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/uclinux.h (MFWRAP_SPEC): New.
+
+2007-06-14  Rask Ingemann Lambertsen  <rask@sygehus.dk>
+
+       PR target/32341
+       * config/v850/v850.c: Include dataflow header file.
+       (substitute_ep_register): Fix typo.
+
+2007-06-14  Paolo Bonzini  <bonzini@gnu.org>
+
+       * configure.ac: Fix earlier checkin.
+       * configure: Regenerated.
+
+2007-06-14  Paolo Bonzini  <bonzini@gnu.org>
+
+       * acinclude.m4 (gcc_AC_CHECK_PROG_VER): Remove.
+       * aclocal.m4: Regenerate.
+       * configure.ac: Use ACX_PROG_CC_WARNING_OPTS,
+       ACX_PROG_CC_WARNINGS_ARE_ERRORS,
+       ACX_PROG_CC_WARNING_ALMOST_PEDANTIC, ACX_CHECK_PROG_VER.
+       * configure: Regenerate.
+       * Makefile.in (LOOSE_WARN): Subst loose_warn.
+
+       * Makefile.in (quickstrap): Build libgcc too.
+
+2007-06-14  Paolo Bonzini  <bonzini@gnu.org>
+
+       * configure.ac: Add --enable-checking=df.  Explicitly mention that
+       the variables are initialized as for "release".
+       * df-core.c: Use it.
+       * configure: Regenerate.
+       * config.in: Regenerate.
+
+2007-06-14  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_expand_nonlocal_goto): Use
+       validate_replace_rtx instead of replace_rtx.
+       (xtensa_expand_prologue): Call df_insn_rescan after replace_rtx.
+
+2007-06-14  Danny Smith  <dannysmith@users.sourceforge.net>
+
+       * config/i386/cygming.h (DWARF_FRAME_REGNUM): Define.
+       (DWARF2_UNWIND_INFO): Override default if configured with
+       SJLJ EH disabled.
+       * config/i386/cygwin.h (STARTFILE_SPEC): Add crtbegin.o.
+       (ENDFILE_SPEC): Add crtend.o.
+       * config/i386/mingw32.h (STARTFILE_SEC): Add crtbegin.o.
+       (ENDFILE_SPEC): Add crtend.o.
+       (TARGET_USE_JCR_SECTION): Define.
+       (MD_UNWIND_SUPPORT): Define for 32-bit target.
+
+       * config/i386/cygming-crtbegin.c: New file.
+       * config/i386/cygming-crtend.c: New file.
+
+2007-06-14  Pascal Obry Pascal Obry  <obry@adacore.com>
+
+       * config/i386/w32-unwind.h: New file.
+
+2007-06-13  Eric Christopher  <echristo@apple.com>
+
+       * config/i386/darwin.h (PREFERRED_STACK_BOUNDARY): Don't let
+       the user set a value below STACK_BOUNDARY.
+
+2007-06-13  Thiemo Seufer  <ths@networkno.de>
+
+       * config/mips/linux.h, config/mips/linux64.h (LIB_SPEC): Always
+       imply -lpthread for -pthread.
+
+2007-06-13  Kazu Hirata  <kazu@codesourcery.com>
+
+       * basic-block.h: Remove the prototype for
+       free_basic_block_vars.
+       * cfglayout.h: Remove the prototype for
+       insn_locators_initialize.
+       * tree.h: Remove the prototype for emit_line_note.
+
+       * tree-ssa-pre.c (mergephitemp): Remove.
+       (init_pre): Don't use mergephitemp.
+
+2007-06-13  Eric Christopher  <echristo@apple.com>
+
+       * config/i386/i386.c (override_options): If we've specified
+       an arch then don't use TARGET_SUBTARGET_ISA_DEFAULTs.
+
+2007-06-13  Bob Wilson  <bob.wilson@acm.org>
+
+       * df-scan.c (df_get_entry_block_def_set): Check if STATIC_CHAIN_REGNUM
+       is defined.
+
+2007-06-13  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.h (EH_RETURN_HANDLER_RTX): Use gen_frame_mem.
+       * config/bfin/bfin.md (UNSPEC_VOLATILE_STORE_EH_HANDLER): New constant.
+       (eh_store_handler): New pattern.
+       (eh_return): Emit it instead of a plain move.
+
+2007-06-13  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_init_mmx_sse_builtins)
+       [__builtin_infq, __builtin_fabsq]: Define usign def_builtin.
+       [__builtin_ia32_rsqrtps, __builtin_ia32_rsqrtss]: Define using
+       def_builtin_const.
+
+2007-06-13  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.c (gen_one_bundle): Delete unused local variables.
+       (find_next_insn_start, find_load): New functions.
+       (bfin_reorg): Use them to deal with the fact that parallel insns are
+       no longer represented as a SEQUENCE.
+
+2007-06-13  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * config/sparc/sparc.c (sparc_override_options): Initialize
+       fpu mask correctly.
+
+2007-06-13  Dave Korn  <dave.korn@artimi.com>
+
+       * config/i386/i386.c (ix86_eax_live_at_start_p): Use df_get_live_out.
+
+2007-06-13  Kazu Hirata  <kazu@codesourcery.com>
+
+       * auto-inc-dec.c, c-incpath.c, config/c4x/libgcc.S,
+       config/sh/divcost-analysis, dbgcnt.def, df-core.c,
+       df-problems.c, df-scan.c, df.h, dominance.c, dse.c, regstat.c,
+       tree-data-ref.c, tree-ssa-loop-im.c, tree-ssa-loop-prefetch.c,
+       tree-vect-transform.c: Fix comment typos.  Follow spelling
+       conventions.
+
+2007-06-12  Seongbae Park  <seongbae.park@gmail.com>
+
+       * df-scan.c (df_get_exit-block_use_set): Always add the stack pointer
+       to the exit block use set.
+       (df_insn_delete, df_insn_rescan): Fixed spelling of "deferring". 
+       * gcse.c (cpro_jump): Don't emit barrier in cfglayout mode.
+       * config/sparc/sparc.c (sparc_check_64): Check df != NULL.
+
+2007-06-12  Seongbae Park  <seongbae.park@gmail.com>
+
+       * opts.c (common_handle_option): Handle new option -fdbg-cnt-list.
+       * dbgcnt.c (dbg_cnt_set_limit_by_name): Return value
+       to indicate an error.
+       (dbg_cnt_process_single_pair, dbg_cnt_list_all_counters):
+       New functions.
+       (dbg_cnt_process_opt): Print an error on a bad argument.
+       * dbgcnt.h (dbg_cnt_list_all_counters): New function declaration.
+       * common.opt (-fdbg-cnt-list): New.
+       * doc/invoke.texi (-fdbg-cnt-list,-fdbg-cnt=): New.
+
+2007-06-12  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-ssa-alias.c (finalize_ref_all_pointers): Clear pt_anything
+       flag on ref-all pointers.
+
+2007-06-12  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/31579
+       * expr.c (expand_expr_addr_expr_1): Call expand_expr
+       for the offset with the modifier as EXPAND_INITIALIZER
+       if the modifier is EXPAND_INITIALIZER.
+       (expand_expr_real_1 <case INTEGER_CST>): Don't force to
+       a register if we had an overflow.
+
+2007-06-12  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * real.c (real_isfinite): New.
+       (real_sqrt): Use it.
+       * real.h (real_isfinite): New.
+       * builtins.c: Use it.
+
+2007-06-12  Ian Lance Taylor  <iant@google.com>
+           Daniel Berlin  <dberlin@dberlin.org>
+
+       PR libstdc++/29286
+       * tree.def: Add CHANGE_DYNAMIC_TYPE_EXPR.
+       * tree.h (CHANGE_DYNAMIC_TYPE_NEW_TYPE): Define.
+       (CHANGE_DYNAMIC_TYPE_LOCATION): Define.
+       (DECL_NO_TBAA_P): Define.
+       (struct tree_decl_common): Add no_tbaa_flag field.
+       * tree-ssa-structalias.c (struct variable_info): Add
+       no_tbaa_pruning field.
+       (new_var_info): Initialize no_tbaa_pruning field.
+       (unify_nodes): Copy no_tbaa_pruning field.
+       (find_func_aliases): Handle CHANGE_DYNAMIC_TYPE_EXPR.
+       (dump_solution_for_var): Print no_tbaa_pruning flag.
+       (set_uids_in_ptset): Add no_tbaa_pruning parameter.  Change all
+       callers.
+       (compute_tbaa_pruning): New static function.
+       (compute_points_to_sets): Remove CHANGE_DYNAMIC_TYPE_EXPR nodes.
+       Call compute_tbaa_pruning.
+       * tree-ssa-alias.c (may_alias_p): Test no_tbaa_flag for pointers.
+       * gimplify.c (gimplify_expr): Handle CHANGE_DYNAMIC_TYPE_EXPR.
+       * gimple-low.c (lower_stmt): Likewise.
+       * tree-gimple.c (is_gimple_stmt): Likewise.
+       * tree-ssa-operands.c (get_expr_operands): Likewise.
+       * tree-ssa-dce.c (mark_stmt_if_obviously_necessary): Likewise.
+       * tree-inline.c (estimate_num_insns_1): Likewise.
+       (copy_result_decl_to_var): Likewise.
+       * expr.c (expand_expr_real_1): Likewise.
+       * tree-pretty-print.c (dump_generic_node): Likewise.
+       * tree-inline.c (copy_decl_to_var): Copy DECL_NO_TBAA_P flag.
+       * omp-low.c (omp_copy_decl_2): Likewise.
+       * print-tree.c (print_node): Print DECL_NO_TBAA_P flag.
+       * doc/c-tree.texi (Expression trees): Document
+       CHANGE_DYNAMIC_TYPE_EXPR.
+
+2007-06-12  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * fold-const.c (fold_binary): Guard (X-X) -> 0 transformation
+       with !HONOR_NANS and !HONOR_INFINITIES.
+       * simplify-rtx.c (simplify_binary_operation_1): Likewise.
+
+2007-06-12  Tristan Gingold  <gingold@adacore.com>
+
+       * gcov.c: Comments updated.
+       (source_info): Add file_time field.
+       (source_index): New variable.
+       (mutiple_files): New variable.
+       (generate_results): New function extracted from process_file.
+       (process_file): Save and restore chain of functions, generate
+       results and free structures only if not merging results.
+       (release_structures): File names are now freed in create_file_names
+       (create_file_names): Free previous file names.
+       (find_source): File date is now read here and modifications in
+       source files is checked here.
+       (read_graph_file): Only reverse order of functions for the current
+       object file.
+       (make_gcov_file_name): Do not generate long names if input_name is
+       NULL.
+       (output_lines): If merging results do not display graph, data and
+       runs informations.
+       Checking source file modification is done in find_source.
+
+       * doc/gcov.texi: Append an s to sourcefile.
+
+2007-06-12  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.md (UNSPEC_NOP): New constant.
+       (forced_nop): New pattern.
+       * config/bfin/bfin.c: Include "df.h".
+       (add_to_reg): Use df_regs_ever_live_p instead of regs_ever_live.
+       (bfin_discover_loop): Use df_get_live_in instead of
+       global_live_at_start.
+       (bfin_reorder_loops): Pass 0 to cfg_layout_initialize.  Call
+       df_analyze when done.
+       (gen_one_bundle): Don't generate SEQUENCE insns, just put modes on
+       the insns.  Use QImode for the final insn in a bundle.  Call
+       df_insn_rescan on generated NOPs; use gen_forced_nop instead of
+       gen_nop.
+       (reorder_var_tracking_notes): New function.
+       (bfin_reorg): Pass no argument to split_all_insns.  Don't call
+       update_life_info.  Call df_analyze after scheduling and bundle
+       generation.  Call reorder_var_tracking_notes if generating these
+       notes.  Call df_finish_pass at the end.
+
+2007-06-12  Dirk Mueller  <dmueller@suse.de>
+
+       * optabs.c (debug_optab_libfuncs): fix gcc_assert to
+       a comparison, not an assignment.
+
+2007-06-12  Olivier Hainque  <hainque@adacore.com>
+
+       * tree-nested.c (convert_local_reference): Handle VIEW_CONVERT_EXPR.
+       Request walking the subtrees only, leaving the current is_lhs/val_only
+       untouched.
+       (convert_non_local_reference): Likewise.
+
+2007-06-12  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/m68k-devices.def (52221, 52223, 5253): New.
+
+2007-06-12  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/15353
+       PR tree-optimization/31657
+       * passes.c (init_optimization_passes): Add pass_tree_ifcombine.
+       * timevar.def: Add TV_TREE_IFCOMBINE.
+       * tree-pass.h (pass_tree_ifcombine): Declare.
+       * tree-ssa-ifcombine.c: New file.
+       * tree-ssa-phiopt.c (blocks_in_phiopt_order): Export.
+       * tree-flow.h (blocks_in_phiopt_order): Declare.
+       * Makefile.in (OBJS-common): Add tree-ssa-ifcombine.o.
+       (tree-ssa-ifcombine.o): New dependencies.
+
+2007-06-12  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR rtl-optimization/32293
+       * combine.c (simplify_if_then_else): Truncate return from
+       nonzero_bits() to correct mode.
+
+2007-06-12  Uros Bizjak  <ubizjak@gmail.com>
+
+       * fold-const (fold_binary) [RDIV_EXPR]: Also optimize a/cbrt(b/c)
+       into a*cbrt(c/b) if flag_unsafe_math_optimizations is set.
+
+2007-06-11  Diego Novillo  <dnovillo@google.com>
+
+       * Makefile.in (reload1.o-warn): Remove.
+
+2007-06-11  Seongbae Park <seongbae.park@gmail.com>
+
+       * combine.c (subst): Use reg_overlap_mentioned_p
+       instead of comparing register numbers directly.
+
+2007-06-11  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * reload1.c (mark_home_live_1): Use the mode parameter.
+
+2007-06-11  Kenneth Zadeck <zadeck@naturalbridge.com>
+
+       * df-scan.c (df_insn_delete, df_insn_rescan, df_insn_rescan_all,
+       df_process_deferred_rescans, df_notes_rescan): Fixed spelling of
+       word "deferred".
+       * df-core.c: Ditto.
+
+2007-06-11  Daniel Berlin  <dberlin@dberlin.org>
+
+       * Merge dataflow-branch into mainline (see ChangeLog.dataflow)
+
+2007-06-11  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md ("*movtf_internal): Penalize moves to and
+       from integer registers.
+       (FP mode splitters): Handle TFmode.
+
+2007-06-11  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-ssa-structalias.c (find_what_p_points_to): Return false
+       for ref-all pointers that point-to anything.
+
+2007-06-11  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/arm/arm.c (arm_output_dwarf_dtprel,
+       TARGET_ASM_OUTPUT_DWARF_DTPREL): New.
+
+2007-06-11  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.md (movdi_insn, movsi_insn, movv2hi_insn,
+       movhi_insn, movqi_insn, movsf_insn, movdf_insn): Don't allow constant
+       to memory moves.
+
+2007-06-11  Rafael Ávila de Espíndola  <espindola@google.com>
+
+       * tree.c (signed_or_unsigned_type_for): New.
+       (unsigned_type_for): Use signed_or_unsigned_type_for.
+       (signed_type_for): Use signed_or_unsigned_type_for.
+       * tree.h (signed_or_unsigned_type_for): New.
+       (get_signed_or_unsigned_type): Remove.
+       * fold-const.c (fold_negate_expr): Use signed_type_for instead of
+       lang_hooks.types.signed_type
+       (size_diffop): Likewise.
+       (all_ones_mask_p): Likewise.
+       (build_range_check): Likewise.
+       (fold_cond_expr_with_comparison): Likewise.
+       (fold_cond_expr_with_comparison): Likewise.
+       (unextend): Likewise.
+       (extract_muldiv_1): Likewise.
+       (fold_single_bit_test_into_sign_test): Likewise.
+       (fold_binary): Likewise.
+       (fold_ternary): Likewise.
+       (operand_equal_for_comparison_p): Use signed_or_unsigned_type_for
+       instead of get_signed_or_unsigned_type.
+       * c-objc-common.h (LANG_HOOKS_SIGNED_TYPE): Remove.
+       (LANG_HOOKS_SIGNED_OR_UNSIGNED_TYPE): Remove.
+       * expr.c (signed_or_unsigned_type_for): Use
+       signed_or_unsigned_type_for instead of get_signed_or_unsigned_type.
+       * langhooks.c (get_signed_or_unsigned_type): Remove.
+       (lhd_signed_or_unsigned_type): Remove.
+       * langhooks.h (lang_hooks_for_types): Remove signed_type and
+       signed_or_unsigned_type.
+       (lhd_signed_or_unsigned_type): Remove.
+       * expmed.c (make_tree): Use signed_type_for instead of
+       lang_hooks.types.signed_type.
+       * c-common.c (same_scalar_type_ignoring_signedness): Use
+       c_common_signed_type instead of lang_hooks.types.signed_type.
+       (c_common_unsigned_type): New.
+       (c_common_signed_type): Just call c_common_signed_or_unsigned_type.
+       (shorten_compare): Use c_common_unsigned_type instead of
+       c_common_signed_or_unsigned_type.
+       (c_common_nodes_and_builtins): Use c_common_unsigned_type instead of
+       unsigned_type_for.
+       * convert.c (convert_to_integer): Use signed_type_for instead of
+       lang_hooks.types.signed_type.
+       * langhooks-def.h (LANG_HOOKS_SIGNED_OR_UNSIGNED_TYPE): Remove.
+       (LANG_HOOK_FOR_TYPES_INITIALIZER): Remove LANG_HOOKS_SIGNED_TYPE and
+       LANG_HOOKS_SIGNED_OR_UNSIGNED_TYPE.
+       * c-format.c (check_format_types): Use c_common_unsigned_type
+       instead of unsigned_type_for.
+       * c-decl.c (groakdeclarator): Likewise.
+       * c-typeck.c (convert_for_assignment): Likewise.
+       * c-common.h (c_common_unsigned_type): New.
+
+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.
+
+2007-06-11  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/32279
+       * fold-const (fold_binary) [RDIV_EXPR]: Optimize a/sqrt(b/c)
+       into a*sqrt(c/b) if flag_unsafe_math_optimizations is set.
+
+2007-06-10  Jan Sjodin  <jan.sjodin@amd.com>
+           Sebastian Pop  <sebpop@gmail.com>
+
+       * lambda-code.c (remove_iv): New.
+       (lambda_loopnest_to_gcc_loopnest): Use remove_iv.
+
+2007-06-10  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-data-ref.c (dr_analyze_alias): Handle case smt is NULL.
+       * tree-predcom.c (mark_virtual_ops_for_renaming): Exported.
+       * tree-ssa-loop-prefetch.c: Include optabs.h.
+       (FENCE_FOLLOWING_MOVNT): New macro.
+       (struct mem_ref): Add independent_p and storent_p fields.
+       (record_ref): Initalize the new fields.
+       (gather_memory_references_ref): Return true if the reference
+       could be analysed.
+       (gather_memory_references): Check whether all memory accesses
+       in loop were recorded.
+       (should_issue_prefetch_p): Return false for nontemporal stores.
+       (nontemporal_store_p, mark_nontemporal_store, emit_mfence_after_loop,
+       may_use_storent_in_loop_p, mark_nontemporal_stores): New functions.
+       (determine_loop_nest_reuse): Detect independent memory references.
+       (loop_prefetch_arrays): Call mark_nontemporal_stores.
+       * tree-flow.h (mark_virtual_ops_for_renaming): Declare.
+       * Makefile.in (tree-ssa-loop-prefetch.o): Add OPTABS_H dependency.
+       * config/i386/i386.h (x86_mfence): Declare.
+       (FENCE_FOLLOWING_MOVNT): Return x86_mfence.
+       * config/i386/i386.c (x86_mfence): New variable.
+       (ix86_init_mmx_sse_builtins): Initialize x86_mfence.
+
+       * tree-pretty-print.c (dump_generic_node): Mark nontemporal stores.
+       * optabs.c (init_optabs): Initialize storent_optab.
+       * optabs.h (enum optab_index): Add OTI_storent.
+       (storent_optab): Declare.
+       * genopinit.c (optabs): Add initialization for storent_optab.
+       * tree.h (MOVE_NONTEMPORAL): New macro.
+       * expr.c (expand_assignment, store_expr, store_constructor_field,
+       store_constructor, store_field, expand_expr_real_1): Propagate
+       nontemporality of the expanded store.
+       (emit_storent_insn): New function.
+       * expr.h (expand_assignment, store_expr): Declaration changed.
+       * function.c (assign_parm_setup_reg): Pass false as nontemporality
+       to expand_assignment.
+       * stmt.c (expand_asm_expr): Ditto.
+       * calls.c (initialize_argument_information): Pass false as
+       nontemporality to store_expr.
+       * config/i386/sse.md (storentv4sf, storentv2df, storentv2di,
+       storentsi): New.
+
+2007-06-09  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-structalias.c (set_uids_in_ptset): Add is_deref'd
+       parameter, use it.
+       (find_what_p_points_to): Pass new parameter to set_uids_in_ptset.
+
+2007-06-09  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-data-ref.c (dr_may_alias_p): Check that decl_a != decl_b,
+       and allow DECL_P here.
+
+2007-06-09  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-scalar-evolution.c (follow_ssa_edge_in_rhs,
+       follow_ssa_edge_in_condition_phi, follow_ssa_edge): Keep more precise
+       track of the size of the expression.
+       * cfghooks.c (merge_blocks): Remove block from loops structure only
+       after call of the merge_blocks hook.
+
+2007-06-09  Tom Tromey  <tromey@redhat.com>
+
+       * c-decl.c (grokdeclarator): Added 'deprecated_state' argument.
+       (deprecated_state): Removed.
+       (start_decl): Update.
+       (enum deprecated_states): Moved earlier.
+       (groktypename): Update.
+       (push_parm_decl): Likewise.
+       (grokfield): Likewise.
+       (start_function): Likewise.
+
+2007-06-09  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/32169
+       * tree-vrp.c (extract_range_from_unary_expr): For NOP_EXPR and
+       CONVERT_EXPR, check whether min and max both converted to an
+       overflow infinity representation.
+
+2007-06-08  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * reload1.c (fixup_abnormal_edges): Clear bb field for insns
+       not inserted on the edge.
+
+2007-06-08  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/lib1funcs.asm (__udivsi3): Use hardware divide
+       instructions if they are supported.
+       (__divsi3, __umodsi3, __modsi3): Likewise.
+       (__ashldi3, __ashrdi3, __lshrdi3): New.
+       * config/xtensa/t-xtensa (LIB1ASMFUNCS): Add DImode shift functions.
+
+2007-06-08  Harsha Jagasia <harsha.jagasia@amd.com>
+           Tony Linthicum <tony.linthicum@amd.com>
+
+       * doc/invoke.texi: Add fvect-cost-model flag.
+       * common.opt (fvect-cost-model): New flag.
+       * tree-vectorizer.c (new_stmt_vec_info): Initialize inside and outside
+       cost fields in stmt_vec_info struct for STMT.
+       * tree-vectorizer.h (stmt_vec_info): Define inside and outside cost
+       fields in stmt_vec_info struct and access functions for the same.
+       (TARG_COND_BRANCH_COST): Define cost of conditional branch.
+       (TARG_VEC_STMT_COST): Define cost of any vector operation, excluding
+       load, store and vector to scalar operation.
+       (TARG_VEC_TO_SCALAR_COST): Define cost of vector to scalar operation.
+       (TARG_VEC_LOAD_COST): Define cost of aligned vector load.
+       (TARG_VEC_UNALIGNED_LOAD_COST): Define cost of misasligned vector load.
+       (TARG_VEC_STORE_COST): Define cost of vector store.
+       (vect_estimate_min_profitable_iters): Define new function.
+       * tree-vect-analyze.c (vect_analyze_operations): Add a compile-time
+       check to evaluate if loop iterations are less than minimum profitable
+       iterations determined by cost model or minimum vect loop bound defined
+       by user, whichever is more conservative.
+       * tree-vect-transform.c (vect_do_peeling_for_loop_bound): Add a
+       run-time check to evaluate if loop iterations are less than minimum
+       profitable iterations determined by cost model or minimum vect loop
+       bound defined by user, whichever is more conservative.
+       (vect_estimate_min_profitable_iterations): New function to estimate
+       mimimimum iterartions required for vector version of loop to be
+       profitable over scalar version.
+       (vect_model_reduction_cost): New function.
+       (vect_model_induction_cost): New function.
+       (vect_model_simple_cost): New function.
+       (vect_cost_strided_group_size): New function.
+       (vect_model_store_cost): New function.
+       (vect_model_load_cost): New function.
+       (vectorizable_reduction): Call vect_model_reduction_cost during
+       analysis phase.
+       (vectorizable_induction): Call vect_model_induction_cost during
+       analysis phase.
+       (vectorizable_load): Call vect_model_load_cost during analysis phase.
+       (vectorizable_store): Call vect_model_store_cost during analysis phase.
+       (vectorizable_call, vectorizable_assignment, vectorizable_operation,
+       vectorizable_promotion, vectorizable_demotion): Call
+       vect_model_simple_cost during analysis phase.
+
+2007-06-08  Simon Baldwin  <simonb@google.com>
+
+       * reg-stack.c (get_true_reg): Readability change.  Moved default case
+       label into direct switch statement scope.
+
+2007-06-08  Simon Baldwin  <simonb@google.com>
+
+       * tree-flow-inline.h (var_ann): Replaced erroneous '=' assignment
+       in gcc_assert() with '==' comparison.
+
+2007-06-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (override_options): Merge TARGET_SSE4_2 and
+       TARGET_ABM handling of x86_popcnt variable.
+
+2007-06-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       * doc/extend.texi (X86 Built-in Functions): Document __builtin_fabsq,
+       __builtin_copysignq and __builtin_infq built-in functions.
+
+2007-06-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       * doc/extend.texi (X86 Built-in Functions): Add missing `@item's in
+       SSE4.2 section.  Correct built-in function names in SSE4A section.
+
+2007-06-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/32243
+       * tree-vect-transform.c (vectorizable_type_promotion): Move check
+       for ncopies after ratio check between nunits_out and nunits_in.
+       (vectorizable_type_demotion): Remove single-use variable "scalar_type".
+
+2007-06-08  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/32224
+       * tree-vect-analyze.c (vect_determine_vectorization_factor): Fail
+       vectorization upon a non GIMPLE_MODIFY_STMT.
+
+2007-06-08  Christian Bruel  <christian.bruel@st.com>
+
+       PR target/29953
+       * config/sh/sh.md (doloop_end): New pattern and splitter.
+       * loop-iv.c (simple_rhs_p): Check for hardware registers.
+
+2007-06-08  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR middle-end/32209
+       * dominance.c (debug_dominance_tree, debug_dominance_tree_1): New
+       functions.
+       (verify_dominators): Do not change dominance tree.
+
+2007-06-08  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/constraints.md: New file.
+       * config/sh/sh.c: Include tm-constrs.h.
+       (reg_class_from_letter): Remove.
+       (prepare_cbranch_operands): Use satisfies_constraint_*
+       function instead of macro.
+       (andcosts, broken_move, sh_secondary_reload): Likewise.
+       * config/sh/predicates.md (trapping_target_operand): Likewise.
+       (and_operand, arith_operand, arith_reg_or_0_operand,
+       cmp_operand, logical_operand, target_operand,
+       ua_address_operand, ua_offset, xor_operand): Likewise.
+       * config/sh/sh.md: Include constraints.md.
+       (*movsicc_t_false): Use satisfies_constraint_* function
+       instead of macro.
+       (*movsicc_t_true, ashlsi3_std, ashlhi3_k, lshrsi3_m,
+       lshrsi3_k, movsi_const_16bit+2, *movhi_media+1,
+       movdi_const_16bit+1, beq, bne, *ptb): Likewise.
+       * config/sh/sh.h (reg_class_from_letter): Remove prototype.
+       (OVERRIDE_OPTIONS): Don't modify reg_class_from_letter.
+       (REG_CLASS_FROM_CONSTRAINT): Remove.
+       (CONSTRAINT_LEN, CONST_OK_FOR_I20, CONST_OK_FOR_I,
+       CONST_OK_FOR_J, CONST_OK_FOR_K16, CONST_OK_FOR_K,
+       CONST_OK_FOR_P27, CONST_OK_FOR_P, CONST_OK_FOR_M,
+       CONST_OK_FOR_N, CONST_OK_FOR_CONSTRAINT_P,
+       CONST_DOUBLE_OK_FOR_LETTER_P): Likewise.
+       (SECONDARY_INOUT_RELOAD_CLASS): Use satisfies_constraint_*
+       function instead of macro.
+       (SECONDARY_INPUT_RELOAD_CLASS): Likewise.
+       (EXTRA_CONSTRAINT_Q, EXTRA_CONSTRAINT_A,
+       EXTRA_CONSTRAINT_Bsc, EXTRA_CONSTRAINT_B,
+       EXTRA_CONSTRAINT_Css, EXTRA_CONSTRAINT_Csu): Remove.
+       (IS_PC_RELATIVE_LOAD_ADDR_P): New macro.
+       (IS_LITERAL_OR_SYMBOLIC_S16_P): Likewise.
+       (IS_LITERAL_OR_SYMBOLIC_U16_P): Likewise.
+       (IS_NON_EXPLICIT_CONSTANT_P): Likewise.
+       (EXTRA_CONSTRAINT_Csy, EXTRA_CONSTRAINT_Z, EXTRA_CONSTRAINT_W,
+       EXTRA_CONSTRAINT_Cpg, EXTRA_CONSTRAINT_C,
+       EXTRA_MEMORY_CONSTRAINT, EXTRA_CONSTRAINT_Sr0,
+       EXTRA_CONSTRAINT_Sua, EXTRA_CONSTRAINT_S,
+       EXTRA_CONSTRAINT_STR): Likewise.
+       (GO_IF_LEGITIMATE_INDEX): Fix indentation.
+
+2007-06-07  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/i386/darwin.h (STACK_BOUNDARY): Define.
+
+2007-06-07  Simon Martin  <simartin@users.sourceforge.net>
+
+       PR c++/30759
+       * c-common.h (flag_cpp0x): Replaced by...
+       (cxx_dialect): ... this new variable specifying the C++ dialect that
+       is used.
+       * c-common.c (flag_cpp0x): Removed.
+       (cxx_dialect): Defined.
+       * c-cppbuiltin.c (c_cpp_builtins): flag_cpp0x rewritten in terms of
+       cxx_dialect.
+       * c-opts.c (c_common_post_options): Likewise.
+       (set_std_cxx98): Set cxx_dialect to cxx98.
+       (set_std_cxx0x): Set cxx_dialect to cxx0x.
+
+2007-06-07  Geoffrey Keating  <geoffk@apple.com>
+           Hui-May Chang <hm.chang@apple.com>
+
+       * doc/invoke.texi (Darwin Options): Update documentation for
+       -mmacosx-version-min.
+       * config.gcc (*-*-darwin*): Set extra_gcc_objs.
+       * config/darwin-driver.c: New file.
+       * config/darwin.h (GCC_DRIVER_HOST_INITIALIZATION): New.
+       * config/t-darwin (darwin-driver.o): New rule.
+
+       * config/darwin-c.c (version_as_macro): Ignore low digit.
+
+2007-06-07  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (standard sse constant splitter): Handle TFmode.
+       (negtf2, abstf2, *absnegtf2_sse): New insn patterns.
+       (CSGNMODE): New mode macro.
+       (CSGNVMODE): New mode attribute.
+       (copysign<mode>3): Rename from copysingsf3 and copysigndf3.  Macroize
+       expander using CSGNMODE mode macro.  Handle TFmode.
+       (copysign<mode>3_const): Rename from copysignsf3_const and
+       copysigndf3_const.  Macroize pattern using CSGNMODE mode macro.
+       Handle TFmode.
+       (copysign<mode>3_var): Rename from copysignsf3_var and
+       copysigndf3_var.  Macroize pattern using CSGNMODE mode macro.
+       Handle TFmode.
+       (copysign<mode>3_var splitter): Macroize pattern using CSGNMODE
+       mode macro.  Handle TFmode.
+       * config/i386/sse.md (andtf3, *andtf3, *nandtf3): New insn patterns.
+       (iortf3, *iortf3): Ditto.
+       (xortf3, *xortf3): Ditto.
+       * config/i386/i386.c (ix86_build_signbit_mask): Create scalar
+       TFmode and TImode masks.
+       (ix86_expand_copysign): Expand TFmode copysign insn.
+       (IX86_BUILTIN_INFQ): New.
+       (IX86_BUILTIN_FABSQ): Ditto.
+       (IX86_BUILTIN_COPYSIGNQ): Ditto.
+       (ix86_init_mmx_sse_builtins) [__builtin_infq]: New builtin definition.
+       [__builtin_fabsq]: Ditto.
+       [__builtin_copysignq]: Ditto.
+       (ix86_expand_builtin) [IX86_BUILTIN_INFQ]: Expand builtin.
+       [IX86_BUILTIN_FABSQ]: Expand builtin using ix86_expand_unop_builtin().
+       [IX86_BUILTIN_COPYSIGNQ]: Expand builtin using
+       ix86_expand_binop_builtin().
+
+2007-06-07  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/lib1funcs.asm: Clean up whitespace.
+
+2007-06-07  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/31850
+       * rtl.h (push_to_sequence2): New.
+       * emit-rtl.c (push_to_sequence2): New.
+       * function.c (assign_parm_data_all): Add new fields.
+       (assign_parm_setup_block): Call push_to_sequence2 instead of
+       push_to_sequence.
+       (assign_parm_setup_reg): Ditto.
+       (assign_parm_setup_stack): Ditto.
+       (assign_parms_unsplit_complex): Ditto.
+       (assign_parms): Change field name.
+
+2007-06-07  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/32220
+       * tree-predcom.c (eliminate_temp_copies): Handle the case that loop
+       phi node is reached before defining statement.
+
+2007-06-06  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR tree-opt/32231
+       * tree-vect-transform.c (vectorizable_call): Call update_stmt
+       after changing the right hand side of the assignment.
+
+2007-06-06  Eric Christopher  <echristo@apple.com>
+
+       * config.gcc (i?86-*-darwin*): Remove arch parameter.
+       (x86_64-*-darwin*): Ditto.
+       * config/i386/darwin.h (TARGET_SUBTARGET32_ISA_DEFAULT): Define.
+       (TARGET_SUBTARGET64_ISA_DEFAULT): Ditto.
+
+2007-06-06  Thomas Neumann  <tneumann@users.sourceforge.net>
+
+       * tree-ssa-alias-warnings.c (maybe_add_match): Cast according to the
+       coding conventions.
+       (add_key): Likewise.
+       * tree-ssa.c (init_tree_ssa): Use type safe memory macros.
+       * tree-ssa-ccp.c (ccp_fold_builtin): Avoid using C++ keywords as
+       variable names.
+       * tree-ssa-coalesce.c (find_coalesce_pair): Use type safe memory
+       macros.
+       (add_cost_one_coalesce): Likewise.
+       * tree-ssa-copy.c (merge_alias_info): Avoid using C++ keywords as
+       variable names. Rename orig to orig_name for consistency.
+       * tree-ssa-dom.c (dom_thread_across_edge): Cast according to the
+       coding conventions.
+       (cprop_into_successor_phis): Avoid using C++ keywords as variable
+       names.
+       (record_equivalences_from_stmt): Likewise.
+       * tree-ssa-dse.c (dse_initialize_block_local_data): Cast according to
+       the coding conventions.
+       (memory_ssa_name_same): Likewise.
+       (dse_optimize_stmt): Likewise.
+       (dse_record_phis): Likewise.
+       (dse_finalize_block): Likewise.
+       * tree-ssa-loop-im.c (outermost_invariant_loop_expr): Avoid using C++
+       keywords as variable names.
+       (may_move_till): Cast according to the coding conventions.
+       (force_move_till_expr): Avoid using C++ keywords as variable names.
+       (force_move_till): Cast according to the coding conventions.
+       (memref_hash): Likewise.
+       (memref_eq): Likewise.
+       (gather_mem_refs_stmt): Likewise.
+       * tree-ssa-loop-ivopts.c (contains_abnormal_ssa_name_p): Avoid
+       using C++ keywords as variable names.
+       (idx_find_step): Cast according to the coding conventions.
+       (idx_record_use): Likewise.
+       (find_depends): Likewise.
+       (prepare_decl_rtl): Likewise.
+       (mbc_entry_hash): Likewise.
+       (mbc_entry_eq): Likewise.
+       * tree-ssa-loop-niter.c (SWAP): Use the correct the type for tmp.
+       (simplify_replace_tree): Avoid using C++ keywords as variable names.
+       (idx_infer_loop_bounds): Cast according to the coding conventions.
+       * tree-ssa-loop-prefetch.c (idx_analyze_ref): Likewise.
+       * tree-ssa-math-opts.c (occ_new ): Likwise.
+       * tree-ssanames.c (duplicate_ssa_name_ptr_info): Use type safe memory
+       macros.
+       * tree-ssa-operands.c (add_def_op): Avoid using C++ keywords as
+       variable names.
+       (add_use_op): Likewise.
+       (add_vop): Likewise.
+       (add_vuse_op): Likewise.
+       (add_vdef_op): Likewise.
+       (get_expr_operands): Likewise.
+       (push_stmt_changes): Use type safe memory macros.
+       * tree-ssa-phiopt.c (replace_phi_edge_with_variable): Avoid using C++
+       keywords as variable names.
+       (conditional_replacement): Likewise.
+       (minmax_replacement): Likewise.
+       (abs_replacement): Likewise.
+       * tree-ssa-pre.c (create_expression_by_pieces): Cast according to the
+       coding conventions.
+       (insert_fake_stores): Avoid using C++ keywords as variable names.
+       * tree-ssa-reassoc.c (add_to_ops_vec): Cast according to the coding
+       conventions.
+       * tree-ssa-structalias.c (heapvar_lookup): Likewise.
+       (heapvar_insert): Use type safe memory macros.
+       (new_var_info): Cast according to the coding conventions.
+       (new_constraint): Likewise.
+       (remove_preds_and_fake_succs): Use type safe memory macros.
+       * tree-ssa-threadupdate.c (thread_block): Cast according to the coding
+       conventions.
+       (thread_single_edge): Likewise.
+       (thread_through_loop_header): Likewise.
+
+2007-06-06  Eric Christopher  <echristo@apple.com>
+
+       * config/i386/i386.c (override_options): Move handling
+       of TARGET_SUBTARGET* earlier.
+
+2007-06-06  Paolo Bonzini  <bonzini@gnu.org>
+
+       * genmodes.c (tagged_printf, emit_insn_modes_h): Don't
+       use %n on printf.
+
+2007-06-06  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * haifa-sched.c (restore_bb_notes): Clear bb field of the notes
+       emited outside of basic block.
+       * cfgbuild.c (find_bb_boundaries): Clear bb field for insns between
+       the created blocks.
+       * rtl.h (delete_insn_chain): Declaration changed.
+       * cfgrtl.c (delete_insn_chain): Add option to clear bb field for
+       non-removed insns.
+       (rtl_delete_block, rtl_merge_blocks): Pass true to delete_insn_chain.
+       (delete_insn_chain_and_edges, try_redirect_by_replacing_jump,
+       rtl_tidy_fallthru_edge, cfg_layout_merge_blocks): Pass false
+       to delete_insn_chain.
+       (rtl_verify_flow_info_1): Verify that the insns in header and footer
+       do not have bb field set.
+       (rtl_verify_flow_info): Verify that insns between basic blocks do not
+       have bb field set.
+       * recog.c (peephole2_optimize): Add argument to delete_insn_chain call.
+       * cfgcleanup.c (try_optimize_cfg): Ditto.
+
+2007-06-06  Thomas Neumann  <tneumann@users.sourceforge.net>
+
+       * lambda-code.c (struct lambda_lattice_s): Add a name to the struct.
+       (lambda_body_vector_new): Use type safe memory macros.
+       (lambda_linear_expression_new): Likewise.
+       (lambda_loopnest_new): Likewise.
+       (lambda_lattice_new): Likewise.
+       (replace_uses_equiv_to_x_with_y): Cast according to the coding
+       conventions. Use type safe memory macros.
+       * lambda.h (struct lambda_trans_matrix_s): Add a name to the struct.
+       (lambda_body_vector_s): Likewise.
+       * lambda-mat.c (lambda_matrix_new): Use type safe memory macros.
+       * lambda-trans.c (lambda_trans_matrix_new): Likewise.
+
+2007-06-06  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-forwprop.c (forward_propagate_into_cond): Return 2
+       if we need to schedule cfg_cleanup.
+       (tree_ssa_forward_propagate_single_use_vars): Do so.
+
+2007-06-06  Ian Lance Taylor  <iant@google.com>
+
+       * fold-const.c (merge_ranges): If range_successor or
+       range_predecessor fail, just return 0.
+
+2007-06-06  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/32216
+       * tree-vectorizer.c (supportable_widening_operation): Determine
+       signedness of FIX_TRUNC_EXPR from output operand.
+       (supportable_narrowing_operation): Ditto.
+       * tree-vect-generic.c (expand_vector_operations_1): Determine
+       signedness of VEC_UNPACK_FLOAT_HI_EXPR and VEC_UNPACK_FLOAT_LO_EXPR
+       from input operand.
+
+2007-06-06  Thomas Neumann  <tneumann@users.sourceforge.net>
+
+       * config/i386/i386.c (enum pta_flags): Move out of struct scope...
+       (struct pta): ...from here. Change flags to unsigned to avoid
+       excessive casting (as it is used as a bit mask).
+       (override_options): Add casts according to the coding convenventions.
+       (x86_64_elf_unique_section): Likewise.
+       (examine_argument): Avoid using C++ keywords as variable names.
+       (construct_container): Likewise.
+       (legitimize_pic_address): Likewise.
+       (get_dllimport_decl): Cast according to the coding conventions. Use
+       type safe memory macros.
+       (legitimize_address): Cast according to the coding conventions.
+       (emit_i387_cw_initialization): Corrected the type of slot to enum
+       ix86_stack_slot.
+       (ix86_init_machine_status): Use type safe memory macros.
+       (bdesc_pcmpestr): Use UNKNOWN instead of integer 0.
+       (bdesc_pcmpistr): Likewise.
+       (bdesc_crc32): Likewise.
+       (bdesc_sse_3arg): Likewise.
+       (bdesc_2arg): Likewise.
+       (bdesc_1arg): Likewise.
+       (ix86_expand_sse_pcmpestr): Cast according to the coding conventions.
+       (ix86_expand_sse_pcmpistr): Likewise.
+       (ix86_expand_vec_set_builtin): Use EXPAND_NORMAL instead of integer 0.
+       (ix86_builtin_vectorized_function): Change the type of fn to unsigned
+       int to match the langhook definition.
+       (ix86_builtin_conversion): Change the type of code to unsigned init to
+       match the langhook definition.
+       (ix86_preferred_reload_class): Avoid using C++ keywords as variable
+       names.
+       (ix86_preferred_output_reload_class): Likewise.
+       (ix86_cannot_change_mode_class): Likewise.
+       (ix86_memory_move_cost): Likewise.
+       (ix86_rtx_costs): Cast the outer_code parameter to enum rtx_code to
+       avoid excessive casting later on.
+       (x86_output_mi_thunk): Avoid using C++ keywords as variable names.
+
+2007-06-06  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/sse.md (sse4_2_pcmpestr_cconly): Prefer pcmpestrm
+       as flags setting insn.
+       (sse4_2_pcmpistr_cconly): Prefer pcmpistrm as flags setting insn.
+
+2007-06-06  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (UNSPEC_ROUNDP, UNSPEC_ROUNDS): Remove.
+       (UNSPEC_ROUND): New.
+       ("sse4_1_round<mode>2"): New insn pattern.
+       ("rint<mode>2"): Expand using "sse4_1_round<mode>2" pattern for
+       SSE4.1 targets.
+       ("floor<mode>2"): Rename from floordf2 and floorsf2.  Macroize
+       expander using SSEMODEF mode macro.  Expand using
+       "sse4_1_round<mode>2" pattern for SSE4.1 targets.
+       ("ceil<mode>2"): Rename from ceildf2 and ceilsf2.  Macroize
+       expander using SSEMODEF mode macro.  Expand using
+       "sse4_1_round<mode>2" pattern for SSE4.1 targets.
+       ("btrunc<mode>2"): Rename from btruncdf2 and btruncsf2.  Macroize
+       expander using SSEMODEF mode macro.  Expand using
+       "sse4_1_round<mode>2" pattern for SSE4.1 targets.
+       * config/i386/sse.md ("sse4_1_roundpd", "sse4_1_roundps"): Use
+       UNSPEC_ROUND instead of UNSPEC_ROUNDP.
+       ("sse4_1_roundsd", "sse4_1_roundss"): Use UNSPEC_ROUND instead of
+       UNSPEC_ROUNDS.
+
+2007-06-06  Jan Sjodin  <jan.sjodin@amd.com>
+           Sebastian Pop  <sebpop@gmail.com>
+
+       * lambda.h (build_linear_expr): New.
+       * lambda-code.c (lbv_to_gcc_expression, lle_to_gcc_expression):
+       Use build_linear_expr, call fold and force_gimple_operand.
+       (lambda_loopnest_to_gcc_loopnest): Check that there is
+       something to insert.
+       * testsuite/gcc.dg/tree-ssa/ltrans-6.c: New.
+
+2007-06-05  Joerg Wunsch  <j.gnu@uriah.heep.sax.de>
+
+       PR preprocessor/23479
+       * doc/extend.texi: Document the 0b-prefixed binary integer
+       constant extension.
+
+2007-06-05  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/32215
+       * tree-vectorizer.c (supportable_widening_operation): Return false
+       for unsupported FIX_TRUNC_EXPR tree code.
+       (supportable_narrowing_operation): Ditto for FLOAT_EXPR tree code.
+
+2007-06-06  Nathan Froyd  <froydnj@codesourcery.com>
+
+       * config/rs6000/rs6000.h (FIXED_SCRATCH): Use r0 as a scratch
+       register on SPE targets.  Change documentation to reflect
+       reality.
+       * config/rs6000/rs6000.c (rs6000_conditional_register_usage):
+       Change FIXED_SCRATCH to 14 and document why we're keeping r14
+       out of the register allocation pool.
+       (rs6000_reg_live_or_pic_offset_p): New function.
+       (rs6000_emit_prologue): Move the actual saving of LR up to free
+       r0 for holding r11.  Split saving of SPE 64-bit registers into
+       its own case.  Ensure that offsets will always be in-range for
+       'evstdd' by using r11 as a scratch register to point at the start
+       of the SPE save area.  Save r11 if necessary, as it is the static
+       chain register.
+       (rs6000_emit_epilogue): Split restoring of SPE 64-bit registers
+       into its own case.  Ensure that offsets will always be in-range
+       for 'evldd' by using r11 as a scratch register to point at the
+       start of the SPE save area.  Also adjust r11 when restoring
+       the stack pointer to compensate for pre-loading r11.
+
+2007-06-05  Thomas Neumann  <tneumann@users.sourceforge.net>
+
+       * cfg.c (init_flow): Use type safe memory macros.
+       (alloc_block): Likewise.
+       (unchecked_make_edge): Likewise.
+       (dump_flow_info): Avoid using C++ keywords as variable names.
+       (copy_original_table_clear): Cast according to the coding conventions.
+       (copy_original_table_set): Likewise.
+       * cfgexpand (label_rtx_for_bb): Likewise.
+       (expand_gimple_basic_block): Likewise.
+       * cfghooks.c (dump_bb): Likewise.
+       (lv_adjust_loop_header_phi): Avoid using C++ keywords as
+       variable names.
+       (lv_add_condition_to_bb): Likewise.
+       * cfglayout (relink_block_chain): Cast according to the coding
+       conventions.
+       (fixup_reorder_chain): Likewise.
+       (fixup_fallthru_exit_predecessor): Likewise.
+       * cfgloop.c (glb_enum_p): Likewise.
+       (get_exit_description): Likewise.
+       (dump_recorded_exit): Likewise.
+       * cfgloop.h (enum loop_estimation): Move out of struct scope...
+       (struct loop): ... from here.
+       * cfgloopmanip.c (rpe_enum_p): Cast according to the coding
+       conventions.
+       * cfgrtl.c (rtl_create_basic_block): Likewise.
+       (rtl_split_block): Likewise.
+       (rtl_dump_bb): Likewise.
+       (cfg_layout_split_block): Likewise.
+       (init_rtl_bb_info): Use typesafe memory macros.
+
+       * graphds.h (struct graph_edge): Renamed edge to graph_edge.
+       * graphds.h: Updated all usages of edge to graph_edge.
+       * graphds.c: Likewise.
+       * cfgloopanal.c: Likewise.
+
+2007-06-05  Ian Lance Taylor  <iant@google.com>
+
+       * tree-vrp.c (compare_values_warnv): Check TREE_NO_WARNING on a
+       PLUS_EXPR or MINUS_EXPR node before setting *strict_overflow_p.
+       (extract_range_from_assert): Set TREE_NO_WARNING when creating an
+       expression.
+       (test_for_singularity): Likewise.
+
+2007-06-05  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/constraints.md ("Y2"): Replaced by ...
+       ("Yt"): This.
+       * config/i386/i386.md: Likewise.
+       * config/i386/mmx.md: Likewise.
+       * config/i386/sse.md: Likewise.
+
+2007-06-05  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/constraints.md ("z"): Replaced by ...
+       ("Y0"): This.
+       * config/i386/sse.md (sse4_1_blendvpd): Likewise.
+       (sse4_1_blendvps): Likewise.
+       (sse4_1_pblendvb): Likewise.
+       (sse4_2_pcmpestr): Likewise.
+       (sse4_2_pcmpestrm): Likewise.
+       (sse4_2_pcmpestr_cconly): Likewise.
+       (sse4_2_pcmpistr): Likewise.
+       (sse4_2_pcmpistrm): Likewise.
+       (sse4_2_pcmpistr_cconly): Likewise.
+
+2007-06-05  Razya Ladelsky  <razya@il.ibm.com>
+
+       * matrix-reorg.c (transform_access_sites): Fix computation.
+       (transform_allocation_sites): Same.
+
+2007-06-05  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (override_options): Use
+       TARGET_SUBTARGET32_ISA_DEFAULT to select default ix86_isa_flags.
+
+2007-06-05  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/predicates.md (reg_not_xmm0_operand): New predicate.
+       (nonimm_not_xmm0_operand): Ditto.
+       * config/i386/sse.md ("sse4_1_blendvpd"): Use "reg_not_xmm0_operand"
+       as operand[0] and operand[1] predicate.  Use "nonimm_not_xmm0_operand"
+       as operand[2] predicate.  Require "z" class XMM register for
+       operand[3].  Adjust asm template.
+       ("sse4_1_blendvpd"): Ditto.
+       ("sse4_1_pblendvb"): Ditto.
+       * config/i386/i386.c (ix86_expand_sse_4_operands_builtin): Do not
+       force op2 into xmm0 register for variable blend instructions.
+
+2007-06-04  Tom Tromey  <tromey@redhat.com>
+
+       * c-tree.h (start_enum): Update.
+       (build_enumerator): Likewise.
+       * c-decl.c (enum_next_value): Removed.
+       (enum_overflow): Likewise.
+       (start_enum): Add c_enum_contents argument.  Don't use globals.
+       (build_enumerator): Likewise.
+       * c-tree.h (struct c_enum_contents): New struct.
+
+2007-06-04  Tom Tromey  <tromey@redhat.com>
+
+       * c-common.c (c_common_get_alias_set): Fix indentation.
+
+2007-06-04  Ian Lance Taylor  <iant@google.com>
+
+       * tree-vrp.c (adjust_range_with_scev): When loop is not expected
+       to overflow, reduce overflow infinity to regular infinity.
+       (vrp_var_may_overflow): New static function.
+       (vrp_visit_phi_node): Check vrp_var_may_overflow.
+
+2007-06-04  Kazu Hirata  <kazu@codesourcery.com>
+
+       * stor-layout.c (layout_type): Remove duplicate code.
+
+2007-06-04  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR c/32191
+       * c-common.c (c_define_builtins): Call targetm.init_builtins ()
+       before build_common_builtin_nodes ().
+
+2007-06-04  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/31733
+       * cfgrtl.c (rtl_verify_flow_info): Skip notes when looking for barrier.
+
+2007-06-04  Jan Hubicka  <jh@suse.cz>
+
+       * tree-predcom.c (replace_ref_with, initialize_root_vars_lm,
+       reassociate_to_the_same_stmt): Call build_gimple_modify_stmt
+       instead of _stat version.
+
+2007-06-03  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/32194
+       * tree-predcom.c (determine_offset): Check that both references have
+       the same type.
+
+2007-06-03  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * cfgloopmanip.c (remove_path, loopify, duplicate_loop_to_header_edge):
+       Change dom_bbs to vector.  Add argument to iterate_fix_dominators call.
+       * loop-unroll.c (unroll_loop_runtime_iterations): Ditto.
+       * tree-cfg.c (tree_duplicate_sese_region): Change doms to vector.
+       Add argument to iterate_fix_dominators call.
+       (remove_edge_and_dominated_blocks): Pass vector to bbs_to_fix_dom.
+       * gcse.c (hoist_code): Change domby to vector.
+       * cfghooks.c (make_forwarder_block): Change doms_to_fix to vector.
+       Add argument to iterate_fix_dominators call.
+       * loop-doloop.c (doloop_modify): Changed recount_dominator to
+       recompute_dominator.
+       * lambda-code.c (perfect_nestify): Ditto.
+       * cfgloopanal.c: Include graphds.h.
+       (struct edge, struct vertex, struct graph, dump_graph, new_graph,
+       add_edge, dfs, for_each_edge, free_graph): Moved to graphds.c.
+       (mark_irreducible_loops): Use graphds_scc.  Remove argument from
+       add_edge call.
+       * graphds.c: New file.
+       * graphds.h: New file.
+       * dominance.c: Include vecprim.h, pointer-set.h and graphds.h.
+       (get_dominated_by, get_dominated_by_region): Change return type to
+       vector.
+       (verify_dominators): Recompute all dominators and compare the results.
+       (recount_dominator): Renamed to ...
+       (recompute_dominator): ... this.  Do not check that the block is
+       dominated by entry.
+       (iterate_fix_dominators): Reimplemented.
+       (prune_bbs_to_update_dominators, root_of_dom_tree,
+       determine_dominators_for_sons): New functions.
+       * et-forest.c (et_root): New function.
+       * et-forest.h (et_root): Declare.
+       * Makefile.in (graphds.o): Add.
+       (cfgloopanal.o): Add graphds.h dependency.
+       (dominance.o): Add graphds.h, vecprim.h and pointer-set.h dependency.
+       * basic-block.h (get_dominated_by, get_dominated_by_region,
+       iterate_fix_dominators): Declaration changed.
+       (recount_dominator): Renamed to ...
+       (recompute_dominator): ... this.
+       * tree-ssa-threadupdate.c (thread_block): Free dominance info.
+       (thread_through_all_blocks): Do not free dominance info.
+
+2007-06-03  Andreas Schwab  <schwab@suse.de>
+
+       * config/m68k/m68k.c (override_options): Don't override
+       REAL_MODE_FORMAT.
+       * config/m68k/m68k-modes.def (SF, DF): Define to use
+       motorola_single_format and motorola_double_format, resp.
+       * real.c (motorola_single_format): Renamed from
+       coldfire_single_format.
+       (motorola_double_format): Renamed from coldfire_double_format.
+       (encode_ieee_extended): Generate a proper canonical NaN image
+       respecting canonical_nan_lsbs_set.
+       (ieee_extended_motorola_format): Set canonical_nan_lsbs_set to
+       true.
+       * real.h: Adjust declarations.
+
+2007-06-03  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/32163
+       * config/sh/sh.md (symGOT_load): Don't schedule insns when
+       the symbol is generated with the stack protector.
+
+2007-06-03  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_attribute_table): Add "interrupt".
+       (m68k_get_function_kind): Return m68k_fk_interrupt_handler on
+       "interrupt".
+       * doc/extend.texi (interrupt): Mention m68k.
+
+2007-06-02  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_expand_sse_4_operands_builtin): Call
+       safe_vector_operand() if input operand is VECTOR_MODE_P operand.
+       (ix86_expand_sse_pcmpestr): Do not check operands for
+       "register_operand", when insn operand predicate is "register_operand".
+       (ix86_expand_sse_pcmpistr): Ditto.
+
+2007-06-02  H.J. Lu  <hongjiu.lu@intel.com>
+           Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (enum reg_class) [SSE_FIRST_REG]: New.
+       (SSE_CLASS_P): Use reg_class_subset_p between SSE_REGS.
+       (REG_CLASS_NAMES): Add "FIRST_SSE_REG" string.
+       (REG_CLASS_CONTENTS): Add members of FIRST_SSE_REG class.
+       * config/i386/constraints.md ("z"): New register constraint
+       for members of SSE_FIRST_REG class.
+       * config/i386/i386-modes.def (CCA, CCC, CCO, CCS): New compare modes.
+       * config/i386/i386.c (regclass_map): Change class of %xmm0 to
+       SSE_FIRST_REG class.
+       (put_condition_code) [EQ, NE]: Output suffixes for new compare modes.
+       (ix86_cc_modes_compatible): Handle CCA, CCC, CCO and CCS modes.
+       (IX86_BUILTIN_PCMPESTRI128): New for SSE4.2.
+       (IX86_BUILTIN_PCMPESTRM128): Likewise.
+       (IX86_BUILTIN_PCMPESTRA128): Likewise.
+       (IX86_BUILTIN_PCMPESTRC128): Likewise.
+       (IX86_BUILTIN_PCMPESTRO128): Likewise.
+       (IX86_BUILTIN_PCMPESTRS128): Likewise.
+       (IX86_BUILTIN_PCMPESTRZ128): Likewise.
+       (IX86_BUILTIN_PCMPISTRI128): Likewise.
+       (IX86_BUILTIN_PCMPISTRM128): Likewise.
+       (IX86_BUILTIN_PCMPISTRA128): Likewise.
+       (IX86_BUILTIN_PCMPISTRC128): Likewise.
+       (IX86_BUILTIN_PCMPISTRO128): Likewise.
+       (IX86_BUILTIN_PCMPISTRS128): Likewise.
+       (IX86_BUILTIN_PCMPISTRZ128): Likewise.
+       (struct builtin_description): Change "flag" field to unsigned.
+       (bdesc_pcmpestr): New builtin description table.
+       (bdesc_pcmpistr): Likewise.
+       (ix86_init_mmx_sse_builtins): Define int_ftype_v16qi_int_v16qi_int_int,
+       v16qi_ftype_v16qi_int_v16qi_int_int and int_ftype_v16qi_v16qi_int.
+       Initialize pcmp[ei]str[im] insns for SSE4.2.
+       (ix86_expand_sse_pcmpestr): New subroutine of ix86_expand_builtin.
+       (ix86_expand_sse_pcmpistr): Likewise.
+       (ix86_expand_builtin): Expand pcmp[ei]str[im] builtins for SSE4.2.
+       * config/i386/i386.md (UNSPEC_PCMPESTR): New for SSE4.2.
+       (UNSPEC_PCMPISTR): Likewise.
+       * config/i386/sse.md (sse4_2_pcmpestr): New insn patern and splitter.
+       (sse4_2_pcmpestri):New isns pattern.
+       (sse4_2_pcmpestrm): Likewise.
+       (sse4_2_pcmpestr_cconly): Likewise.
+       (sse4_2_pcmpistr): New insn patern and splitter.
+       (sse4_2_pcmpistri):New isns pattern.
+       (sse4_2_pcmpistrm): Likewise.
+       (sse4_2_pcmpistr_cconly): Likewise.
+       * config/i386/smmintrin.h: Enable pcmp[ei]str[im] intrinsics
+       in SSE4.2.
+
+2007-06-01  David Daney  <ddaney@avtrex.com>
+
+       * config/mips/mips.c (mips_output_mi_thunk): Only load gp if not
+       LOADGP_ABSOLUTE and not binds_local_p.
+
+2007-06-01  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/darwin.h (LINK_SPEC): Pass -fpie through to the linker.
+
+2007-06-01  Ian Lance Taylor  <iant@google.com>
+
+       * tree-vrp.c (compare_name_with_value): Always set
+       used_strict_overflow if we get a result from the variable itself.
+
+2007-06-01  Ian Lance Taylor  <iant@google.com>
+
+       PR rtl-optimization/31455
+       * lower-subreg.c (find_decomposable_subregs): Don't decompose
+       subregs which have a cast between modes which are not tieable.
+
+2007-06-01  Uros Bizjak  <ubizjak@gmail.com>
+
+       * expr.c (force_operand) [DIV, MOD, UDIV, UMOD, ASHIFTRT]: Remove
+       breaks after return statements.
+
+2007-06-01  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.c (fpscr_set_from_mem): Call get_free_reg
+       only after no_new_pseudos.
+
+2007-05-31  Eric Christopher  <echristo@apple.com>
+
+       * expr.c (convert_move): Assert that we don't have a BLKmode
+       operand.
+       (store_expr): Handle BLKmode moves by calling emit_block_move.
+
+2007-05-31  Daniel Berlin  <dberlin@dberlin.org>
+
+       * c-typeck.c (build_indirect_ref): Include type in error message.
+       (build_binary_op): Pass types to binary_op_error.
+       * c-common.c (binary_op_error): Take two type arguments, print out
+       types with error.
+       * c-common.h (binary_op_error): Update prototype.
+
+2007-05-31  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c: Correct coments on -mno-sse4.
+
+2007-05-31  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config.gcc (i[34567]86-*-*): Add nmmintrin.h to extra_headers.
+       (x86_64-*-*): Likewise.
+       * config/i386/i386.c (OPTION_MASK_ISA_MMX_UNSET): New.
+       (OPTION_MASK_ISA_3DNOW_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSE_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSE2_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSE3_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSSE3_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSE4_1_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSE4_2_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSE4): Likewise.
+       (OPTION_MASK_ISA_SSE4_UNSET): Likewise.
+       (OPTION_MASK_ISA_SSE4A_UNSET): Likewise.
+       (ix86_handle_option): Use OPTION_MASK_ISA_*_UNSET.  Handle SSE4.2.
+       (override_options): Support SSE4.2.
+       (ix86_build_const_vector): Support SImode and DImode.
+       (ix86_build_signbit_mask): Likewise.
+       (ix86_expand_int_vcond): Support V2DImode.
+       (IX86_BUILTIN_CRC32QI): New for SSE4.2.
+       (IX86_BUILTIN_CRC32HI): Likewise.
+       (IX86_BUILTIN_CRC32SI): Likewise.
+       (IX86_BUILTIN_CRC32DI): Likewise.
+       (IX86_BUILTIN_PCMPGTQ): Likewise.
+       (bdesc_crc32): Likewise.
+       (bdesc_sse_3arg): Likewise.
+       (ix86_expand_crc32): Likewise.
+       (ix86_init_mmx_sse_builtins): Support SSE4.2.
+       (ix86_expand_builtin): Likewise.
+       * config/i386/i386.h (TARGET_CPU_CPP_BUILTINS): Define
+       __SSE4_2__ for -msse4.2.
+       * config/i386/i386.md (UNSPEC_CRC32): New for SSE4.2.
+       (CRC32MODE): Likewise.
+       (crc32modesuffix): Likewise.
+       (crc32modeconstraint): Likewise.
+       (sse4_2_crc32<mode>): Likewise.
+       (sse4_2_crc32di): Likewise.
+       * config/i386/i386.opt (msse4.2): New for SSE4.2.
+       (msse4): Likewise.
+       * config/i386/nmmintrin.h: New. The dummy SSE4.2 intrinsic header file.
+       * config/i386/smmintrin.h: Add SSE4.2 intrinsics.
+       * config/i386/sse.md (sse4_2_gtv2di3): New pattern for SSE4.2.
+       (vcond<mode>): Use SSEMODEI instead of SSEMODE124.
+       (vcondu<mode>): Likewise.
+       * doc/extend.texi: Document SSE4.2 built-in functions.
+       * doc/invoke.texi: Document -msse4.2/-msse4.
+
+2007-05-31  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/32160
+       * tree-predcom.c (predcom_tmp_var): New function.  Mark created
+       variable as gimple reg.
+       (initialize_root_vars, initialize_root_vars_lm): Use predcom_tmp_var.
+
+2007-05-31  Kazu Hirata  <kazu@codesourcery.com>
+
+       * gcc.c (main): Don't consider linker options when issuing the
+       warning about a linker input file not being used.
+
+2007-05-30  Ralf Wildenhues  <Ralf.Wildenhues@gmx.de>
+
+       * tree-vrp.c (compare_names): Initialize sop.
+
+2007-05-30  Dirk Mueller  <dmueller@suse.de>
+
+       * cgraphunit.c (cgraph_analyze_function): Remove
+       computation of inline parameters.
+
+2007-05-30  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/darwin.h (TARGET_SUBTARGET_DEFAULT): Undef before define.
+
+2007-05-30  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (arm-wrs-vxworks): Remove dbxelf.h from tm_file.
+       Add vx-common.h.  Include vxworks.h between vx-common.h and
+       arm/vxworks.h.
+       * config/vx-common.h (DWARF2_UNWIND_INFO): Undefine before
+       redefining.
+       * config/vxworks.h (TARGET_ASM_CONSTRUCTOR): Likewise.
+       (TARGET_ASM_DESTRUCTOR): Likewise.
+       * config/arm/vxworks.h (TARGET_OS_CPP_BUILTINS): Check arm_arch_xscale
+       instead of arm_is_xscale.  Use VXWORKS_OS_CPP_BUILTINS.
+       (OVERRIDE_OPTIONS, SUBTARGET_CPP_SPEC): Define.
+       (CC1_SPEC): Add -tstrongarm.  Line up backslashes.
+       (VXWORKS_ENDIAN_SPEC): Define.
+       (ASM_SPEC): Add VXWORKS_ENDIAN_SPEC.
+       (LIB_SPEC, STARTFILE_SPEC, ENDFILE_SPEC): Redefine to their
+       VXWORKS_* equivalents.
+       (LINK_SPEC): Likewise, but add VXWORKS_ENDIAN_SPEC.
+       (ASM_FILE_START): Delete.
+       (TARGET_VERSION): Reformat.
+       (FPUTYPE_DEFAULT, FUNCTION_PROFILER): Define.
+       (DEFAULT_STRUCTURE_SIZE_BOUNDARY): Define.
+       * config/arm/t-vxworks (LIB1ASMSRC, LIB1ASMFUNCS): Define.
+       (FPBIT, DPBIT): Define.
+       (fp-bit.c, dp-bit.c): New rules.
+       (MULTILIB_OPTIONS): Add strongarm, -mrtp and -mrtp/-fPIC multilibs.
+       (MULTILIB_MATCHES, MULTILIB_EXCEPTIONS): Define.
+       * config/arm/arm-protos.h (arm_emit_call_insn): Declare.
+       * config/arm/arm.h: Include vxworks-dummy.h.
+       * config/arm/arm.c (arm_elf_asm_constructor, arm_elf_asm_destructor):
+       Mark with ATTRIBUTE_UNUSED.
+       (arm_override_options): Do not allow VxWorks RTP PIC to be used
+       for Thumb.  Force r9 to be the PIC register for VxWorks RTPs and
+       make it incompatible with -msingle-pic-base.
+       (arm_function_ok_for_sibcall): Return false for calls that might
+       go through a VxWorks PIC PLT entry.
+       (require_pic_register): New function, split out from...
+       (legitimize_pic_address): ...here.  Do not use GOTOFF accesses
+       for VxWorks RTPs.
+       (arm_load_pic_register): Handle the VxWorks RTP initialization
+       sequence.  Use pic_reg as a shorthand for cfun->machine->pic_reg.
+       (arm_emit_call_insn): New function.
+       (arm_assemble_integer): Do not use GOTOFF accesses for VxWorks RTP.
+       * config/arm/arm.md (UNSPEC_PIC_OFFSET): New unspec number.
+       (pic_offset_arm): New pattern.
+       (call, call_value): Use arm_emit_call_insn.
+       (call_internal, call_value_internal): New expanders.
+       * config/arm/lib1funcs.asm (__PLT__): Define to empty for
+       VxWorks unless __PIC__.
+
+2007-05-30  Eric Christopher  <echristo@gmail.com>
+
+       * genrecog.c: Include regs.h in generated file.
+       * genemit.c: Ditto. Fix up formatting.
+       * config/mn10300/constraints.md: New.
+       * config/mn10300/mn10300.md: Include.
+       * config/mn10300/mn10300.c(mn10300_secondary_reload_class):
+       Fix up for removed macro.
+       * config/mn10300/predicates.md (call_address_operand): Ditto.
+       * config/mn10300/mn10300.h (REG_CLASS_FROM_LETTER): Delete.
+       (CONST_OK_FOR_I): Ditto.
+       (CONST_OK_FOR_J): Ditto.
+       (CONST_OK_FOR_K): Ditto.
+       (CONST_OK_FOR_L): Ditto.
+       (CONST_OK_FOR_M): Ditto.
+       (CONST_OK_FOR_N): Ditto.
+       (CONST_DOUBLE_OK_FOR_LETTER_P): Ditto.
+       (OK_FOR_Q): Ditto.
+       (OK_FOR_R): Ditto.
+       (OK_FOR_T): Ditto.
+       (EXTRA_CONSTRAINT): Ditto.
+
+2007-05-30 Uros Bizjak <ubizjak@gmail.com>
+
+       * config/i386/i386.h (MASK_64BIT, MASK_MMX, MASK_3DNOW*, MASK_SSE*):
+       Remove defines.
+       * config/i386/biarch.h (TARGET_64BIT_DEFAULT): Define to
+       OPTION_MASK_ISA_64BIT.
+       * config/i386/i386.c: Rename MASK_* macros to OPTION_MASK_ISA_*.
+
+2007-05-30  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/32152
+       * gimplify.c (gimplify_omp_atomic_pipeline): Use correct
+       types for comparison.
+       * fold-const.c (fold_comparison): Call maybe_canonicalize_comparison
+       with original typed arguments.
+       * config/i386/i386.c (ix86_gimplify_va_arg): Fix type mismatches.
+
+2007-05-30  Jakub Jelinek  <jakub@redhat.com>
+
+       PR tree-optimization/31769
+       * except.c (duplicate_eh_regions): Clear prev_try if
+       ERT_MUST_NOT_THROW region is inside of ERT_TRY region.
+
+2007-05-30  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-scalar-evolution.c (scev_const_prop): Do not create labels.
+       * tree-ssa-sink.c (statement_sink_location): Return basic block and
+       bsi of the location where statements should be inserted.
+       (sink_code_in_bb): Take bsi from statement_sink_location.
+       * lambda-code.c (lambda_loopnest_to_gcc_loopnest): Use bsi_after_labels
+       instead of bsi_start.
+       * tree-profile.c (tree_gen_ic_func_profiler): Pass BSI_NEW_STMT to
+       bsi_insert_after.
+       * tree-cfg.c (bsi_move_after): Pass BSI_NEW_STMT to bsi_insert_after.
+       (bsi_move_before): Document inconsistency with bsi_move_after.
+       (tree_redirect_edge_and_branch): Do not create labels if not necessary.
+
+2007-05-30 Uros Bizjak <ubizjak@gmail.com>
+
+       * config/i386/i386.h (TARGET_ABM): New define.
+       (TARGET_POPCNT): Ditto.
+       (TARGET_64BIT, TARGET_MMX, TARGET_3DNOW, TARGET_3DNOW_A, TARGET_SSE*):
+       New temporary defines to redefine from OPTION_ISA_* defines.
+       (MASK_64BIT, MASK_MMX, MASK_3DNOW, MASK_3DNOW_A, MASK_SSE*):
+       New temporary defines to redefine from OPTION_MASK_ISA_* defines.
+       (ix86_isa_flags): New extern int declaration.
+       (TARGET_SUBTARGET_DEFAULT): New define.
+       (TARGET_SUBTARGET_ISA_DEFAULT): Ditto.
+       (TARGET_SUBTARGET32_DEFAULT): Ditto.
+       (TARGET_SUBTARGET32_ISA_DEFAULT): Ditto.
+       (TARGET_SUBTARGET64_ISA_DEFAULT): Ditto.
+       * config/i386/unix.h: Undef TARGET_SUBTARGET_DEFAULT before define.
+       * config/i386/darwin.h: Change TARGET_64BIT define to
+       OPTION_ISA_64BIT.
+
+       * config/i386/i386.opt (m3dnowa): Define as undocumented option
+       using existing "ix86_isa_flags" varible.
+       (m32, m64): Use existing "ix86_isa_flags" variable.
+       (mmmx, m3dnow): Ditto.
+       (msse, msse2, msse3, mssse3, msse4.1, msse4a): Ditto.
+       (mabm): Define as non-negative option using "x86_abm" variable.
+       (mpopcnt): Define as non-negative option using "x86_popcnt" variable.
+
+       * config/i386/i386.c (ix86_arch_features) [X86_ARCH_CMOVE]:
+       Rewrite feature test bitmap.
+       (ix86_isa_flags): New initialized global int varible.
+       (ix86_isa_flags_explicit): New static int variable.
+       (ix86_handle_option): Set "ix86_isa_flags_explicit" when mmmx, m3dnow,
+       msse, msse2, msse3, msse4.1 and msse4a option is processed.  Change
+       i86_isa_flags and ix86_isa_flags_explicit, not target_flags and
+       target_flags_explicit.
+       (override_options): Remove "target_enable" and "target_disable" fields
+       from "struct ptt". Update processor_target_table accordingly. Remove
+       PTA_PREFETCH_SSE from processor_alias_table entry if PTE_SSE is
+       defined and rearrange PTA_* bits.  Use "ix86_isa_flags" instead of
+       "target_flags" and "ix86_isa_flags_explicit" instead of
+       "target_flags_explicit" when masked with MASK_64BIT, MASK_MMX,
+       MASK_3DNOW, MASK_3DNOW_A or MASK_SSE*.  Set "x86_abm" to true when
+       PTA_ABM is set in processor_alias_table flags entry.  Set "x86_popcnt"
+       to true when either of PTA_POPCNT or PTA_ABM is set in
+       processor_alias_table flags entry.  Set "x86_prefetch_sse" to true
+       when either of PTA_PREFETCH_SSE or PTA_SSE is set in
+       processor_alias_table flags entry.  Remove handling of
+       "target_enable" and "target_disable" fields of processor_target_table.
+       Mask "target_flags" with TARGET_SUBTARGET32_DEFAULT for 32-bit
+       targets or with TARGET_SUBTARGET64_DEFAULT for 64-bit targets.
+       Mask "ix86_isa_flags" with TARGET_SUBTARGET32_ISA_DEFAULT for 32-bit
+       targets or with TARGET_SUBTARGET64_ISA_DEFAULT for 64-bit targets.
+       (def_builtin): Mask "mask" variable with "ix86_isa_flags", not
+       "target_flags".
+       (TARGET_DEFAULT_TARGET_FLAGS): Do not include TARGET_64BIT_DEFAULT.
+
+2007-05-29  David Daney  <ddaney@avtrex.com>
+
+       PR gcc/31975
+       * config/mips/mips.c (mips_output_mi_thunk): Emit
+       NOTE_INSN_PROLOGUE_END at beginning of the thunk.
+
+2007-05-29  Hui-May Chang  <hm.chang@apple.com>
+       * config/i386/i386.c (ix86_function_regparm): Added checking of
+       ix86_force_align_arg_pointer to determine the number of
+       register parameters.
+
+2007-05-29  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-vectorizer.h (DR_MISALIGNMENT): Cast aux to integer.
+       (SET_DR_MISALIGNMENT): New.
+       * tree-vect-analyze.c (vect_compute_data_ref_alignment,
+       vect_update_misalignment_for_peel, vect_enhance_data_refs_alignment):
+       Use SET_DR_MISALIGNMENT.
+       * tree-predcom.c (split_data_refs_to_components): Cast dr->aux from
+       pointer.
+       * tree-data-ref.c (create_data_ref, compute_all_dependences,
+       find_loop_nest): Export.
+       * tree-data-ref.h (struct data_reference): Change aux field to pointer.
+       (create_data_ref, compute_all_dependences, find_loop_nest): Declare.
+       * tree-ssa-loop-prefetch.c: Include tree-data-ref.h.
+       (L1_CACHE_SIZE_BYTES, L2_CACHE_SIZE_BYTES, NONTEMPORAL_FRACTION):
+       New macros.
+       (struct mem_ref): Add field reuse_distance.
+       (find_or_create_group, record_ref): Use XNEW instead of xcalloc.
+       Initialize reuse_distance field.
+       (issue_prefetch_ref): Select temporality of prefetch according to
+       reuse_distance.
+       (volume_of_references, volume_of_dist_vector, add_subscript_strides,
+       self_reuse_distance, determine_loop_nest_reuse): New functions.
+       (loop_prefetch_arrays): Call determine_loop_nest_reuse.
+       (tree_ssa_prefetch_arrays): Dump L2 cache size.
+       * Makefile.in (tree-ssa-loop-prefetch.o): Add TREE_DATA_REF_H
+       dependency.
+
+2007-05-29  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-alias.c: Add aliasing overview.
+
+2007-05-29  Zuxy Meng  <zuxy.meng@gmail.com>
+           Danny Smith  <dannysmith@users.sourceforge.net>
+
+       PR target/29498
+       * config/i386/t-crtfm: Compile crtfastmath.o with
+       -minline-all-stringops.
+       * config/i386/cygwin.h (ENDFILE_SPECS): Add crtfastmath.o.
+       * config/i386/mingw32.h (ENDFILE_SPECS): Add crtfastmath.o.
+
+2007-05-28  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * doc/md.texi: Document constraints on HP PA-RISC.
+
+       * pa/constraints.md: New file.
+       * pa.md: Include constraints.md.
+       * pa.c (cint_ok_for_move): Avoid using CONST_OK_FOR_LETTER_P.
+       (integer_store_memory_operand, ldil_cint_p): New functions.
+       * pa-protos.h (integer_store_memory_operand, ldil_cint_p): Declare.
+       * pa.h (CONST_OK_FOR_LETTER_P, CONST_DOUBLE_OK_FOR_LETTER_P,
+       IS_RELOADING_PSEUDO_P, EXTRA_CONSTRAINT): Remove.
+       * pa32-regs.h (REG_CLASS_FROM_LETTER): Remove.
+       * pa64-regs.h (REG_CLASS_FROM_LETTER): Remove.
+
+2007-05-28  Andrew Pinski  <Andrew_pinski@playstation.sony.com>
+
+       PR c/31339
+       * c-typeck.c (build_unary_op <case PREINCREMENT_EXPR,
+       case POSTINCREMENT_EXPR, case PREDECREMENT_EXPR,
+       case POSTDECREMENT_EXPR>): Return the error_mark_node
+       if either the real or imaginary parts would an
+       error_mark_node.
+
+2007-05-28  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-dce.c (eliminate_unnecessary_stmts): Release LHS SSA
+       name when we remove it from a call.
+
+2007-05-28  Kazu Hirata  <kazu@codesourcery.com>
+
+       * targhooks.c (default_narrow_bitfield): Remove.
+       * targhooks.h: Remove the prototype for
+       default_narrow_bitfield.
+
+       * langhooks-def.h: Remove the prototype for
+       hook_get_alias_set_0.
+       * langhooks.c (hook_get_alias_set_0): Remove.
+
+       * global.c (EXECUTE_IF_CONFLICT): Remove.
+
+2007-05-28  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR tree-opt/32100
+       * fold-const.c (tree_expr_nonnegative_warnv_p): Don't
+       return true when truth_value_p is true and the type
+       is of signed:1.
+
+2007-05-28  Gerald Pfeifer  <gerald@pfeifer.com>
+
+       * doc/install.texi (Prerequisites): We no longer require Autoconf
+       2.13 for the top-level.
+
+2007-05-28  Uros Bizjak  <ubizjak@gmail.com>
+
+       * target/i386/i386.c (ix86_expand_vector_move): Expand unaligned
+       memory access via x86_expand_vector_move_misalign() only for
+       TImode values on 32-bit targets.
+
+2007-05-28  Razya Ladelsky  <razya@il.ibm.com>
+
+       * matrix-reorg.c: New file. Implement matrix flattening and
+       transposing optimization.
+       * tree-pass.h: Add matrix reorg pass.
+       * common.opt: Add fipa-mreorg flag.
+       * Makefile.in: Add matrix-reorg.c.
+       * passes.c: Add matrix reorg pass.
+       * varpool.c (add_new_static_var): New function.
+       * cgraph.h (add_new_static_var): Declare.
+
+2007-05-27  Eric Christopher  <echristo@apple.com>
+
+       * config/rs6000/rs6000.c (rs6000_emit_prologue): Update
+       sp_offset depending on stack size. Save r12 depending
+       on registers we're saving later.
+       (rs6000_emit_epilogue): Update sp_offset depending only
+       on stack size.
+
+2007-05-27  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-vrp.c (execute_vrp): Do not check whether current_loops == NULL.
+       * tree-chrec.c (evolution_function_is_invariant_rec_p): Ditto.
+       * ifcvt.c (if_convert): Ditto.
+       * tree-ssa-threadupdate.c (thread_block): Ditto.
+       (thread_through_all_blocks): Ditto.  Assert that loops were analysed.
+       * tree-ssa-loop-manip.c (rewrite_into_loop_closed_ssa,
+       verify_loop_closed_ssa): Check number_of_loops instead of
+       current_loops.
+       * predict.c (tree_estimate_probability): Ditto.
+       * tree-if-conv.c (main_tree_if_conversion): Ditto.
+       * tree-ssa-loop-ch.c (copy_loop_headers): Ditto.
+       * modulo-sched.c (sms_schedule): Ditto.
+       * tree-scalar-evolution.c (scev_const_prop): Ditto.
+       (scev_finalize): Do not do anything if scev analysis was not
+       initialized.
+       * cfgloopanal.c (mark_irreducible_loops): Do not check whether
+       current_loops == NULL.
+       (mark_loop_exit_edges): Check number_of_loops instead of current_loops.
+       * loop-init.c (loop_optimizer_init): Do not free current_loops when
+       there are no loops.
+       (loop_optimizer_finalize): Assert that loops were analyzed.
+       (rtl_move_loop_invariants, rtl_unswitch, rtl_unroll_and_peel_loops,
+       rtl_doloop): Check number_of_loops instead of current_loops.
+       * tree-ssa-loop.c (tree_loop_optimizer_init): Do not check whether
+       current_loops == NULL.
+       (tree_ssa_loop_init, tree_ssa_loop_im, tree_ssa_loop_unswitch,
+       gate_tree_vectorize tree_linear_transform, check_data_deps,
+       tree_ssa_loop_ivcanon, tree_ssa_empty_loop, tree_ssa_loop_bounds,
+       tree_complete_unroll, tree_ssa_loop_prefetch, tree_ssa_loop_ivopts):
+       Check number_of_loops instead of current_loops.
+       (tree_ssa_loop_done): Do not check whether current_loops == NULL.
+       * tree-ssa-pre.c (fini_pre): Do not take do_fre argument.  Always
+       free loops if available.
+       (execute_pre): Do not pass do_fre to fini_pre.
+
+2007-05-27  Tobias Burnus  <burnus@net-b.de>
+
+       PR middle-end/32083
+       * real.c (mpfr_from_real): Fix sign of -Inf.
+
+2007-05-27  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * tree-vect-transform.c (vectorizable_conversion): Initialize
+       tree_code variables to ERROR_MARK.
+       (vectorizable_type_demotion): Likewise.
+       (vectorizable_type_promotion): Likewise.
+
+2007-05-26  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32065
+       * config/i386/i386.md (movti): Handle push operands via
+       ix86_expand_push().
+
+2007-05-26  Kazu Hirata  <kazu@codesourcery.com>
+
+       * basic-block.h: Remove the prototype for merge_seq_blocks.
+       * cfgcleanup.c (merge_seq_blocks): Remove.
+
+       * tree-flow.h: Remove the prototype for is_aliased_with.
+       * tree-ssa-alias.c (is_aliased_with): Remove.
+
+2007-05-26  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386-protos.h (ix86_expand_sse4_unpack): New.
+
+       * config/i386/i386.c (ix86_expand_sse4_unpack): New.
+
+       * config/i386/sse.md (vec_unpacku_hi_v16qi): Call
+       ix86_expand_sse4_unpack if SSE4.1 is enabled.
+       (vec_unpacks_hi_v16qi): Likewise.
+       (vec_unpacku_lo_v16qi): Likewise.
+       (vec_unpacks_lo_v16qi): Likewise.
+       (vec_unpacku_hi_v8hi): Likewise.
+       (vec_unpacks_hi_v8hi): Likewise.
+       (vec_unpacku_lo_v8hi): Likewise.
+       (vec_unpacks_lo_v8hi): Likewise.
+       (vec_unpacku_hi_v4si): Likewise.
+       (vec_unpacks_hi_v4si): Likewise.
+       (vec_unpacku_lo_v4si): Likewise.
+       (vec_unpacks_lo_v4si): Likewise.
+
+2007-05-26  Kazu Hirata  <kazu@codesourcery.com>
+
+       * c-typeck.c, config/arm/arm.c, config/darwin.c,
+       config/sh/symbian.c, gcc.c, ipa-cp.c, ipa-inline.c, loop-iv.c,
+       omega.c, tree-ssa-loop-niter.c, treestruct.def: Fix typos and
+       follow spelling conventions in various
+       warning/error/diagnostic messages.
+
+       * config/i386/i386.c, config/pa/pa.c, config/spu/spu.c,
+       df-problems.c, df-scan.c, domwalk.c, ebitmap.c, ebitmap.h,
+       fold-const.c, gcc.c, ipa-type-escape.c, omega.c, omega.h,
+       tree-ssa-coalesce.c, tree-ssa-live.c, tree-ssa-structalias.c,
+       tree-vrp.c: Fix comment typos.  Follow spelling conventions.
+       * doc/tm.texi: Follow spelling conventions.
+
+2007-05-25  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR tree-opt/32090
+       * tree-ssa-forwprop.c
+       (forward_propagate_addr_into_variable_array_index): Remove
+       the lhs argument.  Use the type of def_rhs instead of lhs.
+       (forward_propagate_addr_expr_1): Update use of
+       forward_propagate_addr_into_variable_array_index.
+
+2007-05-25  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/mips.c (mips_attribute_table): Add "near" and "far"
+       function attributes, "far" being an alias for "long_call".
+       (TARGET_COMP_TYPE_ATTRIBUTES): Define as mips_comp_type_attributes.
+       (mips_near_type_p, mips_far_type_p): New.
+       (mips_comp_type_attributes): New function to check that attributes
+       attached to a function type are compatible.
+       (mips_output_mi_thunk): Test SYMBOL_REF_LONG_CALL_P() rather than
+       TARGET_LONG_CALLS when deciding whether we can do a direct sibcall
+       to the target function of the thunk.
+       (mips_encode_section_info): Check for "near" and "far" function
+       attributes, and always set the SYMBOL_FLAG_LONG_CALL bit explicitly.
+
+       * config/mips/predicates.md (const_call_insn_operand): Test only
+       SYMBOL_REF_LONG_CALL_P() and not TARGET_LONG_CALLS.
+
+       * doc/extend.texi (Function Attributes): Document MIPS "near" and
+       "far" attributes.
+
+       * testsuite/gcc.target/mips/near-far-1.c: New test case.
+       * testsuite/gcc.target/mips/near-far-2.c: New test case.
+       * testsuite/gcc.target/mips/near-far-3.c: New test case.
+       * testsuite/gcc.target/mips/near-far-4.c: New test case.
+
+2007-05-25  Eric Christopher  <echristo@apple.com>
+
+       * config.gcc: Add i386/t-fprules-softfp64 and soft-fp/t-softfp
+       to x86-darwin configurations.
+       * config/i386/t-darwin: Add softfp support.
+       * config/i386/t-darwin64: Ditto.
+       * config/i386/sfp-machine.h: If mach then don't use
+       aliasing, emit a stub to call.
+
+2007-05-25  Kazu Hirata  <kazu@codesourcery.com>
+
+       * cfglayout.c, cgraphunit.c, config/avr/avr.c, fold-const.c,
+       haifa-sched.c, optabs.h, tree-affine.c, tree-data-ref.c,
+       tree-predcom.c, tree-ssa-alias-warnings.c,
+       tree-ssa-forwprop.c, tree-vect-analyze.c, tree-vrp.c: Fix
+       comment typos.  Follow spelling conventions.
+       * doc/cpp.texi, doc/invoke.texi: Fix typos.
+
+2007-05-26  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/32065
+       * target/i386/i386.c (ix86_expand_vector_move): Force SUBREGs of
+       constants into memory.  Expand unaligned memory references for
+       SSE modes via x86_expand_vector_move_misalign() function.
+
+2007-05-25  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/sse.md (*vec_extractv2di_1_sse2): Do not calculate
+       "memory" attribute for "sseishft" type insn without operands[2].
+
+2007-05-25  Dirk Mueller  <dmueller@suse.de>
+           Marcus Meissner <meissner@suse.de>
+
+       * doc/extend.texi (alloc_size): New attribute.
+       * c-common.c (handle_alloc_size_attribute): New.
+       * tree-object-size.c (alloc_object_size): Use alloc_size
+       attribute, if available.
+
+2007-05-25  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c (__builtin_ia32_vec_ext_v2df): Mark it
+       with MASK_SSE2.
+       (__builtin_ia32_vec_ext_v2di): Likewise.
+       (__builtin_ia32_vec_ext_v4si): Likewise.
+       (__builtin_ia32_vec_ext_v8hi): Likewise.
+       (__builtin_ia32_vec_ext_v16qi): Likewise.
+       (__builtin_ia32_vec_set_v8hi): Likewise.
+
+2007-05-25  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/sse.md (*vec_extractv2di_1_sse2): Correct shift.
+
+2007-05-25  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/arm/arm-protos.h (arm_encode_call_attribute): Delete.
+       (arm_is_longcall_p): Rename to...
+       (arm_is_long_call_p): ...this.  Take a single tree argument and
+       return a bool.
+       * config/arm/arm.h (CALL_SHORT, CALL_LONG, CALL_NORMAL): Delete.
+       (CUMULATIVE_ARGS): Remove call_cookie.
+       (SHORT_CALL_FLAG_CHAR, LONG_CALL_FLAG_CHAR, ENCODED_SHORT_CALL_ATTR_P)
+       (ENCODED_LONG_CALL_ATTR_P): Delete.
+       (ARM_NAME_ENCODING_LENGTHS): Remove SHORT_CALL_FLAG_CHAR and
+       LONG_CALL_FLAG_CHAR cases.
+       (ARM_DECLARE_FUNCTION_SIZE): Delete.
+       * config/arm/elf.h (ASM_DECLARE_FUNCTION_SIZE): Don't use
+       ARM_DECLARE_FUNCTION_SIZE.
+       * config/arm/arm.c (arm_init_cumulative_args): Don't set call_cookie.
+       (arm_function_arg): Return const0_rtx for VOIDmode arguments.
+       (arm_encode_call_attribute, current_file_function_operand): Delete.
+       (arm_function_in_section_p): New function.
+       (arm_is_longcall_p): Rename to...
+       (arm_is_long_call_p): ...this.  Take the target function as a single
+       argument and return a bool.  Do not rely on call cookies.  Check
+       whether the target symbol is in the same section as the current
+       function, not just the same compilation unit.
+       (arm_function_ok_for_sibcall): Use arm_is_long_call_p.
+       (arm_encode_section_info): Don't encode a call type.
+       * config/arm/arm.md (call, call_value): Update calls to
+       arm_is_long(_)call_p.  Simplify logic.
+       (*call_symbol, *call_value_symbol, *call_insn, *call_value_insn):
+       Update calls to arm_is_long(_)call_p.
+
+2007-05-25  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31982
+       * tree-ssa-forwprop.c
+       (forward_propagate_addr_into_variable_array_index): Handle arrays
+       with element size one.
+
+2007-05-24  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * config/spu/spu.md (smulsi3_highpart): Unshare the rtl chain.
+       (umulsi3_highpart): Likewise.
+
+2007-05-24  Ian Lance Taylor  <iant@google.com>
+
+       PR rtl-optimization/32069
+       * regclass.c (regclass): Don't crash if the entry in regno_reg_rtx
+       is NULL.
+
+2007-05-24  Ollie Wild  <aaw@google.com>
+
+       * doc/cpp.texi (Common Predefined Macros): Add __COUNTER__
+       description.
+
+2007-05-24  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * postreload-gcse.c (reg_changed_after_insn_p): New function.
+       (oprs_unchanged_p): Use it to check all registers in a REG.
+       (record_opr_changes): Look for clobbers in CALL_INSN_FUNCTION_USAGE.
+       (reg_set_between_after_reload_p): Delete.
+       (reg_used_between_after_reload_p): Likewise.
+       (reg_set_or_used_since_bb_start): Likewise.
+       (eliminate_partially_redundant_load): Use reg_changed_after_insn_p
+       and reg_used_between_p instead of reg_set_or_used_since_bb_start.
+       Use reg_set_between_p instead of reg_set_between_after_reload_p.
+       * rtlanal.c (reg_set_p): Check whether REG overlaps
+       regs_invalidated_by_call, rather than just checking the
+       membership of REGNO (REG).
+
+2007-05-24  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * doc/passes.texi: Document predictive commoning.
+       * doc/invoke.texi (-fpredictive-commoning): Document.
+       * opts.c (decode_options): Enable flag_predictive_commoning on -O3.
+       * tree-ssa-loop-im.c (get_lsm_tmp_name): Export.  Allow
+       adding indices to the generated name.
+       (schedule_sm): Pass 0 to get_lsm_tmp_name.
+       * tree-ssa-loop-niter.c (stmt_dominates_stmt_p): Export.
+       * tree-pretty-print.c (op_symbol_1): Renamed to ...
+       (op_symbol_code): ... and exported.
+       (dump_omp_clause, op_symbol): Use op_symbol_code
+       instead of op_symbol_1.
+       * tree-pass.h (pass_predcom): Declare.
+       * timevar.def (TV_PREDCOM): New timevar.
+       * tree-ssa-loop.c (run_tree_predictive_commoning,
+       gate_tree_predictive_commoning, pass_predcom): New.
+       * tree-data-ref.c (find_data_references_in_loop): Find the
+       references in dominance order.
+       (canonicalize_base_object_address): Ensure that the result has
+       pointer type.
+       (dr_analyze_innermost): Export.
+       (create_data_ref): Code to fail for references with invariant
+       address moved ...
+       (find_data_references_in_stmt): ... here.
+       * tree-data-ref.h (dr_analyze_innermost): Declare.
+       * tree-affine.c: Include tree-gimple.h and hashtab.h.
+       (aff_combination_find_elt, name_expansion_hash,
+       name_expansion_eq, tree_to_aff_combination_expand,
+       double_int_constant_multiple_p, aff_combination_constant_multiple_p):
+       New functions.
+       * tree-affine.h (aff_combination_constant_multiple_p,
+       tree_to_aff_combination_expand): Declare.
+       * tree-predcom.c: New file.
+       * common.opt (fpredictive-commoning): New option.
+       * tree-flow.h (op_symbol_code, tree_predictive_commoning,
+       stmt_dominates_stmt_p, get_lsm_tmp_name): Declare.
+       * Makefile.in (tree-predcom.o): Add.
+       (tree-affine.o): Add TREE_GIMPLE_H dependency.
+       * passes.c (init_optimization_passes): Add dceloop after
+       copy propagation in loop optimizer.  Add predictive commoning
+       to loop optimizer passes.
+
+2007-05-24  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * target-def.h (TARGET_MANGLE_DECL_ASSEMBLER_NAME): Correct
+       default hook.
+
+2007-05-24  Jan Hubicka  <jh@suse.cz>
+
+       * gengenrtl.c (gendecl, gendef): Output the gens annotated for
+       statistics.
+       (genheader): Include statistics.h.
+
+       * doc/invoke.texi (-fdump-unnumbered): Update docs when line number
+       notes are gone.
+       * print-rtl.c (flag_dump_unnumbered): Update comments.
+       (print_rtl): Fix my previous change.
+       * emit-rtl.c (emit_note_before, emit_note_after): Clear out note
+       specific data.
+
+2007-05-24  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR middle-end/32018
+       * tree-ssa-threadupdate.c (thread_through_loop_header): Use
+       set_loop_copy.
+       (thread_through_all_blocks): Call initialize_original_copy_tables
+       and free_original_copy_tables.
+       * cfgloopmanip.c (duplicate_loop, duplicate_loop_to_header_edge):
+       Use set_loop_copy.
+       * tree-cfg.c (tree_duplicate_sese_region): Ditto.
+       * cfghooks.c (duplicate_block): Use get_loop_copy.
+       * cfg.c: Include cfgloop.h.
+       (loop_copy): New hash table.
+       (initialize_original_copy_tables): Initialize loop_copy table.
+       (free_original_copy_tables): Free loop_copy table.
+       (copy_original_table_clear, copy_original_table_set,
+       set_loop_copy, get_loop_copy): New functions.
+       (set_bb_original, set_bb_copy): Use copy_original_table_set.
+       * cfgloop.h (struct loop): Remove copy field.
+       * Makefile.in (cfg.o): Add CFGLOOP_H dependency.
+       * basic-block.h (set_loop_copy, get_loop_copy): Declare.
+
+2007-05-24  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c (ix86_handle_option): Handle SSE4.1 for
+       -msse/-msse2/-msse3.
+
+2007-05-24  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c (ix86_init_mmx_sse_builtins): Mark
+       __builtin_ia32_vec_set_v2di with MASK_64BIT.
+
+2007-05-24  Danny Smith  <dannysmith@users.sourceforge.net>
+
+       PR target/27067
+       * doc/tm.texi (TARGET_MANGLE_DECL_ASSEMBLER_NAME): Document.
+       * targhooks.h (default_mangle_decl_assembler_name): Declare
+       default hook.
+       * targhooks.c (default_mangle_decl_assembler_name): Define
+       default hook.
+       * target-def.h (TARGET_MANGLE_DECL_ASSEMBLER_NAME) New. Set to
+       default hook.
+       * target.h (struct gcc_target): Add mangle_decl_assembler_name field.
+       * langhooks.c (lhd_set_decl_assembler_name): Call
+       targetm.mangle_decl_assembler_name for names with global scope.
+
+       * config/i386/cygming.h (TARGET_MANGLE_DECL_ASSEMBLER_NAME) Override
+       default.
+       (ASM_OUTPUT_DEF_FROM_DECLS): Simplify to use DECL_ASSEMBLER_NAME.
+       * config/i386/i386-protos.h (i386_pe_mangle_decl_assembler_name):
+       Declare.
+       * config/i386/winnt.c (i386_pe_maybe_mangle_decl_assembler_name):
+       New. Factored out of i386_pe_encode_section_info.
+       (gen_stdcall_or_fastcall_suffix): Get name identifier as argument.
+       Move check for prior decoration of stdcall
+       symbols to i386_pe_encode_section_info.
+       (i386_pe_encode_section_info): Adjust call to
+       gen_stdcall_or_fastcall_suffix.  Use
+       i386_pe_maybe_mangle_decl_assembler_name, if needed.
+       (i386_pe_mangle_decl_assembler_name): New. Wrap
+       i386_pe_maybe_mangle_decl_assembler_name.
+
+2007-05-16  Rafael Ávila de Espíndola  <espindola@google.com>
+
+       * c-common.c (c_common_signed_or_unsigned_type): Delay the check for
+       INTEGRAL_TYPE_P and TYPE_UNSIGNED.
+       * langhooks.c (get_signed_or_unsigned_type): Don't check for
+       INTEGRAL_TYPE_P or TYPE_UNSIGNED.
+       (lhd_signed_or_unsigned_type): Check for INTEGRAL_TYPE_P and
+       TYPE_UNSIGNED.
+
+2007-05-23  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       Fix up MIPS16 hard float and add support for complex.
+
+       * config/mips/mips.h (TARGET_HARD_FLOAT_ABI): New.
+       (TARGET_SOFT_FLOAT_ABI): New.
+       (TARGET_CPU_CPP_BUILTINS): Define __mips_hard_float and
+       __mips_soft_float to reflect the ABI in use, not whether the
+       FPU is directly accessible (e.g., in MIPS16 mode).
+       (UNITS_PER_HWFPVALUE): Use TARGET_SOFT_FLOAT_ABI.
+       (UNITS_PER_FPVALUE): Likewise.
+
+       * config/mips/mips.c (mips_expand_call): Remove redundant
+       TARGET_MIPS16 check.
+       (mips_arg_regno): New.
+       (function_arg_advance): When setting bits in cum->fp_code for
+       MIPS16, don't subtract 1 from cum->arg_number, since it is now
+       zero-based.
+       (function_arg): Use mips_arg_regno.
+       (mips_return_mode_in_fpr_p): New.
+       (mips16_call_stub_mode_suffix): New.
+       (mips16_cfun_returns_in_fpr_p): New.
+       (mips_save_reg_p): Use mips16_cfun_returns_in_fpr_p.
+       (mips_output_function_prologue): Test mips16_hard_float, not
+       !TARGET_SOFT_FLOAT, to decide when a function stub is required.
+       (mips_expand_epilogue): Call MIPS16 helper routines to copy
+       return value into a floating-point register.
+       (mips_can_use_return_insn): Use mips16_cfun_returns_in_fpr_p.
+       (mips_function_value): Rewrite to use mips_return_mode_in_fpr_p.
+       (mips16_fp_args): Handle MIPS32r2 ISA which supports
+       TARGET_FLOAT64, and use mfhc1/mthc1 to copy the most significant
+       word of double arguments from or to the high bits of 64-bit
+       floating point registers.
+       (build_mips16_function_stub): Fill in DECL_RESULT for stubdecl.
+       (mips16_fpret_double): New helper function.
+       (build_mips16_call_stub): Use mips16_return_mode_in_fpr_p.  Add
+       support for complex modes.  Fill in DECL_RESULT for stubdecl.
+       (mips_init_libfuncs): Remove redundant TARGET_MIPS16 check.
+
+       * config/mips/mips16.S
+       (RET, ARG1, ARG2): New.
+       (MERGE_GPRf, MERGE_GPRt): New.
+       (DELAYt, DELAYf): New.
+       (MOVE_SF_BYTE0, MOVE_SI_BYTE0): New.
+       (MOVE_SF_BYTE4, MOVE_SF_BYTE8): New.
+       (MOVE_DF_BYTE0, MOVE_DF_BYTE8): New.
+       (MOVE_SF_RET, MOVE_SC_RET, MOVE_DF_RET, MOVE_DC_RET, MOVE_SI_RET): New.
+       (SFOP): Renamed to...
+       (OPSF3): This, and macro-ified.  Updated all uses.
+       (SFOP2): Renamed to...
+       (OPSF2): This, and macro-ified.  Updated all uses.
+       (SFCMP): Renamed to...
+       (CMPSF): This, and macro-ified.  Updated all uses.
+       (SFREVCMP): Renamed to...
+       (REVCMPSF): This, and macro-ified.  Updated all uses.
+       (__mips16_floatsisf, __mips16_fix_truncsfsi): Macro-ified.
+       (LDDBL1, LDDBL2, RETDBL): Deleted.
+       (DFOP): Renamed to...
+       (OPDF3): This, and macro-ified.  Updated all uses.
+       (DFOP2): Renamed to...
+       (OPDF2): This, and macro-ified.  Updated all uses.
+       (__mips16_extendsfdf2, __mips16_truncdfsf2): Macro-ified.
+       (DFCMP): Renamed to...
+       (CMPDF): This, and macro-ified.  Updated all uses.
+       (DFREVCMP): Renamed to...
+       (REVCMPDF): This, and macro-ified.  Updated all uses.
+       (__mips16_floatsidf, __mips16_fix_truncdfsi): Macro-ified.
+       (RET_FUNCTION): New.
+       (__mips16_ret_sf, __mips16_ret_df): Macro-ified.
+       (__mips16_ret_sc, __mips16_ret_dc): New.
+       (STUB_ARGS_0, STUB_ARGS_1, STUB_ARGS_5, STUB_ARGS_9, STUB_ARGS_2,
+       STUB_ARGS_6, STUB_ARGS_10): New.
+       (CALL_STUB_NO_RET): New.
+       (__mips16_call_stub_1): Macro-ified.
+       (__mips16_call_stub_5): Macro-ified.
+       (__mips16_call_stub_2): Macro-ified.
+       (__mips16_call_stub_6): Macro-ified.
+       (__mips16_call_stub_9): Macro-ified.
+       (__mips16_call_stub_10): Macro-ified.
+       (CALL_STUB_RET): New.
+       (__mips16_call_stub_sf_0): Macro-ified.
+       (__mips16_call_stub_sf_1): Macro-ified.
+       (__mips16_call_stub_sf_5): Macro-ified.
+       (__mips16_call_stub_sf_2): Macro-ified.
+       (__mips16_call_stub_sf_6): Macro-ified.
+       (__mips16_call_stub_sf_9): Macro-ified.
+       (__mips16_call_stub_sf_10): Macro-ified.
+       (__mips16_call_stub_df_0): Macro-ified.
+       (__mips16_call_stub_df_1): Macro-ified.
+       (__mips16_call_stub_df_5): Macro-ified.
+       (__mips16_call_stub_df_2): Macro-ified.
+       (__mips16_call_stub_df_6): Macro-ified.
+       (__mips16_call_stub_df_9): Macro-ified.
+       (__mips16_call_stub_df_10): Macro-ified.
+       (__mips16_call_stub_sc_0): New.
+       (__mips16_call_stub_sc_1): New.
+       (__mips16_call_stub_sc_5): New.
+       (__mips16_call_stub_sc_2): New.
+       (__mips16_call_stub_sc_6): New.
+       (__mips16_call_stub_sc_9): New.
+       (__mips16_call_stub_sc_10): New.
+       (__mips16_call_stub_dc_0): New.
+       (__mips16_call_stub_dc_1): New.
+       (__mips16_call_stub_dc_5): New.
+       (__mips16_call_stub_dc_2): New.
+       (__mips16_call_stub_dc_6): New.
+       (__mips16_call_stub_dc_9): New.
+       (__mips16_call_stub_dc_10): New.
+
+       * config/mips/t-elf (LIB1ASMFUNCS): Add MIPS16 floating-point stubs.
+       * config/mips/t-isa3264 (LIB1ASMFUNCS): Likewise.
+       * config/mips/t-r2900 (LIB1ASMFUNCS): Likewise.
+
+2007-05-23  Ian Lance Taylor  <iant@google.com>
+
+       * doc/invoke.texi (Invoking GCC): Document that the order of the
+       -l option matters.
+
+2007-05-23  Chen Liqin  <liqin@sunnorth.com.cn>
+
+       PR target/30987
+       * config/score/misc.md (bitclr_c, bitset_c, bittgl_c): Remove.
+       * config/score/predicate.md (const_pow2, const_npow2): Remove.
+       * config/score/score.h (ASM_OUTPUT_EXTERNAL): Add ASM_OUTPUT_EXTERNAL
+       undef.
+
+       PR target/30474
+       * config/score/score.c (score_print_operand): Make sure that only
+       lower bits are used.
+
+2007-05-22  Ian Lance Taylor  <iant@google.com>
+
+       * tree-vrp.c (avoid_overflow_infinity): New static function,
+       broken out of set_value_range_to_value.
+       (set_value_range_to_value): Call avoid_overflow_infinity.
+       (extract_range_from_assert): Likewise.
+
+2007-05-22  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/31095
+        * builtins.c (expand_builtin_memmove_args): Strip nops that don't
+       change the type before looking for a COMPOUND_EXPR.
+
+2007-05-22  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (decompose_multiword_subregs): If we change an
+       insn, call remove_retval_note on it.
+
+2007-05-22  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * regs.h (end_hard_regno): New function.
+       (END_HARD_REGNO, END_REGNO): New macros.
+       (add_to_hard_reg_set): New function.
+       (remove_from_hard_reg_set): Likewise.
+       (in_hard_reg_set_p): Likewise.
+       (overlaps_hard_reg_set_p): Likewise.
+       * bt-load.c (find_btr_reference): Use overlaps_hard_reg_set_p.
+       (note_btr_set): Use END_HARD_REGNO.
+       * caller-save.c (setup_save_areas): Use end_hard_regno.
+       (mark_set_regs): Use END_HARD_REGNO.
+       (add_stored_regs): Use end_hard_regno.
+       (mark_referenced_regs): Use add_to_hard_reg_set.
+       * combine.c (update_table_tick): Use END_REGNO.
+       (record_value_for_reg): Likewise.
+       (record_dead_and_set_regs): Likewise.
+       (get_last_value_validate): Likewise.
+       (use_crosses_set_p): Likewise.
+       (reg_dead_at_p_1): Likewise.
+       (reg_dead_at_p): Likewise.
+       (mark_used_regs_combine): Use add_to_hard_reg_set.
+       (move_deaths): Use END_HARD_REGNO.
+       (reg_bitfield_target_p): Use end_hard_regno.
+       (distribute_notes): Use END_HARD_REGNO.
+       * cse.c (mention_regs): Use END_REGNO.
+       (insert): Use add_to_hard_reg_set.
+       (invalidate): Use END_HARD_REGNO.
+       (invalidate_for_call): Likewise.
+       (exp_equiv_p): Use END_REGNO.
+       (cse_insn): Likewise.
+       * cselib.c (cselib_invalidate_regno): Use end_hard_regno.
+       * df-problems.c (df_urec_mark_reg_change): Use END_HARD_REGNO.
+       * df-scan.c (df_ref_record): Use END_HARD_REGNO.
+       * function.c (keep_stack_depressed): Use end_hard_regno.
+       * global.c (global_alloc): Use end_hard_regno.
+       (global_conflicts): Use add_to_hard_reg_set instead of
+       mark_reg_live_nc.
+       (find_reg): Likewise.
+       (mark_reg_store): Likewise.
+       (mark_reg_conflicts): Likewise.
+       (mark_reg_death): Use remove_from_hard_reg_set.
+       (mark_reg_live_nc): Delete.
+       (set_preference): Use end_hard_regno.
+       * local-alloc.c (mark_life): Use add_to_hard_reg_set and
+       remove_from_hard_reg_set.
+       (post_mark_life): Use add_to_hard_reg_set.
+       * mode-switching.c (reg_dies): Use remove_from_hard_reg_set.
+       (reg_becomes_live): Use add_to_hard_reg_set.
+       * recog.c (reg_fits_class_p): Use in_hard_reg_set_p.
+       (peep2_find_free_register): Use add_to_hard_reg_set.
+       * reg-stack.c (convert_regs_exit): Use END_HARD_REGNO.
+       * regclass.c (record_reg_classes): Use in_hard_reg_set_p.
+       * regrename.c (note_sets): Use add_to_hard_reg_set.
+       (clear_dead_regs): Use remove_from_hard_reg_set.
+       (regrename_optimize): Use add_to_hard_reg_set.
+       (find_oldest_value_reg): Use in_hard_reg_set_p.
+       * reload.c (push_reload): Use in_hard_reg_set_p and end_hard_regno.
+       (hard_reg_set_here_p): Use end_hard_regno.
+       (decompose): Likewise.
+       (reg_overlap_mentioned_for_reload_p): Use END_HARD_REGNO.
+       (find_equiv_reg): Use in_hard_reg_set_p and end_hard_regno.
+       * reload1.c (compute_use_by_pseudos): Use add_to_hard_reg_set.
+       (mark_home_live): Use end_hard_regno.
+       (spill_hard_reg): Likewise.
+       (clear_reload_reg_in_use): Likewise.
+       * reorg.c (delete_prior_computation): Use END_REGNO.
+       * resource.c (update_live_status): Use END_HARD_REGNO.
+       (mark_referenced_resources): Use add_to_hard_reg_set.
+       (mark_set_resources): Likewise.
+       (mark_target_live_regs): Likewise.  Use remove_from_hard_reg_set.
+       * rtlanal.c (refers_to_regno_p): Use END_REGNO.
+       (reg_overlap_mentioned_p): Likewise.
+       (dead_or_set_p): Likewise.  Use an exclusive upper loop bound.
+       (covers_regno_no_parallel_p): Use END_REGNO.
+       (find_regno_note): Likewise.
+       (find_reg_fusage): Use END_HARD_REGNO.
+       * stmt.c (decl_overlaps_hard_reg_set_p): Use overlaps_hard_reg_set_p.
+       * var-tracking.c (emit_note_insn_var_location): Use end_hard_regno.
+
+2007-05-22  Richard Sandiford  <rsandifo@nildram.co.uk>
+
+       * mode-switching.c (reg_dies): Change type of second argument to
+       "HARD_REG_SET *".
+       (optimize_mode_switching): Update accordingly.
+
+2007-05-22  Richard Sandiford  <richard@codesourcery.com>
+
+       * hard-reg-set.h (GO_IF_HARD_REG_SUBSET, GO_IF_HARD_REG_EQUAL): Delete
+       in favor of...
+       (hard_reg_subset_p, hard_reg_sets_equal_p, hard_reg_sets_intersect_p)
+       (hard_reg_set_empty_p): ...these new functions.
+       * bt-load.c (choose_btr): Use hard_reg_subset_p instead of
+       GO_IF_HARD_REG_SUBSET.
+       * cfgcleanup.c (old_insns_match_p): Use hard_reg_sets_equal_p
+       instead of GO_IF_HARD_REG_EQUAL.
+       * df-problems.c (df_urec_local_compute): Use hard_reg_set_empty_p
+       instead of GO_IF_HARD_REG_EQUAL.
+       * global.c (find_reg): Use hard_reg_set_empty_p instead of
+       GO_IF_HARD_REG_SUBSET.
+       (modify_reg_pav): Use hard_reg_set_empty_p instead of
+       GO_IF_HARD_REG_EQUAL.
+       * local-alloc.c (find_free_reg): Use hard_reg_subset_p instead
+       of GO_IF_HARD_REG_SUBSET.
+       * reg-stack.c (change_stack, convert_regs_1): Use hard_reg_sets_equal_p
+       instead of GO_IF_HARD_REG_EQUAL.
+       * regclass.c (init_reg_sets_1, reg_scan_mark_refs): Use
+       hard_reg_subset_p instead of GO_IF_HARD_REG_SUBSET.
+       (reg_classes_intersect_p): Use hard_reg_sets_intersect_p instead
+       of GO_IF_HARD_REG_SUBSET,
+       * reload1.c (finish_spills): Use hard_reg_subset_p instead of
+       GO_IF_HARD_REG_SUBSET.
+       * struct-equiv.c (death_notes_match_p): Use hard_reg_sets_equal_p
+       instead of GO_IF_HARD_REG_EQUAL.
+       * config/sh/sh.c (push_regs, calc_live_regs): Use
+       hard_reg_sets_intersect_p instead of hard_regs_intersect_p.
+       (hard_regs_intersect_p): Delete.
+
+2007-05-22  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/sourcebuild.texi (Test Directives) Add dg-message.
+
+2007-05-22  H.J. Lu  <hongjiu.lu@intel.com>
+           Richard Henderson  <rth@redhat.com>
+
+       * config.gcc (i[34567]86-*-*): Add smmintrin.h to
+       extra_headers.
+       (x86_64-*-*): Likewise.
+
+       * config/i386/i386-modes.def (V2QI): New.
+
+       * config/i386/i386.c (ix86_handle_option): Handle SSE4.1 and
+       SSE4A.
+       (override_options): Support SSE4.1.
+       (IX86_BUILTIN_BLENDPD): New for SSE4.1.
+       (IX86_BUILTIN_BLENDPS): Likewise.
+       (IX86_BUILTIN_BLENDVPD): Likewise.
+       (IX86_BUILTIN_BLENDVPS): Likewise.
+       (IX86_BUILTIN_PBLENDVB128): Likewise.
+       (IX86_BUILTIN_PBLENDW128): Likewise.
+       (IX86_BUILTIN_DPPD): Likewise.
+       (IX86_BUILTIN_DPPS): Likewise.
+       (IX86_BUILTIN_INSERTPS128): Likewise.
+       (IX86_BUILTIN_MOVNTDQA): Likewise.
+       (IX86_BUILTIN_MPSADBW128): Likewise.
+       (IX86_BUILTIN_PACKUSDW128): Likewise.
+       (IX86_BUILTIN_PCMPEQQ): Likewise.
+       (IX86_BUILTIN_PHMINPOSUW128): Likewise.
+       (IX86_BUILTIN_PMAXSB128): Likewise.
+       (IX86_BUILTIN_PMAXSD128): Likewise.
+       (IX86_BUILTIN_PMAXUD128): Likewise.
+       (IX86_BUILTIN_PMAXUW128): Likewise.
+       (IX86_BUILTIN_PMINSB128): Likewise.
+       (IX86_BUILTIN_PMINSD128): Likewise.
+       (IX86_BUILTIN_PMINUD128): Likewise.
+       (IX86_BUILTIN_PMINUW128): Likewise.
+       (IX86_BUILTIN_PMOVSXBW128): Likewise.
+       (IX86_BUILTIN_PMOVSXBD128): Likewise.
+       (IX86_BUILTIN_PMOVSXBQ128): Likewise.
+       (IX86_BUILTIN_PMOVSXWD128): Likewise.
+       (IX86_BUILTIN_PMOVSXWQ128): Likewise.
+       (IX86_BUILTIN_PMOVSXDQ128): Likewise.
+       (IX86_BUILTIN_PMOVZXBW128): Likewise.
+       (IX86_BUILTIN_PMOVZXBD128): Likewise.
+       (IX86_BUILTIN_PMOVZXBQ128): Likewise.
+       (IX86_BUILTIN_PMOVZXWD128): Likewise.
+       (IX86_BUILTIN_PMOVZXWQ128): Likewise.
+       (IX86_BUILTIN_PMOVZXDQ128): Likewise.
+       (IX86_BUILTIN_PMULDQ128): Likewise.
+       (IX86_BUILTIN_PMULLD128): Likewise.
+       (IX86_BUILTIN_ROUNDPD): Likewise.
+       (IX86_BUILTIN_ROUNDPS): Likewise.
+       (IX86_BUILTIN_ROUNDSD): Likewise.
+       (IX86_BUILTIN_ROUNDSS): Likewise.
+       (IX86_BUILTIN_PTESTZ): Likewise.
+       (IX86_BUILTIN_PTESTC): Likewise.
+       (IX86_BUILTIN_PTESTNZC): Likewise.
+       (IX86_BUILTIN_VEC_EXT_V16QI): Likewise.
+       (IX86_BUILTIN_VEC_SET_V2DI): Likewise.
+       (IX86_BUILTIN_VEC_SET_V4SF): Likewise.
+       (IX86_BUILTIN_VEC_SET_V4SI): Likewise.
+       (IX86_BUILTIN_VEC_SET_V16QI): Likewise.
+       (bdesc_ptest): New.
+       (bdesc_sse_3arg): Likewise.
+       (bdesc_2arg): Likewise.
+       (bdesc_1arg): Likewise.
+       (ix86_init_mmx_sse_builtins): Support SSE4.1.  Handle SSE builtins
+       with 3 args.
+       (ix86_expand_sse_4_operands_builtin): New.
+       (ix86_expand_unop_builtin): Support 2 arg builtins with a constant
+       smaller than 8 bits as the 2nd arg.
+       (ix86_expand_sse_ptest): New.
+       (ix86_expand_builtin): Support SSE4.1. Support 3 arg SSE builtins.
+       (ix86_expand_vector_set): Support SSE4.1.
+       (ix86_expand_vector_extract): Likewise.
+
+       * config/i386/i386.h (TARGET_CPU_CPP_BUILTINS): Define
+       __SSE4_1__ for -msse4.1.
+
+       * config/i386/i386.md (UNSPEC_BLENDV): New for SSE4.1.
+       (UNSPEC_INSERTPS): Likewise.
+       (UNSPEC_DP): Likewise.
+       (UNSPEC_MOVNTDQA): Likewise.
+       (UNSPEC_MPSADBW): Likewise.
+       (UNSPEC_PHMINPOSUW): Likewise.
+       (UNSPEC_PTEST): Likewise.
+       (UNSPEC_ROUNDP): Likewise.
+       (UNSPEC_ROUNDS): Likewise.
+
+       * config/i386/i386.opt (msse4.1): New for SSE4.1.
+
+       * config/i386/predicates.md (const_pow2_1_to_2_operand): New.
+       (const_pow2_1_to_32768_operand): Likewise.
+
+       * config/i386/smmintrin.h: New. The SSE4.1 intrinsic header
+       file.
+
+       * config/i386/sse.md (*vec_setv4sf_sse4_1): New pattern for
+       SSE4.1.
+       (sse4_1_insertps): Likewise.
+       (*sse4_1_extractps): Likewise.
+       (sse4_1_ptest): Likewise.
+       (sse4_1_mulv2siv2di3): Likewise.
+       (*sse4_1_mulv4si3): Likewise.
+       (*sse4_1_smax<mode>3): Likewise.
+       (*sse4_1_umax<mode>3): Likewise.
+       (*sse4_1_smin<mode>3): Likewise.
+       (*sse4_1_umin<mode>3): Likewise.
+       (sse4_1_eqv2di3): Likewise.
+       (*sse4_1_pinsrb): Likewise.
+       (*sse4_1_pinsrd): Likewise.
+       (*sse4_1_pinsrq): Likewise.
+       (*sse4_1_pextrb): Likewise.
+       (*sse4_1_pextrb_memory): Likewise.
+       (*sse4_1_pextrw_memory): Likewise.
+       (*sse4_1_pextrq): Likewise.
+       (sse4_1_blendpd): Likewise.
+       (sse4_1_blendps): Likewise.
+       (sse4_1_blendvpd): Likewise.
+       (sse4_1_blendvps): Likewise.
+       (sse4_1_dppd): Likewise.
+       (sse4_1_dpps): Likewise.
+       (sse4_1_movntdqa): Likewise.
+       (sse4_1_mpsadbw): Likewise.
+       (sse4_1_packusdw): Likewise.
+       (sse4_1_pblendvb): Likewise.
+       (sse4_1_pblendw): Likewise.
+       (sse4_1_phminposuw): Likewise.
+       (sse4_1_extendv8qiv8hi2): Likewise.
+       (*sse4_1_extendv8qiv8hi2): Likewise.
+       (sse4_1_extendv4qiv4si2): Likewise.
+       (*sse4_1_extendv4qiv4si2): Likewise.
+       (sse4_1_extendv2qiv2di2): Likewise.
+       (*sse4_1_extendv2qiv2di2): Likewise.
+       (sse4_1_extendv4hiv4si2): Likewise.
+       (*sse4_1_extendv4hiv4si2): Likewise.
+       (sse4_1_extendv2hiv2di2): Likewise.
+       (*sse4_1_extendv2hiv2di2): Likewise.
+       (sse4_1_extendv2siv2di2): Likewise.
+       (*sse4_1_extendv2siv2di2): Likewise.
+       (sse4_1_zero_extendv8qiv8hi2): Likewise.
+       (*sse4_1_zero_extendv8qiv8hi2): Likewise.
+       (sse4_1_zero_extendv4qiv4si2): Likewise.
+       (*sse4_1_zero_extendv4qiv4si2): Likewise.
+       (sse4_1_zero_extendv2qiv2di2): Likewise.
+       (*sse4_1_zero_extendv2qiv2di2): Likewise.
+       (sse4_1_zero_extendv4hiv4si2): Likewise.
+       (*sse4_1_zero_extendv4hiv4si2): Likewise.
+       (sse4_1_zero_extendv2hiv2di2): Likewise.
+       (*sse4_1_zero_extendv2hiv2di2): Likewise.
+       (sse4_1_zero_extendv2siv2di2): Likewise.
+       (*sse4_1_zero_extendv2siv2di2): Likewise.
+       (sse4_1_roundpd): Likewise.
+       (sse4_1_roundps): Likewise.
+       (sse4_1_roundsd): Likewise.
+       (sse4_1_roundss): Likewise.
+       (mulv4si3): Don't expand for SSE4.1.
+       (smax<mode>3): Likewise.
+       (umaxv4si3): Likewise.
+       (uminv16qi3): Likewise.
+       (umin<mode>3): Likewise.
+       (umaxv8hi3): Rewrite.  Only enabled for SSE4.1.
+
+       * doc/extend.texi: Document SSE4.1 built-in functions.
+
+       * doc/invoke.texi: Document -msse4.1.
+
+2007-05-22  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/linux.h (ASM_SPEC): Add asm_pcrel_spec.
+       * config/m68k/m68k-none.h (ASM_SPEC): Don't override here.
+       * config/m68k/m68k.h (ASM_PCREL_SPEC): New.
+       (ASM_SPEC): Add asm_pcrel_spec.
+       (EXTRA_SPECS): Add asm_pcrel_spec.
+
+2007-05-21  David Daney  <ddaney@avtrex.com>
+
+       * doc/install.texi (Building a cross compiler): Add requirements
+       for Java cross compiler.
+
+2007-05-21  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/31995
+       * tree-chrec.c (evolution_function_is_affine_multivariate_p):
+       Add loopno argument.  Use evolution_function_is_invariant_rec_p
+       instead of evolution_function_is_constant_p.
+       Update calls to evolution_function_is_affine_multivariate_p.
+       * tree-chrec.h (evolution_function_is_affine_multivariate_p):
+       Add loopno argument.
+       * tree-scalar-evolution.c (gather_chrec_stats): Call
+       evolution_function_is_affine_multivariate_p with a loop
+       number of 0.
+       * tree-data-ref.c (analyze_miv_subscript): Likewise.
+       (analyze_overlapping_iterations): Likewise.
+       (access_functions_are_affine_or_constant_p): Likewise.
+       (build_classic_dist_vector_1): If the access functions
+       are equal, don't do anything.
+
+2007-05-21  Paolo Bonzini  <bonzini@gnu.org>
+           Paolo Carlini  <pcarlini@suse.de>
+           Uros Bizjak  <ubizjak@gmail.com>
+
+       * c-cppbuiltin.c (c_cpp_builtins): Define
+       __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1, __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2,
+       __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4, __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8,
+       __GCC_HAVE_SYNC_COMPARE_AND_SWAP_16, if appropriate.
+       * doc/cpp.texi ([Standard Predefined Macros]): Document.
+
+2007-05-21  Mike Stump  <mrs@apple.com>
+
+       * config/darwin.h (LINK_COMMAND_SPEC): Add .cxx/.cp for dsymutil
+       handling as well.
+       * config/darwin9.h (LINK_COMMAND_SPEC): Likewise.
+
+2007-05-21  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/tmmintrin.h (_mm_alignr_epi8): Provide macro
+       implementation if __OPTIMIZE__ is not defined.
+       (_mm_alignr_pi8): Ditto.
+       * config/i386/ammintrin.h (_mm_extracti_si64): Ditto.
+       (_mm_inserti_si64): Ditto.
+       * config/i386/emmintrin.h (_mm_shuffle_pd): Ditto.
+       (_mm_slli_epi16): Ditto.
+       (_mm_slli_epi32): Ditto.
+       (_mm_slli_epi64): Ditto.
+       (_mm_srai_epi16): Ditto.
+       (_mm_srai_epi32): Ditto.
+       (_mm_srli_si128): Ditto.
+       (_mm_slli_si128): Ditto.
+       (_mm_srli_epi16): Ditto.
+       (_mm_srli_epi32): Ditto.
+       (_mm_srli_epi64): Ditto.
+       (_mm_extract_epi16): Ditto.
+       (_mm_insert_epi16): Ditto.
+       (_mm_shufflehi_epi16): Ditto.
+       (_mm_shufflelo_epi16): Ditto.
+       (_mm_shuffle_epi32): Ditto.
+       * config/i386/xmmintrin.h (_mm_extract_pi16): Ditto.
+       (_m_pextrw): Ditto.
+       (_mm_insert_pi16): Ditto.
+       (_m_pinsrw): Ditto.
+       (_mm_shuffle_pi16): Ditto.
+       (_m_pshufw): Ditto.
+       (_mm_shufle_ps): Ditto.
+       (_mm_prefetch): Ditto.
+
+2007-05-21  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * defaults.h (IBM_FLOAT_FORMAT): Macro definition removed.
+       * doc/tm.texi (IBM_FLOAT_FORMAT): Documentation entry removed.
+       * real.c (encode_i370_single, decode_i370_single,
+       encode_i370_double, decode_i370_double): Functions removed.
+       (i370_single_format, i370_double_format): Initializations removed.
+       (real_maxval, round_for_format, exact_real_truncate, significand_size):
+       Consider the log2_b field to always be one.
+       (ieee_single_format, mips_single_format, coldfire_single_format,
+       ieee_double_format, mips_double_format, coldfire_double_format,
+       ieee_extended_motorola_format, ieee_extended_intel_96_format,
+       ieee_extended_intel_128_format, ieee_extended_intel_96_round_53_format,
+       ibm_extended_format, mips_extended_format, ieee_quad_format,
+       mips_quad_format, vax_f_format, vax_d_format, vax_g_format,
+       decimal_single_format, decimal_double_format, decimal_quad_format,
+       c4x_single_format, c4x_extended_format, real_internal_format): Remove
+       initialization of log2_b.
+       * real.h (i370_single_format, i370_double_format): Declarations
+       removed.
+       * c-cppbuiltin.c (builtin_define_float_constants): Consider the log2_b
+       field to always be one.
+
+2007-05-21  Andreas Schwab  <schwab@suse.de>
+
+       * config/ia64/ia64.c (emit_predicate_relation_info): Fix use of
+       NOTE_INSN_BASIC_BLOCK_P.
+       (process_for_unwind_directive): Likewise.
+
+2007-05-21  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * builtins.c (expand_builtin_setjmp_setup): Update comment.
+       * function.h (struct function): Move va_list_gpr_size,
+       va_list_fpr_size, function_frequency to front of bitfields.  Add
+       calls_unwind_init.
+       (current_function_calls_unwind_init): New.
+       * except.c (expand_builtin_unwind_init): Set
+       current_function_calls_unwind_init not
+       current_function_has_nonlocal_label.
+       * reload1.c (has_nonexceptional_receiver): New.
+       (reload): Use it and current_function_calls_unwind_init to
+       determine whether call-saved regs must be saved.
+
+2007-05-20  Jan Hubicka  <jh@suse.cz>
+
+       * gengtype.c (adjust_field_rtx_def): Use NOTE_KIND instead of
+       NOTE_LINE_NUMBER; use NOTE_INSN_BASIC_BLOCK_P when possible.
+       * ddg.c (create_ddg): LIkewise.
+       * final.c (final): Remove hunk moving line number notes around since
+       they are no longer present at this stage.
+       (final_scan_insn): Use NOTE_KIND instead of
+       NOTE_LINE_NUMBER; use NOTE_INSN_BASIC_BLOCK_P when possible.
+       (output_asm_label): Likewise.
+       * reorg.c (dbr_schedule): Likewise.
+       * haifa-sched.c (unlink_other_notes): Likewise.
+       * mode-switching.c (optimize_mode_switching): Likewise.
+       * graph.c (start_bb): Likewise.
+       * rtl.def (NOTE): Update description.
+       * jump.c (squeeze_notes): Delete.
+       (mark_jump_label): Use NOTE_KIND instead of NOTE_LINE_NUMBER; use
+       NOTE_INSN_BASIC_BLOCK_P when possible.
+       * ifcvt.c (dead_or_predicable): Remove call of squeeze_notes.
+       * dwarf2out.c (gen_label_die): Use NOTE_KIND instead of
+       NOTE_LINE_NUMBER; use NOTE_INSN_BASIC_BLOCK_P when possible.
+       (dwarf2out_var_location): Likewise.
+       * cfgbuild.c (make_edges): Likewise.
+       (find_basic_blocks_1): Likewise.
+       * function.c (reorder_blocks_1): Likewise.
+       (epilogue_done): Likewise.
+       (reposition_prologue_and_epilogue_notes): Likewise.
+       * print-rtl.c (print_rtx): Likewise; drop code for printing
+       line number notes.
+       (print_rtl): Likewise.
+       (print_rtl_single): Likewise.
+       * gcse.c (insert_insn_start_bb): Likewise.
+       * alias.c (init_alias_analysis): Likewise.
+       * calls.c (fixup_tail_calls): Likewise.
+       * except.c (sjlj_emit_function_enter): Likewise.
+       * emit-rtl.c (add_insn_after): Likeiwse.
+       (emit_label_before): Likewise.
+       (emit_label_after): Likewise.
+       (emit_note_before, emit_note_after, emit_note): Update
+       parameter to be enum insn_note; do not deal with source
+       files.
+       * cfgcleanup.c (merge_blocks_move_predecessor_nojumps):
+       Use NOTE_KIND instead of NOTE_LINE_NUMBER; use NOTE_INSN_BASIC_BLOCK_P
+       when possible.
+       (merge_blocks_move_successor_nojumps): Simplify now when
+       we don't have BLOCK notes.
+       (try_optimize_cfg): Likewise.
+       * cfglayout.c (skip_insns_after_block): Likewise.
+       (record_effective_endpoints): Likewise.
+       (duplicate_insn_chain): Likewise.
+       * varasm.c (output_constant_pool_1): Likewise.
+       * sched-deps.c (sched_analyze): Likewise.
+       * rtl.c (NOTE_INSN_MAX_isnt_negative_adjust_NOTE_INSN_BIAS):
+       Exterminate.
+       (note_insn_name): Simplify now when NOTE_INSN_BIAS is gone.
+       * rtl.h (NOTE_SOURCE_LOCATION, NOTE_EXPANDED_LOCATION): Exterminate.
+       (SET_INSN_DELETED): Simplify.
+       (NOTE_LINE_NUMBER): Exterminate.
+       (NOTE_LINE_KIND): New.
+       (NOTE_INSN_BASIC_BLOCK_P): Update.
+       (enum insn_note): Simplify.
+       (GET_NOTE_INSN_NAME) Simplify.
+       (emit_note_before, emit_note_after, emit_note): Update prototype.
+       (squeeze_notes): Remove.
+       * sched-int.h (NOTE_NOT_BB_P): Update.
+       * resource.c (mark_target_live_regs): Update.
+       * sched-rgn.c (debug_dependencies): Update.
+       * sched-vis.c (print_insn): Update.
+       * config/alpha/alpha.c (alpha_handle_trap_shadows): Update.
+       * config/i386/i386.c (ix86_output_function_epilogue): Update.
+       * config/sh/sh.c (sh_adjust_unroll_max): Function dead since gcc 4.0.0.
+       (TARGET_ADJUST_UNROLL_MAX): Likewise.
+       (split_branches): Update.
+       (sh_optimize_target_register_callee_saved): Remove hunk dead since gcc
+       4.0.0.
+       (sh_adjust_unroll_max): Exterminate.
+       * config/c4x/c4x.c (c4x_reorg): Use SET_INSN_DELETED.
+       * config/m68hc11/m68hc11.c (m68hc11_check_z_replacement): Likewise.
+       (m68hc11_reorg): Likewise.
+       * config/ia64/ia64.c (emit_insn_group_barriers): Update.
+       (emit_predicate_relation_info): Update.
+       (process_for_unwind_directive): Update.
+       * config/rs6000/rs6000.c (rs6000_output_function_epilogue): Update.
+       (output_call): Update.
+       * config/pa/pa.c (output_lbranch): Update.
+       (output_millicode_call): Update.
+       (output_call): Update.
+       (pa_combine_instructions): Update.
+       * config/mips/mips.c (mips16_gp_pseudo_reg): Update.
+       * config/bfin/bfin.c (gen_one_bundle): Update.
+       * cfgrtl.c (can_delete_note_p): Update.
+       (delete_insn): Update.
+       (rtl_merge_blocks): Update.
+       (commit_one_edge_insertion): Update.
+       (rtl_verify_flow_info): Update.
+       * stmt.c (expand_case): Do not call squeeze_notes.
+
+2007-05-20  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR middle-end/7651
+       PR c++/11856
+       PR c/12963
+       PR c/23587
+       PR other/29694
+       * c.opt (Wtype-limits): New.
+       * doc/invoke.texi (Wtype-limits): Document it.
+       (Wextra): Enabled by -Wextra.
+       * c-opts.c (c_common_post_options): Enabled by -Wextra.
+       * c-common.c (shorten_compare): Warn with Wtype-limits.
+
+2007-05-20  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/tmmintrin.h (_mm_alignr_epi32): Implement as always
+       inlined function, not as a macro.
+       (_mm_alignr_pi8): Ditto.
+       * config/i386/ammintrin.h (_mm_extracti_si64): Ditto.
+       (_mm_inserti_si64): Ditto.
+       * config/i386/emmintrin.h (_mm_shuffle_pd): Ditto.
+       (_mm_extract_epi16): Ditto.
+       (_mm_insert_epi16): Ditto.
+       (_mm_shufflehi_epi16): Ditto.
+       (_mm_shufflelo_epi16): Ditto.
+       (_mm_shuffle_epi32): Ditto.
+       * config/i386/xmmintrin.h (_mm_set_ss): Use 0.0f for float constant.
+       * config/386/mm3dnow.h: Add __attribute__((__always_inline__)) to
+       all functions.
+       (_m_from_float): Add __extension__ to conversion.  Use 0.0f for
+       float constant.
+       (_m_to_float): Use C89 compatible assignment.
+
+2007-05-20  Martin Michlmayr  <tbm@cyrius.com>
+
+       PR target/32007
+       * config/arm/lib1funcs.asm: Define __ARM_ARCH__ on v2/v3 machines.
+
+2007-05-20  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR middle-end/7651
+       * doc/invoke.texi (Wreturn-type): Complete description.
+       (Wextra): Delete item about return-type warning.
+       * c-decl.c: Delete redundant Wextra warning.
+
+2007-05-20  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/31585
+       * config/i386/pmmintrin.h: Do not include xmmintrin.h
+       * config/i386/xmmintrin.h (_mm_extract_pi16): Implement as always
+       inlined function, not as a macro.
+       (_mm_prefetch): Ditto.
+       (_m_pextrw): Ditto.
+       (_mm_insert_pi16): Ditto.
+       (_m_pinsrw): Ditto.
+       (_mm_shuffle_pi16): Ditto.  Add const to __N argument.
+       (_m_pshufw): Ditto. Add const to __N argument.
+       (_mm_shufle_ps): Ditto.  Add const to __mask argument.
+       * config/i386/emmintrin.h (_mm_slli_epi16): Add const to __B argument.
+       (_mm_slli_epi32): Ditto.
+       (_mm_srli_si128): Implement as always inlined function, not as a
+       macro.  Add __inline to function declaration.
+       (_mm_slli_si128): Ditto.
+
+2007-05-19  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/sfp-machine.h (FP_EX_INVALID, FP_EX_DENORM,
+       FP_EXP_DIVZERO, FP_EX_OVERFLOW, FP_EX_UNDERFLOW, FP_EX_INEXACT):
+       New constants.
+       (struct fenv): New structure.
+       (FP_HANDLE_EXCEPTIONS): New define.
+       (FP_RND_NEAREST, FP_RND_ZERO, FP_RND_PINF, FP_RND_MINF): New constants.
+       (_FP_DECL_EXP): New define.
+       (FP_INIT_ROUNDMODE): New define.
+       (FP_ROUNDMODE): New define.
+
+2007-05-19  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * doc/invoke.texi (Warning Options): Add -Wconversion-sign.
+       (Wconversion): Update description.
+       (Wconversion-sign): New.
+       * c.opt (Wconversion-sign): New.
+       * c-opts.c (c_common_post_options): Uninitialized Wconversion-sign
+       means disabled for C++. Otherwise, take the status of Wconversion.
+       * c-common.c (conversion_warning): Warn with either Wconversion or
+       Wconversion-sign.
+       (warnings_for_convert_and_check): Conditions are already checked by
+       conversion_warning.
+       (convert_and_check): Don't check warnings if the conversion failed.
+
+2007-05-19 Andy Hutchinson <HutchinsonAndy@netscape.net>
+          Anatoly Sokolov <aesok@dol.ru>
+
+       * config/avr/avr-protos.h (expand_prologue, expand_epilogue,
+       avr_epilogue_uses) : Add declaration.
+       * config/avr/predicates.md (avr_sp_immediate_operand): New predicate.
+       * config/avr/constraints.md (R): New constraint.
+       config/avr/avr.md (SREG_ADDR, UNSPEC_SEI, UNSPEC_CLI,
+       UNSPECV_PROLOGUE_SAVES, UNSPECV_EPILOGUE_RESTORES): New constants.
+       (*pop1, *pop2, *pop3, *pop4, *pop5): Combine into ...
+       (*addhi3_sp_R_pc2, *addhi3_sp_R_pc3): ... these patterns.
+       (*movhi_sp, popqi, pophi, enable_interrupt, disable_interrupt,
+       call_prologue_saves, epilogue_restores, return_from_epilogue,
+       return_from_main_epilogue, return_from_interrupt_epilogue,
+       return_from_naked_epilogue, prologue, epilogue): New patterns.
+       (jump): Handle symbol reference.
+       * config/avr/avr.c (out_adj_frame_ptr, out_set_stack_ptr,
+       avr_output_function_prologue, avr_output_function_epilogue): Remove
+       functions.
+       (avr_init_machine_status, expand_prologue, expand_epilogue,
+       avr_asm_function_end_prologue, avr_epilogue_uses,
+       avr_asm_function_begin_epilogue): New functions.
+       (prologue_size, epilogue_size, jump_tables_size): Remove global
+       variables.
+       (TARGET_ASM_FUNCTION_PROLOGUE, TARGET_ASM_FUNCTION_EPILOGUE): Remove.
+       (TARGET_ASM_FUNCTION_END_PROLOGUE): Define.
+       (TARGET_ASM_FUNCTION_BEGIN_EPILOGUE): Define.
+       (avr_override_options): Initialise init_machine_status.
+       (output_movhi): Handle all stack pointer loads.
+       (out_movqi_r_mr, out_movqi_mr_r): Handle SREG_ADDR address.
+       (avr_output_addr_vec_elt): Do not use variable jump_tables_size.
+       * config/avr/avr.h (AVR_2_BYTE_PC, AVR_3_BYTE_PC): New.
+       (EPILOGUE_USES) Redefine.
+       (machine_function) Declare.
+
+2007-05-19  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips_offset_within_alignment_p): Tweak comment.
+       Use a single return statement.
+
+2007-05-19  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR middle-end/30250
+       * builtins.c (do_mpfr_lgamma_r): New.
+       (fold_builtin_2): Handle builtin gamma_r/lgamma_r.
+       * tree.h (CASE_FLT_FN_REENT): New.
+
+2007-05-18  Geoffrey Keating  <geoffk@apple.com>
+
+       * dwarf2out.c (print_die): Use '%ld' not '%lu' to print a 'long'.
+       (output_die): Use 'unsigned long' with %x.
+       * sched-vis.c (print_value): Use 'unsigned HOST_WIDE_INT' and
+       HOST_WIDE_INT_PRINT_HEX to print HOST_WIDE_INT.
+       * tree-dump.c (dump_pointer): Use 'unsigned long' for %lx.
+
+       * unwind-dw2.c (uw_identify_context): Use the CFA, not the IP.
+
+2007-05-18  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/31989
+       PR target/31681
+       PR target/31666
+       * config/i386/i386.c (init_cumulative_args): Set maybe_vaarg to
+       true if function has no argument.
+
+2007-05-18  DJ Delorie  <dj@redhat.com>
+
+       * config/mips/mips.c (mips_offset_within_alignment_p): New.
+       (mips_symbolic_constant_p): Call it for TPREL and DTPREL symbols.
+
+2007-05-18  Uros Bizjak  <ubizjak@gmail.com>
+
+       * longlong.h (__x86_64__): Add definitions for add_ssaaaa,
+       sub_ddmmss, umul_ppmm, udiv_qrnnd, count_leading_zeros and
+       count_trailing_zeros.
+       (__i386__): Implement count_leading_zeros using __builtin_clz().
+       Implement count_trailing_zeros usign __builtin_ctz().
+
+2007-05-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/i386/vxworks.h (ASM_PREFERRED_EH_DATA_FORMAT): Undefine.
+
+2007-05-18  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/31344
+       * expr.c (emit_move_change_mode): Change mode of push operands here.
+
+2007-05-17  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/31953
+       * tree-vrp.c (set_value_range_to_value): Add equiv parameter.
+       Change all callers.
+       (set_value_range_to_null): Call set_value_range_to_value.
+       (extract_range_from_comparison): Likewise.
+
+2007-05-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * toplev.c (print_version): Output GMP/MPFR version info.
+
+       * builtins.c (CASE_MATHFN_REENT): New macro.
+       (mathfn_built_in): Use it.
+       * builtins.def (BUILT_IN_GAMMA_R, BUILT_IN_GAMMAF_R,
+       BUILT_IN_GAMMAL_R, BUILT_IN_LGAMMA_R, BUILT_IN_LGAMMAF_R,
+       BUILT_IN_LGAMMAL_R): New.
+       * doc/extend.texi: Document new builtins.
+
+       PR middle-end/31796
+       * builtins.c (do_mpfr_remquo): New.
+       (fold_builtin_2): Handle BUILT_IN_DREM/BUILT_IN_REMAINDER.
+       (fold_builtin_3): Handle BUILT_IN_REMQUO.
+
+       PR middle-end/30251
+       * builtins.c (fold_builtin_1): Handle y0, y1.
+       (fold_builtin_2): Handle yn.
+
+       PR middle-end/30251
+       * builtins.c (do_mpfr_bessel_n): New.
+       (fold_builtin_1): Handle BUILT_IN_J0 and BUILT_IN_J1.
+       (fold_builtin_2): Handle BUILT_IN_JN.
+
+2007-05-17  Danny Smith  <dannysmith@users.sourceforge.net>
+
+       PR target/31965
+       * config/i386/mingw32.h (_INTEGRAL_MAX_BITS): Define builtin as
+       TYPE_PRECISION (intmax_type_node).
+
+2007-05-17  Steve Ellcey  <sje@cup.hp.com>
+
+       PR target/31850
+       * reload.c (subst_reloads): Remove checking.
+
+2007-05-17  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/31691
+       * combine.c (simplify_set): Build a new src pattern instead of
+       substituting its operands in the COMPARE case.
+
+2007-05-17  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-vrp.c (finalize_jump_threads): Do not care about dominance info.
+       (execute_vrp): Preserve loops through jump threading.
+       * tree-ssa-threadupdate.c (thread_single_edge,
+       dbds_continue_enumeration_p, determine_bb_domination_status,
+       thread_through_loop_header): New functions.
+       (create_edge_and_update_destination_phis,
+       create_edge_and_update_destination_phis): Set loops for the new blocks.
+       (prune_undesirable_thread_requests): Removed.
+       (redirect_edges): Do not pretend that redirect_edge_and_branch can
+       create new blocks.
+       (thread_block): Do not call prune_undesirable_thread_requests.
+       Update loops.
+       (mark_threaded_blocks): Select edges to thread here.
+       (thread_through_all_blocks): Take may_peel_loop_headers argument.
+       Thread edges through loop headers independently.
+       * cfgloopmanip.c (create_preheader, mfb_keep_just): Export.
+       * tree-pass.h (TODO_mark_first_instance): New.
+       (first_pass_instance): Declare.
+       * cfghooks.c (duplicate_block): Put the block to the original loop
+       if copy is not specified.
+       * tree-ssa-dom.c (tree_ssa_dominator_optimize): Preserve loops through
+       jump threading.  Pass may_peel_loop_headers to
+       thread_through_all_blocks according to first_pass_instance.
+       * cfgloop.h (create_preheader): Declare.
+       * tree-flow.h (thread_through_all_blocks): Declaration changed.
+       * basic-block.h (mfb_keep_just, mfb_kj_edge): Declare.
+       * passes.c (first_pass_instance): New variable.
+       (next_pass_1): Set TODO_mark_first_instance.
+       (execute_todo): Set first_pass_instance.
+
+2007-05-17  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/24659
+       * optabs.h (enum optab_index): Add OTI_vec_unpacks_float_hi,
+       OTI_vec_unpacks_float_lo, OTI_vec_unpacku_float_hi,
+       OTI_vec_unpacku_float_lo, OTI_vec_pack_sfix_trunc and
+       OTI_vec_pack_ufix_trunc.
+       (vec_unpacks_float_hi_optab): Define new macro.
+       (vec_unpacks_float_lo_optab): Ditto.
+       (vec_unpacku_float_hi_optab): Ditto.
+       (vec_unpacku_float_lo_optab): Ditto.
+       (vec_pack_sfix_trunc_optab): Ditto.
+       (vec_pack_ufix_trunc_optab): Ditto.
+       * genopinit.c (optabs): Implement vec_unpack[s|u]_[hi|lo]_optab
+       and vec_pack_[s|u]fix_trunc_optab using
+       vec_unpack[s|u]_[hi\lo]_* and vec_pack_[u|s]fix_trunc_* patterns
+       * tree-vectorizer.c (supportable_widening_operation): Handle
+       FLOAT_EXPR and CONVERT_EXPR.  Update comment.
+       (supportable_narrowing_operation): New function.
+       * tree-vectorizer.h (supportable_narrowing_operation): Prototype.
+       * tree-vect-transform.c (vectorizable_conversion): Handle
+       (nunits_in == nunits_out / 2) and (nunits_out == nunits_in / 2) cases.
+       (vect_gen_widened_results_half): Move before vectorizable_conversion.
+       (vectorizable_type_demotion): Call supportable_narrowing_operation()
+       to check for target support.
+       * optabs.c (optab_for_tree_code) Return vec_unpack[s|u]_float_hi_optab
+       for VEC_UNPACK_FLOAT_HI_EXPR, vec_unpack[s|u]_float_lo_optab
+       for VEC_UNPACK_FLOAT_LO_EXPR and vec_pack_[u|s]fix_trunc_optab
+       for VEC_PACK_FIX_TRUNC_EXPR.
+       (expand_binop): Special case mode of the result for
+       vec_pack_[u|s]fix_trunc_optab.
+       (init_optabs): Initialize vec_unpack[s|u]_[hi|lo]_optab and
+       vec_pack_[u|s]fix_trunc_optab.
+
+       * tree.def (VEC_UNPACK_FLOAT_HI_EXPR, VEC_UNPACK_FLOAT_LO_EXPR,
+       VEC_PACK_FIX_TRUNC_EXPR): New tree codes.
+       * tree-pretty-print.c (dump_generic_node): Handle
+       VEC_UNPACK_FLOAT_HI_EXPR, VEC_UNPACK_FLOAT_LO_EXPR and
+       VEC_PACK_FIX_TRUNC_EXPR.
+       (op_prio): Ditto.
+       * expr.c (expand_expr_real_1): Ditto.
+       * tree-inline.c (estimate_num_insns_1): Ditto.
+       * tree-vect-generic.c (expand_vector_operations_1): Ditto.
+
+       * config/i386/sse.md (vec_unpacks_float_hi_v8hi): New expander.
+       (vec_unpacks_float_lo_v8hi): Ditto.
+       (vec_unpacku_float_hi_v8hi): Ditto.
+       (vec_unpacku_float_lo_v8hi): Ditto.
+       (vec_unpacks_float_hi_v4si): Ditto.
+       (vec_unpacks_float_lo_v4si): Ditto.
+       (vec_pack_sfix_trunc_v2df): Ditto.
+
+       * doc/c-tree.texi (Expression trees) [VEC_UNPACK_FLOAT_HI_EXPR]:
+       Document.
+       [VEC_UNPACK_FLOAT_LO_EXPR]: Ditto.
+       [VEC_PACK_FIX_TRUNC_EXPR]: Ditto.
+       * doc/md.texi (Standard Names) [vec_pack_sfix_trunc]: Document.
+       [vec_pack_ufix_trunc]: Ditto.
+       [vec_unpacks_float_hi]: Ditto.
+       [vec_unpacks_float_lo]: Ditto.
+       [vec_unpacku_float_hi]: Ditto.
+       [vec_unpacku_float_lo]: Ditto.
+
+2007-05-16  Uros Bizjak  <ubizjak@gmail.com>
+
+       * soft-fp/README: Update for new files.
+       * soft-fp/floattisf.c: New file.
+       * soft-fp/floattidf.c: New file.
+       * soft-fp/floattitf.c: New file.
+       * soft-fp/floatuntisf.c: New file.
+       * soft-fp/floatuntidf.c: New file.
+       * soft-fp/floatuntitf.c: New file.
+       * soft-fp/fixsfti.c: New file.
+       * soft-fp/fixdfti.c: New file.
+       * soft-fp/fixtfti.c: New file.
+       * soft-fp/fixunssfti.c: New file.
+       * soft-fp/fixunsdfti.c: New file.
+       * soft-fp/fixunstfti.c: New file.
+       * soft-fp/extendxftf.c: New file.
+       * soft-fp/trunctfxf.c: New file.
+
+       * libgcc-std.ver (__extendxftf2): Added to GCC_4.3.0 section.
+       (__trunctfxf2): Ditto.
+
+       * config/i386/libgcc-x86_64-glibc.ver (__addtf3, __divtf3, __eqtf2,
+       __extenddftf2, __extendsftf2, __fixtfdi, __fixtfsi, __fixtfti,
+       __fixunstfdi, __fixunstfsi, __fixunstfti, __floatditf, __floatsitf,
+       __floattitf, __floatunditf, __floatunsitf, __floatuntitf, __getf2,
+       __letf2, __multf3, __negtf2, __subtf3, __trunctfdf2, __trunctfsf2,
+       __unordtf2): Exclude and add to GCC_4.3.0 section for x86_64 targets.
+
+       * config/i386/t-fprules-softfp64: New file.
+       * config/i386/sfp-machine.h: New file.
+       * config.gcc (x86_64-*-linux*, x86_64-*-kfreebsd*-gnu,
+       x86_64-*-knetbsd*-gnu): Add i386/t-fprules-softfp64
+       and soft-fp/t-softfp to tmake_file.
+       (i[34567]86-*-linux*, i[34567]86-*-kfreebsd*-gnu,
+       i[34567]86-*-knetbsd*-gnu): Ditto for --enable-targets=all.
+
+       * config/i386/t-linux64 (softfp_wrap_start): New.
+       (softfp_wrap_end): New.
+       * config/i386/i386.c (ix86_scalar_mode_supported): TFmode is
+       supported for TARGET_64BIT.
+
+2007-05-16  Rafael Ávila de Espíndola  <espindola@google.com>
+
+       * c-common.c (c_common_signed_or_unsigned_type): Emulate
+       c_common_unsigned_type behavior.
+
+2007-05-16  Paolo Bonzini  <bonzini@gnu.org>
+
+       * config/i386/i386.c (legitimize_tls_address): Mark __tls_get_addr
+       calls as pure.
+
+2007-05-16  Eric Christopher  <echristo@apple.com>
+
+       * config/rs6000/rs6000.c (rs6000_emit_prologue): Move altivec register
+       saving after stack push. Set sp_offset whenever we push.
+       (rs6000_emit_epilogue): Move altivec register restore before
+       stack push.
+
+2007-05-16  Richard Sandiford  <richard@codesourcery.com>
+
+       * configure.ac: Allow sysroots to be relocated under $prefix as
+       well as $exec_prefix.
+       * configure: Regenerate.
+
+2007-05-16  Richard Sandiford  <richard@codesourcery.com>
+
+       Revert:
+
+       2007-05-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * configure.ac (gcc_gxx_include_dir): Use $(libsubdir_to_prefix).
+       (gcc_tooldir): Likewise.
+       * configure: Regenerate.
+       * Makefile.in (libsubdir_to_prefix): New variable, based on the
+       old configure.ac gcc_tooldir setting.
+       (prefix_to_exec_prefix): New variable.
+       (DRIVER_DEFINES): Use $(libsubdir_to_prefix)$(prefix_to_exec_prefix)
+       rather than $(unlibsubdir)/../ to derive TOOLDIR_BASE_PREFIX.
+
+2007-05-14  Janis Johnson  <janis187@us.ibm.com>
+
+       * c-typeck.c (build_binary_op): Return early for error.
+
+2007-05-15  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-niter.c (record_estimate): Use GGC_NEW to allocate
+       struct nb_iter_bound.
+       (free_numbers_of_iterations_estimates_loop): Use ggc_free.
+       * gengtype.c (open_base_files): Add cfhloop.h to the list of includes.
+       * cfgloopmanip.c (place_new_loop): Vector larray is gc-allocated.
+       * tree-scalar-evolution.c: Include gt-tree-scalar-evolution.h.
+       (struct scev_info_str, scalar_evolution_info): Add GTY markers.
+       (new_scev_info_str): Use GGC_NEW to allocate struct scev_info_str.
+       (del_scev_info): Use ggc_free.
+       (scev_initialize): Allocate scalar_evolution_info in gc memory.
+       * loop-init.c: Include ggc.h.
+       (loop_optimizer_init): Use GGC_CNEW to allocate struct loops.
+       (loop_optimizer_finalize): Use ggc_free.
+       * tree-ssa-loop.c (pass_tree_unswitch, pass_vectorize,
+       pass_linear_transfom, pass_empty_loop, pass_complete_unroll,
+       pass_iv_optimize): Add TODO_ggc_collect.
+       * function.h (struct function): Remove skip marker from
+       x_current_loops.
+       * cfgloop.c: Include ggc.h.
+       (flow_loops_free, flow_loop_free): Free the loop descriptions in gc
+       memory.
+       (establish_preds): Vector superloops is gc allocated.
+       (alloc_loop): Allocate loop using GGC_CNEW.  Allocate head of
+       loop->exits list.
+       (flow_loops_find): Vector larray is gc allocated.
+       (loop_exit_free): Use ggc_free.
+       (rescan_loop_exit): Use GGC_NEW to allocate struct loop_exit.  Reflect
+       that head of exits list is now not a part of struct loop.
+       (record_loop_exits): Allocate exits table in gc memory.
+       (get_loop_exit_edges, verify_loop_structure, single_exit): Reflect
+       that head of exits list is now not a part of struct loop.
+       * cfgloop.h (struct lpt_decision, struct nb_iter_bound,
+       struct loop_exit): Add GTY marker.
+       (struct loop): Add GTY marker.  Make superloops vector gc allocated.
+       Add skip marker to aux field.  Make head of exits list a separate
+       object.
+       (struct loops): Add GTY marker.  Make larray vector gc allocated.
+       Add param marker to exits table.
+       (get_loops): Type changed.
+       * Makefile.in (tree-scalar-evolution.o): Add
+       gt-tree-scalar-evolution.h dependency.
+       (cfgloop.o, loop-init.o): Add ggc.h dependency.
+       (GTFILES): Add cfgloop.h and tree-scalar-evolution.c.
+       * basic-block.h (struct basic_block_def): Remove skip marker from
+       loop_father field.
+
+2007-05-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       * builtins.c (expand_builtin_mathfn): Use EXPAND_NORMAL instead
+       of 0 in the call to expand_expr().
+       (expand_builtin_mathfn_3): Ditto.
+       (expand_builtin_interclass_mathfn): Ditto.
+       (expand_builtin_cexpi): Ditto.
+       (expand_builtin_int_roundingfn): Ditto.
+       (expand_builtin_int_roundingfn_2): Ditto.
+       (expand_builtin_pow): Ditto.
+       (expand_builtin_powi): Ditto.
+       (expand_builtin_bswap): Ditto.
+       (expand_builtin_unop): Ditto.
+       (expand_builtin_fabs): Ditto.
+       (get_builtin_sync_mem): Use NULL_RTX instead of NULL in
+       the call to expand_expr().
+       (expand_builtin_sync_operation): Ditto.
+       (expand_builtin_compare_and_swap): Ditto.
+       (expand_builtin_lock_test_and_set): Ditto.
+       * except.c (expand_builtin_eh_return_data_regno): Use EXPAND_NORMAL
+       instead of 0 in the call to expand_expr().
+       (expand_builtin_extract_return_addr): Ditto.
+       (expand_builtin_eh_return): Ditto.
+       (expand_eh_return): Ditto.
+       * explow.c (expr_size): Ditto.
+       * expr.c (optimize_bitfield_assignment_op): Ditto.
+       (expand_assignement): Ditto.
+       (store_expr): Ditto.
+       (store_field): Ditto.
+       (expand_expr_addr_expr_1): Use NULL_RTX instead of NULL in
+       the call to expand_expr().
+       (expand_expr_real_1) [COMPLEX_CST]: Use EXPAND_NORMAL instead of 0
+       in the call to expand_expr().
+       [CONSTRUCTOR, PLUS_EXPR, MINUS_EXPR, NEGATE_EXPR, ABS_EXPR,
+       BIT_NOT_EXPR, LSHIFT_EXPR, LT_EXPR, TRUTH_NOT_EXPR]: Ditto.
+       [VEC_UNPACK_HI_EXPR, VEC_UNPACK_LO]: Use expand_normal() instead
+       of expand_expr().
+       * optabs.c (expand_vec_shift_expr): Ditto.
+       (expand_vec_cond_expr): Ditto.
+       (vector_compare_rtx): Use EXPAND_STACK_PARM instead of 1 in the
+       call to expand_expr().
+       * stmt.c (expand_return): Use EXPAND_NORMAL instead of 0
+       in the call to expand_expr().
+
+2007-05-14  Dave Korn  <dave.korn@artimi.com>
+
+       * genautomata.c (gen_regexp_el): Allocate correct size for regexp.
+
+2007-05-14  Rafael Ávila de Espíndola  <espindola@google.com>
+
+       * c-common.c (warnings_for_convert_and_check): Use unsigned_type_for
+       instead of c_common_unsigned_type.
+       (c_common_unsigned_type): Remove.
+       (shorten_compare): Use c_common_signed_or_unsigned_type instead of
+       c_common_unsigned_type.
+       (c_common_nodes_and_builtins): Use unsigned_type_for instead of
+       c_common_unsigned_type.
+       * c-common.h (c_common_unsigned_type): Remove.
+       * c-decl.c (grokdeclarator): Use unsigned_type_for instead of
+       c_common_unsigned_type.
+       * c-format.c (check_format_types): Use unsigned_type_for instead of
+       c_common_unsigned_type.
+       * c-objc-common.h (LANG_HOOKS_UNSIGNED_TYPE): Remove.
+       * c-typeck.c (convert_for_assignment): Use unsigned_type_for instead
+       of c_common_unsigned_type.
+       * convert.c (convert_to_integer): Use unsigned_type_for instead of
+       lang_hooks.types.unsigned_type.
+       * expmed.c (make_tree): Use unsigned_type_for instead of
+       lang_hooks.types.unsigned_type.
+       * fold-const.c (fold_negate_expr): Use unsigned_type_for instead of
+       lang_hooks.types.unsigned_type.
+       (build_range_check): Likewise.
+       (fold_unary): Likewise.
+       (fold_binary): Likewise.
+       (fold_ternary): Likewise.
+       * langhooks-def.h (LANG_HOOKS_UNSIGNED_TYPE): Remove.
+       * langhooks.h (lang_hooks_for_types): Remove unsigned_type.
+       * tree.c (get_unsigned_type): New.
+       (unsigned_type_for): Use get_unsigned_type instead of
+       lang_hooks.types.unsigned_type.
+
+2007-05-14  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k-protos.h: Rename m68k_interrupt_function_p
+       to m68k_get_function_kind.  Update its prototype.
+       * config/m68k/m68k.c (m68k_attribute_table): Add an entry for
+       interrupt_thread.
+       (m68k_interrupt_function_p): Return enum m68k_function_type
+       instead of bool.  Rename to m68k_get_function_kind.
+       (m68k_handle_fndecl_attribute): Reject interrupt_thread if the
+       target is not fido.
+       (m68k_compute_frame_layout): Don't mark any register for save
+       if an interrupt_thread attribute is specified.
+       (m68k_hard_regno_rename_ok): Update a use of
+       m68k_interrupt_function_p.
+       * config/m68k/m68k.h (EPILOGUE_USES): Update a use of
+       m68k_interrupt_function_p.
+       (m68k_function_type): New.
+       * config/m68k/m68k.md (*return): Output a 'sleep' instruction
+       for a function with an interrupt_thread attribute.
+       * doc/extend.texi: Document the interrupt_thread attribute.
+
+2007-05-13  Daniel Berlin  <dberlin@dberlin.org>
+
+       Fix PR tree-optimization/31911
+       * tree-ssa-pre.c (phi_translate): Make sure to cache results even
+       if they didn't change the expression.
+
+2007-05-13  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-scalar-evolution.c (resolve_mixers): Exported.
+       * tree-scalar-evolution.h (resolve_mixers): Declare.
+       * tree-data-ref.c (object_analysis, ptr_decl_may_alias_p,
+       ptr_ptr_may_alias_p, may_alias_p, record_ptr_differ_p,
+       record_record_differ_p, record_array_differ_p, array_ptr_differ_p,
+       base_object_differ_p, base_addr_differ_p, analyze_array_indexes,
+       init_array_ref, init_pointer_ref, analyze_indirect_ref,
+       strip_conversion, analyze_offset_expr, address_analysis,
+       object_analysis, analyze_offset): Removed.
+       (dr_analyze_innermost, dr_analyze_indices, dr_analyze_alias,
+       split_constant_offset, canonicalize_base_object_address,
+       object_address_invariant_in_loop_p, disjoint_objects_p,
+       dr_may_alias_p, dr_address_invariant_p): New functions.
+       (create_data_ref): Use dr_analyze_innermost, dr_analyze_indices
+       and dr_analyze_alias.
+       (initialize_data_dependence_relation): Use dr_may_alias_p
+       and object_address_invariant_in_loop_p.
+       (compute_self_dependence): Handle the case when
+       DDR_ARE_DEPENDENT (ddr) is chrec_dont_know.
+       (find_data_references_in_stmt): Restrict the analysis of data
+       references to the given loop nest.
+       (find_data_references_in_loop): Made static.  Pass loop nest to
+       find_data_references_in_stmt.
+       (compute_data_dependences_for_loop): Use DR_VOPS.
+       (free_data_ref): Free DR_VOPS.
+       * tree-data-ref.h (struct first_location_in_loop): Replaced by ...
+       (struct innermost_loop_behavior): ... new.
+       (struct base_object_info): Replaced by ...
+       (struct indices): ... new.
+       (struct dr_alias): New.
+       (enum data_ref_type): Removed.
+       (struct data_reference): Consist of struct innermost_loop_behavior,
+       struct indices and struct dr_alias.
+       (DR_SET_ACCESS_FNS, DR_FREE_ACCESS_FNS): Removed.
+       (DR_MEMTAG): Renamed to ...
+       (DR_SYMBOL_TAG): ... this.
+       (find_data_references_in_loop): Declaration removed.
+       * tree-vect-analyze.c (vect_compute_data_ref_alignment): Use DR_INIT
+       instead of DR_OFFSET_MISALIGNMENT.  DR_ALIGNED_TO is never NULL.
+       (vect_analyze_data_refs): Use DR_SYMBOL_TAG instead of DR_MEMTAG.
+       * tree-vect-transform.c (vect_create_data_ref_ptr): Ditto.
+
+2007-05-13  Revital Eres  <eres@il.ibm.com>
+
+       * tree-ssa-dse.c (get_use_of_stmt_lhs): New function
+       which walks virtual def-use chains to find redundant stores.
+       (dse_optimize_stmt): Call it.
+
+2007-05-12  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * gcse.c (gcse_main): Do jump bypassing in CPROP2.
+       * passes.c (init_optimization_passes): Move pass_jump_bypass
+       after loop2.
+
+       * basic-block.h (bb_has_eh_pred): Fix style issue.
+
+2007-05-12  Steven Bosscher  <steven@gcc.gnu.org>
+
+       PR rtl-optimization/31848
+       * loop-invariant.c (move_invariant_reg): If we move an insn
+       with a REG_EQUAL note, and that insn is not always executed,
+       remove the REG_EQUAL note.
+
+2007-05-12  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31797
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr): Do not
+       propagate into a stmt that has volatile ops.
+
+2007-05-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * configure.ac (gcc_gxx_include_dir): Use $(libsubdir_to_prefix).
+       (gcc_tooldir): Likewise.
+       * configure: Regenerate.
+       * Makefile.in (libsubdir_to_prefix): New variable, based on the
+       old configure.ac gcc_tooldir setting.
+       (prefix_to_exec_prefix): New variable.
+       (DRIVER_DEFINES): Use $(libsubdir_to_prefix)$(prefix_to_exec_prefix)
+       rather than $(unlibsubdir)/../ to derive TOOLDIR_BASE_PREFIX.
+
+2007-05-11  Silvius Rus  <rus@google.com>
+
+       * Makefile.in (OBJS-common): Add tree-ssa-alias-warnings.o.
+       * c-common.c (strict_aliasing_warning): Modify -Wstrict-aliasing logic.
+       * c-common.h (strict_aliasing_warning): Change return type.
+       * c-opts.c (c_common_handle_option): Add call to set_Wstrict_aliasing.
+       * c-typeck.c (build_indirect_ref): Add call to strict_aliasing_warning.
+       (build_c_cast): Condition call to strict_aliasing_warning.
+       * doc/invoke.texi: Update description of -Wstrict-aliasing[=n].
+       * flags.h (set_Wstrict_aliasing): Declare.
+       * opts.c (set_Wstrict_alising): Define, add call to.
+       * tree-flow.h (strict_aliasing_warning_backend): Declare.
+       * tree-ssa-alias-warnings.c: New file.
+       * tree-ssa-alias.c (compute_may_aliases): Add call to
+       strict_aliasing_warning_backend.
+
+2007-05-11  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-loop-linear.c (gather_interchange_stats, try_interchange_loops):
+       Use loop_depth and loop_outer accessor functions.
+       * tree-ssa-loop-im.c (outermost_invariant_loop, set_level,
+       determine_invariantness_stmt, move_computations_stmt): Ditto.
+       * cfgloopmanip.c (fix_bb_placement, fix_loop_placement, remove_path,
+       add_loop, loopify, unloop, fix_loop_structure): Ditto.
+       * tree-ssa-loop-manip.c (find_uses_to_rename_use): Ditto.
+       * tree-scalar-evolution.c (interpret_loop_phi,
+       compute_scalar_evolution_in_loop, analyze_scalar_evolution_in_loop,
+       instantiate_parameters_1, scev_const_prop): Ditto.
+       * cfghooks.c (make_forwarder_block): Ditto.
+       * cfgloopanal.c (mark_irreducible_loops, mark_loop_exit_edges): Ditto.
+       * modulo-sched.c (loop_canon_p): Ditto.
+       * tree-vectorizer.c (slpeel_tree_duplicate_loop_to_edge_cfg,
+       slpeel_can_duplicate_loop_p): Ditto.
+       * lambda-code.c (invariant_in_loop_and_outer_loops): Ditto.
+       * tree-cfg.c (tree_duplicate_sese_region): Ditto.
+       * cfgloop.c (flow_loop_dump, flow_loop_nodes_find, rescan_loop_exit,
+       cancel_loop, verify_loop_structure): Ditto.
+       (flow_loop_nested_p, superloop_at_depth, flow_loop_free,
+       add_bb_to_loop, remove_bb_from_loops, find_common_loop): Use the
+       superloops vector instead of "pred" array.
+       (establish_preds): Take father loop as an argument.  Initialize the
+       superloops vector.
+       (flow_loop_tree_node_add): Pass father loop to establish_preds.
+       Do not initialize loop->outer.
+       (flow_loop_tree_node_remove): Truncate the superloops vector.
+       * cfgloop.h (struct loop): Removed field "outer", fields "depth" and
+       "pred" merged to "superloops" vector.
+       (loop_depth, loop_outer): New.
+       (fel_init): Use loop_outer.
+
+2007-05-11  Jan Hubicka  <jh@suse.cz>
+
+       * cgraphunit.c: Include gt-cgraphunit.h
+       (static_ctors, static_dtors): New static vars.
+       (record_cdtor_fn, build_cdtor, cgraph_build_cdtor_fns): New functions,
+       based on implementation in c-common.c
+       (cgraph_finalize_function): Call record_cdtor_fn.
+       (cgraph_optimize): Call cgraph_build_cdtor_fns.
+       * decl.c (finish_function): Do not call c_record_cdtor_fn.
+       (c_write_global_declarations): Do not call c_build_cdtor_fns.
+       * c-common.c (static_ctors, static_dtors, c_record_cdtor_fn,
+       build_cdtor, c_build_cdtor_fns): Remove.
+       * c-common.h (static_ctors, static_dtors, c_record_cdtor_fn,
+       c_build_cdtor_fns): Remove prototype.
+
+2007-05-11  Paolo Carlini  <pcarlini@suse.de>
+
+       PR other/31852
+       * builtin-types.def: Add BT_FN_PTR_CONST_PTR_INT_SIZE.
+       * builtins.def: Add BUILT_IN_MEMCHR, use the latter.
+       * builtins.c (fold_builtin_memchr): New.
+       (expand_builtin_memchr): Call the latter.
+       (expand_builtin, fold_builtin_3): Deal with BUILT_IN_MEMCHR.
+       * doc/extend.texi ([Other built-in functions provided by GCC]):
+       Document memchr.
+
+2007-05-11  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md (GPR0_REGNUM, FPR0_REGNUM, FPR2_REGNUM,
+       PFPO_CONVERT, PFPO_OP_TYPE_SF, PFPO_OP_TYPE_DF, PFPO_OP_TYPE_TF,
+       PFPO_OP_TYPE_SD, PFPO_OP_TYPE_DD, PFPO_OP_TYPE_TD, PFPO_OP0_TYPE_SHIFT,
+       PFPO_OP1_TYPE_SHIFT): Constants added.
+       (DFP_ALL): Mode macro defined.
+       ("*trunc<BFP:mode><DFP_ALL:mode>2", "*trunc<DFP_ALL:mode><BFP:mode>2",
+       "*extend<BFP:mode><DFP_ALL:mode>2", "*extend<DFP_ALL:mode><BFP:mode>2"):
+       Insn definitions added.
+       ("trunc<BFP:mode><DFP_ALL:mode>2", "trunc<DFP_ALL:mode><BFP:mode>2",
+       "extend<BFP:mode><DFP_ALL:mode>2", "extend<DFP_ALL:mode><BFP:mode>2"):
+       Expanders added.
+
+2007-05-10  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/31885
+       * tree-chrec.c (chrec_contains_undetermined): Do not consider
+       NULL_TREE to be undetermined.
+       (automatically_generated_chrec_p): Return false for NULL.
+
+2007-05-08  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.h (MOVE_RATIO): Define.
+
+2007-05-10  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (sparc-wrs-vxworks): New target.
+       * config/sparc/vxworks.h, config/sparc/t-vxworks: New files.
+       * config/sparc/sparc-protos.h (sparc_emit_call_insn): Declare.
+       * config/sparc/sparc.h: Include vxworks-dummy.h.
+       (PRINT_OPERAND_ADDRESS): Extend SYMBOL_REF handling to
+       include LABEL_REFs too.
+       * config/sparc/sparc.c (sparc_expand_move): Don't assume that
+       _GLOBAL_OFFSET_TABLE_ - label_ref is a link-time constant on
+       VxWorks.
+       (legitimize_pic_address): Handle LABEL_REFs like SYMBOL_REFs
+       on VxWorks.
+       (load_pic_register): Use gen_vxworks_load_got for VxWorks.
+       (sparc_emit_call_insn): New function.
+       (sparc_function_ok_for_sibcall): Restrict sibcalls to locally-binding
+       functions when generating VxWorks PIC.
+       * config/sparc/sparc.md (vxworks_load_got): New pattern.
+       (call, call_value): Use sparc_emit_call_insn instead of
+       emit_call_insn.
+
+2007-05-09  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_output_literal): Don't use #if.
+
+2007-05-09  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_output_literal): Mask out high bits
+       for floating-point values if HOST_BITS_PER_LONG > 32.  Use
+       split_double instead of operand_subword.
+
+2007-05-08  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.h (LOCAL_ALIGNMENT): Define.
+       * config/bfin/bfin.c (bfin_local_alignment): New function.
+       * config/bfin/bfin-protos.h (bfin_local_alignment): Declare it.
+
+2007-05-08  Chao-ying Fu  <fu@mips.com>
+
+       * doc/md.texi (msub@var{m}@var{n}4, usub@var{m}@var{n}4): Document.
+       * optabs.h (OTI_smsub_widen, OTI_umsub_widen): New optab_indexes.
+       (smsub_widen_optab, umsub_widen_optab): Define.
+       * optabs.c (init_optabs): Initialize smsub_widen_optab and
+       umsub_widen_optab.
+       * genopinit.c (optabs): Fill in smsub_widen_optab and
+       umsub_widen_optab.
+       * expr.c (expand_expr_real_1): Try to use smsub_widen_optab
+       and umsub_widen_optab to implement multiply-subtract sequences.
+       * config/mips/mips.md (*msac<u>_di): Rename to...
+       (<u>msubsidi4): ...this.  Extend condition to include
+       GENERATE_MADD_MSUB and TARGET_DSPR2.  Change the constraint
+       of operand 0 to "ka" and use the three-operand form of msub<u>
+       for TARGET_DSPR2.
+       * config/mips/mips-dspr2.md (mips_msub, mips_msubu): Convert
+       to define_expands.
+
+2007-05-08  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR rtl-optimization/28011
+       * reload.c (push_reload): Set dont_share if IN appears in OUT
+       also when IN is a PLUS rtx.
+       (reg_overlap_mentioned_for_reload_p): Return true if X and IN
+       are same PLUS rtx.
+
+2007-05-08  Kazu Hirata  <kazu@codesourcery.com>
+
+       * emit-rtl.c (unshare_all_rtl_1): Don't copy DECL_RTL.  Don't
+       call unshare_all_decls.
+       (unshare_all_rtl): Adjust the call to unshare_all_rtl_1.
+       (unshare_all_decls): Remove.
+
+2007-05-08  Simon Martin  <simartin@users.sourceforge.net>
+
+       PR 31847
+       * tree-dump.c (dump_options): Don't use TDF_DIAGNOSTIC in "*-all" tree
+       dumps.
+
+2007-05-08  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/mips.h (MAX_FPRS_PER_FMT): Renamed from FP_INC.
+       Update comments and all uses.
+       (MIN_FPRS_PER_FMT): Define.
+       * config/mips/mips.c (function_arg): Fix to correctly handle
+       the -mips32r2 -mfp64 -mabi=32 case.
+       (override_options): Enable use of odd-numbered registers for
+       SFmode values on MIPS32.
+       (mips_save_reg_p): Save whole floating-point register pair if
+       either half is used.
+       (compute_frame_size): Fix comment.
+
+2007-05-08  Jie Zhang  <jie.zhang@analog.com>
+
+       * config/bfin/bfin-protos.h (bfin_expand_epilogue): Add a third
+       argument of type bool.
+       * config/bfin/bfin.c (add_to_reg): Add epilogue_p as a fourth
+       argument. Safely select temporary P register according to it.
+       (do_link): Change call site of add_to_reg accordingly.
+       (do_unlink): Add epilogue_p as a fourth argument and pass it
+       to add_to_reg.
+       (expand_interrupt_handler_epilogue): Change call of do_unlink
+       accordingly.
+       (bfin_expand_prologue): Add a third argument sibcall_p.
+       * config/bfin/bfin.md (epilogue): Change call of
+       bfin_expand_epilogue accordingly.
+       (sibcall_epilogue): Likewise.
+       (eh_return_internal): Likewise.
+
+       * config/bfin/bfin-protos.h (enum bfin_cpu): Add
+       BFIN_CPU_BF534, BFIN_CPU_BF536 and BFIN_CPU_BF561.
+       * config/bfin/bfin.c (bfin_handle_option): Handle
+       -mcpu=bf534, -mcpu=bf536 and -mcpu=bf561.
+       * config/bfin/bfin.h (TARGET_CPU_CPP_BUILTINS):
+       Support bf534, bf536 and bf561.
+       * doc/invoke.texi (Blackfin Options): Document -mcpu and -msim.
+
+2007-05-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/31854
+       * config/i386/i386.c (ix86_function_regparm): Process local
+       functions only when TREE_CODE (decl) equals FUNCTION_DECL.
+
+2007-05-07  Mike Stump  <mrs@apple.com>
+
+       * doc/invoke.texi (Warning Options): Document that -Wempty-body
+       also checks for and while statements in C++.
+
+2007-05-07  Nathan Froyd  <froydnj@codesourcery.com>
+
+       * gcc.c (at_file_supplied): New variable.
+       (main): Set it if we expanded argv.
+       (do_spec_1): Pass an @-file to the linker if we were called with
+       an @-file argument and HAVE_GNU_LD.
+       * collect2.c (at_file_supplied): New variable.
+       (response_file): New variable.
+       (collect_exit): Unlink response_file if necessary.
+       (handler): Likewise.
+       (do_wait): Likewise.
+       (main): Set at_file_supplied if we expanded argv.
+       (collect_execute): Pass an @-file to subprocesses if we were called
+       with an @-file argument.
+       * configure.ac: Add define for HAVE_GNU_LD.
+       * configure: Regenerate.
+       * config.in: Regenerate.
+
+2007-05-07  Naveen.H.S  <naveen.hs@kpitcummins.com>
+
+       * config/m32c/muldiv.md (mulhisi3_c): Limit the mode of the 2nd
+       operand to HI mode.
+       (mulsi3): New.
+       (divsi3): New.
+       (udivsi3): New.
+
+2007-05-07  Jayant Sonar  <jayants@kpitcummins.com>
+
+       * config/m32c/m32c.c (SYMBOL_FLAG_FUNCVEC_FUNCTION): Define.
+       (TARGET_ENCODE_SECTION_INFO): Re-define.
+       (m32c_encode_section_info): New
+       (function_vector_handler): New
+       (current_function_special_page_vector): New
+       (m32c_special_page_vector_p): New.
+       * config/m32c/m32c-protos.h (m32c_special_page_vector_p):
+       Prototype.
+       * config/m32c/jump.md: Added instruction JSRS for functions
+       with attribute "function_vector".
+       * doc/extend.texi (function_vector): Added description
+       for M16C, M32C targets.
+
+2007-05-07  DJ Delorie  <dj@redhat.com>
+
+       PR 31794
+       * config/m32c/shift.md (ashlpsi3_i, ashrpsi3_i, ashlpsi3,
+       ashrpsi3, lshrpsi3): Update shift count constraint.
+
+2007-05-07  Danny Smith  <dannysmith@users.sourceforge.net>
+           Nathan Froyd  <froydnj@codesourcery.com>
+
+       PR 22133
+       * c-incpath.c (add_path): Strip trailing path separators.
+
+2007-05-07  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-ssa-dom.c (tree_ssa_dominator_optimize): Reset cfg_altered.
+       Free dominance info before purging EH edges.
+       (eliminate_degenerate_phis): Likewise.
+       (propagate_rhs_into_lhs): Set cfg_altered to true instead of 1.
+
+2007-05-07  Jan Hubicka  <jh@suse.cz>
+
+       * gimplify.c (gimplify_expr): Do not crash when folding
+       (void *)(int)&a + 4.
+
+2007-05-07  Francois-Xavier Coudert  <fxcoudert@gcc.gnu.org>
+
+       PR driver/31694
+       * c-opts.c (lang_fortran): Make it non static.
+       * c-common.h (lang_fortran): New prototype.
+       * c-cppbuiltin.c (c_cpp_builtins): Create a __GFORTRAN__ if the
+       -lang-fortran option was passed by the driver.
+
+2007-05-06  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * timevar.c (timevar_print): Test ENABLE_ASSERT_CHECKING instead
+       of ASSERT_CHECKING.  Tweak message.
+
+2007-05-06  Revital Eres  <eres@il.ibm.com>
+
+       PR 30957
+       * loop-unroll.c (insert_var_expansion_initialization):
+       Initialize the expansions with -zero instead of +zero.
+
+2007-05-05  Aurelien Jarno  <aurelien@aurel32.net>
+
+       * config/pa/pa.md: Split tgd_load, tld_load and tie_load
+       into pic and non-pic versions. Mark r19 as used for
+       tgd_load_pic, tld_load_pic and tie_load_pic. Mark r27 as used
+       for tgd_load, tld_load and tie_load .
+       * config/pa/pa.c (legitimize_tls_address): Emit pic or non-pic
+       version of tgd_load, tld_load and tie_load depending on the
+       value of flag_pic.
+
+2007-05-04  Ulrich Drepper  <drepper@redhat.com>
+           Jakub Jelinek  <jakub@redhat.com>
+
+       * crtstuff.c (HIDDEN_DTOR_LIST_END): New macro.
+       (__do_global_dtors_aux): Use more paranoid loop to run
+       destructors if HIDDEN_DTOR_LIST_END.
+       (__DTOR_END__): Export as a hidden symbol when HIDDEN_DTOR_LIST_END.
+
+2007-05-04  Jakub Jelinek  <jakub@redhat.com>
+
+       * varasm.c (align_variable): Don't increase alignment for
+       DECL_THREAD_LOCAL_P variables above BITS_PER_WORD through
+       DATA_ALIGNMENT or CONSTANT_ALIGNMENT.
+
+2007-05-04  Josh Conner  <jconner@apple.com>
+
+       * basic-block.h (cdi_direction): Assign values to all enumeration
+       constants.
+       (dom_computed): Remove.
+       (dom_info_state): New.
+       (set_dom_info_availability): New.
+       * tree-ssa-loop-im.c (determine_invariantness): Initialize
+       walk_data.dom_direction.
+       * cfghooks.c (delete_basic_block): Use dom_info_available_p()
+       instead of dom_computed[].
+       (split_edge): Likewise.
+       (create_basic_block): Likewise.
+       (merge_blocks): Likewise.
+       * ifcvt.c (find_if_header): Likewise.
+       * tree-cfgcleanup.c (cleanup_tree_cfg): Likewise.
+       * tree-ssa-dce.c (remove_dead_stmt): Likewise.
+       * tree-ssa.c (verify_ssa): Likewise.
+       * tree-cfg.c (tree_verify_flow_info): Likewise.
+       (remove_edge_and_dominated_blocks): Likewise.
+       * dominance.c (dom_computed): Make static.
+       (calc_dfs_tree_nonrec): Change third param to a bool.
+       (calc_dfs_tree): Change second param to a bool.
+       (calc_idioms): Change second param to a bool.  Use
+       dom_convert_dir_to_idx.
+       (init_dom_info): Validate dir before using.
+       (dom_convert_dir_to_idx): New.
+       (calculate_dominance_info): Use dom_convert_dir_to_idx.  New
+       variable 'reverse' used for calling calc_dfs_tree and calc_idoms.
+       (free_dominance_info): Use dom_convert_dir_to_idx.
+       (get_immediate_dominator): Likewise.
+       (set_immediate_dominator): Likewise.
+       (get_dominated_by): Likewise.
+       (redirect_immediate_dominators): Likewise.
+       (nearest_common_denominator): Likewise.
+       (dominated_by_p): Likewise.
+       (bb_dom_dfs_in): Likewise.
+       (bb_dom_dfs_out): Likewise.
+       (recount_dominator): Likewise.
+       (iterate_fix_dominators): Likewise.
+       (add_to_dominance_info): Likewise.
+       (delete_from_dominance_info): Likewise.
+       (first_dom_son): Likewise.
+       (next_dom_son): Likewise.
+       (dom_info_available_p): Likewise.
+       (dom_info_state): New.
+       (set_dom_info_availability): New.
+
+2007-05-04  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md ("fix_trunc<mode>di2", "fix_trunc<mode>si2"):
+       Expander removed.
+       ("fix_trunc<DSF:mode><GPR:mode>2"): Expander added.
+
+2007-05-04  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.md (adddi3, adddi_carry): Delete.
+       (subdi3, subdi_carry): Delete.
+
+2007-05-04  Jan Hubicka  <jh@suse.cz>
+           Richard Guenther  <rguenther@suse.de>
+
+       * opts.c (decode_options): Do not fiddle with inlining
+       parameters in case of optimizing for size.
+       * ipa-inline.c (cgraph_decide_recursive_inlining): When optimizing
+       for size do nothing.
+       (cgraph_decide_inlining_of_small_function): When optimizing for
+       size never inline functions increasing caller size.
+       (cgraph_early_inlining): Inline for size when optimizing for size.
+
+2007-05-04  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.md (<optab>di3): Now a define_expand which expands
+       logical operations piecewise.
+       (<optab>di_zesidi_di, <optab>di_sesidi_di, negdi2, one_cmpldi2,
+       zero_extendsidi2, subdi_di_zesidi, subdi_zesidi_di, subdi_di_sesidi,
+       subdi_sesidi_di): Delete.
+       (add_with_carry): Produce carry in CC instead of a DREG to shorten
+       the generated sequence.  Allow three-reg add in constraints.  Rewrite
+       the rtl expression for carry to avoid zero_extend of a constant.
+       (sub_with_carry): New pattern.
+       (adddi3, subdi3): Change into define_expand.  For subtract, generate a
+       different sequence not involving jumps.
+       (notbi): Now a named pattern.
+
+2007-05-04  Bradley Lucier  <lucier@math.purdue.edu>
+
+       * doc/invoke.texi (i386 and x86-64 Options) [-mpc32, -mpc64, -mpc80]:
+       Add the note about a significant loss of accuracy of some
+       mathematical routines when these options are used.
+
+2007-05-04  Maxim Kuvyrkov  <mkuvyrkov@ispras.ru>
+
+       * haifa-sched.c (rtx_vec_t): New typedef.
+       (contributes_to_priority_p): Extract piece of priority () into new
+       static function.
+       (priority): Use the function.  Add assertion.
+       (rank_for_schedule, set_priorities): Add assertion to check that
+       insn's priority is initialized.
+       (clear_priorities, calc_priorities): Change signature.  Make it update
+       all relevant insns.  Update all callers ('add_to_speculative_block ()'
+       and 'create_block_check_twin ()').
+       * sched-int.h (struct haifa_insn_data): Remove field 'priority_known'.
+       Add new field 'priority_status'.
+       (INSN_PRIORITY_STATUS): New macro.
+       (INSN_PRIORITY_KNOWN): Change to use INSN_PRIORITY_STATUS.
+
+2007-05-04  Maxim Kuvyrkov  <mkuvyrkov@ispras.ru>
+
+       * sched-ebb.c (debug_ebb_dependencies): New static function.
+       (init_ready_list): Use it.
+
+       * sched-rgn.c (debug_dependencies): Split into 'debug_dependencies ()'
+       with changed signature and 'debug_rgn_dependencies ()'.
+       (debug_rgn_dependencies): New static function.
+       (init_ready_list): Use it.
+
+       * sched-int.h (debug_dependencies): Declare.
+
+2007-05-04  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * libgcc-std.ver (__ffssi2): Added to GCC_4.3.0 section.
+
+2007-05-04  Dirk Mueller  <dmueller@suse.de>
+
+       * c.opt(Wmain,ffreestanding): Enable for C++,ObjC++.
+
+2007-05-03  Jan Hubicka  <jh@suse.cz>
+
+       * fold-const.c (fold_unary): Convert (T1)(X op Y) into
+       ((T1)X op (T1)Y), for pointer type in more cases than before.
+
+       * gimplify.c (gimplify_expr): Fold (void *)&a + 4.
+
+       * tree-object-size.c (plus_expr_object_size): When operand size is
+       unknown, return unknown.
+
+2007-05-03  Dirk Mueller  <dmueller@suse.de>
+
+       * doc/invoke.texi (-m386,-m486,-mpentium,-mpentiumpro): Remove.
+
+       * config/i386/i386.h (CC1_CPU_SPEC): Remove handling for deprecated
+       options.
+
+       * config/i386/i386.opt (m386,m486,mpentium,mpentiumpro): Remove.
+
+2007-05-03  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/sourcebuild.texi (Test Directives) Clarify dg-excess-errors.
+
+2007-05-03  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/soft-fp/double.h, config/soft-fp/extended.h,
+       config/soft-fp/floatundidf.c, config/soft-fp/floatundisf.c,
+       config/soft-fp/floatunsidf.c, config/soft-fp/floatunsisf.c,
+       config/soft-fp/op-2.h, config/soft-fp/op-4.h,
+       config/soft-fp/op-common.h, config/soft-fp/quad.h: Update from
+       glibc CVS.
+
+2007-05-03  Ian Lance Taylor  <iant@google.com>
+
+       * config/rs6000/rs6000.c (rs6000_override_options): Don't set
+       MASK_PPC_GFXOPT for 8540 or 8548.
+
+2007-05-03  Uros Bizjak  <ubizjak@gmail.com>
+
+       * tree-vect-transform.c (vect_update_inits_of_drs): Use
+       vect_print_dump_info() to output debug information.
+
+2007-05-03  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/31768
+       * config/i386/i386.c (print_operand) ['z']: Output 'w' for
+       operands of size 2 when operand is not MEM_P.
+
+2007-05-03  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/30565
+       * lambda-code.c (perfect_nestify): Fix updating of dominators.
+
+2007-05-03  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.md (addpdi3, us_truncpdisi2): New patterns.
+       (umulsi3_highpart): Use them.
+       * config/bfin/lib1funcs.asm (__umulsi3_highpart): Use unsigned move
+       for final accumulator to D regisster tranfser.
+
+2007-05-03  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/31699
+       * tree-vect-analyze.c (vect_update_misalignment_for_peel): Remove
+       wrong code.
+       (vect_enhance_data_refs_alignment): Compute peel amount using
+       TYPE_VECTOR_SUBPARTS instead of vf.
+       * tree-vect-transform.c (vect_gen_niters_for_prolog_loop): Likewise.
+
+2007-05-02  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       PR bootstrap/31776
+       * system.h: Remove inclusion of double-int.h
+       * tree.h: Include double-int.h
+       * gengtype.c: Likewise
+       * cfgloop.h: Likewise
+       * Makefile.in: Adjust dependencies on double-int.h
+
+2007-05-02  Eric Christopher  <echristo@apple.com>
+
+       * config/darwin.h (TARGET_OPTION_TRANSLATE_TABLE): Translate
+       -shared to -Zdynamiclib.
+
+2007-05-02  Seongbae Park  <seongbae.park@gmail.com>
+
+       PR c++/31663
+       * c-common.c (strip_pointer_or_array_types): New function.
+       * c-common.h (strip_pointer_or_array_types): New function declaration.
+
+2007-05-03  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/31771
+       * tree-cfg.c (move_block_to_fn): Assign bb to the correct index.
+
+2007-05-02  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/bpabi.S (aeabi_lcmp): Fix result on overflow.
+
+2007-05-02  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/29715
+       * fold-const.c (fold_comparision): Remove the "foo++ == CONST"
+       transformation.
+
+2007-05-02  Nick Clifton  <nickc@redhat.com>
+
+       * config/frv/predicates.md (symbolic_operand): Accept CONSTs.
+
+2007-05-02  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31146
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): New
+       argument, single_use_p.  If we have a single use that is
+       a conversion to the definition rhs type, propagate that rhs.
+       (forward_propagate_addr_expr): Pass single_use_p argument
+       to forward_propagate_addr_expr_1.
+
+2007-05-01  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c (ix86_expand_sse_comi): Remove unused
+       variable.
+
+2007-05-01  Dwarakanath Rajagopal <dwarak.rajagopal@amd.com>
+
+       * doc/invoke.texi: Fix typo, 'AMD Family 10h core' instead of
+       'AMD Family 10 core'.
+
+2007-05-01  Dwarakanath Rajagopal <dwarak.rajagopal@amd.com>
+
+       * config/i386/i386.c (override_options): Accept k8-sse3, opteron-sse3
+       and athlon64-sse3 as improved versions of k8, opteron and athlon64
+       with SSE3 instruction set support.
+       * doc/invoke.texi: Likewise.
+
+2007-05-01  Dwarakanath Rajagopal <dwarak.rajagopal@amd.com>
+
+       * config/i386/i386.c (override_options): Tuning 32-byte loop
+       alignment for amdfam10 architecture. Increasing the max loop
+       alignment to 24 bytes.
+
+2007-05-01  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/constraints.md: New.
+       * config/m68k/m68k.h (REG_CLASS_FROM_LETTER,
+       CONST_OK_FOR_LETTER_P, CONST_DOUBLE_OK_FOR_LETTER_P,
+       EXTRA_CONSTRAINT): Remove.
+       * config/m68k/m68k.md: Include constraints.md.
+       * expr.c (expand_expr_real_1): Copy DECL_RTL before using it.
+
+2007-05-01  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/31739
+       * tree-vrp.c (vrp_val_is_max): New static function.
+       (vrp_val_is_min): New static function.
+       (set_value_range_to_value): Use TYPE_{MAX,MIN}_VALUE rather than
+       copying the node.
+       (set_value_range): Use vrp_val_is_{max,min}.
+       (extract_range_from_assert): Likewise.
+       (extract_range_from_binary_expr): Likewise.
+       (extract_range_from_unary_expr): Likewise.
+       (dump_value_range, vrp_meet): Likewise.
+       (vrp_visit_phi_node): Likewise.
+       * tree.c (build_distinct_type_copy): Revert change of 2007-04-27.
+
+2007-05-01  Mark Mitchell  <mark@codesourcery.com>
+
+       * config/i386/gmon-sol2.c (size_t): New type.
+       (intptr_t): Likewise.
+       (s_textsize): Declare as size_t.
+       (sbrk): Declare.
+       (monstartup): Use size_t for sizes.
+       (_mcount): Save and restore registers.
+       (internal_mcount): Pass 0 as the first argument to monstartup
+       in 64-bit mode.
+       (moncontrol): Convert pointer to appropriately sized integer
+       before passing to profil.
+
+2007-05-01  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/rs6000/darwin-ldouble.c (__gcc_qunord): Define if
+       __NO_FPRS__, not just if _SOFT_DOUBLE.
+       * config/rs6000/libgcc-ppc-glibc.ver (__gcc_qunord): Likewise.
+       * config/rs6000/rs6000.c (rs6000_init_libfuncs): Use __gcc_qunord
+       also for E500 double.
+       * config/rs6000/rs6000.md (buneq, bunge, bungt, bunle, bunlt,
+       suneq, sunge, sungt, sunle, sunlt): Disable for (TARGET_HARD_FLOAT
+       && !TARGET_FPRS).
+
+2007-05-01  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-loop-manip.c (ip_normal_pos): Check if last stmt
+       is NULL.
+
+2007-05-01  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/rs6000/libgcc-ppc-glibc.ver (__gcc_qgt): Fix typo.
+
+2007-05-01  Jan Hubicka  <jh@suse.cz>
+
+       * tree-vectorize.c (vect_is_simple_use): gimple_min_invariant is
+       invariant.
+
+2007-05-01  Jan Hubicka  <jh@suse.cz>
+
+       * tree.h (maybe_fold_offset_to_component_ref): Remove.
+       (maybe_fold_offset_to_reference): Declare.
+       * fold-const.c (fold_unary): Do not fold
+       (type *)&A into &A->field_of_type_and_offset_0
+       * tree-ssa-ccp.c (maybe_fold_offset_to_array_ref): When base type
+       size is unknown, give up.
+       (maybe_fold_offset_to_component_ref): Ignore firelds with unknown
+       offsets.
+       (maybe_fold_offset_to_reference): New.
+       (maybe_fold_stmt_indirect): Use it.
+       (fold_stmt_r): Fold (type *)&A+offset into A->field_if_type_and_offset.
+       * gimplify.c (gimplify_conversion): Canonicalize conversions to
+       field references.
+       (gimplify_expr): Likewise for plus_expr.
+
+2007-05-01  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-ivopts.c (rewrite_use_nonlinear_expr): Use
+       bsi_after_labels.  Always insert statements before bsi.
+       * tree-vect-transform.c (vect_create_epilog_for_reduction): Ditto.
+       * predict.c (apply_return_prediction): Check for empty blocks.
+       * cfgexpand.c (lab_rtx_for_bb): New variable.
+       (label_rtx_for_bb): Do not create new tree labels.
+       (expand_gimple_basic_block): Add labels recorded in lab_rtx_for_bb.
+       (tree_expand_cfg): Initialize lab_rtx_for_bb.
+       * tree-cfg.c (build_tree_cfg): Call cleanup_dead_labels after
+       creating edges.
+       (label_for_bb): Add field used.
+       (update_eh_label, main_block_label): Mark the label used.
+       (cleanup_dead_labels): Remove unused labels.
+
+2007-05-01  Richard Guenther  <rguenther@suse.de>
+
+       * tree-vrp.c (set_value_range): Do not allocate equiv bitmap
+       if it is not about to be set.
+       (get_value_range): Do not pre-allocate equiv bitmap.
+       (update_value_range): No need to clear equiv field.
+       (add_equivalence): Change prototype to get bitmap pointer.
+       Allocate bitmap here if it is not already.
+       (extract_range_from_assert): Do not allocate bitmap here.
+       Update callers to add_equivalence.
+       (extract_range_from_ssa_name): Likewise.
+       (get_vr_for_comparison): New static helper.
+       (compare_name_with_value): Handle NULL equiv bitmap by
+       peeling the first iteration of the comparison loop.
+       Use get_vr_for_comparison.
+       (compare_names): Handle NULL equiv bitmaps by using fake
+       ones.  Use get_vr_for_comparison.
+
+2007-04-30  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * double-int.c (mpz_set_double_int): Moved from
+       tree-ssa-loop-niter.c.
+       (mpz_get_double_int): Likewise; also, add option to wrap
+       out-of-range integers.
+       * double-int.h: New prototypes for above.
+       * tree.c (get_static_type_bounds): Moved from
+       tree-ssa-loop-niter.c; now returns TYPE_MIN_VALUE and
+       TYPE_MAX_VALUE if they exist..
+       * tree.h: New prototype for above.
+       * tree-ssa-loop-niter.c: Adjust mpz_to_double_int and
+       get_type_bounds calls.
+       (mpz_set_double_int): Move to double-int.c.
+       (get_type_bounds): Move to tree.c, rename to
+       get_static_type_bounds.
+       (mpz_to_double_int): Move to double-int.c, rename to
+       mpz_get_double_int.
+
+2007-04-30  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/lib1funcs.asm (__umodsi3, __modsi3): Rearrange so that
+       DIV0 exception can fall through to a normal return.
+
+2007-04-30  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR middle-end/22156
+       Temporarily revert:
+       2007-04-06  Andreas Tobler  <a.tobler@schweiz.org>
+       * tree-sra.c (sra_build_elt_assignment): Initialize min/maxshift.
+       2007-04-05  Alexandre Oliva  <aoliva@redhat.com>
+       * tree-sra.c (try_instantiate_multiple_fields): Needlessly
+       initialize align to silence bogus warning.
+       2007-04-05  Alexandre Oliva  <aoliva@redhat.com>
+       * tree-sra.c (struct sra_elt): Add in_bitfld_block.  Remove
+       all_no_warning.
+       (struct sra_walk_fns): Remove use_all parameter from use.
+       (sra_hash_tree): Handle BIT_FIELD_REFs.
+       (sra_elt_hash): Don't hash bitfld blocks.
+       (sra_elt_eq): Skip them in parent compares as well.  Handle
+       BIT_FIELD_REFs.
+       (sra_walk_expr): Don't maintain or pass down use_all_p.
+       (scan_use): Remove use_all parameter.
+       (scalarize_use): Likewise.  Re-expand assignment to
+       BIT_FIELD_REF of gimple_reg.  De-scalarize before input or
+       output, and re-scalarize after output.  Don't mark anything
+       for no warning.
+       (scalarize_ldst): Adjust.
+       (scalarize_walk_gimple_modify_statement): Likewise.
+       (build_element_name_1): Handle BIT_FIELD_REFs.
+       (instantiate_element): Don't warn for any element whose parent
+       is used as a whole.
+       (instantiate_missing_elements_1): Return the sra_elt.
+       (canon_type_for_field): New.
+       (try_instantiate_multiple_fields): New.
+       (instantiate_missing_elemnts): Use them.
+       (mark_no_warning): Removed.
+       (generate_one_element_ref): Handle BIT_FIELD_REFs.
+       (REPLDUP, sra_build_elt_assignment): New.
+       (generate_copy_inout): Use them.
+       (generate_element_copy): Likewise.  Handle bitfld differences.
+       (generate_element_zero): Don't recurse for blocks.  Use
+       sra_build_elt_assignment.
+       (generate_one_element_int): Take elt instead of var.  Use
+       sra_build_elt_assignment.
+       (generate_element_init_1): Adjust.
+       (scalarize_use, scalarize_copy): Use REPLDUP.
+       (scalarize_ldst): Move assert before dereference.
+       (dump_sra_elt_name): Handle BIT_FIELD_REFs.
+
+2007-04-30  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR C++/31721
+       * tree.c (reconstruct_complex_type): Reconstruct a reference
+       correctly.
+       Also use the same mode for the pointer as the old pointer type.
+
+2007-04-30  Francois-Xavier Coudert  <coudert@clipper.ens.fr>
+
+       * doc/trouble.texi (Interoperation): Remove note about Ultrix
+       Fortran compiler.
+
+2007-04-29  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR rtl-optimization/31676
+       * df-scan.c (record_nonlocal_goto_receiver_defs): New function.
+       (df_refs_record): Call it.
+
+2007-04-29  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * rtl.def (SS_ABS): New code.
+       * config/bfin/bfin.c (print_operand): New modifier 'v'.
+       (enum bfin_builtins): Add BFIN_BUILTIN_SUM_2X16, BFIN_BUILTIN_ABS_1x32,
+       BFIN_BUILTIN_ROUND_1x32, BFIN_BUILTIN_MULT_1x32x32,
+       BFIN_BUILTIN_MULT_1x32x32NS, BFIN_BUILTIN_SSASHIFT_1x32.
+       (bfin_init_builtins): Define them.
+       (bdesc_1arg, bdesc_2arg): Add some of them here, ...
+       (bfin_expand_builtin): ... and handle the others here.
+       * config/bfin/bfin.md (ssabssi2, ssroundsi2, ssashiftsi3,
+       flag_mul_macv2hi_parts_acconly_andcc0): New patterns.
+       (ss_absv2hi2): Renamed from absv2hi; use ss_abs code.
+       (ssashiftv2hi3, ssashifthi3, lshiftv2hi3, lshifthi3): Shift count
+       operand is only HImode.
+
+2007-04-29  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * regclass.c (scan_one_insn): Remove splitting of
+       two address insns.
+
+2007-04-28  Sandra Loosemore  <sandra@codesourcery.com>
+           Nigel Stephens  <nigel@mips.com>
+
+       * config/mips/mips.h (SLOW_BYTE_ACCESS): Turn off for MIPS16.
+
+2007-04-28  Jan Hubicka  <jh@suse.cz>
+
+       * config/alpha/alpha.c (alpha_output_mi_thunk_osf): Use
+       insn_locators_alloc instead of insn_locators_initialize;
+       call reset_block_changes.
+       * config/sparc/sparc.c (sparc_output_mi_thunk): Likewise.
+       * config/sh/sh.c (sparc_output_mi_thunk): Likewise.
+       * config/is64/ia64.c (ia64_output_mi_thunk): Likewise.
+       * config/rs6000/rs6000.c (rs6000_output_mi_thunk): Likewise.
+       * config/score/score.c (th_output_mi_thunk): Likewise.
+       * config/mips/mips.c (mips_output_mi_thunk): Likewise.
+       * cfglyaout.c (set_curr_insn_source_location, set_curr_insn_block):
+       tolerate uninitialized locator info.
+
+       Re-apply:
+       * function.c (init_function_start): Don't init line number info.
+       (expand_function_end): Update.
+       (reset_block_changes, record_block_change, finalize_block_changes,
+       check_block_change, free_block_changes): Kill.
+       * function.h (reset_block_changes, record_block_change,
+       finalize_block_changes, check_block_change, free_block_changes):
+       Remove prototypes.
+       (struct function): Remove ib_boundaries_block.
+       * emit-rtl.c (make_insn_raw, make_jump_insn_raw, make_call_insn_raw):
+       Use curr_insn_locator to initialize locator.
+       (emit_line_note): Remove.
+       * cfgexpand.c (expand_gimple_cond_expr): Update.
+       (construct_exit_block): Likewise.
+       (tree_expand_cfg): Initialize/finalize locators.
+       * expr.c (expand_expr_real): Update.
+       * cfglayout.c (line_locators_locs, line_locators_lines,
+       file_locators_locs, file_locators_files): Remove.
+       (set_block_levels): Move to cfgexpand.c.
+       (insn_locators_initialize): Remove.
+       (pass_insn_locators_initialize): Remove.
+       (locations_locators_locs, locations_locators_vals): New static vars.
+       (curr_location, last_location, curr_block, last_block, curr_rtl_loc):
+       Likewise.
+       (insn_locators_alloc, insn_locators_finalize,
+       set_curr_insn_source_location, set_curr_insn_block, curr_insn_locator):
+       New functions.
+       (locator_location): New.
+       (locator_line, locator_file): Rewrite.
+       * rtl.h (emit_line_note): Kill.
+       (insn_locators_alloc, insn_locators_finalize,
+       set_curr_insn_source_location, set_curr_insn_block, curr_insn_locator):
+       Declare.
+       * tree-inline.c (initialize_cfun): Do not initialize
+       ib_boundaries_block.
+       * passes.c (pass_insn_locators_initialize): Remove.
+
+2007-04-28  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-cfg.c (move_block_to_fn): Release bb from dominance
+       info.  Update last_basic_block correctly.
+
+2007-04-27  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/31701
+       * config/sh/sh.c (output_stack_adjust): Avoid using the frame
+       register itself to hold the offset constant.  Tell flow the use
+       of r4 and r5 when they are used.
+
+2007-04-27  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-forwprop.c (forward_propagate_into_cond): Keep track
+       if we simplified anything.
+       (tree_ssa_forward_propagate_single_use_vars): Defer overflow
+       warnings until we did a simplification and the stmt was not
+       marked as TREE_NO_WARNING.
+
+2007-04-27  Mike Stump  <mrs@apple.com>
+
+       * config/rs6000/darwin.h (ALWAYS_PUSH_CONSTS_USING_REGS_P): Remove.
+
+2007-04-27  Ian Lance Taylor  <iant@google.com>
+
+       PR middle-end/31710
+       * tree.c (build_distinct_type_copy): If TYPE_MIN_VALUE or
+       TYPE_MAX_VALUE exist, convert them to the new type.
+
+2007-04-27  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-cfgcleanup.c (cleanup_tree_cfg): Verify dominance info
+       if it claims to be available.
+       * tree-ssa-dce.c (remove_dead_stmt): Mark cfg as altered when
+       edge is redirected.
+       (perform_tree_ssa_dce): Always free postdominators.
+
+2007-04-27  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/predicates.md (aligned_memory_operand): Mark
+       as define_special_predicate.
+       (unaligned_memory_operand, normal_memory_operand): Likewise.
+       (reg_or_unaligned_mem_operand): Remove.
+       (any_memory_operand): Match the documentation and check for
+       non-renumbered pseudos during reload.
+       * config/alpha/alpha.c (alpha_secondary_reload): Rename from
+       alpha_secondary_reload_class, update to new interface, make static.
+       Handle CQImode like HImode.  Remove FP subreg check.
+       (alpha_expand_mov): Use replace_equiv_address.
+       (alpha_expand_mov_nobwx): Use any_memory_operand.
+       (TARGET_SECONDARY_RELOAD): New.
+       * config/alpha/alpha.h (SECONDARY_INPUT_RELOAD_CLASS): Remove.
+       (SECONDARY_OUTPUT_RELOAD_CLASS): Remove.
+       * config/alpha/sync.md (I12MODE, I48MODE, modesuffix): Move ...
+       * config/alpha/alpha.md: ... here.
+       (RELOAD12, reloadmode): New.
+       (movcqi): New.
+       (reload_in<RELOAD12>): Macro-ize from reload_inqi, reload_inhi.
+       Don't handle the aligned case here.
+       (reload_out<RELOAD12>): Macro-ize from reload_outqi, reload_outhi.
+       (reload_in<I12MODE>_aligned): Macro-ize from reload_inqi_help,
+       reload_inhi_help.  Don't expect a scratch register.
+       (reload_out<I12MODE>_aligned): Macro-ize from reload_outqi_help,
+       reload_outhi_help.
+       * config/alpha/alpha-protos.h (alpha_secondary_reload_class): Remove.
+
+2007-04-27  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-forwprop.c (get_prop_dest_stmt): Fix comment typo.
+
+2007-04-27  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/30965
+       PR tree-optimization/30978
+       * Makefile.in (tree-ssa-forwprop.o): Depend on $(FLAGS_H).
+       * tree-ssa-forwprop.c (forward_propagate_into_cond_1): Remove.
+       (find_equivalent_equality_comparison): Likewise.
+       (simplify_cond): Likewise.
+       (get_prop_source_stmt): New helper.
+       (get_prop_dest_stmt): Likewise.
+       (can_propagate_from): Likewise.
+       (remove_prop_source_from_use): Likewise.
+       (combine_cond_expr_cond): Likewise.
+       (forward_propagate_comparison): New function.
+       (forward_propagate_into_cond): Rewrite to use fold for
+       tree combining.
+       (tree_ssa_forward_propagate_single_use_vars): Call
+       forward_propagate_comparison to propagate comparisons.
+
+2007-04-27  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31715
+       * tree-ssa-ccp.c (maybe_fold_offset_to_array_ref): Make
+       sure to do computation on the offset in an appropriate
+       signed type.
+
+2007-04-27  Richard Sandiford  <richard@codesourcery.com>
+
+       * reload.h (elimination_target_reg_p): Declare.
+       * reload.c (find_reloads): Don't apply the reg_rtx move
+       optimization if the SET_DEST satisfies elimination_target_reg_p.
+       * reload1.c (elimination_target_reg_p): New function.
+       (gen_reload): In the move/add2 fallback, make sure that op0
+       does not overlap the destination register.
+
+2007-04-27  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-im.c (determine_invariantness_stmt): Attempt to
+       transform only GIMPLE_MODIFY_STMTs.
+       * tree-complex.c (expand_complex_operations_1): Ditto.
+       (expand_complex_div_wide): Do not create gotos in COND_EXPR branches.
+       * tree-ssa-loop-manip.c (build_if_stmt): Removed.
+       (tree_transform_and_unroll_loop): Do not create gotos in COND_EXPR
+       branches.
+       * value-prof.c (tree_divmod_fixed_value, tree_mod_pow2,
+       tree_mod_subtract, tree_ic, tree_stringop_fixed_value): Ditto.
+       * omp-low.c (expand_parallel_call, expand_omp_for_generic,
+       expand_omp_for_static_chunk, expand_omp_for_static_nochunk): Ditto.
+       * tree-vectorizer.c (slpeel_make_loop_iterate_ntimes,
+       slpeel_add_loop_guard): Ditto.
+       * tree-mudflap.c (mf_build_check_statement_for): Ditto.
+       * lambda-code.c (perfect_nestify): Ditto.
+       * tree-iterator.c (tsi_split_statement_list_before): Fix splitting
+       before the first statement.
+       * tree-optimize.c (execute_free_datastructures): Fix comments.
+       (execute_free_cfg_annotations): Do not call disband_implicit_edges.
+       * tree-flow.h (disband_implicit_edges): Declaration removed.
+       * tree-cfg.c (make_cond_expr_edges): Remove gotos from COND_EXPR
+       branches.
+       (cleanup_dead_labels, tree_redirect_edge_and_branch): Handle
+       COND_EXPRs without gotos.
+       (disband_implicit_edges, has_label_p): Removed.
+       (tree_verify_flow_info): Verify that COND_EXPR branches are empty.
+       (tree_lv_add_condition_to_bb): Do not create gotos in COND_EXPR
+       branches.
+       * tree.c (build3_stat): Mark COND_EXPRs used as statements as having
+       side effects.
+       * tree-pretty-print.c (dump_implicit_edges): Dump implicit edges
+       also for COND_EXPRs.
+       * cfgexpand.c (label_rtx_for_bb): New function.
+       (expand_gimple_cond_expr): Do not expect gotos in COND_EXPR branches.
+       Use label_rtx_for_bb to find the labels.
+       (expand_gimple_basic_block): Remove RETURN_EXPR at the end of the
+       last block.  Detect fallthru edges.
+
+2007-04-26  Ian Lance Taylor  <iant@google.com>
+
+       PR target/28675
+       * reload.c (find_reloads_subreg_address): If the address was valid
+       in the original mode but not in the new mode, reload the whole
+       address.
+
+2007-04-27  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-cfgcleanup.c (cfgcleanup_altered_bbs): New global variable.
+       (remove_fallthru_edge): Use remove_edge_and_dominated_blocks.
+       (cleanup_control_expr_graph): Do not invalidate dominance info.
+       Record altered blocks.
+       (cleanup_control_flow, cleanup_forwarder_blocks): Removed.
+       (cleanup_control_flow_bb, split_bbs_on_noreturn_calls,
+       cleanup_tree_cfg_bb): New functions.
+       (remove_forwarder_block): Do not maintain the worklist of blocks.
+       Record altered blocks.
+       (cleanup_tree_cfg_1): Iterate over cfgcleanup_altered_bbs,
+       not over whole cfg.
+       (cleanup_tree_cfg): Do not iterate cleanup_tree_cfg_1.  Only call
+       delete_unreachable_blocks if dominators are not available.
+       * tree-inline.c (optimize_inline_calls): Free dominance information
+       earlier.
+       * tree-flow.h (remove_edge_and_dominated_blocks,
+       cfgcleanup_altered_bbs): Altered.
+       * tree-cfg.c (replace_uses_by, tree_merge_blocks): Record altered
+       blocks.
+       (get_all_dominated_blocks, remove_edge_and_dominated_blocks): New
+       functions.
+       (tree_purge_dead_eh_edges): Use remove_edge_and_dominated_blocks,
+       do not invalidate dominators.
+
+2007-04-26  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (avr_mcu_types): Add support for ATmega8HVA and
+       ATmega16HVA devices. Move AT90USB82 device to 'avr5' architecture.
+       * config/avr/avr.h (LINK_SPEC, CRT_BINUTILS_SPECS): (Ditto.).
+       * config/avr/t-avr (MULTILIB_MATCHES): (Ditto.).
+
+2007-04-26  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/ia64.md (ip_value): Fix itanium_class attribute.
+
+2007-04-26  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31703
+       * tree-ssa-loop-im.c (rewrite_bittest): Make sure to use
+       the right type for the target of the bittest.
+
+2007-04-26  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/i386/vx-common.h (RETURN_IN_MEMORY): Use
+       ix86_sol10_return_in_memory.
+
+2007-04-26  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/i386/i386.c (ix86_sol10_return_in_memory): Remove unused
+       variables.
+
+2007-04-26  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/31598
+       * tree-inline.c (copy_body_r): Don't touch TREE_TYPE of OMP_CLAUSE.
+
+       PR tree-optimization/30558
+       * tree-eh.c (lower_eh_filter): If EH_FILTER_MUST_NOT_THROW
+       clear this_state.prev_try.
+
+2007-04-26  Richard Sandiford  <richard@codesourcery.com>
+           Mark Mitchell  <mark@codesourcery.com>
+
+       * config/i386/i386-protos.h (ix86_sol10_return_in_memory): Declare.
+       * config/i386/i386.c (ix86_sol10_return_in_memory): New function.
+       * config/i386/sol2-10.h (RETURN_IN_MEMORY): Use it.
+
+2007-04-26  Richard Sandiford  <richard@codesourcery.com>
+
+       PR driver/31107
+       * doc/invoke.texi (%:print-asm-header): Document.
+       * gcc.c (asm_options): Use %:print-asm-header() for --target-help
+       and -ftarget-help.
+       (static_spec_functions): Add print-asm-header.
+       (main): Print a banner before the --target-help linker options.
+       (print_asm_header_spec_function): New function.
+
+2007-04-25  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/31403
+       * config/sh/sh.md (movsi_ie): Fix length for TARGET_SH2A.
+       (movsf_ie): Likewise.
+
+2007-04-25  Paolo Carlini  <pcarlini@suse.de>
+
+       * doc/extend.texi ([Type Traits]): Adjust per N2255.
+
+2007-04-25  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/lib1funcs.asm (__udivsi3, __divsi3): Throw an
+       exception for divide-by-zero.
+       (__umodsi3, __modsi3): Likewise.
+
+2007-04-25  Dirk Mueller  <dmueller@suse.de>
+
+       * c-typeck.c (build_compound_expr): Annotate warning()
+       call with OPT_Wunused_value.
+       * tree-ssa.c (warn_uninit): Annotate warning with
+       OPT_Wunintialized.
+       * c-common.c (handle_sentinel_attribute): Annotate warning
+       call with OPT_Wattributes.
+
+2007-04-25  Thiemo Seufer  <ths@mips.com>
+
+       * config/mips/mips.opt (mdmx, mmt, mno-mdmx): New options.
+       (mips16): Fix typo.
+       * config/mips/mips.h (ASM_SPEC): Pass -mmt/-mno-mt and -mdmx/-mno-mdmx
+       on to the assembler.  Improve handling of -mno-mips16.  Add handling
+       of -mno-mips3d, -mno-dsp, -mno-dspr2.
+       * doc/invoke.texi (MIPS Options): Whitespace cleanup.  Fix wrong use
+       of @itemx.  Document -mno-dsp, -mno-dspr2, -mno-paired-single, -mdmx,
+       -mno-mdmx, -mno-mips3d, -mmt and -mno-mt.
+
+2007-04-25  Danny Smith  <dannysmith.users.sourceforge.net>
+
+       PR target/31680
+       * config/i386/winnt.c (i386_pe_file_end): Strip only
+       USER_LABEL_PREFIX when writing export name.
+
+2007-04-25  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (sh-wrs-vxworks): Don't include dbxelf.h.  Include
+       sh/elf.h, vx-common.h and vxworks.h.
+       * config/sh/sh.h: Include config/vxworks-dummy.h.
+       (SUBTARGET_OVERRIDE_OPTIONS): Define.
+       (OVERRIDE_OPTIONS): Use it.
+       * config/sh/sh.md (GOTaddr2picreg): Add suport for VxWorks RTPs.
+       (vxworks_picreg): New pattern.
+       * config/sh/vxworks.h (TARGET_OS_CPP_BUILTINS): Use
+       VXWORKS_OS_CPP_BUILTINS.
+       (LIB_SPEC, LINK_SPEC, STARTFILE_SPEC, ENDFILE_SPEC): Redefine
+       to their VXWORKS_* equivalents.
+       (SUBTARGET_OVERRIDE_OPTIONS, SUBTARGET_CPP_SPEC): Define.
+       (SUBTARGET_LINK_EMUL_SUFFIX, FUNCTION_PROFILER): Define.
+       * config/sh/lib1funcs.asm (NO_FPSCR_VALUES): Define for VxWorks PIC.
+       (set_fpscr, ic_invalidate): Add VxWorks PIC sequences.
+       * config/sh/t-vxworks (MULTILIB_OPTIONS): Add m4a, -mrtp and
+       -mrtp/-fPIC multilibs.
+       (MULTILIB_EXCEPTIONS): Generalize globs accordingly.
+       (MULTILIB_MATCHES, EXTRA_MULTILIB_PARTS): Define.
+       (MULTILIB_OSDIRNAMES): Delete.
+
+2007-04-25  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/18989
+       * config/avr/avr.h (ASM_OUTPUT_ALIGN): Redefine.
+
+2007-04-24  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * real.c (mpfr_from_real): Handle Inf and NaN, and allow the
+       rounding mode to be specified by the caller.
+       (real_to_mpfr) Likewise.
+       * real.h: Update mpfr_from_real, mpfr_to_real prototypes to
+       include new arguments.
+       * builtins.c: Update mpfr_from_real, mpfr_to_real calls.
+
+2007-04-24  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/31605
+       * tree-vrp.c (set_value_range): Check that min and max are not
+       both overflow infinities.
+       (set_value_range_to_value): New static function.
+       (extract_range_from_binary_expr): Call set_value_range_to_value.
+       (extract_range_from_cond_expr): Likewise.
+       (extract_range_from_expr): Likewise.
+       (extract_range_from_unary_expr): Likewise.  Don't create a range
+       which overflows on both sides.
+       (vrp_meet): Check for a useless range.
+       (vrp_visit_phi_node): If we see a constant which looks like an
+       overflow infinity, turn off the TREE_OVERFLOW flag.
+
+2007-04-24  Ian Lance Taylor  <iant@google.com>
+
+       * flow.c (elim_reg_cond): Handle a comparison of a subreg.
+
+2007-04-24  Simon Martin  <simartin@users.sourceforge.net>
+
+       PR diagnostic/25923
+       * tree-pass.h (TDF_DIAGNOSTIC): New dump control to specify that a
+       diagnostic message is being built.
+       * tree-pretty-print.c (dump_generic_node): Only write the
+       formatted text into BUFFER's stream if we are not building a
+       diagnostic message.
+       * toplev.c (default_tree_printer): Pass TDF_DIAGNOSTIC to
+       dump_generic_node.
+       * Makefile.in (toplev.o): Depend on tree-pass.h.
+
+2007-04-24  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/31602
+       * tree-ssa-loop-ch.c (copy_loop_headers): Set TREE_NO_WARNING for
+       conditionals in the copied loop header.
+       * tree-cfg.c (fold_cond_expr_cond): Don't issue undefined overflow
+       warnings if TREE_NO_WARNING is set.
+       * doc/invoke.texi (Warning Options): Clarify that
+       -Wstrict-overflow does not warn about loops.
+
+2007-04-24  Janis Johnson  <janis187@us.ibm.com>
+
+       * config/rs6000/rs6000.c (function_arg_advance): For 32-bit ELF ABI,
+       expand on the comment about _Decimal128 arguments and check the
+       integer result of the modulus operation; for 64-bit ELF ABI, ensure
+       that _Decimal128 argument uses even/odd register pair.
+       (function_arg): Ditto.
+
+2007-04-24  Hui-May Chang <hm.chang@apple.com>
+
+       * reload1.c (merge_assigned_reloads) : Do not merge a RELOAD_OTHER
+       instruction with a RELOAD_FOR_OPERAND_ADDRESS instruction.
+
+2007-04-24  Richard Guenther  <rguenther@suse.de>
+           Olga Golovanevsky  <olga@il.ibm.com>
+
+       * fold-const.c (multiple_of_p): Check for bottom
+       to be zero.
+
+2007-04-24  Richard Henderson  <rth@redhat.com>
+
+       * libgcc2.h (AVOID_FP_TYPE_CONVERSION): Rename from
+       IS_IBM_EXTENDED.  Also define in terms of WIDEST_HARDWARE_FP_SIZE.
+       * libgcc2.c (__floatdisf): Avoid double-word arithmetic when
+       looking for non-zero bits shifted out.  Avoid a recursive call
+       when constructing the scalar.
+       (__floatundisf): Likewise.
+
+2007-04-24  Nathan Froyd  <froydnj@codesourcery.com>
+
+       * dwarf2out.c (field_byte_offset): Move the existing logic
+       under the control of PCC_BITFIELD_TYPE_MATTERS and just use
+       the bit offset of the field if !PCC_BITFIELD_TYPE_MATTERS.
+
+2007-04-24  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       PR target/31641
+       * config/s390/s390.c (s390_expand_setmem): Don't ICE for constant
+       length argument of 0 for memset.
+       (s390_expand_movmem, s390_expand_setmem, s390_expand_cmpmem): Use
+       unsigned shift instead of the signed variant.
+
+2007-04-24  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md ("*cmp<mode>_ccs_0_ibm", "*cmp<mode>_ccs_ibm",
+       "fix_trunc<BFP:mode><GPR:mode>2_ieee", "fix_truncdfsi2_ibm",
+       "floatsidf2_ibm", "floatsisf2", "truncdfsf2_ieee", "truncdfsf2_ibm",
+       "*trunctfdf2_ieee", "*trunctfdf2_ibm", "*trunctfsf2_ieee",
+       "*trunctfsf2_ibm", "extendsfdf2_ieee", "extendsfdf2_ibm",
+       "*extenddftf2_ieee", "*extenddftf2_ibm", "*extendsftf2_ieee",
+       "*extendsftf2_ibm", "*add<mode>3", "*add<mode>3_ibm", "*sub<mode>3_ibm",
+       "*mul<mode>3", "*mul<mode>3_ibm", "*div<mode>3", "*div<mode>3_ibm",
+       "*neg<mode>2_ibm", "*abs<mode>2_ibm"): Insn definitions removed.
+       ("fix_trunc<BFP:mode><GPR:mode>2_bfp", "floatsi<mode>2",
+       "truncdfsf2", "trunctf<mode>2", "add<mode>3", "sub<mode>3",
+       "mul<mode>3", "div<mode>3"): Insn definitions added.
+       ("fixuns_trunc<BFP:mode><GPR:mode>2", "fix_trunc<mode>di2",
+       "fix_trunc<mode>si2"): gen_fix_trunc<BFP:mode><GPR:mode>2_ieee renamed
+       to gen_fix_trunc<BFP:mode><GPR:mode>2_bfp.
+       ("fix_truncdfsi2", "floatsitf2", "truncdfsf2", "trunctfdf2",
+       "trunctfsf2", "extendsfdf2", "extenddftf2", "extendsftf2", "add<mode>3",
+       "sub<mode>3", "mul<mode>3", "div<mode>3"): Expander removed.
+       ("fix_trunc<mode>si2", "extend<DSF:mode><BFP:mode>2"): Expander added.
+       * config/s390/s390.h (TARGET_IBM_FLOAT, TARGET_IEEE_FLOAT,
+       TARGET_FLOAT_FORMAT): Macro definitions removed.
+       (FP_REGNO_P): No special case for !TARGET_IEEE_FLOAT anymore.
+       * config/s390/s390.c (struct processor_costs, z900_cost, z990_cost,
+       z9_109_cost): Remove fields for hexfloat instructions: dxr, ddr and der.
+       (s390_rtx_costs): Remove !TARGET_IEEE_FLOAT special branches.
+       (s390_gen_rtx_const_DI): Function removed.
+       * config/s390/s390-protos.h (s390_gen_rtx_const_DI): Prototype removed.
+
+2007-04-24  Richard Sandiford  <richard@codesourcery.com>
+
+       * optabs.c (set_conv_libfunc): Prefer libgcc2's __ffsMM2 functions
+       over an external ffs function.
+
+2007-04-24  Chao-ying Fu  <fu@mips.com>
+           Richard Sandiford  <richard@nildram.co.uk>
+
+       * doc/md.texi (madd@var{m}@var{n}4, umadd@var{m}@var{n}4): Document.
+       * optabs.h (OTI_smadd_widen, OTI_umadd_widen): New optab_indexes.
+       (smadd_widen_optab, umadd_widen_optab): Define.
+       * optabs.c (init_optabs): Initialize smadd_widen_optab and
+       umadd_widen_optab.
+       * genopinit.c (optabs): Fill in smadd_widen_optab and
+       umadd_widen_optab.
+       * expr.c (expand_expr_real_1): Try to use smadd_widen_optab
+       and umadd_widen_optab to implement multiply-add sequences.
+       * config/mips/mips.md (*<su>mul_acc_di): Rename to...
+       (<u>maddsidi4): ...this.  Extend condition to include
+       GENERATE_MADD_MSUB and TARGET_DSPR2.  Change the constraint
+       of operand 0 to "ka" and use the three-operand form of madd<u>
+       for TARGET_DSPR2.
+       * config/mips/mips-dspr2.md (mips_madd, mips_maddu): Convert
+       to define_expands.
+       * config/mips/constraints.md (ka): New register constraint.
+
+2007-04-24  Jan Hubicka  <j@suse.cz>
+
+       Revert:
+
+       2007-04-23  Jan Hubicka  <jh@suse.cz>
+       * function.c (init_function_start): Don't init line number info.
+       (expand_function_end): Update.
+       (reset_block_changes, record_block_change, finalize_block_changes,
+       check_block_change, free_block_changes): Kill.
+       * function.h (reset_block_changes, record_block_change,
+       finalize_block_changes, check_block_change, free_block_changes):
+       Remove prototypes.
+       (struct function): Remove ib_boundaries_block.
+       * emit-rtl.c (make_insn_raw, make_jump_insn_raw, make_call_insn_raw):
+       Use curr_insn_locator to initialize locator.
+       (emit_line_note): Remove.
+       * cfgexpand.c (expand_gimple_cond_expr): Update.
+       (construct_exit_block): Likewise.
+       (tree_expand_cfg): Initialize/finalize locators.
+       * expr.c (expand_expr_real): Update.
+       * cfglayout.c (line_locators_locs, line_locators_lines,
+       file_locators_locs, file_locators_files): Remove.
+       (set_block_levels): Move to cfgexpand.c.
+       (insn_locators_initialize): Remove.
+       (pass_insn_locators_initialize): Remove.
+       (locations_locators_locs, locations_locators_vals): New static vars.
+       (curr_location, last_location, curr_block, last_block, curr_rtl_loc):
+       Likewise.
+       (insn_locators_alloc, insn_locators_finalize,
+       set_curr_insn_source_location, set_curr_insn_block, curr_insn_locator):
+       New functions.
+       (locator_location): New.
+       (locator_line, locator_file): Rewrite.
+       * rtl.h (emit_line_note): Kill.
+       (insn_locators_alloc, insn_locators_finalize,
+       set_curr_insn_source_location, set_curr_insn_block, curr_insn_locator):
+       Declare.
+       * tree-inline.c (initialize_cfun): Do not initialize
+       ib_boundaries_block.
+       * passes.c (pass_insn_locators_initialize): Remove.
+
+2007-04-24  Daniel Franke  <franke.daniel@gmail.com>
+
+       * doc/invoke.texi: Removed leading '-' from option index entries.
+
+2007-04-23  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-phinodes.c (reserve_phi_args_for_new_edge, remove_phi_node):
+       Use phi_nodes_ptr.
+       (create_phi_node): Use set_phi_nodes.
+       * omp-low.c (expand_omp_parallel): Use bb_stmt_list.
+       * tree-if-conv.c (process_phi_nodes): Use set_phi_nodes.
+       (combine_blocks): Use bb_stmt_list and set_bb_stmt_list.
+       * tree-flow-inline.h (phi_nodes, set_phi_nodes,
+       (bsi_start, bsi_last): Use bb_stmt_list.
+       (phi_nodes_ptr, bb_stmt_list, set_bb_stmt_list): New functions.
+       * cfgexpand.c (expand_gimple_basic_block): Use bb_stmt_list.
+       Traverse the statements using tsi iterator.
+       * basic-block.h (struct basic_block_def): Fields stmt_list
+       and phi_nodes moved to ...
+       (struct tree_bb_info): ... new structure.
+       * tree-cfg.c (create_bb): Allocate il.tree.  Use set_bb_stmt_list.
+       (tree_merge_blocks): Use bb_stmt_list and set_bb_stmt_list.
+       (remove_bb): Handle blocks with NULL stmt list.  Clear il.tree field.
+       (tree_verify_flow_info): Verify that il.tree is not set for
+       entry and exit block.
+       (tree_split_block): Use set_bb_stmt_list.
+
+2007-04-23  Mike Stump  <mrs@apple.com>
+
+       * config/i386/i386.c (ix86_tune_features
+       [X86_TUNE_DEEP_BRANCH_PREDICTION]: Prefer call over thunks on
+       nocona and core2.
+
+2007-04-23  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.md (prefix_extra): New attribute.
+       (length): Add prefix_extra.
+
+       * onfig/i386/sse.md (sse2_movdqu): Set prefix_data16.
+       (sse2_movntv2di): Likewise.
+       (sse2_cvtps2dq): Likewise.
+       (sse2_cvtpd2pi): Likewise.
+       (sse2_cvttpd2pi): Likewise.
+       (*sse2_cvtpd2ps): Likewise.
+       (*add<mode>3): Likewise.
+       (sse2_ssadd<mode>3): Likewise.
+       (sse2_usadd<mode>3): Likewise.
+       (*sub<mode>3): Likewise.
+       (sse2_sssub<mode>3): Likewise.
+       (sse2_ussub<mode>3): Likewise.
+       (*mulv8hi3): Likewise.
+       (*smulv8hi3_highpart): Likewise.
+       (*umulv8hi3_highpart): Likewise.
+       (sse2_umulv2siv2di3): Likewise.
+       (sse2_pmaddwd): Likewise.
+       (ashr<mode>3): Likewise.
+       (lshr<mode>3): Likewise.
+       (ashl<mode>3): Likewise.
+       (sse2_ashlti3): Likewise.
+       (sse2_lshrti3): Likewise.
+       (*umaxv16qi3): Likewise.
+       (*smaxv8hi3): Likewise.
+       (*uminv16qi3): Likewise.
+       (*sminv8hi3): Likewise.
+       (sse2_eq<mode>3): Likewise.
+       (sse2_gt<mode>3): Likewise.
+       (*and<mode>3): Likewise.
+       (sse2_nand<mode>3): Likewise.
+       (*ior<mode>3): Likewise.
+       (*xor<mode>3): Likewise.
+       (sse2_packsswb): Likewise.
+       (sse2_packssdw): Likewise.
+       (sse2_packuswb): Likewise.
+       (sse2_punpckhbw): Likewise.
+       (sse2_punpcklbw): Likewise.
+       (sse2_punpckhwd): Likewise.
+       (sse2_punpcklwd): Likewise.
+       (sse2_punpckhdq): Likewise.
+       (sse2_punpckldq): Likewise.
+       (sse2_punpckhqdq): Likewise.
+       (sse2_punpcklqdq): Likewise.
+       (*sse2_pinsrw): Likewise.
+       (*sse2_pextrw): Likewise.
+       (sse2_pshufd_1): Likewise.
+       (sse2_uavgv16qi3): Likewise.
+       (sse2_uavgv8hi3): Likewise.
+       (sse2_psadbw): Likewise.
+       (sse2_pmovmskb): Likewise.
+       (*sse2_maskmovdqu): Likewise.
+       (*sse2_maskmovdqu_rex64): Likewise.
+       (sse4a_extrqi): Likewise.
+       (sse4a_extrq): Likewise.
+       (sse3_lddqu): Set prefix_rep.
+       (sse3_addsubv4sf3): Likewise.
+       (sse3_haddv4sf3): Likewise.
+       (sse3_hsubv4sf3): Likewise.
+       (sse_cvtss2si): Likewise.
+       (sse_cvtss2si_2): Likewise.
+       (sse_cvtss2siq): Likewise.
+       (sse_cvtss2siq_2): Likewise.
+       (sse_cvttss2si): Likewise.
+       (sse_cvttss2siq): Likewise.
+       (sse2_cvttps2dq): Likewise.
+       (sse3_movshdup): Likewise.
+       (sse3_movsldup): Likewise.
+       (sse2_cvtsd2si): Likewise.
+       (sse2_cvtsd2si_2): Likewise.
+       (sse2_cvtsd2siq): Likewise.
+       (sse2_cvtsd2siq_2): Likewise.
+       (sse2_cvttsd2si): Likewise.
+       (sse2_cvttsd2siq): Likewise.
+       (*sse2_cvtpd2dq): Likewise.
+       (*sse2_cvttpd2dq): Likewise.
+       (sse2_pshuflw_1): Likewise.
+       (sse2_pshufhw_1): Likewise.
+       (sse4a_insertqi): Likewise.
+       (sse4a_insertq): Likewise.
+       (ssse3_phaddwv8hi3): Set prefix_data16 and prefix_extra.
+       (ssse3_phadddv4si3): Likewise.
+       (ssse3_phaddswv8hi3): Likewise.
+       (ssse3_phsubwv8hi3): Likewise.
+       (ssse3_phsubdv4si3): Likewise.
+       (ssse3_phsubswv8hi3): Likewise.
+       (ssse3_pmaddubswv8hi3): Likewise.
+       (ssse3_pmulhrswv8hi3): Likewise.
+       (ssse3_pshufbv16qi3): Likewise.
+       (ssse3_psign<mode>3): Likewise.
+       (ssse3_palignrti): Likewise.
+       (abs<mode>2): Likewise.
+       (ssse3_phaddwv4hi3): Set prefix_extra.
+       (ssse3_phadddv2si3): Likewise.
+       (ssse3_phaddswv4hi3): Likewise.
+       (ssse3_phsubwv4hi3): Likewise.
+       (ssse3_phsubdv2si3): Likewise.
+       (ssse3_phsubswv4hi3): Likewise.
+       (ssse3_pmaddubswv4hi3): Likewise.
+       (ssse3_pmulhrswv4hi3): Likewise.
+       (ssse3_pshufbv8qi3): Likewise.
+       (ssse3_psign<mode>3): Likewise.
+       (ssse3_palignrdi): Likewise.
+       (abs<mode>2): Likewise.
+       (sse2_cvtdq2ps): Set mode to V4SF instead of V2DF.
+       (*vec_dupv2df): Set mode to V2DF instead of V4SF.
+       (sse2_pmovmskb): Set mode to SI instead of V2DF.
+
+2007-04-23  Nick Clifton  <nickc@redhat.com>
+
+       * params.def: Fix formatting of emacs local variables.
+
+2007-04-23  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/sse.md (sse2_stored): Don't split to inter-unit
+       move if inter-unit move isn't allowed.
+       Don't split moving the first element of V2DI to DI to inter-unit
+       move if inter-unit move isn't allowed.
+
+2007-04-23  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-sink.c (execute_sink_code): Calculate CDI_DOMINATORS
+       and CDI_POST_DOMINATORS separately.
+
+2007-04-23  Nick Clifton  <nickc@redhat.com>
+
+       * c.opt (Wformat-contains-nul): Add warning attribute.
+
+2007-04-23  Jan Hubicka  <jh@suse.cz>
+
+       * function.c (init_function_start): Don't init line number info.
+       (expand_function_end): Update.
+       (reset_block_changes, record_block_change, finalize_block_changes,
+       check_block_change, free_block_changes): Kill.
+       * function.h (reset_block_changes, record_block_change,
+       finalize_block_changes, check_block_change, free_block_changes):
+       Remove prototypes.
+       (struct function): Remove ib_boundaries_block.
+       * emit-rtl.c (make_insn_raw, make_jump_insn_raw, make_call_insn_raw):
+       Use curr_insn_locator to initialize locator.
+       (emit_line_note): Remove.
+       * cfgexpand.c (expand_gimple_cond_expr): Update.
+       (construct_exit_block): Likewise.
+       (tree_expand_cfg): Initialize/finalize locators.
+       * expr.c (expand_expr_real): Update.
+       * cfglayout.c (line_locators_locs, line_locators_lines,
+       file_locators_locs, file_locators_files): Remove.
+       (set_block_levels): Move to cfgexpand.c.
+       (insn_locators_initialize): Remove.
+       (pass_insn_locators_initialize): Remove.
+       (locations_locators_locs, locations_locators_vals): New static vars.
+       (curr_location, last_location, curr_block, last_block, curr_rtl_loc):
+       Likewise.
+       (insn_locators_alloc, insn_locators_finalize,
+       set_curr_insn_source_location, set_curr_insn_block, curr_insn_locator):
+       New functions.
+       (locator_location): New.
+       (locator_line, locator_file): Rewrite.
+       * rtl.h (emit_line_note): Kill.
+       (insn_locators_alloc, insn_locators_finalize,
+       set_curr_insn_source_location, set_curr_insn_block, curr_insn_locator):
+       Declare.
+       * tree-inline.c (initialize_cfun): Do not initialize
+       ib_boundaries_block.
+       * passes.c (pass_insn_locators_initialize): Remove.
+
+2007-04-22  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/31448
+       * expr.c (reduce_to_bit_field_precision): Handle
+       CONST_INT rtx's.
+
+2007-04-22  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/24659
+       * optabs.h (enum optab_index) [OTI_vec_unpacks_hi,
+       OTI_vec_unpacks_lo]: Update comment to mention floating point operands.
+       (vec_pack_trunc_optab): Rename from vec_pack_mod_optab.
+       * genopinit.c (optabs): Rename vec_pack_mod_optab
+       to vec_pack_trunc_optab.
+       * tree-vect-transform.c (vectorizable_type_demotion): Do not fail
+       early for scalar floating point operands for NOP_EXPR.
+       (vectorizable_type_promotion): Ditto.
+       * optabs.c (optab_for_tree_code) [VEC_PACK_TRUNC_EXPR]: Return
+       vec_pack_trunc_optab.
+       (expand_binop): Rename vec_float_trunc_optab to vec_pack_mod_optab.
+
+       * tree.def (VEC_PACK_TRUNC_EXPR): Rename from VEC_PACK_MOD_EXPR.
+       * tree-pretty-print.c (dump_generic_node) [VEC_PACK_TRUNC_EXPR]:
+       Rename from VEC_PACK_MOD_EXPR.
+       (op_prio) [VEC_PACK_TRUNC_EXPR]: Ditto.
+       * expr.c (expand_expr_real_1): Ditto.
+       * tree-inline.c (estimate_num_insns_1): Ditto.
+       * tree-vect-generic.c (expand_vector_operations_1): Ditto.
+
+       * config/i386/sse.md (vec_unpacks_hi_v4sf): New expander.
+       (vec_unpacks_lo_v4sf): Ditto.
+       (vec_pack_trunc_v2df): Ditto.
+       (vec_pack_trunc_v8hi): Rename from vec_pack_mod_v8hi.
+       (vec_pack_trunc_v4si): Rename from vec_pack_mod_v4si.
+       (vec_pack_trunc_v2di): Rename from vec_pack_mod_v2di.
+
+       * config/rs6000/altivec.md (vec_pack_trunc_v8hi): Rename from
+       vec_pack_mod_v8hi.
+       (vec_pack_trunc_v4si): Rename from vec_pack_mod_v4si.
+
+       * doc/c-tree.texi (Expression trees) [VEC_PACK_TRUNC_EXPR]:
+       Rename from VEC_PACK_MOD_EXPR.  This expression also represent
+       packing of floating point operands.
+       [VEC_UNPACK_HI_EXPR, VEC_UNPACK_LO_EXPR]: These expression also
+       represent unpacking of floating point operands.
+       * doc/md.texi (Standard Names) [vec_pack_trunc]: Update documentation.
+       [vec_unpacks_hi]: Ditto.
+       [vec_unpacks_lo]: Ditto.
+
+2007-04-22  Jan Hubicka  <jh@suse.cz>
+
+       * final.c (rest_of_handle_final): Call
+       targetm.asm_out.constructor/targetm.asm_out.destructor
+       * cgraphunit.c (cgraph_build_static_cdtor): Don't do it here; set
+       proper priority via decl_*_priority_insert.
+       * c-common.c (c_expand_body): Likewise.
+
+2007-04-22  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/29789
+       * tree-ssa-loop-im.c (stmt_cost): Adjust cost of shifts.
+       (rewrite_reciprocal): New helper split out from
+       determine_invariantness_stmt.
+       (rewrite_bittest): Likewise.
+       (determine_invariantness_stmt): Rewrite (A >> B) & 1 to
+       A & (1 << B) if (1 << B) is loop invariant but (A >> B)
+       is not.
+
+2007-04-22  Revital Eres  <eres@il.ibm.com>
+
+       * loop-unroll.c (var_to_expand): New field to support also
+       insns of the form x = something + x.
+       (analyze_insn_to_expand_var): Use it.
+       (expand_var_during_unrolling): Likewise.
+
+2007-04-21  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * predict.c: Include pointer-set.h.
+       (bb_predictions): New variable.
+       (tree_predicted_by_p, tree_predict_edge,
+       remove_predictions_associated_with_edge): Use bb_predictions map
+       instead of bb->predictions.
+       (clear_bb_predictions, assert_is_empty): New functions.
+       (combine_predictions_for_bb): Use bb_predictions map.  Call
+       clear_bb_predictions.
+       (tree_estimate_probability): Create and free bb_predictions map.
+       * Makefile.in (predict.o): Add pointer-set.h dependency.
+       * basic-block.h (struct basic_block_def): Remove predictions
+       field.
+       * cfgrtl.c (rtl_verify_flow_info_1): Do not check bb->predictions.
+
+2007-04-21  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/31480
+       * config/sh/sh.md (length): Check if prev_nonnote_insn (insn)
+       is null.
+
+2007-04-21  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * timevar.c (timevar_print): Change reference of --disable-checking to
+       --enable-checking=release.  Also warn if assert checking is disabled.
+
+2007-04-21  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR C/30265
+       * c-gimplifier.c (gimplify_compound_literal_expr): Mark the
+       decl as addressable if the compound literal was marked as
+       addressable.
+       Mark the decl as a gimple register if it is a complex or
+       vector decl and does not live in memory.
+
+2007-04-21  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * tree.h (GIMPLE_TUPLE_P): Also true for PHI_NODEs.
+       (GENERIC_NEXT): New function macro.
+       (PHI_CHAIN): Use phi_node's new chain variable.
+       (tree_phi_node): Change tree_common to tree_base
+       and add the chain field.
+       * tree-phinodes.c (make_phi_node): Don't set
+       TREE_TYPE on the new node.
+       * c-decl.c (lang_tree_node): Use GENERIC_NEXT
+       instead of checking GIMPLE_TUPLE_P in chain_next.
+       * tree-vect-transform.c
+       (get_initial_def_for_induction): Look at
+       PHI_RESULT_TREE for the type of the phi node.
+       (update_vuses_to_preheader): Use PHI_CHAIN
+       instead of TREE_CHAIN on the phi node.
+       * tree-ssa-structalias.c (compute_points_to_sets):
+       Likewise.
+       (ipa_pta_execute): Likewise.
+
+2007-04-21  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/31136
+       * fold-const.c (fold_unary): Call fold_convert_const on the
+       original tree.
+
+2007-04-21  Alexandre Oliva  <aoliva@redhat.com>
+
+       * gcse.c (store_killed_in_insn): Handle PARALLELs.
+       (store_killed_in_pat): New.
+
+2007-04-20  Richard Henderson  <rth@redhat.com>
+
+       PR target/31628
+       * config/i386/i386.c (type_has_variadic_args_p): Look for any
+       TREE_LIST with a void_type_node value, not void_list_node exactly.
+
+2007-04-21  Douglas Gregor  <doug.gregor@gmail.com>
+
+       * doc/standards.texi: Re-arrange into language-specific
+       subsections. Add a C++ section, documenting which standards we
+       support.
+
+2007-04-21  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-structalias.c (delete_points_to_sets): Free graph->complex.
+       * tree-ssa-operands.c (finalize_ssa_vuse_ops): Free new_ops.
+
+2007-04-20  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config/rs6000/sysv4.h (STARTFILE_DEFAULT_SPEC): Include
+       ecrti.o and crtbegin.o.
+       (LIB_DEFAULT_SPEC): Include -lc.
+       (ENDFILE_DEFAULT_SPEC): Include crtend.o and ecrtn.o.
+
+2007-04-20  Richard Henderson  <rth@redhat.com>
+
+       PR target/28623
+       * config/alpha/alpha.c (get_unaligned_address): Remove extra_offset
+       argument; update all callers.
+       (get_unaligned_offset): New.
+       * config/alpha/alpha.md (extendqidi2, extendhidi2): Don't use
+       get_unaligned_address, just pass on the address directly.
+       (unaligned_extendqidi): Use gen_lowpart instead of open-coding
+       the subreg in the helper patterns.
+       (unaligned_extendqidi_le): Use get_unaligned_offset.
+       (unaligned_extendqidi_be, unaligned_extendhidi_le): Likewise.
+       (unaligned_extendhidi_be): Likewise.
+       (unaligned_extendhidi): Tidy.
+       * config/alpha/alpha-protos.h: Update.
+
+2007-04-20  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/alpha.h (CPP_SPEC, CPP_SUBTARGET_SPEC): Remove.
+       (EXTRA_SPECS, SUBTARGET_EXTRA_SPECS): Remove.
+       * config/alpha/linux.h (CPP_SPEC): Undef before redefine.
+       * config/alpha/linux-elf.h (EXTRA_SPECS): Rename SUBTARGET_EXTRA_SPECS.
+       * config/alpha/freebsd.h (EXTRA_SPECS): Rename SUBTARGET_EXTRA_SPECS.
+       (CPP_SPEC): Don't include %(cpp_subtarget).
+       * config/alpha/netbsd.h (CPP_SPEC): Rename CPP_SUBTARGET_SPEC.
+       (EXTRA_SPECS): Rename SUBTARGET_EXTRA_SPECS.
+       * config/alpha/osf.h (CPP_SPEC, EXTRA_SPECS): Similarly.
+
+2007-04-20  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/i386/i386.c (bdesc_2arg): Use ORDERED rather than UNORDERED
+       for __builtin_ia32_cmpordss.
+
+       PR tree-optimization/31632
+       * fold-const.c (fold_binary): Use op0 and op1 instead of arg0
+       and arg1 for optimizations of comparison against min/max values.
+       Fold arg0 to arg1's type for optimizations of comparison against
+       min+1 and max-1 values.
+
+2007-04-19  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * reload.c (combine_reloads): When trying to use a dying register,
+       check whether it's uninitialized and don't use if so.
+
+2007-04-19  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * fold-const.c: Remove prototypes for native_encode_expr and
+       native_interpret_expr.
+       (native_encode_expr): Make non-static.
+       (native_interpret_expr): Likewise.
+       * tree.h: Add prototypes for the above.
+
+2007-04-19  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/rs6000/spe.md (*frob_tf_ti, *frob_ti_tf, *frob_ti_tf_2,
+       *mov_si<mode>_e500_subreg0, *mov_si<mode>_e500_subreg0_2,
+       *mov_sitf_e500_subreg8, *mov_sitf_e500_subreg8_2, spe_extenddftf2,
+       spe_fix_trunctfsi2_internal, spe_negtf2_internal, cmptfeq_gpr,
+       tsttfeq_gpr, cmptfgt_gpr, tsttfgt_gpr, cmptflt_gpr, tsttflt_gpr):
+       Add length attributes.
+
+2007-04-19  Janis Johnson  <janis187@us.ibm.com>
+
+       * ginclude/float.h: Check that __STDC_WANT_DEC_FP__ is defined,
+       not that it is 1.
+
+       * c-cppbuiltin.c (c_cpp_builtins): Remove definition of
+       __STDC_WANT_DEC_FP__.
+
+2007-04-19  Joseph Myers  <joseph@codesourcery.com>
+
+       * configure.ac: Allow both powerpc*-*-linux* and powerpc*-*-gnu*
+       for long double compatibility.
+       * configure: Regenerate.
+
+2007-04-19  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/29841
+       * cfgbuild.c (control_flow_insn_p): Return TRUE for unconditional
+       trap instructions.
+       * sched-deps.c (sched_analyze_insn): Prevent all non-jump instructions
+       that may cause control flow transfer from being moved.
+
+2007-04-18  Jan Hubicka  <jh@suse.cz>
+
+       * fold-const.c (div_if_zero_remainder): Do signed divide for pointer
+       types.
+
+2007-04-18  Eric Christopher  <echristo@apple.com>
+
+       * config/rs6000/darwin.md (load_macho_picbase): Use link register
+       only. Update operands.
+       * config/rs6000/rs6000.c (rs6000_emit_prologue): Update caller.
+       * config/rs6000/rs6000.md (builtin_setjmp_receiver): Ditto. Move from
+       link register to pic register.
+
+2007-04-18  Dirk Mueller  <dmueller@suse.de>
+
+       PR diagnostic/31227
+       * tree-vrp.c (search_for_addr_array): New.
+       (check_array_bounds): Suppress warning about
+       address taken of array refs if its not de-referenced.
+
+2007-04-18  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vectorizer.c (destroy_loop_vec_info): Set loop->aux to NULL.
+       * tree-vect-analyze.c (vect_analyze_loop_form): Set loop->aux.
+
+       * tree-vectorizer.h (NITERS_KNOWN_P): New.
+       * tree-vect-analyze.c (vect_analyze_loop_form): Call NITERS_KNOWN_P
+       instead of LOOP_VINFO_INT_NITERS to avoid having to geneate loop_info.
+
+       * tree-vect-analyze.c (vect_determine_vectorization_factor): Add
+       dump print.
+       (vect_analyze_operations): Fix indenetation.  Fix a comment.  Fix a
+       print message.
+       (vect_analyze_scalar_cycles): Fix indentation.
+       (vect_enhance_data_refs_alignment): Fix check in case of peeling.
+       (vect_mark_relevant): Include phis in relevance analysis.
+
+       * tree-vect-transform.c (vect_transform_loop): Add an assert.
+
+2007-04-18  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (ptrreg_to_str): Replace error() with
+       output_operand_lossage().
+
+2007-04-18  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vect-transform.c (get_initial_def_for_reduction): Clean away
+       the unused code for reduction without adjust-in-epilog to simplify the
+       function.
+
+2007-04-18  Wolfgang Gellerich  <gellerich@de.ibm.com>
+
+       * config/s390/s390.h (S390_TDC_POSITIVE_ZERO): New constant.
+       (S390_TDC_NEGATIVE_ZERO): New constant.
+       (S390_TDC_POSITIVE_NORMALIZED_NUMBER): New constant.
+       (S390_TDC_NEGATIVE_NORMALIZED_NUMBER): New constant.
+       (S390_TDC_POSITIVE_DENORMALIZED_NUMBER): New constant.
+       (S390_TDC_NEGATIVE_DENORMALIZED_NUMBER): New constant.
+       (S390_TDC_POSITIVE_INFINITY): New constant.
+       (S390_TDC_NEGATIVE_INFINITY): New constant.
+       (S390_TDC_POSITIVE_QUIET_NAN): New constant.
+       (S390_TDC_NEGATIVE_QUIET_NAN): New constant.
+       (S390_TDC_POSITIVE_SIGNALING_NAN): New constant.
+       (S390_TDC_NEGATIVE_SIGNALING_NAN): New constant.
+       (S390_TDC_INFINITY): New constant.
+       * config/s390/s390.c (s390_canonicalize_comparison): Renamed
+       UNSPEC_CMPINT to UNSPEC_CCU_TO_INT, added a UNSPEC_CCU_TO_INT-like
+       optimization for UNSPEC_CCZ_TO_INT.
+       * config/s390/s390.md ("*TDC_insn_<mode>"): New insn.
+       ("*ccz_to_int"): New insn.
+       ("isinf<mode>2"): New insn.
+       (UNSPEC_CMPINT): Renamed to UNSPEC_CCU_TO_INT.
+       (UNSPEC_CCU_TO_INT): New constant, replaces UNSPEC_CMPINT.
+       (UNSPEC_CCZ_TO_INT): New constant.
+
+2007-04-18  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/19431
+       PR tree-optimization/21463
+       * tree-pass.h (pass_phiprop): Declare.
+       * passes.c (init_optimization_passes): New phiprop pass.
+       * tree-ssa-forwprop.c (struct phiprop_d): New structure.
+       (phivn_valid_p): New helper function.
+       (phiprop_insert_phi): Likewise.
+       (propagate_with_phi): Likewise.
+       (tree_ssa_phiprop): New propagator propagating loads
+       through phi nodes if profitable.
+
+2007-04-18  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vect-analyze.c (process_use): New function.
+       (vect_mark_stmts_to_be_vectorized): Factor out code to process_use.
+       Check phis in all bbs.
+       * tree-vectorizer.c (vect_is_simple_use): Remove a no longer relavant
+       assert.
+
+2007-04-18  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * reload1.c (eliminte_regs_in_insn): Use REG_EQUIV notes the same way
+       we use REG_EQUAL.
+
+2007-04-17  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/30483
+       * config/avr/avr.c (ptrreg_to_str): Replace gcc_unreachable() with
+       error().
+
+2007-04-17  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/sse.md (sse_vmaddv4sf3): Use register_operand
+       on "0".
+       (sse_vmmulv4sf3): Likewise.
+       (sse2_vmaddv2df3): Likewise.
+       (sse2_vmmulv2df3): Likewise.
+
+2007-04-17  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR rtl-optimization/31360
+       * cfgloopanal.c (target_small_cost, target_pres_cost): Removed.
+       (target_reg_cost): New.
+       (init_set_costs): Initialize target_reg_cost.  Add comments
+       regarding the rationale of the costs.
+       (global_cost_for_size): Renamed to...
+       (estimate_reg_pressure_cost): ... and simplify.  Decrease importance
+       of register pressure.
+       * tree-ssa-loop-ivopts.c (ivopts_global_cost_for_size): Use
+       estimate_reg_pressure_cost.  Add number of ivs.
+       (determine_set_costs): Dump target_reg_cost.
+       * loop-invariant.c (gain_for_invariant): Use
+       estimate_reg_pressure_cost.  Removed n_inv_uses argument.
+       (best_gain_for_invariant, find_invariants_to_move): Remove
+       n_inv_uses.
+       * cfgloop.h (target_small_cost, target_pres_cost): Removed.
+       (target_reg_cost): Declare.
+       (global_cost_for_size): Declaration removed.
+       (estimate_reg_pressure_cost): Declare.
+
+2007-04-17  Peter Bergner  <bergner@vnet.ibm.com>
+
+       * config/rs6000/rs6000.c (rs6000_hard_regno_mode_ok): Force TDmode
+       regnos into even/odd register pairs.
+       * config/rs6000/rs6000.h [SLOW_UNALIGNED_ACCESS]: Treat DDmode and
+       TDmode similar to the other floating point modes.
+       [SECONDARY_MEMORY_NEEDED]: Treat DDmode similar to DFmode.
+       * config/rs6000/dfp.md (negdd2, absdd2, negtd2, abstd2): New
+       define_expand's.
+       (negdd2_fpr, absdd2_fpr, nabsdd2_fpr, negtd2_fpr, abstd2_fpr,
+       nabstd2_fpr, movdd_hardfloat64_mfpgpr): New define_insn's.
+       (movdd_hardfloat64): Use TARGET_MFPGPR.
+
+2007-04-17  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * reload1.c (delete_output_reload): Don't count output in n_inherited.
+
+       Revert
+       2005-01-05  Richard Henderson  <rth@redhat.com>
+       PR rtl-opt/10692
+       * reload1.c (do_input_reload): Restrict the optimization deleteing
+       a previous output reload to RELOAD_FOR_INPUT.
+
+2007-04-17  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vectorizer.h (stmt_vec_info_type): Add enum value
+       induc_vec_info_type.
+       (vectorizable_induction): New function declaration.
+       * tree-vect-transform.c (get_initial_def_for_induction): No need to
+       check if already vectorized.  Find first place in BB where new stmts
+       can be inserted.  Takes only one argument.
+       (vectorizable_induction): New function.
+       (vect_transform_stmt): Add case for induc_vec_info_type to call
+       vectorizable_induction.
+       (vect_transform_loop): Consider phis for vectorization.
+       * tree-vect-analyze.c (vect_determine_vectorization_factor): Simplify
+       condition.
+       (analyze_operations): Call vectorizable_induction when analyzing phis.
+       Fix comment.
+       (vect_mark_stmts_to_be_vectorized): Remove redundant checks.
+       (vect_mark_relevant): Include phis in relevance analysis.
+       (vect_mark_stmts_to_be_vectorize): Likewise.
+       * tree-vect-patterns.c (widened_name_p): Remove obsolete asserts.
+
+2007-04-16  Lawrence Crowl  <crowl@google.com>
+
+       * doc/invoke.texi (Debugging Options): Add documentation for the
+       -femit-struct-debug options -femit-struct-debug-baseonly,
+       -femit-struct-debug-reduced, and
+       -femit-struct-debug-detailed[=...].
+
+       * c-opts.c (c_common_handle_option): Add
+       OPT_femit_struct_debug_baseonly, OPT_femit_struct_debug_reduced,
+       and OPT_femit_struct_debug_detailed_.
+       * c.opt: Add specifications for
+       -femit-struct-debug-baseonly, -femit-struct-debug-reduced,
+       and -femit-struct-debug-detailed[=...].
+       * opts.c (set_struct_debug_option): Parse the
+       -femit-struct-debug-... options.
+       * opts.c (matches_main_base, main_input_basename,
+       main_input_baselength, base_of_path, matches_main_base): Add
+       variables and functions to compare header base name to compilation
+       unit base name.
+       * opts.c (should_emit_struct_debug): Add to determine to emit a
+       structure based on the option.
+       (dump_struct_debug) Also disabled function to debug this
+       function.
+       * opts.c (handle_options): Save the base name of the
+       compilation unit.
+
+       * langhooks-def.h (LANG_HOOKS_GENERIC_TYPE_P): Define.
+       (LANG_HOOKS_FOR_TYPES_INITIALIZER): Add.
+       This hook indicates if a type is generic.  Set it by default
+       to "never generic".
+       * langhooks.h (struct lang_hooks_for_types): Add a new hook
+       to determine if a struct type is generic or not.
+       * cp/cp-tree.h (class_tmpl_impl_spec_p): Declare a C++ hook.
+       * cp/tree.c (class_tmpl_impl_spec_p): Implement the C++ hook.
+       * cp/cp-lang.c (LANG_HOOKS_GENERIC_TYPE_P): Override null C hook
+       with live C++ hook.
+
+       * flags.h (enum debug_info_usage): Add an enumeration to describe
+       a program's use of a structure type.
+       * dwarf2out.c (gen_struct_or_union_type_die): Add a new parameter
+       to indicate the program's usage of the type.  Filter structs based
+       on the -femit-struct-debug-... specification.
+       (gen_type_die): Split into two routines, gen_type_die and
+       gen_type_die_with_usage.  gen_type_die is now a wrapper
+       that assumes direct usage.
+       (gen_type_die_with_usage): Replace calls to gen_type_die
+       with gen_type_die_with_usage adding the program usage of
+       the referenced type.
+       (dwarf2out_imported_module_or_decl): Suppress struct debug
+       information using should_emit_struct_debug when appropriate.
+
+2007-04-16  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/31522
+       * tree-vrp.c (vr_phi_edge_counts): New static variable.
+       (vrp_initialize): Allocate vr_phi_edge_counts.
+       (vrp_visit_phi_node): Don't push to infinity if we saw a new
+       executable edge.  Drop test for all constants.
+       (vrp_finalize): Free vrp_phi_edge_counts.
+
+       * doc/cpp.texi (Common Predefined Macros): Clarify description of
+       __GNUC_GNU_INLINE__ and __GNUC_STDC_INLINE__.
+
+       * tree-ssa-propagate.c (cfg_blocks_add): Insert blocks with fewer
+       predecessors at head rather than tail.
+
+2007-04-16  Matthias Klose  <doko@debian.org>
+
+       * config/alpha/linux.h (CPP_SPEC): Define.
+       * config/arm/linux-gas.h (SUBTARGET_CPP_SPEC): Extend.
+
+2007-04-16  Aldy Hernandez  <aldyh@redhat.com>
+
+       * function.h: Remove sequence_stack extern declaration.
+
+2007-04-16  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.h (LONG_DOUBLE_TYPE_SIZE): Change to 64 on
+       TARGET_FIDOA.
+       (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Change to 64 if __mfido__ is
+       defined.
+
+2007-04-16  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (avr_arch_types): Rearranging  array.
+       (enum avr_arch): Add.
+       (avr_mcu_types): Use avr_arch enumeration constants instead of
+       numbers.
+       * config/avr/avr.h (LINK_SPEC): Simplify.
+
+2007-04-16  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_libcall_value,
+       m68k_function_value): Use macros for register names more.
+
+       * config/m68k/m68k.h (FRAME_POINTER_REGNUM): Use A6_REG
+       instead.
+       (M68K_REGNAME): Use A6_REG.
+       * config/m68k/m68k.md (FP_REG): Rename to A6_REG.
+
+2007-04-16  Maxim Kuvyrkov  <mkuvyrkov@ispras.ru>
+
+       PR middle-end/28071
+       * sched-int.h (struct deps): Split field 'pending_lists_length' into
+       'pending_read_list_length' and 'pending_write_list_length'.  Update
+       comment.
+       * sched-deps.c (add_insn_mem_dependence): Change signature.  Update
+       to handle two length counters instead of one.  Update all uses.
+       (flush_pending_lists, sched_analyze_1, init_deps): Update to handle
+       two length counters instead of one.
+       * sched-rgn.c (propagate_deps): Update to handle two length counters
+       instead of one.
+
+2007-04-16  H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/31582
+       * config/i386/i386.c (ix86_expand_vec_set_builtin): Make a
+       copy of source, pass it to ix86_expand_vector_set and return
+       it as target.
+
+2007-04-16  David Ung  <davidu@mips.com>
+           Joseph Myers  <joseph@codesourcery.com>
+
+       * config/mips/mips.h (PROCESSOR_74KC, PROCESSOR_74KF,
+       PROCESSOR_74KX, TUNE_74K, GENERATE_MADD_MSUB): Define.
+       * config/mips/mips.c (mips_cpu_info_table, mips_rtx_cost_data):
+       Add 74K processor information.
+       * config/mips/mips.md: Include 74k.md.
+       (cpu): Add 74kc,74kf,74kx.
+       (ISA_HAS_MADD_MSUB): Change to GENERATE_MADD_MSUB throughout.
+       * config/mips/74k.md: New.
+       * doc/invoke.texi (MIPS Options): Document 74K support.
+
+2007-04-16  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vect-analyze.c (vect_analyze_operations): Reorganize calls to
+       vectorizable_* functions.
+       * tree-vect-transform.c (vectorizable_call): Add check for
+       STMT_VINFO_RELEVANT_P, STMT_VINFO_DEF_TYPE and STMT_VINFO_LIVE_P.
+       (vectorizable_store): likewise.
+       (vectorizable_conversion): Add check for STMT_VINFO_DEF_TYPE.
+       Add comments.
+       (vectorizable_operation, vectorizable_type_demotion): Likewise.
+       (vectorizable_type_promotion, vectorizable_load): Likewise.
+       (vectorizable_live_operation, vectorizable_condition): Likewise.
+       (vectorizable_assignment): Add check for STMT_VINFO_DEF_TYPE and
+       STMT_VINFO_LIVE_P.
+       (vect_transform_stmt): Reorganize calls to vectorizable_* functions.
+
+2007-04-15  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/linux.h (FUNCTION_VALUE_REGNO_P): Use macros for
+       register numbers more.
+       * config/m68k/m68k.h (STACK_POINTER_REGNUM,
+       FRAME_POINTER_REGNUM, STATIC_CHAIN_REGNUM,
+       M68K_STRUCT_VALUE_REGNUM, FUNCTION_VALUE, LIBCALL_VALUE,
+       FUNCTION_VALUE_REGNO_P): Likewise.
+       * config/m68k/m68kelf.h (M68K_STRUCT_VALUE_REGNUM,
+       STATIC_CHAIN_REGNUM): Likewise.
+       * config/m68k/m68kemb.h (FUNCTION_VALUE_REGNO_P): Likewise.
+       * config/m68k/netbsd-elf.h (M68K_STRUCT_VALUE_REGNUM,
+       STATIC_CHAIN_REGNUM, FUNCTION_VALUE_REGNO_P): Likewise.
+       * config/m68k/m68k.md (FP_REG): New.
+
+2007-04-15  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.h (PREFERRED_STACK_BOUNDARY): Prefer 32-bit
+       alignment on fido.
+
+2007-04-15  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/i386/i386.c, config/s390/s390.c, config/s390/s390.md,
+       tree-ssa-loop-niter.c, tree-ssa-structalias.c, tree-vrp.c: Fix
+       comment typos.
+
+2007-04-11  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-prefetch.c (loop_prefetch_arrays): Ignore
+       cold loops.
+
+2007-04-14  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR c/31520
+       * c-decl.c (finish_decl): Grab the type of the decl after the call
+       to store_init_value.
+
+2007-04-14  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * common.opt (fforward-propagate): Fix "Optimization" annotation.
+
+2007-04-14  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/25874
+       * omp-low.c (expand_omp_parallel): If child_cfun->cfg, free
+       dominators, post dominators and cleanup cfg before returning.
+
+2007-04-14  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.h (MODES_TIEABLE_P): Allow more modes to be tied.
+       * config/bfin/bfin.md (movsi_insn): Delete two unused alternatives.
+
+2007-04-14  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config.gcc: Recognize fido.
+       * config/m68k/m68k-devices.def (fidoa): New.
+       * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Define
+       __mfido__.
+       (FL_FIDOA, TARGET_FIDOA): New.
+       * config/m68k/m68k.opt (mfidoa): New.
+
+2007-04-13  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR middle-end/31322
+       * dwarf2out.c (output_call_frame_info): Call assemble_external_libcall
+       when a personality function is used.
+
+2007-04-13  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (xtensa_expand_builtin): Use CALL_EXPR_FN.
+
+2007-04-13  Mike Stump  <mrs@apple.com>
+
+       * config/darwin-c.c (handle_c_option): Handle -fapple-kext here so
+       we can...
+       * config/darwin.opt (fapple-kext): Make C++ only.
+       * config/darwin.c (darwin_override_options): Remove code to ensure
+       -fapple-kext is given for C++ only.
+
+2007-04-13  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/vxworks.h (SUBTARGET_OVERRIDE_OPTIONS): Define.
+       * config/mips/mips.c (override_options): Call
+       SUBTARGET_OVERRIDE_OPTIONS, if defined.
+
+2007-04-13  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.opt (msvr3-shlib): Removed.
+
+       * doc/invoke.texi: Remove -msvr3-shlib.
+
+2007-04-13  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.opt (mpopcnt): Replace "popcount" instruction
+       with "popcnt" instruction.
+
+2007-04-13  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/21258
+       * tree-vrp.c (compare_case_labels): New helper.
+       (find_switch_asserts): New function.
+       (find_assert_locations): Call it for SWITCH_EXPRs.
+
+2007-04-13  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (X87_FLOAT_MODE_P): Check for TARGET_80387.
+       * config/i386/i386.md (*cmpfp0): Remove check for TARGET_80387, this
+       check is now implied in X87_FLOAT_MODE_P.
+       (*cmpfp_u, *cmpfp_<mode>, *cmpfp_i_i387): Ditto.
+       (*cmpfp_iu_387, fix_trunc<mode>_fisttp_i386_1): Ditto.
+       (fix_trunc<mode>_i386_fisttp): Ditto.
+       (fix_trunc<mode>_i387_fisttp_with_temp): Ditto.
+       (*fix_trunc<mode>_i387_1, fix_truncdi_i387): Ditto.
+       (fix_truncdi_i387_with_temp, fix_trunc<mode>_i387): Ditto.
+       (fix_trunc<mode>_i387_with_temp, *fp_jcc_1_387): Ditto.
+       (*fp_jcc_2_387, *fp_jcc_5_387, *fp_jcc_6_387): Ditto.
+       (*fp_jcc_7_387, *fp_jcc_8<mode>_387): Ditto.
+       (unnamed_splitters): Ditto.
+       * config/i386/i386.c (function_value_32): Generate FIRST_FLOAT_REG
+       for X87_FLOAT_MODE_P mode.  Override FIRST_FLOAT_REG with
+       FIRST_SSE_REG for local functions when SSE math is enabled or
+       for functions with sseregparm attribute.
+       (standard_80387_constant_p): Return -1 if mode is not
+       X87_FLOAT_MODE_P.
+       (ix86_cc_mode): Assert that scalar mode is not DECIMAL_FLOAT_MODE_P.
+       (ix86_expand_compare): Ditto.
+       (ix86_expand_carry_flag_compare): Ditto.
+       (ix86_expand_int_movcc): Check for SCALAR_FLOAT_MODE_P instead
+       of FLOAT_MODE_P for cmp_mode and assert that cmp_mode is not
+       DECIMAL_FLOAT_MODE_P.
+       (ix86_preferred_output_reload_class): Use X87_FLOAT_MODE_P instead
+       of SCALAR_FLOAT_MODE_P.
+       (ix86_rtx_costs) [PLUS] Remove FLOAT_MODE_P and fall through to ...
+       [MINUS]: ... here.  Add SSE_FLOAT_MODE_P and X87_FLOAT_MODE_P
+       checks before FLOAT_MODE_P.
+       [MULT]: Add SSE_FLOAT_MODE_P and X87_FLOAT_MODE_P checks
+       before FLOAT_MODE_P.
+       [DIV]: Ditto.
+       [NEG]: Ditto.
+       [ABS]: Ditto.
+       [SQRT]: Ditto.
+       [FLOAT_EXTEND]: Use SSE_FLOAT_MODE_P.
+
+2007-04-12  Paolo Bonzini  <bonzini@gnu.org>
+           Charles Wilson  <libtool@cwilson.fastmail.fm>
+
+       * Makefile.in (stamp-as, stamp-collect-ld, stamp-nm): Remove.
+       (libgcc.mvars): Don't depend on them.
+       * configure.ac (as, collect-ld, nm): Create from exec-tool.in.
+       * exec-tool.in: New.
+
+2007-04-12  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * doc/invoke.text (--help): Document --help=common.
+
+2007-04-12  Thomas Neumann  <tneumann@users.sourceforge.net>
+
+       * stub-objc.c (objc_build_keyword_decl): Avoid C++ keywords.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * Makefile.in (insn-emit.o): Depend on $(INTEGRATE_H).
+       * genemit.c (main): Emit #include "integrate.h".
+       * config/mips/mips-protos.h (SYMBOL_HALF): New mips_symbol_type.
+       (LOADGP_RTP): New mips_loadgp_style.
+       * config/mips/mips.h: Include config/vxworks-dummy.h.
+       (TARGET_RTP_PIC): New macro.
+       (TARGET_USE_GOT): Return true for TARGET_RTP_PIC.
+       (TARGET_USE_PIC_FN_ADDR_REG): Return true for TARGET_VXWORKS_RTP.
+       (ASM_OUTPUT_ADDR_DIFF_ELT): Emit function-relative case tables
+       for TARGET_RTP_PIC.
+       * config/mips/vxworks.h (SUBTARGET_ASM_SPEC): Define.  Pass down
+       -mvxworks-pic when using -mrtp and a PIC option.
+       * config/mips/mips.c (mips_classify_symbol): Return SYMBOL_GOT_DISP
+       for RTP PIC.
+       (mips_symbolic_constant_p, mips_symbolic_address_p)
+       (mips_symbol_insns): Handle SYMBOL_HALF.
+       (override_options): Warn about -G and -mrtp being used together.
+       Initialize mips_lo_relocs[SYMBOL_HALF].
+       (mips_current_loadgp_style): Return LOADGP_RTP for RTP PIC.
+       (mips_emit_loadgp): Handle LOADGP_RTP.
+       (mips_in_small_data_p): Return false for TARGET_VXWORKS_RTP.
+       * config/mips/mips.md (loadgp_rtp): New insn and splitter.
+       (tablejump): Handle function-relative case table entries if
+       TARGET_RTP_PIC.
+       * config/mips/predicates.md (symbol_ref_operand): New predicate.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.md (load_call<mode>): Allow any general register.
+       destination.
+       (sibcall_value_internal, sibcall_value_multiple_internal)
+       (call_value_internal, call_value_split, call_value_multiple_internal)
+       (call_value_multiple_split): Remove constraints from operand 0.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h: In comments, refer to loadgp_absolute
+       rather than loadgp_noshared.
+       * config/mips/mips.c (mips_emit_loadgp): Use gen_loadgp_absolute
+       instead of gen_loadgp_noshared.  Use gen_loadgp_newabi instead of
+       gen_loadgp.
+       * config/mips/mips.md (loadgp): Rename to...
+       (loadgp_newabi): ...this.
+       (loadgp_noshared): Rename to...
+       (loadgp_absolute): ...this.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.c (mips_ok_for_lazy_binding_p): Always return
+       false for locally-binding symbols.
+       (mips_dangerous_for_la25_p): Check mips_global_symbol_p.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips-protos.h (SYMBOL_GOT_LOCAL): Rename to...
+       (SYMBOL_GOT_PAGE_OFST): ...this.
+       (SYMBOL_GOT_GLOBAL): Rename to...
+       (SYMBOL_GOT_DISP): ...this.
+       (SYMBOL_GOTOFF_GLOBAL): Rename to...
+       (SYMBOL_GOTOFF_DISP): ...this.  Update comments accordingly.
+       * config/mips/mips.c (mips_global_symbol_p): New function.
+       (mips_symbol_binds_local_p): Likewise.
+       (mips_classify_symbol): Rename SYMBOL_GOT_GLOBAL to SYMBOL_GOT_DISP
+       and SYMBOL_GOT_LOCAL to SYMBOL_GOT_PAGE_OFST.  Use
+       mips_global_symbol_p and mips_symbol_binds_local_p.
+       (mips_symbolic_constant_p, mips_symbolic_address_p, mips_symbol_insns)
+       (override_options): Rename SYMBOL_GOT_GLOBAL to SYMBOL_GOT_DISP,
+       SYMBOL_GOT_LOCAL to SYMBOL_GOT_PAGE_OFST and SYMBOL_GOTOFF_GLOBAL to
+       SYMBOL_GOTOFF_DISP.
+       (mips_ok_for_lazy_binding_p): New function.
+       (mips_load_call_address, mips_expand_call): Use it.
+       (mips_dangerous_for_la25_p): Likewise.
+       * config/mips/mips.md (*xgot_hi<mode>, *xgot_lo<mode>)
+       (*got_disp<mode>): Use got_disp_operand instead of
+       global_got_operand.  Use SYMBOL_GOTOFF_DISP instead of
+       SYMBOL_GOTOFF_GLOBAL.
+       (*got_page<mode>): Use got_page_ofst_operand instead of
+       local_got_operand.
+       * config/mips/predicates.md (const_call_insn_operand): Use
+       SYMBOL_GOT_DISP instead of SYMBOL_GOT_GLOBAL.
+       (global_got_operand): Rename to...
+       (got_disp_operand): ...this and use SYMBOL_GOT_DISP instead of
+       SYMBOL_GOT_GLOBAL.
+       (local_got_operand): Rename to...
+       (got_page_ofst_operand): ...this and use SYMBOL_GOT_PAGE_OFST instead
+       of SYMBOL_GOT_LOCAL.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/mips/mips.h (TARGET_SPLIT_CALLS): Check
+       TARGET_CALL_CLOBBERED_GP.
+       (TARGET_SIBCALLS): Check TARGET_USE_GOT instead of TARGET_ABICALLS.
+       (TARGET_USE_GOT, TARGET_CALL_CLOBBERED_GP): New macros.
+       (TARGET_CALL_SAVED_GP, TARGET_USE_PIC_FN_ADDR_REG): Likewise.
+       (STARTING_FRAME_OFFSET): Check TARGET_CALL_CLOBBERED_GP instead
+       of TARGET_ABICALLS && !TARGET_NEWABI.
+       (MIPS_CALL): Check TARGET_USE_GOT instead of TARGET_ABICALLS.
+       * config/mips/mips.c (mips_load_call_address): Check
+       TARGET_CALL_SAVED_GP instead of TARGET_NEWABI.
+       (mips_global_pointer): Check TARGET_USE_GOT instead of TARGET_ABICALLS.
+       Check TARGET_CALL_SAVED_GP instead of TARGET_NEWABI.
+       (mips_save_reg_p): Check TARGET_CALL_SAVED_GP instead of
+       TARGET_ABICALLS && TARGET_NEWABI.
+       (mips_current_loadgp_style): Check TARGET_USE_GOT instead of
+       TARGET_ABICALLS.
+       (mips_expand_prologue): Check TARGET_OLDABI instead of !TARGET_NEWABI.
+       (mips_expand_epilogue): Check TARGET_CALL_SAVED_GP instead of
+       TARGET_ABICALLS && TARGET_NEWABI.
+       (mips_output_mi_thunk): Check TARGET_USE_GOT instead of
+       TARGET_ABICALLS.  Check TARGET_CALL_SAVED_GP instead of
+       TARGET_NEWABI.  Use TARGET_USE_PIC_FN_ADDR_REG to decide
+       whether indirect calls must use $25.
+       (mips_extra_live_on_entry): Check TARGET_GOT instead of
+       TARGET_ABICALLS.
+       * config/mips/mips.md (jal_macro): Check flag_pic and
+       TARGET_CALL_CLOBBERED_GP instead of TARGET_ABICALLS and TARGET_NEWABI.
+       (builtin_setjmp_setup, builtin_longjmp): Check TARGET_USE_GOT
+       instead of TARGET_ABICALLS.
+       (exception_receiver): Check TARGET_CALL_CLOBBERED_GP instead of
+       TARGET_ABICALLS && TARGET_OLDABI.
+       (load_call<mode>): Check TARGET_USE_GOT instead of TARGET_ABICALLS.
+       (sibcall): In the comment above the define_insn, mention
+       TARGET_USE_PIC_FN_ADDR_REG instead of TARGET_ABICALLS.
+       * config/mips/constraints.md (c): Check TARGET_USE_PIC_FN_ADDR_REG
+       instead of TARGET_ABICALLS.
+
+2007-04-12  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * doc/md.texi (Blackfin family constraints): Document PA and PB.
+       * config/bfin/bfin.h (CONST_OK_FOR_P): Handle PA and PB.
+       (MACFLAGS_MATCH_P): New macro.
+       * config/bfin/bfin.c (print_operand): Handle MACFLAG_IS_M.
+       (bfin_secondary_reload): Treat EVEN_AREGS and ODD_AREGS like AREGS.
+       * config/bfin/bfin.md (MACFLAG_IS_M): New constant.  Renumber some of
+       the other MACFLAG constants.
+       (sum_of_accumulators, lshrpdi3, ashrpdi3): New patterns.
+       (flag_machi): Tighten constraints.  Renumber some of the operands.
+       (flag_machi_acconly): Tighten constraints.  Correct operand numbers in
+       output template.
+       (flag_machi_parts_acconly): New pattern.
+       (flag_macinithi): Tighten constraints.  Allow any accumulator to be
+       used.
+       (flag_macinit1hi): Tighten constraints.
+       (flag_mul_macv2hi_parts_acconly): New pattern.
+
+       * config/bfin/lib1funcs.asm (___umulsi3_highpart, __smulsi3_highpart):
+       Use a more efficient implementation.
+       * config/bfin/bfin.md (umulsi3_highpart, smulsi3_highpart): Emit
+       inline sequences when not optimizing for size.
+
+       * config/bfin/bfin.md (movhi_low2high, movhi_high2high, movhi_low2low,
+       movhi_high2low): Delete, merge functionality into...
+       (packv2hi): ... this pattern.
+
+       2007-02-11  Jie Zhang  <jie.zhang@analog.com>
+       * config/bfin/bfin.opt (msim): New option.
+       (mcpu=): New option.
+       * config/bfin/bfin-protos.h (enum bfin_cpu): New.
+       (bfin_cpu_t): Typedef of enum bfin_cpu.
+       (bfin_cpu_type): New declaration.
+       * config/bfin/elf.h (STARTFILE_SPEC): Add support for
+       -msim and -mcpu= options.
+       (LIB_SPEC): Likewise.
+       * config/bfin/bfin.c (bfin_cpu_type): Define.
+       (bfin_handle_option): Handle -mcpu= option.
+       * config/bfin/bfin.h (DEFAULT_CPU_TYPE): Define as BFIN_CPU_BF532.
+       (TARGET_CPU_CPP_BUILTINS): Define __ADSPBF531__, __ADSPBF532__,
+       __ADSPBF533__ or __ADSPBF537__ according to the cpu type.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (*-*-vxworks*): Don't add to tm_files in this stanza.
+       (arm-wrs-vxworks, mips-wrs-vxworks, powerpc-wrs-vxworks)
+       (powerpc-wrs-vxworksae): Use ${tm_file}.
+       (i[4567]86-wrs-vxworks, i[4567]86-wrs-vxworksae): Add svr4.h
+       after elfos.h.  Remove i386/sysv4.h and add i386/vx-common.h.
+       * config/i386/vx-common.h: New file.
+
+2007-04-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/vxworks.h (VXWORKS_STARTFILE_SPEC): Use -l:crt0.o instead
+       of crt0.o%s.
+
+2007-04-12  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md ("trunctddd2"): Use TDmode for the target of
+       ldxtr.
+
+2007-04-12  Douglas Gregor  <doug.gregor@gmail.com>
+
+       PR c++/31078
+       PR c++/31103
+       * c-common.c (c_build_qualified_type): Set canonical type
+       appropriately.
+
+2007-04-12  Richard Guenther  <rguenther@suse.de>
+
+       * tree-pretty-print.c (dump_generic_node): Print ARRAY_REF
+       lower bound and element size if lower bound is not zero
+       or either of the ARRAY_REF operands is set.
+
+2007-04-12  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/24689
+       PR tree-optimization/31307
+       * fold-const.c (operand_equal_p): Compare INTEGER_CST array
+       indices by value.
+       * gimplify.c (canonicalize_addr_expr): To be consistent with
+       gimplify_compound_lval only set operands two and three of
+       ARRAY_REFs if they are not gimple_min_invariant.  This makes
+       it never at this place.
+       * tree-ssa-ccp.c (maybe_fold_offset_to_array_ref): Likewise.
+
+2007-04-11  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.c (pa_som_asm_init_sections): Ensure that cfun->machine is not
+       null before emitting a .nsubspa directive.
+
+2007-04-11  Diego Novillo  <dnovillo@redhat.com>
+
+       * tree-ssa-alias.c (dump_mem_ref_stats): Do not call
+       need_to_partition_p if there are no memory statements in the
+       function.
+
+2007-04-11  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-data-ref.c (chrec_steps_divide_constant_p): Removed.
+       (gcd_of_steps_may_divide_p): New function.
+       (analyze_miv_subscript): Use gcd_of_steps_may_divide_p.
+
+2007-04-11  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * reload.c (find_reloads_toplev, find_reloads_address,
+       find_reloads_address_1, find_reloads_subreg_address): Use rtx_equal_p,
+       not a pointer equality test, to decide if we need to call
+       push_reg_equiv_alt_mem.
+
+2007-04-11  Sebastian Pop  <sebastian.pop@inria.fr>
+
+       * tree-data-ref.c (affine_function_zero_p, constant_access_functions,
+       insert_innermost_unit_dist_vector, add_distance_for_zero_overlaps):
+       New.
+       (build_classic_dist_vector): Call add_distance_for_zero_overlaps.
+
+2007-04-11  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-data-ref.c (add_multivariate_self_dist): Force the distance
+       vector to be positive.
+
+2007-04-11  Diego Novillo  <dnovillo@redhat.com>
+
+       PR 30735
+       PR 31090
+       * doc/invoke.texi: Document --params max-aliased-vops and
+       avg-aliased-vops.
+       * tree-ssa-operands.h (get_mpt_for, dump_memory_partitions,
+       debug_memory_partitions): Move to tree-flow.h
+       * params.h (AVG_ALIASED_VOPS): Define.
+       * tree-ssa-alias.c (struct mp_info_def): Remove.  Update all
+       users.
+       (mp_info_t): Likewise.
+       (get_mem_sym_stats_for): New.
+       (set_memory_partition): Move from tree-flow-inline.h.
+       (mark_non_addressable): Only clear the set of symbols for the
+       partition if it exists.
+       (dump_memory_partitions): Move from tree-ssa-operands.c
+       (debug_memory_partitions): Likewise.
+       (need_to_partition_p): New.
+       (dump_mem_ref_stats): New.
+       (debug_mem_ref_stats): New.
+       (dump_mem_sym_stats): New.
+       (debug_mem_sym_stats): New.
+       (update_mem_sym_stats_from_stmt): New.
+       (compare_mp_info_entries): New.
+       (mp_info_cmp): Call it.
+       (sort_mp_info): Change argument to a list of mem_sym_stats_t
+       objects.
+       (get_mpt_for): Move from tree-ssa-operands.c.
+       (find_partition_for): New.
+       (create_partition_for): Remove.
+       (estimate_vop_reduction): New.
+       (update_reference_counts): New.
+       (build_mp_info): New.
+       (compute_memory_partitions): Refactor.
+       Document new heuristic.
+       Call build_mp_info, update_reference_counts,
+       find_partition_for and estimate_vop_reduction.
+       (compute_may_aliases): Populate virtual operands before
+       calling debugging dumps.
+       (delete_mem_sym_stats): New.
+       (delete_mem_ref_stats): New.
+       (init_mem_ref_stats): New.
+       (init_alias_info): Call it.
+       (maybe_create_global_var): Remove alias_info argument.
+       Get number of call sites and number of pure/const call sites
+       from gimple_mem_ref_stats().
+       (dump_alias_info): Call dump_memory_partitions first.
+       (dump_points_to_info_for): Show how many times a pointer has
+       been dereferenced.
+       * opts.c (decode_options): For -O2 set --param
+       max-aliased-vops to 500.
+       For -O3 set --param max-aliased-vops to 1000 and --param
+       avg-aliased-vops to 3.
+       * fortran/options.c (gfc_init_options): Remove assignment to
+       MAX_ALIASED_VOPS.
+       * tree-flow-inline.h (gimple_mem_ref_stats): New.
+       * tree-dfa.c (dump_variable): Dump memory reference
+       statistics.
+       Dump NO_ALIAS* settings.
+       (referenced_var_lookup): Tidy.
+       (mem_sym_stats): New.
+       * tree-ssa-copy.c (may_propagate_copy): Return true if DEST
+       and ORIG are different SSA names for a memory partition.
+       * tree-ssa.c (delete_tree_ssa): Call delete_mem_ref_stats.
+       * tree-flow.h (struct mem_sym_stats_d): Define.
+       (mem_sym_stats_t): Define.
+       (struct mem_ref_stats_d): Define.
+       (struct gimple_df): Add field mem_ref_stats.
+       (enum noalias_state): Define.
+       (struct var_ann_d): Add bitfield noalias_state.
+       (mem_sym_stats, delete_mem_ref_stats, dump_mem_ref_stats,
+       debug_mem_ref_stats, debug_memory_partitions,
+       debug_mem_sym_stats): Declare.
+       * tree-ssa-structalias.c (update_alias_info): Update call
+       sites, pure/const call sites and asm sites in structure
+       returned by gimple_mem_ref_stats.
+       Remove local variable IS_POTENTIAL_DEREF.
+       Increase NUM_DEREFS if the memory expression is a potential
+       dereference.
+       Call update_mem_sym_stats_from_stmt.
+       If the memory references memory, call
+       update_mem_sym_stats_from_stmt for all the direct memory
+       symbol references found.
+       (intra_create_variable_infos): Set noalias_state field for
+       pointer arguments according to the value of
+       flag_argument_noalias.
+       * tree-ssa-structalias.h (struct alias_info): Remove fields
+       num_calls_found and num_pure_const_calls_found.
+       (update_mem_sym_stats_from_stmt): Declare.
+       * params.def (PARAM_MAX_ALIASED_VOPS): Change description.
+       Set default value to 100.
+       (PARAM_AVG_ALIASED_VOPS): Define.
+
+2007-04-11  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/31530
+       * simplify-rtx.c (simplify_binary_operation_1): Do not simplify
+       a * -b + c as c - a * b if we honor sign dependent rounding.
+
+2007-04-11  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin-protos.h (bfin_expand_movmem): Renamed from
+       bfin_expand_strmov.
+       * config/bfin/bfin.c (bfin_expand_prologue, bfin_delegitimize_address,
+       bfin_function_ok_for_sibcall, split_load_immediate): Remove unused
+       variables.
+       (initialize_trampoline): Don't use old-style function definition.
+       (bfin_secondary_reload): Mark IN_P argument as unused.
+
+2007-04-10  Sebastian Pop  <sebastian.pop@inria.fr>
+
+       PR tree-optimization/31343
+       * tree-chrec.h (chrec_zerop): Moved before build_polynomial_chrec.
+       (build_polynomial_chrec): Return a scalar when the evolution is zero.
+       * testsuite/gcc.dg/vect/pr31343.c: New.
+
+2007-04-10  Eric Christopher  <echristo@apple.com>
+
+       * config/i386/i386.h (X87_FLOAT_MODE_P): New.
+       * config/i386/i386.md (*cmpfp0): Use.
+       (*cmpfp_u, *cmpfp_<mode>, *cmpfp_i_i387): Ditto.
+       (*cmpfp_iu_387, fix_trunc<mode>_fisttp_i386_1): Ditto.
+       (fix_trunc<mode>_i386_fisttp): Ditto.
+       (fix_trunc<mode>_i387_fisttp_with_temp): Ditto.
+       (*fix_trunc<mode>_i387_1, fix_truncdi_i387): Ditto.
+       (fix_truncdi_i387_with_temp, fix_trunc<mode>_i387): Ditto.
+       (fix_trunc<mode>_i387_with_temp, *fp_jcc_1_387): Ditto.
+       (*fp_jcc_2_387, *fp_jcc_5_387, *fp_jcc_6_387): Ditto.
+       (*fp_jcc_7_387, *fp_jcc_8<mode>_387): Ditto.
+       (unnamed_splitters): Ditto.
+       * config/i386/i386.c (output_fix_trunc): Assert that
+       we're not being passed a TFmode operand.
+
+2007-04-10  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/31526
+       * tree-inline.c (copy_cfg_body): Use last_basic_block instead of
+       n_basic_blocks to find newly added blocks.
+
+2007-04-10  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (fix_trunc<mode>di_sse): Remove "x" from "xm"
+       alternative.
+       (fix_trunc<mode>si_sse): Ditto.
+       (*floatsisf2_mixed, *floatsisf2_sse): Ditto.
+       (*floatsidf2_mixed, *floatsidf2_sse): Ditto.
+       (*floatdisf2_mixed, *floatdisf2_sse): Ditto.
+       (*floatdidf2_mixed, *floatdidf2_sse): Ditto.
+       (floathi<mode>2): Rename from floathisf2 and floathidf2. Macroize
+       expander using SSEMODEF mode macro.
+       (floatsi<mode>2): Rename from floatsisf2 and floashidf2. Macroize
+       expander using SSEMODEF mode macro.
+       (*floathi<mode>2_i387): Rename from *floathisf2_i387 and
+       *floathidf2_i387. Macroize insn using X87MODEF12 mode macro.
+       (*floatsi<mode>2_i387): Rename from *floatsisf2_i387 and
+       *floatsidf2_i387. Macroize insn using X87MODEF12 mode macro.
+       (*floatdi<mode>2_i387): Rename from *floatdisf2_i387 and
+       *floatdidf2_i387. Macroize insn using X87MODEF12 mode macro.
+       (float<mode>xf2): Rename from floathixf2, floatsixf2 and floatdixf2.
+       Macroize insn using X87MODEF mode macro.
+
+2007-04-09  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/sse.md (sse2_pinsrw): Removed.
+       (sse2_pextrw): Renamed to ...
+       (*sse2_pextrw): This.
+
+2007-04-09  Jan Hubicka  <jh@suse.cz>
+
+       PR target/27869
+       * config/i386/sse.md
+       (sse_vmaddv4sf3, sse_vmmulv4sf3): Remove '%' modifier.
+       (sse_vmsmaxv4sf3_finite, sse_vmsminv4sf3_finite): Remove.
+       (sse2_vmaddv2df3, sse2_vmmulv2df3): Remove '%' modifier.
+       (sse2_vmsmaxv2df3_finite, sse2_vmsminv2df3_finite): Remove.
+
+2007-04-09  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-ccp (maybe_fold_offset_to_component_ref): Recurse into
+       multiple fields of union.
+
+2007-04-09  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * cfgloopmanip.c (create_preheader): Do not use loop_preheader_edge.
+       (create_preheaders): Check that loops are available.
+       (fix_loop_structure): Clean up, improve comments.
+       * tree-ssa-loop-manip.c (rewrite_into_loop_closed_ssa):
+       Check that loops are available.  Set LOOP_CLOSED_SSA to the loops
+       state flags.
+       * tree-scalar-evolution.c (scev_finalize): Clear scalar_evolution_info.
+       * predict.c (tree_estimate_probability): Do not call
+       calculate_dominance_info.  Call create_preheaders.
+       * tree-cfgcleanup.c (cleanup_tree_cfg_loop): Only call
+       rewrite_into_loop_closed_ssa if LOOP_CLOSED_SSA is set in loops state
+       flags.
+       * cfgloop.c (loop_preheader_edge): Assert that loops have preheaders.
+       * cfgloop.h (LOOP_CLOSED_SSA): New constant.
+       * tree-cfg.c (tree_split_edge): Make an assert more precise.
+       * tree-ssa-threadedge.c (thread_across_edge): Comment the function
+       arguments.
+
+2007-04-08  Jan Hubicka  <jh@suse.cz>
+
+       * tree.h (maybe_fold_offset_to_component_ref): Declare.
+       * tree-ssa-ccp.c (maybe_fold_offset_to_component_ref): Export.
+       * fold-const.c (fold_unary): Use it.
+
+2007-04-08  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * varasm.c (assemble_variable): Remove call to
+       lang_hooks.decls.prepare_assemble_variable.
+       * langhooks-def.h (LANG_HOOKS_PREPARE_ASSEMBLE_VARIABLE): Kill.
+       (LANG_HOOKS_DECLS): Remove LANG_HOOKS_PREPARE_ASSEMBLE_VARIABLE.
+       * langhooks.h (lang_hooks_for_decls): Remove
+       prepare_assemble_variable.
+
+2007-04-08  Mike Stump  <mrs@apple.com>
+
+       * config/i386/i386.c: Use inc/dec on Core2.
+
+2007-04-08  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * langhooks.c (lhd_tree_inlining_add_pending_fn_decls,
+       lhd_tree_inlining_anon_aggr_type_p, lhd_tree_inlining_start_inlining,
+       lhd_tree_inlining_end_inlining): Remove.
+       * langhooks.h (struct lang_hooks_for_tree_inlining): Remove then
+       add_pending_fn_decls, anon_aggr_type_p, start_inlining, and
+       end_inlining hooks.
+       * langhooks-def.h (lhd_tree_inlining_add_pending_fn_decls,
+       lhd_tree_inlining_anon_aggr_type_p, lhd_tree_inlining_start_inlining,
+       lhd_tree_inlining_end_inlining): Remove prototypes.
+       (LANG_HOOKS_TREE_INLINING_ADD_PENDING_FN_DECLS,
+       LANG_HOOKS_TREE_INLINING_ANON_AGGR_TYPE_P,
+       LANG_HOOKS_TREE_INLINING_START_INLINING,
+       LANG_HOOKS_TREE_INLINING_END_INLINING): Remove.
+
+       * c-objc-common.h (LANG_HOOKS_TREE_INLINING_ANON_AGGR_TYPE_P): Do
+       not set it.
+
+2007-04-08  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/29932
+       * config/avr/predicates.md (io_address_operand): Delete predicate.
+       (low_io_address_operand): Don't use 'mode' argument.
+       (higth_io_address_operand): Rename ...
+       (high_io_address_operand): ... to this. Don't use 'mode' argument.
+       * config/avr/avr.md (*sbix_branch_tmp, *sbix_branch_tmp_bit7): Adjust
+       for above change.
+
+2007-04-07  Daniel Berlin  <dberlin@dberlin.org>
+
+       Revert change removing staticp.
+
+2007-04-07  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/30289
+       * config/avr/avr.md (*clrmemqi, *clrmemhi): Mark operand 4 as
+       earlyclobber.
+
+2007-04-07  Bruce Korb  <bkorb@gnu.org>
+
+       * c.opt: Add -Wformat-contains-nul.
+       * c-format.c (set_Wformat): Set warn_format_contains_nul to the
+         -Wformat setting.
+       (check_format_info_main): Check OPT_Wformat_contains_nul before emitting
+       the NUL byte warning.
+
+2007-04-07  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c (ix86_handle_option): Handle SSSE3.
+
+2007-04-06  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree.c (staticp): No longer use staticp langhook.
+       * langhooks.c (lhd_staticp): Removed.
+       * langhooks.h (struct lang_hooks): Remove staticp.
+       * c-common.c (c_staticp): Remove.
+       * c-common.h (c_staticp): Ditto.
+       * langhooks-defs.h (lhd_staticp): Ditto.
+       (LHD_HOOKS_STATICP): Ditto
+       * tree.h (gcc_assert_lowered): New macro.
+
+2007-04-06  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-niter.c (idx_infer_loop_bounds): Add and use
+       argument "reliable".
+       (infer_loop_bounds_from_ref, infer_loop_bounds_from_array):
+       Add argument "reliable".  Propagate it through calls.
+       (infer_loop_bounds_from_undefined): Derive number of iterations
+       estimates from references in blocks that do not dominate loop latch.
+       (gcov_type_to_double_int): New function.
+       (estimate_numbers_of_iterations_loop): Use gcov_type_to_double_int
+       and expected_loop_iterations_unbounded.
+       * cfgloopanal.c (expected_loop_iterations_unbounded): New function.
+       (expected_loop_iterations): Use expected_loop_iterations_unbounded.
+       * tree-data-ref.c (estimated_loop_iterations): Export.
+       (get_references_in_stmt): Fix -- do not return addresses of local
+       objects.
+       * cfgloop.h (expected_loop_iterations_unbounded,
+       estimated_loop_iterations): Declare.
+
+2007-04-06  Andreas Tobler  <a.tobler@schweiz.org>
+
+       * tree-sra.c (sra_build_elt_assignment): Initialize min/maxshift.
+
+2007-04-06  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (extend<mode>xf2): Rename from extendsfxf2
+       and extenddfxf2. Macroize expander using X87MODEF12 mode macro.
+       (*truncdfsf_mixed, *truncdfsf_i387, *truncdfsf2_i387_1):
+       Use output_387_reg_move().
+       (*truncxf<mode>2): Rename from *truncxfsf2 and truncxfdf2. Macroize
+       expander using X87MODEF12 mode macro.
+       (*truncxfsf2_mixed): Combine alternatives, ignore "r" alternative when
+       choosing register preferences.  Use output_387_reg_move().
+       (*truncxfdf2_mixed): Combine alternatives, use "r" alternative
+       instead of "x".  Use output_387_reg_move().
+       (*truncxf<mode>2_i387_noop): Rename from *truncxfsf2_i387_noop and
+       *truncxfdf2_i387_noop.  Macroize insn using X87MODEF12 mode macro.
+       (*truncxf<mode>2_i387): Rename from *truncxfsf2_i387 and
+       *truncxfdf2_i387.  Macroize insn using X87MODEF12 mode macro.
+       Use output_387_reg_move().
+       (*truncxf?f_mixed splitter): Macroize splitter using X87MODEF12
+       mode macro.
+       (*truncxf?f_i387 splitter): Ditto.
+
+2007-04-06  Daniel Berlin  <dberlin@dberlin.org>
+
+       * langhooks-def.h (LANG_HOOKS_INITIALIZER): Remove
+       LANG_HOOKS_SAFE_FROM_P.
+       * expr.c (safe_from_p): Remove langhook call.
+       * langhooks.h (lang_hooks): Remove safe_from_p.
+       (lhd_safe_from_p): Remove prototype.
+       * langhooks.c (lhd_safe_from_p): Remove.
+
+2007-04-06  Jan Hubicka  <jh@suse.cz>
+
+       * cgraphunit.c (decide_is_function_needed): Do not keep always_inline
+       functions.
+
+2007-04-06  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (output_387_reg_move): Handle memory operand[0].
+       * config/i386/i386.md (*movsf_1, *movdf_nointeger,
+       *movdf_integer_rex64, *movdf_integer, *movxf_nointeger,
+       *movxf_integer): Use output_387_reg_move() for x87 reg->mem
+       alternative.
+       (*extendsfdf2_mixed, *extendsfdf2_i387, *extendsfxf2_i387,
+       *extenddfxf2_i387, *truncdfsf_fast_mixed): Ditto.
+
+2007-04-05  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/alpha.c (print_operand) [+]: Remove.
+       (alpha_end_function): Print nop if call at end of function.
+       * config/alpha/alpha.h (PRINT_OPERAND_PUNCT_VALID_P): Remove +.
+       * config/alpha/alpha.md (UNSPEC_LDGP1): New.
+       (call_osf_1_er_noreturn, call_value_osf_1_er_noreturn): New.
+       (call_osf_2_er_nogp, call_value_osf_2_er_nogp): New.
+       (call_osf_2_er, call_value_osf_2_er): Merge the ldgp highpart into
+       the call pattern. Update peepholes to match.
+
+2007-04-05  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/extend.texi (Other Builtins): Add decimal float variants
+       of signbit.
+       * builtins.def: Ditto.
+       * builtins.c (expand_builtin): Ditto.
+
+2007-04-05  Uros Bizjak  <ubizjak@gmail.com>
+           H.J. Lu  <hongjiu.lu@intel.com>
+
+       PR target/31478
+       * config/i386/sse.md (sse2_umulv2siv2di3): Use V4SImode instead
+       of V8HImode when calling ix86_binary_operator_ok.
+       (sse2_pmaddwd): Call ix86_binary_operator_ok.
+       (sdot_prodv8hi): Operands 1 and 2 must be register.
+
+2007-04-05  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree-sra.c (try_instantiate_multiple_fields): Needlessly
+       initialize align to silence bogus warning.
+
+2007-04-05  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR middle-end/22156
+       * tree-sra.c (struct sra_elt): Add in_bitfld_block.  Remove
+       all_no_warning.
+       (struct sra_walk_fns): Remove use_all parameter from use.
+       (sra_hash_tree): Handle BIT_FIELD_REFs.
+       (sra_elt_hash): Don't hash bitfld blocks.
+       (sra_elt_eq): Skip them in parent compares as well.  Handle
+       BIT_FIELD_REFs.
+       (sra_walk_expr): Don't maintain or pass down use_all_p.
+       (scan_use): Remove use_all parameter.
+       (scalarize_use): Likewise.  Re-expand assignment to
+       BIT_FIELD_REF of gimple_reg.  De-scalarize before input or
+       output, and re-scalarize after output.  Don't mark anything
+       for no warning.
+       (scalarize_ldst): Adjust.
+       (scalarize_walk_gimple_modify_statement): Likewise.
+       (build_element_name_1): Handle BIT_FIELD_REFs.
+       (instantiate_element): Don't warn for any element whose parent
+       is used as a whole.
+       (instantiate_missing_elements_1): Return the sra_elt.
+       (canon_type_for_field): New.
+       (try_instantiate_multiple_fields): New.
+       (instantiate_missing_elemnts): Use them.
+       (mark_no_warning): Removed.
+       (generate_one_element_ref): Handle BIT_FIELD_REFs.
+       (REPLDUP, sra_build_elt_assignment): New.
+       (generate_copy_inout): Use them.
+       (generate_element_copy): Likewise.  Handle bitfld differences.
+       (generate_element_zero): Don't recurse for blocks.  Use
+       sra_build_elt_assignment.
+       (generate_one_element_int): Take elt instead of var.  Use
+       sra_build_elt_assignment.
+       (generate_element_init_1): Adjust.
+       (scalarize_use, scalarize_copy): Use REPLDUP.
+       (scalarize_ldst): Move assert before dereference.
+       (dump_sra_elt_name): Handle BIT_FIELD_REFs.
+
+2007-04-05  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * regmove.c: Fix unused variable warnings due to previous commit.
+
+2007-04-05  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * regmove.c (STACK_GROWS_DOWNWARD): Don't boolean-ize.
+       (regmove_bb_head): Remove.
+       (copy_src_to_dest): Don't update regmove_bb_head and BB_HEAD.
+       (regmove_optimize): Don't do unnecessary CFG fixes for non-existing
+       problems with fixup_match_1.
+       Don't initialize/free regmove_bb_head.
+
+       (reg_is_remote_constant_p): If an insn is in the same basic block
+       but not before INSN, consider it remote, too.
+
+2007-04-05  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/25448
+       * config/avr/avr.c (avr_handle_fndecl_attribute): Use the
+       DECL_ASSEMBLER_NAME, not the DECL_NAME.
+
+2007-04-05  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.h (TARGET_CPU_CPP_BUILTINS): Reformat.
+       (CONDITIONAL_REGISTER_USAGE): Likewise.
+
+2007-04-04  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/lib1funcs.asm: Remove unused file.
+
+2007-04-04  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       PR other/31356
+       * opts.c (print_specific_help): Fix --help=<language>
+       header line.
+       (common_handle_option): Support --help=common.
+
+2007-04-04  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       PR other/31353
+       * gcc.c (main): Do not run the linker if
+       print_subprocess_help indicates that it shouldn't be
+       run.
+
+2007-04-04  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       PR doc/31355
+       * doc/invoke.texi (--help=): Document <languages> value, fix
+       formatting in tables of values.
+
+2007-04-04  Danny Smith  <dannysmith.users.sourceforge.net>
+
+       * config/i386/winnt-cxx.c (i386_pe_type_dllimport_p): Don't ignore
+       dllimport attribute of virtual methods.
+
+2007-04-04  Chen Liqin  <liqin@sunnorth.com.cn>
+
+       * config/score/crti.asm: Change _bss_start to __bss_start.
+       * config/score/score.h (CONDITIONAL_REGISTER_USAGE): Added.
+       (OUTGOING_REG_PARM_STACK_SPACE) update.
+       * config/score/score.opt: add options to make backend support
+       score5, score5u, score7 and score7d.
+       * config/score/score.md: Likewise.
+       * config/score/misc.md: Likewise.
+       * config/score/mac.md: Likewise.
+       * doc/invoke.texi: Likewise.
+       * doc/md.texi: update constraints define.
+
+2007-04-03  Richard Henderson  <rth@redhat.com>
+
+       * expr.c (store_expr): If get_signed_or_unsigned_type doesn't yield
+       an appropriate type, use the mode instead.
+
+2007-04-03  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (mips-wrs-vxworks): Add vx-common.h to tm_file.
+       Set the default --with-arch setting to mips2.
+       * config/mips/t-vxworks (MULTILIB_OPTIONS, MULTILIB_MATCHES)
+       (MULTILIB_EXCEPTIONS): Redefine with new multilibs.
+       (MULTILIB_OSDIRNAMES): Delete.
+       (MULTILIB_DIRNAMES): Define.
+       * config/mips/vxworks.h (LINK_SPEC): Add VXWORKS_LINK_SPEC.
+       (LIB_SPEC, STARTFILE_SPEC, ENDFILE_SPEC): Define.
+       (TARGET_OS_CPP_BUILTINS): Incorporate old SUBTARGET_CPP_SPEC
+       definitions, except for _WRS_R3K_EXC_SUPPORT.  Call
+       VXWORKS_OS_CPP_BUILTINS.
+       (SUBTARGET_CPP_SPEC): Redefine to VXWORKS_ADDITIONAL_CPP_SPEC.
+       (MIPS_DEBUGGING_INFO): Undefine.
+       (FUNCTION_PROFILER): Define to VXWORKS_FUNCTION_PROFILER.
+
+2007-04-03  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/30704
+       * fold-const.c (native_encode_real): Encode real.c provided longs
+       as a series of 32-bit native integers.
+       (native_interpret_real): Interpret buffer as a series of 32-bit
+       native integers.
+
+2007-04-03  Richard Guenther  <rguenther@suse.de>
+
+       * genpreds.c (write_insn_constraint_len): Write function
+       optimized for CONSTRAINT_LEN implementation.
+       (write_tm_preds_h): Output insn_constraint_len inline and
+       use it for CONSTRAINT_LEN.
+       (write_insn_preds_c): Don't output insn_constraint_len.
+       * doc/md.texi (define_register_constraint): Document multi-letter
+       constraints shall have the same length if they start with the same
+       letter.
+
+2007-04-03  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/31175
+       * config/i386/i386.md (isinf<mode>2): Expand only when
+       TARGET_C99_FUNCTIONS is set.
+
+2007-04-03  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config.gcc (i[34567]86-*-linux*): Add i386/t-crtpc to tm-file.
+       (x86_64-*-linux*): Ditto.
+       * config/i386/i386.opt (mpc): New option.
+       * config/i386/i386.c (overrride_options): Handle
+       ix87_precision_string.
+       * config/i386/crtprec.c: New file.
+       * config/i386/t-crtpc: Ditto.
+       * config/i386/linux.h (ENDFILE_SPEC): Add handling of -mpc32, -mpc64
+       and -mpc80 options.
+       * config/i386/linux64.h (ENDFILE_SPEC): Ditto.
+       * config/i386/t-linux64 (EXTRA_MULTILIB_PARTS): Add
+       crtprec32.o, crtprec64.o and crtprec80.o.
+
+       * doc/invoke.texi (Machine Dependent Options): Add -mpc32, -mpc64
+       and -mpc80 options.
+       (i386 and x86-64 Options): Document -mpc32, -mpc64 and -mpc80 options.
+
+2007-04-02  Eric Christopher  <echristo@apple.com>
+
+       * doc/invoke.texi (i386 and x86-64 Options): Document -m64
+       limitations on darwin.
+
+2007-04-02  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/31137
+       * config/avr/avr.c (avr_rtx_costs): Add missing 'break' statements.
+
+2007-04-02  Dave Korn  <dave.korn@artimi.com>
+
+       * doc/tm.texi (FUNCTION_MODE): Update and extend documentation.
+
+2007-04-02  Dave Korn  <dave.korn@artimi.com>
+
+       * libgcc2.h (exception_descriptor): Don't forward-declare.
+       (__get_eh_table_language, __get_eh_table_version): Delete
+       prototypes of long-dead functions.
+
+2007-04-01  Daniel Berlin  <dberlin@dberlin.org>
+
+       * ebitmap.h: New file
+       * ebitmap.c: New file
+       * Makefile.in (ebitmap.o): New target.
+
+2007-04-01  Jan Hubicka  <jh@suse.cz>
+
+       * emit-rtl.c (emit_insn_before_setloc): Do not ICE when asked to emit
+       before very first instruction.
+
+2007-04-01  Jan Hubicka  <jh@suse.cz>
+
+       * ggc-page.c (ggc_print_statistics): Fix formatting string to avoid
+       waring on 64bit hosts.
+       * bitmap.h: Fix typo in bitmap_head_def.
+
+2007-04-01  Steven Bosscher  <steven@gcc.gnu.org>
+
+       PR rtl-optimization/31391
+       * cfgcleanup.c (try_optimize_cfg): If a removed label is turned
+       into a DELETED_LABEL note, and the label is in an empty basic
+       block, update BB_END as well as BB_HEAD.
+
+2007-04-01  Richard Henderson  <rth@redhat.com>
+
+       PR tree-optimization/31169
+       * tree-vrp.c (extract_range_from_binary_expr) <RSHIFT_EXPR>: Drop
+       to varying if the range is outside [0,  prec-1].
+
+2007-04-01  Richard Sandiford  <richard@codesourcery.com>
+
+       PR target/31388
+       * config/mips/mips.md (load_const_gp): New insn.
+       * config/mips/mips.c (mips_split_symbol): Avoid using or creating
+       the MIPS16 GP pseudo register if no_new_pseudos.
+       (mips16_gp_pseudo_reg): Use gen_load_const_gp.
+
+2007-03-31  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR target/31364
+       * config/rs6000/rs6000.md (call): Convert to LR hard reg for
+       secureplt.
+       (call_value): Likewise.
+
+2007-03-31  Wolfgang Bangerth  <bangerth@dealii.org>
+           Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR 14737
+       * doc/invoke.texi: (optimization options): Reword description
+       of -ffast-math. Document its primary purpose.
+
+2007-03-31  Richard Guenther  <rguenther@suse.de>
+
+       * omp-low.c (splay-tree.h): Include.
+       (lookup_decl): Replace splay-tree usage by pointer-map.
+       (maybe_lookup_decl): Likewise.
+       (new_omp_context): Likewise.
+       (delete_omp_context): Likewise.
+       * gimplify.c (splay-tree.h): Include.
+       * tree-inline.c (insert_decl_map): Replace splay-tree usage by
+       pointer-map.
+       (remap_ssa_name): Likewise.
+       (remap_decl): Likewise.
+       (remap_type_1): Likewise.
+       (remap_type): Likewise.
+       (copy_body_r): Likewise.
+       (expand_call_inline): Likewise.
+       (clone_body): Likewise.
+       (copy_tree_r): Likewise.
+       (remap_save_expr): Likewise.
+       (unsave_r): Likewise.
+       (unsave_expr_now): Likewise.
+       (tree_function_versioning): Likewise.
+       (build_duplicate_type): Likewise.
+       * tree-inline.h (pointer-set.h): Include instead of splay-tree.h.
+       (struct copy_body_data): Replace splay-tree by pointer-map.
+       * Makefile.in (TREE_INLINE_H): Depend on pointer-map.h,
+       not $(SPLAY_TREE_H).
+       (gimplify.o): Depend on $(SPLAY_TREE_H).
+       (omp-low.p): Likewise.
+
+2007-03-31  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/predicates.md (even_register_operand,
+       odd_register_operand): New predicates.
+       * config/avr/avr.md (movw peephole2): New.
+       (movw_r peephole2): New.
+
+2007-03-30  Rafael Ávila de Espíndola  <espindola@google.com>
+
+       * tree.h (get_signed_or_unsigned_type): New.
+       * fold-const.c (operand_equal_for_comparison_p): Use
+       get_signed_or_unsigned_type instead of
+       lang_hooks.types.signed_or_unsigned_type.
+       * expr.c (store_expr): Ditto.
+       * langhooks.c (get_signed_or_unsigned_type): New.
+       (lhd_signed_or_unsigned_type): New.
+       * langhooks.h (lhd_signed_or_unsigned_type): New.
+       * langhooks-def.h (LANG_HOOKS_SIGNED_OR_UNSIGNED_TYPE): Define.
+
+2007-03-30  Richard Henderson  <rth@redhat.com>
+
+       * tree-ssa-loop-ivopts.c: Include target.h.
+       (produce_memory_decl_rtl): Pass the rtx through encode_section_info.
+       (get_address_cost): Force SYMBOL_FLAG_LOCAL set.
+       (force_expr_to_var_cost): Use produce_memory_decl_rtl.
+       * Makefile.in (tree-ssa-loop-ivopts.o): Depend on TARGET_H.
+
+2007-03-30  Richard Henderson  <rth@redhat.com>
+           Kai Tietz  <kai.tietz@onevision.com>
+
+       * config/i386/cygming.h (DWARF2_DEBUGGING_INFO): Enable by
+       default for 64-bit.
+       (PREFERRED_DEBUGGING_TYPE): Prefer dwarf2 for 64-bit.
+       (TARGET_64BIT_MS_ABI): New.
+       (DBX_REGISTER_NUMBER): Handle 64-bit.
+       (SIZE_TYPE, PTRDIFF_TYPE): Use long long for 64-bit.
+       (LONG_TYPE_SIZE): Force to 32.
+       (REG_PARM_STACK_SPACE): New.
+       (OUTGOING_REG_PARM_STACK_SPACE): New.
+       (REGPARM_MAX, SSE_REGPARM_MAX): New.
+       (HANDLE_PRAGMA_PUSH_POP_MACRO): New.
+       (STACK_BOUNDARY): Use 128 for 64-bit.
+       * config/i386/cygwin.asm: Use push/ret to preserve call stack.
+       Add 64-bit implementation.
+       * config/i386/gthr-win32.c (__gthr_win32_key_create): Mark dtor
+       argument unused.
+       * config/i386/i386.c (x86_64_ms_abi_int_parameter_registers): New.
+       (override_options): Set ix86_cmodel for TARGET_64BIT_MS_ABI.
+       Warn for -mregparm, -mrtd in 64-bit mode; force ix86_regparm
+       for 64-bit; use TARGET_SUBTARGET64_DEFAULT.
+       (ix86_handle_cconv_attribute): Don't warn when ignoring if
+       TARGET_64BIT_MS_ABI.
+       (ix86_function_arg_regno_p): Handle TARGET_64BIT_MS_ABI.
+       (ix86_pass_by_reference): Likewise.
+       (ix86_function_value_regno_p): Likewise.
+       (ix86_build_builtin_va_list): Likewise.
+       (ix86_va_start, ix86_gimplify_va_arg): Likewise.
+       (function_arg_advance_ms_64): New.
+       (function_arg_advance): Call it.
+       (function_arg_ms_64): New.
+       (function_arg): Call it.
+       (function_value_ms_64): New.
+       (ix86_function_value_1): Call it.
+       (return_in_memory_ms_64): New.
+       (ix86_return_in_memory): Call it.
+       (setup_incoming_varargs_ms_64): New.
+       (ix86_setup_incoming_varargs): Call it.
+       (ix86_expand_prologue): Handle 64-bit stack probing.
+       (legitimize_pic_address): Handle TARGET_64BIT_MS_ABI.
+       (output_pic_addr_const): Likewise.
+       (x86_this_parameter): Likewise.
+       (x86_output_mi_thunk): Likewise.
+       (x86_function_profiler): Likewise.
+       (TARGET_STRICT_ARGUMENT_NAMING): New.
+       * config/i386/i386.h (TARGET_SUBTARGET64_DEFAULT): New.
+       (TARGET_64BIT_MS_ABI): New.
+       (CONDITIONAL_REGISTER_USAGE): Handle TARGET_64BIT_MS_ABI.
+       * config/i386/i386.md (allocate_stack_worker): Remove.
+       (allocate_stack_worker_32): Rename from allocate_stack_worker_1;
+       describe the clobber of eax without a match_scratch.
+       (allocate_stack_worker_postreload): Remove.
+       (allocate_stack_worker_64): Rename from allocate_stack_worker_rex64;
+       describe the clobbers of rax, r10, r11 properly; use __chkstk symbol.
+       (allocate_stack_worker_rex64_postreload): Remove.
+       (allocate_stack): Handle 64-bit.
+       * config/i386/i386elf (TARGET_SUBTARGET_DEFAULT): Remove.
+       * config/i386/mingw32.h (TARGET_VERSION): Set correctly for 64-bit.
+       (EXTRA_OS_CPP_BUILTINS): Handle 64-bit.
+       (STANDARD_INCLUDE_DIR): Handle TARGET_64BIT_DEFAULT.
+       (STANDARD_STARTFILE_PREFIX_1): Likewise.
+       * config/i386/unix.h (TARGET_SUBTARGET64_DEFAULT): New.
+       * config.build (x86_64-*-mingw*): New host.
+       * config.host (x86_64-*-mingw*): New host.
+       * config.gcc (x86_64-*-mingw*): New target.
+       * gthr-win32.h (__gthread_key_create): Mark dtor unused.
+
+2007-03-30  Richard Henderson  <rth@redhat.com>
+           Kai Tietz  <kai.tietz@onevision.com>
+
+       * c-pragma.c (struct def_pragma_macro_value): New.
+       (struct def_pragma_macro): New.
+       (pushed_macro_table): New.
+       (dpm_hash, dpm_eq): New.
+       (handle_pragma_push_macro, handle_pragma_pop_macro): New.
+       (init_pragma): Install them.
+       * doc/tm.texi (HANDLE_PRAGMA_PUSH_POP_MACRO): New.
+
+2007-03-30  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (avr_override_options): Clear
+       'flag_delete_null_pointer_checks'.
+
+2007-03-30  Paolo Carlini  <pcarlini@suse.de>
+
+       PR c++/26099
+       * c-common.h (enum rid): Add RID_HAS_NOTHROW_ASSIGN,
+       RID_HAS_NOTHROW_CONSTRUCTOR, RID_HAS_NOTHROW_COPY,
+       RID_HAS_TRIVIAL_ASSIGN, RID_HAS_TRIVIAL_CONSTRUCTOR,
+       RID_HAS_TRIVIAL_COPY, RID_HAS_TRIVIAL_DESTRUCTOR,
+       RID_HAS_VIRTUAL_DESTRUCTOR, RID_IS_ABSTRACT, RID_IS_BASE_OF,
+       RID_IS_CONVERTIBLE_TO, RID_IS_CLASS, RID_IS_EMPTY, RID_IS_ENUM,
+       RID_IS_POD, RID_IS_POLYMORPHIC, RID_IS_UNION, as
+       C++ extensions.
+       * doc/extend.texi (Extensions to the C++ Language): Add Type Traits.
+
+2007-03-30  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * regmove.c: Move all of pass_stack_adjustments from here...
+       * combine-stack-adj.c: ...to this new file.
+       * Makefile.in: Add rules for combine-stack-adj.o.
+
+2007-03-30  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/31383
+       * tree-data-ref.c (affine_function_equal_p): Do not require the
+       vectors to have the same length.
+
+2007-03-30  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/30700
+       * dwarf2out.c (reference_to_unused): Ask cgraph for functions
+       availablility; add more sanity checking; ask varpool only about
+       VAR_DECL.
+
+2007-03-29  Richard Henderson  <rth@redhat.com>
+
+       * unwind-generic.h (_sleb128_t, _uleb128_t): Don't use HAVE_LONG_LONG
+       to decide, but __SIZEOF_LONG_LONG__.
+
+2007-03-29  Richard Henderson  <rth@redhat.com>
+
+       * emutls.c (struct __emutls_array): New.
+       (emutls_destroy): Use it instead of casting element 0 from void*.
+       (__emutls_get_address): Likewise.
+
+2007-03-29  Richard Henderson  <rth@redhat.com>
+
+       * varasm.c (initializer_constant_valid_p): Don't deny
+       DECL_DLLIMPORT_P on functions.
+
+       * config/i386/cygming.h: Remove function declarations.
+       (SUBTARGET_ENCODE_SECTION_INFO): Don't undef first.
+       (ASM_OUTPUT_LABELREF): Remove.
+       (COMMON_ASM_OP): Remove.
+       (ASM_OUTPUT_COMMON): Remove.
+       (ASM_OUTPUT_ALIGNED_DECL_COMMON): New.
+       (ASM_DECLARE_OBJECT_NAME): Use i386_pe_maybe_record_exported_symbol.
+       (ASM_DECLARE_FUNCTION_NAME): Likewise.
+       * config/i386/i386-interix.h (SUBTARGET_ENCODE_SECTION_INFO):
+       Rename from TARGET_ENCODE_SECTION_INFO.
+       * config/i386/netware.h: Likewise.
+       * config/i386/i386-protos.h: Update.
+       * config/i386/i386.c (ix86_function_ok_for_sibcall): Turn ifdef
+       of TARGET_DLLIMPORT_DECL_ATTRIBUTES into straight if.
+       (legitimate_constant_p): Reject dllimports.
+       (dllimport_map, get_dllimport_decl): New.
+       (legitimize_dllimport_symbol): New.
+       (legitimize_address, ix86_expand_move): Use it.
+       (TARGET_BINDS_LOCAL_P): Redefine for TARGET_DLLIMPORT_DECL_ATTRIBUTES.
+       * config/i386/i386.h (DLL_IMPORT_EXPORT_PREFIX): Remove.
+       (SYMBOL_FLAG_DLLIMPORT, SYMBOL_REF_DLLIMPORT_P): New.
+       (SYMBOL_FLAG_DLLEXPORT, SYMBOL_REF_DLLEXPORT_P): New.
+       * config/i386/predicates.md (constant_call_address_operand): Only
+       accept symbols; reject dllimport_p symbols.
+       * config/i386/uwin.h (ASM_DECLARE_FUNCTION_NAME): Use
+       i386_pe_maybe_record_exported_symbol.
+       * config/i386/winnt.c (DLL_IMPORT_PREFIX, DLL_EXPORT_PREFIX): Remove.
+       (i386_pe_determine_dllexport_p): Rename from i386_pe_dllexport_p.
+       (i386_pe_determine_dllimport_p): Rename from i386_pe_dllimport_p;
+       trust the setting of DECL_DLLIMPORT_P.
+       (i386_pe_dllexport_name_p, i386_pe_dllimport_name_p): Remove.
+       (i386_pe_mark_dllexport, i386_pe_mark_dllimport): Remove.
+       (gen_stdcall_or_fastcall_suffix): Return NULL if no change required;
+       tidy the argument scanning loop.
+       (i386_pe_encode_section_info): Set SYMBOL_FLAG_DLLIMPORT and
+       SYMBOL_FLAG_DLLEXPORT in SYMBOL_REF_FLAGS.
+       (i386_pe_strip_name_encoding): Remove.
+       (i386_pe_binds_local_p): New.
+       (i386_pe_strip_name_encoding_full): Use default_strip_name_encoding.
+       (i386_pe_output_labelref): Remove.
+       (i386_pe_asm_output_aligned_decl_common): New.
+       (i386_pe_maybe_record_exported_symbol): Rename from
+       i386_pe_record_exported_symbol; check for dllexported symbols.
+
+2007-03-29  Zack Weinberg  <zack@mrtock.ucsd.edu>
+
+       * gengtype.c (oprintf): Mostly revert changes from 2007-03-26;
+       add comment explaining why vsnprintf cannot be used.
+
+2007-03-29  Douglas Gregor  <doug.gregor@gmail.com>
+
+       PR tree-optimization/30666
+       * tree.c (build_complex_type): When creating type names for DWARF2
+       debug info, create TYPE_DECLs for TYPE_NAME instead of
+       IDENTIFIER_NODEs.
+       (build_common_tree_nodes_2): Use build_complex_type when building
+       predefined complex types, to preserve canonical types.
+
+2007-03-29  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * ifcvt.c (struct noce_if_info): Add then_else_reversed field.
+       (noce_get_alt_condition): Look at it to determine whether to
+       reverse the condition or not.
+       (noce_get_condition): Substitute the truth for lies.
+       (noce_find_if_block): Set the then_else_reversed field.
+
+2007-03-29  Lars Poeschel <larsi@wh2.tu-dresden.de>
+
+       * config/fr30/fr30.md (movdi): Do not accept immediates as the
+       destination of this insn.
+       * config/fr30/fr30.c (fr30_move_double): Use emit_move_insn rather
+       than calling gen_rtx_SET directly.  Use r0 to hold the value of
+       'address + 4' rather than a stack based temporary which can be
+       mis-optimized away.
+
+2007-03-29  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.c (s390_secondary_input_reload_class,
+       s390_secondary_output_reload_class): Functions removed.
+       (s390_secondary_reload): New function.
+       (TARGET_SECONDARY_RELOAD): Target macro defined.
+       * config/s390/s390.h (SECONDARY_INPUT_RELOAD_CLASS,
+       SECONDARY_OUTPUT_RELOAD_CLASS): Macro definitions removed.
+       * config/s390/s390.md ("reload_outti", "reload_outdi",
+       "reload_indi", "reload_insi", "reload_out<mode>", "reload_in<mode>",
+       "reload_out<mode>"): Expanders removed.
+       ("reload<mode>_plus", "reload<mode>_nonoffmem_in",
+       "reload<mode>_nonoffmem_out"): Expanders added.
+
+2007-03-29  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * regmove.c (optimize_reg_copy_1): Don't perform DEST->SRC repair
+       action if SRC->DEST replacement failed anyway.
+
+2007-03-28  Mike Stump  <mrs@apple.com>
+
+       * config/darwin9.h (ASM_OUTPUT_ALIGNED_COMMON): Add.
+       * config/darwin.h (MAX_OFILE_ALIGNMENT): Fix.
+       * config/rs6000/darwin.h (ASM_OUTPUT_ALIGNED_COMMON): Removed #undef.
+
+2007-03-28  Dwarakanath Rajagopal  <dwarak.rajagopal@amd.com>
+
+       * config.gcc: Accept barcelona as a variant of amdfam10.
+       * config/i386/i386.c (override_options): Likewise.
+       * doc/invoke.texi: Likewise.
+
+2007-03-28  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-dfa.c (get_ref_base_and_extent): Do not expect positive
+       offsets for BIT_FIELD_REF and COMPONENT_REF.
+
+2007-03-28  Richard Guenther  <rguenther@suse.de>
+
+       * tree.c (is_global_var): Move ...
+       * tree-flow-inline.h (is_global_var): ... here.
+       * tree.h (is_global_var): Remove declaration.
+
+2007-03-28  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (X86_TUNE_PROMOTE_HIMODE_IMUL): New tuning
+       option.
+       (TARGET_TUNE_PROMOTE_HIMODE_IMUL): New define. Use new tuning option.
+       * config/i386/i386.c (ix86_tune_features): Initialize new
+       tuning option.
+       * config/i386/predicates.md (promotable_binary_operator): Use
+       TARGET_TUNE_PROMOTE_HIMODE_IMUL.
+
+2007-03-28  Grigory Zagorodnev <grigory_zagorodnev@linux.intel.com>
+
+       PR target/31380
+       * config/i386/sse.md (uminv16qi3): Use UMIN instead of UMAX.
+
+2007-03-28  Lars Poeschel <larsi@wh2.tu-dresden.de>
+
+       * config/fr30/fr30.md (movsi_internal): Change destination
+       constraint from m to V and add m to the end.
+
+2007-03-28  Christian Bruel  <christian.bruel@st.com>
+
+       * config/sh/sh.md (movsi_i): Fix type attribute.
+
+2007-03-28  Christian Bruel  <christian.bruel@st.com>
+
+       * config/sh/sh.md (movsi_ie): Fix memory constraints attribute length.
+       (movsf_ie): Likewise.
+
+2007-03-28  Christian Bruel  <christian.bruel@st.com>
+
+       * config.gcc: Add sh4-300 to multilib.
+       * config/sh/t-mlib-sh4-300: New file.
+
+2007-03-28  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md ("fix_trunc<mode>di2"): New expander.
+       ("fix_trunc<DFP:mode>di2_dfp"): New insn definition renamed from
+       fix_trunc<mode>di2.
+       ("fixuns_truncdddi2", "fixuns_trunctddi2"): Use
+       fix_trunc<DFP:mode>di2_dfp instead of fix_trunc<mode>di2.
+       ("fix_truncdfsi2", "fix_truncsfsi2", "fixuns_truncdddi2",
+       "fixuns_trunctddi2"): Whitespace fix.
+
+2007-03-28  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.h (CALL_COOKIE_RET_TRAMP_SHIFT): Move after
+       the definition of struct sh_args.
+       (CALL_COOKIE_RET_TRAMP, CALL_COOKIE_STACKSEQ_SHIFT,
+       CALL_COOKIE_INT_REG_GET): Likewise.
+
+2007-03-28  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * ifcvt.c (cond_exec_find_if_block): Return FALSE if no
+       transformations are applied successfully.
+
+2007-03-27  Douglas Gregor  <doug.gregor@gmail.com>
+
+       * tree.c (tree_contains_struct): Permit 512 tree codes.
+       * tree.h (tree_contains_struct): Ditto.
+       (MAX_TREE_CODES): Ditto.
+       (struct tree_base): Make CODE 16 bits, instead of 8 bits. Add
+       SPARE member to store remaining padding bits.
+
+2007-03-27  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (avr_mcu_types): Move at90usb82 device to 'avr4'
+       architecture.
+
+2007-03-27  Janis Johnson  <janis187@us.ibm.com>
+
+       * configure.ac: Fix assembler test for powerpc*-linux decimal float.
+       * configure: Regenerate.
+
+       * configure: Regenerate using the correct version of autoconf.
+
+2007-03-27  Anatoly Sokolov  <aesok@post.ru>
+
+       * config/avr/avr.c (avr_hard_regno_mode_ok): Disallow QImode in stack
+       pointer regs.
+       * config/avr/avr.h (REGISTER_NAMES): Rename "__SPL__" and "__SPH__"
+       regs to "__SP_L__" and "__SP_H__".
+
+2007-03-27  Richard Guenther  <rguenther@suse.de>
+
+       * tree-dfa.c (get_ref_base_and_extent): Replace bit_offset and
+       computations with it with a HOST_WIDE_INT variable.
+
+2007-03-26  Mike Stump  <mrs@apple.com>
+
+       * config/rs6000/darwin.h (DARWIN_MINVERSION_SPEC): Add
+       objective-c-header, objective-c++-header and objc++-cpp-output
+       support.
+       * config/i386/darwin.h (DARWIN_MINVERSION_SPEC): Likewise.
+
+2007-03-26  Richard Henderson  <rth@redhat.com>
+
+       PR target/31361
+       * config/i386/i386.c (IX86_BUILTIN_PSLLDQ128, IX86_BUILTIN_PSLLW128,
+       IX86_BUILTIN_PSLLD128, IX86_BUILTIN_PSLLQ128, IX86_BUILTIN_PSRAW128,
+       IX86_BUILTIN_PSRAD128, IX86_BUILTIN_PSRLW128, IX86_BUILTIN_PSRLD128,
+       IX86_BUILTIN_PSRLQ128): New.
+       (ix86_init_mmx_sse_builtins): Add them.
+       (ix86_expand_builtin): Expand them.
+       * config/i386/sse.md (ashr<mode>3, lshr<mode>3, ashl<mode>3): Make
+       operand 2 be TImode.
+       * config/i386/emmintrin.h (_mm_slli_epi64, _mm_srai_epi16,
+       _mm_srai_epi32, _mm_srli_epi16, _mm_srli_epi32,
+       _mm_srli_epi64): Mark __B const.
+       (_mm_srli_si128, _mm_srli_si128): Fix disabled inline versions.
+       (_mm_sll_epi16, _mm_sll_epi32, _mm_sll_epi64, _mm_sra_epi16,
+       _mm_sra_epi32, _mm_srl_epi16, _mm_srl_epi32, _mm_srl_epi64): Use
+       new two-vector shift builtins.
+
+2007-03-26  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/31345
+       * tree-vrp.c (extract_range_from_binary_expr): Turn ranges like
+       [+INF, +INF(OVF)] into VARYING.
+
+2007-03-26  Zack Weinberg  <zackw@panix.com>
+
+       * gengtype-parse.c: New file.
+       * gengtype-yacc.y: Delete.
+       * gengtype-lex.l: Don't include gengtype-yacc.h.
+       Define YY_DECL and yyterminate appropriately for recursive
+       descent parser.  yylval is now a string out-parameter to yylex.
+       (HWS, EOID): New shorthand.
+       (IWORD): Add a couple more types.
+       (yylex): Add a setup stanza.  Remove the complex rules for
+       detecting GTY'ed types and typedefs; replace with simple
+       keyword detectors.  Adjust everything for the changed
+       definition of yylval.  Ignore all pp-directives, not just #define.
+       (yyerror): Delete.
+       (parse_file): Rename yybegin; do not call yyparse.
+       (yyend): New.
+       * gengtype.c (xasprintf): Export again.
+       (this_file): New.  Use everywhere __FILE__ was being used.
+       (get_lang_bitmap): Special case types defined in gengtype.c.
+       (do_typedef, new_structure): Suppress definition of certain types.
+       (new_structure): Improve diagnostics of duplicate definitions.
+       Make sure location_s is associated with input.h.
+       (nreverse_pairs, define_location_structures): New functions.
+       (main): Improve tagging of kludge types.  Remove old kludges
+       for input.h types; use define_location_structures.
+       * gengtype.h: Update prototypes.  Define token codes here.
+       * Makefile.in: Remove all references to gengtype-yacc.
+       Add rules for gengtype-parse.o.  Adjust rules for gengtype-lex.o
+       and gengtype.
+       * bitmap.h (struct bitmap_head_def): Coalesce definitions,
+       add GTY((skip)) to the field that's only conditionally there.
+       * doc/install.texi: Document that Bison is no longer required
+       unless building treelang.
+
+       * gengtype.c: Don't include gtyp-gen.h.
+       (srcdir): Declare here.
+       (base_files, lang_dir_names): Allocate dynamically.
+       (gt_files, num_gt_files, num_lang_dirs): New globals.
+       (measure_input_list, read_input_line, read_input_list)
+       (set_lang_bitmap): New functions.
+       (get_base_file_bitmap): Rename get_lang_bitmap and drastically
+       simplify, relying on read_input_list to set up the bitmaps.
+       (main): Arguments are no longer unused.  Check for correct number
+       of command line arguments, set srcdir and srcdir_len, then call
+       read_input_list, before doing anything else.  No need to worry
+       about duplicates in main loop.
+       * configure.ac: Simplify the calculation of all_gtfiles.
+       Put language tags in there.  Don't set or substitute
+       all_gtfiles_files_langs or all_gtfiles_files_frags.
+       * Makefile.in: Revamp the way gengtype is invoked, now that it
+       takes a file on its command line with a much simpler format.
+       Remove or replace with gtyp-input.list all references to gtyp-gen.h.
+       (GTFILES): Remove duplicates and C source files.
+       * c-config-lang.in, cp/config-lang.in, objc/config-lang.in
+       * objcp/config-lang.in: Add c-pragma.h to gtfiles.
+       * configure: Regenerate.
+
+       * gengtype.h: Remove all type definitions to gengtype.c; leave
+       only definitions of options_p, type_p, and pair_p as opaque
+       pointers.  Update prototypes.
+       * gengtype.c: Many type definitions moved here from gengtype.h.
+       Consolidate type definitions at the top of the file.
+       (xvasprintf): Delete.
+       (xasprintf): Make static.
+       (create_nested_pointer_option): Add 'next' parameter.
+       (create_field_all, create_field_at): New functions.
+       (create_field): Now a thin wrapper around create_field_all.
+       (create_optional_field): Rename create_optional_field_ and add
+       line argument.  Original name is now a macro which supplies
+       __LINE__.
+       (oprintf): Use vsnprintf directly.
+       (close_output_files): Use fatal rather than perror/exit.
+       (note_def_vec, note_def_vec_alloc): Use create_field_at.
+       (main): Set progname.  Don't use exit.
+       * gengtype-yacc.y (struct_fields): Use create_field_at.
+       (option, optionseqopt): Delete.
+       (optionseq): Consolidate productions from option here so we
+       can use the first argument to create_option.
+
+       * gengtype-lex.l: Distinguish unions from structures in the
+       token type.  Don't call find_structure; return the tag as a string.
+       * gengtype-yacc.y: Add new token types ENT_TYPEDEF_UNION and
+       ENT_UNION.  Type of these, ENT_TYPEDEF_STRUCT, and ENT_STRUCT is
+       string.  Reorganize typedef_struct production accordingly.
+       Use create_nested_ptr_option.
+       * gengtype.c (create_nested_ptr_option): New function.
+       * gengtype.h: Declare it.
+
+       * gengtype.h (struct type): Replace 'sc' with boolean, scalar_is_char.
+       (string_type): Don't declare.
+       (do_scalar_typedef): Declare.
+       (create_scalar_type): Update prototype.
+       * gengtype.c (string_type): Make static.
+       (scalar_nonchar, scalar_char): New.
+       (do_scalar_typedef): Export.  Always use scalar_nonchar for the type.
+       (resolve_typedef): Use scalar_nonchar for error recovery.
+       (create_scalar_type): Remove name_len field.  Return scalar_char
+       or scalar_nonchar as appropriate.
+       (adjust_field_type): Look at scalar_is_char boolean to decide whether
+       to use string_type.
+       (throughout): Use scalar_nonchar instead of calling
+       create_scalar_type, whenever possible.
+       (main): Initialize scalar_char and scalar_nonchar before calling
+       gen_rtx_next.
+       * gengtype-lex.l: Adjust for removal of second argument to
+       create_scalar_type.  Use yylval.s instead of yylval.t when
+       returning SCALAR.
+       * gengtype-yacc.y: Type of SCALAR is string.  Call
+       create_scalar_type from type:SCALAR rule.  Adjust for removal of
+       second argument to create_scalar_type.
+
+       * vec.h: Remove all #if IN_GENGTYPE blocks.
+       Add comment saying that changes may require adjustments to gengtype.
+       * gengtype.c: Don't include coretypes.h or tm.h.
+       Add comment to inclusion of errors.h.
+       (note_def_vec, note_def_vec_alloc): New functions.
+       * gengtype.h: Declare new functions.
+       * gengtype-lex.l: Don't include coretypes.h.
+       (YY_INPUT, macro_input, push_macro_expansion, mangle_macro_name):
+       Delete.
+       (update_lineno): Remove unnecessary prototype.
+       (DEF_VEC_* rules): Simplify using note_def_vec / note_def_vec_alloc.
+       (VEC rule): Just return VEC_TOKEN.
+       * gengtype-yacc.y (VEC_TOKEN): New token type.
+       (type): Add a production for VEC(a,b).
+       * Makefile.in: Update dependencies.
+
+       * gengtype-lex.l: Remove rules for parsing pointer-to-function
+       typedefs that use the old PARAMS macro.
+
+       * gengtype-lex.l: Remove all rules and states relating to yacc
+       input files.
+       * gengtype-yacc.y: Similarly.
+       * gengtype.c (note_yacc_type): Delete function.
+       * gengtype.h: Update prototypes.
+
+2007-03-26  Joseph Myers  <joseph@codesourcery.com>
+
+       * tree-pretty-print.c (dump_generic_node): Report precision of
+       unnamed integer types.
+
+2007-03-26  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * ifcvt.c (noce_try_store_flag_constants): Don't check
+       no_new_pseudos here.
+       (noce_try_store_flag_constants): Don't check no_new_pseudos.
+       (noce_try_addcc, noce_try_store_flag_mask, noce_try_cmove_arith,
+       noce_try_cmove_arith, noce_try_minmax, noce_try_abs,
+       noce_try_sign_mask): Likewise.
+       (if_convert): Check no_new_pseudos here.
+
+       (cond_exec_process_if_block, noce_process_if_block, find_if_block):
+       Remove prototypes.
+       (struct noce_if_info): Add then_bb, else_bb, join_bb members.
+       (noce_get_condition): Handle new then_else_reversed argument.
+       (noce_init_if_info): Remove, fold into noce_find_if_block.
+       (noce_process_if_block): Take a struct noce_if_info as the
+       argument.  Don't set up one based on ce_if_info.  Update pointer
+       references accordingly.
+       (cond_move_process_if_block): Likewise.
+       (process_if_block): Removed.
+       (find_if_block): Removed.  Move functionality two new functions,
+       noce_find_if_block and cond_exec_find_if_block.
+       (noce_find_if_block): New function.  Be aware of IF-THEN-JOIN
+       blocks and the symmetric IF-ELSE-JOIN case.
+       (cond_exec_find_if_block): Also new function mostly based on old
+       find_if_block and process_if_block.
+       (find_if_header): Replace find_if_block call with separately
+       guarded calls to noce_find_if_block and cond_exec_find_if_block.
+       (find_cond_trap): Update noce_get_condition call.
+       (dead_or_predicable): Likewise.
+
+2007-03-26  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/i386/i386.c (IX86_BUILTIN_CMPNEPD, IX86_BUILTIN_CMPNESD):
+       Remove.
+       (IX86_BUILTIN_PSLLW128, IX86_BUILTIN_PSLLD128, IX86_BUILTIN_PSLLQ128,
+       IX86_BUILTIN_PSRAW128, IX86_BUILTIN_PSRAD128, IX86_BUILTIN_PSRLW128,
+       IX86_BUILTIN_PSRLD128, IX86_BUILTIN_PSRLQ128): Remove.
+       (ix86_init_mmx_sse_builtins): Remove v8hi_ftype_v8hi_v2di and
+       v4si_ftype_v4si_v2di.  Remove __builtin_ia32_psllw128,
+       __builtin_ia32_pslld128, __builtin_ia32_psllq128,
+       __builtin_ia32_psrlw128, __builtin_ia32_psrld128,
+       __builtin_ia32_psrlq128, __builtin_ia32_psraw128 and
+       __builtin_ia32_psrad128 builtins.
+
+2007-03-26  Uros Bizjak  <ubizjak@gmail.com>
+
+       * reg-stack.c (replace_reg): Use IN_RANGE macro in gcc_assert().
+       * config/i386/constraints.md
+       (define_constraint "I"): Use IN_RANGE macro.
+       (define_constraint "J"): Ditto.
+       (define_constraint "K"): Ditto.
+       (define_constraint "M"): Ditto.
+       (define_constraint "N"): Ditto.
+       (define_constraint "O"): Ditto.
+       * config/i386/predicates.md
+       (define_predicate "register_no_elim_operand"): Use IN_RANGE macro.
+       (define_predicate "const_0_to_3_operand"): Ditto.
+       (define_predicate "const_0_to_7_operand"): Ditto.
+       (define_predicate "const_0_to_15_operand"): Ditto.
+       (define_predicate "const_0_to_63_operand"): Ditto.
+       (define_predicate "const_0_to_255_operand"): Ditto.
+       (define_predicate "const_1_to_31_operand"): Ditto.
+       (define_predicate "const_2_to_3_operand"): Ditto.
+       (define_predicate "const_4_to_7_operand"): Ditto.
+
+2007-03-25  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/rs6000.c (rs6000_emit_prologue): Always clobber LR
+       in SImode for save_world.
+       * config/rs6000/altivec.md (save_world, restore_world): Convert to
+       LR hard reg.
+
+2007-03-25  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/30784
+       * fold-const.c (fold_ternary): Handle CONSTRUCTOR in case
+       BIT_FIELD_REF.
+
+2007-03-25  Revital Eres  <eres@il.ibm.com>
+
+       * tree-if-conv.c (if_convertible_gimple_modify_stmt_p):
+         Fold movement_possibility function into it.
+
+2007-03-25  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/darwin.md (load_macho_picbase): Ignore operand 0.
+       (load_macho_picbase_{si,di}): Convert to LR hard reg.
+       (call_indirect_nonlocal_darwin64): Same.
+       (call_nonlocal_darwin64): Same.
+       (call_value_indirect_nonlocal_darwin64): Same.
+       (call_value_nonlocal_darwin64): Same.
+       (sibcall_nonlocal_darwin64): Same.
+       (sibcall_value_nonlocal_darwin64): Same.
+       (sibcall_symbolic_64): Same.
+       (sibcall_value_symbolic_64): Same.
+       * config/rs6000/rs6000.c (rs6000_legitimize_tls_address): Remove
+       LR pseudo.
+       (rs6000_emit_load_toc_table): Same.
+       * config/rs6000/altivec.md (restore_world): Convert to LR hard reg.
+       * config/rs6000/rs6000.md (mulh_call): Convert to LR hard reg.
+       (mull_call): Same.
+       (divss_call): Same.
+       (divus_call): Same.
+       (quoss_call): Same.
+       (quous_call): Same.
+       (load_toc_v4_pic_si): Same
+       (load_toc_v4_PIC_1): Same.
+       (load_toc_v4_PIC_1b): Same.
+       (call_indirect_aix{32,64}): Same.
+       (call_value_indirect_aix{32,64}): Same.
+       (call): Same.
+       (call_value): Same.
+       (call_local{32,64}): Same.
+       (call_value_local{32,64}): Same.
+       (call_indirect_nonlocal_aix{32,64}): Same.
+       (call_nonlocal_aix{32,64}): Same.
+       (call_value_indirect_nonlocal_aix{32,64}): Same.
+       (call_value_nonlocal_aix{32,64}): Same.
+       (call_indirect_nonlocal_sysv<mode>): Same.
+       (call_nonlocal_sysv<mode>): Same.
+       (call_value_indirect_nonlocal_sysv<mode>): Same.
+       (call_value_nonlocal_sysv<mode>): Same.
+       (sibcall): Same.
+       (sibcall_local{32,64}): Same.
+       (sibcall_value_local{32,64}): Same.
+       (sibcall_nonlocal_aix{32,64}): Same.
+       (sibcall_value_nonlocal_aix{32,64}): Same.
+       (sibcall_nonlocal_sysv<mode>): Same.
+       (sibcall_value): Same.
+       (sibcall_value_nonlocal_sysv<mode>): Same.
+
+2007-03-24  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/lib1funcs.asm (div0): Use ARM_FUNC_START and do_push.
+       * config/arm/linux-eabi.h: Remove legacy syscall hack.
+
+2007-03-24  Richard Henderson  <rth@redhat.com>
+
+       * config/ia64/constraints.md: New file.
+       * config/ia64/predicates.md: Replace CONST_OK_FOR_? with
+       satisfies_constraint_?.
+       * config/ia64/ia64.c (ia64_move_ok, ia64_legitimate_constant_p,
+       ia64_reload_gp, spill_restore_mem, ia64_expand_prologue,
+       ia64_expand_epilogue, ia64_split_return_addr_rtx, ia64_rtx_costs,
+       ia64_output_mi_thunk): Likewise.
+       (ia64_const_ok_for_letter_p): Remove.
+       (ia64_const_double_ok_for_letter_p): Remove.
+       (ia64_extra_constraint): Remove.
+       * config/ia64/ia64.h (REG_CLASS_FROM_LETTER): Remove.
+       (CONST_OK_FOR_I, CONST_OK_FOR_J, CONST_OK_FOR_K, CONST_OK_FOR_L,
+       CONST_OK_FOR_M, CONST_OK_FOR_N, CONST_OK_FOR_O, CONST_OK_FOR_P,
+       CONST_OK_FOR_LETTER_P, CONST_DOUBLE_OK_FOR_G,
+       CONST_DOUBLE_OK_FOR_LETTER_P, EXTRA_CONSTRAINT,
+       EXTRA_MEMORY_CONSTRAINT): Remove.
+       * config/ia64/ia64.md: Include constriants.md.  Replace
+       CONST_OK_FOR_? with satisfies_constraint_?.
+
+2007-03-23  Michael Meissner  <michael.meissner@amd.com>
+           H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/dfp-bit.h (DPD_BID_NAME): New macro to give either the
+       DPD or BID name.
+       (name macros): Use DPD_BID_NAME to convert names properly.
+
+       * optabs.c (DECIMAL_PREFIX): Prefix string to use for the current
+       decimal floating point format.
+       (init_floating_libfuncs): Change decimal functions so that they
+       have a "bid_" prefix if the decimal system uses the BID format,
+       and "dpd_" prefix if the decimal system uses the DPD format.
+       (init_interclass_conv_libfuncs): Ditto.
+       (init_intraclass_conv_libfuncs): Ditto.
+
+       * config.in (ENABLE_DECIMAL_BID_FORMAT): New macro to say we are
+       using the BID format.
+
+       * configure.ac (ENABLE_DECIMAL_BID_FORMAT): Set to 1/0 to say
+       whether we are using the BID decimal format.
+       * configure: Regenerate.
+
+       * c-cppbuiltin.c (c_cpp_builtins): Define __STDC_WANT_DEC_FP__ if
+       the compiler has decimal floating point enabled.  Define
+       __DECIMAL_BID_FORMAT__ if BID decimal floating point is used
+       instead of DPD.
+
+       * config.in (ENABLE_DECIMAL_BID_FORMAT): New macro to say we are
+       using the BID format.
+
+       * configure.ac (ENABLE_DECIMAL_BID_FORMAT): Set to 1/0 to say
+       whether we are using the BID decimal format.
+       * configure: Regenerate.
+
+       * c-cppbuiltin.c (c_cpp_builtins): Define __STDC_WANT_DEC_FP__ if
+       the compiler has decimal floating point enabled.  Define
+       __DECIMAL_BID_FORMAT__ if BID decimal floating point is used
+       instead of DPD.
+
+       * doc/install.texi (--enable-decimal-float): Document BID and DPD
+       options, and that it is enabled for i386/x86_64 systems.
+
+       * Makefile.in (enable_decimal_float): New.
+       (DECNUMFMT): New.
+       (DECNUMINC): Add  -I$(DECNUMFMT).
+       (DECNUM_H): Mov decimal32.h, decimal64.h and decimal128.h
+       to $(DECNUMFMT) from $(DECNUM).
+
+       * configure.ac: Support * --enable-decimal-float={no,yes,bid,dpd}.
+       Substitute enable_decimal_float.
+       * configure: Regenerated.
+
+       PR other/30529
+       * config/dfp-bit.c (__dec_byte_swap): Use uint32_t instead of
+       unsigned long.
+
+       * configure.ac: Enable decimal float for x86_64-*-linux*.
+       * configure: Regenerated.
+
+       PR other/30530
+       * dfp.c (decimal_real_arithmetic): Use decimal128FlipSign and
+       decimal128ClearSign to flip and clear the sign bit in decimal128.
+       (decimal_real_maxval): Set decimal128SetSign to set the sign
+       bit in decimal128.
+
+2007-03-23  Ian Lance Taylor  <iant@google.com>
+
+       * fold-const.c (fold_binary): Correct warning for X - c >= X.
+
+2007-03-23  Ian Lance Taylor  <iant@google.com>
+
+       * tree-dump.c (dump_files): Correct comment.
+
+2007-03-23  Ian Lance Taylor  <iant@google.com>
+
+       * tree-vrp.c (operand_less_p): Ignore fold overflow warnings.
+
+2007-03-23  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * tracer.c (tracer): Don't take FLAGS argument.  Assert we are
+       in cfglayout mode.  Don't go into and out of cfglayout mode.
+       Link the blocks in the order of the constructed traces.
+       (rest_of_handle_tracer): Adjust call to tracer.
+       * loop-init.c (rtl_loop_init): Assert we are in cfglayout mode.
+       Don't go into cfglayout mode.
+       (rtl_loop_done): Don't go out of cfglayout mode.
+       * cfglayout.c (relink_block_chain): New function, split out from...
+       (fixup_reorder_chain): ...here.  Remove redundant checking.
+       (cfg_layout_finalize): Don't clear the header, footer, and aux
+       fields here, move the code to do so to relink_block_chain.  Likewise
+       for free_original_copy_tables.
+       * rtl.h (tracer): Update prototype.
+       * bb-reorder.c (reorder_basic_blocks): Don't take FLAGS argument.
+       Assert we are in cfglayout mode.  Don't go into and out of cfglayout
+       mode.  Use relink_block_chain to serialize the CFG according to the
+       new basic block order.  Move targetm.cannot_modify_jumps_p check from
+       here...
+       (gate_handle_reorder_blocks): ...to here.
+       (duplicate_computed_gotos): Move targetm.cannot_modify_jumps_p check
+       from here...
+       (gate_duplicate_computed_gotos): ...to here.
+       (rest_of_handle_reorder_blocks): Don't see if anything has changed,
+       something always changes when going into and out of cfglayout mode.
+       Perform an expensive cfg cleanup while going into cfglayout mode.
+       Always update liveness information on HAVE_conditional_execution
+       targets.  Reserialize the basic blocks and go out of cfglayout mode.
+       * reg-stack.c: Include cfglayout.h.
+       (rest_of_handle_stack_regs): Go into and out of cfglayout mode around
+       the call to reorder_basic_blocks.
+       * basic-block.h (reorder_basic_blocks): Update prototype.
+       (relink_block_chain): New prototype.
+       * passes.c (pass_outof_cfg_layout_mode): Move after cse2.
+
+2007-03-23  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/mips/mips.md (type, hazard, *movdi_32bit,
+       *movdi_gp32_fp64, *movdi_64bit, *movsi_internal, movcc,
+       *movhi_internal, *movqi_internal, *movsf_hardfloat,
+       *movdf_hardfloat_64bit, *movdf_hardfloat_32bit, *movdf_softfloat,
+       movv2sf_hardfloat_64bit, load_df_low, load_df_high, store_df_high,
+       mthc1, mfhc1): Change xfer instruction type to mfc and mtc, as
+       applicable.
+       (movcc): Change first xfer to multi.
+       * config/mips/24k.md, config/mips/4100.md, config/mips/4300.md,
+       config/mips/5000.md, config/mips/5400.md, config/mips/5500.md,
+       config/mips/5k.md, config/mips/7000.md, config/mips/9000.md,
+       config/mips/generic.md: Change reservations using "xfer" to use
+       "mfc,mtc".
+       * config/mips/sb1.md (ir_sb1_mtxfer): Use "mtc" instead of
+       using match_operand.
+       (ir_sb1_mfxfer): Use "mfc" instead of using match_operand.
+       * config/mips/sr71k.md (ir_sr70_xfer_from): Use "mfc" instead of
+       examining mode.
+       (ir_sr70_xfer_to): Use "mtc" instead of examining mode.
+
+2007-03-22  Richard Henderson  <rth@redhat.com>
+
+       * config/i386/i386.c: Remove unnecessary function declarations.
+       Move targetm definition, and all related macros, to the end of
+       the file.  Resort some functions to put definitions before uses.
+       (ix86_attribute_table): Make static.  Move to end of file.
+       (ix86_gimplify_va_arg): Make static.
+
+2007-03-22  Richard Henderson  <rth@redhat.com>
+
+       * config/i386/i386.c (ix86_function_regparm): Early exit for 64-bit;
+       don't increase local_regparm with force_align_arg_pointer check.
+       (ix86_function_sseregparm): Assert 32-bit.
+       (type_has_variadic_args_p): New.
+       (ix86_return_pops_args): Early exit for 64-bit.  Reindent; use
+       type_has_variadic_args_p.
+       (ix86_function_arg_regno_p): Use == 0 instead of ! test for eax.
+       (init_cumulative_args): Remove TARGET_DEBUG_ARG.  Remove zero_cum;
+       use memset instead.  Do maybe_vaarg check first; skip attribute
+       tests if true; skip attribute tests for 64-bit.
+       (construct_container): Remove TARGET_DEBUG_ARG.
+       (function_arg_advance_32, function_arg_advance_64): Split out ...
+       (function_arg_advance): ... from here.
+       (function_arg_32, function_arg_64): Split out ...
+       (function_arg): ... from here.
+       (ix86_pass_by_reference): Tidy.
+       (ix86_function_value_regno_p): Rearrange w/ switch on regno.
+       (function_value_32): New, from parts of ix86_function_value
+       and ix86_value_regno.
+       (function_value_64): New, from parts of ix86_function_value
+       and ix86_libcall_value.
+       (ix86_function_value_1): New.
+       (ix86_function_value, ix86_libcall_value): Use it.
+       (return_in_memory_32, return_in_memory_64): Split out ...
+       (ix86_return_in_memory): ... from here.
+       (ix86_struct_value_rtx): Skip for 64-bit.
+       (ix86_libcall_value, ix86_value_regno): Remove.
+       (setup_incoming_varargs_64): Split out ...
+       (ix86_setup_incoming_varargs): ... from here.
+       (ix86_va_start): Remove TARGET_DEBUG_ARG.
+       (legitimate_address_p, legitimize_address): Remove TARGET_DEBUG_ADDR.
+       * config/i386/i386-protos.h (ix86_function_value): Remove.
+       * config/i386/i386.opt (TARGET_DEBUG_ADDR, TARGET_DEBUG_ARG): Remove.
+
+2007-03-22  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR other/23572
+       * c-lex.c (interpret_float): On overflow, emit pedantic warning if
+       infinities not supported, otherwise emit warning if -Woverflow. On
+       underflow, emit warning if -Woverflow.
+       * real.c (real_from_string): Return -1 if underflow, +1 if overflow
+       and 0 otherwise.
+       * real.h (real_from_string): Update declaration
+
+2007-03-22  Kai Tietz  <kai.tietz@onevision.com>
+           Richard Henderson  <rth@redhat.com>
+
+       * defaults.h (OUTGOING_REG_PARM_STACK_SPACE): Provide default.
+       * calls.c (compute_argument_block_size, expand_call,
+       emit_library_call_value_1): Don't ifdef OUTGOING_REG_PARM_STACK_SPACE.
+       * expr.c (block_move_libcall_safe_for_call_parm): Likewise.
+       * function.c (STACK_DYNAMIC_OFFSET): Likewise.
+       * doc/tm.texi (OUTGOING_REG_PARM_STACK_SPACE): Update.
+       * config/alpha/unicosmk.h, config/bfin/bfin.h, config/iq2000/iq2000.h,
+       config/mips/mips.h, config/mn10300/mn10300.h, config/mt/mt.h,
+       config/pa/pa.h, config/rs6000/rs6000.h, config/score/score.h,
+       config/spu/spu.h, config/v850/v850.h (OUTGOING_REG_PARM_STACK_SPACE):
+       Set to 1.
+
+2007-03-22  Joseph Myers  <joseph@codesourcery.com>
+
+       * c-incpath.c (add_sysroot_to_chain): New.
+       (merge_include_chains): Add sysroot argument.  Call
+       add_sysroot_to_chain if sysrooted.
+       (register_include_chains): Update call to merge_include_chains.
+       * doc/cppopts.texi: Document use of '=' in include directory
+       arguments.
+
+2007-03-22  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (cmp<mode>): Rename from cmpsf and cmpdf.
+       Macroize expander using SSEMODEF mode macro.  Use SSE_FLOAT_MODE_P.
+       (*cmpfp_<mode>): Rename from *cmpfp_sf and *cmpfp_df. Macroize
+       insn pattern using X87MODEF12 mode macro.
+
+2007-03-21  Seongbae Park <seongbae.park@gmail.com>
+
+       * regmove.c (regmove_optimize): Use reg_mentioned_p
+       instead of reg_overlap_mentioned_p for DST.
+
+2007-03-21  Mike Stump  <mrs@apple.com>
+
+       * c.opt: Fixup for Objective-C/C++.
+
+2007-03-21  Steve Ellcey  <sje@cup.hp.com>
+
+       * explow.c (convert_memory_address): Fold memory reference when
+       POINTERS_EXTEND_UNSIGNED < 0
+
+2007-03-21  Richard Henderson  <rth@redhat.com>
+
+       PR target/31245
+       * config/i386/emmintrin.h (__m128i, __m128d): Mark may_alias.
+       * config/i386/mmintrin.h (__m64): Likewise.
+       * config/i386/xmmintrin.h (__m128): Likewise.
+
+2007-03-21  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/vxworks.h (VXWORKS_ADDITIONAL_CPP_SPEC): Remove -D options.
+       (VXWORKS_OS_CPP_BUILTINS): Define.
+       * config/i386/vxworks.h (VXWORKS_CPU_DEFINE): Fold into...
+       (TARGET_OS_CPP_BUILTINS): ...here.  Use VXWORKS_OS_CPP_BUILTINS.
+
+2007-03-21  Richard Sandiford  <richard@codesourcery.com>
+
+       * rtl.h (constant_pool_reference_p): Delete.
+       (find_constant_src): Declare.
+       * rtlanal.c (find_constant_src): New function.
+       * simplify-rtx.c (constant_pool_reference_p): Delete.
+       * config/i386/i386.md: Use find_constant_src instead of
+       constant_pool_reference_p/avoid_constant_pool_reference pairs.
+
+2007-03-21  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi (-fpie, -fPIE): Document __pie__ and __PIE__.
+       * c-cppbuiltin.c (c_cpp_builtins): Define them.
+
+2007-03-20  Mark Mitchell  <mark@codesourcery.com>
+
+       * config/arm/elf.h (TARGET_ASM_DESTRUCTOR): Define.
+       * config/arm/arm.c (arm_elf_asm_cdtor): New function.
+       (arm_elf_asm_constructor): Use it.
+       (arm_elf_asm_destructor): New function.
+
+2007-03-20  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * jump.c (mark_jump_label): Treat SEQUENCE specially.
+
+2007-03-20  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/vxlib.c (tls_delete_hook): Use TCB for kernel tasks.
+
+2007-03-19  Andrew Haley  <aph@redhat.com>
+
+       PR tree-optimization/31264
+       * tree-vrp.c (register_edge_assert_for_1): Don't look though
+       VIEW_CONVERT_EXPRs.
+
+2007-03-19  Paolo Bonzini  <bonzini@gnu.org>
+
+       PR rtl-optimization/30907
+       * fwprop.c (forward_propagate_into): Never propagate inside a loop.
+       (fwprop_init): Always call loop_optimizer_initialize.
+       (fwprop_done): Always call loop_optimizer_finalize.
+       (fwprop): We always have loop info now.
+       (gate_fwprop_addr): Remove.
+       (pass_fwprop_addr): Use gate_fwprop as gate.
+
+       PR rtl-optimization/30841
+       * df-problems.c (df_ru_local_compute, df_rd_local_compute,
+       df_chain_alloc): Call df_reorganize_refs unconditionally.
+       * df-scan.c (df_rescan_blocks, df_reorganize_refs): Change
+       refs_organized to refs_organized_size.
+       (df_ref_create_structure): Use refs_organized_size instead of
+       bitmap_size if refs had been organized, and keep refs_organized_size
+       up-to-date.
+       * df.h (struct df_ref_info): Change refs_organized to
+       refs_organized_size.
+       (DF_DEFS_SIZE, DF_USES_SIZE): Use refs_organized_size instead of
+       bitmap_size.
+
+2007-03-19  Mark Mitchell  <mark@codesourcery.com>
+
+       * except.c (output_function_exception_table): Do not reference the
+       EH personality routine for functions that do not require an
+       exception table.
+
+2007-03-20  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/30762
+       * c-typeck.c (convert_for_assignment): Call comptypes for
+       RECORD_TYPE or UNION_TYPE.
+
+       PR inline-asm/30505
+       * reload1.c (reload): Do invalid ASM checking after
+       cleanup_subreg_operands.
+
+2007-03-19  Jeff Law  <law@redhat.com>
+
+       * tree-cfg.c (find_taken_edge): Tighten conditions for
+       optimizing computed gotos.
+
+2007-03-19  Michael Matz  <matz@suse.de>
+
+       * builtins.c (expand_builtin_sync_operation,
+       expand_builtin_compare_and_swap,
+       expand_builtin_lock_test_and_set): Care for extending CONST_INTs
+       correctly.
+
+       * config/i386/sync.md (sync_double_compare_and_swapdi_pic,
+       sync_double_compare_and_swap_ccdi_pic): Use "SD" as constraint
+       for operand 3.
+
+2007-03-19  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * doc/tm.texi: Add brackets around the return type of
+       TARGET_SECONDARY_RELOAD.
+
+2007-03-19  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+       Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31254
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr_1):
+       Use handled_component_p () where appropriate.  Continue
+       propagating into the rhs if we propagated into an INDIRECT_REF
+       on the lhs.
+
+2007-03-19  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md (op_type attribute): RRR instruction type added.
+       (FP, DFP, SD_SF, DD_DF, TD_TF): New mode macros.
+       (xde, xdee): Mode attributes adjusted to support DFP modes.
+       (RRer, f0, op1, Rf, bt, bfp, HALF_TMODE): New mode attributes added.
+       ("cmp<mode>", "*cmp<mode>_css_0", "*cmp<mode>_ccs", TF move splitters,
+       DF move splitters, "floatdi<mode>2", "add<mode>3", "*add<mode>3",
+       "*add<mode>3_cc", "*add<mode>3_cconly", "sub<mode>3", "*sub<mode>3",
+       "*sub<mode>3_cc", "*sub<mode>3_cconly", "mul<mode>3", "*mul<mode>3",
+       "div<mode>3", "*div<mode>3", "*neg<mode>2_nocc", "*abs<mode>2_nocc",
+       "*negabs<mode>2_nocc", "copysign<mode>3"): Adjusted to support DFP
+       numbers.
+       ("*movtf_64", "*movtf_31", "*movdf_64dfp", "*movdf_64", "*movdf_31",
+       "movsf"): Insn definitions removed.
+       ("*mov<mode>_64", "*mov<mode>_31", "mov<mode>", "*mov<mode>_64dfp",
+       "*mov<mode>_64", "*mov<mode>_31", "fix_trunc<DFP:mode>di2",
+       "trunctddd2", "truncddsd2", "extendddtd2", "extendsddd2"): Insn
+       definitions added.
+       ("fixuns_truncdddi2", "fixuns_trunctddi2", "mov<mode>",
+       "reload_in<mode>", "reload_out<mode>"): Expander added.
+       ("movtf", "movdf", "reload_outtf", "reload_outdf", "reload_intf"):
+       Expander removed.
+
+2007-03-19  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md: Only non-functional changes.  Renamed
+       FPR mode macro to BFP all over the file.
+
+2007-03-19  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.md (UNSPEC_COPYSIGN): New constant.
+       (op_type attribute): RRF instruction type added.
+       (fT0): New mode attribute.
+       ("*movdi_64dfp", "*movdf_64dfp", "*neg<mode>2_nocc", "*abs<mode>2_nocc",
+       "*negabs<mode>2_nocc", "copysign<mode>3"): Insn definitions added.
+       * config/s390/s390.h (SECONDARY_MEMORY_NEEDED): Due to a new
+       instruction no secondary memory is needed when moving DFmode values
+       between GPRs and FPRs.
+
+2007-03-19  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.opt ("mhard-float", "msoft-float"): Bit value
+       inverted and documentation adjusted.
+       ("mhard-dfp", "msoft-dfp"): New options.
+       * config/s390/s390.c (s390_handle_arch_option): New architecture
+       switch: z9-ec.
+       (override_options): Sanity checks for the new options added.
+       * config.gcc: New architecture switch: z9-ec.
+       * config/s390/s390.h (processor_flags): PF_DFP added.
+       (TARGET_CPU_DFP, TARGET_DFP): Macro definitions added.
+       (TARGET_DEFAULT): Due to the s390.opt changes hard float is enabled
+       when the bit is NOT set so remove it from the defaults.
+
+2007-03-19  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * genemit.c (main): Print include statement for dfp.h.
+       * dfp.h (decimal_real_arithmetic): Hide prototype if tree_code enum
+       is not available.
+
+2007-03-19  Hans-Peter Nilsson  <hp@axis.com>
+
+       * config/cris/t-elfmulti (EXTRA_MULTILIB_PARTS): Do not define here.
+
+2007-03-19  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/31022
+       * config/sh/sh.c (sh_adjust_cost): Use the result of single_set
+       instead of PATTERN.
+
+2007-03-18  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.c (output_deferred_plabels, output_bb, output_millicode_call,
+       attr_length_call, output_call, output_indirect_call): Cleanup
+       formatting of targetm calls.
+
+2007-03-19  Hans-Peter Nilsson  <hp@axis.com>
+
+       * config/cris/cris.h (HANDLE_PRAGMA_PACK_PUSH_POP): Define to 1.
+
+2007-03-18  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.md: Add fpstore_load and store_fpload instruction types.  Provide
+       reservation, bypass and anti-bypass descriptions for these
+       instructions.  Update move patterns.
+       * pa.c (hppa_fpstore_bypass_p): Check for both TYPE_FPSTORE_LOAD and
+       TYPE_FPSTORE.
+
+2007-03-18  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * tree-vect-transform.c (get_initial_def_for_induction): Replace
+       GET_MODE_NUNITS with TYPE_VECTOR_SUBPARTS.
+       (get_initial_def_for_reduction): Likewise.
+
+2007-03-16  Daniel Berlin  <dberlin@dberlin.org>
+
+       Fix PR tree-optimization/29922
+       * tree-ssa-pre.c (bb_bitmap_sets): Remove RVUSE_* members.
+       (get_representative): Removed.
+       (value_dies_in_block_x): Update for rvuse removal.
+       (valid_in_sets): Update for renaming of vuses_dies_in_block_x.
+       (compute_antic_aux): Handle when PHI nodes appear in
+       non-single-successors.
+       (dump_bitmap_of_names): Removed.
+       (compute_antic_safe): Renamed and removed rvuse calculation.
+       Calculate only antic safe.
+       (insert_into_preds_of_block): Remove assert.
+       (execute_pre): Update for renamed functions.
+       (defer_or_phi_translate_block): New function.
+
+2007-03-17  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/arm/arm.c, config/arm/thumb2.md, config/m68k/m68k.c,
+       config/spu/spu.c, omega.h, passes.c, predict.c: Fix comment
+       typos.
+       * doc/cpp.texi, doc/extend.texi, doc/invoke.texi: Fix typos.
+       Follow spelling conventions.
+
+       * tree-data-ref.h: Remove the prototype for analyze_array.
+
+2007-03-17  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/31041
+       * tree-vect-transform.c (get_initial_def_for_induction): Call
+       force_gimple_operand.
+
+2007-03-17  Olga Golovanevsky  <olga@il.ibm.com>
+
+       * ipa-type-escape.c (look_for_casts) : Revert code to use
+       handled_component_p due to ada test a-numaux.adb.
+
+2007-03-17  Kazu Hirata  <kazu@codesourcery.com>
+
+       * final.c (final_scan_insn): Alter the condition of a
+       conditional trap if we have nonstandard CC.
+
+2007-03-16  Alexandre Oliva  <aoliva@redhat.com>
+
+       * configure.ac: Remove excess quoting from asm line 0 test.
+       * configure: Rebuilt.
+
+2007-03-16  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * doc/invoke.texi (-Wconversion): Document warnings specific to C++.
+       * c-common.c (convert_and_check): Move warning logic to...
+       (warnings_for_convert_and_check): ...here. Define.
+       * c-common.h (warnings_for_convert_and_check): Declare.
+
+2007-03-16  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.c (attr_length_call): Partially revert change of 2007-03-09.
+       (output_call): Likewise.
+
+2007-03-16  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/vxworks.h (SUPPORTS_INIT_PRIORITY): Define.
+
+2007-03-16  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/vx-common.h (WINT_TYPE, WINT_TYPE_SIZE): Define.
+
+2007-03-16  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (override_options): Add PTA_NO_SAHF to k8,
+       opteron, athlon-64 and athlon-fx processor_alias_table entries.
+
+2007-03-16  Sebastian Pop  <sebastian.pop@inria.fr>
+
+       PR tree-optimization/31183
+       * tree-loop-linear.c (gather_interchange_stats, try_interchange_loops):
+       Use double_int instead of unsigned int for representing access_strides.
+       * testsuite/gcc.dg/tree-ssa/pr31183.c: New.
+
+2007-03-16  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31146
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Restructure
+       to allow recursion of forward_propagate_addr_expr.
+       (forward_propagate_addr_into_variable_array_index): Likewise.
+       (forward_propagate_addr_expr): Likewise.
+       (tree_ssa_forward_propagate_single_use_vars): Likewise.
+       (forward_propagate_addr_expr_1): Recurse on simple copies
+       instead of propagating into them.  Do so for useless conversions
+       as well.
+       (forward_propagate_addr_expr): Clean up unused statements after
+       recursion.
+
+2007-03-16  Richard Guenther  <rguenther@suse.de>
+
+       * builtins.c (expand_builtin_cexpi): Use the right argument
+       for the expansion via cexp.
+
+2007-03-16  Alexandre Oliva  <aoliva@redhat.com>
+
+       * configure.ac: Don't require ELF binutils to tolerate # 0 "".
+       * configure: Rebuilt.
+
+2007-03-16  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR debug/29906
+       * dwarf2out.c (force_type_die): Adjust comment.
+       (dwarf2out_imported_module_or_decl): Handle base AT_import types.
+
+2007-03-15  DJ Delorie  <dj@redhat.com>
+
+       * config/frv/predicates.md (minmax_operator): Don't check operands
+       here.
+
+2007-03-15  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-niter.c (record_estimate): Add "upper" argument.
+       Update constant estimates of number of iterations.
+       (record_nonwrapping_iv): Add "upper" argument.  "data_size_bounds_p"
+       argument renamed to "realistic".
+       (compute_estimated_nb_iterations): Removed.
+       (record_niter_bound): New function.
+       (idx_infer_loop_bounds): For possible but unlikely tail arrays,
+       call record_nonwrapping_iv with upper = false.
+       (infer_loop_bounds_from_signedness): Pass upper argument to
+       record_nonwrapping_iv.
+       (estimate_numbers_of_iterations_loop): Do not call
+       compute_estimated_nb_iterations.  Record estimate based on profile
+       information.  Initialize the constant estimates of number of
+       iterations.
+       * tree-data-ref.c (estimated_loop_iterations): Return the recorded
+       estimates.
+       * tree-ssa-loop-prefetch.c (loop_prefetch_arrays): Add dump when
+       number of iterations is too small.
+       * cfgloop.h (struct nb_iter_bound): Remove "realistic" field.
+       (EST_NOT_AVAILABLE): Removed.
+       (struct loop): Replace estimated_nb_iterations by any_upper_bound,
+       nb_iterations_upper_bound, any_estimate and nb_iterations_estimate
+       fields.
+
+2007-03-15  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-niter.c (refine_bounds_using_guard, bound_difference):
+       Handle NE_EXPR guards.
+
+2007-03-15  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c++/24924
+       * c-opts.c (c_common_post_options): Handle C++ post-processing here.
+       Set also -pedantic-errors by default for the  preprocessor unless
+       -fpermissive is given.
+
+2007-03-15  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/29719
+       PR middle-end/31161
+       * builtins.c (expand_builtin_cexpi): As a fallback if we
+       don't have builtins for sincos or cexp create a function
+       declaration for cexp and expand to a call to that.
+       (expand_builtin_int_roundingfn): Always fall
+       back to floor/ceil and its variants even if they may be
+       not available.
+
+2007-03-15  Steven Bosscher  <steven@gcc.gnu.org>
+
+       PR middle-end/31159
+       * cfglayout.c (fixup_reorder_chain): Postpone deleting dead
+       jump tables, move the call to delete_dead_jumptables from here...
+       (cfg_layout_finalize): ...to here.  But rebuild jump labels first.
+       * cfgrtl.c (cfg_layout_can_merge_blocks_p): When not optimizing,
+       don't allow merging of blocks that try_redirect_by_replacing_jump
+       also does not handle when not optimizing.
+
+2007-03-15  Uros Bizjak  <ubizjak@gmail.com>
+           Francois-Xavier Coudert  <coudert@clipper.ens.fr>
+
+       * config/i386/i386.md (x86_sahf_1): Correctly handle
+       HAVE_AS_IX86_SAHF.
+
+2007-03-15  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/31167
+       * config/i386/i386.md (*addti3_1, *addti3_1 splitter): Use
+       x86_64_general_operand as operand[2] predicate.  Remove "iF"
+       from operand constraints and use "e" constraint instead.
+       (*subti3_1, *subti3_1 splitter): Ditto.
+       (*negti2_1, *negti2_1 splitter): Use nonimmediate_operand as
+       operand[1] predicate.
+
+2007-03-14  Sebastian Pop  <sebastian.pop@inria.fr>
+
+       * tree-loop-linear.c (gather_interchange_stats): For multidimensional
+       arrays, multiply the access strides by the size of the sub-array.
+       * testsuite/gcc.dg/tree-ssa/ltrans-5.c: New.
+
+2007-03-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       * configure.ac (HAVE_AS_IX86_SAHF): On x86 targets check whether
+       the configured assembler supports the sahf mnemonic.
+       * configure: Regenerate.
+       * config.in: Regenerate.
+
+       * config/i386/i386.md (x86_sahf_1): Depending on HAVE_AS_IX86_SAHF,
+       emit "sahf" or ".byte\t0x9e" as asm template.
+
+2007-03-14  Michael Meissner  <michael.meissner@amd.com>
+
+       PR 31018
+       * config/i386/i386.h (X86_TUNE_SHORTEN_X87_SSE): New tuning
+       option to replace hard coded TARGET_xxx in md file.
+       (X86_TUNE_AVOID_VECTOR_DECODE): Ditto.
+       (X86_TUNE_SLOW_IMUL_IMM32_MEM): Ditto.
+       (X86_TUNE_SLOW_IMUL_IMM8): Ditto.
+       (X86_TUNE_MOVE_M1_VIA_OR): Ditto.
+       (X86_TUNE_NOT_UNPAIRABLE): Ditto.
+       (X86_TUNE_NOT_VECTORMODE): Ditto.
+       (TUNE_SHORTEN_X87_SSE): Use new tuning option.
+       (TUNE_AVOID_VECTOR_DECODE): Ditto.
+       (TUNE_SLOW_IMUL_IMM32_MEM): Ditto.
+       (TUNE_SLOW_IMUL_IMM8): Ditto.
+       (TUNE_MOVE_M1_VIA_OR): Ditto.
+       (TUNE_NOT_UNPAIRABLE): Ditto.
+       (TUNE_NOT_VECTORMODE): Ditto.
+
+       * config/i386/i386.c (ix86_tune_features): Fill in new tuning
+       options.
+
+       * config/i386/i386.md (fix_trunc?f?1_sse peephole2): Use new
+       tuning options instead of hard coded TARGET_xxx.
+       (fix ssemode peephole2's): Ditto.
+       (imul peephole2's): Ditto.
+       (movsi_or): Ditto.
+       (movdi_or_rex64): Ditto.
+       (move peephole2): Ditto.
+       (not peephole2's): Ditto.
+
+2007-03-14  Dirk Mueller  <dmueller@suse.de>
+
+       * c-common.h (empty_body_warning): Rename to empty_if_body_warning.
+       * c-common.c (empty_if_body_warning): Rephrase diagnostic message.
+       * c-parser.c (c_parser_if_body): Always add an empty statement in case
+       of empty body.
+       * c-parser.c (c_parser_do_statement): Warn about empty body in
+       do/while statement.
+       * c-typeck (c_finish_if_stmt): Call empty_if_body_warning.
+       * doc/invoke.texi (-Wempty-body): Update documentation.
+
+2007-03-14  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c/21438
+       * c-common.h (warn_for_div_by_zero): Declare.
+       * c-common.c (warn_for_div_by_zero): Define.
+       * c-typeck.c (build_binary_op): Call warn_for_div_zero instead of
+       warning.
+
+2007-03-14  Richard Sandiford  <richard@codesourcery.com>
+
+       * Makefile.in (PREPROCESSOR_DEFINES): Add directory terminators
+       to PREFIX and STANDARD_PREFIX.
+
+2007-03-14  Richard Sandiford  <richard@codesourcery.com>
+           Phil Edwards  <phil@codesourcery.com>
+
+       * gthr-vxworks.h: Add an extern "C" wrapper for C++.
+       (__gthread_once_t): Remove busy field for RTPs.
+       (__GTHREAD_ONCE_INIT): Update accordingly.
+
+2007-03-14  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi: Document VxWorks options.
+
+2007-03-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       * doc/invoke.texi (i386 and x86-64 Options): Clarify -msahf option.
+
+2007-03-13  Seongbae Park <seongbae.park@gmail.com>
+
+       PR tree-optimization/30590
+       * tree-nrv.c (tree_nrv): Check for the partial update of the
+       return value.
+
+2007-03-13  Alexandre Oliva  <aoliva@redhat.com>
+
+       * flags.h (flag_random_seed): Remove declaration, in favor of...
+       * toplev.h (get_random_seed, set_random_seed): ... these.
+       * tree.c (get_file_function_name): Use the former.
+       * opts.c (common_handle_option): Use the latter.
+       * toplev.c
+
+2007-03-13  Steven Bosscher  <steven@gcc.gnu.org>
+
+       PR middle-end/31127
+       * cse.c (cse_find_path): Do not bail out if a basic block that
+       we already visited now becomes part of a path that starts at a
+       different basic block.  Just disallow this, to make sure we
+       visit each basic block at most once.
+
+2007-03-13  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-inline.c (cgraph_maybe_hot_edge_p): Look for hot/cold
+       attributes, when profile esitmate is present, calls with very low
+       frequency are cold.
+
+2007-03-13  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/30730
+       PR tree-optimization/26900
+       * tree-ssa-loop-niter.c: Include gmp.h.
+       (bounds): New type.
+       (mpz_set_double_int, get_type_bounds, mpz_to_double_int,
+       split_to_var_and_offset, determine_value_range,
+       bound_difference_of_offsetted_base, refine_bounds_using_guard,
+       bound_difference, bounds_add, bounds_negate,
+       number_of_iterations_ne_max, dump_affine_iv): New functions.
+       (number_of_iterations_ne, number_of_iterations_lt_to_ne,
+       assert_loop_rolls_lt, assert_loop_rolls_le): Use bounds on the
+       difference of initial and final value of control iv to validate
+       results.
+       (number_of_iterations_cond): Add loop parameter.  Determine bounds
+       on the difference of the extremes of the control iv.  Add dumps.
+       (expand_simple_operations): Handle phi nodes.
+       (simplify_using_initial_conditions): Do not record used conditions.
+       (number_of_iterations_exit): Pass loop to number_of_iterations_cond.
+       Do not set additional_info.
+       (implies_nonnegative_p, implies_ge_p): Removed.
+       (derive_constant_upper_bound): Do not use parameter `additional'.
+       (record_estimate): Parameter `additional' removed.  Parameter
+       `i_bound' added.  Do not call derive_constant_upper_bound.
+       (record_nonwrapping_iv): Use derive_constant_upper_bound to
+       bound the number of iterations estimate.
+       (estimate_numbers_of_iterations_loop): Pass the estimate from
+       the number of iterations analysis to record_estimate.
+       * tree.h (multiple_of_p): Declare.
+       * tree-scalar-evolution.c (expression_expensive_p): Removed.
+       (scev_const_prop): Do not check expression_expensive_p.
+       * fold-const.c (multiple_of_p): Exported.
+       * double-int.c (double_int_mask): Exported.
+       * double-int.h (double_int_mask): Declare.
+       * tree-flow.h (struct tree_niter_desc): Removed additional_info
+       field.  Added max field.
+
+2007-03-13  David Taylor  <taylor@candd.org>
+
+       PR driver/12448
+       * gcc.c (cpp_unique_options): If -MT or -MQ is seen, don't pass
+       default -MQ.
+
+2007-03-13  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR target/31123
+       * pa.md (vdepi_ior): Don't allow zero length deposit.  Likewise for
+       two unamed patterns.
+
+2007-03-13  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.opt (mcx16, msahf): New options.
+       * config/i386/i386.c (x86_cmpxchg16b, x86_sahf): Remove.
+       (ix86_tune_features) [X86_TUNE_USE_SAHF]: Enable for m_GENERIC.
+
+       * config/i386/driver-i386.c (bit_LAHF_LM): New define.
+       (host_detect_local_cpu): Detect cx16 and lahf_lm cpuid bits.
+       Output -mcx16 and -msahf options when corresponding bit is set.
+
+       * doc/invoke.texi (i386 and x86-64 Options): Document -mcx16
+       and -msahf options.
+
+2007-03-13  Alexandre Oliva  <aoliva@redhat.com>
+
+       * configure.ac: Test for assembler tolerance to # 0 "".
+       * configure, config.in: Rebuilt.
+       * final.c (final_scan_insn): Emit it if HAVE_AS_LINE_ZERO.
+
+2007-03-13  Geoffrey Keating  <geoffk@apple.com>
+
+       * doc/invoke.texi (Spec Files): Update for '%{,' spec.
+
+       * config/rs6000/darwin-fallback.c: Compile file only on powerpc.
+       (handle_syscall): Handle direct system calls.
+       * config/rs6000/darwin.h (HAS_MD_FALLBACK_FRAME_STATE_FOR): Delete.
+
+2007-03-12  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * doc/invoke.texi: Fix cpp.info cross-reference.
+       * doc/passes.texi: Fix gcc.info cross-reference.
+
+2007-03-12  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/30835
+       * lambda-code.c (can_convert_to_perfect_nest): Check whether
+       bb_for_stmt is not NULL before accessing it.
+
+2007-03-12  Joseph Myers  <joseph@codesourcery.com>
+
+       * gcc.c (main): Handle target_sysroot_hdrs_suffix being NULL for
+       some multilibs.
+
+2007-03-12  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       PR 30635
+       * doc/install.texi: Document --enable-stage1-languages
+
+2007-03-12  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * tree-pass.h (pass_into_cfg_layout_mode,
+       pass_outof_cfg_layout_mode): Declare.
+       * cfglayout.c (into_cfg_layout_mode, outof_cfg_layout_mode,
+       pass_into_cfg_layout_mode, pass_outof_cfg_layout_mode): New.
+       * passes.c (pass_into_cfg_layout_mode): Schedule before jump2.
+       (pass_outof_cfg_layout_mode): Schedule after pass_rtl_ifcvt.
+
+2007-03-12  Seongbae Park <seongbae.park@gmail.com>
+
+       * c-decl.c (warn_variable_length_array): New function.
+       Refactored from grokdeclarator to handle warn_vla
+       and handle unnamed array case.
+       (grokdeclarator): Refactored VLA warning case.
+       * c.opt (Wvla): New flag.
+       * doc/invoke.texi (Wvla): New warning.
+
+2007-03-12  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/alpha.c (alpha_elf_section_type_flags): New.
+       (TARGET_SECTION_TYPE_FLAGS): New.
+
+2007-03-12  Richard Henderson  <rth@redhat.com>
+
+       * config/darwin.c (machopic_reloc_rw_mask): New.
+       * config/darwin-protos.h (machopic_reloc_rw_mask): Declare.
+       * config/darwin.h (TARGET_ASM_RELOC_RW_MASK): New.
+
+2007-03-12  Mark Mitchell  <mark@codesourcery.com>
+
+       * cppdefault.c (cpp_EXEC_PREFIX): New variable.
+       * cppdefault.h (cpp_PREFIX): Document.
+       (cpp_PREFIX_len): Likewise.
+       (cpp_EXEC_PREFIX): New variable.
+       * Makefile.in (PREPROCESSOR_DEFINES): Add STANDARD_EXEC_PREFIX.
+       * c-incpath.c (add_standard_paths): Correct logic for relocating
+       paths within prefix.
+
+2007-03-12  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (fixuns_trunc<mode>hi2): Implement from
+       fixuns_truncsfhi2 and fixuns_truncdfhi2 using SSEMODEF
+       mode macro.
+       (fix_trunc<mode>di_sse): Implement from fix_truncsfdi_sse and
+       fix_truncdfdi_sse using SSEMODEF mode macro.
+       (fix_trunc<mode>si_sse): Implement from fix_truncsfsi_sse and
+       fix_truncdfsi_sse using SSEMODEF mode macro.
+       (fix_trunc?f?i_sse peephole2): Implement using SSEMODEF mode macro.
+       (fix_trunc?f?i_sse K8 peephole2): Fix register constraint.
+
+2007-03-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (i[4567]86-wrs-vxworks, i[4567]86-wrs-vxworksae): Add
+       elfos.h to tm_file.
+
+2007-03-12  Olga Golovanevsky  <olga@il.ibm.com>
+
+       * tree.h : Add multiple_of_p declaration.
+       * fold-const.c (multiple_of_p): Make multiple_of_p public.
+       * ipa-type-escape.c (results_of_malloc): Redundant.
+       (visited_stmts): New. Visited stmt for walk_use_def_chains.
+       (cast_type): Extended with new members.
+       (check_cast): Returns cast_type.
+       (cast): New structure for data of walk_use_def_chains.
+       (is_malloc_result, is_cast_from_non_pointer_1,
+       is_cast_from_non_pointer,
+       is_array_access_through_pointer_and_index): New functions.
+       (look_for_casts): Returns cast types.
+       (check_call): Returns void.
+       (okay_pointer_operation): Use support of pointer plus index,
+       pointer plus constant and allow all multiplications.
+
+2007-03-11  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/31115
+       * tree-vrp.c (extract_range_from_binary_expr): Make sure
+       the shift count is positive and non-anti-range for RSHIFT_EXPR.
+       A shift count of zero is not special as with *_DIV_EXPR.
+       (vrp_int_const_binop): Handle RSHIFT_EXPR for determining overflow
+       direction.
+
+2007-03-11  Ian Lance Taylor  <iant@google.com>
+
+       * tree-vrp.c (vrp_int_const_binop): Handle PLUS_EXPR and
+       the *_DIV_EXPR codes correctly with overflow infinities.
+
+2007-03-11  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-data-ref.c (analyze_offset): Add a return value (bool) to
+       indicate success/failure of the analysis. Add negation to subtrahend
+       in case of subtraction. Fail if both operands contain constants.
+       (create_data_ref): Fail if analyze_offset fails.
+
+2007-03-11  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (frndintxf2): Rename to ...
+       (rintxf2): ... this. Remove expander having same name.
+       (rintsf2, rintdf2): Implement using SSEMODEF macro.
+       (roundsf2, rounddf2): Ditto.
+       (lrint<mode>di2, lrint<mode>si2): Implement using SSEMODEI24 macro.
+       (lround<mode>di2, lround<mode>si2): Ditto.
+
+2007-03-11  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * lower-subreg.c: Include except.h.
+       (decompose_multiword_subregs): Verify that the only control flow
+       insns we can split are loads to multi-words pseudos.
+       Handle breaking such blocks after splitting, instead of calling
+       find_many_sub_basic_blocks.
+
+       * loop-unroll.c (split_edge_and_insert): Don't set BB_SUPERBLOCK
+       on the new basic block.  Add a lengthy comment explaining why we
+       thought this was necessary.
+       * cfglayout.c (cfg_layout_finalize): Don't break superblocks.
+
+2007-03-10  Mark Mitchell  <mark@codesourcery.com>
+
+       PR c++/30924
+       * tree.c (walk_type_fields): Recurse into the element type of
+       ARRAY_TYPEs if there is a pointer set.
+
+2007-03-10  Dirk Mueller  <dmueller@suse.de>
+
+       * c-common.c (warn_logical_operator): Fix condition.
+
+2007-03-10  Tobias Schlüter  <tobi@gcc.gnu.org>
+
+       * config/i386/darwin.h (DARWIN_MINVERSION_SPEC): Add missing
+       quotation mark.
+       * config/darwin.c (machopic_select_section): Remove superfluous
+       argument in call to categorize_decl_for_section.  Remove unused
+       variable shlib.
+
+2007-03-10  Joseph Myers  <joseph@codesourcery.com>
+
+       * configure.ac (glibc_header_dir): Set using with_build_sysroot if
+       defined.
+       * configure: Regenerate.
+
+2007-03-10  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/31101
+       * config/i386/i386.md (UNSPEC_C2_FLAG): New constant.
+       (fpremxf4_i387, fprem1xf4_i387): Use UNSPEC_C2_FLAG.
+       (fmodxf3, fmod<mode>3, remainderxf3, remainder<mode>3):
+       Add LABEL_NUSES to emitted label.
+       * config/i386/i386.c (ix86_emit_fp_unordered_jump): Add
+       branch probability value to emitted jump insn.
+       * reg-stack.c (subst_stack_regs_pat)[UNSPEC]: Handle UNSPEC_C2_FLAG.
+       Do not check life information and do not re-arrange input operands
+       for UNSPEC_FSCALE_EXP, UNSPEC_FPREM_U and UNSPEC_FPREM1_U.
+
+2007-03-10  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/sh.c (sh_insn_length_adjustment): Adjust for
+       the change of decode_asm_operands.
+
+2007-03-10  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * mode-switching.c (create_pre_exit): Skip blockage insn.
+
+2007-03-09  Diego Novillo  <dnovillo@redhat.com>
+
+       * tree-pass.h (TODO_update_smt_usage): Remove.
+       Update all users.
+       * tree-ssa-forwprop.c (forward_propagate_addr_expr_1): Remove
+       argument SOME.
+       Update all users.
+
+2007-03-09  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.c (attr_length_call): Revise condition for long
+       pc-relative branch.
+       (output_call): Use "LONG_PIC_SDIFF" instruction sequence for long
+       local calls on the SOM target.  Don't use "LONG_PIC_PCREL" call
+       sequence on SOM target.
+
+2007-03-09  Geoffrey Keating  <geoffk@apple.com>
+
+       * gcc.c: Document %{, in big comment at top.
+       (input_suffix_matches): Remove special handling for .s and
+       .S.
+       (input_spec_matches): New.
+       (handle_braces): Handle %{,.
+       (validate_switches): ',' indicates a value which is not a switch.
+       * config/alpha/osf.h (ASM_FINAL_SPEC): Use %{, rather than %{.
+       to detect assembler input.
+       * config/i386/sol2.h (CPP_SPEC): Likewise.
+       * config/rs6000/sysv4.h (ASM_SPEC): Likewise.
+       * config/rs6000/vxworks.h (ASM_SPEC): Likewise.
+       * config/rs6000/lynx.h (ASM_SPEC): Likewise.
+       * config/rs6000/linux64.h (ASM_SPEC_COMMON): Likewise.
+       * config/i386/darwin.h (DARWIN_MINVERSION_SPEC): Objective-C plus
+       -m64 causes deployment target to default to 10.5.
+       * config/rs6000/darwin.h (DARWIN_MINVERSION_SPEC): Likewise.
+
+2007-03-09  Richard Henderson  <rth@redhat.com>
+
+       PR target/26090
+       * target.h (targetm.asm.out.reloc_rw_mask): New.
+       * target-def.h (TARGET_ASM_RELOC_RW_MASK): New.
+       (TARGET_ASM_OUT): Use it.
+       * targhooks.c, targhooks.h (default_reloc_rw_mask): New.
+       * varasm.c (categorize_decl_for_section): Remove shlib argument;
+       use the new reloc_rw_mask target hook instead.
+       (default_section_type_flags_1): Merge into...
+       (default_section_type_flags): ... here.
+       (decl_readonly_section_1): Merge into...
+       (decl_readonly_section): ... here.
+       (default_elf_select_section_1): Merge into...
+       (default_elf_select_section): ... here.
+       (default_unique_section_1): Merge into...
+       (default_unique_section): ... here.
+       (compute_reloc_for_rtx_1, compute_reloc_for_rtx): New.
+       (default_select_rtx_section): Use it.
+       (default_elf_select_rtx_section): Likewise.
+       * output.h: Update to match.
+       * doc/tm.texi (TARGET_ASM_RELOC_RW_MASK): New.
+       * config/alpha/alpha.c (alpha_elf_reloc_rw_mask): New.
+       (TARGET_ASM_RELOC_RW_MASK): New.
+       * config/i386/i386.c (x86_64_elf_select_section): Adjust call
+       to categorize_decl_for_section.
+       (x86_64_elf_unique_section): Likewise.
+       * config/ia64/hpux.h (TARGET_ASM_SELECT_SECTION,
+       TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_RTX_SECTION): Remove.
+       (TARGET_ASM_RELOC_RW_MASK): New.
+       * config/ia64/ia64.c (ia64_rwreloc_select_section,
+       ia64_rwreloc_unique_section, ia64_rwreloc_select_rtx_section): Remove.
+       (ia64_hpux_reloc_rw_mask, ia64_reloc_rw_mask): New.
+       (TARGET_RWRELOC): Remove.
+       (ia64_section_type_flags): Adjust call to default_section_type_flags.
+       * config/ia64/sysv4.h (TARGET_ASM_RELOC_RW_MASK): New.
+       * config/rs6000/rs6000.c (rs6000_elf_section_type_flags): Remove.
+       (rs6000_elf_select_section, rs6000_elf_unique_section): Remove.
+       (rs6000_elf_reloc_rw_mask, rs6000_xcoff_reloc_rw_mask): New.
+       (rs6000_xcoff_select_section): Use decl_readonly_section.
+       (rs6000_xcoff_section_type_flags): Use default_section_type_flags.
+       * config/rs6000/sysv4.h (TARGET_ASM_RELOC_RW_MASK): New.
+       (TARGET_ASM_SELECT_SECTION, TARGET_ASM_UNIQUE_SECTION): Remove.
+       (TARGET_SECTION_TYPE_FLAGS): Remove.
+       * config/rs6000/xcoff.h (TARGET_ASM_RELOC_RW_MASK): New.
+
+2007-03-09  Roger Sayle  <roger@eyesopen.com>
+
+       * fold-const.c (fold_comparison): Remove compile-time evaluation of
+       complex constant equality/inequality comparisons for here.
+       (fold_binary) <EQ_EXPR>: Simplify complex comparisons that are
+       known at compile-time or can be simplified to a scalar comparison.
+       (fold_relational_const): Move compile-time evaluation of complex
+       constant equality/inequality comparisons to here.
+
+2007-03-09  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR rtl-optimization/30643
+       * cse.c (cse_insn): Recompute dest_hash after insert_regs for
+       dest_addr_elt.
+       (fold_rtx): Recurse, like before 2006-11-03.
+
+2007-03-09  DJ Delorie  <dj@redhat.com>
+
+       * config/m32c/t-m32c (m32c-pragma.o): Add TM_H dependency to
+       m32c-pragma.o.
+
+2007-03-09  Aldy Hernandez  <aldyh@redhat.com>
+
+       PR tree-optimization/30375
+       * tree-ssa-dse.c (dse_possible_dead_store_p): Do not eliminate if
+       LHS of statements is not the same.
+       * testsuite/gcc.dg/tree-ssa/ssa-dse-10.c: New.
+
+2007-03-09  Chao-ying Fu  <fu@mips.com>
+
+       * doc/extend.texi (MIPS DSP Built-in Functions): Document the DSP
+       REV 2.
+       * doc/invoke.texi (-mdspr2): Document new option.
+       * config/mips/mips.md (UNSPEC_ABSQ_S_QB .. UNSPEC_DPSQX_SA_W_PH):
+       New unspec for DSP REV 2.
+       (<u>mulsidi3_32bit_internal): Check if !TARGET_DSPR2, because
+       these instructions are extended in DSP REV 2.
+       (mips-dspr2.md): Include.
+       * config/mips/mips.opt (mdspr2): New option.
+       * config/mips/mips.c (mips_function_type): Add MIPS_V4QI_FTYPE_V4QI,
+       MIPS_SI_FTYPE_SI_SI_SI, MIPS_DI_FTYPE_DI_USI_USI, MIPS_DI_FTYPE_SI_SI,
+       MIPS_DI_FTYPE_USI_USI, MIPS_V2HI_FTYPE_SI_SI_SI.
+       (override_options): Check TARGET_DSPR2 to enable MASK_DSP.
+       (CODE_FOR_mips_mul_ph): Define it to CODE_FOR_mulv2hi3.
+       (dsp_bdesc): Add DSP REV 2 builtins.  Remove 32-bit only DSP builtins.
+       (dsp_32only_bdesc): New description table for 32-bit only DSP REV 1
+       and 2 builtins.
+       (bdesc_map): Add one field of unsupported_target_flags.
+       (bdesc_arrays): Update entries to have extra fields.  Add
+       dsp_32only_bdesc.
+       (mips_init_builtins): Initialize new function types.
+       Check unsupported_target_fileds to filter out builtins.
+       * config/mips/mips.h (TARGET_CPU_CPP_BUILTINS): Define __mips_dspr2 if
+       TARGET_DSPR2.
+       (ASM_SPEC): Pass mdspr2 to the assembler.
+       * config/mips/mips-dspr2.md: New file.
+
+2007-03-09  Sa Liu  <saliu@de.ibm.com>
+
+       * config/rs6000/altivec.md: Fix vcond patterns using if_then_else.
+
+2007-03-09  Ian Lance Taylor  <iant@google.com>
+
+       * opts.c (common_handle_option): Treat -Wstrict-overflow (with no
+       argument) like -Wstrict-overflow=2.
+       * doc/invoke.texi (Warning Options): Update documentation.
+
+2007-03-09  Dirk Mueller  <dmueller@suse.de>
+
+       PR c++/17946
+       * doc/invoke.texi (-Wlogical-op): Document.
+       * common.opt (-Wlogical-op): New.
+       * c-common.h (warn_logical_operator): Declare.
+       * c-common.c (warn_logical_operator): Define.
+       * c-typeck.c (parser_build_binary_op): Call
+       warn_logical_operator.
+
+2007-03-09  Alexandre Oliva  <aoliva@redhat.com>
+
+       * rtl.h (gen_rtx_ASM_INPUT): Use "" instead of NULL file name.
+       * final.c (final_scan_insn): Test for non-"" file name.
+
+2007-03-09  Sebastian Pop  <sebastian.pop@inria.fr>
+
+       * doc/loop.texi: Document the Omega linear constraints solver.
+       * doc/invoke.texi: Document -fcheck-data-deps, omega-max-vars,
+       omega-max-geqs, omega-max-eqs, omega-max-wild-cards,
+       omega-hash-table-size, omega-max-keys, and
+       omega-eliminate-redundant-constraints.
+       * tree-pass.h (pass_check_data_deps): Declared.
+       * omega.c: New.
+       * omega.h: New.
+       * timevar.def (TV_CHECK_DATA_DEPS): Declared.
+       * tree-ssa-loop.c (check_data_deps, gate_check_data_deps,
+       pass_check_data_deps): New.
+       * tree-data-ref.c (init_data_ref): Remove declaration.
+       (dump_data_dependence_relation): Dump DDR_INNER_LOOP.
+       (analyze_array): Renamed init_array_ref, move up initializations.
+       (init_data_ref): Renamed init_pointer_ref.  Moved before its call.
+       Removed arguments that are set to NULL.
+       (analyze_indirect_ref): Correct indentation, correct call to
+       init_pointer_ref.
+       (object_analysis): Call init_array_ref instead of analyze_array.
+       (initialize_data_dependence_relation): Initialize DDR_INNER_LOOP.
+       (access_functions_are_affine_or_constant_p): Use DR_ACCESS_FNS instead
+       of DR_ACCESS_FNS_ADDR.
+       (init_omega_eq_with_af, omega_extract_distance_vectors,
+       omega_setup_subscript, init_omega_for_ddr_1, init_omega_for_ddr,
+       ddr_consistent_p): New.
+       (compute_affine_dependence): Check consistency of ddrs when
+       flag_check_data_deps is passed.
+       (analyze_all_data_dependences): Uncomment.
+       (tree_check_data_deps): New.
+       * tree-data-ref.h: Include omega.h.
+       (DR_ACCESS_FNS_ADDR): Removed.
+       (data_dependence_relation): Add inner_loop.
+       (DDR_INNER_LOOP): New.
+       * common.opt (fcheck-data-deps): New.
+       * tree-flow.h (tree_check_data_deps): Declare.
+       * Makefile.in (TREE_DATA_REF_H): Depend on omega.h.
+       (OBJS-common): Depend on omega.o.
+       (omega.o): Define.
+       * passes.c (pass_check_data_deps): Scheduled.
+       * params.def (PARAM_OMEGA_MAX_VARS, PARAM_OMEGA_MAX_GEQS,
+       PARAM_OMEGA_MAX_EQS, PARAM_OMEGA_MAX_WILD_CARDS,
+       PARAM_OMEGA_HASH_TABLE_SIZE, PARAM_OMEGA_MAX_KEYS,
+       PARAM_VECT_MAX_VERSION_CHECKS,
+       PARAM_OMEGA_ELIMINATE_REDUNDANT_CONSTRAINTS): New.
+
+2007-03-09  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/30904
+       PR middle-end/31058
+       * tree-vrp.c (extract_range_from_binary_expr): Handle RSHIFT_EXPR
+       the same way as *_DIV_EXPR.
+
+2007-03-09  Alexandre Oliva  <aoliva@redhat.com>
+
+       * recog.c (decode_asm_operands): No mixed declarations and code.
+
+2007-03-09  Alexandre Oliva  <aoliva@redhat.com>
+
+       * rtl.def (ASM_INPUT): Add location.
+       * rtl.h (ASM_INPUT_SOURCE_LOCATION): New.
+       (ASM_INPUT_SOURCE_FILE, ASM_INPUT_SOURCE_LINE): New.
+       (decode_asm_operands): Add loc operand.
+       (gen_rtx_ASM_INPUT, gen_rtx_ASM_INPUT_loc): Define.
+       * stmt.c (expand_asm): Rename to...
+       (expand_asm_loc): ... this.  Add locus argument.  Pass it on to
+       gen_rtx_ASM_INPUT_loc.
+       (expand_asm_expr): Adjust.
+       * recog.c (decode_asm_operands): Add loc operand.
+       (check_asm_operands, extract_insn): Adjust.
+       * reload1.c (maybe_fix_stack_asms): Likewise.
+       * final.c (asm_insn_count): Likewise.
+       (final_scan_insn): Output # line before and after asm.
+
+2007-03-09  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-structalias.c (variable_info): Remove
+       finished_solution.
+       (new_var_info): Ditto.
+       (shared_bitmap_info_t): New structure.
+       (shared_bitmap_table): New variable.
+       (shared_bitmap_hash): New function.
+       (shared_bitmap_eq): Ditto
+       (shared_bitmap_lookup): Ditto.
+       (shared_bitmap_add): Ditto.
+       (merge_smts_into): Change to take bitmap directly.
+       (find_what_p_points_to): Rewrite to use shared bitmap hashtable.
+       (init_alias_vars): Init shared bitmap hashtable.
+       (delete_points_to_sets): Delete shared bitmap hashtable.
+       * tree-ssa-operands.c (add_virtual_operand): Partially revert the
+       is_aliased removal as a change that was still necessary was
+       deleted.
+
+2007-03-09  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (override_options): Conditionally disable
+       x86_sahf for 64bit targets only.
+
+2007-03-08  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR C/31072
+       * c-decl.c (merge_decls): Don't call make_var_volatile.
+       * varasm.c (make_var_volatile): Remove.
+       * output.h (make_var_volatile): Remove.
+
+2007-03-08  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       PR tree-optimization/31085
+       * tree-ssa-address.c (create_mem_ref): Fix test of type of base.
+
+2007-03-08  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.def (lceil, lceilf, lceill, lfloor, lfloorf, lfloorl,
+       llceil, llceilf, llceill, llfloor, llfloorf, llfloorl): Mark with
+       ATTR_CONST_NOTHROW_LIST.
+
+       * fold-const.c (tree_expr_nonnegative_warnv_p): Handle
+       FIX_TRUNC_EXPR.
+
+2007-03-08  Diego Novillo  <dnovillo@redhat.com>
+
+       * doc/tree-ssa.texi: Remove documentation for V_MUST_DEF.
+
+2007-03-08  Geoffrey Keating  <geoffk@apple.com>
+
+       PR 31013
+       * gccspec.c (lang_specific_driver): Do nothing when NEXT_OBJC_RUNTIME
+       is declared.
+       * config/darwin.h (REAL_LIBGCC_SPEC): When -fgnu-runtime is
+       passed, use shared libgcc.
+
+2007-03-08  Roger Sayle  <roger@eyesopen.com>
+
+       * tree-eh.c (do_return_redirection): Call build_gimple_modify_stmt
+       instead of calling build2 with a GIMPLE_MODIFY_STMT.
+       (honor_protect_cleanup_actions, lower_try_finally_switch):
+       Likewise.
+       * tree-if-conv.c (replace_phi_with_cond_gimple_modify_stmt,
+       ifc_temp_var): Likewise.
+       * tree-inline.c (setup_one_parameter): Likewise.
+       * tree-mudflap.c (mf_decl_cache_locals,
+       mf_build_check_statement_for): Likewise.
+       * tree-nested.c (init_tmp_var, save_tmp_var,
+       finalize_nesting_tree_1): Likewise.
+       * tree-outof-ssa.c (insert_copy_on_edge,
+       insert_backedge_copies): Likewise.
+       * tree-profile.c (tree_gen_edge_profiler,
+       tree_gen_ic_profiler): Likewise.
+       * tree-scalar-evolution.c (scev_const_prop): Likewise.
+       * tree-sra.c (sra_build_assignment): Likewise.
+       * tree-ssa-loop-im.c (determine_invariantness_stmt): Likewise.
+       * tree-ssa-math-opts.c (insert_reciprocals,
+       execute_cse_sincos_1): Likewise.
+       * tree-tailcall.c (adjust_accumulator_values,
+       adjust_return_value): Likewise.
+       * tree-vect-patterns.c (vect_pattern_recog_1): Likewise.
+       * tree-vect-transform.c (vect_create_data_ref_ptr,
+       bump_vector_ptr, vect_init_vector, get_initial_def_for_induction,
+       vect_create_epilog_for_reduction, vectorizable_reduction,
+       vectorizable_call, vectorizable_conversion,
+       vectorizable_assignment, vectorizable_operation,
+       vectorizable_type_demotion, vect_gen_widened_results_half,
+       vect_permute_store_chain, vectorizable_store,
+       vect_setup_realignment, vect_permute_load_chain,
+       vectorizable_load, vectorizable_condition,
+       vect_create_cond_for_align_checks): Likewise.
+       * tree-vrp.c (build_assert_expr_for): Likewise.
+
+2007-03-08  Ian Lance Taylor  <iant@google.com>
+
+       * tree-vrp.c: Include "intl.h".
+       (usable_range_p): New static function.
+       (compare_values_warnv): Don't test TYPE_OVERFLOW_UNDEFINED for
+       overflowed values, juts set *strict_overflow_p.
+       (compare_values): Only return -2 if one of the operands is not a
+       constant.
+       (compare_ranges): Call usable_range_p.
+       (compare_range_with_value): Likewise.
+       (vrp_evaluate_conditional_warnv): Rename from
+       vrp_evaluate_conditional.  Make static.  Change all callers.
+       (vrp_evaluate_conditional): New function.
+       (simplify_div_or_mod_using_ranges): Issue warning about reliance
+       on signed overflow.
+       (simplify_abs_using_ranges): Likewise.
+       (simplify_stmt_for_jump_threading): Add within_stmt parameter.
+       * tree-ssa-dom.c (simplify_stmt_for_jump_threading): Add
+       within_stmt parameter.
+       * tree-ssa-propagate.c (fold_predicate_in): Update call to
+       vrp_evaluate_conditional.
+       * tree-ssa-threadedge.c
+       (record_temporary_equivalences_from_stmts_at_dest): Change
+       simplify parameter to take a second tree parameter.
+       (simplify_control_stmt_condition): Likewise.
+       (thread_across_edge): Likewise.
+       * tree-flow.h (vrp_evaluate_conditional): Update declaration.
+       (thread_across_edge): Likewise.
+       * Makefile.in (tree-vrp.o): Depend upon intl.h.
+
+2007-03-08  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (TARGET_SAHF): New define.
+       * config/i386/i386.c (ix86_tune_features) [X86_TUNE_USE_SAHF]:
+       Also enable for m_K8, m_AMDFAM10 and m_CORE2.
+       (x86_sahf): New global variable.
+       (override_options): Add PTA_NO_SAHF to pta_flags enum.  Recode
+       pta_flags masks using shifts.  Add PTA_NO_SAHF to x86_64 and
+       nocona processor flags.  Set x86_sahf when PTA_NO_SAHF is not set
+       in processor flags.  Do not unconditionally disable TARGET_USE_SAHF
+       for 64-bit.
+       (ix86_fp_comparison_sahf_cost): Return high value for !TARGET_SAHF.
+       (ix86_expand_fp_compare): Check for TARGET_CMOVE or TARGET_SAHF
+       when expanding fcomi/sahf based tests.
+       (ix86_emit_fp_unordered_jump): Check for TARGET_SAHF when
+       expanding sahf based alternative. Emit sahf based sequence when
+       optimizing for code size.
+       * config/i386/i386.md (x86_sahf_1): Do not disable for
+       TARGET_64BIT, enable for TARGET_SAHF.
+
+2007-03-08  Martin Michlmayr  <tbm@cyrius.com>
+
+       * tree-ssa-coalesce.c (fail_abnormal_edge_coalesce): Remove
+       spurious whitespace from error message.
+
+2007-03-08  Volker Reichelt  <v.reichelt@netcologne.de>
+
+       PR c++/30852
+       * c-common.c (fold_offsetof_1): Handle COMPOUND_EXPR.
+
+2007-03-08  Alexandre Oliva  <aoliva@redhat.com>
+
+       * c-decl.c (grokdeclarator): Disable warnings for anonymous
+       bitfields.
+       * tree-sra.c (instantiate_element): Propagate disabled warnings
+       from the element itself to the created variable.
+
+2007-03-07  Richard Henderson  <rth@redhat.com>
+
+       PR target/30848
+       * reg-stack.c (emit_swap_insn): If a malformed asm was seen,
+       silently fix up the stack in the case of a missing register.
+
+2007-03-07  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/libunwind.S: Add .arch/.object_arch for armv4 builds.
+
+2007-03-07  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/arm/unwind-arm.c (struct wmmxd_regs, struct wmmxc_regs):
+       New.
+       (phase1_vrs): Use them.
+       (DEMAND_SAVE_WMMXD, DEMAND_SAVE_WMMXC): New.
+       (__gnu_Unwind_Save_WMMXD, __gnu_Unwind_Restore_WMMXD,
+       __gnu_Unwind_Save_WMMXC, __gnu_Unwind_Restore_WMMXC): Declare.
+       (restore_non_core_regs): Call __gnu_Unwind_Restore_WMMXD and
+       __gnu_Unwind_Restore_WMMXC if required.
+       (_Unwind_VRS_Pop): Implement iWMMXt support.
+       * config/arm/libunwind.S (gnu_Unwind_Restore_WMMXD,
+       gnu_Unwind_Save_WMMXD, gnu_Unwind_Restore_WMMXC,
+       gnu_Unwind_Save_WMMXC): Define.
+
+2007-03-07  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/vxworks.h (vxworks_override_options): Declare.
+       (VXWORKS_OVERRIDE_OPTIONS): Use it.
+       * config/vxworks.c: Include target.h and toplev.h.
+       (vxworks_override_options): New function.
+       * config/t-vxworks (vxworks.o): Depend on $(TARGET_H) and toplev.h.
+
+2007-03-07  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.c (override_options): Don't emit an error when
+       -mstack-size is used without providing -mstack-guard.
+       (s390_emit_prologue): Choose stack_guard value automatically if not
+       provided via command line.
+       * doc/invoke.texi: Adjust description of -mstack-guard and
+       -mstack-size.
+
+2007-03-07  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/i386/i386.c (output_set_got): Add a GOT initialization
+       sequence for VxWorks PIC.
+       (legitimate_pic_address_disp_p): Allow UNSPEC_GOT wrappers
+       around labels as well as symbols.  Use gotoff_operand instead
+       of local_symbolic_operand.
+       (legitimize_pic_address): Use gotoff_operand instead of
+       local_symbolic_operand.  Use @GOT accesses for labels as
+       well as symbols.
+       (ix86_output_addr_diff_elt): Use PC-relative rather than
+       GP-relative offsets for VxWorks PIC.
+       (ix86_expand_move): Pass NULL_RTX to legitimize_pic_address unless
+       no_new_pseudos.  Check whether the returned register is op0.
+       * config/i386/i386.md (tablejump): Use PC-relative rather than
+       GP-relative offsets for VxWorks PIC.
+       * config/i386/predicates.md (gotoff_operand): New predicate.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/vxworks.h (VXWORKS_GOTT_BASE, VXWORKS_GOTT_INDEX): Undefine
+       before defining.
+       * config/vxworks-dummy.h: New file.
+       * config/i386/i386.h: Include it.
+
+2007-03-07  Alexandre Oliva  <aoliva@redhat.com>
+
+       * dwarf2out.c (is_inlined_entry_point): New
+       (add_high_low_attributes): Emit DW_AT_entry_pc along with
+       DW_AT_ranges if the first subblock is the entry point.
+
+2007-03-06  David Daney  <ddaney@avtrex.com>
+
+       * doc/install.texi (mips-*-*): Change recommended binutils
+       version.
+
+2007-03-06  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.c (avr_mcu_types): Add support for ATmega325P,
+       ATmega3250P, ATmega329P, ATmega3290P, AT90USB82 and AT90USB162
+       devices.
+       * config/avr/avr.h (LINK_SPEC, CRT_BINUTILS_SPECS): (Ditto.).
+       * config/avr/t-avr (MULTILIB_MATCHES): (Ditto.).
+
+2007-03-06  Jan Hubicka  <jh@suse.cz>
+
+       * errors.h (warning, error, fatal, internal_error): Mark as cold.
+       * predict.c (maybe_hot_bb): Cold functions are never hot; hot
+       functions are hot.
+       (probably_cold_bb_p): Cold functions are cold.
+       (probably_never_executed_bb_p): Cold functions are cold.
+       (tree_bb_level_predictions): Predict calls to cold functions as not
+       taken.
+       (compute_function_frequency): Check hot/cold attributes.
+       * function.h (function_frequency): Update comments.
+       * predict.def (PRED_COLD_FUNCTION): Predict cold function.
+       * c-common.c (handle_hot_attribute, handle_cold_attribute): New.
+       (c_common_att): Add cold and hot.
+
+       * doc/extend.texi (hot,cold attributes): Document.
+
+2007-03-06  Andrew Haley  <aph@redhat.com>
+
+       * function.c (expand_function_end): Move blockage to just after we
+       emit the label for the naked return from the function.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/i386/att.h (ASM_OUTPUT_ASCII, ASM_OUTPUT_SKIP): Undefine
+       before redefining.
+
+2007-03-06  Jan Hubicka  <jh@suse.cz>
+
+       * reg-stack.c (reg_to_stack): Large models don't allow NAN to be
+       loaded for constant large models.  Non-large 64bit PIC can do.
+       * config/i386/i386.h (CASE_VECTOR_MODE): Large PIC cases are 64bit.
+       * cmodel.h: Add LARGE PIC.
+       * config/i386/i386.md (UNSPEC_PLTOFF): New.
+       (UNSPEC_SET_RIP, UNSPEC_SET_GOT_OFFSET): New; renumber other
+       unspecs as needed.
+       (*call_1_rex64): Disable for large models.
+       (*call_1_rex64_large): New.
+       (*call_value_1_rex64): Disable for large models.
+       (*call_value_1_rex64_large): New.
+       (set_rip_rex4): New.
+       (set_got_offset_rex64): New.
+       * config/i386/predicates.md (constant_call_address_operand): For
+       large model constant calls are not possible.
+       * config/i386/i386-protos.h (construct_plt_address): Declare.
+       * config/i386/i386.c (override_options): Accept large models.
+       (ix86_expand_prologue): Expand large PIC GOT pointer load.
+       (legitimate_constant_p): Add new UNSPECs.
+       (legitimate_pic_operand_p): Likewise.
+       (legitimate_pic_address_disp_p): Disallow local symbols for large PICs.
+       (legitimize_pic_address): Do easy RIP relative way for TLS only for
+       non-large model.
+       (output_pic_addr_const): Add PLTOFF.
+       (ix86_output_addr_diff_elt): Output 64bit tables when needed.
+       (ix86_expand_move): Legitimize pic address when in PIC mode.
+       (construct_plt_address): New function.
+       (ix86_expand_call): Offload the address to register and use GOT
+       pointer for large model.
+       * invoke.texi (mcmodel=large): Update documentation.
+
+2007-03-06  Richard Henderson  <rth@redhat.com>
+
+       * config/i386/i386.c (x86_use_leave, x86_push_memory,
+       x86_zero_extend_with_and, x86_movx, x86_double_with_add,
+       x86_use_bit_test, x86_unroll_strlen, x86_deep_branch,
+       x86_branch_hints, x86_use_sahf, x86_partial_reg_stall,
+       x86_partial_flag_reg_stall, x86_use_himode_fiop, x86_use_simode_fiop,
+       x86_use_mov0, x86_use_cltd, x86_read_modify_write, x86_read_modify,
+       x86_split_long_moves, x86_promote_QImode, x86_fast_prefix,
+       x86_single_stringop, x86_qimode_math, x86_promote_qi_regs,
+       x86_himode_math, x86_promote_hi_regs, x86_sub_esp_4, x86_sub_esp_8,
+       x86_add_esp_4, x86_add_esp_8, x86_integer_DFmode_moves,
+       x86_partial_reg_dependency, x86_memory_mismatch_stall,
+       x86_prologue_using_move, x86_epilogue_using_move, x86_shift1,
+       x86_sse_partial_reg_dependency, x86_sse_split_regs,
+       x86_sse_unaligned_move_optimal, x86_sse_typeless_stores,
+       x86_sse_load0_by_pxor, x86_use_ffreep, x86_use_incdec,
+       x86_inter_unit_moves, x86_ext_80387_constants, x86_four_jump_limit,
+       x86_schedule, x86_use_bt, x86_pad_returns,
+       x86_use_xchgb): Merge into ...
+       (ix86_tune_features): ... here.  New array.
+       (x86_cmove, x86_cmpxchg, x86_cmpxchg8b, x86_xadd,
+       x86_bswap): Merge into ...
+       (ix86_arch_features): ... here.  New array.
+       (x86_3dnow_a): Remove.
+       (x86_accumulate_outgoing_args): Make static.
+       (x86_arch_always_fancy_math_387): Make static.
+       (ix86_tune_mask, ix86_arch_mask): Move ...
+       (override_options): ... to local variables here.  Apply the
+       appropriate mask to each element of ix86_arch_features and
+       ix86_tune_features.  Adjust TARGET_CMOVE and TARGET_USE_SAHF
+       as were done in the old macros.
+       (standard_80387_constant_p): Use TARGET_EXT_80387_CONSTANTS.
+       * config/i386/i386.h (x86_use_leave, x86_push_memory,
+       x86_zero_extend_with_and, x86_use_bit_test, x86_cmove, x86_deep_branch,
+       x86_branch_hints, x86_unroll_strlen, x86_double_with_add,
+       x86_partial_reg_stall, x86_movx, x86_use_himode_fiop,
+       x86_use_simode_fiop, x86_use_mov0, x86_use_cltd, x86_use_xchgb,
+       x86_read_modify_write, x86_read_modify, x86_split_long_moves,
+       x86_promote_QImode, x86_single_stringop, x86_fast_prefix,
+       x86_himode_math, x86_qimode_math, x86_promote_qi_regs,
+       x86_promote_hi_regs, x86_integer_DFmode_moves, x86_add_esp_4,
+       x86_add_esp_8, x86_sub_esp_4, x86_sub_esp_8,
+       x86_partial_reg_dependency, x86_memory_mismatch_stall,
+       x86_accumulate_outgoing_args, x86_prologue_using_move,
+       x86_epilogue_using_move, x86_decompose_lea,
+       x86_arch_always_fancy_math_387, x86_shift1,
+       x86_sse_partial_reg_dependency, x86_sse_split_regs,
+       x86_sse_unaligned_move_optimal, x86_sse_typeless_stores,
+       x86_sse_load0_by_pxor, x86_use_ffreep, x86_inter_unit_moves,
+       x86_schedule, x86_use_bt, x86_cmpxchg, x86_cmpxchg8b, x86_xadd,
+       x86_use_incdec, x86_pad_returns, x86_bswap,
+       x86_partial_flag_reg_stall): Remove.
+       (enum ix86_tune_indices): New.
+       (ix86_tune_features): New.
+       (TARGET_USE_LEAVE, TARGET_PUSH_MEMORY, TARGET_ZERO_EXTEND_WITH_AND,
+       TARGET_USE_BIT_TEST, TARGET_UNROLL_STRLEN,
+       TARGET_DEEP_BRANCH_PREDICTION, TARGET_BRANCH_PREDICTION_HINTS,
+       TARGET_DOUBLE_WITH_ADD, TARGET_USE_SAHF, TARGET_MOVX,
+       TARGET_PARTIAL_REG_STALL, TARGET_PARTIAL_FLAG_REG_STALL,
+       TARGET_USE_HIMODE_FIOP, TARGET_USE_SIMODE_FIOP, TARGET_USE_MOV0,
+       TARGET_USE_CLTD, TARGET_USE_XCHGB, TARGET_SPLIT_LONG_MOVES,
+       TARGET_READ_MODIFY_WRITE, TARGET_READ_MODIFY, TARGET_PROMOTE_QImode,
+       TARGET_FAST_PREFIX, TARGET_SINGLE_STRINGOP, TARGET_QIMODE_MATH,
+       TARGET_HIMODE_MATH, TARGET_PROMOTE_QI_REGS, TARGET_PROMOTE_HI_REGS,
+       TARGET_ADD_ESP_4, TARGET_ADD_ESP_8, TARGET_SUB_ESP_4,
+       TARGET_SUB_ESP_8, TARGET_INTEGER_DFMODE_MOVES,
+       TARGET_PARTIAL_REG_DEPENDENCY, TARGET_SSE_PARTIAL_REG_DEPENDENCY,
+       TARGET_SSE_UNALIGNED_MOVE_OPTIMAL, TARGET_SSE_SPLIT_REGS,
+       TARGET_SSE_TYPELESS_STORES, TARGET_SSE_LOAD0_BY_PXOR,
+       TARGET_MEMORY_MISMATCH_STALL, TARGET_PROLOGUE_USING_MOVE,
+       TARGET_EPILOGUE_USING_MOVE, TARGET_SHIFT1, TARGET_USE_FFREEP,
+       TARGET_INTER_UNIT_MOVES, TARGET_FOUR_JUMP_LIMIT, TARGET_SCHEDULE,
+       TARGET_USE_BT, TARGET_USE_INCDEC, TARGET_PAD_RETURNS,
+       TARGET_EXT_80387_CONSTANTS): Use it.
+       (enum ix86_arch_indices): New.
+       (ix86_arch_features): New.
+       (TARGET_CMOVE, TARGET_CMPXCHG, TARGET_CMPXCHG8B, TARGET_XADD,
+       TARGET_BSWAP): Use it.
+       (ix86_tune_mask, ix86_arch_mask): Remove.
+
+2007-03-06  Joseph Myers  <joseph@codesourcery.com>
+
+       PR bootstrap/31020
+       * configure.ac (CROSS_SYSTEM_HEADER_DIR, build_system_header_dir):
+       Define using $${sysroot_headers_suffix}.
+       * configure: Regenerate.
+       * cppdefault.c (cpp_include_defaults): Make FIXED_INCLUDE_DIR a
+       multilib-suffixed directory if SYSROOT_HEADERS_SUFFIX_SPEC
+       defined.
+       * doc/invoke.texi (-print-sysroot-headers-suffix): Document.
+       * gcc.c (print_sysroot_headers_suffix): New.
+       (option_map): Include --print-sysroot-headers-suffix.
+       (display_help): Mention -print-sysroot-headers-suffix.
+       (process_command): Handle -print-sysroot-headers-suffix.
+       (do_spec_1): Append multilib directory to include-fixed path if
+       sysroot suffixes in use.
+       (main): Handle -print-sysroot-headers-suffix.
+       * Makefile.in (start.encap): Don't depend on xlimits.h
+       (xlimits.h): Remove.
+       (stmp-int-hdrs): Don't depend on xlimits.h.  Inline generation of
+       limits.h for each multilib in fixinc_list.
+       (fixinc_list, s-fixinc_list): New.
+       (stmp-fixinc): Depend on fixinc_list.  If not copying headers,
+       generate them for each multilib in fixinc_list.
+       (stmp-fixproto): Use include-fixed.  Run fixproto for each
+       multilib in fixinc_list.
+       (mostlyclean): Don't remove xlimits.h.
+       (clean): Remove include-fixed.
+       (real-install-headers-tar, real-install-headers-cpio,
+       real-install-headers-cp): Don't copy include, only include-fixed.
+       (install-mkheaders): Depend on fixinc_list.  Don't depend on
+       xlimits.h.  Save limits.h files for each multilib in fixinc_list.
+       Always save mkinstalldirs.  Preserve ${sysroot_headers_suffix} in
+       SYSTEM_HEADER_DIR setting in mkheaders.conf.
+
+2007-03-06  Jan Hubicka  <jh@suse.cz>
+
+       * regstack.c (reg_to_stack): When in 64bit PIC mode, we still can load
+       NANs easilly.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * configure.ac: Allow tm_file to contain build-directory files.
+       * configure: Regenerate.
+       * config.gcc (m68k-*-uclinux*): Add ./sysroot-suffix.h to tm_file.
+       * config/m68k/t-uclinux (sysroot-suffix.h): New target.
+       * config/m68k/print-sysroot-suffix.sh: New file.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (PIC_OFFSET_TABLE_REGNUM): Use the REGNO
+       of pic_offset_table_rtx if reload_completed.
+       (CONDITIONAL_REGISTER_USAGE): Use PIC_REG instead of
+       PIC_OFFSET_TABLE_REGNUM.
+       * config/m68k/m68k.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK): Always
+       return true.
+       (m68k_save_reg): Use PIC_REG instead of PIC_OFFSET_TABLE_REGNO.
+       (m68k_output_mi_thunk): Rewrite to use RTL.  Honor vcall_offset.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_save_reg): Save the PIC register in
+       functions that call eh_return.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_save_reg): Save the PIC register in
+       functions that need a constant pool.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       PR target/28181
+       * config/m68k/m68k-protos.h (m68k_secondary_reload_class): Declare.
+       (m68k_preferred_reload_class): Likewise.
+       * config/m68k/m68k.h (HARD_REGNO_MODE_OK): Remove duplicated comment.
+       (SECONDARY_RELOAD_CLASS): Define.
+       (PREFERRED_RELOAD_CLASS): Use m68k_preferred_reload_class.
+       (LIMIT_RELOAD_CLASS): Delete.
+       * config/m68k/m68k.c (m68k_regno_mode_ok): Don't prevent address
+       registers from storing bytes.
+       (m68k_secondary_reload_class): New function.
+       (m68k_preferred_reload_class): Likewise.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_save_reg): Remove special case for
+       leaf functions.
+       (m68k_expand_prologue): Likewise.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k-protos.h (output_sibcall): Declare.
+       (mips_expand_epilogue): Add a bool parameter.
+       (m68k_legitimize_sibcall_address): Declare.
+       * config/m68k/m68k.c (TARGET_FUNCTION_OK_FOR_SIBCALL): Define.
+       (m68k_expand_epilogue): Add a parameter to select between sibling
+       and normal epilogues.  Only generate a return for the latter.
+       (m68k_ok_for_sibcall_p): New function.
+       (m68k_legitimize_sibcall_address, output_sibcall): New functions.
+       * config/m68k/m68k.md (sibcall, *sibcall): New patterns.
+       (sibcall_value, *sibcall_value): Likewise.
+       (*call, *call_value): Require !SIBLING_CALL_P.
+       (epilogue): Update call to m68k_expand_epilogue.
+       (sibcall_epilogue): New pattern.
+       * config/m68k/predicates.md (const_call_operand): Say that this
+       predicate applies to sibling calls too.
+       (sibcall_operand): New predicate.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.md (movsf_cf_soft): Provide the same non-mov3q
+       alternatives as movsi_cf.
+       (movsf_cf_hard): Add commentary.
+
+2007-03-06  Kazu Hirata  <kazu@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k-protos.h (m68k_interrupt_function_p): Declare.
+       (m68k_movem_pattern_p, m68k_output_movem): Likewise.
+       (m68k_expand_prologue, m68k_expand_epilogue): Likewise.
+       * config/m68k/m68k.h (EPILOGUE_USES): Define.  Treat all registers
+       as being live on exit from an interrupt function.
+       (PRINT_OPERAND_PUNCT_VALID_P): Return true for '?'.
+       * config/m68k/m68k.c (MIN_MOVEM_REGS, MIN_FMOVEM_REGS): New macros.
+       (m68k_frame): Remove reg_rev_mask and fpu_rev_mask.
+       (TARGET_ASM_FUNCTION_PROLOGUE, TARGET_ASM_FUNCTION_EPILOGUE): Delete.
+       (m68k_interrupt_function_p): Globalize.
+       (m68k_compute_frame_layout): Remove reverse mask code.
+       (m68k_emit_movem, m68k_set_frame_related): New functions.
+       (m68k_output_function_prologue): Delete in favor of...
+       (m68k_expand_prologue): ...this new function.
+       (m68k_output_function_epilogue): Delete in favor of...
+       (m68k_expand_epilogue): ...this new function.
+       (m68k_split_offset, m68k_movem_pattern_p, m68k_output_movem): New
+       functions.
+       (print_operand): Handle %?.
+       * config/m68k/m68k.md (UNSPEC_SIN, UNSPEC_COS): Remove excess space.
+       (UNSPEC_GOT, A1_REG, PIC_REG, FP0_REG): New constants.
+       (prologue, epilogue): New patterns.
+       (return): Turn into a define_expand.
+       (*return): New pattern, derived from old "return" pattern.  Use rte
+       rather than rts for interrupt functions.  Only use rtd if the pop
+       count is nonzero.
+       (*m68k_store_multiple, *m68k_store_multiple_automod): New patterns.
+       (*m68k_load_multiple, *m68k_load_multiple_automod): Likewise.
+       (link, *link, unlink, *unlink, load_got): Likewise.
+
+2007-03-06  Richard Sandiford  <richard@codesourcery.com>
+
+       PR target/23482
+       PR target/17114
+       * config/m68k/m68k-protos.h (m68k_legitimate_base_reg_p): Declare.
+       (m68k_legitimate_index_reg_p, m68k_legitimate_address_p): Likewise.
+       (m68k_matches_q_p, m68k_matches_u_p): Likewise.
+       * config/m68k/m68k.h (EXTRA_CONSTRAINT): Use m68k_matches_q_p
+       and m68k_matches_u_p.
+       (PCREL_GENERAL_OPERAND_OK, LEGITIMATE_BASE_REG_P): Delete.
+       (INDIRECTABLE_1_ADDRESS_P, GO_IF_NONINDEXED_ADDRESS): Delete.
+       (GO_IF_INDEXABLE_BASE, GO_IF_INDEXING, GO_IF_INDEXED_ADDRESS): Delete.
+       (LEGITIMATE_INDEX_REG_P, LEGITIMATE_INDEX_P): Delete.
+       (GO_IF_COLDFIRE_FPU_LEGITIMATE_ADDRESS): Delete.
+       (REG_STRICT_P): New macro.
+       (LEGITIMATE_PIC_OPERAND_P): Use REG_STRICT_P rather than
+       PCREL_GENERAL_OPERAND_OK.
+       (REG_OK_FOR_BASE_P): Merge definitions.  Use REG_STRICT_P and
+       m68k_legitimate_base_reg_p.
+       (REG_MODE_OK_FOR_INDEX_P): Likewise m68k_legitimate_index_reg_p.
+       (GO_IF_LEGITIMATE_ADDRESS): Likewise m68k_legitimate_address_p.
+       (PIC_CASE_VECTOR_ADDRESS): Update comment.
+       * config/m68k/m68k.c (m68k_address): New structure.
+       (m68k_legitimate_base_reg_p, m68k_legitimate_index_reg_p)
+       (m68k_decompose_index, m68k_legitimate_constant_address_p)
+       (m68k_jump_table_ref_p, m68k_decompose_address)
+       (m68k_legitimate_address_p, m68k_legitimate_mem_p, m68k_matches_q_p)
+       (m68k_matches_u_p): New functions.
+       (print_operand_address): Rewrite to use m68k_decompose_index.
+
+2007-03-05  David Taylor  <dtaylor@emc.com>
+
+       * gcc.c: Correct copyright date in --version output.
+
+2007-03-05  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.md: In unamed move patterns, disparge copies between general
+       and floating point registers using '?' modifier.  Don't include 'f'
+       constraint for register preferences in DImode, SImode, HImode and
+       QImode patterns.  Likewise for 'r' in DFmode and SFmode patterns.
+       Remove constraints for copies between general and floating registers
+       in soft-float DFmode pattern.
+       (movdf): Fail if operand1 is a CONST_DOUBLE and operand0 is a hard
+       floating register.
+       (movsf): Likewise.
+
+2007-03-05  Mike Stump  <mrs@apple.com>
+
+       * c-common.c (targetcm): Add.
+       * c-opts.c (c_common_handle_option): Handle language specific
+       target options.
+       * opts.c (handle_option): Verify language for target options, if
+       any are given.
+       * opth-gen.awk: Add CL_LANG_ALL.
+       * target-def.h (TARGET_HANDLE_C_OPTION): Add.
+       (TARGETCM_INITIALIZER): Add.
+       * target.h (struct gcc_targetcm): Add.
+       (targetcm): Add.
+       * targhooks.c (default_handle_c_option): Add.
+       * targhooks.h (default_handle_c_option): Add.
+       * doc/tm.texi (TARGET_HANDLE_C_OPTION): Add.
+
+       * config/darwin.opt (iframework): Add.
+       * config/darwin.h (TARGET_HAS_TARGETCM): Add.
+       * config/darwin-c.c (handle_c_option): Add.
+       (TARGET_HANDLE_C_OPTION): Add.
+       (targetcm): Add.
+       * doc/invoke.texi (Darwin Options): Add -iframework.
+
+2007-03-05  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * convert.c (convert_to_integer): Fix nearbyint/rint -> *lrint
+       conversion.
+
+2007-03-05  Ian Lance Taylor  <iant@google.com>
+
+       * c.opt (fgnu89-inline): New option.
+       * c-opts.c (c_common_post_options): Set default value for
+       flag_gnu89_inline.
+       * c-decl.c (WANT_C99_INLINE_SEMANTICS): Remove.
+       (pop_scope): Check flag_gnu89_inline rather than flag_isoc99 for
+       inline functions.
+       (diagnose_mismatched_decls, merge_decls, start_decl): Likewise.
+       (grokdeclarator, start_function): Likewise.
+       * c-cppbuiltin.c (c_cpp_builtins): Define either
+       __GNUC_GNU_INLINE__ or __GNUC_STDC_INLINE__.
+       * doc/invoke.texi (Option Summary): Mention -fgnu89-inline.
+       (C Dialect Options): Document -fgnu89-inline.
+       * doc/extend.texi (Function Attributes): Explain what the
+       gnu_inline attribute does.
+       * doc/cpp.texi (Common Predefined Macros): Document
+       __GNUC_GNU_INLINE__ and __GNUC_STDC_INLINE__.
+
+2007-03-05  Ian Lance Taylor  <iant@google.com>
+
+       PR tree-optimization/31034
+       * tree-vrp.c (extract_range_from_assert): Don't try to handle a
+       half-range if the other side is an overflow infinity.
+
+2007-03-05  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config.gcc (bfin*-uclinux*): Use t-bfin-uclinux.
+       (bfin*-linux-uclibc*): New configuration.
+       * config/linux.h (LINK_GCC_C_SEQUENCE_SPEC): Undefined before
+       defining.
+       * config/bfin/linux.h: New file.
+       * config/bfin/libgcc-bfin.ver: New file.
+       * config/bfin/t-bfin-uclinux: New file.
+       * config/bfin/t-bfin-linux: New file.
+       * config/bfin/uclinux.h (LINUX_TARGET_OS_CPP_BUILTINS): New macro.
+       (TARGET_OS_CPP_BUILTINS): New macro.
+
+2007-03-05  Richard Guenther  <rguenther@suse.de>
+
+       * fold-const.c (fold_binary): Remove duplicate folding
+       of comparison of non-null ADDR_EXPR against null.
+
+2007-03-05  Richard Guenther  <rguenther@suse.de>
+           Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/26420
+       * tree-vectorizer.c (vectorize_loops): Bail out early if there
+       are no loops in the function.  Only print the number of
+       vectorized loops if it is greater than zero or we are supposed
+       to print information about unvectorized loops.
+
+2007-03-05  Revital Eres  <eres@il.ibm.com>
+
+       * gcc.dg/var-expand1.c: New test.
+       * loop-unroll.c (analyze_insn_to_expand_var): Add dump info
+       when an accumulator is expanded.
+
+2007-03-04  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR other/30465
+       * c-common.c (convert_and_check): Don't give warnings for
+       conversion if 'expr' already overflowed.
+
+2007-03-04  Roger Sayle  <roger@eyesopen.com>
+
+       PR middle-end/30744
+       * fold-const.c (fold_comparison): Enforce type consistency when
+       transforming ~X op ~Y to Y op X, and ~X op C to X op' ~C.
+
+2007-03-04  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-address.c (create_mem_ref): Do not put an expression
+       containing a cast to the base of TARGET_MEM_REF.
+
+2007-03-04  Martin Michlmayr  <tbm@cyrius.com>
+
+       * tree.c (tree_contains_struct_check_failed): Remove spurious
+       whitespace from error message.
+
+2007-03-04 Andrew Pinski <andrew_pinski@playstation.sony.com>
+
+       PR target/30406
+       * config/rs6000/rs6000.c (rs6000_function_value): Look at bit size
+       instead of precision.
+
+2007-03-04  Roman Zippel <zippel@linux-m68k.org>
+           Nathan Sidwell  <nathan@codesourcery.com>
+
+       * emit-rtl.c (find_auto_inc): New.
+       (try_split): recreate REG_INC notes,
+       Use regular for loops rather than whiles.
+
+2007-03-03  Andreas Schwab  <schwab@suse.de>
+
+       * configure.ac (HAVE_AS_REL16): Move test back to correct place.
+       * configure: Regenerate.
+
+2007-03-03  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.def (ATTR_MATHFN_FPROUNDING): Rely on
+       flag_rounding_math, not flag_unsafe_math_optimizations.
+
+       * c-pretty-print.c (pp_c_direct_abstract_declarator): Use
+       fold_build2.
+       * config/alpha/alpha.c (alpha_fold_builtin_zapnot,
+       alpha_fold_vector_minmax): Likewise.
+       * config/i386/i386.c (ix86_gimplify_va_arg): Likewise.
+       * config/sparc/sparc.c (sparc_gimplify_va_arg): Likewise.
+
+2007-03-02  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-sra.c (sra_walk_fns) <ldst>: Document new restriction.
+       (sra_walk_modify_expr) <rhs_elt>: Treat the reference as a use
+       if the lhs has side-effects.
+       <lhs_elt>: Treat the reference as a use if the rhs has side-effects.
+
+2007-03-02  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (TUNEMASK): Remove define.
+       (ARCHMASK): Remove define.
+       (TARGET_*): Use ix86_tune_mask variable instead of TUNEMASK.
+        Use ix86_arch_mask variable instead of ARCHMASK.
+       * config/i386/i386.c (override_options): Ditto.
+       (standard_80387_constant_p): Ditto.
+
+2007-03-02  Ian Lance Taylor  <iant@google.com>
+
+       Used signed infinities in VRP.
+       * tree-vrp.c (uses_overflow_infinity): New static function.
+       (supports_overflow_infinity): New static function.
+       (make_overflow_infinity): New static function.
+       (negative_overflow_infinity): New static function.
+       (positive_overflow_infinity): New static function.
+       (is_negative_overflow_infinity): New static function.
+       (is_positive_overflow_infinity): New static function.
+       (is_overflow_infinity): New static function.
+       (overflow_infinity_range_p): New static function.
+       (compare_values_warnv): New function split out of compare_values.
+       (compare_value): Call it.
+       (set_value_range_to_nonnegative): Add overflow_infinity
+       parameter.  Change caller.
+       (vrp_expr_computes_nonnegative): Add strict_overflow_p parameter.
+       Change callers.
+       (vrp_expr_computes_nonzero): Likewise.
+       (compare_ranges, compare_range_with_value): Likewise.
+       (compare_name_with_value, compare_names): Likewise.
+       (vrp_evaluate_conditional): Likewise.
+       (set_value_range): Handle infinity
+       (vrp_operand_equal_p, operand_less_p): Likewise.
+       (extract_range_from_assert): Likewise.
+       (vrp_int_const_binop): Likewise.
+       (extract_range_from_binary_expr): Likewise.
+       (extract_range_from_unary_expr): Likewise.
+       (extract_range_from_comparison): Likewise.
+       (extract_range_from_expr): Likewise.
+       (dump_value_range): Likewise.
+       (vrp_visit_cond_stmt, vrp_visit_phi_node): Likewise.
+       (test_for_singularity): Likewise.
+       (vrp_int_const_binop): Remove inline qualifier.
+       (adjust_range_with_scev): Add comment.
+       * tree-flow.h (vrp_evaluate_conditional): Update declaration.
+
+2007-03-02  Diego Novillo  <dnovillo@redhat.com>
+
+       * tree-ssa-structalias.c (could_have_pointers): Tidy.
+       (get_constraint_for): Likewise.
+       (do_structure_copy): Likewise.
+       (find_func_aliases): Fix references to MODIFY_EXPR.
+       (intra_create_variable_infos): Tidy.
+       * tree-ssa-operands.c (add_virtual_operand): Add argument
+       IS_CALL_SITE.
+       When adding members of alias sets, if IS_CALL_SITE is true and
+       the symbol is not call-clobbered, skip it.
+       Adjust all callers.
+
+2007-03-02  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * config/alpha/alpha.c (alpha_gp_save_rtx): Insert the insns at the
+       entry by means of emit_insn_at_entry.
+
+2007-03-02  Richard Henderson  <rth@redhat.com>
+
+       * expr.h (promoted_input_arg): Remove decl.
+       * function.c (promoted_input_arg): Merge into ...
+       * combine.c (setup_incoming_promotions): ... only caller.
+       Rearrange to avoid double loop.
+
+2007-03-02  Ben Elliston  <bje@au.ibm.com>
+           Peter Bergner  <bergner@vnet.ibm.com>
+           Janis Johnson  <janis187@us.ibm.com>
+
+       * config/rs6000/dfp.md: New file.
+       * config/rs6000/rs6000.md: Include dfp.md.
+       (add<mode>3_internal1): Disable for DECIMAL_FLOAT_MODE_P operands.
+       * config/rs6000/rs6000.c (rs6000_hard_regno_mode_ok): Handle DDmode
+       and TDmode decimal float modes in FP registers.
+       (num_insns_constant): Likewise.
+       (rs6000_legitimate_offset_address_p): Likewise.
+       (rs6000_legitimize_address): Likewise.
+       (rs6000_legitimize_reload_address): Likewise.
+       (rs6000_legitimate_address): Likewise.
+       (rs6000_emit_move): Likewise.
+       (function_arg_boundary): Likewise.
+       (function_arg_advance): Likewise.
+       (rs6000_darwin64_record_arg_recurse): Likewise.
+       (function_arg): Likewise.
+       (rs6000_gimplify_va_arg): Likewise.
+       (rs6000_split_multireg_move): Likewise.
+       (rs6000_output_function_epilogue): Likewise.
+       (rs6000_output_function_epilogue): Likewise.
+       (rs6000_register_move_cost): Likewise.
+       (rs6000_function_value): Likewise.
+       (rs6000_libcall_value): Likewise.
+
+2007-03-02  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/t-vxworks (LIMITS_H_TEST): Define to true for VxWorks.
+
+2007-03-02  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/t-vxworks (LIBGCC2_INCLUDES): Pass -nostdinc.
+       Use $MULTIDIR to choose between the kernel and RTP headers,
+       and use $WIND_BASE and $WIND_USR to locate them.
+
+2007-03-02  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (override_options): Put initialization of
+       ix86_tune_mask and ix86_arch_mask to the correct place.
+
+2007-03-02  Uros Bizjak  <ubizjak@gmail.com>
+           Michael Meissner  <michael.meissner@amd.com>
+
+       PR target/31019
+       * config/i386/i386.h (TUNEMASK): Redefine to use ix86_tune_mask.
+       (ARCHMASK): Define.
+       (TARGET_CMOVE): Use ARCHMASK.
+       (TARGET_CMPXCHG): Ditto.
+       (TARGET_CMPXCHG8B): Ditto.
+       (TARGET_XADD): Ditto.
+       (TARGET_BSWAP): Ditto.
+       * config/i386/i386.c (ix86_tune_mask): New global variable.
+       (ix86_arch_mask): Ditto.
+       (override_options): Initialize ix86_tune_mask and
+       ix86_arch_mask. Use ARCHMASK to clear MASK_NO_FANCY_MATH_387 in
+       target_flags.
+
+2007-03-02  Ben Elliston  <bje@au.ibm.com>
+
+       PR 30992
+       * config/dfp-bit.c (DFP_TO_INT): Initialise qval with "1.".
+
+2007-03-02  Joseph Myers  <joseph@codesourcery.com>
+
+       * target.h (init_dwarf_reg_sizes_extra): New target hook.
+       * target-def.h (TARGET_INIT_DWARF_REG_SIZES_EXTRA): New default.
+       * doc/tm.texi (TARGET_INIT_DWARF_REG_SIZES_EXTRA): Document.
+       * dwarf2out.c (expand_builtin_init_dwarf_reg_sizes): Call this
+       hook.
+       * config/rs6000/rs6000.c (TARGET_INIT_DWARF_REG_SIZES_EXTRA,
+       rs6000_init_dwarf_reg_sizes_extra): New.
+       * config/rs6000/linux-unwind.h (ppc_fallback_frame_state): Support
+       SPE register high parts.
+
+2007-03-01  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * Makefile.in: Add install-pdf target as
+       copied from automake v1.10 rules.
+       * configure.ac: Add install-pdf to target list.
+       * configure: Regenerate.
+
+2007-03-01  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/arm.c (arm_legitimate_index_p): Limit iWMMXt addressing
+       modes to LDRD for DImode.
+       (output_move_double): Fixup out of range ldrd/strd.
+       (vfp_secondary_reload_class): Rename...
+       (coproc_secondary_reload_class): ... to this.  Add wb argument.
+       * config/arm/arm.h (SECONDARY_OUTPUT_RELOAD_CLASS): Use
+       coproc_secondary_reload_class for CLASS_IWMMXT.
+       (SECONDARY_INPUT_RELOAD_CLASS): Ditto.
+       * arm-protos.h (coproc_secondary_reload_class): Update prototype.
+
+2007-03-01  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-prefetch.c (determine_unroll_factor): Bound the
+       unroll factor by the estimated number of iterations.
+       (loop_prefetch_arrays): Do not prefetch in loops that iterate less
+       than prefetch latency.
+
+       * config/i386/driver-i386.c (describe_cache, detect_caches_amd,
+       decode_caches_intel, detect_caches_intel): New functions.
+       (host_detect_local_cpu): Use detect_caches_amd and
+       detect_caches_intel.
+
+2007-03-01  Richard Henderson  <rth@redhat.com>
+
+       * expr.c (emit_move_complex_push): Export.
+       (emit_move_complex_parts): Split out from ...
+       (emit_move_complex): ... here.
+       * expr.h (emit_move_complex_push, emit_move_complex_parts): Declare.
+       * config/i386/i386.md (movcdi): New.
+
+2007-03-01  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (ix86_modes_tieable_p): Fix typo, use also
+       size of mode1 to check for tieable modes in MMX case.
+
+2007-03-01  Richard Sandiford  <richard@codesourcery.com>
+
+       * Makefile.in (rtlanal.o): Depend on tree.h.
+       * rtl.h (offset_within_section_p, split_const): Declare.
+       * rtlanal.c: Include tree.h.
+       (offset_within_block_p): New function, taken from
+       mips_offset_within_object_p.
+       (split_const): New function, taken from mips_split_const.
+       * config/m68k/m68k-protos.h (m68k_illegitimate_symbolic_constant_p):
+       Declare.
+       * config/m68k/m68k.h (M68K_OFFSETS_MUST_BE_WITHIN_SECTIONS_P): Define.
+       (CONSTANT_ADDRESS_P): Only accept legitimate constants.
+       (LEGITIMATE_CONSTANT_P): Check m68k_illegitimate_symbolic_constant_p.
+       * config/m68k/m68k.c (TARGET_CANNOT_FORCE_CONST_MEM): Define.
+       (m68k_illegitimate_symbolic_constant_p): New function.
+       * config/m68k/m68k.md (movsi): Remove misleading predicates.
+       If M68K_OFFSETS_MUST_BE_WITHIN_SECTIONS_P and the source is a
+       symbolic constant that might be outside the symbol's section,
+       move the symbol first and then add the offset.
+       * config/m68k/uclinux.h (M68K_OFFSETS_MUST_BE_WITHIN_SECTIONS_P):
+       Override.
+       * config/mips/mips.c (mips_split_const): Delete.
+       (mips_offset_within_object_p): Delete.
+       (mips_symbolic_constant_p): Use offset_within_section_p and
+       split_const instead of mips_offset_within_object_p and
+       mips_split_const.
+       (mips_cannot_force_const_mem, mips_const_insns, mips_unspec_address)
+       (mips_legitimize_const_move, print_operand_reloc)
+       (mips_dangerous_for_la25_p): Use split_const instead of
+       mips_split_const.
+
+2007-02-28  Eric Christopher  <echristo@apple.com>
+
+       * Makefile.in (install-include-dir): Don't rm -rf include.
+
+2007-02-28  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/30364
+       * fold-const.c (fold_binary): Do not associate expressions
+       with more than one variable for integer types that do not wrap.
+
+2007-02-28  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * builtins.c (fold_builtin_call_list, fold_builtin_call_valist):
+       Delete, and replace with...
+       (fold_builtin_call_array): This.  Update callers to use it.
+       * fold-const.c (fold_build_call_list): Delete, and replace with...
+       (fold_build_call_array): This.
+       (fold_build_call_list_initializer): Delete, and replace with...
+       (fold_build_call_array_initializer): This.
+       * tree.h: Update declarations to reflect above changes.
+
+       * c-typeck.c (build_function_call): Store converted arguments
+       in a stack-allocated array instead of building a list.
+       (convert_arguments): Store arguments in the array passed in as an
+       argument, and return the actual number of arguments.
+       * c-format.c: (check_function_format): Pass arguments in an
+       array instead of a list.
+       * c-common.c (check_function_nonnull): Likewise.
+       (check_function_sentinel): Likewise.
+       (check_function_arguments): Likewise.
+       * c-common.h: Update declarations to reflect above changes.
+
+2007-02-28  Jan Hubicka  <jh@suse.cz>
+
+       * predict.def (PRED_TREE_EARLY_RETURN, PRED_CONST_RETURN,
+       PRED_NEGATIVE_RETURN): Update outcomes.
+
+2007-02-28  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * calls.c (emit_library_call_value_1): Handle partial registers
+       correctly when building up CALL_INSN_FUNCTION_USAGE.
+
+2007-02-27  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa/predicates.md (move_src_operand): Allow zero for mode.
+       * pa/pa.md: Fix constraints for zero CONST_DOUBLE in 64-bit DFmode
+       move pattern.
+
+2007-02-27  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/30970
+       * config/i386/sse.md (*mov<mode>_internal, *movv4sf_internal,
+       *movv2df_internal): Enable pattern only for valid operand
+       combinations.
+       * config/i386/i386.c (ix86_modes_tieable_p): For SSE registers,
+       tie only 128bit modes. For MMX registers, tie only 64bit modes.
+
+2007-02-27  Mike Stump  <mrs@apple.com>
+
+       * config/darwin-crt3.c: Avoid compilation when compiling for a
+       kext multilib.
+
+2007-02-27  Joseph Myers  <joseph@codesourcery.com>
+
+       * Makefile.in (PREPROCESSOR_DEFINES, test-protoize-simple): Define
+       FIXED_INCLUDE_DIR.
+       (stmp-int-hdrs, stmp-fixinc, install-headers): Use include-fixed
+       for fixed headers and limits.h.
+       (install-include-dir, install-headers-tar, install-headers-cpio,
+       install-headers-cp, real-install-headers-tar,
+       real-install-headers-cpio, real-install-headers-cp): Handle
+       include-fixed as well as include.
+       (install-mkheaders): Don't install files that go only in include
+       not include-fixed.
+       * cppdefault.c (cpp_include_defaults): Separate FIXED_INCLUDE_DIR
+       from GCC_INCLUDE_DIR.
+       * gcc.c (process_command): Remove special -BstageN/ handling.
+       (do_spec_1): Add include-fixed directories.
+
+2007-02-27  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/t-bfin-elf (LIB1ASMFUNCS): Add _umulsi3_highpart and
+       _smulsi3_highpart.
+       * config/bfin/lib1funcs.asm (___umulsi3_highpart, ___smulsi3_highpart):
+       New functions.
+       * config/bfin/bfin.md (smulsi3_highpart, umulsi3_highpart): New
+       patterns.
+
+2007-02-27  Mark Mitchell  <mark@codesourcery.com>
+
+       * c-common.c (get_priority): Add check for
+       SUPPORTS_INIT_PRIORITY.
+
+2007-02-27  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.md (doloop_end): FAIL if counter reg isn't SImode.
+
+       * config/bfin/bfin.c: Include "cfglayout.h".
+       (MAX_LSETUP_DISTANCE): New macro.
+       (struct loop_info): New members incoming, incoming_src and
+       incoming_dest.  Delete member predecessor.
+       (length_for_loop): New function.
+       (bfin_optimize_loop): Handle more different loop structures.
+       (bfin_discover_loop): Rework detection of predecessor blocks by
+       examining incoming edges.
+       (bfin_discover_loops, bfin_free_loops): New functions, broken out of
+       bfin_reorg_loops.
+       (bfin_reorder_loops): New function.
+       (bfin_reorg_loops): Use these three new functions.
+
+       * config/bfin/bfin.h (enum reg_class, REG_CLASS_NAMES,
+       REG_CLASS_CONTENTS): Add D0REGS through D7REGS.
+       (CONSTRAINT_LEN): Add entry for 'q'.
+       (REG_CLASS_FROM_CONSTRAINT): Renamed from REG_CLASS_FROM_LETTER.
+       Add 'q' constraints.
+       (REGNO_REG_CLASS): For R0 through R7, return corresponding regclass.
+       (CLASS_LIKELY_SPILLED_P): True for R0, R1 and R2.
+
+       * config/bfin/bfin.md (add_with_carry): New pattern.
+       (s_or_u, su_optab, su_modifier): New code macros/attrs.
+       (<su_optab>hisi_ll, <su_optab>hisi_lh, <su_optab>hisi_hl,
+       <su_optab>hisi_hh): Renamed from mulhisi_xx patterns; macroized to
+       support unsigned multiplies too.  Removed incorrect commutativity from
+       operand 1 constraint where appropriate.
+       (usmulhisi_ull, usmulhisi_ulh, usmulhisi_uhl, usmulhisi_uhh): New
+       patterns.
+       (<su_optab>hisi_ll_lh, <su_optab>hisi_ll_hl, <su_optab>hisi_ll_hh,
+       <su_optab>hisi_lh_hl, <su_optab>hisi_lh_hh, <su_optab>hisi_hl_hh):
+       New patterns.
+       (usmulhisi_ll_lul, usmulhisi_ll_luh, usmulhisi_ll_hul,
+       usmulhisi_ll_huh, usmulhisi_lh_lul, usmulhisi_lh_luh, usmulhisi_lh_hul,
+       usmulhisi_lh_huh, usmulhisi_hl_lul, usmulhisi_hl_luh, usmulhisi_hl_hul,
+       usmulhisi_hl_huh, usmulhisi_hh_lul, usmulhisi_hh_luh, usmulhisi_hh_hul,
+       usmulhisi_hh_huh): New patterns.
+
+       * config/bfin/bfin.md (ssashiftv2hi3, ssashifthi3, lshiftv2hi3,
+       lshifthi3): Fix output template to use half reg for operand 2.
+
+       * config/bfin/bfin.c (bfin_output_mi_thunk): Use R3 as scratch reg
+       instead of R2.
+
+       * config/bfin/bfin.md (rotl16, rotlsi3, rotrsi3): New patterns.
+
+2007-02-27  Andreas Schwab  <schwab@suse.de>
+
+       * Makefile.in (TEXI_GCCINSTALL_FILES): Add gcc-common.texi.
+
+2007-02-27  Jan Hubicka  <jh@suse.cz>
+
+       * predict.c (last_basic_block_p): Remove.
+       (tree_estimate_probability): Update return heuristic for commonized
+       return blocks.
+
+2007-02-26  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * Makefile.in (TEXI_GCCINSTALL_FILES): Add gcc-vers.texi dependency.
+
+2007-02-26  Brooks Moses  <brooks.moses@codesourcery.com>
+
+       * doc/include/gcc-common.texi (versionsubtitle): New macro.
+       * doc/cpp.texi: Standardize title page.
+       * doc/cppinternals.texi: Likewise.
+       * doc/gcc.texi: Standardize title page, remove version number
+       from copyright page.
+       * doc/gccint.texi: Likewise.
+       * doc/install.texi: Standardize title page, add table of
+       contents.
+
+2007-02-26  Jan Hubicka  <jh@suse.cz>
+
+       * predict.def: Set outcomes according to more recent results.
+       (PRED_LOOP_CONDITION, PRED_LOOP_PRECONDITIONING, PRED_LOOP_HEADER):
+       Remove dead predictors.
+       * predict.c (return_prediction): Fix pasto.
+
+2007-02-27  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * loop-iv.c (simplify_using_initial_values): Fix oversight in previous
+       change; avoid a memory leak when returning early.
+
+2007-02-26  Mark Mitchell  <mark@codesourcery.com>
+
+       * c-decl.c (static_ctors): Move to c-common.c.
+       (static_dtors): Likewise.
+       (finish_function): Use c_record_cdtor_fn.
+       (build_cdtor): Move to c-common.c.
+       (c_write_global_declarations): Use c_build_cdtor_fns.
+       * c-common.h (static_ctors): Declare.
+       (static_dtors): Likewise.
+       (c_record_cdtor_fn): Likewise.
+       (c_build_cdtor_fns): Likewise.
+       * c-common.c (static_ctors): New variable.
+       (static_dtors): Likewise.
+       (c_record_cdtor_fn): New function.
+       (build_cdtor): Move from c-decl.c
+       (c_build_cdtor_fns): New function.
+
+       * output.h (assemble_addr_to_section): Declare.
+       (get_cdtor_priority_section): Likewise.
+       * varasm.c (assemble_addr_to_section): New function.
+       (get_cdtor_priority_section): Likewise.
+       (default_named_section_asm_out_destructor): Use them.
+       (destor_dtor_section_asm_out_destructor): Likewise.
+       (default_named_section_asm_out_constructor): Likewise.
+       (default_ctor_section_asm_out_constructor): Likewise.
+       * config.gcc (*-*-vxworks*): Include vxworks.o.
+       * config/t-vxworks (vxworks.o): New target.
+       * config/vxworks.h (ALWAYS_NUMBER_CTORS_SECTIONS): Remove.
+       (TARGET_ASM_CONSTRUCTOR): Define.
+       (TARGET_ASM_DESTRUCTOR): Likewise.
+       (vxworks_asm_out_constructor): Declare.
+       (vxworks_asm_out_destructor): Likewise.
+
+       * c-common.c (get_priority): Check that we have not just an
+       INTEGER_CST, but an integer constant with integeral type.
+
+2007-02-25  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR tree-optimization/30938
+       * tree-vect-transform.c (vectorizable_call): Fix off-by-one error:
+       use &dt[nargs-1] instead of &dt[nargs] in the call to
+       vect_is_simple_use().
+
+2007-02-25  Ulrich Weigand  <uweigand@de.ibm.com>
+
+       * reload.c (find_reloads_address_1): Handle PLUS expressions resulting
+       from register elimination as PRE_MODIFY / POST_MODIFY increments.
+       Do not attempt to handle MEM inside auto-inc expressions.
+       * reload1.c (eliminate_regs_1): Do not attempt to handle elimination
+       of a register modified by an auto-inc expression.  However, do handle
+       elimination of a register used as PRE_MODIFY / POST_MODIFY increment.
+       (elimination_effects): Prohibit elimination of a register modified
+       by an auto-inc expression.  Disable register elimination rules whose
+       target register is modified by an auto-inc expression with variable
+       increment.
+
+2007-02-25  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-ssa-loop-niter.c (compute_estimated_nb_iterations): Fix
+       off-by-one error.
+       (array_at_struct_end_p): New function.
+       (idx_infer_loop_bounds): Use it.
+       (estimate_numbers_of_iterations_loop): Export.
+       * predict.c (predict_loops): Use estimated_loop_iterations_int.
+       Do not use PRED_LOOP_EXIT on exits predicted by # of iterations.
+       (tree_estimate_probability): Call record_loop_exits.
+       * tree-data-ref.c (get_number_of_iters_for_loop): Replaced by ...
+       (estimated_loop_iterations, estimated_loop_iterations_int,
+       estimated_loop_iterations_tree): New functions.
+       (analyze_siv_subscript_cst_affine,
+       compute_overlap_steps_for_affine_1_2,
+       analyze_subscript_affine_affine): Use estimated_loop_iterations_int.
+       (analyze_miv_subscript): Use estimated_loop_iterations_tree.
+       * predict.def (PRED_LOOP_ITERATIONS): Update comment.
+       (PRED_LOOP_ITERATIONS_GUESSED): New.
+       * cfgloop.c (record_loop_exits): Do nothing if there are no loops.
+       * cfgloop.h (estimate_numbers_of_iterations_loop,
+       estimated_loop_iterations_int): Declare.
+
+2007-02-25  Mark Mitchell  <mark@codesourcery.com>
+
+       * doc/extend.texi: Document optional priority argument to
+       constructors and destructors.
+       * tree.c (init_priority_for_decl): Adjust GTY markers.
+       (init_ttree): Use priority-info hash functions for
+       init_priority_for_decl.
+       (tree_map_eq): Rename to ...
+       (tree_map_base_eq): ... this.
+       (tree_map_marked_p): Rename to ...
+       (tree_map_base_marked_p): ... this.
+       (tree_map_base_hash): New function.
+       (decl_init_priority_lookup): Rework.
+       (decl_fini_priority_lookup): New function.
+       (decl_priority_info): New function.
+       (decl_init_priority_insert): Use it.
+       (decl_fini_priority_insert): Likewise.
+       (decl_restrict_base_lookup): Adjust for refactoring of tree_map
+       hierarchy.
+       (decl_restrict_base_insert): Likewise.
+       (decl_debug_expr_insert): Likewise.
+       (decl_value_expr_lookup): Likewise.
+       (decl_value_expr_insert): Likewise.
+       * tree.h (priority_type): New type.
+       (decl_init_priority_lookup): Use priority_type.
+       (decl_fini_priority_lookup): New function.
+       (decl_init_priority_insert): Use priority_type.
+       (decl_fini_priority_insert): New function.
+       (DECL_HAS_INIT_PRIORITY): Tweak comments.
+       (DECL_INIT_PRIORITY): Likewise.
+       (SET_DECL_INIT_PRIORITY): Add comment.
+       (DECL_FINI_PRIORITY): New macro.
+       (SET_DECL_FINI_PRIORITY): Likewise.
+       (DEFAULT_INIT_PRIORITY): Document.
+       (MAX_INIT_PRIORITY): Likewise.
+       (MAX_RESERVED_INIT_PRIORITY): Likewise.
+       (tree_map_base): New type.
+       (tree_map_base_eq): New function.
+       (tree_map_base_hash): Likewise.
+       (tree_map_base_marked_p): Likewise.
+       (tree_map): Inherit from tree_map_base.
+       (tree_map_eq): Make it a macro.
+       (tree_map_marked_p): Likewise.
+       (tree_int_map): Inherit from tree_map_base.
+       (tree_int_map_eq): Make it a macro.
+       (tree_int_map_hash): Likewise.
+       (tree_int_map_marked_p): Likewise.
+       (tree_priority_map): New type.
+       (tree_priority_map_eq): New macro.
+       (tree_priority_map_hash): Likewise.
+       (tree_priority_map_marked_p): Likewise.
+       * varasm.c (emults_decl): Adjust for refactoring of tree_map
+       hierarchy.
+       (emutls_common_1): Likewise.
+       * lambda-code.c (replace_uses_equiv_to_x_with_y): Likewise.
+       * tree-ssa-structalias.c (heapvar_lookup): Adjust for refactoring
+       of tree_map hierarchy.
+       * tree-cfg.c (move_stmt_r): Likewise.
+       (new_label_mapper): Likewise.
+       * c-tree.h (c_expand_body): Move to ...
+       * c-common.h (c_expand_body): ... here.
+       * c-decl.c (c_expand_body): Move to ...
+       * c-common.c (c_expand_body): ... here.
+       (c_common_attribute_table): Allow 1 argument for the constructor
+       and destructor attributes.
+       (get_priority): New function.
+       (handle_constructor_attribute): Set DECL_INIT_PRIORITY.
+       (handle_destructor_attribute): Set DECL_FINI_PRIORITY.
+
+2007-02-24  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/30509
+       * tree-inline.c (copy_bb): Produce exact copy of EH info when
+       copying for inlining.
+
+2007-02-24  Uros Bizjak  <ubizjak@gmail.com>
+           Jan Hubicka  <jh@suse.cz>
+
+       PR target/30778
+       * cofnig/i386/i386.c (counter_mode): New function.
+       (expand_set_or_movmem_via_loop): Use it.
+       (expand_movmem_epilogue): Likewise; fix pasto.
+       (ix86_expand_movmem): Do emit guard even for constant counts.
+       (ix86_expand_setmem): Likewise.
+
+2007-02-25  Nick Clifton  <nickc@redhat.com>
+
+       * config/frv/frv.h (ASM_OUTPUT_CASE_LABEL): Delete.
+       (JUMP_TABLES_IN_TEXT_SECTION): Define.
+
+2007-02-24  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/30770
+       * config/i386/i386.md (expand_movmem_epilogue): Fix typo, mask
+       count argument with 0x10, not with 0x16.
+       (expand_setmem_epilogue): Ditto.
+
+2007-02-24  Mike Stump  <mrs@apple.com>
+
+       * config/i386/i386.c (output_pic_addr_const): Stubify optimized
+       symbols.
+
+2007-02-24  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/30951
+       * fold-const.c (fold_binary): Fold x +- CST op x for
+       EQ_EXPR and NE_EXPR.
+
+2007-02-24  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.md (muldi3): Force subregs to registers in 64-bit expander.
+
+2007-02-24  Jan Hubicka  <jh@suse.cz>
+
+       * cgraphunit.c (decide_is_function_needed): Honor
+       -fkeep-inline-functions.
+
+2007-02-24  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.c (fold_builtin_modf): New.
+       (fold_builtin_2): Use it.
+
+2007-02-24  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * loop-iv.c (implies_p): Detect additional cases where A implies B.
+       (determine_max_iter): Take additional LOOP arg; all callers changed.
+       Lose broken logic dealing with PLUS.  Try to limit the upper bound by
+       one using simplifications.
+       (simplify_using_initial_values): Return if the expression becomes
+       invalid due to altered regs.
+
+2007-02-23  DJ Delorie  <dj@redhat.com>
+
+       * doc/tm.h (BIGGEST_ALIGNMENT): Clarify the purpose of this macro.
+
+2007-02-23  Mike Stump  <mrs@apple.com>
+
+       * tlink.c (scan_linker_output): Parse linker messages from
+       darwin9's linker better.
+
+2007-02-23  Steve Ellcey  <sje@cup.hp.com>
+
+       PR debug/29614
+       * varpool.c (varpool_assemble_pending_decls): Set
+       varpool_last_needed_node to null.
+
+2007-02-23  DJ Delorie  <dj@redhat.com>
+
+       * config/i386/i386.c (ix86_data_alignment): Don't specify an
+       alignment bigger than the object file can handle.
+
+2007-02-23  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/30825
+       * config/i386/i386.md (*movdi_1_rex64, zero_extendsidi2_32,
+       zero_extendsidi2_rex64): Penalize MMX register<->memory moves.
+       (*movsf_1): Penalize MMX moves.
+
+2007-02-23  Bernd Schmidt  <bernd.schmidt@analog.com>
+
+       * config/bfin/bfin.md (doloop_end): Fail for loops that can iterate
+       2^32-1 or more times unless flag_unsafe_loop_optimizations.
+
+       * loop-iv.c (determine_max_iter): Moved in front of its sole user.
+
+2007-02-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.c (fold_builtin_logb, fold_builtin_significand): New.
+       (fold_builtin_1): Use them.
+       * fold-const.c (tree_expr_nonnegative_warnv_p): Handle
+       BUILT_IN_SIGNIFICAND.
+
+2007-02-23  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/i386/i386.c (bdesc_1arg): Initialize
+       IX86_BUILTIN_MOVSHDUP and IX86_BUILTIN_MOVSLDUP with
+       "__builtin_ia32_movshdup" and "__builtin_ia32_movsldup".
+       (ix86_init_mmx_sse_builtins): Remove IX86_BUILTIN_MOVSHDUP
+       and IX86_BUILTIN_MOVSLDUP.
+
+2007-02-22  Paolo Bonzini  <bonzini@gnu.org>
+
+       PR rtl-optimization/30841
+       * fwprop.c (propagate_rtx_1): Accept a VOIDmode replacement address.
+
+2007-02-22  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.c (fold_builtin_frexp): New.
+       (fold_builtin_2): Use it.
+
+2007-02-22  Mark Mitchell  <mark@codesourcery.com>
+
+       * doc/invoke.texi (Spec Files): Document getenv spec function.
+
+       * gcc.c (getenv_spec_function): New function.
+       (static_spec_functions): Add it.
+       * config/vxworks.h (VXWORKS_TARGET_DIR): Remove.
+       (VXWORKS_ADDITIONAL_CPP_SPEC): Use getenv to find the VxWorks
+       header files.
+
+2007-02-22  Michael Matz  <matz@suse.de
+
+       PR c++/29433
+       * dwarf2out.c (add_AT_string): Call ggc_strdup once per string.
+       (type_tag): Use lang_hooks.dwarf_name instead of DECL_NAME.
+
+2007-02-22  Ian Lance Taylor  <iant@google.com>
+
+       PR debug/30898
+       * dwarf2out.c (concatn_mem_loc_descriptor): New static function.
+       (mem_loc_descriptor): Call it.
+
+2007-02-22  Zdenek Dvorak  <dvorakz@suse.cz>
+           Ira Rosen  <irar@il.ibm.com>
+
+       * tree-data-ref.c (ptr_ptr_may_alias_p): Take alias sets into account.
+
+2007-02-22  Ira Rosen  <irar@il.ibm.com>
+
+       PR tree-optimization/30843
+       * tree-vect-transform.c (vect_transform_loop): Remove strided scalar
+       stores only after all the group is vectorized.
+
+2007-02-22  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/30858
+       * tree-vectorizer.c (vect_is_simple_reduction): Check that the stmts
+       in the reduction cycle have a single use in the loop.
+       * tree-vectorizer.h (relevant): Add documentation.
+
+2007-02-20  Mike Stump  <mrs@apple.com>
+
+       * configure.ac (powerpc*-*-darwin*): #include <sys/cdefs.h>.
+       * configure: Regenerate.
+
+2007-02-21  Trevor Smigiel  <trevor_smigiel@playstation.sony.com>
+
+       Change the defaults of some parameters and options.
+       * config/spu/spu-protos.h (spu_optimization_options): Declare.
+       * config/spu/spu.c (spu_optimization_options): Add.
+       (spu_override_options): Change params in spu_optimization_options.
+       * config/spu/spu.h (OPTIMIZATION_OPTIONS): Define.
+
+       Register 127 is only 16 byte aligned when used as a frame pointer.
+       * config/spu/spu-protos.h (spu_init_expanders): Declare.
+       * config/spu/spu.c (spu_expand_prologue): Set REGNO_POINTER_ALIGN for
+       HARD_FRAME_POINTER_REGNUM.
+       (spu_legitimate_address): Use regno_aligned_for_reload.
+       (regno_aligned_for_load): HARD_FRAME_POINTER_REGNUM is only 16 byte
+       aligned when frame_pointer_needed is true.
+       (spu_init_expanders): New.  Set alignment of HARD_FRAME_POINTER_REGNUM
+       to 8 bits.
+       * config/spu/spu.h (INIT_EXPANDERS): Define.
+
+       Make sure shift and rotate instructions have valid immediate operands.
+       * config/spu/predicates.md (spu_shift_operand): Remove.
+       * config/spu/spu.c (print_operand): Add [efghEFGH] modifiers.
+       * config/spu/constraints.md (W, O): Extend range.
+       * config/spu/spu.md (umask, nmask): Define.
+       (ashl<mode>3, ashldi3, ashlti3_imm, shlqbybi_ti, shlqbi_ti, shlqby_ti,
+       lshr<mode>3, rotm_<mode>, lshr<mode>3_imm, rotqmbybi_<mode>,
+       rotqmbi_<mode>, rotqmby_<mode>, ashr<mode>3, rotma_<mode>,
+       rotl<mode>3, rotlti3, rotqbybi_ti, rotqby_ti, rotqbi_ti): Use
+       spu_nonmem_operand instead of spu_shift_operands.  Use new modifiers.
+       (lshr<mode>3_reg): Fix rtl description.
+
+       Make sure mulhisi immediate operands are valid.
+       * config/spu/predicates.md (imm_K_operand): Add.
+       * config/spu/spu.md (mulhisi3_imm, umulhisi3_imm): Use imm_K_operand.
+
+       Generate constants using fsmbi and andi.
+       * config/spu/spu.c (enum immediate_class): Add IC_FSMBI2.
+       (print_operand, spu_split_immediate, classify_immediate,
+       fsmbi_const_p): Handle IC_FSMBI2.
+
+       Correctly handle a CONST_VECTOR containing symbols.
+       * config/spu/spu.c (print_operand): Handle HIGH correctly.
+       (spu_split_immediate): Split CONST_VECTORs with -mlarge-mem.
+       (immediate_load_p): Allow symbols that use 2 instructions to create.
+       (classify_immediate, spu_builtin_splats): Don't accept a CONST_VECTOR
+       with symbols when flag_pic is set.
+       (const_vector_immediate_p): New.
+       (logical_immediate_p, iohl_immediate_p, arith_immediate_p): Don't
+       accept a CONST_VECTOR with symbols.
+       (spu_legitimate_constant_p): Use const_vector_immediate_p.  Don't
+       accept a CONST_VECTOR with symbols when flag_pic is set.  Handle HIGH
+       correctly.
+       * config/spu/spu.md (high, low): Delete.
+       (low_<mode>): Define.
+
+       Remove INTRmode and INTR_REGNUM, which didn't work.
+       * config/spu/spu.c (spu_conditional_register_usage): Remove reference
+       of INTR_REGNUM.
+       * config/spu/spu-builtins.md (spu_idisable, spu_ienable, set_intr,
+       set_intr_pic, set_intr_cc, set_intr_cc_pic, set_intr_return, unnamed
+       peephole2 pattern): Don't use INTR or 131.
+       (movintrcc): Delete.
+       * config/spu/spu.h (FIRST_PSEUDO_REGISTER, FIXED_REGISTERS,
+       CALL_USED_REGISTERS, REGISTER_NAMES, INTR_REGNUM): Remove INTR_REGNUM.
+       * config/spu/spu.md (UNSPEC_IDISABLE, UNSPEC_IENABLE): Remove.
+       (UNSPEC_SET_INTR): Add.
+       * config/spu/spu-modes.def (INTR): Remove.
+
+       More accurate warnings about run-time relocations.
+       * config/spu/spu.c (reloc_diagnostic): Test in_section.
+
+       Correctly warn about immediate arguments to specific intrinsics.
+       * config/spu/spu.c (spu_check_builtin_parm): Handle CONST_VECTORs.
+       (spu_expand_builtin_1): Call spu_check_builtin_parm before checking
+       the instruction predicate.
+
+       Fix tree check errors with latest update.
+       * config/spu/spu.c (expand_builtin_args, spu_expand_builtin_1): Use
+       CALL_EXPR_ARG.
+       (spu_expand_builtin): Use CALL_EXPR_FN.
+
+       Add missing specific intrinsics.
+       * config/spu/spu-builtins.def: Add si_bisled, si_bisledd and
+       si_bislede.
+       * config/spu/spu_internals.h: Ditto.
+
+       Fix incorrect operand modifiers.
+       * config/spu/spu-builtins.md (spu_mpy, spu_mpyu): Remove use of %H.
+       * config/spu/spu.md (xor<mode>3): Change %S to %J.
+
+       Optimize one case of zero_extend of a vec_select.
+       * config/spu/spu.md (_vec_extractv8hi_ze): Add.
+
+       Accept any immediate for hbr.
+       * config/spu/spu.md (hbr): Change s constraints to i.
+
+2007-02-21  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/arm.c (thumb2_final_prescan_insn): Don't incrememnt
+       condexec_count when skipping USE and CLOBBER.
+
+2007-02-21  Nick Clifton  <nickc@redhat.com>
+
+       * common.opt (Warray-bounds): Add Warning attribute.
+       (Wstrict-overflow, Wstrict-overflow=, Wcoverage-mismatch):
+       Likewise.
+       (fsized-zeroes): Add Optimization attribute.
+       (fsplit-wide-types, ftree-scev-cprop): Likewise.
+       * c.opt (Wc++0x-compat): Add Warning attribute.
+
+2007-02-21  Ulrich Weigand  <uweigand@de.ibm.com>
+
+       PR middle-end/30761
+       * reload1.c (eliminate_regs_in_insn): In the single_set special
+       case, attempt to re-recognize the insn before falling back to
+       having reload fix it up.
+
+2007-02-20  Eric Christopher  <echristo@gmail.com>
+
+       * config/frv/frv.c (frv_read_argument): Take a tree and int argument.
+       Rewrite accordingly.
+       (frv_read_iacc_argument): Ditto.
+       (frv_expand_set_builtin): Take a call instead of arglist, update for
+       above changes.
+       (frv_expand_unop_builtin): Ditto.
+       (frv_expand_binop_builtin): Ditto.
+       (frv_expand_cut_builtin): Ditto.
+       (frv_expand_binopimm_builtin): Ditto.
+       (frv_expand_voidbinop_builtin): Ditto.
+       (frv_expand_int_void2arg): Ditto.
+       (frv_expand_prefetches): Ditto.
+       (frv_expand_voidtriop_builtin): Ditto.
+       (frv_expand_voidaccop_builtin): Ditto.
+       (frv_expand_load_builtin): Ditto.
+       (frv_expand_store_builtin): Ditto.
+       (frv_expand_mdpackh_builtin): Ditto.
+       (frv_expand_mclracc_builtin): Ditto.
+       (frv_expand_mrdacc_builtin): Ditto.
+       (frv_expand_mwtacc_builtin): Ditto.
+       (frv_expand_builtin): Remove usage of CALL_EXPR_ARGS, update
+       calls for above.
+
+2007-02-20  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/invoke.texi (RS/6000 and PowerPC Options): Add -mcmpb and -mdfp.
+       * configure.ac (HAVE_GAS_CMPB): Check for assembler support of the
+       cmpb instruction.
+       (HAVE_GAS_DFP): Check for assembler support of decimal floating
+       point instructions.
+       * configure: Regenerate.
+       * config.in: Regenerate.
+       * config/rs6000/rs6000.opt (mcmpb, mdfp): New.
+       * config/rs6000/rs6000.c (rs6000_override_options): Add CMPB and DFP
+       masks to power6 and power6x and to POWERPC_MASKS.
+       * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Define
+       _ARCH_PWR6.
+       * config/rs6000/rs6000.h: Check assembler support for CMPB and DFP.
+       * config/rs6000/sysv4.opt (mprototype): Use variable, not mask.
+       * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS):
+       Access PROTOTYPE as variable, not mask.
+
+2007-02-20  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * rtl.h (remove_reg_equal_equiv_notes): New prototype.
+       * rtlanal.c (remove_reg_equal_equiv_notes): New function.
+       * combine.c (adjust_for_new_dest): Use it.
+       * postreload.c (reload_combine): Likewise.
+
+2007-02-20  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * rtlanal.c (find_reg_equal_equiv_note): Do not find REG_EQ*
+       notes on an insn with multiple sets, even if single_set returns
+       non-NULL for that insn.
+
+2007-02-20  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * fold-const.c (tree_expr_nonnegative_warnv_p): Handle scalb,
+       scalbn and scalbln.
+
+2007-02-20  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/darwin.h (LINK_SPEC): Default -mmacosx-version-min only
+       if user didn't pass it.
+       * config/i386/darwin.h (CC1_SPEC): Likewise.
+       * config/rs6000/darwin.h (CC1_SPEC): Likewise.
+       (DARWIN_MINVERSION_SPEC): Don't depend on user's setting of
+       -mmacosx-version-min.
+
+2007-02-20  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+           Uros Bizjak  <ubizjak@gmail.com>
+
+       * optabs.h (enum optab_index): Add new OTI_scalb.
+       (scalb_optab): Define corresponding macro.
+       * optabs.c (init_optabs): Initialize scalb_optab.
+       * genopinit.c (optabs): Implement scalb_optab using scalb?f3
+       patterns.
+       * builtins.c (expand_builtin_mathfn_2, expand_builtin): Handle
+       BUILT_IN_SCALB{,F,L}, BUILT_IN_SCALBN{,F,L} and BUILT_IN_SCALBLN{,F,L}.
+       (expand_builtin): Expand BUILT_IN_SCALB{,F,L}, BUILT_IN_SCALBN{,F,L}
+       and BUILT_IN_SCALBLN{,F,L} using expand_builtin_mathfn_2 if
+       flag_unsafe_math_optimizations is set.
+
+       * config/i386/i386.md (scalbxf3, scalb<mode>3): New expanders
+       to implement scalbf, scalb and scalbl built-ins as inline x87
+       intrinsics.
+
+2007-02-20  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+           DJ Delorie <dj@redhat.com>
+
+       PR other/30824
+       * diagnostic.c (diagnostic_count_diagnostic): Move -Werror logic to...
+       (diagnostic_report_diagnostic): ... here, and turn them into real
+       errors. If warnings are inhibited, no need to do anything.
+
+2007-02-20  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (expm1xf2): Reorder insn sequence for
+       better code generation.
+
+2007-02-20  Ben Elliston  <bje@au.ibm.com>
+
+       * config/m68hc11/m68hc11.h (OVERRIDE_OPTIONS): Remove extra ;.
+
+2007-02-20  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/alpha/alpha.c, config/alpha/alpha.md,
+       config/alpha/lib1funcs.asm, config/alpha/vms-crt0-64.c,
+       config/alpha/vms-psxcrt0-64.c, config/arc/arc.c,
+       config/arc/arc.h, config/arm/arm.c, config/arm/arm.md,
+       config/arm/lib1funcs.asm: Follow spelling conventions.
+
+       * config/c4x/c4x.md, config/cris/cris.c, config/crx/crx.c,
+       config/fr30/fr30.md, config/i386/i386.h,
+       config/iq2000/iq2000.h, config/iq2000/predicates.md,
+       config/pa/milli64.S, config/pa/pa.c, config/pa/pa.h,
+       config/pa/pa.md, config/pa/pa32-regs.h, config/pa/pa64-regs.h,
+       config/pdp11/pdp11.c, config/pdp11/pdp11.h,
+       config/rs6000/altivec.md, config/rs6000/rs6000.c,
+       config/s390/s390-modes.def, config/sparc/netbsd-elf.h,
+       config/sparc/sparc.c, config/sparc/sparc.h,
+       config/sparc/sparc.md, config/spu/constraints.md,
+       config/spu/spu.c, config/stormy16/stormy16.md: Follow spelling
+       conventions.
+
+2007-02-20  Alan Modra  <amodra@bigpond.net.au>
+
+       PR target/29943
+       * varasm.c (use_blocks_for_decl_p): Return false for decls with
+       alias attribute.
+
+2007-02-19  Kazu Hirata  <kazu@codesourcery.com>
+
+       * doc/invoke.texi (-ftree-lrs): Remove.
+
+2007-02-19  Diego Novillo  <dnovillo@redhat.com>
+
+       * tree-ssa-pre.c (create_value_expr_from): Initialize POOL to
+       NULL.
+
+2007-02-19  Lee Millward  <lee.millward@codesourcery.com>
+
+       * config/ia64/ia64.c (ia64_expand_builtin): Use the
+       new CALL_EXPR_FN macro for retrieving the function
+       declaration of the input expression.
+
+2007-02-19  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * c.opt (Waddress): New.
+       * common.opt (Walways-true): Delete.
+       (Wstring-literal-comparison): Delete.
+       * doc/invoke.texi (Warning Options): Delete -Walways-true and
+       -Wstring-literal-comparison. Add -Waddress.
+       (Waddress): New.
+       (Walways-true): Delete.
+       (Wstring-literal-comparison): Delete.
+       * doc/extend.texi (#pragma GCC diagnostic): Use -Wformat
+       consistently instead of -Walways-true in example.
+       * c-opts.c (c_common_handle_option): -Waddress is enabled by -Wall.
+       * c-typeck.c (parser_build_binary_op): Replace
+       -Wstring-literal-comparison and -Walways-true with -Waddress.
+       * c-common.c (c_common_truthvalue_conversion): Replace -Walways-true
+       with -Waddress.
+
+2007-02-19  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-cfg.c (dump_function_to_file): Be prepared for functions
+       without DECL_STRUCT_FUNCTION initialized.
+
+2007-02-19  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gimplify.c (gimplify_init_ctor_preeval_1): Detect potential overlap
+       due to calls to functions taking pointers as parameters.
+
+2007-02-19  Richard Henderson  <rth@redhat.com>
+
+       PR debug/29558
+       * var-tracking.c (track_expr_p): Disallow AGGREGATE_TYPE_P
+       in memory.
+
+2007-02-19  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * config/s390/s390.c (s390_call_saved_register_used,
+       s390_function_ok_for_sibcall): Adjust the way CALL_EXPR arguments are
+       accessed to the new scheme.
+
+2007-02-19  Jan-Benedict Glaw  <jbglaw@lug-owl.de>
+
+       * config/cris/cris.c (cris_movem_load_rest_p, cris_store_multiple_op_p)
+       (cris_print_index, cris_print_operand, cris_print_operand_address)
+       (cris_reload_address_legitimized, cris_rtx_costs, cris_address_cost)
+       (cris_side_effect_mode_ok, cris_valid_pic_const, cris_split_movdx)
+       (cris_expand_pic_call_address): Use xxx_P predicate macros instead of
+       GET_CODE () == xxx.
+       * config/cris/cris.h (SECONDARY_RELOAD_CLASS, EXTRA_CONSTRAINT_Q,
+       EXTRA_CONSTRAINT_T, BDAP_INDEX_P, BIAP_INDEX_P, SIMPLE_ADDRESS_P,
+       GO_IF_LEGITIMATE_ADDRESS): Ditto.
+       * config/cris/cris.md (define_insns: *btst, movdi, *mov_side<mode>)
+       (*mov_sidesisf, *mov_side<mode>_mem, *mov_sidesisf_mem)
+       (*clear_side<mode>, movsi, *movsi_internal, *ext_sideqihi)
+       (*ext_side<mode>si, *op_side<mode>, *op_swap_side<mode>, addsi3)
+       (*extopqihi_side, *extop<mode>si_side, *extopqihi_swap_side)
+       (*extop<mode>si_swap_side, addi_mul, *addi,andsi3, andhi3, ashl<mode>3)
+       (uminsi3, call, call_value): Ditto.
+       (define_split: indir_to_reg_split, unnamed): Ditto.
+
+2007-02-19  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/30975
+       * tree-vect-trasnform.c (vect_get_vec_def_for_stmt_copy): Remove
+       wrong assert.
+
+2007-02-18  Eric Christopher  <echristo@gmail.com>
+
+       * mips.c (mips_prepare_builtin_arg): Add argnum parameter.
+       Remove use of arglist.
+       (mips_expand_builtin): Remove use of arglist, pass in expr.
+       (mips_expand_builtin_direct): Rewrite handling for arglist removal.
+       (mips_expand_builtin_movtf): Ditto.
+       (mips_expand_builtin_compare): Ditto.
+
+2007-02-19  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree-sra.c (sra_build_assignment): Replace assertion
+       checking with a comment explaining why it can't be done.
+
+2007-02-18  Sandra Loosemore  <sandra@codesourcery.com>
+
+       PR middle-end/30833
+       * tree-dump.c (dequeue_and_dump): Add tcc_vl_exp case missed
+       during CALL_EXPR representation conversion.
+       * tree-ssa-propagate.c (set_rhs): Likewise.
+
+2007-02-19  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree-sra.c (sra_build_assignment): Disable assertion checking
+       for now.
+
+2007-02-18  Roger Sayle  <roger@eyesopen.com>
+
+       * function.c (gimplify_parameters): Call build_gimple_modify_stmt
+       instead of calling build2 with a GIMPLE_MODIFY_STMT.
+       * gimple-low.c (lower_function_body, lower_builtin_setjmp):
+       Likewise.
+       * gimplify.c (build_stack_save_restore, gimplify_return_expr,
+       gimplify_decl_expr,  gimplify_self_mod_expr, gimplify_cond_expr,
+       gimplify_init_ctor_eval_range, gimple_push_cleanup,
+       gimplify_omp_for, gimplify_omp_atomic_pipeline,
+       gimplify_omp_atomic_mutex, gimplify_expr, gimplify_one_sizepos,
+       force_gimple_operand): Likewise.
+       * ipa-cp.c (constant_val_insert): Likewise.
+       * lambda-code.c (lbv_to_gcc_expression, lle_to_gcc_expression,
+       lambda_loopnest_to_gcc_loopnest, replace_uses_equiv_to_x_with_y,
+       perfect_nestify): Likewise.
+       * langhooks.c (lhd_omp_assignment): Likewise.
+       * omp-low.c (lower_rec_input_clauses, lower_reduction_clauses,
+       lower_copyprivate_clauses, lower_send_clauses,
+       lower_send_shared_vars, expand_parallel_call,
+       expand_omp_for_generic, expand_omp_for_static_nochunk,
+       expand_omp_for_static_chunk, expand_omp_sections,
+       lower_omp_single_copy, lower_omp_for_lastprivate,
+       lower_omp_parallel, init_tmp_var, save_tmp_var): Likewise.
+       * value-prof.c (tree_divmod_fixed_value, tree_mod_pow2,
+       tree_mod_subtract, tree_ic, tree_stringop_fixed_value):
+       Likewise.
+
+2007-02-19  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/sh/divtab.c, config/sh/sh.c, config/sh/sh.h,
+       config/sh/sh.md: Follow spelling conventions.
+
+       * config/frv/frv.c, config/frv/frv.h, config/frv/frv.md,
+       config/frv/predicates.md: Follow spelling conventions.
+
+       * config/m68k/linux-unwind.h: Fix a comment typo.
+       * target.h: Follow spelling conventions.
+
+2007-02-18  Roger Sayle  <roger@eyesopen.com>
+
+       PR rtl-optimization/28173
+       * simplify-rtx.c (simplify_binary_operation_1) <IOR>: Optimize
+       (X & C1) | C2 as C2 when (C1 & C2) == C1 and X has no side-effects.
+       Optimize (X & C1) | C2 as X | C2 when (C1 | C2) == ~0.
+       Canonicalize (X & C1) | C2 as (X & (C1 & ~C2)) | C2.
+       <AND>: Canonicalize (X | C1) & C2 as (X & C2) | (C1 & C2).
+
+2007-02-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.c (fold_builtin_load_exponent): New.
+       (fold_builtin_2): Use it.
+
+2007-02-18  Steven Bosscher  <steven@gcc.gnu.org>
+
+       PR rtl-optimization/30773
+       * local-alloc.c (update_equiv_regs): Do not set reg_equiv_init
+       if we fail to attach a REG_EQUIV note.
+
+2007-02-18  David Edelsohn  <edelsohn@gnu.org>
+           Roger Sayle  <roger@eyesopen.com>
+
+       * config/rs6000/rs6000.md (bswapsi2): New define_insn and splitter.
+
+2007-02-18  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * calls.c (initialize_argument_information): Pass original EXP
+       and STRUCT_VALUE_ADDR_VALUE instead of a list of arguments.  Move
+       code to split complex arguments here, as part of initializing the
+       ARGS array.
+       (expand_call): Remove code that builds a list of arguments and
+       inserts implicit arguments into it.  Instead, just count how many
+       implicit arguments there will be so we can determine the size of
+       the ARGS array, and let initialize_argument_information do the work.
+       (split_complex_values): Delete unused function.
+
+2007-02-18  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-eh.c (tree_could_trap_p): Handle VIEW_CONVERT_EXPR.
+
+2007-02-18  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * calls.c (mem_overlaps_already_clobbered_arg_p): Return true
+       for arg pointer based indexed addressing.
+
+2007-02-18  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/ia64/ia64.h, config/ia64/ia64.md,
+       config/ia64/predicates.md, config/ia64/sysv4.h: Follow
+       spelling conventions.
+
+2007-02-18  Roman Zippel <zippel@linux-m68k.org>
+
+       * config/m68k/m68k.c (split_di): New.
+       * config/m68k/m68k-protos.h: Declare split_di.
+       * config/m68k/m68k.md (extendsidi2*,ashldi3*,ashrdi3*,lshrdi3*):
+         Improve predicate handling and split constant shifts.
+
+2007-02-18  Roman Zippel <zippel@linux-m68k.org>
+
+       * config/m68k/m68k.md (extv,extzv,insv): disable dynamic
+       parameter for register bitfield operations, general predicates
+       cleanup
+
+2007-02-18  Roman Zippel <zippel@linux-m68k.org>
+
+       * config/m68k/linux.h (MD_UNWIND_SUPPORT): Define.
+       * config/m68k/linux-unwind.h: New file.
+
+2007-02-18  Kazu Hirata  <kazu@codesourcery.com>
+
+       * cfgloop.c, config/alpha/alpha.c, config/bfin/bfin.c,
+       config/i386/athlon.md, config/ia64/ia64.md,
+       config/rs6000/rs6000.c, config/s390/s390.c, config/spu/spu.md,
+       df-problems.c, df.h, fold-const.c, ipa-cp.c, ipa-inline.c,
+       ipa-prop.h, see.c, struct-equiv.c, tree-inline.c,
+       tree-ssa-loop-niter.c, tree-vect-analyze.c,
+       tree-vect-transform.c: Fix comment typos.
+
+2007-02-17  Kazu Hirata  <kazu@codesourcery.com>
+
+       * sched-deps.c (find_insn_list): Remove.
+       * sched-int.h: Remove the prototype for find_insn_list.
+
+2007-02-16  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/darwin.h (LINK_SPEC): Always pass -macosx_version_min
+       to linker.
+       (DARWIN_EXTRA_SPECS): Add %(darwin_minversion).
+       * config/rs6000/darwin.h (SUBTARGET_OVERRIDE_OPTIONS): Just call
+       darwin_rs6000_override_options.
+       (C_COMMON_OVERRIDE_OPTIONS): Expect
+       darwin_macosx_version_min to be non-NULL always.
+       (TARGET_C99_FUNCTIONS): Likewise.
+       (CC1_SPEC): Always pass -mmacosx-version-min to cc1*.
+       (DARWIN_MINVERSION_SPEC): New.
+       * config/rs6000/rs6000.c (darwin_rs6000_override_options): New.
+       * config/i386/darwin.h (CC1_SPEC): Always pass -mmacosx-version-min
+       to cc1*.
+       (DARWIN_MINVERSION_SPEC): New.
+       * config/darwin.opt (mmacosx-version-min): Initialize to non-NULL
+       value.
+       * config/darwin-c.c (darwin_cpp_builtins): Expect
+       darwin_macosx_version_min to be non-NULL always.
+
+       * config/rs6000/rs6000.c: Clean up trailing whitespace.
+
+2007-02-16  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.h (x86_use_xchgb): New.
+       (TARGET_USE_XCHGB): New macro.
+       * config/i386/i386.c (x86_use_xchgb): Set for PENT4.
+       * config/i386/i386.md (*rotlhi3_1 splitter, *rotrhi3_1 splitter):
+       Split after reload into bswaphi for shifts of 8.
+       (bswaphi_lowpart): Generate rolw insn for HImode byte swaps.
+       (*bswaphi_lowpart_1): Generate xchgb for Q registers for TARGET_XCHGB
+       or when optimizing for size.
+
+2007-02-16  Richard Guenther  <rguenther@suse.de>
+           Christian Bruel  <christian.bruel@st.com>
+
+       * fold-const.c (tree_swap_operands_p): Treat SSA_NAMEs like
+       DECLs but prefer SSA_NAMEs over DECLs.
+
+2007-02-16  Richard Guenther  <rguenther@suse.de>
+
+       * tree-flow-inline.h (single_imm_use_p): Remove.
+       (zero_imm_uses_p): Likewise.
+       * tree-ssa-coalesce.c (create_outofssa_var_map): Use has_single_use
+       instead of single_imm_use_p.
+       * tree-cfg.c (replace_uses_by): Use has_zero_use instead of
+       zero_imm_uses_p.
+
+2007-02-16  Ralf Wildenhues  <Ralf.Wildenhues@gmx.de>
+
+       PR other/27843
+       * Makefile.in (SYSTEM_HEADER_DIR): Use single quotes to avoid
+       nested double- and backquotes.
+
+2007-02-15  Roger Sayle  <roger@eyesopen.com>
+
+       PR middle-end/30391
+       * tree.c (expr_align): Handle MODIFY_EXPR.  GIMPLE_MODIFY_STMT
+       should be unreachable.
+       (build2_stat): Allow construction of MODIFY_EXPR at any time.
+       For the time being redirect GIMPLE_MODIFY_STMT to the new
+       (renamed) build_gimple_modify_stmt_stat.
+       (build2_gimple_stat): Rename to...
+       (build_gimple_modify_stmt_stat): Now longer take a CODE argument.
+       Always build a GIMPLE_MODIFY_STMT node.
+       * tree.h (build2_gimple, build2_gimple_stat): Delete.
+       (build_gimple_modify_stmt, build_gimple_modify_stmt_stat): New
+       declarations.
+
+       * tree-cfg.c (factor_computed_gotos, tree_merge_blocks,
+       gimplify_val): Use build_gimple_modify_stmt instead of build2_gimple.
+       * tree-complex.c (set_component_ssa_name, expand_complex_move,
+       expand_complex_div_wide): Likewise.
+       * tree-ssa-dom.c (record_equivalences_from_stmt): Likewise.
+       * tree-ssa-loop-im.c (schedule_sm): Likewise.
+       * tree-ssa-loop-ivopts.c (rewrite_use_nonlinear_expr): Likewise.
+       * tree-ssa-loop-manip.c (create_iv): Likewise.
+       * tree-ssa-phiopt.c (conditional_replacement, minmax_replacement,
+       abs_replacement): Likewise.
+       * tree-ssa-pre.c (create_expression_by_pieces, poolify_modify_stmt,
+       realify_fake_stores): Likewise.
+
+       * builtins.c (std_expand_builtin_va_start): Build a MODIFY_EXPR
+       node rather than a GIMPLE_MODIFY_STMT node.
+       (std_gimpify_va_arg_expr, expand_builtin_va_copy,
+       fold_builtin_memset, fold_builtin_memory_op, do_mpfr_sincos):
+       Likewise.
+       (integer_valued_real_p): Handle MODIFY_EXPR, not GIMPLE_MODIFY_STMT.
+       * expr.c (expand_expr_real_1): Handle both MODIFY_EXPR and
+       GIMPLE_MODIFY_STMT.
+
+2007-02-15  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/30433
+       * fold-const.c (fold_comparison): Add back the
+       folding of constant complex comparisions.
+
+2007-02-15  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/30729
+       * stmt.c (warn_if_unused_value): VA_ARG_EXPR has side
+       effects unknown to this function, return early.
+
+2007-02-15  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (move_eh_region_note): New static function.
+       (resolve_simple_move): Call it.
+       (decompose_multiword_subregs): Track blocks for which we resolve a
+       simple move which is also a control flow insn.  Pass them to
+       find_many_sub_basic_blocks.
+       (pass_lower_subreg): Add TODO_verify_flow.
+       (pass_lower_subreg2): Likewise.
+
+2007-02-15  Sandra Loosemore  <sandra@codesourcery.com>
+           Brooks Moses  <brooks.moses@codesourcery.com>
+           Lee Millward  <lee.millward@codesourcery.com>
+
+       * tree.h (enum tree_code_class): Add tcc_vl_exp.
+       (VL_EXP_CLASS_P): New.
+       (TREE_OPERAND_CHECK): Use TREE_OPERAND_LENGTH instead of
+       TREE_CODE_LENGTH.
+       (TREE_OPERAND_CHECK_CODE): Likewise.
+       (GIMPLE_STMT_OPERAND_CHECK): Likewise.
+       (TREE_RTL_OPERAND_CHECK): Likewise.
+       (tree_operand_check_failed): Make second parameter the whole tree
+       instead of its code.  Fixed callers.
+       (VL_EXP_CHECK): New.
+       (TREE_OPERAND_LENGTH): New.
+       (VL_EXP_OPERAND_LENGTH): New.
+       (CALL_EXPR_FN): New.
+       (CALL_EXPR_STATIC_CHAIN): New.
+       (CALL_EXPR_ARGS): New.
+       (CALL_EXPR_ARG): New.
+       (call_expr_nargs): New.
+       (CALL_EXPR_ARGP): New.
+       (build_nt_call_list): Declare.
+       (build_vl_exp_stat): Declare.
+       (build_vl_exp): New.
+       (build_call_list): Declare.
+       (build_call_nary): Declare.
+       (build_call_valist): Declare.
+       (build_call_array): Declare.
+       (call_expr_arg): Declare.
+       (call_expr_argp): Declare.
+       (call_expr_arglist): Declare.
+       (fold_build_call_list): Declare.
+       (fold_build_call_list_initializer): Declare.
+       (fold_call_expr): Declare to replace fold_builtin.
+       (fold_builtin_fputs): Update to agree with modified definition.
+       (fold_builtin_strcpy): Likewise.
+       (fold_builtin_strncpy): Likewise.
+       (fold_builtin_memory_chk): Likewise.
+       (fold_builtin_stxcpy_chk): Likewise.
+       (fold_builtin_strncpy_chk): Likewise.
+       (fold_builtin_next_arg): Likewise.
+       (fold_build_call_expr): Declare.
+       (fold_builtin_call_list): Declare.
+       (fold_builtin_call_valist): Declare.
+       (build_call_expr): Declare.
+       (validate_arglist): Update to agree with modified definition.
+       (tree_operand_length): New.
+       (call_expr_arg_iterator): New.
+       (init_call_expr_arg_iterator): New.
+       (next_call_expr_arg): New.
+       (first_call_expr_arg): New.
+       (more_call_expr_args_p): New.
+       (FOR_EACH_CALL_EXPR_ARG): New.
+
+       * tree.c (tree_code_class_string): Add entries for tcc_vl_exp
+       and tcc_gimple_stmt.
+       (tree_code_size): Update documentation.  Use sizeof (tree) rather
+       than sizeof (char *).
+       (tree_size): Likewise.  Add case for tcc_vl_exp.
+       (tree_node_structure): Add case for tcc_vl_exp.
+       (contains_placeholder_p): Likewise.
+       (substitute_in_expr): Likewise.
+       (substitute_placeholder_in_expr): Likewise.
+       (stabilize_reference_1): Likewise.
+       (build3_stat): Remove logic for CALL_EXPRs.  Replace with assertion
+       to diagnose breakage of this interface for constructing CALL_EXPRs.
+       (build_nt): Add similar assertion here.
+       (build_nt_call_list): New.
+       (simple_cst_equal) <CALL_EXPR>: Rewrite to use new accessors.
+       (iterative_hash_expr): Use TREE_OPERAND_LENGTH instead of
+       TREE_CODE_LENGTH.
+       (get_callee_fndecl): Use new CALL_EXPR accessors.
+       (tree_operand_check_failed): Change parameters to pass entire node
+       instead of its code, so that we can call TREE_OPERAND_LENGTH on it.
+       (process_call_operands): New.
+       (build_vl_exp_stat): New.
+       (build_call_list): New.
+       (build_call_nary): New.
+       (build_call_valist): New.
+       (build_call_array): New.
+       (walk_tree): Use TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+       (call_expr_arglist): New.
+
+       * tree.def (CALL_EXPR): Change representation of CALL_EXPRs to use
+       tcc_vl_exp instead of a fixed-size tcc_expression.
+
+       * doc/c-tree.texi (CALL_EXPR): Document new representation and
+       accessors for CALL_EXPRs.
+       (AGGR_INIT_EXPR): Likewise.
+
+2007-02-15  Sandra Loosemore  <sandra@codesourcery.com>
+           Brooks Moses  <brooks.moses@codesourcery.com>
+           Lee Millward  <lee.millward@codesourcery.com>
+
+       * builtins.c (c_strlen): Return NULL_TREE instead of 0.
+       (expand_builtin_nonlocal_goto): Change parameter to be entire
+       CALL_EXPR instead of an arglist.  Use new CALL_EXPR accessors.
+       (expand_builtin_prefetch): Likewise.
+       (expand_builtin_classify_type): Likewise.
+       (mathfn_built_in): Return NULL_TREE instead of 0.
+       (expand_errno_check): Use new CALL_EXPR accessors.
+       (expand_builtin_mathfn): Use new CALL_EXPR accessors and constructors.
+       Return NULL_RTX instead of 0.
+       (expand_builtin_mathfn_2): Likewise.
+       (expand_builtin_mathfn_3): Likewise.
+       (expand_builtin_interclass_mathfn): Likewise.
+       (expand_builtin_sincos): Likewise.
+       (expand_builtin_cexpi): Likewise.
+       (expand_builtin_int_roundingfn): Likewise.
+       (expand_builtin_int_roundingfn_2): Likewise.
+       (expand_builtin_pow): Likewise.
+       (expand_builtin_powi): Likewise.
+       (expand_builtin_strlen): Pass entire CALL_EXPR as parameter instead
+       of arglist, fixing callers appropriately.  Use new CALL_EXPR
+       accessors and constructors.  Return NULL_RTX instead of 0.
+       (expand_builtin_strstr): Likewise.
+       (expand_builtin_strchr): Likewise.
+       (expand_builtin_strrchr): Likewise.
+       (expand_builtin_strpbrk): Likewise.
+       (expand_builtin_memcpy): Likewise.
+       (expand_builtin_mempcpy): Likewise.
+       (expand_builtin_mempcpy_args): New.
+       (expand_builtin_memmove): Similarly to expand_builtin_mempcpy.
+       (expand_builtin_memmove_args): New.
+       (expand_builtin_bcopy): Similarly to expand_builtin_mempcpy.
+       (expand_movstr): Likewise.
+       (expand_builtin_strcpy): Likewise.
+       (expand_builtin_strcpy_args): New.
+       (expand_builtin_stpcpy): Similarly to expand_builtin_strcpy.
+       (expand_builtin_strncpy): Likewise.
+       (expand_builtin_memset): Likewise.
+       (expand_builtin_memset_args): New.
+       (expand_builtin_bzero): Similarly to expand_builtin_memset.
+       (expand_builtin_memcmp): Likewise.
+       (expand_builtin_strcmp): Likewise.
+       (expand_builtin_strncmp): Likewise.
+       (expand_builtin_strcat): Likewise.
+       (expand_builtin_strncat): Likewise.
+       (expand_builtin_strspn): Likewise.
+       (expand_builtin_strcspn): Likewise.
+       (expand_builtin_args_info): Likewise.
+       (expand_builtin_va_start): Likewise.
+       (gimplify_va_arg_expr): Likewise.
+       (expand_builtin_va_end): Likewise.
+       (expand_builtin_va_copy): Likewise.
+       (expand_builtin_frame_address): Likewise.
+       (expand_builtin_alloca): Likewise.
+       (expand_builtin_bswap): Likewise.
+       (expand_builtin_unop): Likewise.
+       (expand_builtin_fputs): Likewise.
+       (expand_builtin_expect): Likewise.
+       (expand_builtin_fabs): Likewise.
+       (expand_builtin_copysign): Likewise.
+       (expand_builtin_printf): Likewise.
+       (expand_builtin_fprintf): Likewise.
+       (expand_builtin_sprintf): Likewise.
+       (expand_builtin_init_trampoline): Likewise.
+       (expand_builtin_signbit): Likewise.
+       (expand_builtin_fork_or_exec): Likewise.
+       (expand_builtin_sync_operation): Likewise.
+       (expand_builtin_compare_and_swap): Likewise.
+       (expand_builtin_lock_test_and_set): Likewise.
+       (expand_builtin_lock_release): Likewise.
+       (expand_builtin): Likewise.
+       (builtin_mathfn_code): Likewise.
+
+       (fold_builtin_constant_p): Pass call arguments individually instead
+       of as an arglist, fixing callers appropriately.  Use new CALL_EXPR
+       accessors and constructors.  Return NULL_TREE instead of 0.
+       (fold_builtin_expect): Likewise.
+       (fold_builtin_classify_type): Likewise.
+       (fold_builtin_strlen): Likewise.
+       (fold_builtin_nan): Likewise.
+       (integer_valued_real_p): Likewise.
+       (fold_trunc_transparent_mathfn): Likewise.
+       (fold_fixed_mathfn): Likewise.
+       (fold_builtin_cabs): Likewise.
+       (fold_builtin_sqrt): Likewise.
+       (fold_builtin_cbrt): Likewise.
+       (fold_builtin_cos): Likewise.
+       (fold_builtin_cosh): Likewise.
+       (fold_builtin_tan): Likewise.
+       (fold_builtin_sincos): Likewise.
+       (fold_builtin_cexp): Likewise.
+       (fold_builtin_trunc): Likewise.
+       (fold_builtin_floor): Likewise.
+       (fold_builtin_ceil): Likewise.
+       (fold_builtin_round): Likewise.
+       (fold_builtin_int_roundingfn): Likewise.
+       (fold_builtin_bitop): Likewise.
+       (fold_builtin_bswap): Likewise.
+       (fold_builtin_logarithm): Likewise.
+       (fold_builtin_hypot): Likewise.
+       (fold_builtin_pow): Likewise.
+       (fold_builtin_powi): Likewise.
+       (fold_builtin_exponent): Likewise.
+       (fold_builtin_memset): Likewise.
+       (fold_builtin_bzero): Likewise.
+       (fold_builtin_memory_op): Likewise.
+       (fold_builtin_bcopy): Deleted; call site changed to invoke
+       fold_builtin_memory_op directly.
+       (fold_builtin_strcpy): Similarly as for fold_builtin_memory_op.
+       (fold_builtin_strncpy): Likewise.
+       (fold_builtin_memcmp): Likewise.
+       (fold_builtin_strcmp): Likewise.
+       (fold_builtin_strncmp): Likewise.
+       (fold_builtin_signbit): Likewise.
+       (fold_builtin_copysign): Likewise.
+       (fold_builtin_isascii): Likewise.
+       (fold_builtin_toascii): Likewise.
+       (fold_builtin_isdigit): Likewise.
+       (fold_builtin_fabs): Likewise.
+       (fold_builtin_abs): Likewise.
+       (fold_builtin_fmin_fmax): Likewise.
+       (fold_builtin_carg): Likewise.
+       (fold_builtin_classify): Likewise.
+       (fold_builtin_unordered_cmp): Likewise.
+
+       (fold_builtin_0, fold_builtin_2, fold_builtin_3, fold_builtin_4):
+       New functions split out from fold_builtin_1.
+       (fold_builtin_n): New.
+       (fold_builtin_varargs): New.
+       (fold_builtin): Deleted.  Most callers changed to use fold_call_expr
+       instead.
+       (fold_call_expr): New.
+       (build_function_call_expr): Rewrite to use new helper function.
+       (fold_builtin_call_list): New.
+       (build_call_expr): New.
+       (fold_builtin_call_valist): New.
+       (rewrite_call_expr): New.
+       (validate_arg): New.
+       (validate_arglist): Change parameter to be entire CALL_EXPR instead
+       of an arglist.  Change return type to bool.  Use new CALL_EXPR
+       accessors.
+
+       (fold_builtin_strstr): Pass call arguments individually instead
+       of as an arglist, fixing callers appropriately.  Use new CALL_EXPR
+       accessors and constructors.  Return NULL_TREE instead of 0.
+       (fold_builtin_strchr): Likewise.
+       (fold_builtin_strrchr): Likewise.
+       (fold_builtin_strpbrk): Likewise.
+       (fold_builtin_strcat): Likewise.
+       (fold_builtin_strncat): Likewise.
+       (fold_builtin_strspn): Likewise.
+       (fold_builtin_strcspn): Likewise.
+       (fold_builtin_fputs): Likewise.
+       (fold_builtin_next_arg): Likewise.
+       (fold_builtin_sprintf): Likewise.
+
+       (expand_builtin_object_size): Use new CALL_EXPR accessors.  Use
+       NULL_RTX instead of 0.
+       (expand_builtin_memory_chk): Likewise.
+       (maybe_emit_chk_warning): Likewise.
+       (maybe_emit_sprintf_chk_warning): Likewise.
+
+       (fold_builtin_object_size): Pass call arguments individually instead
+       of as an arglist, fixing callers appropriately.  Use new CALL_EXPR
+       accessors and constructors.  Return NULL_TREE instead of 0.
+       (fold_builtin_memory_chk): Likewise.
+       (fold_builtin_stxcpy_chk): Likewise.
+       (fold_builtin_strncpy_chk): Likewise.
+       (fold_builtin_strcat_chk): Likewise.
+       (fold_builtin_strcat_chk): Likewise.
+       (fold_builtin_strncat_chk): Likewise.
+       (fold_builtin_sprintf_chk): Likewise.
+       (fold_builtin_snprintf_chk): Likewise.
+       (fold_builtin_printf): Likewise.
+       (fold_builtin_vprintf): Likewise.
+
+       * fold-const.c (negate_expr_p): Use new CALL_EXPR accessors and
+       constructors.
+       (operand_equal_p): Add separate tcc_vl_exp/CALL_EXPR case.
+       (make_range): Use TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+       (extract_muldiv_1): Add VL_EXP_CLASS_P case.
+       (fold_mathfn_compare): Use new CALL_EXPR accessors and constructors.
+       (fold_unary): Likewise.
+       (fold_binary): Likewise.
+       (fold_ternary): Remove CALL_EXPR case, since they are no longer
+       ternary expressions.
+       (fold): Add logic for tcc_vl_exp.
+       (fold_checksum_tree): Make it know about tcc_vl_exp.  Use
+       TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+       (fold_build3_stat): Add assertion to flag broken interface for
+       constructing CALL_EXPRs.
+       (fold_build_call_list): New.
+       (fold_build_call_list_initializer): New.
+       (tree_expr_nonnegative_p): Use new CALL_EXPR accessors and
+       constructors.
+       (fold_strip_sign_ops): Likewise.
+
+2007-02-15  Sandra Loosemore  <sandra@codesourcery.com>
+           Brooks Moses  <brooks.moses@codesourcery.com>
+           Lee Millward  <lee.millward@codesourcery.com>
+
+       * tree-dump.c (dequeue_and_dump) <CALL_EXPR>: Use new CALL_EXPR
+       accessors and dump arguments explicitly.
+
+       * tree-pretty-print.c (do_niy): Use TREE_OPERAND_LENGTH instead of
+       TREE_CODE_LENGTH.
+       (dump_generic_node): Use new CALL_EXPR accessors and walk arguments
+       explicitly.
+       (print_call_name): Use new CALL_EXPR accessors.
+
+       * print-tree.c (print_node): Add case tcc_vl_exp.  Print
+       CALL_EXPR arguments explicitly instead of as a list.  Use
+       TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+
+       * tree-vrp.c (stmt_interesting_for_vrp): Use new CALL_EXPR accessors.
+       (vrp_visit_stmt): Likewise.
+
+       * tree-ssa-loop-im.c (outermost_invariant_loop_expr): Make it
+       know about tcc_vl_exp.  Use TREE_OPERAND_LENGTH instead of
+       TREE_CODE_LENGTH.
+       (force_move_till_expr): Likewise.
+
+       * targhooks.c (default_external_stack_protect_fail): Use
+       build_call_expr instead of build_function_call_expr.
+       (default_hidden_stack_protect_fail): Likewise.
+
+       * tree-complex.c (expand_complex_libcall): Use build_call_expr to
+       build the call.
+
+       * cgraphbuild.c (build_cgraph_edges): Use new CALL_EXPR accessors
+       and walk arguments explicitly.
+
+       * tree-ssa-loop-niter.c (simplify_replace_tree): Use
+       TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+       (expand_simple_operations): Likewise.
+       (infer_loop_bounds_from_array): Use new CALL_EXPR accessors.
+
+       * gengtype.c (adjust_field_tree_exp): Use TREE_OPERAND_LENGTH instead
+       of TREE_CODE_LENGTH.
+       (walk_type): Tweak walking of arrays not to blow up on CALL_EXPRs.
+
+       * optabs.c (expand_widen_pattern-expr): Use TREE_OPERAND_LENGTH
+       instead of TREE_CODE_LENGTH.
+
+       * value_prof.c (tree_ic): Use new CALL_EXPR accessors.
+       (tree_ic_transform): Likewise.
+       (interesting_stringop_to_profile_p): Pass entire CALL_EXPR as
+       parameter instead of arglist.  Fix callers.
+       (tree_stringop_fixed_value): Use new CALL_EXPR accessors.
+       (tree_stringops_transform): Likewise.
+       (tree_indirect_call_to_profile): Likewise.
+       (tree_stringops_values_to_profile): Likewise.
+
+       * tree-tailcall.c (find_tail_calls): Use new CALL_EXPR iterator.
+       (eliminate_tail_call): Likewise.
+
+       * ipa-cp.c (ipcp_update_callgraph): Use new CALL_EXPR accessors.
+
+       * tree-scalar-evolution.c (chrec_contains_symbols_defined_in_loop):
+       Use TREE_OPERAND_LENGTH and generalize to handle any number of
+       operands.
+       (instantiate_parameters_1): Can't handle tcc_vl_exp here.
+
+       * omp-low.c (build_omp_barrier): Use build_call_expr.
+       (lower_rec_input_clauses): Likewise.
+       (lower_reduction_clauses): Likewise.
+       (expand_parallel_call): Likewise.
+       (maybe_catch_exception): Likewise.
+       (expand_omp_for_generic): Likewise.
+       (expand_omp_for_static_nochunk): Likewise.
+       (expand_omp_sections): Likewise.
+       (lower_omp_single_simple): Likewise.
+       (lower_omp_single_copy): Likewise.
+       (lower_omp_master): Likewise.
+       (lower_omp_ordered): Likewise.
+       (lower_omp_critical): Likewise.
+
+       * ipa-reference.c (check-call): Use new CALL_EXPR iterator.
+       (scan_for_static_refs): Create tcc_vl_exp case for CALL_EXPR.
+
+       * tree-gimple.c (is_gimple_call_addr): Fix doc.
+       (recalculate_side_effects): Use TREE_OPERAND_LENGTH instead of
+       TREE_CODE_LENGTH.  Add tcc_vl_exp case.
+
+       * tree-chrec.c (chrec_contains_symbols): Use TREE_OPERAND_LENGTH
+       and generalize to handle any number of operands.
+       (chrec_contains_undetermined): Likewise.
+       (tree_contains_chrecs): Likewise.
+       (evolution_function_is_invariant_rec_p): Use TREE_OPERAND_LENGTH.
+
+       * cgraphunit.c (update_call_expr): Use new CALL_EXPR accessors.
+
+       * tree-ssa-ccp.c (ccp_fold): Use new CALL_EXPR accessors.  Use
+       fold_call_expr instead of fold_builtin.
+       (ccp_fold_builtin): Likewise.  Update calls into builtins.c to
+       match declarations there.
+       (fold_stmt): Use new CALL_EXPR constructor and accessors.  Doc
+       updates.
+
+       * tree-ssa-loop-ivopts.c (expr_invariant_in_loop_p): Use
+       TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+
+       * ipa-pure-const.c (check_call): Use new CALL_EXPR accessors.
+       (scan_function): Add case tcc_vl_exp for CALL_EXPR.
+
+       * tree-stdarg.c (execute_optimize_stdarg): Use new CALL_EXPR
+       accessors.
+
+       * tree-ssa-math-opts.c (execute_cse_sincos_1): Use build_call_expr.
+       (execute_cse_sincos): Use new CALL_EXPR accessors.
+
+       * tree-ssa-alias.c (find_used_portions): Use new CALL_EXPR iterator.
+
+       * gimple-low.c (lower_function_body): Use build_call_expr.
+       (lower_builtin_setjmp): Likewise.
+
+       * expr.c (emit_block_move_via_libcall): Use build_call_expr.
+       (set_storage_via_libcall): Likewise.
+       (safe_from_p): Add tcc_vl_exp case.  Use TREE_OPERAND_LENGTH
+       instead of TREE_CODE_LENGTH.
+       (expand_expr_real_1): Use new CALL_EXPR accessors.
+
+       * tree-browser.c (store_child_info): Use TREE_OPERAND_LENGTH and
+       generalize to handle any number of operands.
+       (TB_parent_eq): Likewise.
+
+       * predict.c (expr_expected_value): Use new CALL_EXPR accessors.
+       (strip_builtin_expect): Likewise.
+
+       * function.c (gimplify_parameters): Use build_call_expr.
+
+       * tree-vectorizer.c (vect_is_simple_reduction): Use
+       TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+
+       * ipa-type-escape.c (check_call): Use new CALL_EXPR iterators.
+       (scan_for_refs): Add case tcc_vl_exp for CALL_EXPR.
+
+       * tree-data-ref.c (get_references_in_stmt): Use new CALL_EXPR
+       iterators.
+
+       * gimplify.c (build_stack_save_restore): Use build_call_expr.
+       (gimplify_decl_expr): Likewise.
+       (gimplify_call_expr): Use fold_call_expr instead of fold_builtin.
+       Use new CALL_EXPR iterators.
+       (gimplify_modify_expr_to_memcpy): Use build_call_expr.
+       (gimplify_modify_expr_to_memset): Likewise.
+       (gimplify_variable_sized_compare): Likewise.
+       (gimplify_omp_atomic_fetch_op): Likewise.
+       (gimplify_omp_atomic_pipeline): Likewise.
+       (gimplify_omp_atomic_mutex): Likewise.
+       (gimplify_function_tree): Likewise.
+
+       * calls.c (alloca_call_p): Use new CALL_EXPR accessors.
+       (call_expr_flags): Likewise.
+       (expand_call): Likewise.
+
+       * except.c (expand_builtin_eh_return_data_regno): Pass entire
+       CALL_EXPR as parameter instead of arglist.  Use new CALL_EXPR
+       accessors.
+
+       * coverage.c (create_coverage): Use build_call_expr.
+
+       * tree-ssa-pre.c (expression_node_pool, list_node_pool): Delete.
+       (temp_call_expr_obstack): New.
+       (pool_copy_list): Delete.
+       (temp_copy_call_expr): New.
+       (phi_translate): Add case tcc_vl_exp for CALL_EXPR.  Use new
+       CALL_EXPR accessors.  Get rid of special goo for copying argument
+       lists and use temp_copy_call_expr instead.
+       (valid_in_sets): Add case tcc_vl_exp for CALL_EXPR.  Use new
+       CALL_EXPR accessors.
+       (create_expression_by_pieces): Likewise.  Use build_call_array
+       to construct the result instead of fold_build3.
+       (create_value_expr_from): Add tcc_vl_exp.  Delete special goo for
+       dealing with argument lists.
+       (init_pre): Remove references to expression_node_pool and
+       list_node_pool.  Init temp_call_expr_obstack instead.
+       (fini_pre): Remove references to expression_node_pool and
+       list_node_pool.
+
+       * tree-sra.c (sra_walk_call_expr): Use new CALL_EXPR accessors
+       and walk arguments explicitly instead of as a list.
+
+       * tree-mudflap.c (mf_build_check_statement_for): Use build_call_expr.
+       (mx_register_decls): Likewise.
+       (mudflap_register_call): Likewise.
+       (mudflap_finish_file): Likewise.
+
+       * ipa-prop.c (ipa_callsite_compute_count): Use new CALL_EXPR accessors.
+       (ipa_callsite_compute_param): Likewise.
+
+       * tree-vect-patterns.c (vect_recog_pow_pattern): Use new CALL_EXPR
+       accessors and constructor.
+
+       * tree-nested.c (convert_nl_goto_reference): Use new CALL_EXPR
+       accessors and constructor.
+       (convert_tramp_reference): Likewise.
+       (convert_call_expr): Likewise.
+       (finalize_nesting_tree_1): Likewise.
+
+       * tree-ssa.c (tree_ssa_useless_type_conversion): Use new CALL_EXPR
+       accessors.
+
+       * tree-ssa-loop-prefetch.c (issue_prefetch_ref): Use build_call_expr.
+
+       * tree-inline.c (initialize_inlined_parameters): Pass entire
+       CALL_EXPR as parameter instead of arglist.  Use new CALL_EXPR
+       accessors.
+       (estimate_num_insns_1): Use new CALL_EXPR accessors.
+       (expand_call_inline): Tidy up call to initialize_inlined_parameters.
+
+       * tree-vect-transform.c (vect_create_epilog_for_reduction): Use
+       TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+       (vectorizable_reduction): Likewise.
+       (vectorizable_call): Use new CALL_EXPR iterators.
+       (vectorizable_conversion): Use build_call_expr.
+       (vectorizable_operation): Use TREE_OPERAND_LENGTH.
+       (vect_gen_widened_results_half): Use build_call_expr.
+       (vect_setup_realignment): Likewise.
+       (vectorizable_live_operation): Use TREE_OPERAND_LENGTH.
+
+       * tree-object-size.c (alloc_object_size): Use new CALL_EXPR accessors.
+       (pass_through_call): Likewise.
+       (compute_object_sizes): Likewise.  Use fold_call_expr instead of
+       fold_builtin.
+
+       * tree-profile.c (tree_gen_interval_profiler): Use build_call_expr.
+       (tree_gen_pow2_profiler): Likewise.
+       (tree_gen_one_value_profiler): Likewise.
+       (tree_gen_ic_func_profiler): Likewise.
+       (tree_gen_average_profiler): Likewise.
+       (tree_gen_ior_profiler): Likewise.
+
+       * tree-ssa-structalias.c (get_constraint_for): Add case tcc_vl_exp.
+       (find_func_aliases): Use new CALL_EXPR accessors.  Add case
+       tcc_vl_exp.  Use TREE_OPERAND_LENGTH instead of TREE_CODE_LENGTH.
+
+       * tree-ssa-reassoc.c (get_rank): Use TREE_OPERAND_LENGTH instead
+       of TREE_CODE_LENGTH.
+
+       * stmt.c (warn_if_unused_value): Use TREE_OPERAND_LENGTH instead
+       of TREE_CODE_LENGTH.
+
+       * convert.c (convert_to_real): Use new CALL_EXPR accessors and
+       constructor.
+       (convert_to_integer): Likewise.
+
+       * tree-ssa-operands.c (get_call_expr_operands): Use new CALL_EXPR
+       accessors.
+
+2007-02-15  Sandra Loosemore  <sandra@codesourcery.com>
+           Brooks Moses  <brooks.moses@codesourcery.com>
+           Lee Millward  <lee.millward@codesourcery.com>
+
+       * config/alpha/alpha.c (alpha_expand_builtin): Use new CALL_EXPR
+       accessors.
+       * config/frv/frv.c (frv_expand_builtin): Likewise.
+       * config/s390/s390.c (s390_expand_builtin): Likewise.
+
+       * config/sparc/sparc.c (sparc_gimplify_va_arg): Use build_call_expr.
+       (sparc_expand_builtin): Use new CALL_EXPR accessors.
+
+       * config/i386/i386.c (ix86_function_ok_for_sibcall): Likewise.
+       (ix86_expand_binop_builtin): Pass entire CALL_EXPR as parameter
+       instead of arglist.  Use new CALL_EXPR accessors on it.  Fix callers.
+       (ix86_expand_store_builtin): Likewise.
+       (ix86_expand_unop_builtin): Likewise.
+       (ix86_expand_unop1_builtin): Likewise.
+       (ix86_expand_sse_compare): Likewise.
+       (ix86_expand_sse_comi): Likewise.
+       (ix86_expand_vec_init_builtin): Likewise.
+       (ix86_expand_vec_ext_builtin): Likewise.
+       (ix86_expand_vec_set_builtin): Likewise.
+       (ix86_expand_builtin): Use new CALL_EXPR accessors.
+
+       * config/sh/sh.c (sh_expand_builtin): Use new CALL_EXPR accessors.
+       * config/c4x/c4x.c (c4x_expand_builtin): Likewise.
+
+       * config/iq2000/iq2000.c (expand_one_builtin): Pass entire CALL_EXPR
+       instead of arglist.  Use new CALL_EXPR accessors.  Fix callers.
+       (iq2000_expand_builtin): Use new CALL_EXPR accessors.
+
+       * config/rs6000/rs6000-c.c (altivec_build_resolved_builtin): Use
+       build_call_expr.
+       * config/rs6000/rs6000.c (rs6000_gimplify_va_arg): Likewise.
+       (rs6000_expand_unop_builtin): Pass entire CALL_EXPR instead of
+       arglist.  Use new CALL_EXPR accessors.  Fix callers.
+       (altivec_expand_abs_builtin): Likewise.
+       (rs6000_expand_binop_builtin): Likewise.
+       (altivec_expand_predicate_builtin): Likewise.
+       (altivec_expand_lv_builtin): Likewise.
+       (spe_expand_stv_builtin): Likewise.
+       (altivec_expand_stv_builtin): Likewise.
+       (rs6000_expand_ternop_builtin): Likewise.
+       (altivec_expand_ld_builtin): Use new CALL_EXPR accessors.
+       (altivec_expand_st_builtin): Likewise.
+       (altivec_expand_dst_builtin): Likewise.
+       (altivec_expand_vec_init_builtin): Pass entire CALL_EXPR instead of
+       arglist.  Use new CALL_EXPR accessors.  Fix callers.
+       (altivec_expand_vec_set_builtin): Likewise.
+       (altivec_expand_vec_ext_builtin): Likewise.
+       (altivec_expand_builtin): Use new CALL_EXPR accessors.
+       (spe_expand_builtin): Likewise.
+       (spe_expand_predicate_builtin): Pass entire CALL_EXPR instead of
+       arglist.  Use new CALL_EXPR accessors.  Fix callers.
+       (spe_expand_evsel_builtin): Likewise.
+       (rs6000_expand_builtin): Use new CALL_EXPR accessors.  VCFUX and
+       FCFSX cases must construct whole new CALL_EXPR, not just arglist.
+
+       * config/arm/arm.c (arm_expand_binop_builtin): Pass entire CALL_EXPR
+       instead of arglist.  Use new CALL_EXPR accessors.  Fix callers.
+       (arm_expand_unop_builtin): Likewise.
+       (arm_expand_builtin): Use new CALL_EXPR accessors.
+
+       * config/mips/mips.c (mips_expand_builtin): Use new CALL_EXPR
+       accessors.
+
+       * config/bfin/bfin.c (bfin_expand_binop_builtin): Pass entire
+       CALL_EXPR instead of arglist.  Use new CALL_EXPR accessors.
+       Fix callers.
+       (bfin_expand_unop_builtin): Likewise.
+       (bfin_expand_builtin): Use new CALL_EXPR accessors.
+
+2007-02-15  Sandra Loosemore  <sandra@codesourcery.com>
+           Brooks Moses  <brooks.moses@codesourcery.com>
+           Lee Millward  <lee.millward@codesourcery.com>
+
+       * c-semantics.c (build_stmt): Add internal diagnostic check.
+
+       * c-pretty-print.c (pp_c_postfix_expression): Use new CALL_EXPR
+       accessors.  Print arguments explicitly instead of as a list.
+
+       * c-typeck.c (build_function_call): Use new CALL_EXPR constructors.
+
+       * c-omp.c (c_finish_omp_barrier): Use build_call_expr.
+       (c_finish_omp_flish): Likewise.
+
+       * c-common.c (verify_tree): Use new CALL_EXPR accessors.  Traverse
+       arguments explicitly instead of as a list.  Use TREE_OPERAND_LENGTH
+       instead of TREE_CODE_LENGTH.
+       (check_function_arguments_recurse): Use new CALL_EXPR accessors.
+       (c_warn_unused_result): Likewise.
+
+2007-02-15  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c/26494
+       * doc/invoke.texi (Warning Options): Remove
+       -Werror-implicit-function-declaration.
+       (Wimplicit-function-declaration): Update description.
+       * opts.c (common_handle_option): Move handling of -Werror=* to...
+       (enable_warning_as_error): ...here.
+       * opts.h (enable_warning_as_error): Declare.
+       * c-decl.c (implicit_decl_warning): Unless
+       -Wno-implicit-function-declaration is given, emit a pedwarn if
+       -std=c99 or emit a warning if -Wimplicit-function-declaration.
+       * c.opt (Wimplicit-function-declaration): Replace
+       mesg_implicit_function_declaration with
+       warn_implicit_function_declaration.
+       * c-opts.c (c_common_handle_option):
+       -Werror-implicit-function-declaration is exactly equal as
+       -Werror=implicit-function-declaration.
+       (set_Wimplicit): Replace mesg_implicit_function_declaration with
+       warn_implicit_function_declaration.
+       (c_common_post_options): -Wimplict-function-declaration is enabled
+       by default by -std=c99, otherwise is disabled by default.
+       * c-objc-common.c (c_objc_common_init): Remove flawed logic.
+
+2007-02-15  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gimplify.c (gimplify_modify_expr): During gimplification, attach a
+       DECL on the rhs to a DECL on the lhs for debug info purposes if the
+       former is ignored but not the latter.
+
+2007-02-15  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * expr.c (expand_expr_real_1) <normal_inner_ref>: If a temporary
+       is made and the reference doesn't use the alias set of its type,
+       do not create the temporary using that type.
+
+2007-02-15  Aldy Hernandez  <aldyh@redhat.com>
+
+       * jump.c: Remove prototypes for delete_computation and
+       delete_prior_computation.
+
+2007-02-15  Paolo Bonzini  <bonzini@gnu.org>
+
+       * jump.c (get_label_after): Delete.
+       (get_label_before, delete_computation, delete_jump,
+       delete_prior_computation, follow_jumps): Move...
+       * reorg.c (delete_computation, delete_prior_computation): ... here...
+       (get_label_before, delete_jump): ... making these static ...
+       (follow_jumps): ... and simplifying this since it only runs after
+       reload.
+       * rtl.h (get_label_after, get_label_before, delete_jump,
+       follow_jumps): Delete prototypes.
+
+2007-02-15  Paolo Bonzini  <bonzini@gnu.org>
+
+       * caller-save.c (save_call_clobbered_regs): Do not process sibcalls.
+
+2007-02-15  Nick Clifton  <nickc@redhat.com>
+
+       * varasm.c (default_asm_output_anchor): Prepend * to . symbol in
+       order to prevent it from being munged by the target.
+
+2007-02-15  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md: Remove misleading comment.
+
+2007-02-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       * config/frv/frv.md (reload_incc, reload_outcc, reload_incc_uns,
+       reload_outcc_uns, reload_incc_nz, reload_outcc_nz): Remove
+       invalid patterns.
+
+2007-02-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree-sra.c (instantiate_missing_elements): Canonicalize
+       bit-field types.
+       (sra_build_assignment): New.
+       (generate_copy_inout, generate_element_copy,
+       generate_element_zero, generate_one_element_init): Use it.
+
+2007-02-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       * tree-sra.c (instantiate_missing_elements): Canonicalize
+       bit-field types.
+       (sra_build_assignment): New.
+       (generate_copy_inout, generate_element_copy,
+       generate_element_zero, generate_one_element_init): Use it.
+
+2007-02-15  Alexandre Oliva  <aoliva@redhat.com>
+
+       * dwarf2out.c (dwarf2out_finish): Accept namespaces as context of
+       limbo die nodes.
+
+2007-02-14  Joseph Myers  <joseph@codesourcery.com>
+
+       * emit-rtl.c (set_mem_attributes_minus_bitpos): Treat complex
+       types as aggregates not scalars.
+       * function.c (assign_stack_temp_for_type): Likewise.
+
+2007-02-14  Roger Sayle  <roger@eyesopen.com>
+           Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * tree-dump.c (dump_switch_p_1): Require exact match of the option
+       name.
+
+2007-02-14  Zdenek Dvorak  <dvorakz@suse.cz>
+
+       * passes.c (next_pass_1): Clear the next field of the copied
+       pass structure.
+
+2007-02-14  Richard Henderson  <rth@redhat.com>
+
+       * tree-sra.c (early_sra): New.
+       (decl_can_be_decomposed_p): Deny va_list if early_sra.
+       (tree_sra_early, pass_sra_early): New.
+       * tree-pass.h (pass_sra_early): Declare.
+       * passes.c (init_optimization_passes): Use it.
+
+2007-02-14  Richard Guenther  <rguenther@suse.de>
+
+       * flags.h (issue_strict_overflow_warning): Convert to a macro.
+
+2007-02-14  Dorit Nuzman  <dorit@il.ibm.com>
+
+        PR tree-optimization/30771
+       * tree-vect-analyze.c (vect_determine_vectorization_factor): Traverse
+       also phi nodes.
+       (vect_analyze_operations): Induction phis can now be marked as
+       used_in_loop.
+       (vect_mark_stmts_to_be_vectorized): No special treatment for phis.
+       Update documentation accordingly.
+
+2007-02-14  Nick Clifton  <nickc@redhat.com>
+
+       * builtin-types.def (DEF_FUNCTION_TYPE_x): Do not imply that at
+       most 3 arguments are supported.
+       (DEF_FUNCTION_TYPE_VAR_5): Fix typo in its description.
+
+2007-02-13  Seongbae Park <seongbae.park@gmail.com>
+
+       * bitmap.c (bitmap_and, bitmap_and_compl, bitmap_xor):
+       Ensure dst->current is valid.
+
+2007-02-13  Paul Brook  <paul@codesourcery.com>
+
+       * config.gcc: Add arm*-*-uclinux-*eabi.
+       * config/arm/uclinux-elf.h (TARGET_OS_CPP_BUILTINS): Define.
+       (SUBTARGET_EXTRA_LINK_SPEC): Define.
+       (STARTFILE_SPEC, ENDFILE_SPEC): Remove broken -shared handling.
+       (LINK_GCC_C_SEQUENCE_SPEC): Undef.
+       (LINK_SPEC): Define.
+       (LIB_SPEC): Define.
+       * config/arm/arm.c (arm_override_options): Use r9 as EABI PIC
+       register.
+       * config/arm/uclinux-eabi.h: New file.
+       * config/arm/linux-eabi.h (WCHAR_TYPE): Remove.
+       * config/arm/linux-gas.h (WCHAR_TYPE): Use unsigned long on AAPCS
+       based targets.
+
+2007-02-13  Ian Lance Taylor  <iant@google.com>
+
+       * common.opt: Add Wstrict-overflow and Wstrict-overflow=.
+       * flags.h (warn_strict_overflow): Declare.
+       (enum warn_strict_overflow_code): Define.
+       (issue_strict_overflow_warning): New static inline function.
+       * opts.c (warn_strict_overflow): New variable.
+       (common_handle_option): Handle OPT_Wstrict_overflow and
+       OPT_Wstrict_overflow_.
+       * c-opts.c (c_common_handle_option): Set warn_strict_overflow for
+       OPT_Wall.
+       * fold-const.c: Include intl.h.
+       (fold_deferring_overflow_warnings): New static variable.
+       (fold_deferred_overflow_warning): New static variable.
+       (fold_deferred_overflow_code): New static variable.
+       (fold_defer_overflow_warnings): New function.
+       (fold_undefer_overflow_warnings): New function.
+       (fold_undefer_and_ignore_overflow_warnings): New function.
+       (fold_deferring_overflow_warnings_p): New function.
+       (fold_overflow_warning): New static function.
+       (make_range): Add strict_overflow_p parameter.  Change all
+       callers.
+       (extract_muldiv, extract_muldiv_1): Likewise.
+       (fold_unary) [ABS_EXPR]: Check ABS_EXPR before calling
+       tree_expr_nonnegative_p.
+       (fold_negate_expr): Call fold_overflow_warning.
+       (fold_range_test): Likewise.
+       (fold_comparison): Likewise.
+       (fold_binary): Likewise.  Call tree_expr_nonnegative_warnv_p
+       instead of tree_expr_nonnegative_p.
+       (tree_expr_nonnegative_warnv_p): Rename from
+       tree_expr_nonnegative_p, add strict_overflow_p parameter.
+       (tree_expr_nonnegative_p): New function.
+       (tree_expr_nonzero_warnv_p): Rename from tree_expr_nonzero_p, add
+       strict_overflow_p parameter.
+       (tree_expr_nonzero_p): New function.
+       * passes.c (verify_interpass_invariants): New static function.
+       (execute_one_pass): Call it.
+       * tree-ssa-loop-niter.c (expand_simple_operations): Ignore fold
+       warnings.
+       (number_of_iterations_exit, loop_niter_by_eval): Likewise.
+       (estimate_numbers_of_iterations): Likewise.
+       (scev_probably_wraps_p): Likewise.
+       * tree-ssa-ccp.c: Include "toplev.h".
+       (evaluate_stmt): Defer fold overflow warnings until we know we are
+       going to optimize.
+       (struct fold_stmt_r_data): Add stmt field.
+       (fold_stmt_r): Defer fold overflow warnings until we know we
+       optimized.
+       (fold_stmt): Initialize stmt field of fold_stmt_r_data.
+       (fold_stmt_inplace): Likewise.
+       * tree-cfgcleanup.c: Include "toplev.h" rather than "errors.h".
+       (cleanup_control_expr_graph): Defer fold overflow warnings until
+       we know we are going to optimize.
+       * tree-cfg.c (fold_cond_expr_cond): Likewise.
+       * tree-ssa-threadedge.c (simplify_control_stmt_condition):
+       Likewise.
+       * tree-vrp.c (vrp_expr_computes_nonnegative): Call
+       tree_expr_nonnegative_warnv_p instead of tree_expr_nonnegative_p.
+       * tree-ssa-loop-manip.c (create_iv): Likewise.
+       * c-typeck.c (build_conditional_expr): Likewise.
+       (build_binary_op): Likewise.
+       * tree-vrp.c (vrp_expr_computes_nonzero): Call
+       tree_expr_nonzero_warnv_p instead of tree_expr_nonzero_p.
+       (extract_range_from_unary_expr): Likewise.
+       * simplify-rtx.c (simplify_const_relational_operation): Warn when
+       assuming that signed overflow does not occur.
+       * c-common.c (pointer_int_sum): Ignore fold overflow warnings.
+       * tree.h (tree_expr_nonnegative_warnv_p): Declare.
+       (fold_defer_overflow_warnings): Declare.
+       (fold_undefer_overflow_warnings): Declare.
+       (fold_undefer_and_ignore_overflow_warnings): Declare.
+       (fold_deferring_overflow_warnings_p): Declare.
+       (tree_expr_nonzero_warnv_p): Declare.
+       * doc/invoke.texi (Option Summary): Add -Wstrict-overflow to list
+       of warning options.
+       (Warning Options): Document -Wstrict-overflow.
+       * Makefile.in (tree-ssa-threadedge.o): Depend on toplev.h.
+       (tree-ssa-ccp.o): Likewise.
+       (tree-cfgcleanup.o): Change errors.h dependency to toplev.h.
+       (fold-const.o): Depend on intl.h.
+
+2007-02-13  Ian Lance Taylor  <iant@google.com>
+
+       PR middle-end/30751
+       * lower-subreg.c (resolve_simple_move): Decompose subregs in
+       addresses.
+
+2007-02-13  Stuart Hastings  <stuart@apple.com>
+
+       * config/i386/i386.md (fixuns_truncdfhi2): Require SSE2.
+
+2007-02-13  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/alpha.c (alpha_stdarg_optimize_hook): Strip
+       handled_component_p before looking for the indirect_ref.
+
+2007-02-13  Richard Henderson  <rth@redhat.com>
+
+       * config/i386/i386.md (bswapsi_1): Rename from bswapsi2,
+       remove flags clobber.
+       (bswapsi2): New expander, emit code for !TARGET_BSWAP.
+       (bswaphi_lowpart): New.
+       (bswapdi2): Rename from bswapdi2_rex, remove flags clobber,
+       remove TARGET_BSWAP test.  Delete expander of the same name.
+
+       * optabs.c (widen_bswap, expand_doubleword_bswap): New.
+       (expand_unop): Use them.
+
+2007-02-13  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (cmpdi_ccno_1_rex64, *cmpsi_ccno_1,
+       *cmphi_ccno_1, *cmpqi_ccno_1, *movsi_xor, *movstricthi_xor,
+       *movstrictqi_xor, *movdi_xor_rex64, *ashldi3_1_rex64,
+       *ashldi3_cmp_rex64, *ashldi3_cconly_rex64, ashlsi3, *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): Remove equivalent
+       assembler dialect choice from asm templates.
+
+2007-02-12  Richard Henderson  <rth@redhat.com>
+
+       * config/i386/i386.md (fixuns_trunc<SSEMODEF>si_1): New insn.
+       (fixuns_trunc<SSEMODEF>si2): Use it.
+       * config/i386/sse.md (vec_setv4sf_0): Export.
+       * config/i386/i386.c (ix86_build_const_vector): Export.
+       (ix86_split_convert_uns_si_sse): Rename from
+       ix86_expand_convert_uns_si_sse and rewrite as a splitter.
+       * config/i386/i386-protos.h: Update.
+
+2007-02-13  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c/29521
+       * c-typeck.c (c_finish_return): Improve warning message.
+
+2007-02-12  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * alias.c (find_symbolic_term): Delete unused function.
+
+2007-02-12  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (paritydi2, paritysi2): New expanders.
+       (paritydi2_cmp, paritydi2_cmp): New insn and split patterns.
+       (*parityhi2_cmp, *parityqi2_cmp): New insn patterns.
+
+2007-02-12  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree.h (DECL_IGNORED_P): Document further effect for FUNCTION_DECL.
+       * cgraphunit.c (cgraph_expand_function): If DECL_IGNORED_P is set on
+       the function, temporarily point the debug interface to the null one.
+
+2007-02-12  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * dwarf2out.c (round_up_to_align): New static function.
+       (field_byte_offset): Use it to round the offset.
+
+2007-02-12  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/alpha.md (bswapsi2, bswapdi2): New.
+       (inswl_const): Export.
+
+2007-02-12  Richard Henderson  <rth@redhat.com>
+
+       * calls.c (emit_library_call_value_1): If PROMOTE_MODE modifed the
+       result mode of the libcall, convert back to outmode.
+
+2007-02-12  Roger Sayle  <roger@eyesopen.com>
+
+       * config/i386/i386.md (*bswapdi2_rex): Renamed from bswapdi2.
+       (bswapdi2): New define_expand to implement 32-bit implementation.
+
+2007-02-12  Nick Clifton  <nickc@redhat.com>
+
+       * doc/invoke.texi (Overall Options): Document --help=.
+       * gcc.c (target_help_flag): Rename to print_subprocess_flag.
+       (cc1_options): Pass --help= on to cc1.
+       (display_help): Add description of --help=.
+       (process_command): Add code to handle --help=.  Allow translated
+       --help and --target-help switches to be passed on to compiler
+       sub-process.
+       (main): Remove unused if statement.
+       * opts.c (columns): Remove.
+       (LEFT_COLUMN): Define.
+       (wrap_help): Add columns argument.
+       (print_filtered_help): Change parameters to be an include bitmask,
+       an exclude bitmask, an any bitmask and the column width.  Move the
+       code to display the params list here.  Add code to display the
+       status of options rather than their descriptions if the quiet flag
+       is not active.
+       (print_specific_help): Change parameters to be an include bitmask,
+       an exclude bitmask and an any bitmask.  Move code to look up the
+       column width here.  Decide upon the title for an options listing.
+       (common_handle_options): Add code to handle --help=.  Adapt code
+       for --help and --target-help to use the revised form of the
+       print_specific_help function.
+       (print_help): Delete.
+       (print_param_help): Delete.
+       (print_switch): Delete.
+       * opts.h (cl_lang_count): Add prototype.
+       (CL_PARAMS, CL_WARNING, CL_OPTIMIZATION, CL_MIN_OPTION_CLASS,
+       CL_MAX_OPTION_CLASS): New defines.
+       * optc-gen.awk: Add construction of cl_lang_count.
+       * c.opt: Add Warning attribute to warning options and Optimization
+       attribute to optimization options.
+       * common.opt: Likewise.
+       Add --help=.
+       Add -fhelp and -ftarget-help as aliases for the transformed --help
+       and --target-help options.
+       * opt-functions.awk: Add code to handle Warning and Optimization
+       attributes.
+
+2007-02-12  Richard Henderson  <rth@redhat.com>
+
+       * config/alpha/constraints.md: New file.
+       * config/alpha/alpha.c: Include tm-constrs.h.
+       (alpha_const_ok_for_letter_p, alpha_const_double_ok_for_letter_p,
+       alpha_extra_constraint): Remove.
+       (alpha_emit_conditional_branch): Use satisfies_constraint_*.
+       * config/alpha/alpha-protos.h: Update.
+       * config/alpha/alpha.h (REG_CLASS_FROM_LETTER): Remove.
+       (CONST_OK_FOR_LETTER_P, CONST_DOUBLE_OK_FOR_LETTER_P): Remove.
+       (EXTRA_CONSTRAINT): Remove.
+       * config/alpha/alpha.md: Include constraints.md.
+       (adddi splitter): Use satisfies_constraint_*.
+       * config/alpha/predicates.md (add_operand): Likewise.
+       (sext_add_operand, addition_operation): Likewise.
+
+2007-02-12  Dorit Nuzman  <dorit@il.ibm.com>
+
+       PR tree-optimization/29145
+       * tree-data-ref.c (base_addr_differ_p): Make us more conservative
+       in our handling of restrict qualified pointers.
+
+2007-02-12  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR middle-end/7651
+       * doc/invoke.texi (Wunused-value): Update description.
+       (Wextra): Delete item.
+       * opts.c (set_Wextra): Don't use the value of Wextra to set the
+       value of Wunused-value.
+       * c-typeck.c (c_process_expr_stmt): Don't check extra_warnings.
+       (c_finish_stmt_expr): Don't check extra_warnings.
+       (emit_side_effect_warnings): The caller is responsible to check
+       warn_unused_value.
+
+2007-02-11  Roger Sayle  <roger@eyesopen.com>
+           Matt Thomas  <matt@3am-software.com>
+
+       * simplify-rtx.c (simplify_relational_operation_1): Correct typo.
+
+2007-02-11  Roger Sayle  <roger@eyesopen.com>
+
+       * simplify-rtx.c (simplify_relational_operation_1): Optimize
+       comparisons of POPCOUNT against zero.
+       (simplify_const_relational_operation): Likewise.
+
+2007-02-11  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * doc/invoke.texi (Wextra): Delete outdated paragraph.
+
+2007-02-11  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * dwarf2out.c (root_type): Delete unused function.
+
+2007-02-11  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * genattrtab.c (contained_in_p): Delete unused function.
+       (write_expr_attr_cache): Likewise.
+
+2007-02-11  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-inline.c (cgraph_edge_badness): Add "else" missing in the
+       previous patch.
+
+2007-02-11  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * fwprop.c (try_fwprop_subst): Use set_unique_reg_note
+       to add the REG_EQ* note.
+       * see.c (see_merge_one_use_extension): Likewise.
+       * local-alloc.c (update_equiv_regs): Likewise.  Also don't
+       turn REG_EQUAL notes into REG_EQUIV notes if the target
+       register may have more than one set.
+       * function.c (assign_parm_setup_reg): Use set_unique_reg_note.
+       * gcse.c (try_replace_reg): Likewise.
+       * alias.c (init_alias_analysis): Use find_reg_equal_equiv_note.
+       * calls.c (fixup_tail_calls): Likewise.  Abort if there is
+       more than one REG_EQUIV note.
+       * reload1.c (gen_reload): Use set_unique_reg_note.
+
+2007-02-11  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.c (TARGET_VECTORIZE_BUILTIN_CONVERSION): Define.
+       (ix86_builtin_conversion): New function.
+
+2007-02-06  Mark Mitchell  <mark@codesourcery.com>
+
+       PR target/29487
+       * tree.h (DECL_REPLACEABLE_P): New macro.
+       * except.c (set_nothrow_function_flags): Likewise.
+
+2007-02-11  Tehila Meyzels  <tehila@il.ibm.com>
+           Ira Rosen  <irar@il.ibm.com>
+           Dorit Nuzman  <dorit@il.ibm.com>
+
+       * doc/tm.texi (TARGET_VECTORIZE_BUILTIN_CONVERSION): New target hook.
+       * targhooks.c (default_builtin_vectorized_conversion): New.
+       * targhooks.h (default_builtin_vectorized_function): New declaration.
+       * target.h (struct vectorize): Add builtin_conversion field.
+       * tree-vectorizer.h (type_conversion_vec_info_type): New enum
+       stmt_vec_info_type value.
+       (vectorizable_conversion): New declaration.
+       * tree-vect-analyze.c (vect_analyze_operations): Add
+       vectorizable_conversion call.
+       * target-def.h (TARGET_VECTORIZE_BUILTIN_CONVERSION): New.
+       * tree-vect-transform.c (vectorizable_conversion): New function.
+       (vect_transform_stmt): Add case for type_conversion_vec_info_type.
+       * tree-vect-generic.c (expand_vector_operations_1): Consider correct
+       mode.
+       * config/rs6000/rs6000.c (rs6000_builtin_conversion): New.
+       (TARGET_VECTORIZE_BUILTIN_CONVERSION): Defined.
+       (rs6000_expand_builtin): Add handling a case of ALTIVEC_BUILTIN_VCFUX
+       or ALTIVEC_BUILTIN_VCFSX.
+
+2007-02-10  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       PR target/30634
+       * pa.md (movdf): For 64-bit target, fail if operand 1 is a non-zero
+       CONST_DOUBLE and operand 0 is a hard register.
+       (movdi): For 64-bit target, remove code to force CONST_DOUBLE to
+       memory.  Fail if operand 1 is a non-zero CONST_INT and operand 0
+       is a hard floating-point register.
+
+2007-02-10  Richard Henderson  <rth@redhat.com>
+           Jakub Jelinek  <jakub@redhat.com>
+           Alexandre Oliva  <aoliva@redhat.com>
+
+       * Makefile.in (libgcc-support, libgcc.mvars): Add emutls.c.
+       * builtin-types.def (BT_WORD): Make unsigned.
+       (BT_FN_VOID_PTR_WORD_WORD_PTR): New.
+       * builtins.def (BUILT_IN_EMUTLS_GET_ADDRESS): New.
+       (BUILT_IN_EMUTLS_REGISTER_COMMON): New.
+       * c-decl.c (grokdeclarator): Don't error if !have_tls.
+       * c-parser.c (c_parser_omp_threadprivate): Likewise.
+       * dwarf2out.c (loc_descriptor_from_tree_1): Don't do anything for
+       emulated tls.
+       * expr.c (emutls_var_address): New.
+       (expand_expr_real_1): Expand emulated tls.
+       (expand_expr_addr_expr_1): Likewise.
+       * libgcc-std.ver: Add __emutls_get_address, __emutls_register_common.
+       * output.h (emutls_finish): Declare.
+       * toplev.c (compile_file): Call it.
+       * tree-ssa-address.c (gen_addr_rtx): Check for const-ness of the
+       address before wrapping in CONST.
+       * varasm.c (emutls_htab, emutls_object_type): New.
+       (EMUTLS_VAR_PREFIX, EMUTLS_TMPL_PREFIX): New.
+       (get_emutls_object_name, get_emutls_object_type): New.
+       (get_emutls_init_templ_addr, emutls_decl): New.
+       (emutls_common_1, emutls_finish): New.
+       (assemble_variable): When emulating tls, swap decls; generate
+       constructor for the emutls objects.
+       (do_assemble_alias): When emulating tls, swap decl and target name.
+       (default_encode_section_info): Don't add SYMBOL_FLAG_TLS_SHIFT
+       for emulated tls.
+       * varpool.c (decide_is_variable_needed): Look at force_output.
+       Recurse for emulated tls.
+       (cgraph_varpool_remove_unreferenced_decls): Remove checks redundant
+       with decide_is_variable_needed.
+       * emutls.c: New file.
+       * config/sparc/sol2.h (ASM_DECLARE_OBJECT_NAME): Only emit
+       tls_object for real tls.
+
+2007-02-10  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR rtl-optimization/29599
+       * reload1.c (eliminate_regs_in_insn): Take the destination
+       mode into account when computing the offset.
+
+2007-02-09  Stuart Hastings  <stuart@apple.com>
+           Richard Henderson  <rth@redhat.com>
+
+       * config/i386/i386.h (TARGET_KEEPS_VECTOR_ALIGNED_STACK): New.
+       * config/i386/darwin.h: (TARGET_KEEPS_VECTOR_ALIGNED_STACK): New.
+       * config/i386/i386.md (fixuns_trunc<mode>si2, fixuns_truncsfhi2,
+       fixuns_truncdfhi2): New.
+       (fix_truncsfdi_sse): Call ix86_expand_convert_sign_didf_sse.
+       (floatunsdidf2): Call ix86_expand_convert_uns_didf_sse.
+       (floatunssisf2): Add call to ix86_expand_convert_uns_sisf_sse.
+       (floatunssidf2): Allow nonimmediate source.
+       * config/i386/sse.md (movdi_to_sse): New.
+       (vec_concatv2di): Drop '*'.
+       * config/i386/i386-protos.h (ix86_expand_convert_uns_si_sse,
+       ix86_expand_convert_uns_didf_sse, ix86_expand_convert_uns_sidf_sse,
+       ix86_expand_convert_uns_sisf_sse, ix86_expand_convert_sign_didf_sse):
+       New.
+       * config/i386/i386.c (ix86_expand_convert_uns_si_sse,
+       ix86_expand_convert_uns_didf_sse, ix86_expand_convert_uns_sidf_sse,
+       ix86_expand_convert_uns_sisf_sse, ix86_expand_convert_sign_didf_sse,
+       ix86_build_const_vector, ix86_expand_vector_init_one_nonzero): New.
+       (ix86_build_signbit_mask): Fix decl of v, refactor to call
+       ix86_build_const_vector.
+       (x86_emit_floatuns): Rewrite.
+
+2007-02-10  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * genautomata.c (longest_path_length): Delete unused function.
+       (struct state): Delete unused longest_path_length.
+       (UNDEFINED_LONGEST_PATH_LENGTH): Delete unused macro.
+       (get_free_state): Delete unused.
+
+2007-02-09  Jan Hubicka  <jh@suse.cz>
+
+       * params.def (PARAM_INLINE_UNIT_GROWTH): Set to 30.
+       * doc/invoke.texi (inline-unit-growth): Update default value.
+
+       * Makefile.in (passes.o, ipa-inline.o): Add dependencies.
+       * cgraphbuild.c (build_cgraph_edges): Compute frequencies.
+       (rebuild_cgraph_edges): Likewise.
+       * cgraph.c (cgraph_set_call_stmt): Add new argument frequency.
+       (dump_cgraph_node): Dump frequencies.
+       (cgraph_clone_edge): Add frequency scales.
+       (cgraph_clone_node): Add freuqnecy.
+       * cgraph.h (cgraph_edge): Add freuqnecy argument.
+       (CGRAPH_FREQ_BASE, CGRAPH_FREQ_MAX): New constants.
+       (cgraph_create_edge, cgraph_clone_edge, cgraph_clone_node): Update.
+       * tree-pass.h (TODO_rebuild_frequencies): New constant.
+       * cgraphunit.c (verify_cgraph_node): Verify frequencies.
+       (cgraph_copy_node_for_versioning): Update call of cgraph_clone_edge.
+       (save_inline_function_body): Likewise.
+       * ipa-inline.c: inluce rtl.h
+       (cgraph_clone_inlined_nods): Update call of cgraph_clone_node.
+       (cgraph_edge_badness): Use frequencies.
+       (cgraph_decide_recursive_inlining): Update clonning.
+       (cgraph_decide_inlining_of_small_function): Dump frequency.
+       * predict.c (estimate_bb_frequencies): Export.
+       * predict.h (estimate_bb_frequencies): Declare.
+       * tree-inline.c (copy_bb): Watch overflows.
+       (expand_call_inline): Update call of cgraph_create_edge.
+       (optimize_inline_calls): Use TODO flags to update frequnecies.
+       * passes.h: Include predict.h
+       (init_optimization_passes): Move profile ahead.
+       (execute_function_todo): Handle TODO_rebuild_frequencies.
+
+2007-02-09  Roger Sayle  <roger@eyesopen.com>
+
+       * config/alpha/alpha.c (emit_insxl): Force the first operand of
+       the insbl or inswl pattern into a register.
+
+2007-02-09  Roger Sayle  <roger@eyesopen.com>
+
+       * config/ia64/ia64.md (bswapdi2): New define_insn.
+
+2007-02-09  Richard Henderson  <rth@redhat.com>
+
+       * config/i386/constraints.md (Ym): New constraint.
+       * config/i386/i386.md (movsi_1): Change Y2 to Yi constraints.
+       (movdi_1_rex64): Split sse and xmm general register moves from
+       memory move alternatives.  Use conditional register constraints.
+       (movsf_1, movdf_integer): Likewise.
+       (zero_extendsidi2_32, zero_extendsidi2_rex64): Likewise.
+       (movdf_integer_rex64): New.
+       (pushsf_rex64): Fix output constraints.
+       * config/i386/sse.md (sse2_loadld): Split rm alternative, use Yi.
+       (sse2_stored): Likewise.
+       (sse2_storeq_rex64): New.
+       * config/i386/i386.c (x86_inter_unit_moves): Enable for not
+       amd and not generic.
+       (ix86_secondary_memory_needed): Don't bypass TARGET_INTER_UNIT_MOVES
+       for optimize_size.  Remove SF/DFmode hack.
+
+2007-02-09  Dwarakanath Rajagopal  <dwarak.rajagopal@amd.com>
+
+       * config/i386/driver-i386.c: Turn on -mtune=native for AMDFAM10.
+       (bit_SSE4a): New.
+
+2007-02-09  Nathan Sidwell  <nathan@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (m68010-*-netbsdelf*, m68k*-*-netbsdelf*)
+       (m68k*-*-openbsd*, m68k-*-linux*): Set default_cf_cpu.
+       (m68k-*-aout*, m68k-*-coff*, m68k-*-uclinux*, m68k-*-rtems*): Add
+       m68k/t-mlib to tmake_file.
+       (m68020-*-elf*, m68k-*-elf*): Likewise.  Add t-m68kbare as well.
+       (m68k*-*-*): Use --with-arch to pick a default for --with-cpu.
+       (m680[012]0-*-*, m68k*-*-*): Add support for --with-arch.
+       Allow it to be cf or m68k.  Set m68k_arch_family.  If that
+       variable is not empty, add t-$m68k_arch_family to tmake_file.
+       Add t-mlibs to tmake_file.
+       * doc/install.texi: Document --with-arch=m68k and --with-arch=cf.
+       * config/m68k/t-cf: New file.
+       * config/m68k/t-m68k: Likewise.
+       * config/m68k/t-mlibs: Likewise.
+       * config/m68k/t-m68kbare (MULTILIB_OPTIONS, MULTILIB_DIRNAMES)
+       (MULTILIB_MATCHES, MULTILIB_EXCEPTIONS): Delete.
+       (M68K_MLIB_DIRNAMES, M68K_MLIB_OPTIONS): Define.
+       * config/m68k/t-m68kelf (MULTILIB_OPTIONS, MULTILIB_DIRNAMES)
+       (MULTILIB_MATCHES, MULTILIB_EXCEPTIONS, LIBGCC, INSTALL_LIBGCC):
+       Delete.
+       * config/m68k/t-openbsd (MULTILIB_OPTIONS, LIBGCC): Delete.
+       (INSTALL_LIBGCC): Delete.
+       (M68K_MLIB_DIRNAMES, M68K_MLIB_OPTIONS): Define.
+       * config/m68k/t-rtems (MULTILIB_OPTIONS, MULTILIB_DIRNAMES)
+       (MULTILIB_MATCHES, MULTILIB_EXCEPTIONS): Delete.
+       (M68K_MLIB_CPU): Define.
+       * config/m68k/t-uclinux (MULTILIB_OPTIONS, MULTILIB_DIRNAMES)
+       (MULTILIB_MATCHES, MULTILIB_EXCEPTIONS): Delete.
+       (M68K_MLIB_CPU, M68K_MLIB_OPTIONS, M68K_MLIB_DIRNAMES): Define.
+
+2007-02-09  Zdenek Dvorak  <dvorakz@suse.cz>
+           Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/23361
+       * fold-const.c (fold_comparison): Handle obfuscated comparisons
+       against INT_MIN/INT_MAX.
+       * tree-ssa-loop-ivcanon.c (remove_empty_loop): Print to dump
+       file if a loop is removed.
+
+2007-02-09  Joseph Myers  <joseph@codesourcery.com>
+
+       * calls.c (store_one_arg): Pass correct alignment to
+       emit_push_insn for non-BLKmode values.
+       * expr.c (emit_push_insn): If STRICT_ALIGNMENT, copy to an
+       unaligned stack slot via a suitably aligned slot.
+
+2007-02-08  DJ Delorie  <dj@redhat.com>
+
+       * config/m32c/m32c.c (m32c_unpend_compare): Add default to silence
+       warnings.
+       (legal_subregs): Use unsigned char, make const.
+       (m32c_illegal_subreg_p): Use ARRAY_SIZE.  Delete unused variables.
+
+2007-02-08  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/lib1funcs.asm (RETLDM): Pop directly into PC when no
+       special interworking needed.
+
+2007-02-08  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/xmmintrin.h: Make inclusion of emmintrin.h
+       conditional to __SSE2__.
+       (Entries below should have been added to first ChangeLog
+       entry for amdfam10 dated 2007-02-05)
+       * config/i386/emmintrin.h: Generate #error if __SSE2__ is not
+       defined.
+       * config/i386/pmmintrin.h: Generate #error if __SSE3__ is not
+       defined.
+       * config/i386/tmmintrin.h: Generate #error if __SSSE3__ is not
+       defined.
+
+2007-02-08  DJ Delorie  <dj@redhat.com>
+
+       * config/m32c/m32c-protos.h (m32c_illegal_subreg_p): New.
+       * config/m32c/m32c.c (legal_subregs): New.
+       (m32c_illegal_subreg_p): New.
+       * config/m32c/predicates.md (m32c_any_operand): Use it to reject
+       unsupported subregs of hard regs.
+
+2007-02-08  Jan Hubicka  <jh@suse.cz>
+
+       * tree-cfg.c (bsi_replace): Shortcut when replacing the statement with
+       the same one; always update histograms.
+
+2007-02-08  Diego Novillo  <dnovillo@redhat.com>
+
+       * passes.c (init_optimization_passes): Tidy comment.
+
+2007-02-08  Roger Sayle  <roger@eyesopen.com>
+
+       * simplify-rtx.c (simplify_unary_operation_1) <POPCOUNT>: We can
+       strip zero_extend, bswap and rotates from POCOUNT's argument.
+       <PARITY>: Likewise, we can strip not, bswap, sign_extend,
+       zero_extend and rotates from PARITY's argument.
+       <BSWAP>: A byte-swap followed by a byte-swap is an identity.
+       (simplify_const_unary_operation) <BSWAP>: Evaluate the byte-swap
+       of an integer constant at compile-time.
+
+2007-02-08  Diego Novillo  <dnovillo@redhat.com>
+
+       PR 30562
+       * tree-flow.h (struct var_ann_d): Remove field 'is_used'.
+       Update all users.
+       * tree-ssa-alias.c (compute_is_aliased): Remove.  Update all
+       users.
+       (init_alias_info):
+       * tree-ssa-live.c (remove_unused_locals): Do not remove
+       TREE_ADDRESSABLE variables.
+       * tree-ssa-structalias.c (compute_points_to_sets): Tidy.
+       * tree-ssa-operands.c (add_virtual_operand): Remove argument
+       FOR_CLOBBER.  Update all users.
+       If VAR has an associated alias set, add a virtual operand for
+       it if no alias is found to conflict with the memory reference.
+
+2007-02-07  Jan Hubicka  <jh@suse.cz>
+           Robert Kidd <rkidd@crhc.uiuc.edu>
+
+       * value-prof.c (visit_hist, free_hist): Return 1 instead of 0.
+
+2007-02-07  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (simple_move): Reject PARTIAL_INT modes.
+
+2007-02-07  Roger Sayle  <roger@eyesopen.com>
+
+       * config/rs6000/rs6000.md (ctz<mode>2, ffs<mode>2, popcount<mode>2,
+       parity<mode>2, smulsi3_highpart, abstf2_internal, allocate_stack,
+       tablejumpdi, movsi_to_cr_one): Remove constraints from
+       define_expand's match_operands.
+
+2007-02-07  Roger Sayle  <roger@eyesopen.com>
+
+       * global.c (compute_regsets): Move declatation of "i" inside of
+       #ifdef ELIMINABLE_REGS to avoid unused variable bootstrap failure.
+
+2007-02-07  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/30703
+       * gimplify.c (gimplify_scan_omp_clauses): Remove special casing
+       of INDIRECT_REF <RESULT_DECL>.
+
+       * config/i386/i386.c (override_options): Set PTA_SSSE3 for core2.
+
+2007-02-06  J"orn Rennecke  <joern.rennecke@arc.com>
+           Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       PR target/29746
+       * config/sh/sh.c (expand_cbranchdi4): Use scratch register
+       properly.
+       (sh_initialize_trampoline): Add parentheses to avoid a warning.
+
+2007-02-06  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * doc/loop.texi: Document possibility not to perform disambiguation
+       of loops with multiple latches.
+       * cfgloopmanip.c (alp_enum_p): Removed.
+       (add_loop): Handle subloops.  Use get_loop_body_with_size.
+       (create_preheader): Do not allow ENTRY_BLOCK_PTR to be preheader.
+       * cfghooks.c (redirect_edge_and_branch_force): Set dominator for
+       the new forwarder block.
+       (make_forwarder_block): Only call new_bb_cbk if it is not NULL.
+       Handle the case latch is NULL.
+       * tree-ssa-dom.c (tree_ssa_dominator_optimize): Avoid cfg
+       modifications when marking loop exits.
+       * ifcvt.c (if_convert): Ditto.  Mark loop exits even if cfg cannot
+       be modified.
+       * loop-init.c (loop_optimizer_init): Do not modify cfg.  Call
+       disambiguate_loops_with_multiple_latches.
+       * tree-cfgcleanup.c (cleanup_tree_cfg_loop): Calculate dominators
+       before fix_loop_structure.
+       * cfgloop.c: Include pointer-set.h and output.h.
+       (canonicalize_loop_headers, HEADER_BLOCK, LATCH_EDGE,
+       update_latch_info, mfb_keep_just, mfb_keep_nonlatch): Removed.
+       (get_loop_latch_edges, find_subloop_latch_edge_by_profile,
+       find_subloop_latch_edge_by_ivs, find_subloop_latch_edge,
+       mfb_redirect_edges_in_set, form_subloop, merge_latch_edges,
+       disambiguate_multiple_latches, get_loop_body_with_size,
+       disambiguate_loops_with_multiple_latches): New functions.
+       (flow_loop_dump): Dump multiple latch edges.
+       (flow_loop_nodes_find): Handle loops with multiple latches.
+       (flow_loops_find): Ditto. Do not call canonicalize_loop_headers.
+       (glb_enum_p): Modified.
+       (get_loop_body): Use get_loop_body_with_size.
+       * cfgloop.h (LOOPS_HAVE_RECORDED_EXITS): New flag.
+       (AVOID_CFG_MODIFICATIONS): New constant.
+       (disambiguate_loops_with_multiple_latches, add_loop,
+       get_loop_body_with_size): Declare.
+       * Makefile.in (cfgloop.o): Add pointer-set.h and output.h.
+
+2007-02-06  Seongbae Park <seongbae.park@gmail.com>
+
+       PR inline-asm/28686
+       * global.c (compute_regsets): New function.
+       (global_alloc): Refactored ELIMINABLE_REGSET
+       and NO_GLOBAL_ALLOC_REGS computation out.
+       (rest_of_handle_global_alloc): Call compute_regsets()
+       for non-optimizing case.
+
+2007-02-06  Richard Henderson  <rth@redhat.com>
+
+       * config/i386/constraints.md (Y2): Rename from Y.
+       (Yi): New constraint.
+       * config/i386/i386.md (movsi_1, movdi_2, pushdf_nointeger,
+       pushdf_integer, movdf_nointeger, movdf_integer, zero_extendsidi2_32,
+       zero_extendsidi2_rex64, truncxfdf2_mixed): Change Y constraints to Y2.
+       (extendsfdf2_mixed, extendsfdf2_sse, truncdfsf_fast_mixed,
+       truncdfsf_fast_sse, truncdfsf_mixed, fix_truncdfdi_sse,
+       fix_truncdfsi_sse, floatsidf2_mixed, floatsidf2_sse,
+       floatdidf2_mixed, floatdidf2_sse, absnegdf2_mixed,
+       absnegdf2_sse, sse_setccdf, fop_df_comm_mixed, fop_df_comm_sse,
+       fop_df_1_mixed, fop_df_1_sse): Change Y constraints to x.
+       * config/i386/mmx.md (mov<MMXMODEI>_internal_rex64,
+       mov<MMXMODEI>_internal, movv2sf_internal_rex64, movv2sf_internal,
+       vec_extractv2si_1): Change Y constraints to Y2.
+       * config/i386/sse.md (vec_setv4sf_0, vec_concatv2df, vec_dupv4si,
+       vec_dupv2di, sse2_concatv2si, vec_concatv4si_1, vec_concatv2di):
+       Change Y constraints to Y2.
+       (sse2_loadld): Change Y constraints to x.
+
+2007-02-06  Roger Sayle  <roger@eyesopen.com>
+
+       * config/rs6000/rs6000.md (popcount<mode>2): Rewrite.
+       (parity<mode>2): New define_expand using rs6000_emit_parity.
+       * config/rs6000/rs6000.c (rs6000_emit_popcount,
+       rs6000_emit_parity): New functions.
+       * config/rs6000/rs6000-protos.h (rs6000_emit_popcount,
+       rs6000_emit_parity): Prototype here.
+
+2007-02-06  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (simple_move_operand): Reject CONST.
+       (resolve_clobber): Call validate_change rather than directly
+       assigning to XEXP (pat, 0).
+
+2006-02-06  Paolo Bonzini  <bonzini@gnu.org>
+
+       * Makefile.in (tree-ssa-loop-ivopts.o): Add pointer-set.h dependency.
+       (tree-ssa-reassoc.o): Add pointer-set.h dependency.
+       (tree-cfg.o): Remove hashtab.h dependency.
+
+       * tree-ssa-loop-ivopts.c: Include pointer-set.h.
+       (struct ivopts_data): Change niters to pointer_map_t.
+       (struct nfe_cache_elt, nfe_hash, nfe_eq): Delete.
+       (niter_for_exit): Create pointer_map on demand.  Change for
+       pointer_map API.
+       (tree_ssa_iv_optimize_init): Initialize data->niters to NULL.
+       (free_loop_data): Destroy data->niters if created and reset field.
+       (tree_ssa_iv_optimize_finalize): Don't delete data->niters here.
+       (tree_ssa_iv_optimize_loop): Check for presence of stale data.
+
+       * tree-ssa-reassoc.c: Include pointer-set.h.
+       (bb_rank): Change to long *.
+       (operand_rank): Change to pointer_map_t.
+       (find_operand_rank): Return long, -1 if not found.  Declare as inline.
+       (insert_operand_rank): Accept long.
+       (operand_entry_hash, operand_entry_eq): Remove.
+       (get_rank): Return long.  Adjust for changes above.
+       (init_reassoc): Change rank type to long.  Adjust creation of bb_rank
+       and operand_rank.
+       (fini_reassoc): Delete operand_rank with pointer_map_destroy.
+
+       * tree-ssa-structalias.c (vi_for_tree): Change to pointer_map.
+       (struct tree_vi, tree_vi_t, tree_vi_hash, tree_vi_eq): Delete.
+       (insert_vi_for_tree): Rewrite for pointer_map API.  Assert argument
+       is not NULL.
+       (lookup_vi_for_tree): Rewrite for pointer_map API.  Return varinfo_t
+       directly since it cannot be NULL.
+       (get_vi_for_tree): Rewrite for pointer_map API.
+       (find_what_p_points_to): Adjust for change to lookup_vi_for_tree.
+       (init_alias_vars): Create vi_for_tree as pointer_map.
+       (delete_points_to_sets): Delete vi_for_tree using pointer_map_destroy.
+
+       * tree-cfg.c: Don't include hashtab.h.
+       (edge_to_cases): Declare as pointer_map.
+       (struct edge_to_cases_elt, edge_to_cases_hash, edge_to_cases_eq):
+       Delete.
+       (edge_to_cases_cleanup): Rewrite as pointer_map_traverse callback.
+       (start_recording_case_labels): Create edge_to_cases as pointer_map.
+       (end_recoding_case_labels): Cleanup edge_to_cases manually before
+       destroying it.
+       (record_switch_edge): Delete.
+       (get_cases_for_edge): Adjust for pointer_map API, inline
+       record_switch_edge (rewritten for new API), remove goto.
+
+2006-02-06  Paolo Bonzini  <bonzini@gnu.org>
+
+       * Makefile.in (tree-nested.o): Add pointer-set.h dependency.
+       * tree-nested.c: Include pointer-set.h.
+       (var_map_elt, var_map_eq, var_map_hash): Delete.
+       (struct nesting_info): Remove GTY marker.  Change the two htab_t's
+       to pointer_map_t's.
+       (nesting_info_bitmap_obstack): New.
+       (lookup_field_for_decl): Adjust for pointer_map API.
+       (lookup_tramp_for_decl): Adjust for pointer_map API.
+       (get_nonlocal_debug_decl): Adjust for pointer_map API.
+       (get_local_debug_decl): Adjust for pointer_map API.
+       (convert_nl_goto_reference): Adjust for pointer_map API.
+       (convert_nl_goto_receiver): Adjust for pointer_map API.
+       (create_nesting_tree): Create outside GGC space.  Create bitmap on
+       the new obstack.  Create field_map and var_map as pointer_maps.
+       (free_nesting_tree): Adjust for changes to create_nesting_tree.
+       (root): Delete.
+       (lower_nested_functions): Move root here, no need to NULL it.
+       Initialize and release the obstack.
+
+2007-02-06  Paolo Bonzini  <bonzini@gnu.org>
+
+       * tree.c (tree_int_map_hash, tree_int_map_eq, tree_int_map_marked_p):
+       Remove prototypes and make them non-static.
+       (struct tree_int_map): Remove.
+       * tree.h (struct tree_int_map): Move here, turning TO into an
+       unsigned int.
+       (tree_int_map_hash, tree_int_map_eq, tree_int_map_marked_p): Declare.
+
+       * tree.h (TREE_COMPLEXITY): Remove.
+       (struct tree_exp): Remove complexity field.
+       * tree.c (build1_stat): Don't set it.
+
+2007-02-06  Dorit Nuzman  <dorit@il.ibm.com>
+           Victor Kaplansky  <victork@il.ibm.com>
+
+       * tree-vectorizer.c (vect_is_simple_use): Support induction.
+       (vect_is_simple_reduction): Support reduction with induction as
+       one of the operands.
+       (vect_is_simple_iv_evolution): Fix formatting.
+       * tree-vect-analyze.c (vect_mark_stmts_to_be_vectorized): Fix
+       formatting.  Don't mark induction phis for vectorization.
+       (vect_analyze_scalar_cycles): Analyze all inductions, then reductions.
+       * tree-vect-transform.c (get_initial_def_for_induction): New function.
+       (vect_get_vec_def_for_operand): Support induction.
+       (vect_get_vec_def_for_stmt_copy): Fix formatting and add check for
+       induction case.
+       (vectorizable_reduction): Support reduction with induction as one of
+       the operands.
+       (vectorizable_type_demotion): Use def-type of stmt argument rather
+       than dummy def-type.
+
+       * tree-ssa-loop.c (gate_scev_const_prop): Return the value of
+       flag_tree_scev_cprop.
+       * common.opt (tree-scev-cprop): New flag.
+
+       * tree-vect-transform.c (vect_create_destination_var): Use 'kind' in
+       call to vect_get_new_vect_var.
+
+2007-02-06  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-vect-patterns.c (vect_recog_widen_mult_pattern): Check that
+       vectype is not NULL.
+       (vect_pattern_recog_1): Likewise.
+
+2007-02-05  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * fold-const.c (negate_expr_p): Handle CONJ_EXPR.
+       (fold_negate_expr): Likewise.
+
+2007-02-05  Alexandre Oliva  <aoliva@redhat.com>
+
+       PR debug/30189
+       * dwarf2out.c (modified_type_die): Follow DECL_ORIGINAL_TYPE
+       even if cv-qualification is the same.
+
+2007-02-05  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/rs6000/darwin-tramp.asm (__trampoline_setup): Call
+       __enable_execute_stack on completion.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/athlon.md (athlon_fldxf_k8, athlon_fld_k8,
+       athlon_fstxf_k8, athlon_fst_k8, athlon_fist, athlon_fmov,
+       athlon_fadd_load, athlon_fadd_load_k8, athlon_fadd, athlon_fmul,
+       athlon_fmul_load, athlon_fmul_load_k8, athlon_fsgn,
+       athlon_fdiv_load, athlon_fdiv_load_k8, athlon_fdiv_k8,
+       athlon_fpspc_load, athlon_fpspc, athlon_fcmov_load,
+       athlon_fcmov_load_k8, athlon_fcmov_k8, athlon_fcomi_load_k8,
+       athlon_fcomi, athlon_fcom_load_k8, athlon_fcom): Added amdfam10.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/i386.md (x86_sahf_1, cmpfp_i_mixed, cmpfp_i_sse,
+       cmpfp_i_i387, cmpfp_iu_mixed, cmpfp_iu_sse, cmpfp_iu_387,
+       swapsi, swaphi_1, swapqi_1, swapdi_rex64, fix_truncsfdi_sse,
+       fix_truncdfdi_sse, fix_truncsfsi_sse, fix_truncdfsi_sse,
+       x86_fldcw_1, floatsisf2_mixed, floatsisf2_sse, floatdisf2_mixed,
+       floatdisf2_sse, floatsidf2_mixed, floatsidf2_sse,
+       floatdidf2_mixed, floatdidf2_sse, muldi3_1_rex64, mulsi3_1,
+       mulsi3_1_zext, mulhi3_1, mulqi3_1, umulqihi3_1, mulqihi3_insn,
+       umulditi3_insn, umulsidi3_insn, mulditi3_insn, mulsidi3_insn,
+       umuldi3_highpart_rex64, umulsi3_highpart_insn,
+       umulsi3_highpart_zext, smuldi3_highpart_rex64,
+       smulsi3_highpart_insn, smulsi3_highpart_zext, x86_64_shld,
+       x86_shld_1, x86_64_shrd, sqrtsf2_mixed, sqrtsf2_sse,
+       sqrtsf2_i387, sqrtdf2_mixed, sqrtdf2_sse, sqrtdf2_i387,
+       sqrtextendsfdf2_i387, sqrtxf2, sqrtextendsfxf2_i387,
+       sqrtextenddfxf2_i387): Added amdfam10_decode.
+
+       * config/i386/athlon.md (athlon_idirect_amdfam10,
+       athlon_ivector_amdfam10, athlon_idirect_load_amdfam10,
+       athlon_ivector_load_amdfam10, athlon_idirect_both_amdfam10,
+       athlon_ivector_both_amdfam10, athlon_idirect_store_amdfam10,
+       athlon_ivector_store_amdfam10): New define_insn_reservation.
+       (athlon_idirect_loadmov, athlon_idirect_movstore): Added
+       amdfam10.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/athlon.md (athlon_call_amdfam10,
+       athlon_pop_amdfam10, athlon_lea_amdfam10): New
+       define_insn_reservation.
+       (athlon_branch, athlon_push, athlon_leave_k8, athlon_imul_k8,
+       athlon_imul_k8_DI, athlon_imul_mem_k8, athlon_imul_mem_k8_DI,
+       athlon_idiv, athlon_idiv_mem, athlon_str): Added amdfam10.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/athlon.md (athlon_sseld_amdfam10,
+       athlon_mmxld_amdfam10, athlon_ssest_amdfam10,
+       athlon_mmxssest_short_amdfam10): New define_insn_reservation.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/athlon.md (athlon_sseins_amdfam10): New
+       define_insn_reservation.
+       * config/i386/i386.md (sseins): Added sseins to define_attr type
+       and define_attr unit.
+       * config/i386/sse.md: Set type attribute to sseins for insertq
+       and insertqi.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/athlon.md (sselog_load_amdfam10, sselog_amdfam10,
+       ssecmpvector_load_amdfam10, ssecmpvector_amdfam10,
+       ssecomi_load_amdfam10, ssecomi_amdfam10,
+       sseaddvector_load_amdfam10, sseaddvector_amdfam10): New
+       define_insn_reservation.
+       (ssecmp_load_k8, ssecmp, sseadd_load_k8, seadd): Added amdfam10.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/athlon.md (cvtss2sd_load_amdfam10,
+       cvtss2sd_amdfam10, cvtps2pd_load_amdfam10, cvtps2pd_amdfam10,
+       cvtsi2sd_load_amdfam10, cvtsi2ss_load_amdfam10,
+       cvtsi2sd_amdfam10, cvtsi2ss_amdfam10, cvtsd2ss_load_amdfam10,
+       cvtsd2ss_amdfam10, cvtpd2ps_load_amdfam10, cvtpd2ps_amdfam10,
+       cvtsX2si_load_amdfam10, cvtsX2si_amdfam10): New
+       define_insn_reservation.
+
+       * config/i386/sse.md (cvtsi2ss, cvtsi2ssq, cvtss2si,
+       cvtss2siq, cvttss2si, cvttss2siq, cvtsi2sd, cvtsi2sdq,
+       cvtsd2si, cvtsd2siq, cvttsd2si, cvttsd2siq,
+       cvtpd2dq, cvttpd2dq, cvtsd2ss, cvtss2sd,
+       cvtpd2ps, cvtps2pd): Added amdfam10_decode attribute.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/athlon.md (athlon_ssedivvector_amdfam10,
+       athlon_ssedivvector_load_amdfam10, athlon_ssemulvector_amdfam10,
+       athlon_ssemulvector_load_amdfam10): New define_insn_reservation.
+       (athlon_ssediv, athlon_ssediv_load_k8, athlon_ssemul,
+       athlon_ssemul_load_k8): Added amdfam10.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/i386.h (TARGET_SSE_UNALIGNED_MOVE_OPTIMAL): New macro.
+       (x86_sse_unaligned_move_optimal): New variable.
+
+       * config/i386/i386.c (x86_sse_unaligned_move_optimal): Enable for
+       m_AMDFAM10.
+       (ix86_expand_vector_move_misalign): Add code to generate movupd/movups
+       for unaligned vector SSE double/single precision loads for AMDFAM10.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/i386.h (TARGET_AMDFAM10): New macro.
+       (TARGET_CPU_CPP_BUILTINS): Add code for amdfam10.
+       Define TARGET_CPU_DEFAULT_amdfam10.
+       (TARGET_CPU_DEFAULT_NAMES): Add amdfam10.
+       (processor_type): Add PROCESSOR_AMDFAM10.
+
+       * config/i386/i386.md: Add amdfam10 as a new cpu attribute to match
+       processor_type in config/i386/i386.h.
+       Enable imul peepholes for TARGET_AMDFAM10.
+
+       * config.gcc: Add support for --with-cpu option for amdfam10.
+
+       * config/i386/i386.c (amdfam10_cost): New variable.
+       (m_AMDFAM10): New macro.
+       (m_ATHLON_K8_AMDFAM10): New macro.
+       (x86_use_leave, x86_push_memory, x86_movx, x86_unroll_strlen,
+       x86_cmove, x86_3dnow_a, x86_deep_branch, x86_use_simode_fiop,
+       x86_promote_QImode, x86_integer_DFmode_moves,
+       x86_partial_reg_dependency, x86_memory_mismatch_stall,
+       x86_accumulate_outgoing_args, x86_arch_always_fancy_math_387,
+       x86_sse_partial_reg_dependency, x86_sse_typeless_stores,
+       x86_use_ffreep, x86_use_incdec, x86_four_jump_limit,
+       x86_schedule, x86_use_bt, x86_cmpxchg16b, x86_pad_returns):
+       Enable/disable for amdfam10.
+       (override_options): Add amdfam10_cost to processor_target_table.
+       Set up PROCESSOR_AMDFAM10 for amdfam10 entry in
+       processor_alias_table.
+       (ix86_issue_rate): Add PROCESSOR_AMDFAM10.
+       (ix86_adjust_cost): Add code for amdfam10.
+
+2007-02-05  Harsha Jagasia  <harsha.jagasia@amd.com>
+
+       * config/i386/i386.opt: Add new Advanced Bit Manipulation (-mabm)
+       instruction set feature flag. Add new (-mpopcnt) flag for popcnt
+       instruction. Add new SSE4A (-msse4a) instruction set feature flag.
+       * config/i386/i386.h: Add builtin definition for SSE4A.
+       * config/i386/i386.md: Add support for ABM instructions
+       (popcnt and lzcnt).
+       * config/i386/sse.md: Add support for SSE4A instructions
+       (movntss, movntsd, extrq, insertq).
+       * config/i386/i386.c: Add support for ABM and SSE4A builtins.
+       Add -march=amdfam10 flag.
+       * config/i386/ammintrin.h: Add support for SSE4A intrinsics.
+       * doc/invoke.texi: Add documentation on flags for sse4a, abm, popcnt
+       and amdfam10.
+       * doc/extend.texi: Add documentation for SSE4A builtins.
+
+2007-02-05  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (constantpool_mem_p): Skip over SUBREGs.
+
+2007-02-05  Richard Guenther  <rguenther@suse.de>
+
+       * tree-vectorizer.h (vectorizable_function): Add argument type
+       argument, change return type.
+       * tree-vect-patterns.c (vect_recog_pow_pattern): Adjust caller.
+       * tree-vect-transform.c (vectorizable_function): Handle extra
+       argument, return vectorized function decl.
+       (build_vectorized_function_call): Remove.
+       (vectorizable_call): Handle calls with result and argument types
+       differing.  Handle loop vectorization factor correctly.
+       * targhooks.c (default_builtin_vectorized_function): Adjust for
+       extra argument.
+       * targhooks.h (default_builtin_vectorized_function): Likewise.
+       * target.h (builtin_vectorized_function): Add argument type
+       argument.
+       * config/i386/i386.c (ix86_builtin_vectorized_function): Handle
+       extra argument, allow vectorizing of lrintf.
+       * doc/tm.texi (TARGET_VECTORIZE_BUILTIN_VECTORIZED_FUNCTION): Adjust
+       documentation of target hook.
+
+2007-02-05  Hans-Peter Nilsson  <hp@axis.com>
+
+       PR target/30665
+       * config/cris/cris.md ("*andsi_movu", "*andsi_clear", "*andhi_movu")
+       ("*andhi_clear", andu (casesi+45)): For size-changed operand where
+       memory is allowed, require !side_effects_p, not just !MEM_VOLATILE_P.
+
+2007-02-05  Roger Sayle  <roger@eyesopen.com>
+
+       * fold-const.c (fold_unary) <REAL_PART>: Test for availability of
+       BUILT_IN_COS before simplifying REAL_PART(CEXPI)) to COS.
+       <IMAG_PART>: Likewise, check for availability of BUILT_IN_SIN.
+       * builtins.c (fold_builtin_sincos): Check for TARGET_C99_FUNCTIONS
+       before canonicalizing sincos to cexpi.
+       (fold_builtin_cexp): Likewise, for canonicalizing cexp to cexpi.
+
+2007-02-05  Roger Sayle  <roger@eyesopen.com>
+
+       * config/alpha/alpha.c (alpha_add_builtins): New Helper function.
+       Set TREE_READONLY and TREE_NOTHROW directly, not via attributes.
+       (alpha_init_builtins): Use alpha_add_builtins to process tables.
+
+2007-02-05  Roger Sayle  <roger@eyesopen.com>
+
+       * mips-tfile.c (initialize_init_file): Correct endianness test.
+
+2007-02-05  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.md (pushdi-1, pushdi, movsi+1): Don't use
+       the 'y' constraint.
+
+2007-02-05  Richard Sandiford  <richard@codesourcery.com>
+
+       * dwarf2out.c (dwarf2out_frame_debug_expr): Record the register
+       saves in a PARALLEL before the register assignments.
+
+2007-02-05  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/tm.texi (DWARF_ALT_FRAME_RETURN_COLUMN): Do not require
+       DWARF_FRAME_RETURN_COLUMN to be a general register.
+       * dwarf2out.c (init_return_column_size): New function, split from...
+       (expand_builtin_init_dwarf_reg_sizes): ...here.  Allow both
+       DWARF_FRAME_RETURN_COLUMN and DWARF_ALT_FRAME_RETURN_COLUMN
+       to be nongeneral registers.
+       * config/m68k/m68k.h (DWARF_FRAME_REGNUM): Only map FP and
+       integer registers.
+       (DWARF_FRAME_REGISTERS, DWARF_FRAME_RETURN_COLUMN): Define.
+       (DWARF_ALT_FRAME_RETURN_COLUMN): Define.
+
+2007-02-04  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * cfgcleanup.c (try_optimize_cfg): Avoid removing ENTRY_BLOCK_PTR.
+
+2007-02-04  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * cfgloopmanip.c (loop_delete_branch_edge): Removed.
+       (remove_path): Use can_remove_branch_p and remove_branch instead
+       of loop_delete_branch_edge.
+       * tree-ssa-loop-manip.c (scale_dominated_blocks_in_loop): New function.
+       (tree_transform_and_unroll_loop): Remove dead branches immediately.
+       Update profile using scale_dominated_blocks_in_loop.
+       * cfghooks.c (can_remove_branch_p, remove_branch): New functions.
+       * cfghooks.h (struct cfg_hooks): Add can_remove_branch_p.
+       (can_remove_branch_p, remove_branch): Declare.
+       * tree-cfg.c (tree_can_remove_branch_p): New function.
+       (tree_cfg_hooks): Add tree_can_remove_branch_p.
+       * cfgrtl.c (rtl_can_remove_branch_p): New function.
+       (rtl_cfg_hooks, cfg_layout_rtl_cfg_hook): Add rtl_can_remove_branch_p.
+
+2007-02-05  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/30696
+       * ipa-inline.c (cgraph_clone_inlined_nodes): When there are unanalyzed
+       nodes in cgraph, don't remove offline copy of the function.
+
+2007-02-04  Jan Hubicka  <jh@suse.cz>
+
+       * tree-sra.c (sra_walk_expr): Add linebreaks. BITFIELD_REFs into
+       vectors might cause maybe_lookup_element_for_expr to be called
+       on non-sra-candidate.
+
+2007-02-04  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/bfin/bfin-modes.def, config/bfin/bfin.c,
+       config/bfin/bfin.md, config/bfin/predicates.md: Follow
+       spelling conventions.
+
+2007-02-04  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/30636
+       * fold-const.c (try_move_mult_to_index): Make sure to not
+       overflow one dimension of a multi-dimensional array access.
+
+2007-02-04  Jan Hubicka  <jh@suse.cz>
+
+       * passes.c (init_optimization_passes): Reindent.
+
+2007-02-04  Jan Hubicka  <jh@suse.cz>
+           Eric Botcazou  <ebotcazou@adacore.com>
+
+       * tree-optimize.c (has_abnormal_outgoing_edge_p): Move to...
+       (execute_fixup_cfg): Break out the abnormal goto code.
+       * tree-inline.c (has_abnormal_outgoing_edge_p): ...here.
+       (make_nonlocal_label_edges): Move here from execute_fixup_cfg.
+       (optimize_inline_calls): Call make_nonlocal_label_edges.
+
+2007-02-04  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Return
+       true when something was changed.
+       (rename_ssa_copies): When something was changed, do
+       TODO_remove_unused_locals.
+       * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_value):
+       add TODO_remove_unused_locals when instruction was removed.
+
+2007-02-04  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-inline.c (try_inline): Improve debug output; work on already
+       inline edges too.
+       (cgraph_decide_inlining_incrementally): Indent; improve debug output;
+       call try_inline for already inlined edges too when flattening;
+       inline also functions that make callee growth but overall unit size
+       reduce.
+
+2007-02-04  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m32c/bitops.md, config/m32c/jump.md,
+       config/m32c/m32c.c, config/m32c/m32c.h, config/m32r/m32r.c,
+       config/m32r/m32r.h, config/m32r/m32r.md,
+       config/m32r/predicates.md, config/m68hc11/larith.asm,
+       config/m68hc11/m68hc11.c, config/m68hc11/m68hc11.h,
+       config/m68k/m68k.h, config/mcore/mcore.md, config/mips/4k.md,
+       config/mips/mips-protos.h, config/mips/mips.c,
+       config/mips/mips.h, config/mips/mips.md, config/mips/mips16.S,
+       config/mn10300/mn10300.h, config/mn10300/predicates.md,
+       config/mt/mt.c, config/mt/mt.h, config/mt/mt.md: Follow
+       spelling conventions.
+
+       * config/v850/v850.c, config/v850/v850.h, config/v850/v850.md:
+       Follow spelling conventions.
+
+2007-02-03  Douglas Gregor  <doug.gregor@gmail.com>
+
+       * c-opts.c (c_common_post_options): If C++0x mode is enabled, don't
+       warn about C++0x compatibility.
+
+2007-02-04  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/h8300/h8300.c, config/h8300/h8300.h,
+       config/h8300/h8300.md: Follow spelling conventions.
+
+2007-02-03  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR middle-end/30667
+       * combine.c (try_combine): Do not substitute source operand
+       with constants wider than 2 * HOST_BITS_PER_WIDE_INT.
+
+2007-02-03  Jan Hubicka  <jh@suse.cz>
+
+       PR gcov-profile/30650
+       * value-prof.c (stringop_block_profile): Fix handling of size counter;
+       do not divide by zero for never executed counters.
+       (tree_find_values_to_profile): Fix counters.
+       * gcov-ui.h (GCOV_COUNTER_AVERAGE, GCOV_COUNTER_IOR): Fix comments.
+
+2007-02-03  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (simple_move_operand): New static function,
+       broken out of simple_move.  Reject LABEL_REF, SYMBOL_REF, and HIGH
+       operands.
+       (simple_move): Call simple_move_operand.
+       (find_decomposable_subregs): Add special handling of MEMs.
+       (can_decompose_p): Rename from cannot_decompose_p.  Reverse
+       meaning of return value.  If we see a hard register, test whether
+       it can store a word_mode value.  Change all callers.
+
+2007-02-03  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.md (addvdi3, addvsi3, subvdi3, subvsi3, negvdi2, negvsi2): New
+       ftrapv insns and expanders.
+       (subdi3): Change define_expand operand 1 to arith11_operand, and
+       operand 2 to reg_or_0_operand.  Change constraints of 64-bit insn
+       pattern to handle reg_or_0 operands.  Revise 32-bit insn pattern to
+       handle 11-bit constants and reg_or_0 operands in operands 1 and 2,
+       respectively.
+
+       PR middle-end/30174
+       * varasm.c (notice_global_symbol): Treat global objects as weak when
+       flag_shlib is true.
+
+2007-02-03  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * emit-rtl.c (dconstpi): Delete.
+       (dconstsqrt2): New.
+       (init_emit_once): Delete dconstpi and init dconstsqrt2.
+       * real.h (dconstpi): Delete.
+       (dconstsqrt2): New.
+       * builtins.c (fold_builtin_cabs): Use dconstsqrt2.
+       (fold_builtin_hypot): Likewise.
+
+2007-02-03  Tom Tromey  <tromey@redhat.com>
+
+       PR driver/30246
+       * gcc.c (cpp_unique_options): Any of -ggdb3, -gstabs3,
+       -gcoff3, -gxcoff3, -gvms3 implies -dD.
+
+2007-02-03  Kazu Hirata  <kazu@codesourcery.com>
+
+       * c-decl.c, config/avr/avr.c, config/avr/avr.h,
+       config/m68k/m68k.c, config/m68k/netbsd-elf.h,
+       config/mn10300/mn10300.c, config/pdp11/pdp11.h,
+       config/rs6000/cell.md, config/rs6000/darwin.h,
+       config/sh/sh.md, config/sh/sh4-300.md, config/spu/spu.c,
+       config/spu/spu.md, cselib.c, expr.c, haifa-sched.c, hwint.h,
+       jump.c, reload.c, sched-deps.c, sched-int.h, tree-inline.c,
+       tree-profile.c, tree-ssa-live.h, tree-vrp.c: Fix comment
+       typos.  Follow spelling conventions.
+       * doc/invoke.texi: Follow spelling conventions.
+
+2007-02-03  Roger Sayle  <roger@eyesopen.com>
+
+       * simplify-rtx.c (simplify_relational_operation_1): Implement some
+       canonicalization transformations that attempt to simplify integer
+       constant comparisons to become comparisons against zero.
+
+2007-02-03  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.c (fold_builtin_cabs): Fold cabs(x+xi) into
+       fabs(x)*sqrt(2).
+       * fold-const.c (fold_binary): Fix comment typos.  Fold complex
+       (x,0)-(0,y) into (x,-y).  Likewise (0,y)-(x,0) into (-x,y).
+
+2007-02-02  Mike Stump  <mrs@apple.com>
+
+       * config/darwin9.h (DARWIN_LINKER_GENERATES_ISLANDS): Add.
+       * config/rs6000/rs6000.c (DARWIN_GENERATE_ISLANDS): Add.
+       (output_call): Use DARWIN_GENERATE_ISLANDS to decide when to
+       generate a branch island.
+
+2007-02-02  Bob Wilson  <bob.wilson@acm.org>
+
+       * config/xtensa/xtensa.c (smalloffset_mem_p): Use BASE_REG_P.
+       (xtensa_legitimate_address_p): New.
+       (xtensa_legitimize_address): New.
+       (xtensa_output_addr_const_extra): New.
+       * config/xtensa/xtensa.h (REG_OK_STRICT_FLAG): Define.
+       (BASE_REG_P): New.
+       (REG_OK_FOR_BASE_P): Use BASE_REG_P.
+       (GO_IF_LEGITIMATE_ADDRESS): Move code to xtensa_legitimate_address_p.
+       (LEGITIMIZE_ADDRESS): Move code to xtensa_legitimize_address.
+       (OUTPUT_ADDR_CONST_EXTRA): Move code to xtensa_output_addr_const_extra.
+       * config/xtensa/xtensa-protos.h (xtensa_legitimate_address_p): New.
+       (xtensa_legitimize_address): New.
+       (xtensa_output_addr_const_extra): New.
+
+2007-02-02  Steve Ellcey  <sje@cup.hp.com>
+
+       * config/ia64/ia64.c (ia64_print_operand): Fix compare strings.
+
+2007-02-02  Ian Lance Taylor  <iant@google.com>
+
+       * expmed.c (expand_divmod): Add comment.
+
+2007-02-02  Kazu Hirata  <kazu@codesourcery.com>
+
+       * emit-rtl.c (renumber_insns): Remove.
+       * flags.h: Remove the extern for flag_renumber_insns.
+       * rtl.h: Remove the prototype for renumber_insns.
+       * toplev.c (flag_renumber_insns): Remove.
+
+2007-02-02  Hui-May Chang  <hm.chang@apple.com>
+
+       Revert for x86 darwin:
+       2005-06-19  Uros Bizjak  <uros@kss-loka.si>
+
+       * config/i386/i386.c (ix86_function_arg_regno_p): Put back the
+       code before the following patch under TARGET_MACHO.
+       (ix86_function_value_regno_p): Likewise.
+
+2007-02-02  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * fold-const.c (negate_expr_p, fold_negate_expr): Handle
+       COMPLEX_EXPR.
+
+2007-02-02  Maxim Kuvyrkov  <mkuvyrkov@ispras.ru>
+
+       PR target/29682
+       * config/ia64/ia64.c (ia64_speculate_insn): Restrict to memory
+       loads to general or fp registers.  Add comments.
+       * config/ia64/ia64.md (reg_pred_prefix): Add comment.
+
+2007-02-02  Paolo Bonzini  <bonzini@gnu.org>
+
+       * pointer-set.c (insert_aux): Only return insertion slot.
+       (pointer_set_insert): Adjust.
+       (pointer_set_traverse, struct pointer_map_t, pointer_map_create,
+       pointer_map_destroy, pointer_map_insert, pointer_map_contains,
+       pointer_map_traverse): New.
+       * pointer-set.h (pointer_set_traverse, struct pointer_map_t,
+       pointer_map_create,  pointer_map_destroy, pointer_map_insert,
+       pointer_map_contains, pointer_map_traverse): Declare.
+
+2007-02-02  Jakub Jelinek  <jakub@redhat.com>
+
+       PR middle-end/30473
+       * builtins.c (fold_builtin_sprintf): Do not attempt to optimize
+       sprintf (str, "%s").  Do not optimize sprintf (str, "nopercent", p++).
+
+2007-02-02  Maxim Kuvyrkov  <mkuvyrkov@ispras.ru>
+
+       * sched-int.h (ds_to_dk, dk_to_ds): Declare functions.
+
+       (struct _dep): New type.
+       (dep_t): New typedef.
+       (DEP_PRO, DEP_CON, DEP_KIND): New access macros.
+       (DEP_STATUS): New access macro.  The macro with the same name was
+       renamed to DEP_LINK_STATUS.
+       (dep_init): Declare function
+
+       (struct _dep_link): New type.
+       (dep_link_t): New typedef.
+       (DEP_LINK_NODE, DEP_LINK_NEXT, DEP_LINK_PREV_NEXTP): New access macros.
+       (DEP_LINK_DEP, DEP_LINK_PRO, DEP_LINK_CON, DEP_LINK_KIND): New macros.
+       (DEP_LINK_STATUS): New macro.
+       (debug_dep_links): New debug function.
+
+       (struct _deps_list): New type.
+       (deps_list_t): New typedef.
+       (DEPS_LIST_FIRST): New access macro.
+       (FOR_EACH_DEP_LINK): New cycle macro.
+       (create_deps_list, free_deps_list, delete_deps_list): Declare
+       functions.
+       (deps_list_empty_p, debug_deps_list, add_back_dep_to_deps_list): Ditto.
+       (find_link_by_pro_in_deps_list, find_link_by_con_in_deps_list): Ditto.
+       (copy_deps_list_change_con): Ditto.
+
+       (move_dep_link): Declare function.
+
+       (struct _dep_node): New type.
+       (dep_node_t): New typedef.
+       (DEP_NODE_BACK, DEP_NODE_DEP, DEP_NODE_FORW): New access macros.
+
+       (struct haifa_insn_data.back_deps): New field to hold backward
+       dependencies of the insn.
+       (struct haifa_insn_data.depend): Rename to forw_deps.  Change its type
+       to deps_list_t.
+       (struct haifa_insn_data.resolved_deps): Rename to resolved_back_deps.
+       Change its type to deps_list_t.
+       (INSN_BACK_DEPS): New access macro to use instead of LOG_LINKS.
+       (INSN_DEPEND): Rename to INSN_FORW_DEPS.
+       (RESOLVED_DEPS): Rename to INSN_RESOLVED_BACK_DEPS.
+
+       (INSN_COST): Move to haifa-sched.c.  Use insn_cost () instead.
+
+       (DEP_STATUS): Rename to DEP_LINK_STATUS.  Fix typo in the comment.
+
+       (add_forw_dep, delete_back_forw_dep, insn_cost): Update declaration
+       and all callers.
+       (dep_cost): Declare.
+
+       * sched-deps.c (CHECK): New macro to (en/dis)able sanity checks.
+       (ds_to_dk, dk_to_ds): New functions.
+
+       (init_dep_1): New static function.
+       (init_dep): New function.
+       (copy_dep): New static function.
+
+       (dep_link_consistent_p, attach_dep_link, add_to_deps_list): New static
+       functions.
+       (detach_dep_link): New static function.
+       (move_dep_link): New function.
+
+       (dep_links_consistent_p, dump_dep_links): New static functions.
+       (debug_dep_links): New debugging function.
+
+       (deps_obstack, dl_obstack, dn_obstack): New static variables.
+
+       (alloc_deps_list, init_deps_list): New static functions.
+       (create_deps_list): New function.
+       (clear_deps_list): New static function.
+       (free_deps_list, delete_deps_list, deps_list_empty_p): New functions.
+       (deps_list_consistent_p, dump_deps_list): New static functions.
+       (debug_deps_list): New function.
+       (add_back_dep_to_deps_list, find_link_by_pro_in_deps_list): New
+       functions.
+       (find_link_by_con_in_deps_list, copy_deps_list_change_con): Ditto.
+
+       (maybe_add_or_update_back_dep_1, add_or_update_back_dep_1): Update to
+       use new scheduler dependencies lists.
+       (add_back_dep, delete_all_dependences, fixup_sched_groups): Ditto.
+       (sched_analyze): Ditto.  Initialize dependencies lists.
+       (add_forw_dep, compute_forward_dependences): Update to use new
+       scheduler dependencies lists.
+
+       (init_dependency_caches): Init deps_obstack.
+       (free_dependency_caches): Free deps_obstack.
+
+       (adjust_add_sorted_back_dep, adjust_back_add_forw_dep): Update to use
+       new scheduler dependencies lists.
+       (delete_forw_dep, add_or_update_back_forw_dep): Ditto.
+       (add_back_forw_dep, delete_back_forw_dep): Ditto.
+
+       * sched-rgn.c (set_spec_fed, find_conditional_protection, is_pfree):
+       Update to use new scheduler dependencies lists.
+       (is_conditionally_protected, is_prisky, add_branch_dependences): Ditto.
+       (debug_dependencies): Ditto.
+       (schedule_region): Update comments.
+
+       * sched-ebb.c (earliest_block_with_similiar_load): Update to use new
+       scheduler dependencies lists.
+       (schedule_ebb): Update comments.
+
+       * rtl.def (DEPS_LIST): Remove.
+
+       * lists.c (unused_deps_list): Remove.
+       (free_list): Update assertions.
+
+       (alloc_DEPS_LIST, free_DEPS_LIST_list, free_DEPS_LIST_node): Remove.
+       (remove_free_DEPS_LIST_elem, copy_DEPS_LIST_list): Ditto.
+
+       * rtl.h (free_DEPS_LIST_list, alloc_DEPS_LIST): Remove declarations.
+       (remove_free_DEPS_LIST_elem, copy_DEPS_LIST_list): Ditto.
+
+       * haifa-sched.c (comments): Update.
+       (insn_cost1): Remove.  Inline the code into insn_cost ().
+       (insn_cost): Update to use new scheduler dependencies lists.  Move
+       processing of the dependency cost to dep_cost ().
+       (dep_cost): New function.  Use it instead of insn_cost () when
+       evaluating cost of the dependency.  Use compatible interface to
+       interact with the target.
+       (priority): Update to use new scheduler dependencies lists.
+       (rank_for_schedule): Ditto.  Optimize heuristic that prefers the insn
+       with greater number of insns that depend on the insn.
+       (schedule_insn): Update to use new scheduler dependencies lists.  Add
+       code to free backward dependencies lists.  Inline and optimize code
+       from resolve_dep () - see PR28071.
+       (ok_for_early_queue_removal): Update to use new scheduler dependencies
+       lists.  Update call to targetm.sched.is_costly_dependence hook.
+
+       (fix_inter_tick, try_ready, fix_tick_ready): Update to use new
+       scheduler dependencies lists.
+
+       (resolve_dep): Remove.  Move the logic to schedule_insn ().
+       (init_h_i_d): Initialize dependencies lists.
+
+       (process_insn_depend_be_in_spec): Rename to
+       process_insn_forw_deps_be_in_spec.  Update to use new scheduler
+       dependencies lists.
+       (add_to_speculative_block, create_check_block_twin, fix_recovery_deps):
+       Update to use new scheduler dependencies lists.
+       (clear_priorities, calc_priorities, add_jump_dependencies): Ditto.
+
+       * ddg.c (create_ddg_dependence, create_ddg_dep_no_link): Update to use
+       new scheduler dependencies lists.
+       (build_intra_loop_deps): Ditto.
+
+       * target.h (struct _dep): Declare to use in
+       gcc_target.sched.is_costly_dependence.
+       (struct gcc_target.sched.adjust_cost): Fix typo.
+       (struct gcc_target.sched.is_costly_dependence): Change signature to
+       use single dep_t parameter instead of an equivalent triad.
+       (struct gcc_target.sched.adjust_cost_2): Remove.
+
+       * target-def.h (TARGET_SCHED_ADJUST_COST_2): Remove.
+
+       * reg-notes.def (DEP_TRUE, DEP_OUTPUT, DEP_ANTI): Update comments.
+
+       * doc/tm.texi (TARGET_SCHED_IS_COSTLY_DEPENDENCE): Update
+       documentation.
+       (TARGET_SCHED_ADJUST_COST_2): Remove documentation.
+
+       * doc/rtl.texi (LOG_LINKS): Remove part about instruction scheduler.
+       (REG_DEP_TRUE): Document.
+
+       * config/ia64/ia64.c (ia64_adjust_cost_2): Rename to ia64_adjust_cost.
+       Change signature to correspond to the targetm.sched.adjust_cost hook.
+       Update use in TARGET_SCHED_ADJUST_COST_2.
+       (TARGET_SCHED_ADJUST_COST_2): Rename to TARGET_SCHED_ADJUST_COST.
+       (ia64_dependencies_evaluation_hook, ia64_dfa_new_cycle): Update to use
+       new scheduler dependencies lists.
+       (ia64_gen_check): Ditto.
+
+       * config/mips/mips.c (vr4130_swap_insns_p): Update to use new
+       scheduler dependencies lists.
+
+       * config/rs6000/rs6000.c (rs6000_is_costly_dependence): Change
+       signature to correspond to the targetm.sched.is_costly_dependence hook.
+       (is_costly_group): Update to use new scheduler dependencies lists.
+
+       * config/spu/spu.c (spu_sched_adjust_cost): Use insn_cost () function
+       instead of INSN_COST () macro.
+
+2007-02-01  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (resolve_clobber): Handle a subreg of a concatn.
+
+2007-02-01  Guy Martin  <gmsoft@gentoo.org>
+
+       * pa.md (tp_load): Correct mfctl instruction syntax.
+
+2007-02-01  Geoffrey Keating  <geoffk@apple.com>
+
+       * config/rs6000/rs6000.c (rs6000_stack_info): Correct
+       altivec_padding_size calculation on AIX.  Improve comment, add
+       assert to verify that it's right.
+
+       * config/rs6000/darwin.h (MD_UNWIND_SUPPORT): Don't define for
+       64-bit.
+
+2007-2-01  Seongbae Park  <seongbae.park@gmail.com>
+
+       PR inline-asm/28686
+       * global.c (global_alloc): Add mising initialization of
+       ELIMINABLE_REGSET.
+
+2007-02-01  Roger Sayle  <roger@eyesopen.com>
+
+       * alias.c (init_alias_analysis): Correct whitespace.
+       * bb-reorder.c (fix_edges_for_rarely_executed_code,
+       partition_hot_cold_basic_blocks): Likewise.
+       * builtins.c (expand_builtin_printf, expand_builtin_fprintf,
+       expand_builtin_sprintf, fold_builtin_carg, fold_builtin_sprintf,
+       maybe_emit_sprintf_chk_warning, fold_builtin_sprintf_chk,
+       fold_builtin_snprintf_chk, fold_builtin_printf,
+       fold_builtin_fprintf, do_mpfr_ckconv, do_mpfr_arg1, do_mpfr_arg2,
+       do_mpfr_arg3, do_mpfr_sincos): Likewise.
+       * cfgcleanup.c (cleanup_cfg): Likewise.
+       * cfgexpand.c (tree_expand_cfg): Likewise.
+       * fold-const.c (fold_binary) <RDIV_EXPR>: Likewise.
+       * function.c (get_next_funcdef_no): Likewise.
+       * gengtype.c (main): Likewise.
+       * genmodes.c (main): Likewise.
+       * gcse.c (bypass_conditional_jumps, print_ldst_list): Likewise.
+       * haifa-sched.c (schedule_block, extend_h_i_d): Likewise.
+       * ifcvt.c (noce_emit_move_insn): Likewise.
+       * modulo-sched.c (generate_prolog_epilog, sms_schedule_by_order):
+       Likewise.
+       * stor-layout.c (get_best_mode): Likewise.
+       * tree-ssa-loop-niter.c (get_val_for): Likewise.
+       * tree-ssa-structalias.c (get_varinfo, get_varinfo_fc,
+       scc_visit, do_ds_constraint, do_complex_constraint, label_visit,
+       perform_var_substitution, solve_graph): Likewise.
+       * tree-vrp.c (vrp_finalize): Likewise.
+
+2007-02-01  Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c (simplify_gen_subreg_concatn): If we ask for the
+       high part of a paradoxical subreg, return a constant zero.
+
+2007-02-01  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * toplev.c (lang_dependent_init): Call init_set_costs.
+       * loop-init.c (loop_optimizer_init): Do not call init_set_costs.
+
+2007-02-01  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/30656
+       * fold-const.c (fold_negate_expr): Allow negating a
+       constant if overflow does not change.
+
+2007-02-01  Ralf Wildenhues  <Ralf.Wildenhues@gmx.de>
+
+       * doc/c-tree.texi (Expression trees): Improve markup.
+       * doc/tm.texi (Register Classes, Addressing Modes)
+       (Floating Point): Fix spacing after abbreviations.  Fix some
+       typos.
+
+2007-02-01  Ben Elliston  <bje@au.ibm.com>
+
+       * doc/invoke.texi: Replace "bugfix" with "bug fix" throughout.
+       * doc/contrib.texi: Likewise.
+       * doc/install.texi: Likewise.
+
+2007-01-31  Richard Henderson  <rth@redhat.com>
+           Ian Lance Taylor  <iant@google.com>
+
+       * lower-subreg.c: New file.
+       * rtl.def (CONCATN): Define.
+       * passes.c (init_optimization_passes): Add pass_lower_subreg and
+       pass_lower_subreg2.
+       * emit-rtl.c (update_reg_offset): New static function, broken out
+       of gen_rtx_REG_offset.
+       (gen_rtx_REG_offset): Call update_reg_offset.
+       (gen_reg_rtx_offset): New function.
+       * regclass.c: Revert patch of 2006-03-05, restoring
+       reg_scan_update.
+       (clear_reg_info_regno): New function.
+       * dwarf2out.c (concatn_loc_descriptor): New static function.
+       (loc_descriptor): Handle CONCATN.
+       * common.opt (fsplit_wide_types): New option.
+       * opts.c (decode_options): Set flag_split_wide_types when
+       optimizing.
+       * timevar.def (TV_LOWER_SUBREG): Define.
+       * rtl.h (gen_reg_rtx_offset): Declare.
+       (reg_scan_update): Declare.
+       * regs.h (clear_reg_info_regno): Declare.
+       * tree-pass.h (pass_lower_subreg): Declare.
+       (pass_lower_subreg2): Declare.
+       * doc/invoke.texi (Option Summary): List -fno-split-wide-types.
+       (Optimize Options): Add -fsplit-wide-types to -O1 list.  Document
+       -fsplit-wide-types.
+       * doc/rtl.texi (Regs and Memory): Document concat and concatn.
+       * Makefile.in (OBJS-common): Add lower-subreg.o.
+       (lower-subreg.o): New target.
+
+2007-01-31  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/sh/sh.h (HAVE_SECONDARY_RELOADS): Remove.
+
+2007-01-31  Anatoly Sokolov <aesok@post.ru>
+
+       PR target/19087
+       * config/avr/avr.c (DWARF2_ADDR_SIZE): Define.
+
+2007-01-31  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR middle-end/29335
+       * builtins.c (fold_builtin_sqrt): Use MPFR for constant args.
+
+2007-01-31  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * cfgloop.h: Include vec-prim.h.
+       (enum li_flags): Remove LI_ONLY_OLD.
+       (loop_iterator): Changed.
+       (fel_next, fel_init): Iterate over loop tree.
+       (FOR_EACH_LOOP_BREAK): New macro.
+       * loop-unswitch.c (unswitch_loops): Do not pass LI_ONLY_OLD to
+       FOR_EACH_LOOP.
+       * tree-ssa-loop-unswitch.c (tree_ssa_unswitch_loops): Ditto.
+       * modulo-sched.c (sms_schedule): Ditto.
+       * tree-vectorizer.c (vectorize_loops): Ditto.
+       * doc/loop.texi: Update information on loop numbering and behavior of
+       FOR_EACH_LOOP wrto new loops.
+       * tree-scalar-evolution.c (compute_overall_effect_of_inner_loop,
+       add_to_evolution_1): Test nestedness of loops instead of comparing
+       their numbers.
+       * tree-chrec.c (chrec_fold_plus_poly_poly,
+       chrec_fold_multiply_poly_poly, chrec_evaluate,
+       hide_evolution_in_other_loops_than_loop, chrec_component_in_loop_num,
+       reset_evolution_in_loop): Ditto.
+       * Makefile.in (CFGLOOP_H): Add vecprim.h dependency.
+
+2007-01-31  Dirk Mueller  <dmueller@suse.de>
+
+       * c-common.c (warn_about_parentheses): Separate warning about
+       un-parenthized sequence of comparison operators from the one
+       which is supposed to warn about x <= y <= z.
+
+2007-01-31  Uros Bizjak  <ubizjak@gmail.com>
+
+       * optabs.h (enum optab_index): Add new OTI_isinf.
+       (isinf_optab): Define corresponding macro.
+       * optabs.c (init_optabs): Initialize isinf_optab.
+       * genopinit.c (optabs): Implement isinf_optab using isinf?f2
+       patterns.
+       * builtins.c (mathfn_built_in): Handle BUILT_IN_ISINF{,F,L}.
+       (expand_builtin_interclass_mathfn): Expand BUILT_IN_ISINF{,F,L}
+       using isinf_optab.
+       (expand_builtin): Expand BUILT_IN_ISINF{,F,L} using
+       expand_builtin_interclass_mathfn.
+       * reg_stack.c (subst_stack_regs_pat): Handle UNSPEC_FXAM.
+       * config/i386/i386.md (UNSPEC_FXAM): New constant.
+       (fxam<mode>2_i387): New insn pattern.
+       (isinf<mode>2) New expander to implement isinf, isinff and isinfl
+       built-in functions as x87 inline asm.
+
+2007-01-31  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/arm/unwind-arm.h (_sleb128_t, _uleb128_t): New.
+
+2007-01-30  Eric Christopher  <echristo@apple.com>
+
+       * config.gcc: Add geode.
+
+2007-01-31  Kazu Hirata  <kazu@codesourcery.com>
+
+       * cgraphunit.c, config/arm/arm.c, config/m68k/m68k.c,
+       ipa-inline.c, tree-profile.c, tree-ssa-live.c,
+       tree-ssa-math-opts.c, tree-ssanames.c, tree-vect-analyze.c,
+       value-prof.c: Fix comment typos.
+
+2007-01-30  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c++/24745
+       * doc/invoke.texi (Wpointer-arith): Document warning.
+
+2007-01-30  Janis Johnson  <janis187@us.ibm.com>
+
+       * doc/extend.texi (Decimal Floating Types): Remove decfloat.h from
+       the list of discrepancies from the draft TR.
+
+2007-01-30  Dirk Mueller  <dmueller@suse.de>
+
+       PR c++/30601
+       * doc/invoke.texi (-Wreturn-type): Update description to
+       match new behavior.
+
+2007-01-30  Richard Sandiford  <richard@codesourcery.com>
+
+       * cfgrtl.c (try_redirect_by_replacing_jump): Check only_sets_cc0_p.
+
+2007-01-30  Uros Bizjak  <ubizjak@gmail.com>
+
+       * builtins.c (expand_builtin_int_interclass_roundingfn): New function
+       to handle optabs that operate on floating point input argument and
+       output to integer output.
+       (expand_builtin_mathfn) [BUILT_IN_ILOGB]: Move from here ...
+       (expand_builtin_interclass_mathfn) [BUILT_IN_ILOGB]: ... to here.
+       (expand_builtin): Expand BUILT_IN_ILOGB{,F,L} using
+       expand_builtin_interclass_mathfn ().
+       * config/i386/i386.md (fxtractxf3_i387): Rename from *fxtractxf3_i387.
+       (ilogbsi2): Remove.
+       (ilogbxf2, ilogb<mode>2): New expanders to implement ilogb, ilogbf and
+       ilogbl built-in functions as x87 intrinsics.
+
+2007-01-30  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/27657
+       * dwarf2out.c (reference_to_unused): Query varpool if the
+       variable was output.
+
+2007-01-30  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/30313
+       * passes.c (execute_one_pass): Reset in_gimple_form to not
+       confuse non-unit-at-a-time mode.
+
+2007-01-29  Roger Sayle  <roger@eyesopen.com>
+           Richard Guenther  <rguenther@suse.de>
+
+       * fold-const.c (round_up): Make HIGH an unsigned HOST_WIDE_INT to
+       avoid undefined behaviour on overflow.  Use force_fit_type_double
+       to construct the constant with the specified TREE_OVERFLOW.
+
+2007-01-29  Janis Johnson  <janis187@us.ibm.com>
+
+       * config/dfp-bit.c: Add parameterized support for fp exceptions.
+       * config/dfp-bit.h: Ditto.
+
+2007-01-29  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * c-decl.c (pop_scope): Replace warnings with call to
+       warn_for_unused_label.
+       * c-common.h (warn_for_unused_label): Declare.
+       * c-common.c (warn_for_unused_label): Define.
+
+2007-01-29  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * tree-optimize.c (update_inlined_to_pointers): Delete unused
+       function.
+
+2007-01-29  Janis Johnson  <janis187@us.ibm.com>
+
+       * Makefile.in (USER_H): Remove decfloat.h.
+       * ginclude/decfloat.h: Delete, moving contents to ...
+       * ginclude/float.h: Add support for decimal floating point,
+       guarded by __STDC_WANT_DEC_FP__.
+
+2007-01-29  Mike Stump  <mrs@apple.com>
+
+       * doc/gccint.texi (Top): Rename Loop Representation to Loop
+       Analysis and Representation to resolve case insensitive conflict.
+       * doc/loop.texi (Loop Analysis and Representation): Likewise.
+
+2007-01-28  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree.h (struct tree_memory_tag): Add aliases member.
+       (MTAG_ALIASES): New macro.
+       * tree-ssa-alias.c (alias_bitmap_obstack): New variable.
+       (add_may_alias): Remove pointer-set. Update for may_aliases being
+       a bitmap.
+       (mark_aliases_call_clobbered): Update for may_aliases being a
+       bitmap.
+       (compute_tag_properties): Ditto.
+       (create_partition_for): Ditto.
+       (compute_memory_partitions): Ditto.
+       (dump_may_aliases_for): Ditto.
+       (is_aliased_with): Ditto.
+       (add_may_alias_for_new_tag): Ditto.
+       (rewrite_alias_set_for): Rewrite for may_aliases being a bitmap.
+       (compute_is_aliased): New function.
+       (compute_may_aliases): Call compute_is_aliased).
+       (init_alias_info): Initialize alias_bitmap_obstack.
+       (union_alias_set_into): New function.
+       (compute_flow_sensitive_aliasing): Use union_aliases_into.
+       (have_common_aliases_p): Rewrite to take two bitmaps and use
+       intersection.
+       (compute_flow_insensitive_aliasing): Stop using pointer-sets.
+       Update for bitmaps.
+       (finalize_ref_all_pointers): Update for add_may_alias changes.
+       (new_type_alias): Ditto.
+       * tree-flow-inline.h (may_aliases): Return a bitmap.
+       * tree-dfa.c (dump_variable): Check for MTAG_P'ness.
+       * tree-ssa.c (verify_flow_insensitive_alias_info): Update for
+       may_aliases being a bitmap.
+       * tree-flow.h (struct var_ann_d): Remove may_aliases member.
+       may_aliases now returns a bitmap.
+       * tree-ssa-structalias.c (merge_smts_into): Update for may_aliases
+       being a bitmap.
+       * tree-ssa-operands.c (add_virtual_operand): Update for
+       may_aliases being a bitmap.
+
+2007-01-29  Daniel Berlin  <dberlin@dberlin.org>
+
+       PR tree-optimization/30630
+       * tree-ssa-structalias.c (do_complex_constraint): Mark correct
+       variable as changed.
+
+2007-01-29  Simon Martin  <simartin@users.sourceforge.net>
+
+       PR c++/28266
+       * gimplify.c (gimplify_target_expr): Make sure that the TARGET_EXPR is
+       expanded only once even if an error occurs.
+
+2007-01-29  Ben Elliston  <bje@au.ibm.com>
+
+       * gcov-io.h (__gcov_indirect_call_profiler): Declare.
+       (__gcov_average_profiler): Likewise.
+       (__gcov_ior_profiler): Likewise.
+       (__gcov_merge_ior): Likewise.
+
+2007-01-28  Jan Hubicka  <jh@suse.cz>
+
+       * builtins.c (expand_builtin_memset): Fix typo in my last patch.
+       * value-prof.c (stringop_block_profile): Likewise.
+
+2007-01-28  Jan Hubicka  <jh@suse.cz>
+
+       * expr.c (emit_block_move_via_movmem, emit_block_move_via_libcall):
+       Add variant handling histograms; add wrapper.
+       (clear_storage_via_libcall): Export.
+       (emit_block_move_hints): Break out from ...; add histograms.
+       (emit_block_move): ... this one.
+       (clear_storage_hints): Break out from ...; add histograms.
+       (clear_storage): ... this one.
+       (set_storage_via_memset): Handle histogram.
+       * expr.h (emit_block_move_via_libcall, emit_block_move_hints): Declare.
+       (clear_storage_hints, clear_storage_via_libcall): Declare.
+       (set_storage_via_setmem): Update prototype.
+       * doc/md.texi (movmem, setmem): Document new arguments.
+
+       * value-prof.c (dump_histogram_value, tree_find_values_to_profile):
+       Add new histograms.
+       (stringop_block_profile): New global function.
+       (tree_stringops_values_to_profile): Profile block size and alignment.
+       * value-prof.h (enum hist_type): add HIST_TYPE_AVERAGE and
+       HIST_TYPE_IOR.
+       (struct profile_hooks): Add gen_average_profiler and gen_ior_profiler.
+       (stringop_block_profile): Declare.
+       * builtins.c: Include value-prof.h.
+       (expand_builtin_memcpy, expand_builtin_memset): Pass block profile.
+       * gcov-ui.h (GCOV_COUNTER_NAMES): Add new counter.
+       (GCOV_COUNTER_AVERAGE, GCOV_COUNTER_IOR): New constants.
+       (GCOV_COUNTERS, GCOV_LAST_VALUE_COUNTER): Update.
+       * profile.c (instrument_values): Add new counters.
+       * cfgexpand.c (expand_gimple_basic_block): Propagate histograms to
+       calls.
+       * tree-profile.c (tree_average_profiler_fn, tree_ior_profiler_fn): New.
+       (tree_init_edge_profiler): Build new profilers.
+       (tree_gen_average_profiler, tree_gen_ior_profiler): New.
+       (pass_tree_profile): Add dump.
+       (tree_profile_hooks): Update.
+       * Makefile.in (LIBGCOV): Add new constants.
+       * libgcov.c (__gcov_merge_ior, __gcov_average_profiler,
+       __gcov_ior_profiler): New.
+       * config/i386/i386.md (movmem/setmem expanders): Add new optional
+       arguments.
+
+2007-01-28  David Edelsohn  <edelsohn@gnu.org>
+
+       * doc/md.texi (Standard Pattern Names): Document blockage pattern.
+
+2007-01-28  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * tree-ssa-loop-unswitch.c: Include tree-inline.h.
+       (tree_unswitch_single_loop): Pass eni_size_weights to
+       tree_num_loop_insns.
+       * tree-ssa-loop-manip.c: Include tree-inline.h.
+       (can_unroll_loop_p): Pass eni_size_weights to
+       tree_num_loop_insns.
+       * tree-ssa-loop-ch.c (should_duplicate_loop_header_p):
+       Pass eni_size_weights to estimate_num_insns.
+       * tree.h (init_inline_once): Export.
+       * toplev.c (backend_init): Call init_inline_once.
+       * cgraphunit.c (cgraph_process_new_functions,
+       cgraph_analyze_function): Pass eni_inlining_weights to
+       estimate_num_insns.
+       * ipa-inline.c (compute_inline_parameters): Ditto.
+       * tree-ssa-loop-ivcanon.c (tree_num_loop_insns): Pass weights
+       to estimate_num_insns.
+       (try_unroll_loop_completely): Pass eni_size_weights to
+       tree_num_loop_insns.
+       * tree-eh.c (decide_copy_try_finally): Pass eni_size_weights
+       ot estimate_num_insns.
+       * tree-ssa-loop-prefetch.c: Include tree-inline.h.
+       (loop_prefetch_arrays): Pass eni_time_weights to tree_num_loop_insns.
+       * tree-inline.c (eni_inlining_weights, eni_size_weights,
+       eni_time_weights): New variables.
+       (init_inline_once): Initialize them.
+       (struct eni_data): Mew.
+       (estimate_num_insns_1, estimate_num_insns): Use weights.
+       * tree-inline.h (struct eni_weights_d): New.
+       (eni_inlining_weights, eni_size_weights, eni_time_weights): Declare.
+       (estimate_num_insns): Declaration changed.
+       * cfgloop.h (tree_num_loop_insns): Declaration changed.
+       * Makefile.in (tree-ssa-loop-unswitch.o, tree-ssa-loop-prefetch.o,
+       tree-ssa-loop-manip.o): Add TREE_INLINE_H dependency.
+
+2007-01-28  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * tree-data-ref.c (conflict_fn): Assert that the number of affine
+       relations in the conflict function is valid.
+
+2007-01-27  Ian Lance Taylor  <iant@google.com>
+
+       * common.opt: Add fstrict-overflow.
+       * opts.c (decode_options): Set flag_strict_overflow if -O2.
+       * flags.h (TYPE_OVERFLOW_WRAPS): Define.
+       (TYPE_OVERFLOW_UNDEFINED): Define.
+       (TYPE_OVERFLOW_TRAPS): Define.  This replaces TYPE_TRAP_SIGNED.
+       Replace all uses.
+       * tree.h (TYPE_TRAP_SIGNED): Don't define.
+       * fold-const.c (negate_expr_p): Use TYPE_OVERFLOW_UNDEFINED.
+       (fold_negate_expr): Likewise.
+       (make_range): Likewise.
+       (extract_muldiv_1): Likewise.
+       (maybe_canonicalize_comparison): Likewise.
+       (fold_comparison): Likewise.
+       (fold_binary): Likewise.
+       (tree_expr_nonnegative_p): Likewise.
+       (tree_expr_nonzero_p): Likewise.
+       * tree-vrp.c (compare_values): Likewise.
+       (extract_range_from_binary_expr): Likewise.
+       (extract_range_from_unary_expr): Likewise.
+       * tree-ssa-loop-niter.c (infer_loop_bounds_from_signedness):
+       Likewise.
+       (nowrap_type_p): Likewise.
+       * tree-scalar-evolution.c (simple_iv): Likewise.
+       * fold-const.c (negate_expr_p): Use TYPE_OVERFLOW_WRAPS.
+       (build_range_check): Likewise.
+       (extract_muldiv_1): Likewise.
+       (fold_comparison): Likewise.
+       * tree-vrp.c (vrp_int_const_binop): Likewise.
+       (extract_range_from_unary_expr): Likewise.
+       * convert.c (convert_to_integer): Likewise.
+       * fold-const.c (fold_negate_expr): Use TYPE_OVERFLOW_TRAPS.
+       (fold_comparison): Likewise.
+       (fold_binary): Likewise.
+       * optabs.c (optab_for_tree_code): Likewise.
+       * tree-vectorizer.c (vect_is_simple_reduction): Likewise.
+       * simplify-rtx.c (simplify_const_relational_operation): Check
+       flag_strict_overflow and flag_trapv.
+       (simplify_const_relational_operation): Likewise.
+       * doc/invoke.texi (Option Summary): Mention -fstrict-overflow.
+       (Optimize Options): Add -fstrict-overflow to -O2 list.  Document
+       -fstrict-overflow.
+
+2007-01-27  Roger Sayle  <roger@eyesopen.com>
+
+       * tree.c (tree_fold_gcd): Delete.
+       * tree.h (tree_fold_gcd): Remove prototype.
+       * tree-data-ref.c (tree_fold_divides_p): Don't use tree_fold_gcd to
+       test whether one constant integer is a multiple of another.  Instead
+       call int_const_binop with TRUNC_MOD_EXPR and test for a zero result.
+       * fold-const.c (multiple_of_p): We've determined both TOP and
+       BOTTOM are integer constants so we can call int_const_binop directly
+       instead of the more generic const_binop.
+
+2007-01-27  Roger Sayle  <roger@eyesopen.com>
+
+       * fold-const.c (size_binop): In the fast-paths for X+0, 0+X, X-0 and
+       1*X check that the constant hasn't overflowed, to preserve the
+       TREE_OVERFLOW bit.
+       (round_up): Provide an efficient implementation when rouding-up an
+       INTEGER_CST to a power-of-two.
+
+2007-01-28  Ralf Wildenhues  <Ralf.Wildenhues@gmx.de>
+
+       * doc/sourcebuild.texi: Add comma for clarity.
+       * doc/extend.texi: Fix some typos.
+       * doc/passes.texi: Likewise.
+       * doc/cppinternals.texi: Likewise.
+       * doc/c-tree.texi: Likewise.
+       * doc/tree-ssa.texi: Likewise.
+       * doc/install.texi: Likewise.
+
+2007-01-27  Jan Hubicka  <jh@suse.cz>
+
+       * tree-sra.c (sra_walk_function): Don't rely on aliases being build.
+       (pass_sra): Do not require alias information.
+       * passes.c (init_optimization_passes): Add SRA
+
+2007-01-27  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * tracer.c (rest_of_handle_tracer): We already cleaned
+       up the CFG in tracer() so don't do it here again.
+       * cfgcleanup.c (rest_of_handle_jump2): Don't repeat
+       cleanup_cfg here, either.  And don't call renumber_insns.
+
+       * cfgrtl.c (rtl_verify_flow_info_1): Don't verify that BB_END
+       and BB_HEAD are in the insn stream here.  Instead make sure
+       that BB_INSN is valid on all insns.  Also, do check here that
+       there are no pending branch predictions...
+       (rtl_verify_flow_info): ...instead of doing it here.  Checks
+       for BB_END and BB_HEAD moved from rtl_verify_flow_info_1 to
+       here.
+
+2007-01-26  Roger Sayle  <roger@eyesopen.com>
+
+       * config/i386/i386.c (ix86_swap_binary_operands_p): New helper
+       function to simplify/factorize operand order canonicalization.
+       (ix86_fixup_binary_operands): Reorganize using the above function.
+       (ix86_binary_operator_ok): Likewise.
+
+2007-01-27  Jakub Jelinek  <jakub@redhat.com>
+
+       * genattrtab.c (struct attr_value_list, insn_code_values): Move to
+       file scope from optimize_attrs.
+       (simplify_test_exp): If insn_code_values is not NULL, use it to speed
+       up search.
+       (optimize_attrs): Clear insn_code_values after freeing it.
+
+2007-01-26  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * tree-ssa-address.c (create_mem_ref): Remove ", bsi" from
+       a parts.base assignment.
+
+2007-01-26  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * tree-data-ref.c (dump_subscript): Use dump_conflict_function.
+       (compute_subscript_distance, initialize_data_dependence_relation,
+       finalize_ddr_dependent, analyze_ziv_subscript,
+       analyze_siv_subscript_cst_affine,
+       compute_overlap_steps_for_affine_univar,
+       compute_overlap_steps_for_affine_1_2, analyze_subscript_affine_affine,
+       analyze_siv_subscript, analyze_miv_subscript,
+       analyze_overlapping_iterations, subscript_dependence_tester_1,
+       compute_self_dependence, free_dependence_relation): Work
+       with affine_fn instead of chrecs.
+       (dump_affine_function, dump_conflict_function, affine_function_equal_p,
+       common_affine_function, affine_function_base,
+       affine_function_constant_p, affine_fn_op, affine_fn_plus,
+       affine_fn_minus, affine_fn_free, conflict_fn_not_known,
+       conflict_fn_no_dependence, free_conflict_function, free_subscripts,
+       conflict_fn, affine_fn_cst, affine_fn_univar): New functions.
+       (all_chrecs_equal_p): Removed.
+       * tree-data-ref.h (affine_fn, conflict_function): New types.
+       (struct subscript): Change type of conflicting_iterations_in_a
+       and conflicting_iterations_in_b.
+
+2007-01-26  Steve Ellcey  <sje@cup.hp.com>
+
+       PR other/30182
+       * config/pa/pa.h (TARGET_HPUX_11): New.
+       * config/pa/pa-hpux11.h (TARGET_HPUX_11): New.
+       * config/pa/pa.c (pa_init_builtins): Use TARGET_HPUX_11.
+
+2007-01-26  Daniel Berlin  <dberlin@dberlin.org>
+       Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-structalias.c (solve_graph): Handle case
+       we merged the variable to another.
+
+2007-01-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.c (fold_builtin_1): Treat ccos and ccosh as 'even'
+       functions.
+
+       * fold-const.c (negate_mathfn_p): Treat casin, casinh, catan,
+       catanh, cproj, csin, csinh, ctan and ctanh as 'odd' functions.
+
+2007-01-25  DJ Delorie  <dj@redhat.com>
+
+       * config/m32c/m32c.c (m32c_cannot_change_mode_class): We don't
+       allow changes to modes which don't fit in those registers.
+
+       * reload1.c (choose_reload_regs): Check for invalid subregs before
+       computing their locations, not after.
+
+2007-01-25  Geoffrey Keating  <geoffk@apple.com>
+
+       PR 25127
+       * config/rs6000/rs6000.c (first_altivec_reg_to_save): On Darwin,
+       save Altivec registers in an eh_return function.
+       (compute_vrsave_mask): Likewise.
+       (rs6000_stack_info): Correct AIX/Darwin stack alignment computation
+       for saving Altivec registers.
+       (rs6000_emit_prologue): Don't allocate stack twice in
+       eh_return function.  Correct expected value of altivec_save_offset
+       when using save_world.  Describe save of R0 to stack when using
+       save_world.  Describe stack pointer adjustment when using
+       save_world.  Remove duplicated eh_return parameter register saving.
+       Update sp_offset variable after save_world.
+       * config/rs6000/t-darwin (LIB2FUNCS_STATIC_EXTRA): Remove
+       darwin-world.asm.
+       (LIB2FUNCS_EXTRA): Add darwin-world.asm.
+       * config/rs6000/darwin.h (SUBTARGET_OVERRIDE_OPTIONS): -m64
+       implies Altivec.
+
+2007-01-25  Steve Ellcey  <sje@cup.hp.com>
+
+       * config.gcc (ia64*-*-hpux*): Make posix threads the default.
+
+2007-01-25  Steve Ellcey  <sje@cup.hp.com>
+
+       PR other/30182
+       * config/pa/pa.c (pa_init_builtins): Set asm names for finite routines.
+       * config/ia64/ia64.c (ia64_init_builtins): Ditto.
+
+2007-01-25  Richard Guenther  <rguenther@suse.de>
+
+       * doc/invoke.texi (-Wcoverage-mismatch): Document.
+       * common.opt (-Wcoverage-mismatch): New warning option.
+       * coverage.c (get_coverage_counts): Ignore coverage mismatch
+       if -Wcoverage-mismatch is given.
+
+2007-01-25  Razya Ladelsky  <razya@il.ibm.com>
+
+       * ipa-cp.c (ipcp_insert_stage, ipcp_driver): Support for SSA.
+       (ipcp_driver): Change to static definition.
+       Add dumping of the ifunctions.
+       (constant_val_insert): Remove unused parameter. Support for SSA.
+       (ipcp_propagate_const): Support for SSA.
+       (ipcp_profile_bb_print): Print only analyzed nodes.
+       (ipcp_replace_map_create): Remove support for Fortran constant
+       for now.
+       * ipa-prop.c (ipa_method_modify_stmt,
+       ipa_callsite_compute_param): Support for SSA.
+       * ipa-prop.h (ipcp_driver): Remove declaration.
+       (IS_VALID_TREE_MAP_INDEX): Add define.
+
+2007-01-24  Geoffrey Keating  <geoffk@apple.com>
+
+       * unwind-dw2.c (execute_stack_op): Handle DW_OP_swap.
+
+2007-01-24  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR middle-end/30447
+       * builtins.c (fold_builtin_cabs): Use MPFR to evaluate a
+       constant argument to cabs and do it without checking for
+       -funsafe-math-optimizations.
+
+2007-01-24  Douglas Gregor  <dgregor@osl.iu.edu>
+
+       * c-common.h (RID_FIRST_CXX0X): New.
+       (RID_LAST_CXX0X): New.
+       * c-opts.c (c_common_handle_option): -Wc++0x-compat is triggered
+       by -Wall.
+       * c.opt (Wc++0x-compat): New.
+       * doc/invoke.texi (-Wc++0x-compat): Document.
+
+2007-01-24  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       * builtins.c (fold_builtin_carg): New.
+       (fold_builtin_1): Use it.
+
+2007-01-24  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-inline.c (cgraph_decide_inlining): Initialize initial_insns.
+
+       * ipa-inline.c (initial_insns, max_insns): Delete.
+       (compute_max_insns): New function.
+       (cgraph_decide_inlining_of_small_function): Use it; take minimal
+       amount of insns as base for code growth.
+       (cgraph_decide_inlining): Make initial_insns local; do not compute
+       max_insns.
+       * params.def (PARAM_INLINE_UNIT_GROWTH): Set to 60.
+       * doc/invoke.texi (inline-unit-growth): Update docs.
+
+2007-01-24  Jakub Jelinek  <jakub@redhat.com>
+
+       * config/i386/i386.h (x86_cmpxchg16b): Remove const.
+       (TARGET_CMPXCHG16B): Define to x86_cmpxchg16b.
+       * config/i386/i386.c (x86_cmpxchg16b): Remove const.
+       (override_options): Add PTA_CX16 flag.  Set x86_cmpxchg16b
+       for CPUs that have PTA_CX16 set.
+
+       PR middle-end/27416
+       * gimplify.c (omp_check_private): New function.
+       (gimplify_scan_omp_clauses): Use it for
+       firstprivate/lastprivate/reduction.
+
+       PR middle-end/30494
+       * gimplify.c (omp_add_variable): Don't call omp_notice_variable
+       on TYPE_SIZE_UNIT for GOVD_LOCAL VLAs.
+
+       PR middle-end/30421
+       * omp-low.c (lower_omp_for_lastprivate): Add dlist argument.
+       If lower_lastprivate_clauses emits some statements, append them
+       to dlist rather than body_p and to body_p append an initializer.
+       (lower_omp_for): Adjust caller.
+
+2007-01-24  Steve Ellcey  <sje@cup.hp.com>
+
+       * target.h (globalize_decl_name): New.
+       * target-def.h (TARGET_ASM_GLOBALIZE_DECL_NAME): New.
+       * output.h (default_globalize_decl_name): New.
+       * varasm.c (asm_output_bss): Use globalize_decl_name instead of
+       globalize_label.
+       (globalize_decl): Ditto.
+       (default_globalize_decl_name): New.
+       * config/ia64/ia64.c (ia64_globalize_decl_name): New.
+       (ia64_handle_version_id_attribute): New.
+       (TARGET_ASM_GLOBALIZE_DECL_NAME): New.
+       (ia64_asm_output_external): Use globalize_decl_name instead
+       of globalize_label.
+       * doc/extend.texi (version_id): New pragma.
+       * doc/tm.texi (ARGET_ASM_GLOBALIZE_DECL_NAME): New target hook.
+
+2007-01-24  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * unwind-dw2-fde.c (get_cie_encoding): Replaced _Unwind_Word with
+       _uleb128_t and _Unwind_SWord with _sleb128_t.
+       * unwind-dw2.c (extract_cie_info, execute_stack_op,
+       execute_cfa_program, uw_frame_state_for, uw_update_context_1):
+       Likewise.
+       * unwind-c.c (parse_lsda_header, PERSONALITY_FUNCTION): Likewise.
+       * unwind-pe.h (read_uleb128, read_sleb128,
+       read_encoded_value_with_base): Likewise.
+       * unwind-generic.h: Define _sleb128_t and _uleb128_t types.
+
+2007-01-24  Richard Guenther  <rguenther@suse.de>
+
+       * builtins.c (expand_builtin_cexpi): Get the fndecl
+       for cexp in the correct way.
+
+2007-01-24  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-dce.c (eliminate_unnecesary_stmts): Remove dead LHS
+       of calls.
+
+2007-01-24  Andreas Krebbel  <krebbel1@de.ibm.com>
+
+       * c-cppbuiltin.c (builtin_define_type_sizeof): New function.
+       (c_cpp_builtins): New builtin macros: __SIZEOF_INT__, __SIZEOF_LONG__,
+       __SIZEOF_LONG_LONG__, __SIZEOF_SHORT__, __SIZEOF_POINTER__,
+       __SIZEOF_FLOAT__, __SIZEOF_DOUBLE__, __SIZEOF_LONG_DOUBLE__,
+       __SIZEOF_SIZE_T__, __SIZEOF_WCHAR_T__, __SIZEOF_WINT_T__ and
+       __SIZEOF_PTRDIFF_T__.
+       * doc/cpp.texi: Documentation for the new builtin macros added.
+
+2007-01-24  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (tanxf2, tan<mode>2, atan<mode>2, log<mode>2,
+       log10<mode>2, log2<mode>2, expxf2, exp10xf2, exp2xf2): Use op2
+       instead of operands[2] to avoid access past the end of array.
+
+2007-01-24  Richard Sandiford  <richard@codesourcery.com>
+
+       * reload1.c (emit_reload_insns): Pass the reload register
+       for a non-spill output reload through forget_old_reloads_1.
+
+2007-01-23  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Define
+       _SOFT_DOUBLE if doubles use software floating-point.
+       * config/rs6000/libgcc-ppc-glibc.ver: Export additional long
+       double functions if _SOFT_DOUBLE, not _SOFT_FLOAT.
+       * config/rs6000/darwin-ldouble.c: Also compile functions for
+       hard-float without FPRs.  Use fmsub function for all __NO_FPRS__
+       cases.  Compile extra functions if _SOFT_DOUBLE, not _SOFT_FLOAT.
+       * config/rs6000/linuxspe.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Remove
+       commented-out long double override.
+       (CPP_LONGDOUBLE_DEFAULT_SPEC): Likewise.
+       * config/rs6000/eabispe.h: Likewise.
+       * config/rs6000/rs6000.c (rs6000_override_options): Don't override
+       long double for non-SPE.
+       (rs6000_handle_option): Likewise.
+       (invalid_e500_subreg): Disallow more subregs involding DImode,
+       DFmode, TImode or TFmode.
+       (rs6000_legitimate_offset_address_p): Check TFmode offsets for
+       E500 double.
+       (legitimate_lo_sum_address_p): Also check for TFmode for E500
+       double.
+       (rs6000_legitimize_address): Also handle TFmode for E500 double.
+       (rs6000_legitimize_reload_address): Also handle TFmode for E500
+       double.
+       (rs6000_legitimate_address): Also check for TFmode for E500
+       double.
+       (rs6000_emit_move): Use DFmode subregs of TFmode for E500 double.
+       (spe_build_register_parallel): Handle TFmode and TCmode.
+       (rs6000_spe_function_arg): Handle TFmode and TCmode for E500
+       double.
+       (function_arg): Handle TFmode and TCmode for E500 double.
+       (rs6000_init_libfuncs): Initialize extra libfuncs for soft double
+       in general.
+       (print_operand): Handle TFmode and TImode for %y.
+       (rs6000_generate_compare): Handle TFmode comparisons for E500
+       double.
+       (spe_func_has_64bit_regs_p): Check for TFmode for E500 double.
+       (rs6000_function_value): Handle TFmode and TCmode for E500 double.
+       (rs6000_libcall_value): Handle TFmode and TCmode for E500 double.
+       * config/rs6000/rs6000.h (CANNOT_CHANGE_MODE_CLASS): Check for
+       TFmode for E500 double.
+       * config/rs6000/rs6000.md (FP): Allow TF for E500 double.
+       (floatsidf2): Enable for E500 double.
+       (movtf_softfloat): Use rs6000_nonimmediate_operand.
+       (extenddftf2): Change to extenddftf2_fprs.
+       (extenddftf2): Call gen_spe_extenddftf2 or gen_extenddftf2_fprs
+       depending on TARGET_E500_DOUBLE.
+       (extendsftf2): Enable for E500 double.
+       (trunctfdf2): Enable for E500 double.
+       (trunctfsf2): Change to trunctfsf2_fprs.
+       (trunctfsf2): Call gen_spe_trunctfsf2 or gen_trunctfsf2_fprs
+       depending on TARGET_E500_DOUBLE.
+       (floatsitf2): Enable for E500 double.
+       (fix_trunctfsi2): Change to fix_trunctfsi2_fprs.
+       (fix_trunctfsi2): Call gen_spe_fix_trunctfsi2 or
+       gen_fix_trunctfsi2_fprs depending on TARGET_E500_DOUBLE.
+       (negtf2): Change to negtf2_internal.
+       (negtf2): New expander.
+       (abstf2): Enable for E500 double.  Call gen_spe_abstf2_tst,
+       gen_spe_abstf2_cmp or gen_abstf2_internal depending on
+       TARGET_E500_DOUBLE and flag_unsafe_math_optimizations.
+       (movdi_internal32): Use rs6000_nonimmediate_operand.
+       (unnamed splitter): Likewise.
+       * config/rs6000/spe.md (CMPTFEQ_GPR, TSTTFEQ_GPR, CMPTFGT_GPR,
+       TSTTFGT_GPR, CMPTFLT_GPR, TSTTFLT_GPR): New unspecs.
+       (SPE64TF, DITI): New mode macros.
+       (frob_df_di): Change to frob_<SPE64:mode>_<DITI:mode>; allow more
+       modes.
+       (frob_tf_ti): New.
+       (frob_<mode>_di_2): New.
+       (frob_tf_di_8_2): New.
+       (frob_di_df): Change to frob_di_<mode>; allow more modes.
+       (frob_ti_tf): New.
+       (frob_di_df_2): Change to frob_<DITI:mode>_<SPE64:mode>_2; allow
+       more modes.
+       (frob_ti_<mode>_8_2): New.
+       (frob_ti_tf_2): New.
+       (mov_si<mode>_e500_subreg0, mov_si<mode>_e500_subreg0_2,
+       mov_si<mode>_e500_subreg4, mov_si<mode>_e500_subreg4_2): Allow
+       TFmode.
+       (mov_sitf_e500_subreg8, mov_sitf_e500_subreg8_2,
+       mov_sitf_e500_subreg12, mov_sitf_e500_subreg12_2): New.
+       (spe_trunctfdf2_internal1, spe_trunctfsf2, spe_extenddftf2,
+       spe_fix_trunctfsi2, spe_fix_trunctfsi2_internal,
+       spe_negtf2_internal, spe_abstf2_cmp, spe_abstf2_tst): New.
+       (cmptfeq_gpr, tsttfeq_gpr, cmptfgt_gpr, tsttfgt_gpr, cmptflt_gpr,
+       tsttflt_gp): New.
+
+2007-01-23  Ian Lance Taylor  <iant@google.com>
+
+       * Makefile.in (OBJS-common): Reformat, alphabetize, but put
+       insn-*.o first.
+       (OBJS-archive): Reformat, alphabetize.
+       (OBJS): Change out_object_file to OBJS-md.
+
+2007-01-23  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md: Use REG_P, MEM_P, CONST_INT_P, LABEL_P,
+       JUMP_P and CALL_P predicates where applicable.
+       * config/i386/i386.c: Ditto.
+       * config/i386/i386.md: Ditto.
+       * config/i386/mmx.md: Ditto.
+       * config/i386/predicates.md: Ditto.
+
+2007-01-22  Andreas Schwab  <schwab@suse.de>
+
+       * config/m68k/m68k.h: Fix comment.
+
+2007-01-22  Jan Hubicka  <jh@suse.cz>
+
+       * passes.c (init_optimization_passes): Do not rerun
+       pass_early_warn_uninitialized.
+
+2007-01-22  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/30038
+       * tree-ssa-math-opts.c (maybe_record_sincos): New static helper
+       function.
+       (execute_cse_sincos_1): Likewise.
+       (execute_cse_sincos): Likewise.
+       (gate_cse_sincos): Likewise.
+       (pass_cse_sincos): New pass CSEing sin() and cos() calls using
+       the cexpi() canonicalization of sincos().
+       * tree-pass.h (pass_cse_sincos): Declare.
+       * passes.c (init_optimization_passes): New pass pas_cse_sincos.
+
+2007-01-21  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       PR rtl-optimization/29329
+       * combine.c (replaced_rhs_insn): Rename to i2mod.
+       (replaced_rhs_value): Rename to i2mod_new_rhs.
+       (i2mod_old_rhs): New global variable.
+       (combine_instructions): Adjust for above change.  Save a copy of
+       the old RHS into i2mod_old_rhs when the contents of a REG_EQUAL
+       note are substituted in the second instruction.
+       (distribute_notes) <REG_DEAD>: Adjust for above change.  Do not
+       ditch the note if it pertains to the second eliminated register
+       and this register is mentioned in i2mod_old_rhs.
+
+       Revert:
+       2006-09-12  Eric Botcazou  <ebotcazou@libertysurf.fr>
+
+       * combine.c (distribute_notes) <REG_DEAD>: Do not consider SETs past
+       the insn to which the note was originally attached.
+
+2007-01-21  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-inline.c (inlining_mode): Comment, move up.
+       (cgraph_decide_inlining_incrementally): Do not perform inlining
+       itself; fix handling of flattening of self recursive functions.
+       (cgraph_find_cycles): Remove.
+       (cgraph_flatten_node): Remove.
+       (cgraph_decide_inlining): Use incremental inliner to handle flattening.
+       (try_inline): New function.
+       (cgraph_early_inlining): Update call of
+       cgraph_decide_inlining_incrementally.  Apply inlining here.
+       (apply_inline): Update call of cgraph_decide_inlining_incrementally.
+
+2007-01-21  Dirk Mueller  <dmueller@suse.de>
+
+       PR bootstrap/30511
+       * tree-vrp.c (check_array_bounds): do not warn
+       about ADDR_EXPR's of ARRAY_REF's which are immediately
+       used in binary expressions.
+
+2007-01-21  Ira Rosen  <irar@il.ibm.com>
+
+       * tree-vectorizer.h (struct _stmt_vec_info): Add new field
+       read_write_dep and macros for its access.
+       * tree-vectorizer.c (new_stmt_vec_info): Initialize the new field.
+       * tree-vect-analyze.c (vect_analyze_data_ref_dependence): Remove
+       argument, call vect_check_interleaving for every independent pair of
+       data-refs. Mark loads that access the same memory location as a store
+       in the loop.
+       (vect_check_dependences): Remove.
+       (vect_analyze_data_ref_dependences): Remove  vect_check_dependences
+       call, fix the call to vect_analyze_data_ref_dependence.
+       (vect_analyze_data_ref_access): For statements that access the same
+       data-ref, check that they are not stores; for loads, check that there
+       is no store that access the same location.
+
+2007-01-20  Roger Sayle  <roger@eyesopen.com>
+           Joseph Myers  <joseph@codesourcery.com>
+
+       * doc/invoke.texi (-fdump-rtl-combine): Fix under/overfull hbox.
+       (-fdump-rtl-stack): Likewise.
+       (-fno-signed-zeros): Use @minus{} for a minus sign.  Correct typo.
+       (-mcheck-zero-division, -mcpu): Fix under/overfull hbox.
+       (-mpt-fixed): Use @minus{} for minus sign.
+       (Using Precompiled Headers): Fix under/overfull hbox.
+
+2007-01-20  Jan Hubicka  <jh@suse.cz>
+
+       * tree-flow.h (struct stmt_ann_d): Move references_memory to proper
+       place within annotation.
+
+2007-01-20  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa.c (output_move_double): Change array size of xoperands to 4.
+
+2007-01-20  Jan Hubicka  <jh@suse.cz>
+
+       * tree-tailcall.c (adjust_return_value): Do not use RESULT_DECL
+       as temporary.
+
+2007-01-19  Ian Lance Taylor  <iant@google.com>
+
+       * expmed.c (expand_divmod) [TRUNC_MOD_EXPR, TRUNC_DIV_EXPR]: Cast
+       constant to unsigned HOST_WIDE_INT before negating.
+
+2007-01-19  Ian Lance Taylor  <iant@google.com>
+
+       * tree-ssa-operands.h (struct vuse_vec_d): Change num_vuse field
+       to unsigned.
+       (VUSE_VECT_ELEMENT) [ENABLE_CHECKING]: Use unsigned comparison.
+       (VUSE_ELEMENT_PTR) [ENABLE_CHECKING]: Likewise.
+       (SET_VUSE_VECT_ELEMENT) [ENABLE_CHECKING]: Likewise.
+       (SET_VUSE_ELEMENT_VAR) [ENABLE_CHECKING]: Likewise.
+       (SET_VUSE_ELEMENT_PTR) [ENABLE_CHECKING]: Likewise.
+       (realloc_vdef, realloc_vuse): Change second parameter to
+       unsigned.
+       (ssa_operand_iterator_d): Change vuse_index and mayuse_index
+       fields to unsigned.
+       * tree-ssa-operands.c (realloc_vop): Change num_elem parameter to
+       unsigned. Change x and lim locals to unsigned.
+       (realloc_vdef, realloc_vuse): Change num_elem parameter to
+       unsigned.
+       (finalize_ssa_vuse_ops): Change old_i local to unsigned.
+       (copy_virtual_operands): Change i and n locals to unsigned.
+
+2007-01-19  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
+
+       PR middle-end/29335
+       * builtins.c (fold_builtin_1): Handle builtin fdim.
+
+2007-01-20  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa.c (init_tree_ssa): Do not call init_alias_heapvars.
+       * tree-ssa-structalias.c (compute_points_to_sets): Do call
+       init_alias_heapvars.
+       (init_alias_heapvars): Initialize only when not already initialized.
+       (delete_alias_heapvars): Set heapvar_for_stmt to NULL.
+
+2007-01-19  Roger Sayle  <roger@eyesopen.com>
+
+       * common.opt (fsigned-zeros): New command line option.
+       * flags.h (HONOR_SIGNED_ZEROS): Control via flag_signed_zeros instead
+       of flag_unsafe_math_optimizations.
+       * opts.c (set_fast_math_flags): The -ffast-math command line option
+       implies -fno-signed-zeros.
+       (fast_math_flags_set_p): Likewise.
+
+       * doc/invoke.texi: Document new -fno-signed-zeros option, and update
+       the documentation of -ffast-math appropriately.  Wrap long lines.
+
+2007-01-19  Steve Ellcey  <sje@cup.hp.com>
+
+       * system.h (ASM_MAKE_LABEL_LINKONCE): Poison.
+       * varasm.c (globalize_decl): Remove ASM_MAKE_LABEL_LINKONCE ifdef.
+
+2007-01-19  Tomas Bily  <tbily@suse.cz>
+
+       * cgraphunit.c (cgraph_finalize_function): Updating of pid
+       * tree-profile.c:
+       (tree_init_ic_make_global_vars): New function
+       (tree_init_edge_profiler): call of tree_init_ic_make_global_vars
+       (tree_gen_ic_profiler): New function
+       (tree_gen_ic_func_profiler): New function
+       (tree_profiling): Added calling of tree_gen_ic_func_profiler
+       (tree_profile_hooks): Added hook for indirec/virtual calls
+       * value-prof.c (tree_find_values_to_profile): New case for
+       indirect calls
+       (tree_values_to_profile): Call for determining indirect/virtual
+       counters
+       (tree_indirect_call_to_profile): New function
+       (tree_ic_transform): New function
+       (tree_ic): New function
+       (find_func_by_pid): New function
+       (init_pid_map): New function
+       (tree_value_profile_transformations): Added check for
+       indirect/virtual call transformation
+       * value-prof.h (enum hist_type): New counter type for
+       indirect/virtual calls
+       (profile_hooks): Added new hook for profiling indirect/virtual
+       calls
+       * profile.c (instrument_values): New case for indirect/virtual
+       call added
+       * gcov-io.h (GCOV_LAST_VALUE_COUNTER): Changed to 6
+       (GCOV_COUNTER_V_INDIR): New counter type
+       (GCOV_COUNTER_NAMES): New name of counter "indirect" added
+       (GCOV_MERGE_FUNCTIONS): New merge function for indirect/virtual
+       call added
+       * cgraph.c: Definition of cgraph_max_pid
+       (cgraph_create_node): Default init of pid attribute
+       * cgraph.h: Declaration of cgraph_max_pid
+       (struct cgraph_node): Added pid attribute
+       * libgcov.c (__gcov_indirect_call_profiler): New function
+       (__gcov_one_value_profiler_body): New function
+       (__gcov_one_value_profiler): Body was moved to
+       __gcov_one_value_profiler_body and calls it
+
+2007-01-19  Basile Starynkevitch  <basile@starynkevitch.net>
+
+       * doc/gty.texi (Options): Document the mark_hook option to GTY.
+       * gengtype.c (write_types_data, write_func_for_structure,
+       write_types, ggc_wtd, pch_wtd): Add skip_hooks to
+       write_types_data, ggc_wtd, pch_wtd for processing mark_hook.
+       (walk_type, write_func_for_structure): Generate the mark_hook if
+       needed.
+
+2007-01-19  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-inline.c (cgraph_decide_inlining_incrementally): Instead of
+       'early' argument take inlining mode argument specifying whether to
+       inline for size/speeed or all functions; add support for flattening;
+       improve dumpting.
+       (cgraph_early_inlining): Update call of decide_inlining_incrementally.
+
+2007-01-19  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c++/17947
+       * toplev.c (warn_deprecated_use): Use %qD instead of %qs to print
+       the name of the declared identifier.
+
+2007-01-19  Dirk Mueller  <dmueller@suse.de>
+
+       * config/i386.h (CONDITIONAL_REGISTER_USAGE): Store
+       result of PIC_OFFSET_TABLE_REGNUM in temporary variable to avoid
+       duplicate evaluation.
+
+2007-01-19  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (acos<mode>2): Rename from acossf2 and acosdf2.
+       Macroize expander using X87MODEF12 mode macro.  Extend operand 1
+       to XFMode, use acosxf2 and truncate result to requested mode.
+       Use SSE_FLOAT_MODE_P to disable patterns for SSE math.
+       (asin<mode>2): Similarly, with asin expanders.
+       (*fscalexf4_i387): Rename from *fscalexf4.
+       (expNcorexf3): New expander.
+       (expxf2, exp10xf2, exp2xf2): Use expNcorexf3 expander.
+       (exp<mode>2): Rename from expsf2 and expdf2. Macroize expander using
+       X87MODEF12 mode macro.  Extend operand 1 to XFMode, use expxf2 and
+       truncate result to requested mode. Use SSE_FLOAT_MODE_P to disable
+       patterns for SSE math.
+       (exp10<mode>2): Similarly, with exp10 expanders.
+       (exp2<mode>2): Similarly, with exp2 expanders.
+       (expm1<mode>2): Similarly, with expm1 expanders.
+       (ldexp<mode>3): Similarly, with ldexp expanders.
+       (log<mode>2, log10<mode>2, log2<mode>2, log1p<mode>2, logb<mode>2):
+       Use gen_truncxf<mode>2_i387_noop to truncate result.
+
+2007-01-19  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (PREFERRED_STACK_BOUNDARY): Define to 32
+       for ColdFire targets.
+
+2007-01-19  Nathan Sidwell  <nathan@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (M68K_STATIC_CHAIN_REG_NAME): New macro.
+       (INITIALIZE_TRAMPOLINE): Use STATIC_CHAIN_REGNUM.
+       (__transfer_from_trampoline): Use M68K_STATIC_CHAIN_REG_NAME.
+       * config/m68k/m68kelf.h (STATIC_CHAIN_REGNUM): Override.
+       (M68K_STATIC_CHAIN_REG_NAME): Likewise.
+       * config/m68k/netbsd-elf.h (M68K_STATIC_CHAIN_REG_NAME): Likewise.
+
+2007-01-19  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.md (adddi_dilshr32): Rename to...
+       (*adddi_dilshr32): ...this.  Fix formatting.  Remove commented-out
+       non-canonical pattern.  Restrict to !TARGET_COLDFIRE.
+       (*adddi_dilshr32_cf): New pattern.
+       (adddi3, subdi3): Remove first alternatives.
+
+2007-01-19  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.c (notice_update_cc): If an SFmode move is
+       implemented using move.l, do not use its cc result for floating-point
+       comparisons.
+
+2007-01-19  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (EXTRA_CONSTRAINT): Stop the 'T' constraint
+       from accepting 's' constraints if flag_pic.
+
+2007-01-19  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.md (bordered, bunordered, buneq, bunge, bungt)
+       (bunle, bunlt, bltgt, bordered_rev, bunordered_rev, buneq_rev)
+       (bunge_rev, bungt_rev, bunle_rev, bunlt_rev, bltgt_rev): Change
+       condition from TARGET_68881 to TARGET_HARD_FLOAT.
+
+2007-01-19  Sandra Loosemore  <sandra@codesourcery.com>
+
+       * longlong.h (count_leading_zeros, COUNT_LEADING_ZEROS_0): Add
+       ColdFire alternatives.
+       * config/m68k/m68k.h (CLZ_DEFINED_VALUE_AT_ZERO): New macro.
+       * config/m68k/m68k.md (clzsi2): Define for ColdFire
+       architectures that support ff1 instruction.
+
+2007-01-19  Richard Sandiford  <richard@codesourcery.com>
+           Julian Brown  <julian@codesourcery.com>
+
+       * config/m68k/m68k.h (CONST_OK_FOR_LETTER_P): Add an 'R' case.
+       * config/m68k/m68k.md (*movsi_cfv4): Fold into...
+       (*movsi_cf): ...here.  Remove unnecessary 'R' from 'Rg'.
+       Add commentary.
+
+2007-01-19  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k-protos.h (valid_mov3q_const): Take a HOST_WIDE_INT
+       and return a bool.
+       (output_move_const_into_data_reg, output_move_simode_const): Delete.
+       * config/m68k/m68k.c (const_method, const_int_cost): Take a
+       HOST_WIDE_INT instead of an rtx.
+       (m68k_rtx_costs): Update call accordingly.
+       (output_move_const_into_data_reg): Likewise.  Fix formatting.
+       (valid_mov3q_const): Take a HOST_WIDE_INT instead of an rtx.
+       Return a bool.
+       (output_move_simode_const): Update calls after above changes.
+       Rework to use automatic variables and predicates like MEM_P.
+       * config/m68k/m68k.md (pushexthisi_const): Update call to
+       valid_mov3q_const.
+
+2007-01-19  Dirk Mueller  <dmueller@suse.de>
+
+       * tree-ssa-alias.c (perform_var_substitution): Fix typo
+       in dump_flags test.
+
+2007-01-19  Richard Guenther  <rguenther@suse.de>
+
+       * builtins.c (expand_builtin_cexpi): Fall back to expanding
+       via cexp in case sincos is not available.
+
+2007-01-19  Richard Guenther  <rguenther@suse.de>
+
+       * doc/tm.texi (TARGET_HAS_SINCOS): Document new target macro.
+       * defaults.h (TARGET_HAS_SINCOS): Default to off.
+       * config/linux.h (TARGET_HAS_SINCOS): Set to on if we have glibc.
+       * config/alpha/linux.h (TARGET_HAS_SINCOS): Likewise.
+       * config/sparc/linux.h (TARGET_HAS_SINCOS): Likewise.
+       * config/sparc/linux64.h (TARGET_HAS_SINCOS): Likewise.
+       * config/rs6000/linux.h (TARGET_HAS_SINCOS): Likewise.
+       * config/rs6000/linux64.h (TARGET_HAS_SINCOS): Likewise.
+
+2007-01-19  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (*fpatanxf3_i387, fpatan_extend<mode>xf3_i387):
+       New insn patterns.
+       (atan2sf3_1, atan2df3_1, atan2xf3_1): Remove insn patterns.
+       (atan2xf3): Directly generate RTL pattern.
+       (atan2<mode>3): Rename from atan2sf3 and atan2df3 and macroize insn
+       patterns using X87MODEF12 mode macro.  Use fpatan_extend<mode>xf3_i387
+       and truncate result to requested mode.  Use SSE_FLOAT_MODE_P to
+       disable patterns for SSE math.
+       (atan<mode>2): Rename from atansf2 and atandf2 and macroize insn
+       patterns using X87MODEF12 mode macro.  Use fpatan_extend<mode>xf3_i387
+       and truncate result to requested mode.  Use SSE_FLOAT_MODE_P to
+       disable patterns for SSE math.
+
+2007-01-19  Alexandre Oliva  <aoliva@redhat.com>
+
+       * libgcc-std.ver: Fix typo in %inherit for GCC_4.3.0.
+
+2007-01-18  Roger Sayle  <roger@eyesopen.com>
+
+       * fold-const.c (fold_unary) <VIEW_CONVERT_EXPR>: Optimize away a
+       VIEW_CONVERT_EXPR to the same type as it's operand.
+
+2007-01-18  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/darwin-ldouble.c: Only build _SOFT_FLOAT if
+       configured for long double 128.
+
+2007-01-18  Mike Stump  <mrs@apple.com>
+
+       * config/rs6000/rs6000.c (rs6000_emit_vector_compare): Fix build
+       error.
+
+2007-01-18  Michael Meissner  <michael.meissner@amd.com>
+
+       * config/i386/i386.c (ix86_compute_frame_layout): Make fprintf's
+       in #if 0 code type correct.
+
+2007-01-18  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-operands.c (vop_free_bucket_size): Never return value
+       greater than NUM_VOP_FREE_BUCKETS.
+
+2007-01-18  Daniel Berlin  <dberlin@dberlin.org>
+
+       * tree-ssa-structalias.c: Update comments.
+       (ptabitmap_obstack): Removed.
+       (pta_obstack): New.
+       (oldpta_obstack): Ditto.
+       (stats): Add a few members.
+       (struct variable_info): Remove node, complex, address_taken, and
+       indirect_target members. Add oldsolution member.
+       (new_var_info): Do not initialize removed members.
+       (constraint_expr_type): Remove INCLUDES.
+       (constraint_graph): Add size, implicit_preds, rep,
+       indirect_cycles, eq_rep, label, direct_nodes, and complex members.
+       (FIRST_REF_NODE): New macro.
+       (LAST_REF_NODE): Ditto.
+       (FIRST_ADDR_NODE): Ditto.
+       (find): New function.
+       (unite): Ditto.
+       (dump_constraint): Do not handle INCLUDES.
+       (insert_into_complex): Do not insert duplicate constraints.
+       (condense_varmap_nodes): Renamed and rewritten into ...
+       (merge_node_constraints): This. Also fix bug in handling of
+       offseted copy constraints.
+       (clear_edges_for_node): No longer need to deal with preds at all,
+       or removing associated preds/succs.
+       (merge_graph_nodes): Deal with indirect_cycles.
+       Don't deal with predecessors.
+       (add_implicit_graph_edge): New function.
+       (add_pred_graph_edge): Ditto.
+       (add_graph_edge): Don't deal with predecessors.
+       (build_constraint_graph): Removed.
+       (build_pred_graph): New function.
+       (build_succ_graph): Ditto.
+       (struct scc_info): Removed in_component. Added roots, dfs, and
+       node_mapping. Remove visited_index, unification_queue.
+       (scc_visit): Deal with union-find we do now.
+       Deal with cycles with REF nodes.
+       (collapse_nodes): Renamed and rewritten to ...
+       (unify_nodes): This.
+       (process_unification_queue): Removed.
+       (topo_visit): Cleanup
+       (do_da_constraint): Use find.
+       (do_sd_constraint): Ditto.
+       (do_ds_constraint): Ditto.
+       (do_complex_constraint): Ditto.
+       (init_scc_info): Update for removed and added members.
+       (find_and_collapse_graph_cycles): Renamed and rewritten into ...
+       (find_indirect_cycles): This.
+       (equivalence_class): New variable.
+       (label_visit): New function.
+       (perform_variable_substitution): Rewritten.
+       (free_var_substitution_info): New function.
+       (find_equivalent_node): Ditto.
+       (move_complex_constraints): Ditto.
+       (eliminate_indirect_cycles): Ditto.
+       (solve_graph): Only propagate changed bits.
+       Use indirect cycle elimination.
+       Use find.
+       (tree_id_t): Rename to tree_vi_t, delete id member, add vi member.
+       (tree_id_eq): Renamed to ...
+       (tree_vi_eq): This. Update for member change
+       (insert_id_for_tree): Renamed and rewritten to ...
+       (insert_vi_for_tree): This.
+       (lookup_id_for_tree): Renamed and rewritten to ...
+       (lookup_vi_for_tree): This.
+       (get_id_for_tree): Renamed and rewritten to ...
+       (get_vi_for_tree): Ditto.
+       (get_constraint_exp_from_ssa_var): Update to use get_vi_for_tree.
+       (process_constraint): Don't handle INCLUDES.
+       Remove special ADDRESSOF case.
+       (find_func_aliases): Rewrite to use vi functions instead of id
+       ones.
+       (create_function_info_for): Ditto.
+       (create_variable_info_for): Ditto.
+       (intra_create_variable_infos): Ditto.
+       (merge_smts_into): Ditto.
+       (find_what_p_points_to): Ditto.
+       (init_base_vars): Ditto.
+       (init_alias_vars): Ditto.
+       (remove_preds_and_fake_succs): New function.
+       (dump_sa_points_to_info): Dump new stats.
+       (dump_solution_for_var): Use find.
+       (set_used_smts): Fix formatting.
+       (compute_points_to_sets): Updated for new functions.
+       (ipa_pta_execute): Ditto.
+
+2007-01-18  Kazu Hirata  <kazu@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/tm.texi (TARGET_FUNCTION_VALUE): Expand documentation of
+       parallels.
+       * calls.c (expand_call): If the return value is a PARALLEL,
+       extract its first member.
+       * config/m68k/linux.h (FUNCTION_EXTRA_EPILOGUE): Remove.
+       * config/m68k/m68k.c (m68k_output_function_epilogue): Don't
+       use FUNCTION_EXTRA_EPILOGUE.
+       (m68k_function_value): Return a PARALLEL if the return value
+       is of a pointer type.
+       * config/m68k/netbsd-elf.h (current_function_returns_pointer)
+       (FUNCTION_EXTRA_EPILOGUE): Remove.
+       * config/m68k/m68k.md (D0_REG): New constant.
+
+2007-01-18  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_output_function_epilogue): Don't
+       output a NOP for empty epilogues.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.c (m68k_use_return_insn): Update comments
+       before function.  Extend register save check to include all
+       registers, not just integer ones.
+
+2007-01-18  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/m68k/m68k-protos.h (use_return_insn): Rename to...
+       (m68k_use_return_insn): ...this.
+       * config/m68k/m68k.h (USE_RETURN_INSN): Delete.
+       * config/m68k/m68k.c (use_return_insn): Rename to...
+       (m68k_use_return_insn): ...this.
+       * config/m68k/m68k.md (return): Use m68k_use_return_insn instead
+       of USE_RETURN_INSN.
+
+2007-01-18  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/fpgnulib.c (__truncdfsf2): Implement round to
+       nearest even, fix denormal rounding overflow.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.md (movsf_cf_hard): Use fsmove instead of
+       f%$smove and f%$move.
+       (movdf_cf_hard): Use fdmove for cases 0 and 3 and fmove for case 1.
+       (extendsfdf2_cf): Use fdmove instead of f%&move.
+       (truncdfsf2_cf): Use fsmove instead of f%$smove.
+       (add<mode>3_cf, sub<mode>3_cf): Use <FP:prec> instead of <FP:round>.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.md (movdf_cf_hard): Use output_move_double for
+       GPR<-GPR moves.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * real.h (real_format): Add a canonical_nan_lsbs_set field.
+       (coldfire_single_format): Declare.
+       (coldfire_double_format): Likewise.
+       * real.c (encode_ieee_single): Use canonical_nan_lsbs_set instead
+       of qnan_msb_set to determine the lower bits of a canonical
+       NaN significand.
+       (encode_ieee_double): Likewise.
+       (encode_ieee_quad): Likewise.
+       (ieee_single_format): Initialize canonical_nan_lsbs_set.
+       (mips_single_format): Likewise.
+       (ieee_double_format): Likewise.
+       (mips_double_format): Likewise.
+       (ieee_extended_motorola_format): Likewise.
+       (ieee_extended_intel_96_format): Likewise.
+       (ieee_extended_intel_128_format): Likewise.
+       (ieee_extended_intel_96_round_53_format): Likewise.
+       (ibm_extended_format): Likewise.
+       (mips_extended_format): Likewise.
+       (ieee_quad_format): Likewise.
+       (mips_quad_format): Likewise.
+       (vax_f_format): Likewise.
+       (vax_d_format): Likewise.
+       (vax_g_format): Likewise.
+       (i370_single_format): Likewise.
+       (i370_double_format): Likewise.
+       (decimal_single_format): Likewise.
+       (decimal_double_format): Likewise.
+       (decimal_quad_format): Likewise.
+       (c4x_single_format): Likewise.
+       (c4x_extended_format): Likewise.
+       (real_internal_format): Likewise.
+       (coldfire_single_format): New real_format.
+       (coldfire_double_format): Likewise.
+       * config/pdp11/pdp11.c (pdp11_f_format): Initialize
+       canonical_nan_lsbs_set.
+       (pdp11_d_format): Likewise.
+       * config/m68k/m68k.c (override_options): Override REAL_FORMAT_MODE
+       if TARGET_COLDFIRE_CPU.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k-protos.h (m68k_output_pic_call): Delete.
+       (output_call, m68k_legitimize_call_address): Declare.
+       * config/m68k/m68k.h (EXTRA_CONSTRAINT): Remove unnecessary
+       parenthesees.  Add support for a 'W' constraint.
+       (LEGITIMATE_PIC_OPERAND_P): Remove SYMBOL_REF_FLAG handling.
+       (PRINT_OPERAND_PUNCT_VALID_P): Remove comment about 'o'.
+       (m68k_symbolic_call, m68k_symbolic_jump): Declare.
+       * config/m68k/m68k.c (m68k_symbolic_call, m68k_symbolic_jump): New
+       variables.
+       (override_options): Initialize them.  Do not set flag_no_function_cse
+       for TARGET_ID_SHARED_LIBRARY.
+       (m68k_output_pic_call): Delete.
+       (m68k_legitimize_call_address): New function.
+       (print_operand): Remove the %o prefix.  Handle the %p prefix.
+       (output_call): New function.
+       (m68k_output_mi_thunk): Use m68k_symbolic_jump.  Always load the
+       target address from the GOT if symbolic jumps are not allowed.
+       * config/m68k/m68k.md (call, general_operand): Do not set
+       SYMBOL_REF_FLAG.  Use m68k_legitimize_call_address instead.
+       Merge separate flag_pic and !flag_pic define_insns into...
+       (*call, *call_value): ...these new patterns.  Match the address
+       rather than the containing MEM and require it to be a call_operand.
+       Use output_call to generate the asm template.
+       * config/m68k/predicates.md (const_call_operand): New predicate.
+       (call_operand): Likewise.
+
+2007-01-18  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/m68k.h (REGISTER_MOVE_COST): Simplify definition.
+       (STACK_GROWS_DOWNWARD): Define to 1.
+       (FUNCTION_VALUE, LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P): Equivocate
+       comments, emphasizing that these values are only defaults.
+       * config/m68k/linux.h (LINK_SPEC): Fix formatting in #undef.
+       * config/m68k/m68k.c (const_method): Remove trailing whitespace.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.md (cmpsi): Remove outdated flag_pic handling.
+
+2007-01-18  Kazu Hirata  <kazu@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (DATA_REGNO_P, ADDRESS_REGNO_P, INT_REGNO_P)
+       (FP_REGNO_P): New macros.
+       (REGNO_OK_FOR_INDEX_P, REGNO_OK_FOR_BASE_P, REGNO_OK_FOR_DATA_P)
+       (REGNO_OK_FOR_FP_P, REG_OK_FOR_INDEX_P, REG_OK_FOR_BASE_P): Use them.
+       (EH_RETURN_STACKADJ_RTX): Use A0_REG.
+       * config/m68k/m68k.c (m68k_regno_mode_ok): Use the new REGNO macros.
+
+2007-01-18  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config.gcc (m68k-*-aout*, m68k-*-coff*, m68020-*-elf*, m68k-*-elf*)
+       (m68k-*-uclinuxoldabi, m68k-*-uclinux*, m68k-*-rtems*): Add t-floatlib
+       to $tmake_file.
+       * config/m68k/t-floatlib: New file, extracting common code from...
+       * config/m68k/t-m68kbare, config/m68k/t-m68kelf,
+       * config/m68k/t-uclinux: Here.
+       * config/m68k/fpgnulib.c: Do not compile extendeed precision
+       routines on ColdFire targets.
+
+2007-01-18  Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config.gcc (m68k-*-aout*, m68k-*-coff*, m68020-*-elf*, m68k-*-elf*)
+       (m68010-*-netbsdelf*, m68k*-*-netbsdelf*, m68k*-*-openbsd*)
+       (m68k-*-uclinuxoldabi, m68k-*-uclinux*, m68k-*-linux*)
+       (m68k-*-rtems*): Use tm_file rather than m68k/m68k.h and
+       explicitly set MOTOROLA to 1.
+       * config/m68k/m68k.h (MOTOROLA): Simplify definition accordingly.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+           Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/m68k.h (PCC_STATIC_STRUCT_RETURN): Delete.
+       (ASM_OUTPUT_REG_PUSH, ASM_OUTPUT_REG_POP): Add MOTOROLA cases.
+       * config/m68k/coff.h (REGISTER_PREFIX_MD): Delete.
+       * config/m68k/m68020-elf.h (LIB_SPEC): Delete.
+       * config/m68k/m68k-none.h (CC1_SPEC, CPP_SUBTARGET_SPEC): Delete.
+       * config/m68k/m68kelf.h (IMMEDIATE_PREFIX, REGISTER_PREFIX_MD)
+       (ASM_OUTPUT_REG_PUSH, ASM_OUTPUT_REG_POP): Delete.
+       (NO_DOLLAR_IN_LABEL, PCC_STATIC_STRUCT_RETURN): Don't undefine.
+       (BSS_ASM_OP, ASM_OUTPUT_SKIP, ASM_OUTPUT_ASCII): Delete.
+       * config/m68k/m68kemb.h (PCC_STATIC_STRUCT_RETURN): Don't undefine.
+       * config/m68k/linux.h (SIZE_TYPE, PTRDIFF_TYPE, WCHAR_TYPE)
+       (WCHAR_TYPE_SIZE, TARGET_OBJFMT_CPP_BUILTINS): Delete.
+       (TARGET_OS_CPP_BUILTINS): Don't define mc68000 and mc68020 here.
+       (DBX_REGISTER_NUMBER): Delete.
+       * config/m68k/netbsd-elf.h (IMMEDIATE_PREFIX): Delete.
+       (PCC_STATIC_STRUCT_RETURN): Don't undefine.
+       * config/m68k/openbsd.h (PCC_STATIC_STRUCT_RETURN): Define.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (m68k-*-uclinux*): Add flat.h to $tm_file.
+       * config/flat.h: New file.
+       * crtstuff.c (USE_PT_GNU_EH_FRAME): Don't define if
+       OBJECT_FORMAT_FLAT.
+       * config/m68k/m68k.h (ASM_PREFERRED_EH_DATA_FORMAT): Do not use
+       indirect references for -msep-data or -mid-shared-library.
+       Do not use PC-relative code addresses either.
+       * config/m68k/m68k.c (override_options): Restrict -fPIC error
+       to -mpcrel.
+       * config/m68k/uclinux.h (STARTFILE_SPEC): Define.  Use Scrt1.o
+       for shared libraries and crt1.o for executables.  Use crti.o and
+       crtbegin.o.
+       (ENDFILE_SPEC): Use crtend.o and crtn.o.
+       (LIB_SPEC): Suppress -Rlibc.gdb if -static-libc is given.
+       Do not add -elf2flt or -shared-lib-id options here.
+       (LINK_SPEC): Define.  Pass -elf2flt if no -elf2flt option is given.
+       Pass -shared-lib-id if -mid-shared-library, taking the library
+       identifier from -mshared-library-id if given, otherwise
+       defaulting to 0.
+       (EH_FRAME_IN_DATA_SECTION): Do not undefine.
+       (INIT_SECTION_ASM_OP, FINI_SECTION_ASM_OP): Likewise.
+       (TARGET_OS_CPP_BUILTINS): Define __GXX_MERGED_TYPEINFO_NAMES=0
+       and __GXX_TYPEINFO_EQUALITY_INLINE=0 if -mid-shared-library.
+       (DRIVER_SELF_SPECS): Map unadorned PIC options to -msep-data.
+       * config/m68k/t-uclinux (EXTRA_MULTILIB_PARTS): Add crtbegin.o
+       and crtend.o.
+       * config/m68k/lb1sf68.asm (PICCALL): Use an lea and pc-relative
+       jump sequence for ISA A and ISA A+.
+       (PICJUMP): Likewise.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (m68k-*-uclinux*): Base the port on the common
+       and m68k GNU/Linux files rather than on the generic ELF ones.
+       * config/m68k/uclinux.h (TARGET_VERSION): Override.
+       (TARGET_OS_CPP_BUILTINS): Use LINUX_TARGET_OS_CPP_BUILTINS.
+
+2007-01-18  Julian Brown  <julian@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (LONG_DOUBLE_TYPE_SIZE): Make 64-bit on ColdFire.
+       (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Likewise.
+       * config/m68k/netbsd-elf.h (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Undefine
+       before redefining.
+       * config/m68k/uclinux-oldabi.h (LONG_DOUBLE_TYPE_SIZE): Redefine to
+       80 unconditionally.
+       (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Likewise.
+
+2007-01-18  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/install.texi: Document m68k-uclinuxoldabi.
+       * config.gcc (m68k-*-uclinuxoldabi): New configuration.
+       * config/m68k/uclinux-oldabi.h: New file, copied from
+       config/m68k/uclinux.h.
+
+2007-01-18  Kaz Kojima  <kkojima@rr.iij4u.or.jp>
+
+       * config/m32r/m32r-protos.h (m32r_expand_epilogue): Declare it.
+       * config/m32r/m32r.c (m32r_setup_incoming_varargs): Use gen_frame_mem.
+       (m32r_compute_frame_size): Use unsigned for regno.
+       (m32r_reload_lr): Use gen_frame_mem.
+       (pop): New.
+       (m32r_output_function_epilogue): Don't output the function epilogue
+       textually here.
+       (m32r_expand_epilogue): New.
+       (direct_return): Return false if the function has the interrupt
+       attribute.
+       (m32r_hard_regno_rename_ok): Remove code for the textual epilogue.
+       * config/m32r/m32r.md (epilogue): New expander.
+       (return_lr, return_rte): New insns.
+       (return): Make it expander.
+       (return_normal): New expander.
+
+2007-01-18  Josh Conner  <jconner@apple.com>
+
+       PR target/30485
+       * config/rs6000/rs6000.c (rs6000_emit_vector_compare): Add
+       support for UNLE, UNLT, UNGE, and UNGT.
+
+2007-01-18  Jan Hubicka  <jh@suse.cz>
+
+       * tree-vrp.c (finalize_jump_threads): Do not call cleanup_cfg by hand.
+       * tree-tailcall (add_virtual_phis): Likewise.
+       (optimize_tail_call): Return TODOs.
+       (execute_tail_calls): Return TODOs.
+       * tree-ssa-ccp (execute_fold_all_builtins): Do cleanup_cfg via TODO.
+       * tree-cfgcleanup.c (cleanup_tree_cfg_loop): Return if something
+       changed.
+       * tree-ssa-forwprop.c (tree_ssa_forward_propagate_single_use_value):
+       Cleanup cfg using TODO.
+       * tree-flow.h (cleanup_tree_cfg_loop): Update prototype.
+       * passes.c (execute_function_todo): When cleanup did something, remove
+       unused locals.
+       * tree-cfg.c (pass_build_cfg): Add cleanup_cfg TODO.
+       (make_edges): Don't cleanup_cfg.
+
+2007-01-18  Uros Bizjak  <ubizjak@gmail.com>
+
+       * reg-stack.c (subst_stack_regs_pat) [UNSPEC_SINCOS_COS,
+       UNSPEC_XTRACT_FRACT]: Use generic code for instructions that
+       operate on the top of stack.
+       [UNSPEC_SINCOS_SIN, UNSPEC_XTRACT_EXP, UNSPEC_TAN]: Rewrite
+       register handling of instructions that output to the second
+       stack slot.
+       [UNSPEC_TAN_ONE, UNSPEC_TAN_TAN]: Remove.
+       (move_for_stack_reg): Special-case check for dead destination
+       stack slot for constant load of 1.0 inside UNSPEC_TAN.
+
+       * config/i386/i386.md (UNSPEC_TAN): New constant.
+       (UNSPEC_TAN_ONE, UNSPEC_TAN_TAN): Remove.
+       (fptanxf4_i387, fptan_extend<mode>xf4_i387): New patterns
+       to correctly model move of constant 1.0 to top stack slot.
+       (*tandf3_1, *tansf3_1, *tanxf3_1): Remove insn patterns.
+       (unnamed peephole2 pattern): Remove corresponding peephole2
+       pattern that optimizes tan insn and loading of constant 1.0.
+       (tanxf2): Use fptanxf4_i387.
+       (tan<mode>2): Rename from tansf2 and tandf2 and macroize insn
+       patterns using X87MODEF12 mode macro.  Use fptan_extend<mode>xf4_i387
+       and truncate result to requested mode.  Use SSE_FLOAT_MODE_P to
+       disable patterns for SSE math.
+       (sincos<mode>3): Use truncxf<mode>2_i387_noop for truncation.
+       (fyl2x_extend<mode>xf3_i387): Use X87MODEF12 for operand 1.
+
+2007-01-18  Dirk Mueller  <dmueller@suse.de>
+           Richard Guenther <rguenther@suse.de>
+
+       PR diagnostic/8268
+       * doc/invoke.texi (Warray-bounds): Document -Warray-bounds.
+       * common.opt (Warray-bounds): Add new warning option.
+       * c-opts.c (c_common_handle_option): Define -Warray-bounds
+       if -Wall is given.
+       * Makefile.in: make tree-vrp.o depend on toplev.h
+       * tree-vrp.c (vrp_finalize): Call check_array_refs if -Warray-bounds
+       is enabled.
+       (check_array_refs, check_array_bounds, check_array_ref): New.
+
+2007-01-18  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-ccp.c (ccp_finalize): Return if something changed.
+       (execute_ssa_ccp): Return flags conditionally.
+       * tree-ssa-propagate.c (substitue_and_fold): Return if something was
+       changed.
+       * tree-ssa-propagate.h (substitute_and_fold): Update prototype.
+
+2007-01-18  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * cfgcleanup.c (cleanup_cfg): Detect cfglayout mode and set
+       the CLEANUP_CFGLAYOUT flag when in cfglayout mode.
+
+       * Makefile.c (GTFILES): Add cfglayout.h.
+       * gengtype.c (open_base_files): Likewise.
+       * cfglayout.c (cfg_layout_function_footer,
+       cfg_layout_function_header) Reindent to make gengtype happy.
+       * cfglayout.h (cfg_layout_function_footer,
+       cfg_layout_function_header): Add GTY(()) marker.
+
+       * ifcvt.c (noce_try_sign_mask): Make sure INSN_B is non-null.
+
+2007-01-18  Ben Elliston  <bje@au.ibm.com>
+
+       * genautomata.c (write_automata): Include xstrerror output in the
+       error message if writing the DFA description file fails.
+
+2007-01-17  H.J. Lu  <hongjiu.lu@intel.com>
+
+       * config/mips/mips-protos.h (mips_output_external): Make it
+       return void.
+       * config/mips/iris.h (TARGET_ASM_EXTERNAL_LIBCALL): Removed.
+       * config/mips/mips.c (irix_output_external_libcall): Likewise.
+       (extern_list): Likewise.
+       (extern_head): Likewise.
+       (TARGET_ASM_FILE_END): Likewise.
+       (mips_file_end): Likewise.
+       (mips_output_external): Rewritten.
+
+2007-01-18  Ben Elliston  <bje@au.ibm.com>
+
+       * genpreds.c (write_insn_preds_c): Only write out the function
+       body for regclass_for_constraint if we have register constraints.
+
+2007-01-17  Tom Tromey  <tromey@redhat.com>
+
+       * doc/sourcebuild.texi (libgcj Tests): Use sourceware.org.
+       * doc/install.texi (Testing): Use sourceware.org.
+       (Binaries): Likewise.
+       (Specific): Likewise.
+       * doc/contrib.texi (Contributors): Use sourceware.org.
+
+2007-01-17  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr.h (AVR_HAVE_LPMX): New macro.
+       (AVR_ENHANCED): Rename to ...
+       (AVR_HAVE_MUL): ... new.
+       (avr_enhanced_p): Rename to ...
+       (avr_have_mul_p): ... new.
+       (TARGET_CPU_CPP_BUILTINS): Use 'avr_have_mul_p' instead of
+       'avr_enhanced_p' for "__AVR_ENHANCED__". Define "__AVR_HAVE_MUL__".
+       * config/avr/avr.c (avr_enhanced_p): Rename to ...
+       (avr_have_mul_p): ... new.
+       (base_arch_s): Rename 'enhanced' to 'have_mul'.
+       (avr_override_options): Use 'avr_have_mul_p' and 'have_mul' instead of
+       'avr_enhanced_p' and 'enhanced'.
+       (ashlhi3_out, ashrhi3_out, lshrhi3_out, avr_rtx_costs): Use
+       AVR_HAVE_MUL instead of AVR_ENHANCED.
+       * avr.md (*tablejump_enh): Use AVR_HAVE_LPMX instead of AVR_ENHANCED.
+       (mulqi3, *mulqi3_enh, *mulqi3_call, mulqihi3, umulqihi3, mulhi3,
+       *mulhi3_enh, *mulhi3_call, mulsi3, *mulsi3_call): Use AVR_HAVE_MUL
+       instead of AVR_ENHANCED.
+       (*tablejump_enh): Use AVR_HAVE_LPMX instead of AVR_ENHANCED.
+       * libgcc.S: Use __AVR_HAVE_MUL__ instead of __AVR_ENHANCED__.
+       (__tablejump__): Use __AVR_HAVE_LPMX__ instead of __AVR_ENHANCED__.
+
+2007-01-17  Ian Lance Taylor  <iant@google.com>
+
+       * vec.h (VEC_reserve_exact): Define.
+       (vec_gc_p_reserve_exact): Declare.
+       (vec_gc_o_reserve_exact): Declare.
+       (vec_heap_p_reserve_exact): Declare.
+       (vec_heap_o_reserve_exact): Declare.
+       (VEC_OP (T,A,reserve_exact)): New static inline function, three
+       versions.
+       (VEC_OP (T,A,reserve)) [all versions]: Remove handling of
+       negative parameter.
+       (VEC_OP (T,A,alloc)) [all versions]: Call ...reserve_exact.
+       (VEC_OP (T,A,copy)) [all versions]: Likewise.
+       (VEC_OP (T,a,safe_grow)) [all versions]: Likewise.
+       * vec.c (calculate_allocation): Add exact parameter.  Change all
+       callers.
+       (vec_gc_o_reserve_1): New static function, from vec_gc_o_reserve.
+       (vec_gc_p_reserve, vec_gc_o_reserve): Call vec_gc_o_reserve_1.
+       (vec_gc_p_reserve_exact, vec_gc_o_reserve_exact): New functions.
+       (vec_heap_o_reserve_1): New static function, from vec_heap_o_reserve.
+       (vec_heap_p_reserve, vec_heap_o_reserve): Call vec_heap_o_reserve_1.
+       (vec_heap_p_reserve_exact): New function.
+       (vec_heap_o_reserve_exact): New function.
+
+2007-01-17  Jan Hubicka  <jh@suse.cz>
+
+       * ipa-type-escape.c (look_for_casts): Revamp using handled_component_p.
+
+2007-01-17  Eric Christopher  <echristo@apple.com>
+
+       * config.gcc: Support core2 processor.
+
+2007-01-16  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssanames.c (release_dead_ssa_names): Instead of ggc_freeing
+       the names, just unlink the chain so we don't crash on dangling
+       pointers
+       to dead SSA names.
+
+2007-01-16  Jan Hubicka  <jh@suse.cz>
+
+       * cgraph.h (cgraph_decide_inlining_incrementally): Kill.
+       * tree-pass.h: Reorder to make IPA passes appear toegher.
+       (pass_early_inline, pass_inline_parameters, pass_apply_inline):
+       Declare.
+       * cgraphunit.c (cgraph_finalize_function): Do not compute inling
+       parameters, do not call early inliner.
+       * ipa-inline.c: Update comments.  Include tree-flow.h
+       (cgraph_decide_inlining): Do not compute inlining parameters.
+       (cgraph_decide_inlining_incrementally): Return TODOs; assume to
+       be called with function context set up.
+       (pass_ipa_inline): Remove unreachable functions before pass.
+       (cgraph_early_inlining): Simplify assuming to be called from the
+       PM as local pass.
+       (pass_early_inline): New pass.
+       (cgraph_gate_ipa_early_inlining): New gate.
+       (pass_ipa_early_inline): Turn into simple wrapper.
+       (compute_inline_parameters): New function.
+       (gate_inline_passes): New gate.
+       (pass_inline_parameters): New pass.
+       (apply_inline): Move here from tree-optimize.c
+       (pass_apply_inline): New pass.
+       * ipa.c (cgraph_remove_unreachable_nodes): Verify cgraph after
+       transforming.
+       * tree-inline.c (optimize_inline_calls): Return TODOs rather than
+       doing them by hand.
+       (tree_function_versioning): Do not allocate dummy struct function.
+       * tree-inline.h (optimize_inline_calls): Update prototype.
+       * tree-optimize.c (execute_fixup_cfg): Export.
+       (pass_fixup_cfg): Remove
+       (tree_rest_of_compilation): Do not apply inlines.
+       * tree-flow.h (execute_fixup_cfg): Declare.
+       * Makefile.in (gt-passes.c): New.
+       * passes.c: Include gt-passes.h
+       (init_optimization_passes): New passes.
+       (nnodes, order): New static vars.
+       (do_per_function_toporder): New function.
+       (execute_one_pass): Dump current pass here.
+       (execute_ipa_pass_list): Don't dump current pass here.
+
+2007-01-16  Janis Johnson  <janis187@us.ibm.com>
+
+       * config/dfp-bit.c (dfp_compare_op): Return separate value for NaN.
+       (DFP_NE, DFP_LE, DFP_GE): Return false for NaN.
+
+2007-01-16  David Edelsohn  <edelsohn@gnu.org>
+
+       * config/rs6000/darwin-ldouble.c: Build file for SOFT_FLOAT.
+       (strong_alias): Define.
+       (__gcc_qmul): Provide non-FMA for soft-float.
+       (__gcc_qdiv): Same.
+       (__gcc_qneg): New.
+       (__gcc_qeq): New.
+       (__gcc_qle): New.
+       (__gcc_qge): New.
+       (__gcc_qunord): New.
+       (__gcc_stoq): New.
+       (__gcc_dtoq): New.
+       (__gcc_qtos): New.
+       (__gcc_qtod): New.
+       (__gcc_qtoi): New.
+       (__gcc_qtou): New.
+       (__gcc_itoq): New.
+       (__gcc_utoq): New.
+       (fmsub): New.
+       * config/rs6000/rs6000.c (rs6000_init_libfuncs): Initialize
+       soft-float functions.
+       * config/rs6000/libgcc-ppc-glibc.ver: Version soft-float symbols.
+       * config/rs6000/sysv4.h (SUBTARGET_OVERRIDE_OPTIONS): Do not warn
+       about long double soft float.
+
+2007-01-16  Dorit Nuzman  <dorit@il.ibm.com>
+           Tehila Meyzels  <tehila@il.ibm.com>
+
+       * tree-vectorizer.h (is_pattern_stmt_p): New.
+       * tree-vect-analyze.c (vect_determine_vectorization_factor): Fix
+       formatting (tabs instead of spaces). Cleanup and clarify setting
+       of STMT_VINFO_VECTYPE. Call is_pattern_stmt_p.
+       * tree-vect-transform.c (vect_get_vec_def_for_operand): Fix typo.
+       (vectorizable_type_demotion): Check that types are integral.
+       (vectorizable_type_promotion): Likewise.
+       (vectorizable_store): Fix typo.  Eliminate new-line at end of
+       comments.
+
+2007-01-16  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssanames.c (release_dead_ssa_names): Remove invalidated
+       cgraph edges too.
+
+2007-01-15  Eric Christopher  <echristo@apple.com>
+
+       * ifcvt.c: Include vec.h, vecprim.h.
+       (check_cond_move_block): New argument regs.
+       Reorganize. Add registers used to regs.
+       (cond_move_process_if_block): Use regs set above as
+       loop bounds.
+
+2007-01-15  Eric Christopher  <echristo@apple.com>
+
+       * config/darwin.h: Update copyright.
+       (TARGET_OPTION_TRANSLATE_TABLE): Add umbrella.
+       (LINK_COMMAND_SPEC): Add -u.
+       (LINK_SPEC): Fix umbrella for above.
+
+2007-01-15  Joseph S. Myers  <joseph@codesourcery.com>
+
+       * config/soft-fp/op-common.h, config/soft-fp/op-4.h: Update from
+       glibc CVS.
+
+2007-01-15  Tom Tromey  <tromey@redhat.com>
+
+       * doc/sourcebuild.texi (libgcj Tests): Don't mention jacks.
+       * doc/install.texi (Testing): Don't mention jacks.
+       (Configuration): Document --enable-java-maintainer-mode.  Move
+       --with-java-home to libgcj-specific section.  Document
+       --with-ecj-jar.
+       (Prerequisites): Mention --enable-java-maintainer-mode, ecj1.
+
+2007-01-15  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-dce.c (DCE_TODOs): New.
+       (propagate_necessity): Return if something changed.
+       (eliminate_unnecessary_stmts): Likewise.
+       (perform_tree_ssa_dce): Return TODO flags when needed.
+       (pass_dce, pass_dce_loop, pass_cd_dce): Remove TODO flags.
+
+2007-01-15  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (fyl2xxf3_i387): Rename from fyl2x_xf3.
+       (fyl2x_extend<mode>xf3_i387): New insn pattern.
+       (log<mode>2): Rename from logsf2 and logdf2 and macroize insn
+       patterns using X87MODEF12 mode macro.  Extend operand 1
+       to XFmode. Use SSE_FLOAT_MODE_P to disable patterns for SSE math.
+       (log10<mode>2): Ditto.
+       (log2<mode>2): Ditto.
+       (log1p<mode>2): Ditto.
+       (logb<mode>2): Ditto.
+       (fyl2xp1xf3_i387): Rename from fyl2xp1_xf3.
+       (fyl2xp1_extend<mode>xf3_i387): New insn pattern.
+       (*fxtractxf3_i387): Rename from *fxtractxf3.
+       (fxtract_extend<mode>xf3_i387): New insn pattern.
+       (ilogbsi2): Use match_dup 3, not match_operand:XF 3.
+       * config/i386/i386.c (ix86_emit_i387_log1p): Use gen_fyl2xp1xf3_i387()
+       and gen_fyl2xxf3_i387().
+
+2007-01-14  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * loop-unswitch.c (unswitch_loop): Do not call fix_loop_placement.
+       * cfgloopmanip.c (fix_loop_placement): Made static.  Use
+       get_loop_exit_edges.  Changed return type to bool.
+       * cfgloop.h (fix_loop_placement): Declaration removed.
+
+2007-01-14  Dorit Nuzman  <dorit@il.ibm.com>
+
+       * param.h (MIN_VECT_LOOP_BOUND): New.
+       * params.def (MIN_VECT_LOOP_BOUND): New.
+       * tree-vectorizer.c (slpeel_tree_peel_loop_to_edge): Takes another
+       argument - minimum threshold for number of iterations.
+       * tree-vectorizer.h (slpeel_tree_peel_loop_to_edge): Add another
+       argument to declaration.
+       * tree-vect-analyze.c (vect_analyze_operations): Check value of
+       MIN_VECT_LOOP_BOUND.
+       * tree-vect-transform.c (vect_do_peeling_for_loop_bound): Call
+       slpeel_tree_peel_loop_to_edge with additional argument.
+       (vect_do_peeling_for_alignment): Likewise.
+       * doc/invoke.texi (min-vect-loop-bound): Document new param option.
+
+2007-01-14  Uros Bizjak  <ubizjak@gmail.com>
+
+       PR target/30413
+       * config/i386/i386.c (print_operand) ['z']: Output 'b' for
+       operands of size 1.
+
+2007-01-14  Jan Hubicka  <jh@suse.cz>
+
+       * tree-dfa.c (remove_referenced_var): New function.
+       * tree-ssa-live.c (remove_unused_locals): Walk referenced vars and
+       prune referenced vars list too.
+       * tree-flow.h (remove_referenced_var): Declare.
+
+2007-01-14  Jan Hubicka  <jh@suse.cz>
+
+       * tree-eh.c (add_stmt_to_eh_region_fn): Do not add call_exprs
+       separately.
+       (remove_stmt_from_eh_region_fn): Do not remove call_exprs.
+       (verify_eh_throw_stmt_node, verify_eh_throw_table_statements): Kill.
+       * except.h (verify_eh_throw_table_statements): Kill prototype.
+       * cfgexpand.c (expand_gimple_basic_block): Propagate Eh regions
+       into call exrepssions.
+       * tree-optimize.c (execute_free_cfg_annotatiosn): Do not call
+       eh trhow verifier.
+       * tree-cfg.c: Include pointer-set.h.
+       (verify_node_sharing): Work on pointer set.
+       (verify_eh_throw_stmt_node): New.
+       (verify_stmts): Use pointers sets, verify throw_stmt.
+
+2007-01-13  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * ipa-reference.c (analyze_function): Consider also addresses taken
+       in phi nodes.
+
+2007-01-12  Roger Sayle  <roger@eyesopen.com>
+
+       * c-typeck.c (null_pointer_constant_p): Replace use of
+       TREE_CONSTANT_OVERFLOW with TREE_OVERFLOW.
+       (build_c_cast): Likewise.
+
+2007-01-12  Roger Sayle  <roger@eyesopen.com>
+
+       * tree.h (force_fit_type_double): Remove unused final argument.
+       * c-common.c (constant_expression_warning): Replace use of
+       TREE_CONSTANT_OVERFLOW with TREE_OVERFLOW.
+       (convert_and_check): Likewise.
+       (shorten_compare): Update call to force_fit_type_double.
+       (c_common_truthvalue_conversion) <INTEGER_CST>: Use integer_zerop.
+       * convert.c (convert_to_pointer): Update call to
+       force_fit_type_double.
+       * fold-const.c (force_fit_type_double): Remove overflowed_const
+       argument.
+       (int_const_binop, fold_convert_const_int_from_int,
+       fold_convert_const_int_from_real, fold_div_compare,
+       fold_sign_changed_comparison, fold_unary, fold_negate_const,
+       fold_abs_const, fold_not_const): Remove the final argument from
+       calls to force_fit_type_double.
+
+2007-01-12  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       * configure.ac: Set insn to "nop" for spu-*-* also.
+       * configure: Regenerate.
+
+2007-01-12  Olga Golovanevsky  <olga@il.ibm.com>
+
+       * builtins.def : Add BUILT_IN_FREE.
+
+2007-01-12  Jan Hubicka  <jh@suse.cz>
+
+       PR tree-optimization/30443
+       * tree-inline.c (tree_function_versioning): Do not optimize when
+       cloning for inlining.
+
+2007-01-12  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * doc/loop.texi: Document recording of loop exits.
+       * cfgloopmanip.c (loopify, duplicate_loop): Use alloc_loop.
+       (update_single_exits_after_duplication,
+       update_single_exit_for_duplicated_loop,
+       update_single_exit_for_duplicated_loops): Removed.
+       (duplicate_loop_to_header_edge): Do not call
+       update_single_exits_after_duplication and
+       update_single_exit_for_duplicated_loops.
+       (loop_version): Do not update single_exit information.
+       (fix_loop_structure): Use record_loop_exits instead of
+       mark_single_exit_loops.
+       * tree-ssa-loop-manip.c (tree_transform_and_unroll_loop): Update
+       the lists of loop exits.
+       * cfghooks.c (redirect_edge_and_branch, redirect_edge_and_branch_force,
+       split_edge, merge_blocks): Update the lists of loop exits.
+       * modulo-sched.c (sms_schedule): Pass LOOPS_HAVE_RECORDED_EXITS to
+       loop_optimizer_init.
+       * loop-init.c (loop_optimizer_init): Call record_loop_exits instead
+       of mark_single_exit_loops.
+       (loop_optimizer_finalize): Call release_recorded_exits.
+       * tree-ssa-loop.c (tree_loop_optimizer_init): Pass
+       LOOPS_HAVE_RECORDED_EXITS to loop_optimizer_init.
+       * tree-vectorizer.c (slpeel_tree_duplicate_loop_to_edge_cfg): Do not
+       update single exit information.
+       * lambda-code.c (perfect_nestify): Ditto.
+       * cfgloop.c (flow_loop_free): Destroy the list of exits of the loop.
+       (mark_single_exit_loops): Removed.
+       (alloc_loop, loop_exit_hash, loop_exit_eq, loop_exit_free,
+       get_exit_descriptions, rescan_loop_exit, record_loop_exits,
+       dump_recorded_exit, dump_recorded_exits, release_recorded_exits): New
+       functions.
+       (get_loop_exit_edges, single_exit): Use recorded exit lists.
+       (add_bb_to_loop, remove_bb_from_loops): Update the lists of loop exits.
+       (verify_loop_structure): Verify consistency of the exit lists.
+       (flow_loops_find): Use alloc_loop.  Initialize exits hash.
+       (set_single_exit): Removed.
+       * cfgloop.h (struct loop_exit): New function.
+       (struct loop): single_exit_ field replaced by exits field.
+       (LOOPS_HAVE_MARKED_SINGLE_EXITS): Replaced by
+       LOOPS_HAVE_RECORDED_EXITS.
+       (struct loops): Added exits hash.
+       (mark_single_exit_loops, set_single_exit): Declaration removed.
+       (release_recorded_exits, record_loop_exits, rescan_loop_exit): Declare.
+
+2007-01-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi: Avoid use of @headitem.
+
+2007-01-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * cse.c (cse_insn): Move HAVE_CC0 code after declarations.
+
+2007-01-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/install.texi: Fix m68k-*-* anchor and add m68k-*-* to the
+       list of targets.
+
+2007-01-12  Nathan Sidwell  <nathan@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi: Document -mno-bitfield, -mno-rtd and -mno-short.
+       * config/m68k/m68k.opt: Resort options.
+       (mbitfield, mrtd, mshort): Remove RejectNegative properties.
+
+2007-01-12  Nathan Sidwell  <nathan@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * doc/invoke.texi: Document the macros that are defined by
+       m68k's -mtune and -mhard-float options.
+       * config/m68k/m68k-protos.h (m68k_cpp_cpu_ident) Declare.
+       (m68k_cpp_cpu_family): Likewise.
+       * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Add a full set
+       of __ucfv*__ macros.  Define __mcffpu__ if generating code for
+       ColdFire FPUs.  Define __mcf_cpu_* and __mcf_family_* macros.
+       * config/m68k/m68k.c (m68k_cpp_cpu_ident): New function.
+       (m68k_cpp_cpu_family): Likewise.
+
+2007-01-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Treat all mc68*
+       macros besides mc68000 as tuning macros.  Use a switch statement
+       to set them and mcpu32.
+
+2007-01-12  Julian Brown  <julian@codesourcery.com>
+
+       * config/m68k/m68k.h: Use TARGET_68040 instead of TARGET_68040_ONLY.
+       (TARGET_68040_ONLY): Rename to...
+       (TARGET_68040): ...this.
+       * config/m68k/m68k.c: Use TARGET_68040 instead of TARGET_68040_ONLY.
+       * config/m68k/m68k.md: Likewise.
+
+2007-01-12  Julian Brown  <julian@codesourcery.com>
+           Nathan Sidwell  <nathan@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (m680[012]0-*-*, m68k*-*-*): Set m68k_cpu_ident to
+       the -mcpu= argument associated with the --with-cpu setting.
+       Define M68K_DEFAULT_TUNE to the default -mtune= option,
+       if different from the one implied by the -mcpu setting.
+       Accept --with-cpu=FOO if FOO is listed in m68k-devices.def,
+       using mcpu=FOO as the default CPU option.  Set target_cpu_default2.
+       * doc/invoke.texi: Mention ColdFire in the introduction to the
+       m68k options.  Document the new -march, -mcpu, -mtune, -mdiv,
+       -mno-div and -mhard-float options.  Make -m68881 a synonym for
+       -mhard-float.  Document the previously-undocumented -m5206e,
+       -m528x, -m5307 and -m5407 options.  Tweak the existing option
+       documentation for consistency.
+       * doc/install.texi: Mention new --with-cpu arguments.
+       * config/m68k/m68k.h (OPTION_DEFAULT_SPECS): Only use the
+       default CPU if neither -mcpu nor -march are specified.
+       (ASM_CPU_SPEC): Pass down -mcpu and -march options.
+       (TARGET_CPU_CPP_BUILTINS): Set __mcfisa*__ macros from
+       TARGET_ISA*.  Set the legacy __mcf*__ cpu macros in the same way,
+       using m68k_tune to decide between families that implement the
+       same ISA.  Use m68k_tune to set __mcfv4e__.
+       (FL_BITFIELD, FL_68881, FL_COLDFIRE, FL_CF_HWDIV, FL_CF_MAC)
+       (FL_CF_EMAC, FL_CF_EMAC_B, FL_CF_USP, FL_CF_FPU, FL_ISA_68000)
+       (FL_ISA_68010, FL_ISA_68020, FL_ISA_68040, FL_ISA_A, FL_ISA_B)
+       (FL_ISA_C, FL_ISA_MMU): New macros.
+       (MASK_COLDFIRE): Delete.
+       (TARGET_68010, TARGET_68020, TARGET_68040_ONLY, TARGET_COLDFIRE)
+       (TARGET_ISAB): Redefine in terms of m68k_cpu_flags.
+       (TARGET_68881, TARGET_COLDFIRE_FPU): Redefine in terms of m68k_fpu.
+       (TARGET_HARD_FLOAT): Do not define here.
+       (TARGET_ISAAPLUS, TARGET_ISAC): New macros.
+       (TUNE_68000): New macro.
+       (TUNE_68000_10): Redefine in terms of TUNE_68000 and TUNE_68010.
+       (TUNE_68010, TUNE_68030, TUNE_68040, TUNE_68060, TUNE_CPU32)
+       (TUNE_CFV2): Redefine in terms of m68k_tune.
+       (uarch_type, target_device, fpu_type): New enums.
+       (m68k_cpu, m68k_tune, m68k_fpu, m68k_cpu_flags): Declare.
+       * config/m68k/m68k.c (TARGET_DEFAULT): Remove MASK_68881.
+       (FL_FOR_isa_00, FL_FOR_isa_10, FL_FOR_isa_20, FL_FOR_isa_40)
+       (FL_FOR_isa_cpu32, FL_FOR_isa_a, FL_FOR_isa_aplus, FL_FOR_isa_b)
+       (FL_FOR_isa_c): New macros.
+       (m68k_isa): New enum.
+       (m68k_target_selection): New structure.
+       (all_devices, all_isas, all_microarchs): New tables.
+       (m68k_cpu_entry, m68k_arch_entry, m68k_tune_entry, m68k_cpu)
+       (m68k_tune, m68k_fpu, m68k_cpu_flags): New variables.
+       (MASK_ALL_CPU_BITS): Delete.
+       (m68k_find_selection): New function.
+       (m68k_handle_option): Handle -mcpu=, -march= and -mtune=.
+       Map the legacy target options to a combination of the new ones.
+       (override_options): Set m68k_cpu, m68k_tune, m68k_fpu and
+       m68k_cpu_flags.  Handle M68K_DEFAULT_TUNE.  Use m68k_cpu_flags
+       to derive default MASK_BITFIELD, MASK_CF_HWDIV and MASK_HARD_FLOAT
+       settings.
+       * config/m68k/m68k.opt (m5200, m5206e, m528x, m5307, m5407, mcfv4e)
+       (m68010, m68020, m68020-40, m68020-60, m68030, m68040): Remove Mask
+       properties.
+       (m68881, msoft-float): Change mask from 68881 to HARD_FLOAT.
+       (march=, mcpu=, mdiv, mhard-float, mtune=): New options.
+       * config/m68k/m68k-devices.def: New file.
+
+2007-01-12  Richard Sandiford  <richard@codesourcery.com>
+           Nathan Sidwell  <nathan@codesourcery.com>
+
+       * config/m68k/m68k.h (ASM_CPU_SPEC, ASM_SPEC, EXTRA_SPECS)
+       (SUBTARGET_EXTRA_SPECS): New macros.
+       * config/m68k/linux.h (ASM_SPEC): Remove CPU flags;
+       use %(asm_cpu_spec) instead.
+       * config/m68k/m68k-none.h (ASM_SPEC): Likewise.
+       * config/m68k/openbsd.h (ASM_SPEC): Likewise.
+       * config/m68k/netbsd-elf.h (ASM_SPEC): Likewise.
+       (EXTRA_SPECS): Rename to...
+       (SUBTARGET_EXTRA_SPECS): ...this.
+
+2007-01-12  Nathan Sidwell  <nathan@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+           Julian Brown  <julian@codesourcery.com>
+
+       * config.gcc (m68k-*-aout*, m68k-*-coff*, m68020-*-elf*, m68k-*-elf*)
+       (m68k-*-uclinux*, m68k-*-linux*, m68k-*-rtems*): Set default_m68k_cpu
+       to the configuration's default CPU.
+       (m68010-*-netbsdelf*, m68k*-*-netbsdelf*, m68k*-*-openbsd*): Likewise.
+       Remove default masks.
+       (m680[012]0-*-*): Set the default with_cpu to the first part of
+       the target name.
+       (m68k*-*-*): Set the default with_cpu to m$default_m68k_cpu.
+       (m68k*-*-linux): Extend the --with-cpu handling to...
+       (m680[012]0-*-*, m68k*-*-*): ...these configurations.  Allow m68000
+       and m68010.  Don't set target_cpu_default2.
+       * doc/install.texi: Document --with-cpu for m68k.
+       * config/m68k/m68k.h (OPTION_DEFAULT_SPECS): Define.
+       * config/m68k/m68k-none.h (TARGET_CPU_DEFAULT, M68K_CPU_m68k)
+       (M68K_CPU_m68000, M68K_CPU_m68010, M68K_CPU_m68020, M68K_CPU_m68030)
+       (M68K_CPU_m68040, M68K_CPU_m68302, M68K_CPU_m68332, TARGET_DEFAULT)
+       (ASM_CPU_DEFAULT_SPEC, CC1_CPU_DEFAULT_SPEC): Delete.
+       (ASM_SPEC): Remove use of %(asm_cpu_default).
+       (EXTRA_SPECS, SUBTARGET_EXTRA_SPECS, MULTILIB_DEFAULTS): Delete.
+       * config/m68k/linux.h (TARGET_DEFAULT): Delete.
+       (CPP_SPEC): Merge definitions.  Do not handle __HAVE_68881__ here.
+       * config/m68k/netbsd-elf.h (TARGET_OS_CPP_BUILTINS): Define
+       __HAVE_FPU__ if TARGET_HARD_FLOAT.
+       (TARGET_DEFAULT): Delete.
+       (EXTRA_SPECS): Delete cpp_cpu_default_spec, cpp_cpu_spec,
+       cpp_fpu_spec, asm_default_spec and netbsd_cpp_spec.
+       (CPP_CPU_SPEC): Delete.
+       (TARGET_VERSION): Merge definitions, using TARGET_68010 to pick
+       the appropriate string.
+       (CPP_CPU_DEFAULT_SPEC, ASM_DEFAULT_SPEC, CPP_FPU_SPEC): Delete.
+       (CPP_SPEC): Define to NETBSD_CPP_SPEC.
+       (ASM_SPEC): Don't use %(asm_default_spec).
+       * config/m68k/m68k.c (TARGET_DEFAULT_TARGET_FLAGS): Remove
+       TARGET_DEFAULT and add MASK_68881.
+       * config/m68k/m68k.md: Remove mention of TARGET_DEFAULT from comments.
+
+2007-01-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config.gcc (m68010-*-netbsdelf*): Add MASK_68010.
+       (m68k*-*-netbsdelf*, m68k*-*-openbsd*, m68k*-linux*): Add
+       MASK_68010 alongside MASK_68020.
+       * doc/invoke.texi: Document -m68010.
+       * config/m68k/m68k.opt (m68010): New.
+       * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Define mc68010
+       if TUNE_68010.
+       (TUNE_68010): New macro.
+       * config/m68k/m68k-none.h (M68K_CPU_m68k, M68K_CPU_m68010)
+       (M68K_CPU_m68020, M68K_CPU_m68030, M68K_CPU_m68040)
+       (M68K_CPU_m68332): Add MASK_68010.
+       * config/m68k/linux.h (TARGET_DEFAULT): Add MASK_68010 to
+       fallback definition.
+       * config/m68k/netbsd-elf.h (CPP_CPU_SPEC): Remove now-redundant
+       defines.
+       * config/m68k/m68k.c (MASK_ALL_CPU_BITS): Add MASK_68010.
+       (m68k_handle_option): Handle OPT_m68010.  Add MASK_68010
+       to all entries that use MASK_68020.
+       (output_move_simode_const, output_move_himode, output_move_qimode)
+       (output_move_stricthi, output_move_strictqi): Use TARGET_68010
+       instead of TARGET_68020 to select clr behavior.  Remove comment
+       about there being no TARGET_68010.
+       * config/m68k/m68k.md: Likewise throughout.
+
+2007-01-12  Julian Brown  <julian@codesourcery.com>
+
+       * config/m68k/m68k.h (TARGET_ISAB): New macro.
+       * config/m68k/m68k.c: Use TARGET_ISAB rather than TARGET_CFV4.
+       * config/m68k/m68k.md: Likewise.
+
+2007-01-12  Julian Brown  <julian@codesourcery.com>
+
+       * config/m68k/m68k.h (LEGITIMATE_INDEX_P, LEGITIMIZE_ADDRESS): Use
+       TARGET_COLDFIRE_FPU instead of TARGET_CFV4E.
+
+2007-01-12  Julian Brown  <julian@codesourcery.com>
+
+       * config/m68k/m68k.h (TUNE_68040_60): New macro.
+       * config/m68k/m68k.c (standard_68881_constant_p): Use it.
+       * config/m68k/m68k.md: Likewise.
+
+2007-01-12  Julian Brown  <julian@codesourcery.com>
+           Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Use TUNE_68030
+       instead of TARGET_68030, TUNE_68040 instead of TARGET_68040,
+       TUNE_68060 instead of TARGET_68060 and TUNE_CPU32 instead of
+       TARGET_CPU32.
+       (TARGET_CPU32): Rename to...
+       (TUNE_CPU32): ...this.
+       (TUNE_68000_10, TUNE_68030, TUNE_68040, TUNE_68060)
+       (TUNE_CFV2): New macros.
+       * config/m68k/netbsd-elf.h (LONG_DOUBLE_TYPE_SIZE): Simplify;
+       remove conditions that are implied by TARGET_68020.
+       * config/m68k/m68k.c (m68k_output_function_prologue): Use TUNE_68040
+       instead of TARGET_68040 and TUNE_CPU32 instead of TARGET_CPU32.
+       (m68k_output_function_epilogue): Likewise.
+       (m68k_rtx_costs): Likewise.  Use TUNE_68060 instead of TARGET_68060
+       and TUNE_CFV2 instead of TARGET_5200.  Use TUNE_68000_10 instead of
+       "!TARGET_68020 && !TARGET_COLDFIRE" to choose between 68000 and
+       non-68000 timings.  Refactor multiplication and division costs.
+       (output_addsi3): Use TUNE_68040 instead of TARGET_68040 and
+       TUNE_CPU32 instead of TARGET_CPU32.
+       (standard_68881_constant_p): Use TUNE_68040 instead of TARGET_68040
+       and TUNE_68060 instead of TARGET_68060.
+       * config/m68k/m68k.md: Use TUNE_68040 instead of TARGET_68040,
+       TUNE_68060 instead of TARGET_68060, and TUNE_CPU32 instead of
+       TARGET_CPU32.
+       (movsi_const0): Use TUNE_68000_10 rather than "!TARGET_68020
+       && !TARGET_COLDFIRE" to choose between moveq and clr.
+       Likewise in the unnamed movsf pattern.
+       (ashlsi_17_24, lshrsi_17_24): Guard with TUNE_68000_10 rather than
+       "!TARGET_68020 && !TARGET_COLDFIRE".  Likewise the unnamed
+       ashiftrt pattern.
+
+2007-01-12  Richard Sandiford  <richard@codesourcery.com>
+
+       * config/m68k/m68k.h (TARGET_CPU_CPP_BUILTINS): Increase amount
+       of tabbing before backslashes.
+
+2007-01-11  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
+
+       * pa-linux.h (ASM_OUTPUT_INTERNAL_LABEL): Undefine.
+       * pa.h (ASM_OUTPUT_LABEL): Output colon when using GAS.
+       (ASM_OUTPUT_INTERNAL_LABEL): Define.
+
+2007-01-11  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * tree-ssa-loop-ivopts.c (extract_cond_operands): Split from
+       find_interesting_uses_cond.
+       (find_interesting_uses_cond): Use extract_cond_operands.
+       (rewrite_use_compare): Use extract_cond_operands and
+       force_gimple_operand_bsi.  Do not call update_stmt.
+       (determine_use_iv_cost_condition): Use extract_cond_operands.
+       Return cheaper of using original bound and changing the exit bound.
+
+2007-01-11  Zdenek Dvorak <dvorakz@suse.cz>
+
+       PR tree-optimization/29516
+       * tree-ssa-address.c (tree_mem_ref_addr, add_to_parts,
+       most_expensive_mult_to_index, addr_to_parts,
+       create_mem_ref, maybe_fold_tmr): Make the type of
+       fields of TARGET_MEM_REF sizetype.
+       (move_fixed_address_to_symbol, move_pointer_to_base):
+       New functions.
+       * tree.def (TARGET_MEM_REF): Add comment on types of
+       the operands.
+
+2007-01-11  Joseph Myers  <joseph@codesourcery.com>
+
+       * c-common.c (vector_types_convertible_p): Treat opaque types as
+       always convertible if they have the same size, but not otherwise.
+
+2007-01-11  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * ifcvt.c (struct noce_if_info): Add comments to the fields.
+       Remove the b_unconditional field.
+       (noce_try_sign_mask): Do not look at b_unconditional.
+       (noce_process_if_block): Do not use merge_if_blocks.  Update
+       the CFG here.  Do not set b_unconditional.
+       (cond_move_process_if_block): Likewise.
+       (find_cond_trap): Likewise.
+       (check_cond_move_block): Require simple jump insns at the end
+       of the basic block.
+
+2007-01-11  Jan Hubicka  <jh@suse.cz>
+
+       PR tree-optimization/1046
+       * tree-tailcall.c (suitable_for_tail_call_opt_p): Use TREE_ADDRESSABLE
+       when alias info is not ready.
+       (pass_tail_recursion): Do not require aliasing.
+       * tree-ssa-copyrename.c (pass_rename_ssa_cop): Likewise.
+       * tree-ssa-ccp.c (pass_ccp, pass_fold_builtins): Likewise.
+       * tree-ssa-copy.c (pass_copy_prop): Likewise.
+       * tree-ssa-forwprop.c (pass_forwprop): Likewise.
+       * tree-ssa-dce.c (pass_dce, pass_dce_loop, pass_cd_dce): Likewise.
+       * passes.c (init_optimization_passes): Execute rename_ssa_copies,
+       ccp, forwprop, copy_prop, merge_phi, copy_prop, dce and tail recursion
+       before inlining.
+       * tree-ssa-operands.c (add_virtual_operand, get_indirect_ref_operand):
+       When aliasing is not build, mark statement as volatile.
+
+2007-01-11  Tom Tromey  <tromey@redhat.com>
+
+       PR preprocessor/15185
+       PR preprocessor/20989
+       * doc/cppopts.texi <-MT>: Update description of algorithm for
+       computing default target.
+       <-M, -MD>: Reword "basename" text.
+
+2007-01-11  Roger Sayle  <roger@eyesopen.com>
+
+       * builtins.c (expand_builtin_pow, expand_builtin_powi,
+       fold_builtin_cabs, fold_builtin_sqrt, fold_builtin_trunc,
+       fold_builtin_floor, fold_builtin_ceil, fold_builtin_round,
+       fold_builtin_int_int_roundingfn, fold_builtin_bitop,
+       fold_builtin_bswap, real_constp, fold_builtin_pow,
+       fold_builtin_powi, fold_builtin_signbit, fold_builtin_copysign,
+       do_mpfr_arg1, do_mpfr_arg2, do_mpfr_arg3, do_mpfr_sincos): Replace
+       uses of the macro TREE_CONSTANT_OVERFLOW with TREE_OVERFLOW.
+       * convert.c (convert_to_pointer): Likewise.
+       * expr.c (highest_pow2_factor, expand_expr_real_1): Likewise.
+       * fold-const.c (force_fit_type, fold_negate_expr, int_const_binop,
+       const_binop, fold_convert_const_int_from_int,
+       fold_convert_const_int_from_real,
+       fold_convert_const_real_from_real, sign_bit_p,
+       optimize_minmax_comparison, extract_muldiv_1, fold_div_compare,
+       fold_sign_changed_comparison, fold_unary, fold_comparison,
+       fold_binary, multiple_of_p, tree_Expr_non_zero_p,
+       fold_negate_const, fold_abs_const, fold_not_const): Likewise.
+       * print-tree.c (print_node_brief, print_node): Likewise.
+       * stor-layout.c (place_field, layout_type): Likewise.
+       * tree-chrec.c (keep_cast): Likewise.
+       * tree.c (build_vector, build_real, build_real_from_int_cst,
+       build_complex): Likewise.
+
+2007-01-11  Roger Sayle  <roger@eyesopen.com>
+
+       * tree.h (TREE_CONSTANT_OVERFLOW): Obsolete.  For the time being,
+       treat TREE_CONSTANT_OVERFLOW as a synonym of TREE_OVERFLOW.
+
+2007-01-11  Paolo Bonzini  <bonzini@gnu.org>
+
+       * configure.ac (strict1_warn): Rename to strict_warn.
+       (WERROR, --enable-werror, symlink hacks, stage1_cflags,
+       cc_set_by_configure, quoted_cc_set_by_configure,
+       stage_prefix_set_by_configure, quoted_stage_prefix_set_by_configure,
+       all_boot_languages, all_stagestuff): Remove.
+       (target_list): Remove bootstrap targets.
+       * Makefile.in (quickstrap): Unconditionally make a synonym of all.
+       (BOOT_LANGUAGES, STAGE1_CFLAGS, STAGE1_CHECKING,
+       REMAKEFLAGS, FLAGS_TO_PASS, PREPEND_DOTDOT_TO_RELATIVE_PATHS,
+       SUBDIR_FLAGS_TO_PASS, WERROR_FLAGS, STRICT2_WARN, LANG_STAGESTUFF,
+       VOL_FILES, POSTSTAGE1_FLAGS_TO_PASS, STAGE2_FLAGS_TO_PASS,
+       STAGEPROFILE_FLAGS_TO_PASS, STAGEFEEDBACK_FLAGS_TO_PASS, stage1_build,
+       stage1_copy, stage2_build, stage2_copy, stageprofile_build,
+       stageprofile_copy, stage3_build, stage3_copy, stagefeedback_build,
+       stagefeedback_copy, stage4_build, clean_s1, clean_sw, bootstrap,
+       bootstrap-lean, bootstrap2, bootstrap2-lean, bootstrap3,
+       bootstrap3-lean, bootstrap4, bootstrap4-lean, unstage1, unstage2,
+       unstage3, unstage4, unstageprofile, unstagefeedback, restage, restage2,
+       restage3, restage4, restageprofile, restagefeedback, bubbleestrap,
+       cleanstrap, unstrap, restrap, *compare, *compare3, *compare4,
+       *compare-lean, *compare3-lean, *compare4-lean, stage1-start, stage1,
+       stage2-start, stage2, stage3-start, stage3, stage4-start, stage4,
+       stageprofile-start, stageprofile, stagefeedback-start, stagefeedback,
+       risky-stage1, risky-stage2, risky-stage3, risky-stage4): Remove.
+       (ORDINARY_FLAGS_TO_PASS): Rename to FLAGS_TO_PASS.
+       (STAGECOPYSTUFF, STAGEMOVESTUFF): Consolidate into MOSTLYCLEANFILES.
+       (mostlyclean): Adjust.
+       (clean, distclean): Don't mention bootstrap stuff.
+       * configure: Regenerate.
+       * ada/config-lang.in, cp/config-lang.in, forttran/config-lang.in,
+       java/config-lang.in, objc/config-lang.in, objcp/config-lang.in,
+       treelang/config-lang.in (stagestuff): Remove.
+       * doc/sourcebuild.texi (stage1, stage2, stage3, stage4,
+       stageprofile, stagefeedback, stagestuff): Remove mention.
+
+2007-01-11  Nick Clifton  <nickc@redhat.com>
+
+       * config/mcore/predicates.md (mcore_general_movesrc_operand):
+       Accept CONSTs.
+       (mcore_general_movdst_operand): Do not accept CONST_INTs.
+       (mcore_arith_K_S_operand): Run the test for the S constraint not
+       the test for the M constraint.
+       (mcore_addsub_operand): Do not accept integer values that are
+       larger than 32 bits.
+       * config/mcore/mcore.md: Remove unused constraints from split.
+       (andsi3): Use HOST_WIDE_INT instead of int to hold an INTVAL.
+       (addsi3): Likewise.
+       (allocate_stack): Likewise.
+       * config/mcore/mcore.c (mcore_print_operand): Restrict output of P
+       operands to 32 bits.
+       (mcore_const_costs): Use HOST_WIDE_INT instead of int to hold an
+       INTVAL.
+       (mcore_and_cost, mcore_modify_comparison, const_ok_for_mcore,
+       mcore_const_ok_for_inline, mcore_const_trick_uses_not,
+       try_constant_tricks, mcore_num_ones, mcore_num_zeros,
+       mcore_output_bclri, mcore_output_andn, output_inline_const,
+       mcore_output_move, mcore_output_movedouble): Likewise.
+       (mcore_output_cmov): Use CONST_OK_FOR_M and CONST_OK_FOR_N.
+       (output_inline_const): Likewise.
+       (output_inline_const): Fix format strings used in sprintf
+       statements.
+       * config/mcore/mcore-protos.h: Update prototypes for changed
+       functions in mcore.c.
+       * config/mcore/mcore.h (CONST_OK_FOR_I): Cast values to
+       HOST_WIDE_INT and not int.
+       (CONST_OK_FOR_J, CONST_OK_FOR_K, CONST_OK_FOR_L, CONST_OK_FOR_M,
+       CONST_OK_FOR_N): Likewise.
+       (LEGITIMATE_CONSTANT_P): Also check CONSTANT_P.
+       (GO_IF_LEGITIMATE_INDEX): Use HOST_WIDE_INT instead of int to hold
+       an INTVAL.
+
+2007-01-10  Jan Hubicka  <jh@suse.cz>
+
+       * tree-vrp.c (remove_range_assertions): Release defs.
+       * tree-ssa-loop-ivopts.c (rmeove_statement): Likewise.
+       * tree-ssa-dom.c (remove_stmt_or_phi): Likewise.
+
+2007-01-10  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/arm.c (arm_rtx_costs_1): Handle mutiply-subtract.
+       * config/arm/arm.md (mulsi3subsi): New insn.
+
+2007-01-10  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * tree-ssa-loop-manip.c (tree_unroll_loop): Make it a wrapper over ...
+       (tree_transform_and_unroll_loop): New.
+       * tree-flow.h (transform_callback, tree_transform_and_unroll_loop):
+       Declare.
+
+2007-01-10  Robert Kennedy <jimbob@google.com>
+
+       * fold-const.c (fold_comparison): Fold comparisons like (x *
+       1000 < 0) to (x < 0).
+
+2007-01-10  Ian Lance Taylor  <iant@google.com>
+
+       * tree-pretty-print.c (dump_generic_node): Print parentheses when
+       operands have the same priority.
+
+2007-01-10  Tom Tromey  <tromey@redhat.com>
+
+       * fold-const.c (fold_truthop): Don't check can_use_bit_fields_p.
+       (fold_binary): Likewise.
+       * langhooks.c (lhd_can_use_bit_fields_p): Removed.
+       * langhooks-def.h (lhd_can_use_bit_fields_p): Removed.
+       (LANG_HOOKS_CAN_USE_BIT_FIELDS_P): Removed.
+       (LANG_HOOKS_INITIALIZER): Remove LANG_HOOKS_CAN_USE_BIT_FIELDS_P.
+       * langhooks.h (struct lang_hooks): Removed field
+       'can_use_bit_fields_p'.
+
+2007-01-10  Ralf Corsépius <ralf.corsepius@rtems.org>
+
+       * config/bfin/t-bfin, config/bfin/t-bfin-elf: Remove GCC_CFLAGS.
+
+2007-01-10  Razya Ladelsky  <razya@il.ibm.com>
+
+       * function.c (get_last_funcdef_no): New function.
+       * function.h (get_last_funcdef_no): Declare.
+       * tree-inline.c (initialize_cfun): Add initialization.
+       (tree_function_versioning): Cleanup.
+
+2007-01-10  Jan Hubicka  <jh@suse.cz>
+
+       * tree-inline.c (setup_one_parameter): Do not propagate into abnormal
+       PHIs.
+
+2007-01-10  Sa Liu  <saliu@de.ibm.com>
+           Ben Elliston  <bje@au.ibm.com>
+
+       * spu.h (STACK_SAVE_AREA): Use VOIDmode for SAVE_FUNCTION, SImode
+       for SAVE_NONLOCAL and Pmode for any other save level.
+       * spu-protos.h (spu_restore_stack_block): Declare.
+       * spu.md (save_stack_block): Remove.
+       (restore_stack_block): Call spu_restore_stack_block.
+       * spu.c (spu_restore_stack_block): New function.
+       (spu_expand_epilogue): Remove old comment.
+
+2007-01-09  Zdenek Dvorak <dvorakz@suse.cz>
+
+       PR tree-optimization/30322
+       * tree-ssa-loop-ivopts.c (fold_affine_expr, iv_value): Removed.
+       (cand_value_at): Return the value as aff_tree.
+       (may_eliminate_iv): Convert the bound from aff_tree to tree.
+       * tree-affine.c (aff_combination_add_cst, aff_combination_add_product,
+       aff_combination_mult): New functions.
+       (aff_combination_add): Use aff_combination_add_cst.
+       (aff_combination_convert): Allow conversions to a wider type.
+       (tree_to_aff_combination): Handle BIT_NOT_EXPR.
+       * tree-affine.h (aff_combination_mult): Declare.
+
+2007-01-09  Carlos O'Donell  <carlos@codesourcery.com>
+
+       * doc/tm.texi: Update documentation to reflect reality of exec
+       and start file search behaviours. Update copyright year.
+       * doc/invoke.texi: Explain how GCC_EXEC_PREFIX is used to find
+       header file directories.
+
+2007-01-09  Uros Bizjak  <ubizjak@gmail.com>
+
+       * config/i386/i386.md (*sinxf2): Rename to *sinxf2_i387.
+       (*cosxf2): Rename to cosxf2_i387.
+       (*sindf2, *sinsf2): Extend operand 1 to XFmode.  Macroize patterns
+       using X87MODEF12 mode macro. Rename patterns to
+       *sin_extend<mode>xf2_i387.  Use SSE_FLOAT_MODE_P to disable patterns
+       for SSE math.
+       (*cosdf2, *cossf2): Ditto.
+       (sincosdf3, sincossf3): Ditto.  Rewrite corresponding splitters
+       to match extended input operands.
+       (sincos<mode>3): New expander.
+       (*sinextendsfdf2, *cosextendsfdf2, *sincosextendsfdf3): Remove
+       insn patterns and corresponding splitters.
+
+2007-01-09  Kaz Kojima  <kkojima@gcc.gnu.org>
+
+       * config/sh/t-linux (TARGET_LIBGCC2_CFLAGS): Delete.
+       (SHLIB_MAPFILES, SHLIB_LINK, SHLIB_INSTALL): Likewise.
+
+2007-01-09  Nicolas Pitre  <nico@cam.org>
+
+       PR target/30173
+       * arm/ieee754-df.S (Lad_s): Also test the low word of X for zero.
+
+2007-01-08  Geoffrey Keating  <geoffk@apple.com>
+
+       * target.h (struct gcc_target): New field library_rtti_comdat.
+       * target-def.h (TARGET_CXX_LIBRARY_RTTI_COMDAT): New.
+       (TARGET_CXX): Add TARGET_CXX_LIBRARY_RTTI_COMDAT.
+       * doc/tm.texi (C++ ABI): Document TARGET_CXX_LIBRARY_RTTI_COMDAT.
+       * config/darwin.h (TARGET_CXX_LIBRARY_RTTI_COMDAT): Define.
+
+2007-01-08  Geoffrey Keating  <geoffk@apple.com>
+
+       * doc/invoke.texi (Optimize Options): Correct description of -O0.
+
+2007-01-08  Richard Guenther  <rguenther@suse.de>
+
+       * tree.h (force_fit_type_double): Export.
+       (force_fit_type): Remove.
+       * fold-const.c (force_fit_type_double): New function.
+       (force_fit_type): Remove.
+       (int_const_binop): Use it.
+       (fold_convert_const_int_from_int): Likewise.
+       (fold_convert_const_int_from_real): Likewise.
+       (fold_div_compare): Likewise.
+       (fold_sign_changed_comparison): Likewise.
+       (fold_unary): Likewise.
+       (fold_negate_const): Likewise.
+       (fold_abs_const): Likewise.
+       (fold_not_const): Likewise.
+       * c-common.c (shorten_compare): Use force_fit_type_double.
+       * convert.c (convert_to_pointer): Likewise.
+
+2007-01-08  Richard Guenther  <rguenther@suse.de>
+
+       * tree.h (build_int_cst_wide_type): Export.
+       * tree.c (build_int_cst_wide_type): New function.
+       (build_int_cst_wide): Fix comment.
+       * builtins.c (fold_builtin_object_size): Use build_int_cst
+       to build -1 or 0 of the correct type.  Use fit_double_type
+       to check for overflow.
+       * fold-const.c (optimize_bit_field_compare): Use build_int_cst_type
+       to build the mask.
+       (decode_field_reference): Likewise.
+       (all_ones_mask_p): Likewise.
+       (native_interpret_int): Use build_int_cst_wide_type.
+       (fold_binary): Use build_int_cst_type to build an all-ones
+       value.
+       * stor-layout.c (set_sizetype): Use build_int_cst_wide_type.
+
+2007-01-08  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config/pa/t-pa64 (libgcc_stub.a): Use $(T).
+
+2007-01-09  Ben Elliston  <bje@au.ibm.com>
+
+       * genautomata.c (STATS_OPTION): New option.
+       (stats_flag): New flag.
+       (gen_automata_option): Handle it.
+       (initiate_automaton_gen): Ditto.
+       (write_automata): Output statistics only if stats_flag is
+       set. Likewise, output time statistics only if time_flag is set.
+       * doc/md.texi (Processor pipeline description): Document new flag.
+
+2007-01-08  Richard Guenther  <rguenther@suse.de>
+
+       * builtins.c (fold_builtin_int_roundingfn): Use fit_double_type.
+       * tree.c (build_int_cst_type): Likewise.
+       (size_in_bytes): Don't call force_fit_type on the result.
+       (int_fits_type_p): Use fit_double_type.
+       * fold-const.c (fit_double_type): New function.
+       (force_fit_type): Use it.
+       * tree.h (fit_double_type): Export.
+
+2007-01-08  Jan Hubicka  <jh@suse.cz>
+
+       * tree-vectorizer.c (gate_increase_alignment): Fix return type.
+       * ipa.c (function_and_variable_visibility): Fix return type.
+
+2007-01-08  Richard Guenther  <rguenther@suse.de>
+
+       * tree-ssa-ccp.c (maybe_fold_offset_to_array_ref): Use type
+       of offset to build the index.
+       * tree-pretty-print.c (dump_generic_node): Don't build negated
+       const just for printing.
+       * c-pretty-print.c (pp_c_integer_constant): Likewise.
+       * builtins.c (fold_builtin_int_roundingfn): Check if result
+       fits the type by using force_fit_type and comparing the result.
+       * predict.c (predict_loops): Use compare_tree_int for comparison.
+       * tree.c (build_int_cst): Fall back to integer_type_node for
+       NULL_TREE type.
+       (build_int_cst_wide): Assert type is non-null.
+
+2007-01-08  Roberto Costa  <roberto.costa@st.com>
+
+       * tree-vrp.c (extract_range_from_cond_expr): New.
+       (extract_range_from_expr): Handle COND_EXPR nodes used as expressions.
+       * tree-ssa-ccp.c (get_maxval_strlen): Handle COND_EXPR nodes used
+       as expressions.
+       (fold_stmt): Bug fix, avoid infinite recursion when folding COND_EXPRs.
+       * tree-ssa-forwprop.c (simplify_cond, forward_propagate_into_cond,
+       tree_ssa_forward_propagate_single_use_vars): Handle COND_EXPR nodes
+       used as expressions.
+       * tree-object-size.c (cond_expr_object_size): New.
+       (collect_object_sizes_for): Handle COND_EXPR nodes used as expressions.
+
+2007-01-08  Jan Hubicka  <jh@suse.cz>
+
+       * tree-ssa-forwprop.c (forward_propagate_into_cond,
+       tree_ssa_forward_propagate_single_use_va): Release defs of propagated
+       statement.
+
+2007-01-08  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/23603
+       * tree-vrp.c (set_value_range_to_truthvalue): New function.
+       (extract_range_from_binary): Fall back to truthvalue instead of
+       varying for TRUTH_*_EXPR.
+       (extract_range_from_comparison): Fall back to truthvalue instead of
+       varying.
+       (vrp_visit_phi_node): Don't adjust new range bounds to +INF/-INF
+       if all visited PHI values were constant.
+
+2007-01-08  Jan Hubicka  <jh@suse.cz>
+
+       * cgraphunit.c (cgraph_process_new_functions): Reset reachable flag.
+       (cgraph_analyze_function): break out from ...
+       (cgraph_finalize_compilation_unit): ... here.
+       (cgraph_expand_function): Remove forgoten commented out line.
+       (cgraph_optimize): Analyze functions.
+
+2007-01-08  Jan Hubicka  <jh@suse.cz>
+
+       * tree-pas.h (TODO_remove_function): New flag.
+       (TODO_update*): Renumber.
+       (pass_ipa_increase_alignment,
+       pass_ipa_function_and_variable_visibility): New passes.
+       * cgraphunit.c (cgraph_increase_alignment): Move to tree-vectorizer.c
+       (cgraph_function_and_variable_visibility): Move to ipa.c
+       (cgraph_optimize): Don't call cgraph_function_and_variable_visibility,
+       cgraph_increase_alignment.
+       * ipa-inline.c (cgraph_decide_inlining): Don't push timevar.
+       (cgraph_decide_inlining_incrementally): Push TV_INTEGRATION before
+       calling tree-inline.
+       (cgraph_early_inlining): Do not call cgraph_remove_unreachable_nodes.
+       (pass_ipa_inline, pass_early_ipa_inlining): Set TODO_remove_functions
+       * tree-vectorizer.c (increase_alignment): Move here from cgraphunit.c
+       (gate_increase_alignment): New function.
+       (pass_ipa_increase_alignment): New pass.
+       * ipa.c: Inline tree-pass.h and timevar.h
+       (function_and_variable_visibility): Move here from cgraphunit.c
+       * tree-optimize.c (pass_early_local_passes): Add TODO_remove_functions.
+       * passes.c (init_optimization_passes): Add the two new passes.
+       (execute_todo): Handle cgraph_remove_functions.
+
+2007-01-08  Nick Clifton  <nickc@redhat.com>
+
+       * config/frv/predicates.md (reg_or_0_operand): Accept
+       CONST_DOUBLEs.
+
+2007-01-08  Ralf Corsépius <ralf.corsepius@rtems.org>
+
+       * config/bfin/rtems.h, config/bfin/t-rtems: New.
+       * config.gcc: Add bfin*-rtems*.
+
+2007-01-08  Mark Shinwell  <shinwell@codesourcery.com>
+
+       * c.opt: Add -flax-vector-conversions.
+       * c-typeck.c (convert_for_assignment): Pass flag to
+       vector_types_convertible_p to allow emission of note.
+       (digest_init): Likewise.
+       * c-opts.c: Handle -flax-vector-conversions.
+       * c-common.c (flag_lax_vector_conversions): New.
+       (vector_types_convertible_p): Unless -flax-vector conversions
+       has been passed, disallow conversions between vectors with
+       differing numbers of subparts and/or element types.  If such
+       a conversion is disallowed, possibly emit a note on the first
+       occasion only to inform the user of -flax-vector-conversions.
+       The new last argument specifies this.
+       * c-common.h (flag_lax_vector_conversions): New.
+       (vector_types_convertible_p): Add extra argument.
+       * config/i386/i386.c (ix86_init_mmx_sse_builtins): Use
+       char_type_node for V*QI type vectors.
+       * config/rs6000/rs6000-c.c (altivec_overloaded_builtins):
+       Update to satisfy new typechecking rules.
+       * config/rs6000/altivec.h (vec_cmple): Use vec_cmpge, for both
+       C and C++ variants.
+       * doc/invoke.texi (C Dialect Options): Document
+       -flax-vector-conversions.
+
+2007-01-08  Mark Shinwell  <shinwell@codesourcery.com>
+
+       PR tree-optimization/29877
+       * tree-ssa-ter.c (is_replaceable_p): Deem assignments with
+       a register variable on the RHS to not be replaceable.
+
+2007-01-08  Chen Liqin  <liqin@sunnorth.com.cn>
+       * config/score/t-score-elf (MULTILIB_OPTIONS): Change.
+       * config/score/predicates.md (const_uimm5, sr0_operand, const_simm12,
+       const_simm15, const_pow2, const_npow2): Added.
+       * config/score/misc.md (insv, extv, extzv, movmemsi,
+       move_lbu_a/b, mov_lhu_a/b etc): Added and fix some bug.
+       * config/score/score.c (score_address_cost, score_select_cc_mode):
+       Added.
+       Change CONST_OK_FOR_LETTER_P/EXTRA_CONSTRAINT define.
+       Update score_rtx_costs for MACRO TARGET_RTX_COSTS.
+       Update score_print_operand.
+       * config/score/score.h (DATA_ALIGNMENT, SELECT_CC_MODE): Added.
+       Adjust register allocate order and update some macro define.
+       * config/score/score-mdaux.c (mdx_unaligned_load, mdx_unsigned_store,
+       mdx_block_move_straight, mdx_block_move_loop_head,
+       mdx_block_move_loop_body, mdx_block_move_loop_foot,
+       mdx_block_move_loop, mdx_block_move): Added.
+       (mdx_movsicc, mdp_select_add_imm, mdp_select, mds_zero_extract_andi,
+       mdp_limm): Updated and fix some bug and typo.
+       * config/score/score.md (movqi/hi/si, add/sub/zero/ext): Updated.
+       (movsf, movdf, doloop_end): Added.
+
+2007-01-08  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/arm/arm.c, config/arm/arm.h, config/arm/arm.md,
+       config/arm/thumb2.md: Fix comment typos.
+       * doc/extend.texi: Fix a typo.
+
+2007-01-07  Eric Christopher  <echristo@apple.com>
+
+       * configure.ac: Check for __stack_chk_fail for darwin.
+       * configure: Regenerate.
+
+2007-01-07  Richard Guenther  <rguenther@suse.de>
+
+       * tree-vrp.c (extract_range_from_assert): CSE calls to
+       compare_values where possible.
+       (extract_range_from_unary_expr): Likewise.
+
+2007-01-07  Anatoly Sokolov <aesok@post.ru>
+
+       * config/avr/avr-protos.h (call_insn_operand): Delete prototype.
+       * config/avr/avr.c (call_insn_operand): Delete function.
+       * config/avr/avr.md (*pushqi, *pushhi, *pushsi, *pushsf): Use REG_SP
+       instead of register number. Use predicates.
+       * config/avr/predicates.md (const0_operand, reg_or_0_operand,
+       call_insn_operand): Add.
+
+2007-01-06  Jan Hubicka  <jh@suse.cz>
+
+       * tree-pass.h (pass_build_cgraph_edges): Declare.
+       * cgraphunit.c (record_refernece): Move to cgraphbuild.c
+       (visited_nodes): Remove.
+       (cgraph_create_edges): Move to cgraphbuild.c; rename to
+       build_cgrpah_edges; make visited_nodes local.
+       (cgraph_process_new_functions): DO not call initialize_inline_failed.
+       (record_references_in_initializer): Move to cgraphbuild.c
+       (initialize_inline_failed, rebuild_cgraph_edges,
+       pass_rebuild_cgraph_edges): Move to cgraphbuild.c.
+       (verify_cgraph_node): Make visited_nodes local.
+       (cgraph_analyze_function): Do not call cgraph_create_edges and
+       initialize_inline_failed.
+       (cgraph_expand_function): Do not call cgraph_lower_function;
+       assert that function is already lowered.
+       * Makefile.in (cgraphbuild.o): New.
+       * passes.c (init_optimization_passes): Add pass_build_cgraph_edges
+       at the end of lowering passes.
+
+2007-01-06  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * ifcvt.c (cond_move_convert_if_block): New function, code
+       factored out from...
+       (cond_move_process_if_block): ...here.  Call the new function
+       on the THEN and ELSE blocks.
+       (merge_if_block): Do not copy global_live_at_end, merge_blocks
+       already takes care of this.
+
+2007-01-05  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR c/19978
+       * tree.h (TREE_OVERFLOW_P): New.
+       * c-typeck.c (parser_build_unary_op): Warn only if result
+       overflowed and operands did not.
+       (parser_build_binary_op): Likewise.
+       (convert_for_assignment): Remove redundant overflow_warning.
+       * c-common.c (overflow_warning): Don't check or set TREE_OVERFLOW.
+
+2007-01-05  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       * c-typeck.c (store_init_value): Split over two lines to follow
+       the GNU coding style.
+
+2007-01-05  Benjamin Kosnik  <bkoz@redhat.com>
+
+       * c-cppbuiltin.c (c_cpp_builtins): __GXX_EXPERIMENTAL_CPP0X__ to
+       __GXX_EXPERIMENTAL_CXX0X__.
+       * doc/cpp.texi: Same.
+
+2007-01-05  Richard Guenther  <rguenther@suse.de>
+
+       PR middle-end/27826
+       * tree.c (get_narrower): Do not construct COMPONENT_REFs
+       with mismatched types.  Instead explicitly build a
+       conversion NOP_EXPR.
+
+2007-01-05  Ian Lance Taylor  <iant@google.com>
+
+       * c-common.c (decl_with_nonnull_addr_p): New function.
+       (c_common_truthvalue_conversion): Call it.
+       * c-typeck.c (build_binary_op): Likewise.
+       * c-common.h (decl_with_nonnull_addr_p): Declare.
+
+2007-01-05  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c/30360
+       * libgcc2.c (__divdc3): Compare c and d against 0.0 instead of
+       denom against 0.0.
+
+2007-01-05  Joel Brobecker  <brobecker@adacore.com>
+
+       * doc/install.texi (Final install): Document the fact that
+       the GNAT runtime should not be stripped.
+
+2007-01-04  Jan Hubicka  <jh@suse.cz>
+
+       * tree-inline.c (fold_marked_statements): Update operand caches
+       and EH after folding
+
+2007-01-04  Ian Lance Taylor  <iant@google.com>
+
+       * c-common.c (check_function_nonnull): Whitespace fix.
+
+2007-01-04  Jan Hubicka  <jh@suse.cz>
+
+       * tree-optimize.c (execute_fixup_cfg): Correct previously mistakely
+       comitted older version of patch.
+       (pass_fixup_cfg): Add TODOs to verify flow and statements, dump
+       function, celanup cfg and collect garbage.
+
+2007-01-04  Mike Stump  <mrs@apple.com>
+
+       * Makefile.in (mostlyclean): Don't remove libgcc anymore.
+       (clean): Likewise.
+
+2007-01-04  Eric Christopher  <echristo@apple.com>
+
+       * libgcc2.c (__bswapsi2): Use SItype.
+       (__bswapdi2): Use DItype.
+       * libgcc2.h: Update for above.
+
+2007-01-04  Paul Brook  <paul@codesourcery.com>
+
+       * config/arm/arm.md (arm_mulsi3, thumb_mulsi3, mulsi3_compare0,
+       mulsi_compare0_scratch, mulsi3addsi, mulsi3addsi_compare0,
+       mulsi3addsi_compare0_scratch, mulsidi3adddi, mulsidi3,
+       umulsidi3, umulsidi3adddi, smulsi3_highpart,
+       umulsi3_highpart): Make conditional on !arm_arch6.
+       (arm_mulsi3_v6, thumb_mulsi3_v6, mulsi3_compare0_v6,
+       mulsi_compare0_scratch_v6, mulsi3addsi_v6, mulsi3addsi_compare0_v6,
+       mulsi3addsi_compare0_scratch_v6, mulsidi3adddi_v6, mulsidi3_v6,
+       umulsidi3_v6, umulsidi3adddi_v6, smulsi3_highpart_v6,
+       umulsi3_highpart_v6): New insns.
+
+2007-01-04  Roger Sayle  <roger@eyesopen.com>
+
+       * fold-const.c (fold_convert): When casting an expression to void,
+       fold_ignored_result may discover a GIMPLE_MODIFY_STMT which doesn't
+       have a type.  Instead of attempting to build a NOP_EXPR, return
+       these "special" trees directly.
+
+2007-01-04  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/rs6000/rs6000.c (rs6000_rtx_costs): Make adjustment for
+       MULT inside MINUS as either argument.  Use rs6000_cost->dmul -
+       rs6000_cost->fp not 0 as adjustment for outer NEG.
+
+2007-01-04  Jan Hubicka  <jh@suse.cz>
+
+       * cgraph.c (cgraph_release_function_body): New function.
+       (cgraph_remove_node): Use it.
+       * cgraph.h (cgraph_release_function_body): Declare.
+       * cgraphunit.c (cgraph_expand_function): Use it.
+       * ipa.c (cgraph_remove_unreahchable_nodes): Use it.
+       * tree-ssa.c (delete_tree_ssa): Allow to be called before aliasing
+       is initialized and while compilation of other function is running.
+       * tree-optimize.c (execute_free_cfg_annotations): Move code to clear
+       statement CFG annotations from here to ...
+       * tree-cfg.c (delete_tree_cfg_annotations): ... here.
+
+2007-01-04  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * cfgloop.h (enum li_flags): Make the constants powers of two.
+
+2007-01-04  Jan Hubicka  <jh@suse.cz>
+
+       * tree-inline.c (copy_bb): Insert new statements to statements_to_fold
+       set.
+       (fold_marked_statements): New function.
+       (optimize_inline_calls, tree_function_versioning): Fold new statements.
+       * tree-inline.h (copy_body_data): Add statements_to_fold.
+
+2007-01-03  Daniel Jacobowitz  <dan@codesourcery.com>
+
+       * config.gcc: Mention libgcc/config.host.
+       * Makefile.in: Update comments mentioning libgcc.
+       (LIBGCC, INSTALL_LIBGCC, GCC_PARTS, mklibgcc): Delete.
+       (all.cross, start.encap, rest.encap, rest.cross): Update
+       dependencies for libgcc move.
+       (libgcc.mk, LIBGCC_DEPS, libgcov.a, libgcc.a, stmp-multilib)
+       (clean-target, clean-target-libgcc): Delete.
+       (srcdirify, GCC_EXTRA_PARTS): New macros.
+       (libgcc-support, libgcc.mvars): New rules.
+       (distclean): Remove mention of mklibgcc.
+       (install): Don't reference INSTALL_LIBGCC.
+       (install-common): Don't reference EXTRA_PARTS.
+       (install-libgcc, install-multilib): Delete rules.
+       * mklibgcc.in: Delete file.
+       * doc/configfiles.texi: Don't mention mklibgcc.
+
+       * config/i386/t-darwin (SHLIB_VERPFX): Delete (moved to libgcc).
+       * config/i386/t-darwin64 (SHLIB_VERPFX): Likewise.
+       * config/rs6000/t-darwin (SHLIB_VERPFX): Likewise.
+       * config/rs6000/t-ppccomm (TARGET_LIBGCC2_CFLAGS, SHLIB_MAPFILES)
+       (mklibgcc, ldblspecs): Likewise.
+
+       * config/i386/t-nwld (libgcc.def, libc.def, libpcre.def)
+       (posixpre.def): Use $(T).
+       (SHLIB_EXT, SHLIB_NAME, SHLIB_SLIBDIR_QUAL, SHLIB_DEF, SHLIB_MAP)
+       (SHLIB_SRC, SHLIB_INSTALL): Delete.
+       (SHLIB_LINK): Make dummy.
+       * config/t-slibgcc-darwin: Delete contents except for dummy SHLIB_LINK.
+
+       * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Clear.
+
+       * config/alpha/t-crtfm: Use $(T) in rules for EXTRA_PARTS.
+       * config/alpha/t-vms, config/alpha/t-vms64, config/fr30/t-fr30,
+       config/i386/t-rtems-i386, config/ia64/t-ia64, config/rs6000/t-beos,
+       config/rs6000/t-newas, config/sparc/t-elf: Likewise.
+
+       * configure.ac (all_outputs): Remove mklibgcc.
+       * configure: Regenerated.
+
+2007-01-03  Josh Conner  <jconner@apple.com>
+
+       PR middle-end/29683
+       * calls.c (compute_argument_addresses): Set stack and stack_slot
+       for partial args, too.
+       (store_one_arg): Use locate.size.constant for the size when
+       generating a save_area.
+
+2007-01-03  Robert Kennedy <jimbob@google.com>
+
+       * tree-cfg.c (tree_merge_blocks): Release SSA_NAME phi results
+       whose definitions are deleted due to basic block merging.
+
+2007-01-03  Paul Brook  <paul@codesourcery.com>
+
+       PR target/16634
+       * config/arm/arm.c (output_return_instruction): Pop PC in interrupt
+       functions.
+       (use_return_insn): Return 0 for Thumb interrupt functions.
+       (print_multi_reg): Add rfe argument for IRQ returns.
+       (arm_output_epilogue): Pop interrupt return address directly into PC.
+       (arm_expand_prologue): Only adjust IRQ return address in Arm mode.
+
+2007-01-03  Paul Brook  <paul@codesourcery.com>
+
+       Merge from sourcerygxx-4_1.
+       * config/arm/thumb2.md: New file.
+       * config/arm/elf.h (JUMP_TABLES_IN_TEXT_SECTION): Return True for
+       Thumb-2.
+       * config/arm/coff.h (JUMP_TABLES_IN_TEXT_SECTION): Ditto.
+       * config/arm/aout.h (ASM_OUTPUT_ADDR_VEC_ELT): Add !Thumb-2 assertion.
+       (ASM_OUTPUT_ADDR_DIFF_ELT): Output Thumb-2 jump tables.
+       * config/arm/aof.h (ASM_OUTPUT_ADDR_DIFF_ELT): Output Thumb-2 jump
+       tables.
+       (ASM_OUTPUT_ADDR_VEC_ELT): Add !Thumb-2 assertion.
+       * config/arm/ieee754-df.S: Use macros for Thumb-2/Unified asm
+       comptibility.
+       * config/arm/ieee754-sf.S: Ditto.
+       * config/arm/arm.c (thumb_base_register_rtx_p): Rename...
+       (thumb1_base_register_rtx_p): ... to this.
+       (thumb_index_register_rtx_p): Rename...
+       (thumb1_index_register_rtx_p): ... to this.
+       (thumb_output_function_prologue): Rename...
+       (thumb1_output_function_prologue): ... to this.
+       (thumb_legitimate_address_p): Rename...
+       (thumb1_legitimate_address_p): ... to this.
+       (thumb_rtx_costs): Rename...
+       (thumb1_rtx_costs): ... to this.
+       (thumb_compute_save_reg_mask): Rename...
+       (thumb1_compute_save_reg_mask): ... to this.
+       (thumb_final_prescan_insn): Rename...
+       (thumb1_final_prescan_insn): ... to this.
+       (thumb_expand_epilogue): Rename...
+       (thumb1_expand_epilogue): ... to this.
+       (arm_unwind_emit_stm): Rename...
+       (arm_unwind_emit_sequence): ... to this.
+       (thumb2_legitimate_index_p, thumb2_legitimate_address_p,
+       thumb1_compute_save_reg_mask, arm_dwarf_handle_frame_unspec,
+       thumb2_index_mul_operand, output_move_vfp, arm_shift_nmem,
+       arm_save_coproc_regs, thumb_set_frame_pointer, arm_print_condition,
+       thumb2_final_prescan_insn, thumb2_asm_output_opcode, arm_output_shift,
+       thumb2_output_casesi): New functions.
+       (TARGET_DWARF_HANDLE_FRAME_UNSPEC): Define.
+       (FL_THUMB2, FL_NOTM, FL_DIV, FL_FOR_ARCH6T2, FL_FOR_ARCH7,
+       FL_FOR_ARCH7A, FL_FOR_ARCH7R, FL_FOR_ARCH7M, ARM_LSL_NAME,
+       THUMB2_WORK_REGS): Define.
+       (arm_arch_notm, arm_arch_thumb2, arm_arch_hwdiv, arm_condexec_count,
+       arm_condexec_mask, arm_condexec_masklen)): New variables.
+       (all_architectures): Add armv6t2, armv7, armv7a, armv7r and armv7m.
+       (arm_override_options): Check new CPU capabilities.
+       Set new architecture flag variables.
+       (arm_isr_value): Handle v7m interrupt functions.
+       (user_return_insn): Return 0 for v7m interrupt functions.  Handle
+       Thumb-2.
+       (const_ok_for_arm): Handle Thumb-2 constants.
+       (arm_gen_constant): Ditto.  Use movw when available.
+       (arm_function_ok_for_sibcall): Return false for v7m interrupt
+       functions.
+       (legitimize_pic_address, arm_call_tls_get_addr): Handle Thumb-2.
+       (thumb_find_work_register, arm_load_pic_register,
+       legitimize_tls_address, arm_address_cost, load_multiple_sequence,
+       emit_ldm_seq, emit_stm_seq, arm_select_cc_mode, get_jump_table_size,
+       print_multi_reg, output_mov_long_double_fpa_from_arm,
+       output_mov_long_double_arm_from_fpa, output_mov_double_fpa_from_arm,
+       output_mov_double_fpa_from_arm, output_move_double,
+       arm_compute_save_reg_mask, arm_compute_save_reg0_reg12_mask,
+       output_return_instruction, arm_output_function_prologue,
+       arm_output_epilogue, arm_get_frame_offsets, arm_regno_class,
+       arm_output_mi_thunk, thumb_set_return_address): Ditto.
+       (arm_expand_prologue): Handle Thumb-2.  Use arm_save_coproc_regs.
+       (arm_coproc_mem_operand): Allow POST_INC/PRE_DEC.
+       (arithmetic_instr, shift_op): Use arm_shift_nmem.
+       (arm_print_operand): Use arm_print_condition.  Handle '(', ')', '.',
+       '!' and 'L'.
+       (arm_final_prescan_insn): Use extract_constrain_insn_cached.
+       (thumb_expand_prologue): Use thumb_set_frame_pointer.
+       (arm_file_start): Output directive for unified syntax.
+       (arm_unwind_emit_set): Handle stack alignment instruction.
+       * config/arm/lib1funcs.asm: Remove default for __ARM_ARCH__.
+       Add v6t2, v7, v7a, v7r and v7m.
+       (RETLDM): Add Thumb-2 code.
+       (do_it, shift1, do_push, do_pop, COND, THUMB_SYNTAX): New macros.
+       * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Define __thumb2__.
+       (TARGET_THUMB1, TARGET_32BIT, TARGET_THUMB2, TARGET_DSP_MULTIPLY,
+       TARGET_INT_SIMD, TARGET_UNIFIED_ASM, ARM_FT_STACKALIGN, IS_STACKALIGN,
+       THUMB2_TRAMPOLINE_TEMPLATE, TRAMPOLINE_ADJUST_ADDRESS,
+       ASM_OUTPUT_OPCODE, THUMB2_GO_IF_LEGITIMATE_ADDRESS,
+       THUMB2_LEGITIMIZE_ADDRESS, CASE_VECTOR_PC_RELATIVE,
+       CASE_VECTOR_SHORTEN_MODE, ADDR_VEC_ALIGN, ASM_OUTPUT_CASE_END,
+       ADJUST_INSN_LENGTH): Define.
+       (TARGET_REALLY_IWMMXT, TARGET_IWMMXT_ABI, CONDITIONAL_REGISTER_USAGE,
+       STATIC_CHAIN_REGNUM, HARD_REGNO_NREGS, INDEX_REG_CLASS,
+       BASE_REG_CLASS, MODE_BASE_REG_CLASS, SMALL_REGISTER_CLASSES,
+       PREFERRED_RELOAD_CLASS, SECONDARY_OUTPUT_RELOAD_CLASS,
+       SECONDARY_INPUT_RELOAD_CLASS, LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P,
+       TRAMPOLINE_SIZE, INITIALIZE_TRAMPOLINE, HAVE_PRE_INCREMENT,
+       HAVE_POST_DECREMENT, HAVE_PRE_DECREMENT, HAVE_PRE_MODIFY_DISP,
+       HAVE_POST_MODIFY_DISP, HAVE_PRE_MODIFY_REG, HAVE_POST_MODIFY_REG,
+       REGNO_MODE_OK_FOR_BASE_P, LEGITIMATE_CONSTANT_P,
+       REG_MODE_OK_FOR_BASE_P, REG_OK_FOR_INDEX_P, GO_IF_LEGITIMATE_ADDRESS,
+       LEGITIMIZE_ADDRESS, THUMB2_LEGITIMIZE_ADDRESS,
+       GO_IF_MODE_DEPENDENT_ADDRESS, MEMORY_MOVE_COST, BRANCH_COST,
+       ASM_APP_OFF, ASM_OUTPUT_CASE_LABEL, ARM_DECLARE_FUNCTION_NAME,
+       FINAL_PRESCAN_INSN, PRINT_OPERAND_PUNCT_VALID_P,
+       PRINT_OPERAND_ADDRESS): Adjust for Thumb-2.
+       (arm_arch_notm, arm_arch_thumb2, arm_arch_hwdiv): New declarations.
+       * config/arm/arm-cores.def: Add arm1156t2-s, cortex-a8, cortex-r4 and
+       cortex-m3.
+       * config/arm/arm-tune.md: Regenerate.
+       * config/arm/arm-protos.h: Update prototypes.
+       * config/arm/vfp.md: Enable patterns for Thumb-2.
+       (arm_movsi_vfp): Add movw alternative.  Use output_move_vfp.
+       (arm_movdi_vfp, movsf_vfp, movdf_vfp): Use output_move_vfp.
+       (thumb2_movsi_vfp, thumb2_movdi_vfp, thumb2_movsf_vfp,
+       thumb2_movdf_vfp, thumb2_movsfcc_vfp, thumb2_movdfcc_vfp): New.
+       * config/arm/libunwind.S: Add Thumb-2 code.
+       * config/arm/constraints.md: Update include Thumb-2.
+       * config/arm/ieee754-sf.S: Add Thumb-2/Unified asm support.
+       * config/arm/ieee754-df.S: Ditto.
+       * config/arm/bpabi.S: Ditto.
+       * config/arm/t-arm (MD_INCLUDES): Add thumb2.md.
+       * config/arm/predicates.md (low_register_operand,
+       low_reg_or_int_operand, thumb_16bit_operator): New.
+       (thumb_cmp_operand, thumb_cmpneg_operand): Rename...
+       (thumb1_cmp_operand, thumb1_cmpneg_operand): ... to this.
+       * config/arm/t-arm-elf: Add armv7 multilib.
+       * config/arm/arm.md: Update patterns for Thumb-2 and Unified asm.
+       Include thumb2.md.
+       (UNSPEC_STACK_ALIGN, ce_count): New.
+       (arm_incscc, arm_decscc, arm_umaxsi3, arm_uminsi3,
+       arm_zero_extendsidi2, arm_zero_extendqidi2): New
+       insns/expanders.
+       * config/arm/fpa.md: Update patterns for Thumb-2 and Unified asm.
+       (thumb2_movsf_fpa, thumb2_movdf_fpa, thumb2_movxf_fpa,
+       thumb2_movsfcc_fpa, thumb2_movdfcc_fpa): New insns.
+       * config/arm/cirrus.md: Update patterns for Thumb-2 and Unified asm.
+       (cirrus_thumb2_movdi, cirrus_thumb2_movsi_insn,
+       thumb2_cirrus_movsf_hard_insn, thumb2_cirrus_movdf_hard_insn): New
+       insns.
+       * doc/extend.texi: Document ARMv7-M interrupt functions.
+       * doc/invoke.texi: Document Thumb-2 new cores+architectures.
+
+2007-01-03  Jakub Jelinek  <jakub@redhat.com>
+
+       * unwind-dw2.c (SIGNAL_FRAME_BIT, EXTENDED_CONTEXT_BIT): Define.
+       (struct _Unwind_Context): Rename args_size to flags, remove
+       signal_frame field, add a new args_size field and version field.
+       (_Unwind_IsSignalFrame, _Unwind_SetSignalFrame,
+       _Unwind_IsExtendedContext): New inline functions.
+       (_Unwind_GetGR, _Unwind_SetGR, _Unwind_GetGRPtr, _Unwind_SetGRPtr):
+       Assume by_value array is only present if _Unwind_IsExtendedContext.
+       (_Unwind_GetIPInfo, execute_cfa_program, uw_frame_state_for): Use
+       _Unwind_IsSignalFrame.
+       (__frame_state_for): Initialize context.flags to EXTENDED_CONTEXT_BIT.
+       (uw_update_context_1): Use _Unwind_SetSignalFrame.
+       (uw_init_context_1): Initialize context->flags to
+       EXTENDED_CONTEXT_BIT.
+       * config/rs6000/linux-unwind.h (frob_update_context): Use
+       _Unwind_SetSignalFrame.
+
+2007-01-03  Andrew Pinski  <andrew_pinski@playstation.sony.com>
+
+       PR middle-end/30353
+       * gimplify.c (gimplify_modify_expr_complex_part): Move below
+       tree_to_gimple_tuple.  Call tree_to_gimple_tuple when we need
+       the value.
+
+2007-01-03  Kazu Hirata  <kazu@codesourcery.com>
+
+       * config/i386/i386.h (NON_STACK_REG_P, REGNO_OK_FOR_SIREG_P,
+       REGNO_OK_FOR_DIREG_P, REWRITE_ADDRESS, ASM_OPERAND_LETTER,
+       RET, AT_SP): Remove.
+       * config/i386/i386.md (*sse_prologue_save_insn): Use return
+       instead of RET.
+
+       * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
+       * cfgbuild.c (find_basic_blocks): Likewise.
+       * cfgrtl.c (rtl_create_basic_block): Likewise.
+       * function.c (temp_slots_at_level): Likewise.
+       * reg-stack.c (stack_regs_mentioned): Likewise.
+       * regclass.c (allocate_reg_info): Likewise.
+       * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
+       set_bb_for_stmt, move_block_to_fn): Likewise.
+       * tree-complex.c (tree_lower_complex): Likewise.
+       * vec.h (VEC_safe_grow_cleared): New.
+
+       * cgraphunit.c, tree-ssa-alias.c: Fix comment typos.
+
+2007-01-03  Zdenek Dvorak <dvorakz@suse.cz>
+
+       * loop-unswitch.c (unswitch_loop): Pass probabilities to loopify.
+       * tree-ssa-loop-unswitch.c (tree_unswitch_loop): Pass probabilities
+       to loop_version.
+       * cfgloopmanip.c (scale_loop_frequencies): Export.
+       (loopify): Scale the frequencies by prescribed coefficients.
+       (set_zero_probability): New function.
+       (duplicate_loop_to_header_edge): Improve updating of frequencies.
+       (lv_adjust_loop_entry_edge, loop_version): Set probabilities
+       and frequencies according to arguments.
+       * tree-ssa-loop-manip.c (tree_unroll_loop): Set probabilities
+       correctly.
+       * cfg.c (scale_bbs_frequencies_int): Allow scaling the frequencies up.
+       * modulo-sched.c (sms_schedule): Set probabilities for entering
+       versioned loop correctly.
+       * tree-vect-transform.c (vect_transform_loop): Ditto.
+       * cfgloop.h (loopify, loop_version): Declaration changed.
+       (scale_loop_frequencies): Declared.
+
+2007-01-02  Jan Hubicka  <jh@suse.cz>
+
+       * cgraph.c: Include tree-flow.h
+       (cgraph_add_new-function): Handle IPA_SSA mode; execute
+       early_local_passes.
+       * cgraph.h (enum cgraph_state): Add CGRAPH_STATE_IPA_SSA.
+       * tree-pass.h (pass_all_early_optimizations): Declare.
+       * cgraphunit.c (cgraph_process_new_functions): Add IPA_SSA; execute
+       early_local_passes.
+       (cgraph_analyze_function): Do early_local_passes.
+       * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
+       Do not add referenced vars.
+       * tree-optimize.c (gate_all_optimizations): Do not execute when not in
+       SSA form.
+       (gate_all_early_local_passes): New gate.
+       (pass_early_local_passes): Use new gate.
+       (execute_early_local_optimizations): New functions.
+       (gate_all_early_optimizations): New gate.
+       (pass_all_early_optimizations): New pass.
+       (execute_free_datastructures): Free SSA only when initialized.
+       (gate_init_datastructures): Init only when optimizing.
+       (tree_lowering_passes): Do early local passes when called late.
+       * tree-profile.c (do_tree_profiling): Don't profile functions added
+       late.
+       (do_early_tree_profiling, pass_early_tree_profile): Kill.
+       * tree-cfg.c (update_modified_stmts): Do not update when operands are
+       not active.
+       * passes.c (init_optimizations_passes): Reorder so we go into SSA
+       during early_local_passes.
+       * Makefile.in (cgraph.o): Add dependency on tree-flow.h.
+
+
+2007-01-02  Carlos O'Donell  <carlos@codesourcery.com>
+
+       * Makefile.in: Update copyright year.
+
+2007-01-02  Carlos O'Donell  <carlos@codesourcery.com>
+
+       * Makefile.in: Export GCC_EXEC_PREFIX before calling $(RUNTEST)
+       in $(lang_checks) and check-consistency targets.
+
+2007-01-02  Jan Hubicka  <jh@suse.cz>
+
+       * tree-mudflap.c (mf_decl_cache_locals, mf_build_check_statement_for):
+       Do not add referenced vars.
+       * tree-cfg.c (update_modified_stmts): Do not update when SSA operands
+       are not active.
+       * passes.c (init_optimization_passes): Put mudflap_2 after
+       free_datastructures.
+
+2007-01-02  Jan Hubicka  <jh@suse.cz>
+
+       * tree-optimize (execute_fixup_cfg): Set after_inlining flag.
+       Set NOTHROW flag on call statements proved to be nothrow.
+       Update statement of local calls so new pure/const functions are
+       updated. Update_ssa when in ssa form. Mark PHI nodes of nonlocal
+       goto receivers.
+       (tree_rest_of_compilation): Register hooks and initialize bitmap
+       early. Do not set after_inlining flag.
+
+2007-01-02  Steve Ellcey  <sje@cup.hp.com>
+
+       * sbitmap.c (HOST_BITS_PER_LONG_LONG): Change to
+       HOST_BITS_PER_LONGLONG
+
+2007-01-02  Manuel Lopez-Ibanez <manu@gcc.gnu.org>
+
+       PR c/19977
+       * c-typeck.c (store_init_value): Don't emit pedantic overflow
+       warning for non-static initializers.
+
+2007-01-02  Steven Bosscher  <steven@gcc.gnu.org>
+
+       * config/alpha/alpha.md, arm/arm.c, darwin.c, frv/frv.md,
+       m32r/m32r.c, m32r/m32r.c, mn10300/mn10300.md, pa/pa.c,
+       rs6000/rs6000.c, s390/s390.md, sh/sh.md, sparc/sparc.c:
+       Always use set_unique_reg_note to add REG_EQUAL notes.
+
+2007-01-02  Kazu Hirata  <kazu@codesourcery.com>
+
+       Revert:
+       2007-01-02  Kazu Hirata  <kazu@codesourcery.com>
+
+       * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
+       * cfgbuild.c (find_basic_blocks): Likewise.
+       * cfgrtl.c (rtl_create_basic_block): Likewise.
+       * function.c (temp_slots_at_level): Likewise.
+       * reg-stack.c (stack_regs_mentioned): Likewise.
+       * regclass.c (allocate_reg_info): Likewise.
+       * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
+       set_bb_for_stmt, move_block_to_fn): Likewise.
+       * tree-complex.c (tree_lower_complex): Likewise.
+       * vec.h (VEC_safe_grow_cleared): New.
+
+2007-01-02  Ian Lance Taylor  <iant@google.com>
+
+       * c-common.c (c_common_truthvalue_conversion): When warning about
+       using an assignment as a truth value, set TREE_NO_WARNING.
+
+2007-01-02  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
+
+       PR middle-end/7651
+       * c.opt (Wold-style-declaration): New.
+       * doc/invoke.texi (C-only Warning Options): New.
+       (Wold-style-declaration): Document it.
+       (Wextra): Enabled by -Wextra.
+       * c-opts.c (c_common_post_options): Enabled by -Wextra.
+       * c-decl.c (declspecs_add_scspec): Replace -Wextra with
+       -Wold-style-declaration.
+
+2007-01-02  Kazu Hirata  <kazu@codesourcery.com>
+
+       * alias.c (init_alias_analysis): Use VEC_safe_grow_cleared.
+       * cfgbuild.c (find_basic_blocks): Likewise.
+       * cfgrtl.c (rtl_create_basic_block): Likewise.
+       * function.c (temp_slots_at_level): Likewise.
+       * reg-stack.c (stack_regs_mentioned): Likewise.
+       * regclass.c (allocate_reg_info): Likewise.
+       * tree-cfg.c (init_empty_tree_cfg, build_tree_cfg, create_bb,
+       set_bb_for_stmt, move_block_to_fn): Likewise.
+       * tree-complex.c (tree_lower_complex): Likewise.
+       * vec.h (VEC_safe_grow_cleared): New.
+
+2007-01-02  Douglas Gregor  <doug.gregor@gmail.com>
+
+       * c-common.c (c_common_nodes_and_builtins): Since variants of
+       void_type_node get built before it is given a name, we need to
+       give those variants the name, too.
+       (complete_array_type): We need to work with the canonical main
+       type of the array, from which we will build the qualified version.
+       * params.def (PARAM_VERIFY_CANONICAL_TYPES): New.
+       * print-tree.c (print_node): Display canonical type information
+       for each type.
+       * stor-layout.c (layout_type): When we don't know the
+       alignment of a type for which we're building an array, we end up
+       guessing wrong, so make the type require structural equality.
+       * tree.c (make_node_stat): When we build a new type, it is its
+       own canonical type.
+       (build_type_attribute_qual_variant): When building an attribute
+       variant, its canonical type is the non-attribute variant. However,
+       if the attributes are target-dependent and they differ, we need to
+       use structural equality checks for this type.
+       (build_qualified_type): A qualified type is not equivalent to its
+       unqualified variant; set the canonical type appropriately.
+       (build_distinct_type_copy): When building a distinct type from
+       another type, the new type is its own canonical type.
+       (build_variant_type_copy): When building a new type variant, we
+       assume that it is equivalent to the original type.
+       (build_pointer_type_for_mode): When building a pointer type, also
+       build a canonical type pointer.
+       (build_reference_type_for_mode): When building a reference type,
+       also build a canonical type reference.
+       (build_index_type): When we can't hash an index type (e.g.,
+       because its maximum value is negative), the index type requires
+       structural equality tests.
+       (build_array_type): Build the canonical form of an array type.
+       (build_function_type): Function types require structural equality,
+       because they contain default arguments, attributes, etc.
+       (build_method_type_directly): Ditto for method types.
+       (build_offset_type): Build the canonical offset type.
+       (build_complex_type): Build the canonical vector type.
+       (make_vector_type): Build the canonical vector type.
+       * tree.h (TYPE_CANONICAL): New.
+       (TYPE_STRUCTURAL_EQUALITY_P): New.
+       (SET_TYPE_STRUCTURAL_EQUALITY): New.
+       (struct tree_type): Added "canonical" field.
+       * params.h (VERIFY_CANONICAL_TYPES): New.
+       * doc/c-tree.texi (TYPE_CANONICAL): Document.
+       (TYPE_STRUCTURAL_EQUALITY_P): Document.
+       (SET_TYPE_STRUCTURAL_EQUALITY): Document.
+       * doc/invoke.texi (verify-canonical-types): Document --param
+       parameter for verifying canonical types.
+
+2007-01-02  Joseph Myers  <joseph@codesourcery.com>
+
+       * config.gcc (powerpc-*-eabispe*, powerpc-*-eabisimaltivec*,
+       powerpc-*-eabisim*, powerpc-*-eabialtivec*, powerpc-*-eabi*,
+       powerpc-*-rtems*, powerpc-wrs-vxworks, powerpc-wrs-vxworksae,
+       powerpcle-*-eabisim*, powerpcle-*-eabi*): Add rs6000/e500.h to
+       tm_file.
+       * config/rs6000/e500.h: New.
+       * config/rs6000/eabi.h (TARGET_SPE_ABI, TARGET_SPE, TARGET_E500,
+       TARGET_ISEL, TARGET_FPRS, TARGET_E500_SINGLE, TARGET_E500_DOUBLE):
+       Remove.
+       * config/rs6000/linuxspe.h (TARGET_SPE_ABI, TARGET_SPE,
+       TARGET_E500, TARGET_ISEL, TARGET_FPRS, TARGET_E500_SINGLE,
+       TARGET_E500_DOUBLE): Remove.
+       * config/rs6000/vxworks.h (TARGET_SPE_ABI, TARGET_SPE,
+       TARGET_E500, TARGET_ISEL, TARGET_FPRS): Remove.
+       * config/rs6000/rs6000.h (CHECK_E500_OPTIONS): Define.
+       * config/rs6000/rs6000.c (rs6000_override_options): Use
+       CHECK_E500_OPTIONS.
+
+2007-01-02  Joseph Myers  <joseph@codesourcery.com>
+
+       * config/rs6000/rs6000.c (print_operand): Check (TARGET_SPE ||
+       TARGET_E500_DOUBLE), not TARGET_E500, for %y.
+       (rs6000_generate_compare, rs6000_emit_sCOND, output_cbranch,
+       rs6000_emit_cmove): Don't check TARGET_E500.
+       * config/rs6000/rs6000.md (bunordered, bordered, sunordered,
+       sordered): Don't check TARGET_E500.
+
+2007-01-01  Eric Christopher  <echristo@apple.com>
+
+       * config/mips/mips.c (mips_regno_mode_ok_for_base_p): Use
+       HARD_REGISTER_NUM_P.
+
+2007-01-01  Roger Sayle  <roger@eyesopen.com>
+
+       * fold-const.c (fold_binary) <EQ_EXPR>: Fold "(X^C1) eq/ne C2" into
+       "X eq/ne (C1^C2)".  Fold "(X^Z) eq/ne (Y^Z)" as "X eq/ne Y" when Z
+       has no side-effects.  Fold "(X^C1) eq/ne (Y^C2)" as "(X^(C1^C2))
+       eq/ne Y".
+
+2007-01-01  Mike Stump  <mrs@apple.com>
+
+       * configure.ac: Remove support for building with Apple's gcc-3.1.
+
+2007-01-02  Joseph Myers  <joseph@codesourcery.com>
+
+       PR middle-end/30311
+       * caller-save.c (add_stored_regs): Only handle SUBREGs if inner
+       REG is a hard register.  Do not modify REG before calling
+       subreg_nregs.
+       * rtlanal.c (subreg_get_info): Don't assert size of XMODE is a
+       multiple of the size of YMODE for certain lowpart cases.
+
+2007-01-01  Andrew Pinski  <pinskia@gmail.com>
+
+       PR middle-end/30253
+       * gimplify (voidify_wrapper_expr): Update for
+       GIMPLE_MODIFY_STMT.
+
+2007-01-01  Andreas Schwab  <schwab@suse.de>
+
+       PR target/29166
+       * config/ia64/ia64.c (ia64_compute_frame_size): Account space for
+       save of BR0 in extra_spill_size instead of spill_size.
+       (ia64_expand_prologue): Save BR0 outside of the gr/br/fr spill
+       area.
+       (ia64_expand_epilogue): Restore BR0 from its new location.
+
+2007-01-01  Andrew Pinski  <pinskia@gmail.com>
+
+       * gimplify.c (gimplify_init_constructor <case VECTOR_TYPE>):
+       Use a temporary variable if the left hand side is not a gimple
+       register.
+
+2007-01-01  Andrew Pinski  <pinskia@gmail.com>
+
+       * gimplify.c (gimplify_return_expr): Make the temporary variable
+       for the return expression, a gimple register variable.
+
+2007-01-01  Jan Hubicka  <jh@suse.cz>
+
+       * emit-rtl.c (emit_copy_of_insn_after): Do not call copy_insn_1 for
+       INSN_LIST.
+
+2007-01-01  Mike Stump  <mrs@apple.com>
+
+       * configure.ac (HAVE_GAS_LITERAL16): Add autoconf check for
+       .literal16.
+       * config/darwin.c (machopic_select_rtx_section): Use
+       HAVE_GAS_LITERAL16.
+       (darwin_mergeable_constant_section): Likewise.
+       * configure: Regenerate.
+       * config.in: Regenerate.
+
+2007-01-01  Jan Hubicka  <jh@suse.cz>
+           Andrew Pinski  <pinskia@gmail.com>
+
+       * cgraphunit.c (cgraph_optimize): Call cgraph_add_new_functions
+       before starting IPA passes.