+2004-02-28 Andrew Pinski <pinskia@physics.uc.edu>
+
+ * config/darwin.h (machopic_finish): Output stub even if the
+ symbol is already defined.
+
+2004-02-28 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
+
+ * pa64-hpux.h (LIB_SPEC): Fix linking under HP-UX 11.00 with -p and -pg.
+
+2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
+
+ * genattr.c (main): Don't define
+ TRADITIONAL_PIPELINE_INTERFACE or DFA_PIPELINE_INTERFACE.
+ * system.h (TRADITIONAL_PIPELINE_INTERFACE): Poison.
+ (DFA_PIPELINE_INTERFACE): Likewise.
+ * doc/tm.texi (TRADITIONAL_PIPELINE_INTERFACE): Remove.
+ (DFA_PIPELINE_INTERFACE): Likewise.
+
+2004-02-28 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (tstsi, tstdi): Delete.
+
+2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
+
+ * config/mips/mips.c (override_options): Remove an obsolete
+ duplicate definition of the "e" constraint.
+ * config/mips/mips.h: Update a comment accordingly.
+
+2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
+
+ * config/mips/mips.md: Complete the unfinished R4000
+ multiply/shift errata workaround. Improve documentation.
+ (hazard): Use TARGET_FIX_R4000 to decide whether an "imul" instruction
+ has a hilo hazard.
+ (mulsi3, mulsi3_internal, mulsi3_r4000): Use TARGET_FIX_R4000.
+ (muldi3, muldi3_internal): Likewise.
+ (muldi3_internal2): Remove, replacing with...
+ (muldi3_mult3, muldi3_r4000): ...these new patterns.
+ (mulsidi3): Take the errata into account.
+ (mulsidi3_32bit): Remove, replacing with...
+ (mulsidi3_32bit_internal, mulsidi3_32bit_r4000): ...these new patterns.
+ (mulsidi3_64bit, mulsidi3_64bit_parts): Disable if TARGET_FIX_R4000.
+ (umulsidi3): Take the errata into account.
+ (umulsidi3_32bit): Remove, replacing with..
+ (umulsidi3_32bit_internal, umulsidi3_32bit_r4000): ...these patterns.
+ (umulsi3_highpart, umulsi3_highpart_internal): Disable if
+ TARGET_FIX_R4000.
+ (smulsi3_highpart, smulsi3_highpart_internal): Likewise.
+ (smuldi3_highpart, umuldi3_highpart): Likewise.
+ * doc/invoke.texi: Document the errata workaround.
+
+2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
+
+ * config/mips/mips-protos.h (mips_idiv_insns): Declare.
+ * config/mips/mips.h (MASK_FIX_SB1): Bump.
+ (MASK_FIX_R4000, TARGET_FIX_R4000): New macros.
+ (TARGET_SWITCHES): Add -mfix-r4000 and -mno-fix-r4000.
+ * config/mips/mips.c (mips_idiv_insns): New function.
+ (override_options): Make -march=r4000 imply -mfix-r4000 by default.
+ (mips_output_division): Add a workaround for the R4000 divide/shift
+ errata.
+ * config/mips/mips.md (length): Use mips_idiv_insns() to calculate
+ the length of an "idiv" instruction.
+ * doc/invoke.texi: Document the new switches.
+
+2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
+
+ * doc/tm.texi (IS_COSTLY_DEPENDENCE): Change to
+ TARGET_SCHED_IS_COSTLY_DEPENDENCE.
+
+2004-02-28 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
+
+ PR optimization/14229
+ * cfgrtl.c (rtl_tidy_fallthru_edge): Do not fail for !onlyjump jump.
+
+2004-02-28 Eric Botcazou <ebotcazou@act-europe.fr>
+
+ * fold-const.c (fold): Strip NOPs that change the signedness
+ for RSHIFT too. Expand comment.
+
+2004-02-27 Ian Lance Taylor <ian@wasabisystems.com>
+
+ PR optimization/7871
+ * flow.c (mark_set_1): Don't add LOG_LINKS for global registers
+ from or to call insns.
+
+2004-02-27 Eric Botcazou <ebotcazou@libertysurf.fr>
+
+ PR optimization/7871
+ * flow.c (propagate_one_insn): Interpret calls as setting global
+ registers, not merely clobbering them.
+
+2004-02-27 Dale Johannesen <dalej@apple.com>
+
+ * config/darwin.c (machopic_output_possible_stub_label): Remove.
+ config/darwin-protos.h: Ditto.
+ config/darwin.h: Remove call to it.
+ * combine.c (distribute_notes): Do not place a REG_DEAD note
+ when value is both set and used.
+
+2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
+
+ * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
+ as well.
+ * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
+ * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
+
+2004-02-27 Andrew Pinski <apinski@apple.com>
+
+ * c-typeck.c (tagged_types_tu_compatible_p) <ENUMERAL_TYPE>:
+ Speedup common case of the type values being in the same order.
+
+2004-02-27 Steve Ellcey <sje@cup.hp.com>
+
+ * config/ia64/ia64.h (no-inline-float-divide): New option.
+ * config/ia64/ia64.h (no-inline-int-divide): New option.
+ * config/ia64/ia64.h (no-inline-sqrt): New option.
+ (TARGET_DEFAULT): Add MASK_INLINE_FLOAT_DIV_THR to define.
+ * config/ia64/hpux.h (TARGET_DEFAULT): Ditto.
+ * config/ia64/ia64.c (ia64_override_options): Modify error
+ checking for inlined division/sqrt.
+
+2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
+
+ * bb-reorder.c, cfgbuild.c, diagnostic.c, explow.c, profile.c,
+ ra-build.c, read-rtl.c, tracer.c, unwind-dw2-fde-glibc.c,
+ value-prof.c, config/darwin-protos.h, config/frv/frv-abi.h,
+ config/i386/pmmintrin.h, config/pa/pa-hpux.h: Update
+ copyright.
+
+2004-02-27 Paul Brook <paul@codesourcery.com>
+
+ * function.c (assign_parms): Don't count pretend args for alignment.
+
+2004-02-27 Richard Henderson <rth@redhat.com>
+
+ * passes.c: New file.
+ * Makefile.in (OBJS-common): Add it.
+ * diagnostic.c (rtl_dump_and_exit): Move decl ...
+ * flags.h (rtl_dump_and_exit): ... here.
+ * output.h (size_directive_output, last_assemble_variable_decl):
+ Move from toplev.c.
+ * rtl.h (reg_alloc): Move from toplev.c.
+ * toplev.c (HAVE_conditional_execution, DUMPFILE_FORMAT,
+ struct dump_file_info, enum dump_file_index, dump_file_tbl,
+ open_dump_file, close_dump_file, rest_of_decl_compilation,
+ rest_of_type_compilation, rest_of_handle_final,
+ rest_of_handle_delay_slots, rest_of_handle_stack_regs,
+ rest_of_handle_variable_tracking, rest_of_handle_machine_reorg,
+ rest_of_handle_new_regalloc, rest_of_handle_old_regalloc,
+ rest_of_handle_regrename, rest_of_handle_reorder_blocks,
+ rest_of_handle_sched, rest_of_handle_sched2, rest_of_handle_regmove,
+ rest_of_handle_tracer, rest_of_handle_if_conversion,
+ rest_of_handle_if_after_combine, rest_of_handle_web,
+ rest_of_handle_branch_prob,
+ rest_of_handle_value_profile_transformations, rest_of_handle_cfg,
+ rest_of_handle_addressof, rest_of_handle_sibling_calls,
+ rest_of_handle_jump_bypass, rest_of_handle_inlining,
+ rest_of_handle_null_pointer, rest_of_handle_combine,
+ rest_of_handle_life, rest_of_handle_cse, rest_of_handle_cse2,
+ rest_of_handle_gcse, rest_of_handle_loop_optimize,
+ rest_of_handle_loop2, rest_of_compilation): Move to passes.c.
+ (decode_d_option): Use enable_rtl_dump_file.
+ (compile_file, finalize, do_compile): Move profile+combine+graph
+ cleanup to finish_optimization_passes.
+ * toplev.h (init_optimization_passes, finish_optimization_passes,
+ enable_rtl_dump_file): Declare.
+
+2004-02-27 Eric Botcazou <ebotcazou@act-europe.fr>
+ Roger Sayle <roger@eyesopen.com>
+
+ * fold-const.c (fold): Revert 2004-02-25 change. Use the original
+ operands to build a tree with swapped operands.
+ * expr.c (expand_expr_real) <MAX_EXPR>: Consistently use the
+ 'unsignedp' predicate to specify the signedness.
+
+2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
+
+ * c-decl.c, c-ppoutput.c, combine.c, cppfiles.c, dwarf2out.c,
+ expr.c, fold-const.c, gcc.c, haifa-sched.c, loop-iv.c,
+ params.def, read-rtl.c, rtl.c, rtlanal.c, toplev.c: Fix
+ comment typos and formatting. Follow spelling conventions.
+
2004-02-26 Aldy Hernandez <aldyh@redhat.com>
* config/rs6000/rs6000.md: Add fixuns_truncsfsi2 and