+2004-08-23 James E Wilson <wilson@specifixinc.com>
+
+ * reg-notes.def (REG_NOTE): In comment, change DEF_INSN_NOTE to
+ DEF_REG_NOTE.
+
+2004-08-23 Mark Mitchell <mark@codesourcery.com>
+
+ PR c/14492
+ * dwarf2out.c (loc_descriptor_from_tree): Robustify.
+
+2004-08-23 Diego Novillo <dnovillo@redhat.com>
+
+ * cfg.c (check_bb_profile): Fix typos.
+ * function.c (assign_parm_is_stack_parm): Likewise.
+ * tree-nested.c: Likewise.
+
+2004-08-23 Daniel Jacobowitz <dan@debian.org>
+
+ * ggc-zone.c (struc alloc_chunk): Rearrange flag bits and SIZE.
+ Remove TYPECODE.
+ (ggc_alloc_zone_1): Mark TYPE as unused. Don't save it in the chunk.
+
+2004-08-23 Eric Christopher <echristo@redhat.com>
+
+ * defaults.h (VECTOR_MODE_SUPPORTED_P): Remove macro.
+ * system.h (VECTOR_MODE_SUPPORTED_P): Poison.
+ * target-def.h (TARGET_VECTOR_MODE_SUPPORTED_P): Define.
+ * target.h: Ditto.
+ * hooks.h: Include machmode.h.
+ (hook_bool_mode_false): Declare.
+ * hooks.c (hook_bool_mode_false): Define.
+ * expr.c (vector_mode_valid_p): Use targetm.vector_mode_supported_p.
+ * stor-layout.c (layout_type): Ditto.
+ * config/alpha/alpha.c (alpha_vector_mode_supported_p): New function.
+ Define to target macro.
+ * config/alpha/alpha.h (VECTOR_MODE_SUPPORTED_P): Delete.
+ * config/arm/arm.c: Ditto. Use.
+ * config/arm/arm.h: Ditto.
+ * config/arm/arm-protos.h: Ditto.
+ * config/i386/i386.c: Ditto.
+ * config/i386/i386.h: Ditto.
+ * config/rs6000/rs6000.c: Ditto.
+ * config/rs6000/rs6000.h: Ditto.
+ * config/sh/sh.c: Ditto.
+ * config/sh/sh.h: Ditto.
+ * config/sh/sh-protos.h: Ditto.
+ * config/sh/sh.md: Use.
+ * doc/tm.texi: Move documentation for VECTOR_MODE_SUPPORTED_P
+ to TARGET_VECTOR_MODE_SUPPORTED_P.
+
+2004-08-23 Nathan Sidwell <nathan@codesourcery.com>
+
+ * Makefile.in (BUILD_ERRORS): Set to build-errors.
+ (errors.o): New target for host.
+ (build-errors.o): New target for build.
+ (genobjs): Replace errors.o with build-errors.
+ (gengenrtl$(buildexeext)): Add $(BUILD_ERRORS).
+ (GCOV_OBJS, GCOV_DUMP_OBJS): Add errors.o.
+ (fix-headers$(build_exeext)): Add $(BUILD_ERRORS).
+ (fix-header.o): Add errors.h
+ * collect2.c (fancy_abort): Add parameters.
+ * collect2.h (fancy_abort): Don't declare.
+ * errors.h (fancy_abort): Don't declare.
+ * errors.c: Include either bconfig.h or config.h.
+ (fancy_abort): Trim filename.
+ * fix-header.c (v_fatal, fatal): Remove.
+ (progname): Remove definition.
+ (main): Set progname here.
+ * gcc.c (fancy_abort): Add parameters.
+ * gcc.h (fancy_abort): Remove declaration.
+ * gcov.c (fancy_abort): Remove.
+ * rtl.h (fancy_abort): Don't declare.
+ (abort): Don't define.
+ * tree.h (fancy_abort): Don't declare.
+ (abort): Don't define.
+ * system.h (fancy_abort): Declare.
+ (abort): Define to fancy_abort.
+ * fixinc/Makefile.in (ALLOBJ): Add ../build-errors.o
+
+ * tree.h (enum size_type_kind): Remove USIZETYPE, UBITSIZETYPE.
+ (usize_type, ubitsizetype): Remove.
+ * stor-layout.c (set_sizetype): Don't initialize usizetype,
+ ubitsizetype.
+ * fold-const.c (size_diffop): TYPE can never be ubitsizetype.
+
+ * tree.h (build_distinct_type_copy): New.
+ (build_type_copy): ... here. Rename to ...
+ (build_variant_type_copy): ... here.
+ * tree.c (build_qualified_type): Rename build_type_copy call.
+ (build_distinct_type_copy): New, broken out of ...
+ (build_type_copy): ... here. Rename to ...
+ (build_variant_type_copy): ... here. Use
+ build_distinct_type_copy.
+ (build_common_tree_nodes_2): Rename build_type_copy call.
+ * c-common.c (c_common_nodes_and_builtins): Rename build_type_copy
+ call.
+ (handle_packed_attribute, handle_unused_attribute,
+ handle_transparanet_union_attribute, handle_aligned_attribute,
+ handle_deprecated_attribute): Likewise.
+ * c-decl.c (clone_underlying_type, store_parm_decls_oldstyle):
+ Likewise.
+ * config/arm/arm.c (arm_handle_isr_attribyte): Likewise.
+ * config/rs6000/rs6000.c (rs6000_init_builtins): Use
+ build_distinct_type_copy.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (mfhilo_[sd]i): Redefine using :GPR. Add mode
+ attribute.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (length): Don't use mips_fetch_insns for indexed
+ loads and stores.
+ (*lwxc1_<mode>, *ldxc1_<mode>, *swxc1_<mode>, *sdxc1_<mode>): Name
+ formerly unnamed patterns. Redefine using :P for the address. Remove
+ explicit length attributes.
+
+2004-08-23 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
+
+ * tree-ssa-loop-im.c (fem_single_reachable_address, for_each_memref):
+ New functions.
+ (single_reachable_address): Use them.
+ (schedule_sm): Add dump.
+ (is_call_clobbered_ref): New function.
+ (determine_lsm_reg): Check whether the reference is call clobbered.
+ Only work for gimple_reg_type values.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (*mov<mode>_ra): Name previously unnamed MIPS16
+ $31 store insns. Redefine using :GPR.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (P): New mode macro.
+ (*xgot_hi[sd]i, *xgot_lo[sd]i, *got_disp[sd]i, *got_page[sd]i)
+ (*load_got[sd]i, *low[sd]i, *low[sd]i_mips16): Redefine using :P.
+ Add mode attributes.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (UNSPEC_[LS][WD][LR]): Delete in favor of...
+ (UNSPEC_{LOAD,STORE}_{LEFT,RIGHT}): ...these new constants. Shuffle
+ later constants to cover the gap.
+ (load, store): New mode attributes.
+ (mov_l[wd]l, mov_l[wd]r, mov_s[wd]l, mov_s[wd]r): Redefine using :GPR.
+ Use new unspec constants.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (one_cmpl[sd]i2): Redefine using :GPR.
+ (and[sd]3, ior[sd]i3, xor[sd]i3): Likewise. Change 32-bit patterns
+ to use register_operand rather than uns_arith_operand as the predicate
+ for operand 1. Remove redundant MIPS16 force_reg() for operand 1.
+ (*and[sd]i3, *ior[sd]i3, *xor[sd]i3): Name formerly unnamed patterns.
+ Redefine using :GPR. Make same predicate change here. Extend the
+ commutativity of operands 1 and 2 from the SImode version to the
+ DImode one.
+ (*and[sd]i3_mips16, *ior[sd]i3_mips16, *xor[sd]i3_mips16): Likewise,
+ but with no predicate changes.
+ (*nor[sd]i3): Redefine using :GPR.
+
+2004-08-23 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
+
+ * tree-ssa-operands.c (get_call_expr_operands): Add VUSE operands for
+ noreturn functions.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.h (ISA_HAS_DCLZ_DCLO): Delete.
+ * config/mips/mips.md (abs[sd]i2): Redefine using :GPR. Only use
+ branch-likely insns for absdi2 if GENERATE_BRANCHLIKELY. Use "%."
+ rather than "%z2" (with a fake const0_rtx for operand 2).
+ (ffs[sd]i2): Redefine using :GPR.
+ (clz[sd]i2): Likewise. Use ISA_HAS_CLO_CLZ for the 64-bit case.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md ({,u}divmod[sd]i4): Redefine using :GPR.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.md (any_extend): New code macro.
+ (u, su): New code attributes.
+ ({,u}mulsidi3, {,u}mulsidi3_32bit_internal, {,u}mulsidi3_32bit_r4000)
+ ({u,s}mulsi3_highpart, {u,s}mulsi3_highpart_internal)
+ ({u,s}mulsi3_highpart_mulhi_internal, {s,u}muldi3_highpart)
+ (*{s,u}mul_acc_di): Redefine using any_extend.
+ (*{,u}muls_di, *{s,u}msac_di): Likewise. Change names of patterns
+ to reflect real insn names.
+ (*mulsidi3_64bit, *mulsidi3_64bit_parts): Replace use of match_operator
+ with an any_extend template.
+ ({u,s}mulsi3_highpart_neg_mulhi_internal): Redefine using any_extend.
+ Add '*' to name.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config/mips/mips.h (GENERATE_MULT3_SI): Check TARGET_MAD.
+ * config/mips/mips.md (mul[sd]i3, mul[sd]i3_internal)
+ (mul[sd]i3_r4000): Redefine using :GPR.
+ (mulsi3_mult3): Don't check TARGET_MAD separately.
+ (muldi3_mult3): Moved after mulsi_mult3.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * config.gcc (mips-*-*): Remove definitions of MASK_GAS and
+ OBJECT_FORMAT_ELF. Set MASK_SPLIT_ADDR by default if using GNU ld.
+ * config/mips/mips.h (MASK_GAS): Delete. Shuffle later masks down.
+ (TARGET_GAS, TARGET_MIPS_AS): Delete.
+ (TARGET_GPWORD): Define to true for n32 on IRIX.
+ (TARGET_SWITCHES): Remove -mmips-as. Turn -mgas into a no-op.
+ (MIPS_AS_ASM_SPEC, SUBTARGET_MIPS_AS_ASM_SPEC): Delete.
+ (GAS_ASM_SPEC): Delete, folding into ASM_SPEC.
+ (ASM_ABI_DEFAULT_SPEC, TARGET_ASM_SPEC): Delete.
+ (MDEBUG_ASM_SPEC): Delete, folding into...
+ (SUBTARGET_ASM_DEBUGGING_SPEC): ...here.
+ (ASM_SPEC): Inline old GAS_ASM_SPEC. Use GNU names for ABI switches.
+ (EXTRA_SPECS): Remove mips_as_asm_spec, gas_asm_spec, target_asm_spec,
+ subtarget_mips_as_asm_spec, mdebug_asm_spec. Use MULTILIB_ABI_DEFAULT
+ to define asm_abi_default_spec.
+ (ASM_STABS_OP, ASM_STABN_OP, ASM_STABD_OP): Delete.
+ (TARGET_ASM_SELECT_SECTION): Delete.
+ * config/mips/mips.c (MIPS_MAX_FIRST_STACK_STEP): Define to 0x7ff0
+ for non-mips16 code, removing previous workaround for SGI assemblers.
+ (TARGET_ASM_INTEGER, mips_assemble_integer): Delete.
+ (TARGET_ASM_ALIGNED_DI_OP): Define this instead.
+ (override_options): Remove !TARGET_GAS and !have_named_sections code.
+ (print_operand): Fold TARGET_GAS conditionals into asm strings.
+ (mips_output_filename): Remove !TARGET_GAS code. Replace use of
+ ASM_STABS_OP and ASM_STABN_OP.
+ (mips_file_start): Remove TARGET_MIPS_AS/TARGET_GAS checks.
+ (mips_output_aligned_decl_common): Remove mention of SGI o32 assembler.
+ (mips_output_function_prologue): Remove !TARGET_GAS code.
+ (mips_select_rtx_section): Remove !have_named_sections code.
+ (mips_select_section): Delete.
+ * config/mips/mips.md (trap): Remove !TARGET_GAS check.
+ * config/mips/linux.h (TARGET_DEFAULT): Remove use of MASK_GAS.
+ * config/mips/sdb.h (PUT_SDB_DEF, PUT_SDB_PLAIN_DEF): Delete.
+ (PUT_SDB_BLOCK_START, PUT_SDB_BLOCK_END): Fold TARGET_GAS conditional.
+ * config/mips/vxworks.h (ASM_SPEC): As for mips.h.
+ * config/mips/windiss.h (ASM_SPEC): Likewise.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * read-rtl.c (map_value, mapping, macro_group): New structures.
+ (BELLWETHER_CODE): New macro.
+ (modes, codes, bellwether_codes): New variables.
+ (find_mode, uses_mode_macro_p, apply_mode_macro, find_code)
+ (uses_code_macro_p, apply_code_macro, apply_macro_to_string)
+ (apply_macro_to_rtx, uses_macro_p, add_condition_to_string)
+ (add_condition_to_rtx, apply_macro_traverse, add_mapping)
+ (add_map_value, initialize_macros): New functions.
+ (def_hash, def_hash_eq_p): Generalize to anything that points to,
+ or starts with, a char * field.
+ (find_macro, read_mapping, check_code_macro): New functions.
+ (read_rtx_1): New, split out from read_rtx. Handle the new
+ define_{mode,code}_{macro,attr} constructs. Use find_macro
+ to parse the name of a code or mode. Use BELLWETHER_CODE to
+ extract the format and to choose a suitable code for rtx_alloc.
+ Modify recursive invocations to use read_rtx_1.
+ (read_rtx): Call initialize_macros. Apply code and mode macros
+ to the rtx returned by read_rtx_1. Cache everything after the
+ first macro expansion for subsequent read_rtx calls.
+ * doc/md.texi: Document new .md constructs.
+ * config/mips/mips.md (GPR): New mode macro.
+ (d, si8_di5): New mode attributes.
+ (any_cond): New code macro.
+ (add[sd]i3): Redefine using :GPR.
+ (*add[sd]i3): Likewise, renaming from add[sd]i3_internal.
+ (*add[sd]i3_sp[12], *add<mode>3_mips16): Redefine using :GPR, naming
+ previously unnamed MIPS16 patterns.
+ (*addsi3_extended): Renamed from addsi3_internal_2. Fix overly long
+ lines. Don't match (plus (const_int 0) ...).
+ (*addsi3_extended_mips16): Name previously unnamed MIPS16 pattern.
+ Use a define_split to generate the addition.
+ (sub[sd]i3): Redefine using :GPR. Turn subsi3 into a define_insn.
+ (subsi3_internal): Delete.
+ (*subsi3_extended): Renamed from subsi3_internal_2.
+ (bunordered, bordered, bunlt, bunge, buneq, bltgt, bunle, bungt)
+ (beq, bne, bgt, bge, blt, ble, bgtu, bgeu, bltu, bleu): Redefine
+ using an any_cond template.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * read-rtl.c (read_rtx): Tidy use of format_ptr.
+
+2004-08-23 Richard Sandiford <rsandifo@redhat.com>
+
+ * read-rtl.c (string_obstack): New file-scope variable.
+ (read_string, read_quoted_string, read_braced_string)
+ (read_escape): Remove obstack parameter and use string_obstack instead.
+ (read_rtx): Remove function-local rtl_obstack and initialize
+ string_obstack instead. Update call to read_string.
+
+2004-08-22 Andrew Pinski <apinski@apple.com>
+
+ PR c/15262
+ * c-typeck.c (build_unary_op): Use &a.b if the foldded lowered
+ expression is not constant.
+ (c_finish_return): Do not go through INDIRECT_REF when looking
+ for the inner expression of an ADDR_EXPR for warning about.
+
+2004-08-22 Richard Henderson <rth@redhat.com>
+
+ PR 17075
+ * cfgexpand.c (expand_gimple_tailcall): Detect when we can both
+ create new blocks and fall through.
+ (expand_gimple_basic_block): Update to match.
+
+2004-08-22 Ulrich Weigand <uweigand@de.ibm.com>
+
+ * reload.c (find_reloads_address): Make return value tri-state.
+ Return -1 if LEGITIMIZE_RELOAD_ADDRESS succeeded.
+ (find_reloads): Assume that reloaded addresses match 'o' or
+ EXTRA_MEMORY_CONSTRAINT constraints only if find_reloads_address
+ returned 1 (not -1). Omit optional reloads for address operands
+ only if find_reloads_address returned 1 (not -1).
+
+ * config/s390/s390.c (legitimize_reload_address): New function.
+ * config/s390/s390-protos.h (legitimize_reload_address): Declare.
+ * config/s390/s390.h (LEGITIMIZE_RELOAD_ADDRESS): Define. Call
+ legitimize_reload_address.
+
+2004-08-22 Richard Hendersion <rth@redhat.com>
+
+ * tree.h (SAVE_EXPR_RESOLVED_P): New.
+ * gimplify.c (gimplify_save_expr): Use it.
+ * expr.c (expand_expr_real_1): Likewise. Also set DECL_IGNORED_P
+ on the temporary variable.
+
+2004-08-22 Andrew Pinski <pinskia@physics.uc.edu>
+
+ * fold-const.c (rtl_expr_nonnegative_p): Delete.
+ * tree.h (rtl_expr_nonnegative_p): Remove.
+
+2004-08-22 Steven Bosscher <stevenb@suse.de>
+
+ * config/i386/ppro.md (ppro_complex_insn): Add missing check
+ for cpu==pentiumpro.
+
+ * combine.c (struct reg_stat): Fix comment typo.
+
+2004-08-22 Joseph S. Myers <jsm@polyomino.org.uk>
+
+ * c-tree.h (c_sizeof_nowarn): Remove.
+
+2004-08-21 Joseph S. Myers <jsm@polyomino.org.uk>
+
+ * c-decl.c (set_array_declarator_type): Rename to
+ set_array_declarator_inner.
+ (build_c_parm, build_attrs_declarator, build_function_declarator):
+ New functions.
+ (make_pointer_declarator): Call build_attrs_declarator.
+ * c-tree.h (set_array_declarator_type): Rename to
+ set_array_declarator_inner.
+ (build_c_parm, build_attrs_declarator, build_function_declarator):
+ New prototypes.
+ * c-parse.in (after_type_declarator,
+ parm_declarator_starttypename, parm_declarator_nostarttypename,
+ notype_declarator, absdcl_maybe_attribute, direct_absdcl1, parm,
+ firstparm): Use these functions
+
+2004-08-21 Joseph S. Myers <jsm@polyomino.org.uk>
+
+ * c-decl.c (build_array_declarator, set_array_declarator_type,
+ start_decl, grokdeclarator, grokparms): Change boolean parameters
+ to type bool.
+ * c-tree.h (build_array_declarator, set_array_declarator_type,
+ start_decl): Update prototypes.
+ * c-decl.c, c-parse.in: All callers changed.
+
+2004-08-21 Mike Stump <mrs@apple.com>
+
+ * config/rs6000/darwin.h (SUBTARGET_OPTIONS): Move from here, to...
+ (darwin_fix_and_continue): Likewise.
+ (darwin_fix_and_continue_switch): Likewise.
+ * config/darwin.h (SUBTARGET_OPTIONS): ...here, to fix -mone-byte-bool.
+ (darwin_fix_and_continue): Likewise.
+ (darwin_fix_and_continue_switch): Likewise.
+
+2004-08-21 Danny Smith <dannysmith@users.sourceforge.net>
+
+ PR c++/16030
+ * config/i386/winnt/c (gen_stdcall_suffix, gen_fastcall_suffix):
+ Remove, merging into ...
+ (gen_stdcall_or_fastcall_suffix): New function, returning tree
+ rather than const char*, and accepting additional parameter.
+ Don't add suffix to '*'-prefixed symbols or variadic functions.
+ (i386_pe_encode_section_info): Adjust for call to new function.
+ Call change_decl_assembler_name.
+
+2004-08-20 Mike Stump <mrs@apple.com>
+
+ * config/darwin.c (machopic_indirect_data_reference): Mark
+ stubs as defined.
+ * config/386/386.c (darwin_local_data_pic): Add.
+ (legitimate_constant_p): Reorder so that PLUS handling runs
+ before darwin_local_data_pic to match the ordering in
+ legitimate_pic_address_disp_p and so that MINUS runs after
+ darwin_local_data_pic as otherwise the darwin_local_data_pic
+ logic can be skipped, which would be very bad.
+ (legitimate_pic_address_disp_p): Move from from here to
+ darwin_local_data_pic so it can be reused.
+
+2004-08-21 Alan Modra <amodra@bigpond.net.au>
+
+ * config/rs6000/linux64.h (DOT_SYMBOLS): Define.
+ (CRT_CALL_STATIC_FUNCTION): Define !DOT_SYMBOLS version.
+ (ASM_DECLARE_FUNCTION_SIZE): Modify for !DOT_SYMBOLS.
+ (ASM_OUTPUT_SOURCE_LINE, DBX_OUTPUT_BRAC, DBX_OUTPUT_NFUN): Likewise.
+ (RS6000_ABI_NAME): Define as "linux".
+ (SUBSUBTARGET_OVERRIDE_OPTIONS): Set dot_symbols.
+ * config/rs6000/sysv4.h (SUBTARGET_OVERRIDE_OPTIONS): Select
+ ABI_AIX when rs6000_abi_name is "linux" and TARGET_64BIT.
+ * config/rs6000/rs6000-protos.h (rs6000_output_function_entry): Decl.
+ * config/rs6000/rs6000.c (dot_symbols): New global var.
+ (rs6000_output_function_entry): New function, modified for
+ !DOT_SYMBOLS..
+ (print_operand <case 'z'>): ..extracted from here.
+ (rs6000_assemble_visibility): Modify for !DOT_SYMBOLS.
+ (rs6000_output_function_epilogue): Likewise.
+ (rs6000_elf_declare_function_name): Likewise.
+ * config/rs6000/rs6000.h (DOT_SYMBOLS): Define.
+ (ASM_WEAKEN_DECL, ASM_OUTPUT_DEF_FROM_DECLS): Modify for !DOT_SYMBOLS.
+ * configure.ac (HAVE_LD_NO_DOT_SYMS): Add new AC_DEFINE.
+ * configure: Regenerate.
+ * config.in: Regenerate.
+
+2004-08-20 Mark Mitchell <mark@codesourcery.com>
+
+ * reload.c (find_reloads_address): Fix thinko in previous change.
+
+ * reload.c (find_reloads_address): Reload the sum of a LO_SUM and
+ a CONST_INT.
+
+2004-08-20 Jakub Jelinek <jakub@redhat.com>
+
+ PR rtl-optimization/17099
+ * combine.c (force_to_mode): Check if inner_mask has any bits set
+ outside of GET_MODE (x) instead of op_mode.
+
+2004-08-20 Mark Mitchell <mark@codesourcery.com>
+
+ * config.gcc (arm*-*-symbianelf*): Add t-symbian Makefile
+ fragment.
+ * config/arm/bpabi.h (RENAME_LIBRARY_SET): Fix typo.
+ (SUBTARGET_EXTRA_ASM_SPEC): Pass -meabi=3 to the assembler.
+ * config/arm/symbian.h (SUBTARGET_CPU_DEFAULT): Assume ARMV5
+ architecture.
+ (SUBTARGET_ASM_FLOAT_SPEC): Default to -mfpu=vfp for hard-float
+ configurations.
+ * config/arm/t-symbian: New file.
+
+2004-08-20 Andrew Pinski <apinski@apple.com>
+
+ * regrename.c (kill_value_regno): ANSIfy.
+
+2004-08-20 Dale Johannesen <dalej@apple.com>
+
+ * config/rs6000/rs6000.c (rs6000_rtx_costs): Improve DIV/MOD.
+
+2004-08-20 Daniel Jacobowitz <dan@debian.org>
+
+ * regrename.c (kill_value_one_regno): Renamed from kill_value_regno.
+ (kill_value_regno): New function, derived from kill_value.
+ (kill_value): Update.
+ (copyprop_hardreg_forward_1): Update call to kill_value_regno.
+
+2004-08-20 Daniel Berlin <dberlin@dberlin.org>
+
+ Fix PR tree-optimization/17111
+ * tree-ssa-pre.c (create_value_expr_from): Don't change the types
+ of non-value_handles.
+ (bitmap_set_contains): All constants are in every set.
+
+2004-08-20 Nathan Sidwell <nathan@codesourcery.com>
+
+ * fold-const.c (round_up, round_down): Use build_int_cst.
+ Optimize common case.
+
+2004-08-20 Zack Weinberg <zack@codesourcery.com>
+ John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
+
+ * config/pa/pa-protos.h (readonly_data, one_only_readonly_data_section,
+ one_only_data_section): Rename to som_readonly_data_section,
+ som_one_only_readonly_data_section and som_one_only_data_section.
+ * config/pa/pa.c (ONE_ONLY_TEXT_SECTION_ASM_OP,
+ NEW_TEXT_SECTION_ASM_OP, DEFAULT_TEXT_SECTION_ASM_OP): Delete
+ conditional defines.
+ (som_text_section_asm_op): Replace ONE_ONLY_TEXT_SECTION_ASM_OP,
+ NEW_TEXT_SECTION_ASM_OP and DEFAULT_TEXT_SECTION_ASM_OP with actual
+ string values.
+ (pa_select_section): Use renamed section functions.
+ * config/pa/pa.h (EXTRA_SECTIONS, EXTRA_SECTION_FUNCTIONS,
+ SOM_READONLY_DATA_SECTION_FUNCTION,
+ SOM_ONE_ONLY_READONLY_DATA_SECTION_FUNCTION,
+ SOM_ONE_ONLY_DATA_SECTION_FUNCTION, FORGET_SECTION_FUNCTION):
+ Define here ...
+ * config/pa/som.h: ... not here.
+ (DEFAULT_TEXT_SECTION_ASM_OP, NEW_TEXT_SECTION_ASM_OP,
+ ONE_ONLY_TEXT_SECTION_ASM_OP, READONLY_DATA_ASM_OP,
+ ONE_ONLY_READONLY_DATA_SECTION_ASM_OP,
+ ONE_ONLY_DATA_SECTION_ASM_OP): Delete.
+ (READONLY_DATA_SECTION): Use som_readonly_data_section.
+
+2004-08-20 Nathan Sidwell <nathan@codesourcery.com>
+
+ * fold-const.c (int_const_binop): Don't generate non-overflowing
+ size-types specially.
+ (fold_convert_const): Likewise.
+
+ * stor-layout.c (initialize_sizetypes): Set SIZETYPE earlier,
+ clear cache on copied sizetype.
+
+2004-08-20 Ben Elliston <bje@au.ibm.com>
+
+ * configure.ac: Don't escape apostrophe in --enable-coverage help.
+ * configure: Regenerate.
+
+2004-08-20 Danny Smith <dannysmith@users.sourceforge.net>
+
+ PR 5620
+ * gcc.c (struct stat input_stat): Don't define if
+ HOST_LACKS_INODE_NUMBERS
+ (do_spec_1): If HOST_LACKS_INODE_NUMBERS, use lrealpath rather
+ than stat to determine if temp file is same as input file.
+ * doc/hostconfig.texi: Document HOST_LACKS_INODE_NUMBERS.
+ * config/i386/xm-mingw32.h: Define HOST_LACKS_INODE_NUMBERS
+
+2004-08-20 Richard Sandiford <rsandifo@redhat.com>
+
+ * configure.ac (mips*-*-*): Print an error if not using GAS.
+ * configure: Regenerated.
+ * doc/install.texi: Remove irix5 bullet from --with-gnu-as. Remove
+ comments about buggy MIPSpro assemblers.
+ * config.gcc (mips-sgi-irix[56]*): Combine stanzas. Include elfos.h
+ before mips.h and iris.h after it. Use t-iris and t-slibgcc-irix.
+ Use iris5.h only for IRIX 5 configs. Use iris6.h and t-iris6 for
+ IRIX 6 configs. Define IRIX_USING_GNU_LD if using GNU ld.
+ * config/mips/iris5.h (TARGET_IRIX, SWITCHES_NEED_SPACES)
+ (DEFAULT_SIGNED_CHAR, WORD_SWITCH_TAKES_ARG, SUBTARGET_CC1_SPEC)
+ (NO_IMPLICIT_EXTERN_C, MIPS_DEFAULT_GVALUE)
+ (TARGET_ASM_EXTERNAL_LIBCALL): Move to iris.h.
+ (WCHAR_TYPE, WCHAR_TYPE_SIZE, TARGET_OS_CPP_BUILTINS): Delete in favor
+ of more general IRIX 6 definitions.
+ (OBJECT_FORMAT_ELF, ASM_OUTPUT_ASCII, ASM_WEAKEN_LABEL)
+ (HANDLE_SYSV_PRAGMA): Delete in favor of elfos.h definitions.
+ (TARGET_IRIX5, ABICALLS_ASM_OP, BSS_SECTION_ASM_OP, HAS_INIT_SECTION)
+ (LD_INIT_SWITCH, LD_FINI_SWITCH, SUBTARGET_ASM_OPTIMIZING_SPEC)
+ (ASM_FINAL_SPEC, DBX_DEBUGGING_INFO, MIPS_DEBUGGING_INFO)
+ (PREFERRED_DEBUGGING_TYPE, DWARF2_UNWIND_INFO, SET_FILE_NUMBER)
+ (LABEL_AFTER_LOC, DOLLARS_IN_IDENTIFIERS, NO_DOLLAR_IN_LABEL)
+ (TARGET_ASM_NAMED_SECTION, EXTRA_SECTION_FUNCTIONS)
+ (ASM_DECLARE_FUNCTION_SIZE, ASM_OUTPUT_WEAK_ALIAS)
+ (SUBTARGET_EXTRA_SPECS): Delete definitions or undefs.
+ (LINK_SPEC): Move most of definition to iris.h.
+ (SUBTARGET_LINK_SPEC): New macro.
+ (IRIX_STARTFILE_SPEC): Fold into...
+ (STARTFILE_SPEC): ...here.
+ (IRIX_ENDFILE_SPEC): Fold into...
+ (ENDFILE_SPEC): ...here.
+ * config/mips/iris6.h (TARGET_IRIX5): Remove override.
+ (WCHAR_TYPE, WCHAR_TYPE_SIZE, WINT_TYPE, WINT_TYPE_SIZE)
+ (DWARF_OFFSET_SIZE, DWARF_INITIAL_LENGTH_SIZE, SET_ASM_OP)
+ (LINK_ELIMINATE_DUPLICATE_LDIRECTORIES, ASM_DECLARE_OBJECT_NAME)
+ (ASM_FINISH_DECLARE_OBJECT, LOCAL_LABEL_PREFIX): Move to iris.h.
+ (TARGET_OS_CPP_BUILTINS): Likewise. Guard IRIX6-specific bits.
+ (DWARF2_UNWIND_INFO, DWARF2_GENERATE_TEXT_SECTION_LABEL)
+ (SUBTARGET_CPP_SPEC, DWARF2_DEBUGGING_INFO, MIPS_DEBUGGING_INFO)
+ (PREFERRED_DEBUGGING_TYPE, DWARF2_FRAME_INFO, MD_EXEC_PREFIX)
+ (ASM_DECLARE_FUNCTION_NAME, ASM_DECLARE_FUNCTION_SIZE)
+ (FUNCTION_NAME_ALREADY_DECLARED, SUPPORTS_INIT_PRIORITY)
+ (POPSECTION_ASM_OP, SUBTARGET_ASM_SPEC, SUBTARGET_MIPS_AS_ASM_SPEC)
+ (SUBTARGET_ASM_DEBUGGING_SPEC, SUBTARGET_ASM_OPTIMIZING_SPEC)
+ (BSS_SECTION_ASM_OP*, READONLY_DATA_SECTION_ASM_OP*)
+ (EH_FRAME_SECTION_NAME, MUST_USE_SJLJ_EXCEPTIONS, CTORS_SECTION_ASM_OP)
+ (DTORS_SECTION_ASM_OP, TARGET_ASM_NAMED_SECTION, EH_FRAME_SECTION_NAME)
+ (ASM_OUTPUT_ALIGN, ASM_OUTPUT_FILENAME, ASM_OUTPUT_ALIGNED_LOCAL)
+ (ASM_OUTPUT_ALIGNED_BSS): Remove definitions or undefs.
+ (TARGET_IRIX6): Define to 1.
+ (DRIVER_SELF_SPECS): Define.
+ (DWARF2_FRAME_INFO): Define to 1 rather than !TARGET_SGI_O32_AS.
+ (SUBTARGET_CC1_SPEC): Remove in favor of DRIVER_SELF_SPECS.
+ (SUBTARGET_LINK_SPEC): New macro.
+ (IRIX_STARTFILE_SPEC): Fold into...
+ (STARTFILE_SPEC): ...here. Remove !mabi=* case.
+ (SUBTARGET_{,DONT_}WARN_UNUSED_SPEC): New macros.
+ (LIB_SPEC, LIBGCC_SPEC): Use them.
+ (LIB_SPEC): Remove !mabi=* case.
+ (IRIX_ENDFILE_SPEC): Fold into...
+ (ENDFILE_SPEC): ...here. Remove !mabi=* case.
+ * config/mips/mips-protos.h (irix_output_external_libcall): Delete.
+ * config/mips/mips.h (TARGET_IRIX5, TARGET_SGI_O32_AS): Delete.
+ (TARGET_IRIX6): New macro.
+ (ASM_ABI_DEFAULT_SPEC): Remove !ELF definition.
+ (MD_EXEC_PREFIX, MD_STARTFILE_PREFIX, SET_FILE_NUMBER)
+ (LABEL_AFTER_LOC): Delete.
+ * config/mips/mips.c (TARGET_ASM_FILE_START, TARGET_ASM_FILE_END)
+ (TARGET_SECTION_TYPE_FLAGS): Remove TARGET_IRIX versions.
+ (mips_build_builtin_va_list): Check TARGET_IRIX6.
+ (override_options): Remove TARGET_SGI_O32_AS-related code.
+ (irix_output_external_libcall): Make static.
+ (mips_output_filename): Avoid use of SET_FILE_NUMBER and
+ LABEL_AFTER_LOC.
+ (mips_file_start): Tidy guard for ABI sections. Remove use of
+ ABICALLS_ASM_OP; use .abicalls instead.
+ (mips_output_aligned_decl_common, mips_declare_object_name)
+ (mips_finish_declare_object): Remove use of TARGET_SGI_O32_AS.
+ (mips_output_function_prologue): Set TREE_ASM_WRITTEN if emitting
+ .globl foo .text directives.
+ (irix_asm_named_section_1, irix_asm_named_section)
+ (irix_section_align_entry, irix_section_align_htab)
+ (irix_orig_asm_out_file, irix_section_align_entry_eq)
+ (irix_section_align_entry_hash, irix_asm_output_align)
+ (irix_file_start, irix_section_align_1, copy_file_data)
+ (irix_file_end, irix_section_type_flags): Delete.
+ * config/mips/irix-crti.asm (__gcc_init): Move to .gcc_init section.
+ Use standard section syntax. Remove protective "jr $31".
+ (__gcc_fini): Likewise .gcc_fini.
+ * config/mips/irix-crtn.asm: Adjust sections accordingly.
+ * config/mips/sdb.h (PUT_SDB_SIZE, PUT_SDB_TYPE): Moved from
+ iris5gas.h.
+ * config/mips/t-iris (irix-crti.o, irix-crtn.o): New rules, moved
+ from t-irix-gld.
+ (EXTRA_MULTILIB_PARTS): Define.
+ * config/mips/t-iris6: Remove bogus comment.
+ (EXTRA_MULTILIB_PARTS, CRTSTUFF_T_CFLAGS): Delete.
+ * config/mips/iris5gas.h, config/mips/iris5gld.h,
+ config/mips/iris6gas.h, config/mips/iris6gld.h,
+ config/mips/t-iris5-as, config/mips/t-iris5-gas
+ config/mips/t-irix-gld: Delete.
+ * config/mips/iris.h: New file.
+ * config/mips/t-slibgcc-irix: Renamed from t-iris5-6.
+
+2004-08-20 Richard Earnshaw <rearnsha@arm.com>
+
+ * postreload.c (reload_cse_move2add): Allow any condjump, but check
+ that the implicit set isn't clobbered in the jump insn.
+
+2004-08-19 Mark Mitchell <mark@codesourcery.com>
+
+ * defaults.h (TARGET_LIBGCC_LIBFUNCS): Remove.
+ * optabs.c (init_optabs): Don't check it.
+ * config/arm/bpabi.h (TARGET_LIBGCC_LIBFUNCS): Do not define.
+ * doc/tm.texi (TARGET_LIBGCC_FUNCS): Remove.
+
+2004-08-18 Andreas Krebbel <krebbel1@de.ibm.com>
+
+ * config/s390/s390.md (s390_warn_framesize_string)
+ (s390_warn_dynamic_string, s390_stack_size_string)
+ (s390_stack_guard_string): New global string variables.
+ (s390_warn_framesize, s390_warn_dynamicstack_p, s390_stack_size)
+ (s390_stack_guard): New global variables.
+ (override_options): Added checks for the new options.
+ (s390_emit_prologue): Emit stack check and trap code and perform
+ compile time stack size checking.
+
+ * config/s390/s390.h (TARGET_OPTIONS): Added new options
+ "warn-framesize", "warn-dynamicstack", "stack-size" and
+ "stack-guard".
+
+ * doc/invoke.texi: Added documentation for the new options.
+
+2004-08-19 Ulrich Weigand <uweigand@de.ibm.com>
+
+ * unwind-dw2-fde.c (get_cie_encoding): Cast argument to strlen
+ to eliminate warning.
+ (linear_search_fdes): Declare p as unsigned.
+ (binary_search_mixed_encoding_fdes): Likewise.
+ * unwind-dw2.c (get_cie_encoding): Cast argument to strlen
+ to eliminate warning.
+ * config/s390/linux.h (MD_FALLBACK_FRAME_STATE_FOR): Add missing
+ type cast.
+
+2004-08-19 Ulrich Weigand <uweigand@de.ibm.com>
+
+ * config/s390/s390-protos.h (preferred_la_operand_p): Adapt prototype.
+ * config/s390/s390.c (preferred_la_operand_p): Accept two operands
+ instead of one. Check for strictly legitimate address.
+ * config/s390/s390.md ("*la_31"/"*la_64" peepholes): Adapt call
+ to preferred_la_operand_p, do not call gen_rtx_PLUS in predicate.
+
+2004-08-19 Eric Christopher <echristo@redhat.com>
+
+ * langhooks-def.h (LANG_HOOKS_UNSAVE_EXPR_NOW): Remove.
+ * langhooks.h (unsave_expr_now): Ditto.
+ * tree.h (unsave_expr_1): Remove prototype.
+ (lhd_unsave_expr_now): Rename to unsave_expr_now.
+ * tree-inline.c (unsave_expr_1): Move here
+ from tree.c. Make static.
+ (unsave_expr_now): Rename from lhd_unsave_expr_now.
+ * tree-sra.c: Fix up for rename.
+ * tree-ssa-copy.c: Ditto.
+ * tree-eh.c: Ditto.
+ * tree.c (unsave_expr_1): Move to tree-inline.c.
+
+2004-08-19 Caroline Tice <ctice@apple.com>
+
+ * config/i386/cygming.h (switch_to_section): Fix typo (change
+ in_unlikely_text_section to in_unlikely_executed_text).
+
+2004-08-19 Daniel Berlin <dberlin@dberlin.org>
+
+ * vec.h (VEC_lower_bound): New macro.
+
+2004-08-19 Richard Sandiford <rsandifo@redhat.com>
+
+ PR target/16446
+ * config/mips/mips.c (struct mips_arg_info): Delete num_bytes.
+ (mips_arg_info): Update accordingly. Remove common treatment of fpr_p;
+ treat each ABI separately. Deal with n32/n64 complex float arguments.
+ (function_arg): Add associated complex handling here.
+
+2004-08-19 Richard Henderson <rth@redhat.com>
+
+ * config/arm/arm.c (arm_gen_load_multiple): Use
+ adjust_automodify_address. Take base memory and offset instead
+ of unchanging/struct/scalar bits.
+ (arm_gen_store_multiple): Likewise.
+ (arm_gen_movmemqi): Use adjust_automodify_address.
+ * config/arm/arm-protos.h: Update decls.
+ * config/arm/arm.md (load_multiple): Update arm_gen_load_multiple call.
+ (store_multiple): Similarly.
+
+2004-08-19 J"orn Rennecke <joern.rennecke@superh.com>
+
+ * regclass.c (globalize_reg): Update call_really_used_regs.
+
+2004-08-19 Nathan Sidwell <nathan@codesourcery.com>
+
+ * doc/invoke.texi (integer-share-limit): Document.
+
+ * tree.h (TYPE_CACHED_VALUES_P): New.
+ (TYPE_CACHED_VALUES): New.
+ (TYPE_ORIG_SIZE_TYPE): Adjust.
+ * tree.def (INTEGER_CST): Update documentation.
+ * tree.c: Inlcude params.h.
+ (build_int_cst): Cache small values.
+ (build_type_copy): Do not copy the value cache.
+ * c-common.c (c_common_nodes_and_builtins): Add comment, remove
+ unneeded zeroing.
+ * c-typeck.c (build_c_cast): Add comment about OVERFLOW setting.
+ * expmed.c (const_mult_add_overflow_p): Clear type copy's value
+ cache.
+ * fold-const.c (force_fit_type): Copy value when setting
+ overflows.
+ (int_const_binop): Likewise.
+ * stor-layout.c: Include params.h
+ (set_sizetype): Create values cache.
+ (fixup_unsigned_type): Set UNSIGNED_P before caching any values.
+ * params.def (PARAM_INTEGER_SHARE_LIMIT): New.
+ * params.h (INTEGER_SHARE_LIMIT): New.
+ * Makefile.in (tree.o, stor-layout.o): Depend on PARAMS_H.
+
+2004-08-19 Paolo Bonzini <bonzini@gnu.org>
+
+ * gimplify.c (gimplify_minimax_expr): Remove.
+ (gimplify_expr) <MIN_EXPR, MAX_EXPR>: Remove special handling.
+
+2004-08-19 Dorit Naishlos <dorit@il.ibm.com>
+
+ * tree-vectorizer.c (vect_can_force_dr_alignment_p): Replace
+ STACK_BOUDARY with PREFERRED_STACK_BOUNDARY.
+
+2004-08-19 Mark Mitchell <mark@codesourcery.com>
+
+ * bpabi.h (FPUTYPE_DEFAULT): Set it to FPUTYPE_VFP.
+
+2004-08-18 Andrew Pinski <apinski@apple.com>
+
+ * varasm.c (ecode_reg_name): Do nothing if the asmspec is empty.
+
+2004-08-18 Mark Mitchell <mark@codesourcery.com>
+
+ * config/arm/bpabi.c (__aeabi_ul2d): Give it default visibility.
+ (__aeabi_ul2f): Likewise.
+
+2004-08-18 Richard Henderson <rth@redhat.com>
+
+ * config/xtensa/xtensa.c (xtensa_expand_block_move): Expand block
+ move to rtl completely.
+ (struct meminsnbuf, xtensa_emit_block_move): Remove.
+ (xtensa_find_mode_for_size): Remove.
+ * config/xtensa/xtensa-protos.h (xtensa_emit_block_move): Remove.
+ * config/xtensa/xtensa.md (movmemsi_internal): Remove.
+
+2004-08-18 Richard Henderson <rth@redhat.com>
+
+ * config/mcore/mcore.c (mode_from_align): Remove DImode.
+ (block_move_sequence): Rewrite to use adjust_address.
+ (mcore_expand_block_move): Cleanup logic. Accept only operands.
+ Return boolean indicating success/failure.
+ * config/mcore/mcore-protos.h (mcore_expand_block_move): Update decl.
+ * config/mcore/mcore.md (movmemsi): Update to match.
+
+2004-08-18 Mike Stump <mrs@apple.com>
+
+ * doc/invoke.texi (-mfix-and-continue): Add support for
+ fast turn around debugging.
+ (-ffix-and-continue): Likewise.
+ (-mindirect-data): Likewise.
+ (-findirect-data): Likewise.
+ * config/darwin.c (TARGET_FIX_AND_CONTINUE): Likewise.
+ (indirect_data): Likewise.
+ (machopic_data_defined_p): Likewise.
+ (machopic_output_indirection): Likewise.
+ (darwin_encode_section_info): Likewise.
+ (darwin_fix_and_continue): Likewise.
+ (darwin_fix_and_continue_switch): Likewise.
+ * config/darwin.h (MACHO_SYMBOL_STATIC): Likewise.
+ * config/rs6000/darwin.h (SUBTARGET_OVERRIDE_OPTIONS): Likewise.
+ (SUBTARGET_OPTION_TRANSLATE_TABLE): Likewise.
+ (SUBTARGET_OPTIONS): Likewise.
+ (darwin_fix_and_continue): Likewise.
+ (darwin_fix_and_continue_switch): Likewise.
+ (TARGET_FIX_AND_CONTINUE): Likewise.
+ * config/rs6000.c (rs6000_emit_prologue): Likewise.
+
+2004-08-19 Steven Bosscher <stevenb@suse.de>
+
+ * basic-block.h (struct edge_def): Remove crossing_edge.
+ (EDGE_CROSSING): New define.
+ (EDGE_ALL_FLAGS): Update.
+ * bb-reorder.c (find_traces_1_round, better_edge_p,
+ find_rarely_executed_basic_blocks_and_cr, fix_up_fall_thru_edges,
+ find_jump_block, fix_crossing_conditional_branches,
+ fix_crossing_unconditional_branches, add_reg_crossing_jump_notes):
+ Replace all occurences of crossing_edge with an edge flag check
+ or set/reset.
+ * cfgcleanup.c (try_simplify_condjump, try_forward_edges,
+ try_crossjump_bb): Likewise.
+ * cfglayout.c (fixup_reorder_chain): Likewise.
+ * cfgrtl.c (force_nonfallthru_and_redirect,
+ commit_one_edge_insertion): Likewise.
+
+ * Makefile.in (cfganal.o): Depend on TIMEVAR_H.
+ * tree-flow.h (compute_dominance_frontiers): Move prototype...
+ * basic-block.h: ...here.
+ * tree-cfg.c (compute_dominance_frontiers_1,
+ compute_dominance_frontiers): Move from here...
+ * cfganal.c: ...to here. Include timevar.h.
+
+2004-08-18 James E Wilson <wilson@specifixinc.com>
+
+ * config/mips/mips.h (ASM_SPEC): In comment, change -meabi= to -mabi=.
+ * config/mips/sb1.md (ir_sb1_divsf_1pipe): Renamed from ...1pipes.
+
+ * config/mips/mips.md (type): Add frdiv.
+ (divsf3+1, divsf3+2): Change type to frdiv.
+ * config/mips/sb1.md (ir_sb1_recipsf_2pipes, ir_sb1_recipsf_1pipe,
+ ir_sb1_recipdf_2pipes, ir_sb1_recipdf_1pipe): New.
+
+ * config/mips/3000.md (r3k_fdiv_single, r3k_fdiv_double): Add frdiv.
+ * config/mips/4300.md (r4300_fdiv_single, r4300_fdiv_double): Likewise.
+ * config/mips/4600.md (r4600_fdiv_single, f4600_fdiv_double): Likewise.
+ * config/mips/5000.md (r5k_fdiv_single): Likewise.
+ * config/mips/5400.md (ir_vr54_fdiv_sf, ir_vr54_fdiv_df): Likewise.
+ * config/mips/5500.md (ir_vr55_fdiv_sf, ir_vr55_fdiv_df): Likewise.
+ * config/mips/6000.md (r6k_fdiv_single, r6k_fdiv_double): Likewise.
+ * config/mips/7000.md (rm7_fp_divsqrt_df, rm7_fp_divsqrt_sf): Likewise.
+ * config/mips/9000.md (rm8k_fdivs, rm9k_fdivd): Likewise.
+ * config/mips/generic.md (generic_fdiv_single, generic_fdiv_double):
+ Likewise.
+ * config/mips/sr71k.md (ir_sr70_fdiv_sf, ir_sr70_fdiv_df): Likewise.
+
+2004-08-18 Robert Bowdidge <bowdidge@apple.com>
+
+ * config/rs6000/x-darwin: Remove XCFLAGS -mdynamic-no-pic to
+ get regression tester working again.
+
+2004-08-18 Zack Weinberg <zack@codesourcery.com>
+
+ * insn-notes.def, reg-notes.def: New files.
+ * rtl.h: Use them to define enum insn_note and enum reg_note.
+ * rtl.c: Use them to define note_insn_name and reg_note_name.
+ * Makefile.in (RTL_BASE_H): Update.
+
+ * modulo-sched.c, sched-rgn.c, final.c: NOTE_DISABLE_SCHED_OF_BLOCK
+ renamed to NOTE_INSN_DISABLE_SCHED_OF_BLOCK.
+
+2004-08-18 Richard Earnshaw <rearnsha@arm.com>
+
+ * arm.c (arm_size_rtx_costs): New function.
+ (arm_override_options): Use it if optimizing for space.
+
+2004-08-18 Richard Henderson <rth@redhat.com>
+
+ * emit-rtl.c (gen_const_mem): New.
+ * rtl.h (gen_const_mem): Declare.
+ * expr.c (do_tablejump): Use it.
+ * varasm.c (force_const_mem): Likewise.
+ * config/darwin.c (machopic_indirect_data_reference): Likewise.
+ (machopic_legitimize_pic_address): Likewise.
+ * config/arm/arm.c (legitimize_pic_address): Likewise.
+ * config/i386/i386.c (legitimize_pic_address): Likewise.
+ (legitimize_tls_address): Likewise.
+ * config/ia64/ia64.c (ia64_expand_tls_address): Likewise.
+ * config/ia64/ia64.md (load_fptr): Likewise.
+ * config/m32r/m32r.c (m32r_legitimize_pic_address): Likewise.
+ * config/pa/pa.c (legitimize_pic_address): Likewise.
+ * config/rs6000/rs6000.c (rs6000_legitimize_tls_address): Likewise.
+ (rs6000_emit_move): Likewise.
+ * config/s390/s390.c (legitimize_pic_address): Likewise.
+ (legitimize_tls_address): Likewise.
+ * config/s390/s390.md (casesi): Likewise.
+ * config/sh/sh.c (sh_reorg): Likewise.
+ * config/sparc/sparc.c (legitimize_pic_address): Likewise.
+ * config/v850/v850.md (casesi): Likewise.
+
+ * config/darwin.c (machopic_indirect_call_target): Set MEM_NOTRAP_P.
+ * config/sh/sh.c (prepare_move_operands): Remove incorrect
+ use of MEM_READONLY_P.
+
+2004-08-18 Steven Bosscher <stevenb@suse.de>
+
+ * Makefile.in (OBJS-common): Add postreload-gcse.c.
+ Add new postreload-gcse.o.
+ * cse.c (SAFE_HASH): Define as wrapper around safe_hash.
+ (lookup_as_function, insert, rehash_using_reg, use_related_value,
+ equiv_constant): Use SAFE_HASH instead of safe_hash.
+ (exp_equiv_p): Export. Add for_gcse argument when comparing
+ for GCSE.
+ (lookup, lookup_for_remove, merge_equiv_classes, find_best_addr,
+ find_comparison_args, fold_rtx, cse_insn): Update callers.
+ (hash_rtx): New function derived from old canon_hash and bits
+ from gcse.c hash_expr_1.
+ (canon_hash_string): Rename to hash_rtx_string.
+ (canon_hash, safe_hash): Make static inline. Call hash_rtx.
+ * cselib.c (hash_rtx): Rename to cselib_hash_rtx.
+ (cselib_lookup): Update this caller.
+ * gcse.c (modify_mem_list_set, canon_modify_mem_list_set):
+ Make static.
+ (hash_expr): Call hash_rtx.
+ (ldst_entry): Likewise.
+ (expr_equiv_p): Call exp_equiv_p.
+ (struct unoccr, hash_expr_1, hash_string_1, lookup_expr,
+ reg_used_on_edge, reg_set_between_after_reload_p,
+ reg_used_between_after_reload_p, get_avail_load_store_reg,
+ is_jump_table_basic_block, bb_has_well_behaved_predecessors,
+ get_bb_avail_insn, hash_scan_set_after_reload,
+ compute_hash_table_after_reload,
+ eliminate_partially_redundant_loads, gcse_after_reload,
+ get_bb_avail_insn, gcse_after_reload_main): Remove.
+ * postreload-gcse.c: New file, reincarnating most of the above.
+ * rtl.h (exp_equiv_p, hash_rtx): New prototypes.
+ (gcse_after_reload_main): Update prototype.
+ * timevar.def (TV_GCSE_AFTER_RELOAD): New timevar.
+ * passes.c (rest_of_handle_gcse2): Use it.
+
+2004-08-18 Diego Novillo <dnovillo@redhat.com>
+
+ * tree-ssa-loop.c (pass_loop_init): Add TODO_dump_func.
+ (pass_loop_done): Likewise.
+
+2004-08-18 Andrew Pinski <apinski@apple.com>
+
+ * config/rs6000/darwin.md: Delete the altivec patterns which are
+ handled differently now.
+ (load_macho_picbase_di): Make sure that is only happens for TARGET_64BIT
+ (macho_correct_pic_di): Likewise.
+ (call_indirect_nonlocal_darwin64): Likewise.
+ Delete the save world/saveFP/saveVec patterns.
+
+ Revert the reversion of: 2004-08-16 Stan Shebs <shebs@apple.com>
+ * config/darwin.c (macho_indirect_data_reference): Add DImode case.
+ * config/rs6000/rs6000.md: Include darwin.md.
+ (builtin_setjmp_receiver): Add DImode case.
+ * config/rs6000/rs6000.c (rs6000_emit_move): Add DImode case to
+ Darwin bits.
+
+2004-08-18 Matt Austern <austern@apple.com>
+
+ Dead code stripping
+ * darwin.h (EH_FRAME_SECTION_ATTR): Mark so it doesn't get stripped.
+ * darwin.c (darwin_file_end): Mark file as potentially strippable.
+
+2004-08-18 Richard Henderson <rth@redhat.com>
+
+ * alias.c (readonly_fields_p): Remove.
+ (objects_must_conflict_p): Don't call it.
+ * tree.h (readonly_fields_p): Remove.
+ * langhooks.h (struct lang_hooks): Remove honor_readonly.
+ * langhooks-def.h (LANG_HOOKS_HONOR_READONLY): Remove.
+
+2004-08-18 Diego Novillo <dnovillo@redhat.com>
+
+ * tree-dfa.c (add_referenced_var): Only global variables are
+ call-clobbered.
+ * tree-flow.h (struct ptr_info_def): Add field pt_global_mem.
+ * tree-ssa-alias.c (compute_points_to_and_addr_escape): Mark
+ all pointers dereferenced if the statement dereferences them.
+ (create_name_tags): Do not create memory tags for pointers
+ that have PT_ANYTHING set.
+ Also check if PT_VARS is not empty before creating a name tag.
+ (compute_flow_sensitive_aliasing): Don't mark call-clobbered
+ variables that share the same alias set with a pointer that
+ may point anywhere.
+ (add_may_alias): Add FIXME comment to remove clobbering
+ aliased variables and tags.
+ (replace_may_alias): Likewise.
+ (set_pt_anything): Do not clear PT_VARS nor IS_DEREFERENCED.
+ (merge_pointed_to_info): If the original variable has not
+ points-to information, call set_pt_anything.
+ (add_pointed_to_var): Do not prevent adding a pointed-to
+ variable if the pointers is PT_ANYTHING.
+ If the variable is a global, set PT_GLOBAL_MEM.
+ (collect_points_to_info_r): Don't assume that PLUS_EXPRs of
+ pointer type only come in PTR+OFFSET flavours.
+ Always call merge_pointed_to_info on PHI arguments that are
+ SSA_NAMEs.
+ (get_nmt_for): Mark call-clobbered tags whose pointer points
+ to global memory.
+ * tree-ssa-operands.c (opf_kill_def, opf_no_vops): Switch
+ values.
+ (get_indirect_ref_operands): Always clear OPF_KILL_DEF from
+ FLAGS.
+ (add_stmt_operand): Abort if the caller tried to add a killing
+ definition for a memory tag.
+ * tree-ssa.c (verify_flow_sensitive_alias_info): Remove
+ unnecessary checks.
+
+2004-08-18 J"orn Rennecke <joern.rennecke@superh.com>
+
+ * sh.h (CONDITIONAL_REGISTER_USAGE): Don't exclude fixed registers
+ from call_used_regs. Update call_really_used_regs.
+ (CALL_REALLY_USED_REGISTERS): Define.
+ * sh.c (output_stack_adjust, shmedia_target_regs_stack_space):
+ Replace call_used_regs with call_really_used_regs.
+ (calc_live_regs, sh_media_register_for_return): Likewise.
+ (sh5_schedule_saves, sh_expand_prologue, reg_unused_after): Likewise.
+ * sh.md (return_media): Likewise.
+
+2004-08-18 Andrew Pinski <apinski@apple.com>
+
+ * config/darwin.c (machopic_legitimize_pic_address): Only set
+ MEM_READONLY_P in the non TARGET_TOC case.
+
+2004-08-18 Zack Weinberg <zack@codesourcery.com>
+
+ * rtl.def (NIL): Delete.
+ * read-rtl.c (read_rtx): Handle (nil) like (define_constants).
+ Tighten the syntax a little.
+
+ * cfgloop.h, combine.c, cse.c, loop-iv.c, postreload.c, reload.c
+ * config/alpha/alpha.c, config/alpha/alpha.h, config/arc/arc.h
+ * config/arm/arm.h, config/frv/frv.h, config/i386/i386.c
+ * config/i386/predicates.md, config/m32r/m32r.h
+ * config/m68hc11/m68hc11.c, config/mcore/mcore.h, config/mips/mips.c
+ * config/mmix/mmix.c, config/pa/pa.h, config/sh/sh.h
+ * config/sparc/sparc.h, doc/tm.texi:
+ Replace all occurrences of NIL with UNKNOWN.
+
+2004-08-18 Zack Weinberg <zack@codesourcery.com>
+
+ * dojump.c (do_jump <unordered_bcc>): Do not recursively call
+ self with a TRUTH_ORIF_EXPR; generate the appropriate jump
+ sequence inline. Move drop_through_label code into this
+ block, being the only place it is used. Adjust comments.
+
+2004-08-18 Fariborz Jahanian <fjahanian@apple.com>
+
+ * config/rs6000/altivec.md: Add new patterns for calls to
+ save_world/rest_world functions.
+
+ * config/rs6000/rs6000-protos.h: (save_world_operation,
+ restore_world_operation) new declarations.
+
+ * config/rs6000/rs6000.c: (struct rs6000_stack) new world_save_p
+ field added.
+ (rs6000_stack_info): Set world_save_p field.
+ (save_world_operation): New function.
+ (restore_world_operation): New function.
+ (compute_save_world_info): New function.
+ (rs6000_stack_info): Call compute_save_world_info.
+ (rs6000_emit_prologue): Check for world_save_p and generate
+ pattern to call save_world for saving all non-volatile and
+ special registers.
+ (rs6000_emit_epilogue): Check for world_save_p and generate
+ pattern to call rest_world to restore saved registers.
+
+ config/rs6000/rs6000.h: macros FIRST_SAVED_ALTIVEC_REGNO,
+ FIRST_SAVED_FP_REGNO, FIRST_SAVED_GP_REGNO defined.
+ (rs6000_reg_names): New entries added for save_world_operation and
+ restore_world_operation.
+
+2004-08-18 Caroline Tice <ctice@apple.com>
+
+ * Makefile.in (STAGEFEEDBACK_FLAGS_TO_PASS) Add
+ "-freorder-blocks-and-partition" to the flags used in second
+ stage of profiledbootstrap.
+ * bb-reorder.c (push_to_next_round_p): Add new variable,
+ next_round_is_last; set and use variable to make sure, when
+ partitioning, that the last trace construction round consists
+ of all (and only) cold basic blocks.
+ (rotate_loop): Don't copy blocks that end in a section
+ crossing jump.
+ (copy_bb): Correctly initialize "partition" of duplicated bb.
+ (add_unlikely_executed_notes): Add a comment.
+ (find_rarely_executed_basic_blocks_and_crossing_edges): Modify
+ to make sure, if function contains hot blocks, that the
+ successors of ENTRY_BLOCK_PTR are hot; also, only look for
+ crossing edges if the architecture supports named sections.
+ (mark_bb_for_unlikely_executed_section): Modify to always
+ insert the NOTE_INSN_UNLIKELY_EXECUTED_CODE immediately after
+ the basic block note insn.
+ (fix_crossing_unconditional_branches): Remove extra space.
+ (fix_edges_for_rarely_executed_code): Modify to only do
+ partitioning work if the architecture supports named sections.
+ (reorder_basic_blocks): Modify to only add
+ NOTE_INSN_UNLIKELY_EXECUTED_CODE notes if the architecture
+ supports named sections.
+ * c-common.c (handle_section_attribute): Initialize new global
+ variable, user_defined_section_attribute, to true if user has
+ specified one.
+ * cfgcleanup.c (try_forward_edges): Modify to not attempt to
+ forward edges that cross section boundaries.
+ * cfglayout.c (fixup_reorder_chain): Modify to only fix up
+ partitioning information if the architecture supports named
+ sections.
+ * cfgrtl.c (target.h): Add statement to include this.
+ (rtl_split_block): Make sure newly created bb gets correct
+ partition.
+ (try_redirect_by_replacing_jump): Make sure redirection isn't
+ attempting to cross section boundaries.
+ (force_nonfallthru_and_redirect): Only do partition fix up if
+ architecture supports named sections.
+ (rtl_split_edge): Make sure newly created bb ends up in
+ correct partition.
+ (commit_one_edge_insertion): Remove code that incorrectly
+ updated basic block partition; Make sure partition fix up only
+ happens if architecture supports named sections and it's not
+ already done.
+ (rtl_verify_flow_info_1): Fix if-condition on test/error
+ condition that fallthru edges are not allowed to cross section
+ boundaries.
+ * defaults.h (NORMAL_TEXT_SECTION_NAME): Remove this.
+ * final.c (final_scan_insn): Remove redundant test from if-statement;
+ change calls to text_section into calls to function_section; add code
+ to only to partitioning fix up if architecture supports named
+ sections.
+ * ifcvt.c (find_if_case_1): Make sure newly created bb has correct
+ partition.
+ (if_convert): Add targetm.have_named_sections to test.
+ * output.h (unlikely_section_label): Extern declaration for new global
+ variable.
+ (unlikely_text_section_name): Likewise.
+ * opts.c (decode_options): If both partitioning and DWARF debugging
+ are turned on, issue a warning that this doesn't work, and change
+ partitiong to basic block reordering (without hot/cold partitions).
+ * passes.c (rest_of_handle_final): Re-set new global variable,
+ user_defined_section_attribute, to false.
+ (rest_of_compilation): Change options for calling partitioning
+ function: Don't call if the user defined the section attribute, and
+ don't call if DECL_ONE_ONLY is true for the current function.
+ * predict.c (choose_function_section): Return immediately if we
+ are doing hot/cold partitioning (i.e. let the basic block partitioning
+ determine where the function belongs).
+ * reg-stack.c (emit_swap_insn): Add condition to step over
+ NOTE_INSN_UNLIKELY_EXECUTED_CODE notes.
+ * toplev.c (user_defined_section_attribute): New global variable.
+ * toplev.h (user_defined_section_attribute): Extern declaration
+ for new global variable.
+ * varasm.c (unlikely_section_label): New global variable.
+ (unlikely_text_section_name): New global variable.
+ (unlikely_text_section): Add code to initialize
+ unlikely_text_section_name if necessary; modify to use
+ unlikely_text_section_name and unlikely_section_label; also to use
+ named_section properly.
+ (in_unlikely_text_section): Modify to work correctly with
+ named_section and to use unlikely_text_section_name.
+ (named_section): Add code to work properly with cold section.
+ (function_section): Clean up if-statement.
+ * config/darwin.c (darwin_asm_named_section): Return to original
+ code, removing use of SECTION_FORMAT_STRING.
+ * config/arm/pe.h (switch_to_section): Add case for
+ in_unlikely_executed_text to switch statement.
+ * config/i386/cygming.h (switch_to_section): Likewise.
+ * config/i386/darwin.h (NORMAL_TEXT_SECTION_NAME): Remove.
+ (SECTION_FORMAT_STRING): Likewise.
+ * config/mcore/mcore.h (switch_to_section): Likewise.
+ * config/rs6000/darwin.h (NORMAL_TEXT_SECTION_NAME): Remove.
+ (SECTION_FORMAT_STRING): Remove.
+
2004-08-18 Roger Sayle <roger@eyesopen.com>
* config/i386/i386.h (FIXED_REGISTERS): Update encoding to be
(prescan_loop): Likewise. Don't check function usage for clobbered
unchanging memory.
* rtlanal.c (rtx_unstable_p): Check MEM_READONLY_P,
- not RTX_UNCHANGING_P.
+ not RTX_UNCHANGING_P.
(rtx_varies_p, modified_between_p, modified_in_p): Likewise.
* varasm.c (force_const_mem): Likewise.
* stmt.c (expand_decl): Don't set RTX_UNCHANGING_P.
MEM_READONLY_P instead of RTX_UNCHANGING_P.
(machopic_indirect_call_target): Likewise.
(machopic_legitimize_pic_address): Likewise.
- * config/arm/arm.c (legitimize_pic_address, arm_gen_load_multiple,
+ * config/arm/arm.c (legitimize_pic_address, arm_gen_load_multiple,
arm_gen_store_multiple, arm_gen_movmemqi): Likewise.
* config/arm/arm.md (load_multiple, store_multiple): Likewise.
* config/frv/frv.md (symGOT2reg): Likewise.
(xstormy16_reorg): New.
(TARGET_MACHINE_DEPENDENT_REORG): Define.
-
* config/stormy16/stormy16.md (movqi_internal): Make name public.
(movhi_internal): Likewise.
(cbhranchhi): Likewise.
xstormy16_below100_operand, xstormy16_below100_or_register,
xstormy16_onebit_set_operand, xstormy16_onebit_clr_operand): New.
(PREDICATE_CODES): Add new predicates.
-
+
* config/stormy16/stormy16.c
(xstormy16_asm_output_aligned_common, xstormy16_below100_symbol,
xstormy16_below100_operand, xstormy16_below100_or_register,
* doc/invoke.texi (-fkeep-inline-functions): Update documentation.
2004-08-17 Robert Bowdidge <bowdidge@apple.com>
-
- * config/rs6000/x-darwin: Add -mdynamic-no-pic to gcc build flags.
+
+ * config/rs6000/x-darwin: Add -mdynamic-no-pic to gcc build flags.
2004-08-17 Andreas Tobler <a.tobler@schweiz.ch>
2004-08-17 Dorit Naishlos <dorit@il.ibm.com>
- * tree-vectorizer.c: New File: loop vectorization on SSAed GIMPLE trees.
+ * tree-vectorizer.c: New File: loop vectorization on SSAed GIMPLE
+ trees.
* tree-vectorizer.h: New File: Same.
* Makefile.in (tree-vectorizer.c, tree-vectorizer.h): Add new files.
* common.opt (ftree-vectorize): New flag to enable vectorization.
- * timevar.def (TV_TREE_VECTORIZATION): New dump file for vectorization
- pass.
+ * timevar.def (TV_TREE_VECTORIZATION): New dump file for
+ vectorization pass.
* tree-data-ref.h (init_data_ref): Additional argument.
(array_base_name_differ_p): Moved to tree-data-ref.c.
* tree-data-ref.c (array_base_name_differ_p): Revised.
with an extra argument.
(analyze_all_data_dependences): Same.
(init_data_ref): Additional argument is_read to set DR_IS_READ.
- * tree-ssa-phiopt.c (empty_block_p): Expose for usage out of this file.
+ * tree-ssa-phiopt.c (empty_block_p): Expose for usage out of this
+ file.
* tree-flow.h (vectorize_loops, empty_block_p): Add declaration.
* tree-optimize.c (pass_vectorize): Schedule the vectorization pass.
- * tree-pass.h (tree_opt_pass pass_vectorize): Declare the new
+ * tree-pass.h (tree_opt_pass pass_vectorize): Declare the new
vectorization pass.
* tree-ssa-loop.c (tree_ssa_loop_init): Call scev_initialize.
(tree_ssa_loop_done): Call scev_finalize.
(tree_vectorize): Define the new vectorization pass.
- * defaults.h (UNITS_PER_SIMD_WORD): Allow targets to specify the size of
- the vector they support (until support for multiple vector sizes is
- added to the vectorizer).
+ * defaults.h (UNITS_PER_SIMD_WORD): Allow targets to specify the
+ size of the vector they support (until support for multiple vector
+ sizes is added to the vectorizer).
* config/i386/i386.h (UNITS_PER_SIMD_WORD): Define.
* config/rs6000/rs6000.h (UNITS_PER_SIMD_WORD): Define.
* invoke.texi (fdump-tree-vect, ftree-vectorize): Add
2004-08-16 Adam Nemet <anemet@lnxw.com>
* Makefile.in (LIBS): Move $(LIBIBERTY) after $(BANSHEELIB).
-
+
2004-08-16 Andrew Pinski <apinski@apple.com>
* target-def.h (TARGET_EH_RETURN_FILTER_MODE): Remove
* config/i386/xmmintrin.h: Include <mm_malloc.h>.
2004-08-03 H.J. Lu <hongjiu.lu@intel.com>
- Tanguy Fautrà <tfautre@pandora.be>
+ Tanguy FautrÃ\83 <tfautre@pandora.be>
* config/i386/pmm_malloc.h: New file.