summaryrefslogtreecommitdiff
path: root/gcc/ChangeLog-2007
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/ChangeLog-2007')
-rw-r--r--gcc/ChangeLog-200734170
1 files changed, 34170 insertions, 0 deletions
diff --git a/gcc/ChangeLog-2007 b/gcc/ChangeLog-2007
new file mode 100644
index 00000000000..27f28128b76
--- /dev/null
+++ b/gcc/ChangeLog-2007
@@ -0,0 +1,34170 @@
+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
+ * reload1.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 Avila de Espindola <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 Avila de Espindola <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 Avila de Espindola <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 Avila de Espindola <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 Avila de Espindola <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 <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.