1. 19 Nov, 2000 1 commit
    • Warning fixes: · ce1cc601
      	* builtins.c (c_getstr): Constify variable.
      	* gmon-sol2.c (_mcleanup): Comment out #endif labels.
      	* conflict.c (const_conflict_graph_arc): New typedef.
      	(arc_hash, arc_eq): Avoid needlessly casting away const-ness.
      	* cppmacro.c (builtin_macro): Likewise.
      	* dwarf2out.c (output_comp_unit): Constify variable.
      	* fix-header.c (v_fatal): Add ATTRIBUTE_PRINTF.
      	* protoize.c (IS_SAME_PATH_CHAR): Use TOUPPER, not toupper.
      	* ssa.c (ssa_rename_from_hash_function): Avoid needlessly casting
      	away const-ness.
      	* tradcpp.c (rescan, do_line, macroexpand, macarg): Use
      	ISALNUM/ISDIGIT/ISPRINT, not isalnum/isdigit/isprint.
      	* varasm.c (const_str_htab_hash, const_str_htab_eq,
      	compare_constant_1, record_constant_1): Constify.
      
      From-SVN: r37565
      Kaveh R. Ghazi committed
  2. 14 Nov, 2000 1 commit
    • Michael Matz <matzmich@cs.tu-berlin.de> · f8032688
              * dominance.c: New file.
              * Makefile.in (OBJS): Add dominance.o.
      
              * flow.c (compute_flow_dominators): Remove.
              (compute_immediate_dominators): Remove.
              (compute_immediate_postdominators): Remove.
              * basic-block.h: Remove their prototypes.
              (calculate_dominance_info): Add prototype.
      
              * dce.c (eliminate_dead_code): Change calls to above functions.
              Don't compute dominators but only immediate dominators.
              * flow.c (flow_loops_find): Change callers.
              * gcse.c (compute_code_hoist_data): Likewise.
              * haifa-sched.c (schedule_insns): Likewise.
              * ifcvt.c (if_convert): Likewise.
              * ssa.c (convert_to_ssa): Likewise, and only compute immediate
              dominators.
      
      From-SVN: r37449
      Michael Matz committed
  3. 07 Nov, 2000 1 commit
    • alias.c [...] (init_alias_analysis, [...]): Use memset () instead of bzero (). · 961192e1
      	* alias.c (init_alias_analysis), calls.c (expand_call,
      	emit_library_call_value_1), combine.c (init_reg_last_arrays),
      	cse.c (new_basic_block), dbxout.c (dbxout_type), diagnostic.c
      	(init_output_buffer, set_diagnostic_context), dwarf2out.c
      	(equate_decl_number_to_die, build_abbrev_table), emit-rtl.c
      	(init_emit_once), fold-const.c (mul_double, div_and_round_double),
      	function.c (assign_parms), gcse.c (compute_can_copy,
      	alloc_gcse_mem, alloc_reg_set_mem, record_one_set,
      	compute_hash_table, compute_set_hash_table,
      	compute_expr_hash_table), genattrtab.c (optimize_attrs), global.c
      	(global_alloc, global_conflicts), haifa-sched.c (compute_trg_info,
      	clear_units, schedule_block), integrate.c (initialize_for_inline,
      	expand_inline_function), jump.c (thread_jumps), local-alloc.c
      	(local_alloc), loop.c (combine_movables, count_loop_regs_set,
      	load_mems_and_recount_loop_regs_set), print-tree.c (debug_tree),
      	regclass.c (init_reg_sets, init_reg_sets_1, regclass,
      	record_reg_classes, allocate_reg_info), reload.c
      	(get_secondary_mem, remove_address_replacements, find_reloads),
      	reload1.c (reload, set_initial_label_offsets, finish_spills,
      	reload_as_needed, choose_reload_regs_init,
      	reload_cse_simplify_operands), reorg.c (dbr_schedule), sbitmap.c
      	(sbitmap_zero), simplify-rtx.c (simplify_plus_minus), ssa.c
      	(rename_registers), stmt.c (expand_end_case), unroll.c
      	(unroll_loop), varray.c (varray_grow), objc/objc-act.c: Use memset
      	() instead of bzero ().
      
      ch:
      	* actions.c (check_missing_cases), typeck.c (build_chill_slice,
      	build_chill_cast): Use memset () instead of bzero ().
      
      cp:
      	* class.c (duplicate_tag_error, build_vtbl_initializer), decl.c
      	(push_binding_level), error.c (cp_tree_printer), pt.c
      	(process_partial_specialization, tsubst_template_arg_vector),
      	search.c (lookup_member): Use memset () instead of bzero ().
      
      java:
      	* expr.c (note_instructions), jcf-io.c (find_class), jcf-parse.c
      	(init_outgoing_cpool), lex.c (java_init_lex): Use memset ()
      	instead of bzero ().
      
      From-SVN: r37303
      Joseph Myers committed
  4. 20 Oct, 2000 1 commit
    • Warning fixes: · 8f54374e
      	* mips.h (REG_CLASS_FROM_LETTER): Cast array arg to unsigned char.
      
      	* sparc.c (load_pic_register): Delete unused varaible.
      
      	* libgcc2.c (__addvsi3): Delete unused variable.
      
      	* libgcc2.h (__absvsi2, __absvdi2, __addvsi3, __addvdi3,
      	__subvsi3, __subvdi3, __mulvsi3, __mulvdi3, __negvsi2,
      	__negvdi2): Prototype.
      
      	* ssa.c (apply_delayed_renames): Avoid undefined operation.
      
      	* toplev.c (display_target_options): Make static to match
      	prototype.  Delete empty declaration.
      
      From-SVN: r36987
      Kaveh R. Ghazi committed
  5. 04 Aug, 2000 1 commit
    • alias.c (mark_constant_function): Use INSN_P. · 2c3c49de
      	* alias.c (mark_constant_function): Use INSN_P.
      	(init_alias_analysis): Likewise.
      	* combine.c (combine_instructions): Use INSN_P.
      	(can_combine_p): Likewise.
      	(try_combine): Likewise.
      	(distribute_notes): Likewise.
      	(distribute_links): Likewise.
      	* cse.c (cse_around_loop): Use INSN_P.
      	(invalidate_skipped_block): Likewise.
      	(cse_set_around_loop): Likewise.
      	(cse_end_of_basic_block): Likewise.
      	(delete_trivially_dead_insns): Likewise.
      	* emit-rtl.c (unshare_all_rtl_again): Use INSN_P.
      	(unshare_all_rtl_1): Likewise.
      	(next_cc0_user): Likewise.
      	(try_split make_insn_raw): Likewise.
      	(remove_unnecessary_notes): Likewise.
      	* final.c (shorten_branches): Use INSN_P.
      	(leaf_renumber_regs): Likewise.
      	(leaf_renumber_regs_insn): Likewise.
      	* flow.c (find_label_refs): Use INSN_P.
      	(verify_wide_reg): Likewise.
      	(notice_stack_pointer_modification): Likewise.
      	(count_or_remove_death_notes): Likewise.
      	(verify_flow_info): Likewise.
      	(clear_log_links): Likewise.
      	* function.c (fixup_var_refs_insns): Use INSN_P.
      	(compute_insns_for_mem): Likewise.
      	* gcse.c (alloc_gcse_mem): Use INSN_P.
      	(compute_sets): Likewise.
      	(compute_hash_table): Likewise.
      	(classic_gcse): Likewise.
      	(cprop): Likewise.
      	(insert_insn_end_bb): Likewise.
      	(delete_null_pointer_checks_1): Likewise.
      	* global.c (expand_preferences): Use INSN_P.
      	(build_insn_chain): Likewise.
      	* graph.c (node_data): Use INSN_P.
      	* haifa-sched.c (priority): Use INSN_P.
      	(rm_line_notes): Likewise.
      	(rm_other_notes): Likewise.
      	(find_insn_reg_weight): Likewise.
      	(init_target_units): Likewise.
      	(schedule_block): Likewise.
      	(compute_block_forward_dependences): Likewise.
      	(debug_dependencies): Likewise.
      	(set_priorities): Likewise.
      	* integrate.c (function_cannot_inline_p): Use INSN_P.
      	(save_parm_insns): Likewise.
      	(copy_insn_list): Likewise.
      	* jump.c (mark_all_labels): Use INSN_P.
      	(never_reached_warning): Likewise.
      	* lcm.c (optimize_mode_switching): Use INSN_P.
      	* local-alloc.c (validate_equiv_mem): Use INSN_P.
      	(memref_used_between_p): Likewise.
      	(update_equiv_regs): Likewise.
      	(block_alloc): Likewise.
      	(no_conflict_p): Likewise.
      	* loop.c (scan_loop): Use INSN_P.
      	(find_and_verify_loops): Likewise.
      	(count_loop_regs_set): Likewise.
      	(loop_reg_used_before_p): Likewise.
      	(strength_reduce): Likewise.
      	(recombine_givs): Likewise.
      	(check_dbra_loop): Likewise.
      	(load_mems): Likewise.
      	(try_copy_prop): Likewise.
      	* print-rtl.c (print_rtx): Use INSN_P.
      	* recog.c (find_single_use): Use INSN_P.
      	* reg-stack.c (stack_regs_mentioned): Use INSN_P.
      	(next_flags_user): Likewise.
      	(swap_rtx_condition): Likewise.
      	* regmove.c (mark_flags_life_zones): Use INSN_P.
      	(optimize_reg_copy_1): Likewise.
      	(optimize_reg_copy_2): Likewise.
      	(optimize_reg_copy_3): Likewise.
      	(reg_is_remote_constant_p): Likewise.
      	(fixup_match_2): Likewise.
      	(regmove_optimize): Likewise.
      	(fixup_match_1): Likewise.
      	* regrename.c (build_def_use): Use INSN_P.
      	(replace_reg_in_block): Likewise.
      	(consider_use): Likewise.
      	* reload.c (find_equiv_reg): Use INSN_P.
      	* reload1.c (reload): Use INSN_P.
      	(maybe_fix_stack_asms): Likewise.
      	(calculate_needs_all_insns): Likewise.
      	(reload_as_needed): Likewise.
      	(emit_output_reload_insns): Likewise.
      	(delete_address_reloads_1): Likewise.
      	(reload_cse_regs_1): Likewise.
      	(reload_combine): Likewise.
      	(reload_cse_move2add): Likewise.
      	* reorg.c (redundant_insn): Use INSN_P.
      	(dbr_schedule): Likewise.
      	* resource.c (find_dead_or_set_registers): Use INSN_P.
      	(mark_target_live_regs): Likewise.
      	* rtlanal.c (reg_used_between_p): Use INSN_P.
      	(reg_referenced_between_p): Likewise.
      	(reg_set_between_p): Likewise.
      	(reg_set_p): Likewise.
      	(single_set): Likewise.
      	(multiple_sets): Likewise.
      	(find_last_value): Likewise.
      	(reg_set_last): Likewise.
      	(find_reg_note): Likewise.
      	(find_regno_note): Likewise.
      	* sibcall.c (sequence_uses_addressof): Use INSN_P.
      	* simplify-rtx.c (cselib_process_insn): Use INSN_P.
      	* ssa.c (find_evaluations): Use INSN_P.
      	(rename_block): Likewise.
      	(rename_equivalent_regs): Likewise.
      	* unroll.c (loop_find_equiv_value): Use INSN_P.
      	(set_dominates_use): Likewise.
      	* varasm.c (mark_constant_pool): Use INSN_P.
      	(mark_constants): Likewise.
      	* config/alpha/alpha.c (alpha_does_function_need_gp): Use INSN_P.
      	(alphaev4_next_group): Likewise.
      	(alphaev5_next_group): Likewise.
      	* config/c4x/c4x.c (c4x_process_after_reload): Use INSN_P.
      	(c4x_rptb_rpts_p): Likewise.
      	* config/mips/mips.c (mips16_optimize_gp): Use INSN_P.
      	* config/rs6000/rs6000.c (uses_TOC): Use INSN_P.
      	(rs6000_adjust_priority): Likewise.
      	* config/sh/sh.c (sh_loop_align): Use INSN_P.
      	(machine_dependent_reorg): Likewise.
      	(split_branches): Likewise.
      	* config/tahoe/tahoe.c (tahoe_cmp_check): Use INSN_P.
      
      From-SVN: r35494
      Rodney Brown committed
  6. 03 Aug, 2000 1 commit
  7. 02 Aug, 2000 1 commit
    • Makefile.in (OBJS): Added dce.o. · b53978a3
      	* Makefile.in (OBJS): Added dce.o.
      	(ssa.o): Updated target to include ssa.h.
      	(flow.o): Likewise.
      	(toplev.o): Likewise.
      	(dce.o): Created target.
      	* basic-block.h: Added comments.
      	(INVALID_BLOCK): Added definition.
      	(connect_infinite_loops_to_exit): Added declaration.
      	Moved SSA declarations to ssa.h.
      	* flow.c: Added inclusion of ssa.h.
      	(struct depth_first_search_dsS, depth_first_search_ds):
      	Added definitions.
      	(compute_immediate_postdominators): Added definition.
      	(connect_infinite_loops_to_exit): Likewise.
      	(flow_dfs_compute_reverse_init): Likewise.
      	(flow_dfs_compute_reverse_add_bb): Likewise.
      	(flow_dfs_compute_reverse_execute): Likewise.
      	(flow_dfs_compute_reverse_finish): Likewise.
      	* rtl.h (rtx/in_struct): Added use to determine insn necessity.
      	(LABEL_P): Added definition.
      	(JUMP_P): Likewise.
      	(NOTE_P): Likewise.
      	(BARRIER_P): Likewise.
      	(JUMP_TABLE_DATA_P): Likewise.
      	(INSN_DEAD_CODE_P): Likewise.
      	* ssa.c: Replaced inclusions with ssa.h inclusion.
      	(CONVERT_HARD_REGISTER_TO_SSA_P): Moved to ssa.h.
      	(rename_registers): Removed unnecessary variables.
      	* ssa.h: Created by moving declarations from ssa.c and
      	basic-block.h.
      	* timevar.def: Defined TV_DEAD_CODE_ELIM.
      	* toplev.c: Added ssa.h inclusion.
      	(dump_file_index): Added DFI_dce.
      	(dump_file): Added "dce" entry.
      	Defined flag_ssa.
      	(f_options): Added dce entry.
      	* invoke.texi: Document -fdce.  Emphasize experimental status of
      	-fssa.
      
      Co-Authored-By: Mark Mitchell <mark@codesourcery.com>
      
      From-SVN: r35419
      Jeffrey Oldham committed
  8. 31 Jul, 2000 1 commit
    • Makefile.in (ssa.o): Updated header files in dependences. · cdbca172
      	* Makefile.in (ssa.o): Updated header files in dependences.
      	* basic-block.h: Added compute_immediate_postdominators declaration.
      	* config/i386/i386.h (CONVERT_HARD_REGISTER_TO_SSA_P): Added
      	definition.
      	* flow.c (compute_immediate_dominators): Updated comment.
      	(compute_immediate_postdominators): Added definition.
      	* rtl.h (HARD_REGISTER_P): Added definition.
      	* ssa.c: Include additional header files.
      	(assert): Added definition.
      	(ssa_rename_to_lookup): Added to reimplement ssa_rename_to to
      	include select hard registers.
      	(ssa_rename_to_insert): Likewise.
      	(ssa_rename_from_initialize): Likewise.
      	(ssa_rename_from_lookup): Likewise.
      	(original_register): Likewise.
      	(ssa_rename_from_insert): Added to reimplement ssa_rename_from to
      	include select hard reigsters.
      	(ssa_rename_from_traverse): Likewise.
      	(ssa_rename_from_free): Likewise.
      	(ssa_rename_from_print): Likewise.
      	(ssa_rename_from_print_1): Likewise.
      	(ssa_rename_from_hash_function): Likewise.
      	(ssa_rename_from_equal): Likewise.
      	(ssa_rename_from_delete): Likewise.
      	(simplify_to_immediate_dominators): Removed in favor of
      	flow.c:compute_immediate_dominators.
      	(find_evaluations_1): Modified to work with hard registers.
      	(insert_phi_node): Likewise.
      	(insert_phi_nodes): Likewise.
      	(struct rename_set_data): Updated prev_reg comment.
      	(create_delayed_rename): Modified to work with hard registers.
      	(RENAME_NO_RTX): Updated comment.
      	(apply_delayed_renames): Modified to work with hard registers.
      	(rename_insn_1): Likewise and added handling of CLOBBER rtls.
      	(rename_block): Updated to use revised ssa_rename_to interface.
      	(rename_registers): Updated to use revised ssa_rename_to and
      	ssa_rename_from interface.
      	(convert_to_ssa): Revised to use compute_immediate_dominators and
      	deal with hard registers.
      	(make_regs_equivalent_over_bad_edges): Modified to work with hard
      	registers.  Added check for illegal unification of hard register.
      	(make_equivalent_phi_alternatives_equivalent): Modified to work
      	with hard registers.
      	(compute_conservative_reg_partition): Likewise.
      	(coalesce_if_unconflicting): Modified to work with hard registers
      	and check for conflicting hard registers.
      	(mark_phi_and_copy_regs): Revised loop to work only on pseudo
      	registers.
      	(rename_equivalent_regs_in_insn): Modified to work with hard
      	registers.
      	(record_canonical_element_1): Added definition.
      	(check_hard_regs_in_partition): Added definition.
      	(convert_from_ssa): Added data structure deallocation and check
      	for illegal hard register unification.
      	(conflict_hard_regs_p): Added definition.
      	* toplev.c (rest_of_compilation): Added comment.
      
      From-SVN: r35384
      Jeffrey D. Oldham committed
  9. 27 Jul, 2000 1 commit
    • Put phi nodes after NOTE_INSN_BASIC_BLOCK. · 589ca5cb
      	* rtl.h (NOTE_INSN_BASIC_BLOCK_P): New macro.
      	* bb-reorder.c (get_next_bb_note): Use NOTE_INSN_BASIC_BLOCK_P.
      	(get_prev_bb_note): Likewise.
      	(remove_scope_notes): Likewise.
      	* flow.c (commit_one_edge_insertion): Likewise.
      	(merge_blocks_nomove): Likewise.
      	(verify_flow_info): Likewise.
      	* gcse.c (insert_insn_end_bb): Likewise.
      	* reg-stack.c (emit_swap_insn): Likewise.
      	* ssa.c (first_insn_after_basic_block_note): New function.
      	(insert_phi_node): Use it.
      	(rename_block): Likewise.
      	(eliminate_phi): Likewise.
      	(make_regs_equivalent_over_bad_edges): Likewise.
      	(make_equivalent_phi_alternatives_equivalent): Likewise.
      	(for_each_successor_phi): Likewise.
      	(convert_from_ssa): Modify phi-node deletion algorithm.
      
      From-SVN: r35296
      Mark Mitchell committed
  10. 21 Jul, 2000 1 commit
  11. 27 Jun, 2000 1 commit
  12. 26 Jun, 2000 1 commit
    • ssa.c (struct rename_set_data): Change the name of field 'set_dest' to 'old_reg'. · 5397b155
      * ssa.c (struct rename_set_data): Change the name of field
      'set_dest' to 'old_reg'.  Add comments.
      (struct rename_context): Change the name of 'set_data' to
      'new_renames'.  Add new field 'done_renames'.
      (create_delayed_rename): New function.
      (apply_delayed_renames): New function.
      (rename_insn_1): Use the new functions.  Handle CLOBBERS.  Handle
      SUBREGs and similar by emitting a move.
      (new_registers_for_updates): Delete, functionality moved to
      apply_delayed_renames.
      (rename_block): Handle moves emitted by rename_insn_1 by putting
      them into a SEQUENCE with the original insn.  Add sanity checks
      and comments.
      (rename_equivalent_regs_in_insn): Don't handle SUBREGs specially.
      (rename_equivalent_regs): Expand SEQUENCEs out to individual insns.
      
      From-SVN: r34720
      Geoff Keating committed
  13. 19 May, 2000 1 commit
  14. 04 May, 2000 1 commit
    • bb-reorder.c (get_next_bb_note, [...]): Prototype. · 36244024
      	* bb-reorder.c (get_next_bb_note, get_prev_bb_note): Prototype.
      
      	* diagnostic (vbuild_message_string, build_message_string,
      	build_location_prefix, output_get_prefix, init_output_buffer,
      	output_notice, vline_wrapper_message_with_location,
      	v_message_with_decl, default_print_error_function): De-constify.
      	(set_real_maximum_length): Prototype.
      
      	* diagnostic.h (struct output_buffer, init_output_buffer,
      	output_get_prefix, output_set_prefix): De-constify.
      
      	* function.c (init_function_start): Constify.
      
      	* gensupport.c (remove_constraints, process_rtx): Prototype.
      
      	* gthr-posix.h: Indent uses of #pragma.
      
      	* objc/objc-act.c (ggc_mark_imp_list, ggc_mark_hash_table):
      	Prototype.
      
      	* predict.c (find_expected_value): Delete prototype.
      	(expected_value_to_br_prob): Initialize variable `ev_reg'.
      
      	* sbitmap.h (debug_sbitmap): Prototype.
      
      	* ssa.c (compute_coalesced_reg_partition): Prototype.
      
      	* stor-layout.c (debug_rli): Prototype.
      
      	* tree.h (round_down): Prototype.
      	(init_function_start): Constify.
      
      ch:
      	* ch-tree.h (init_function_start): Constify.
      
      From-SVN: r33675
      Kaveh R. Ghazi committed
  15. 27 Apr, 2000 3 commits
  16. 09 Apr, 2000 1 commit
    • ssa.c (convert_to_ssa): Eliminate dead code when calling life_analysis. · 6308dae9
      	* ssa.c (convert_to_ssa): Eliminate dead code when calling
      	life_analysis.
      	(convert_from_ssa): Call compute_bb_for_insn before life_analysis.
      	(for_each_successor_phi): Change parameter to basic_block.
      	(coalesce_regs_in_successor_phi_nodes): Likewise.
      	(coalesce_regs_in_copies): Likewise.
      	(compute_coalesced_reg_partition): Use basic_block instead of index.
      	* rtl.h (convert_to_ssa): Delete.
      	(convert_from_ssa): Likewise.
      	(successor_phi_fn): Likewise.
      	(for_each_successor_phi): Likewise.
      	(in_ssa_form): Likewise.
      	* basic-block.h (convert_to_ssa): Moved from rtl.h.
      	(convert_from_ssa): Likewise.
      	(successor_phi_fn): Likewise.
      	(in_ssa_form): Likewise.
      	(for_each_successor_phi): Likewise.  Change parameter to basic_block.
      	* flow.c (calculate_global_regs_live): Pass a basic_block to
      	for_each_successor_phi.
      
      From-SVN: r33032
      Alex Samuel committed
  17. 07 Apr, 2000 2 commits
  18. 06 Apr, 2000 1 commit
    • rtl.h (INSN_P): New macro. · 4e872036
      	* rtl.h (INSN_P): New macro.
      	(successor_phi_fn): New typedef.
      	(for_each_successor_phi): New prototype.
      	(in_ssa_form): New variable.
      	(PHI_NODE_P): Likewise.
      	* flow.c (calculate_global_regs_live): Add to new_live_at_end from
      	phi nodes in successors.
      	(mark_used_regs): Add PHI case.
      	(set_phi_alternative_reg): New function.
      	(life_analysis): Assert that dead code elimination is not selected
      	when in SSA form.
      	* toplev.c (to_ssa_time): New variable.
      	(from_ssa_time): Likewise.
      	(compile_file): Zero to_ssa_time and from_ssa_time.
      	Print time to convert to and from SSA.
      	(rest_of_compilation): Time convert_to_ssa and convert_from_ssa.
      	(print_time): Compute percent fraction as integer.
      	* ssa.c (PHI_NODE_P): Moved to rtl.h.
      	(convert_to_ssa): Check if we're already in SSA.
      	Don't eliminate dead code in life_analysis.
      	Rerun flow and life analysis at bottom.
      	(eliminate_phi): Use canonical regnos when adding nodes.
      	(mark_reg_in_phi): New function.
      	(mark_phi_and_copy_regs): Likewise.
      	(convert_from_ssa): Rerun life analysis at top.
      	Use coalesced partition.
      	Check for removing a phi node at the end of the block.
      	(compute_coalesced_reg_partition): New function.
      	(coalesce_regs_in_copies): Likewise.
      	(coalesce_reg_in_phi): Likewise.
      	(coalesce_regs_in_sucessor_phi_nodes): Likewise.
      	(for_each_successor_phi): Likewise.
      	(rename_context): New struct.
      	(rename_block): Use a rename_context with rename_insn_1.  When
      	renaming sets of a subreg, emit a copy of the entire reg first.
      	(rename_insn_1): Treat data as a rename_context *.  Save current
      	insn in set_data.
      	(rename_set_data): Add field set_insn.
      	* Makefile.in (HASHTAB_H): Move up in file.
      	(OBSTACK_H): New macro.
      	(collect2.o): Use OBSTACK_H in dependencies.
      	(sdbout.o): Likewise.
      	(emit-rtl.o): Likewise.
      	(simplify-rtx.o): Likewise.
      	(fix-header.o): Likewise.
      	(OBJS):	Add conflict.o.
      	(conflict.o): New rule.
      	* basic-block.h: Include partition.h.
      	(conflict_graph): New typedef.
      	(conflict_graph_enum_fn): Likewise.
      	(conflict_graph_new): New prototype.
      	(conflict_graph_delete): Likewise.
      	(conflict_graph_add): Likewise.
      	(conflict_graph_conflict_p): Likewise.
      	(conflict_graph_enum): Likewise.
      	(conflict_graph_merge_regs): Likewise.
      	(conflict_graph_print): Likewise.
      	(conflict_graph_compute): Likewise.
      	* conflict.c: New file.
      
      From-SVN: r32979
      Alex Samuel committed
  19. 04 Apr, 2000 1 commit
    • sparc.c (output_restore_regs): Prototype. · e77d72cb
      	* sparc.c (output_restore_regs): Prototype.
      	(sparc_emit_float_lib_cmp): Constification.
      
      	* emit-rtl.c (const_int_htab_hash, const_int_htab_eq): Likewise.
      
      	* reload1.c (reload_cse_delete_noop_set, reload_cse_simplify):
      	Prototype.
      
      	* simplify-rtx.c (entry_and_rtx_equal_p): Constification.
      	(get_value_hash, hash_rtx): Likewise.
      
      	* ssa.c (compute_conservative_reg_partition): Prototype.
      
      	* tree.c (mark_hash_entry): Prototype.
      
      From-SVN: r32896
      Kaveh R. Ghazi committed
  20. 25 Mar, 2000 1 commit
    • * Rework fields used to describe positions of bitfields and · 770ae6cc
      	modify sizes to be unsigned and use HOST_WIDE_INT.
      	* alias.c (reg_known_value_size): Now unsigned.
      	* c-typeck.c (build_unary_op, case ADDR_EXPR): Use byte_position.
      	(really_start_incremental_init): Use bitsize_zero_node.
      	(push_init_level, pop_init_level, output_init_element): Likewise.
      	Use bitsize_unit_node and bitsize_one_node.
      	(output_pending_init_elements, process_init_element): Likewise.
      	* combine.c (combine_max_regno, reg_sign_bit_copies): Now unsigned.
      	(make_extraction): Position and length HOST_WIDE_INT and unsigned
      	HOST_WIDE_INT, respectively.
      	(get_pos_from_mask): Passed in value is unsigned HOST_WIDE_INT.
      	(num_sign_bit_copies): Returns unsigned.
      	BITWIDTH now unsigned; rework arithmetic.
      	Remove recursive call from arg to MAX.
      	(combine_instructions, init_reg_last_arrays): NREGS now unsigned.
      	(setup_incoming_promotions, can_combine_p, try_combine, simplify_set):
      	REGNO now unsigned.
      	(set_nonzero_bit_and_sign_copies): NUM now unsigned.
      	(find_split_point, expand_compound_operation, make_extraction): LEN
      	now unsigned HOST_WIDE_INT, POS now HOST_WIDE_INT.
      	(make_field_assignment): Likewise.
      	(combine_simplify_rtx): Add cast.
      	(expand_compound_operation): MODEWIDTH now unsigned; rework arithmetic.
      	(force_to_mode): WIDTH now unsigned; add cast.
      	(if_then_else_cond): SIZE now unsigned.
      	(nonzero_bits): MODE_WIDTH, RESULT_WIDTH, and WIDTH now unsigned.
      	(extended_count): Now returns unsigned.
      	(simplify_shift_const): COUNT unsigned; arg is now INPUT_COUNT.
      	Add SIGNED_COUNT variable; MODE_WORDS and FIRST_COUNT now unsigned.
      	(simplify_comparison): MODE_WIDTH now unsigned.
      	(update_table_tick): REGNO and ENDREGNO now unsigned; new var R.
      	(mark_used_regs_combine): Likewise; rework arithmetic.
      	(record_value_for_reg): REGNO, ENDREGNO, and I now unsigned.
      	(record_dead_and_set_regs, reg_dead_at_p, distribute_notes): Likewise.
      	(record_promoted_value): REGNO now unsigned.
      	(get_last_value_validate): REGNO, ENDREGNO, and J now unsigned.
      	(get_last_value): REGNO now unsigned.
      	(use_crosses_set_p): REGNO and ENDREGNO now unsigned.
      	(reg_dead_regno, reg_dead_endregno): Now unsigned.
      	(remove_death): Arg REGNO now unsigned.
      	(move_deaths):  REGNO, DEADREGNO, DEADEND, OUREND, and I now unsigned.
      	(reg_bitfield_target_p): REGNO, REGNO, ENDREGNO, and ENDTREGNO
      	now unsigned.
      	* convert.c (convert_to_integer): INPREC and OUTPREC now unsigned.
      	* cse.c (struct qty_table_elem): FIRST_REG and LAST_REG now unsigned.
      	(struct cse_reg_info): REGNO now unsigned.
      	(cached_regno): Now unsigned.
      	(REGNO_QTY_VALID_P): Add cast.
      	(make_new_qty, make_regs_eqv, delete_reg_eqiv): Regno args unsigned.
      	(remove_invalid_regs): Likewise.
      	(remove_invalid_subreg_refs): Likewise; arg WORD also unsigned
      	as are variables END and I.
      	(get_cse_reg_info, insert): Likewise.
      	(mention_regs, invalidate_for_call): REGNO, ENDREGNO, and I unsigned.
      	(canon_hash): Likewise.
      	(insert_regs, lookup_for_remove): REGNO now unsigned.
      	(invalidate): REGNO, ENDREGNO, TREGNO, and TENDREGNO now unsigned.
      	New variable RN.
      	* dbxout.c (dbxout_parms, dbxout_reg_parms): Don't check for REGNO < 0.
      	* dwarf2out.c (dwarf2ou_frame_debug_expr): Remove cast.
      	* emit-rtl.c (subreg_realpart_p): Add cast.
      	(operand_subword): Arg I is now unsigned as is var PARTWORDS.
      	(operand_subword_force): Arg I is now unsigned.
      	* except.c (eh_regs): Variable I is now unsigned.
      	* explow.c (hard_function_value): BYTES is unsigned HOST_WIDE_INT.
      	* expmed.c (store_fixed_bit_field): Position is HOST_WIDE_INT;
      	length is unsigned HOST_WIDE_INT; likewise for internal variables.
      	(store_split_bit_field, extract_fixed_bit_field): Likewise.
      	(extract_split_bit_field, store_bit_field, extract_bit_field):
      	Likewise.
      	* expr.c (store_constructor_fields, store_constructor, store_field):
      	Positions are HOST_WIDE_INT and lengths are unsigned HOST_WIDE_INT.
      	(expand_assignment, expand_expr, expand_expr_unaligned): Likewise.
      	(do_jump): Likewise.
      	(move_by_pieces, move_by_pieces_ninsns, clear_by_pieces):
      	MAX_SIZE is now unsigned.
      	(emit_group_load): BYTEPOS is HOST_WIDE_INT; BYTELEN is unsigned.
      	(emit_group_store): Likewise.
      	(emit_move_insn): I now unsigned.
      	(store_constructor): Use host_integerp, tree_low_cst, and
      	bitsize_unit_node.
      	(get_inner_reference): Return bitpos and bitsize as HOST_WIDE_INT.
      	Rework all calculations to use trees and new fields.
      	* expr.h (promoted_input_arg): Regno now unsigned.
      	(store_bit_field, extract_bit_field): Adjust types of pos and size.
      	(mark_seen_cases): Arg is HOST_WIDE_INT.
      	* flow.c (verify_wide_reg_1): REGNO now unsigned.
      	* fold-const.c (decode_field_reference): Size and pos HOST_WIDE_INT;
      	precisions and alignments are unsigned.
      	(optimize_bit_field_compare, fold_truthop): Likewise.
      	(int_const_binop): Adjust threshold for size_int_type_wide call.
      	(fold_convert): Likewise.
      	(size_int_type_wide): Make table larger and fix thinko that only
      	had half of table used.
      	(all_ones_mask_p, fold): Precisions are unsigned.
      	* function.c (put_reg_info_stack): REGNO is unsigned.
      	(instantiate_decl): Size is HOST_WIDE_INT.
      	(instantiate_virtual_regs): I is unsigned.
      	(assign_parms): REGNO, REGNOI, and REGNOR are unsigned.
      	(promoted_input_arg): REGNO is unsigned.
      	* function.h (struct function): x_max_parm_reg is now unsigned.
      	* gcse.c (max_gcse_regno): Now unsigned.
      	(struct null_pointer_info): min_reg and max_reg now unsigned.
      	(lookup_set, next_set): REGNO arg now unsigned.
      	(compute_hash_table): REGNO and I now unsigned.
      	(handle_avail_expr): regnum_for_replacing now unsigned.
      	(cprop_insn): REGNO now unsigned.
      	(delete_null_pointer_checks_1): BLOCK_REG now pointer to unsigned.
      	* ggc-common.c (ggc_mark_tree_children, case FIELD_DECL): New case.
      	* global.c (set_preference): SRC_REGNO, DEST_REGNO, and I now unsigned.
      	* hard-reg-set.h (reg_class_size): Now unsigned.
      	* integrate.c (mark_stores): LAST_REG and I now unsigned; new UREGNO.
      	* jump.c (mark_modified_reg): I now unsigned; add cast.
      	(rtx_equal_for_thread_p): Add cast.
      	* loop.c (max_reg_before_loop): Now unsigned.
      	(struct_movable): REGNO now unsigned.
      	(try_copy_prop): REGNO arg unsigned.
      	(regs_match_p): XN and YN now unsigned.
      	(consec_sets_invariant_p, maybe_eliminate_biv): REGNO now unsigned.
      	(strength_reduce): Likewise; NREGS also unsigned.
      	(first_increment_giv, last_increment_giv unsigned): Now unsigned.
      	* loop.h (struct iv_class): REGNO now unsigned.
      	(max_reg_before_loop, first_increment_giv, last_increment_giv):
      	Now unsigned.
      	* machmode.h (mode_size, mode_unit_size): Now unsigned.
      	(mode_for_size, smallest_mode_for_size): Pass size as unsigned.
      	* optabs.c (expand_binop): I and NWORDS now unsigned.
      	(expand_unop): I now unsigned.
      	* print-tree.c (print_node): Don't print DECL_FIELD_BITPOS, but do
      	print DECL_FIELD_OFFSET and DECL_FIELD_BIT_OFFSET.
      	* real.c (significand_size): Now returns unsigned.
      	* real.h (significand_size): Likewise.
      	* regclass.c (reg_class_size): Now unsigned.
      	(choose_hard_reg_mode): Both operands now unsigned.
      	(record_reg_classes): REGNO and NR now unsigned.
      	(reg_scan): NREGS now unsigned.
      	(reg_scan_update): old_max_regno now unsigned.
      	(reg_scan_mark_refs): Arg MIN_REGNO and var REGNO now unsigned.
      	* reload.c (find_valid_class): BEST_SIZE now unsigned.
      	(find_dummy_reload): REGNO, NWORDS, and	I now unsigned.
      	(hard_reg_set_here_p): Args BEG_REGNO and END_REGNO now unsigned.
      	Likewise for variable R.
      	(refers_to_regno_for_reload_p): Args REGNO and END_REGNO now unsigned,
      	as are variables INNER_REGNO and INNER_ENDREGNO; add new variable R.
      	(find_equiv_reg): Add casts.
      	(regno_clobbered_p): Arg REGNO now unsigned.
      	* reload.h (struct reload): NREGS now unsigned.
      	(refers_to_regno_for_reload_p): Regno args are unsigned.
      	(regno_clobbered_p): Likewise.
      	* reload1.c (reg_max_ref_width, spill_stack_slot_width): Now unsigned.
      	(compute_use_by_pseudos): REGNO now unsigned.
      	(find_reg): I and J now unsigned, new variable K, and change loop
      	variables accordingly; THIS_NREGS now unsigned.
      	(alter_reg): INHERENT_SIZE and TOTAL_SIZE now unsigned.
      	(spill_hard_reg): REGNO arg now unsigned; add casts.
      	(forget_old_reloads_1): REGNO, NR, and I now unsigned.
      	(mark_reload_reg_in_use): Arg REGNO and vars NREGS and I now unsigned.
      	(clear_reload_reg_in_use): Arg REGNO and vars NREGS, START_REGNO,
      	END_REGNO, CONFLICT_START, and CONFLICT_END now unsigned.
      	(reload_reg_free_p, reload_reg_reaches_end_p): Arg REGNO now unsigned.
      	(choose_reload_regs): MAX_GROUP_SIZE now unsigned.
      	(emit_reload_insns): REGNO now unsigned.
      	(reload_cse_move2add): Add cast.
      	(move2add_note_store): REGNO and I now unsigned; new variable ENDREGNO
      	and rework loop.
      	* resource.c (mark_referenced_resources, mark_set_resources): New
      	variable R; REGNO and LAST_REGNO now unsigned.
      	(mark_target_live_regs): J and REGNO now unsigned.
      	* rtl.c (mode_size, mode_unit_size): Now unsigned.
      	* rtl.h (union rtunion_def): New field rtuint.
      	(XCUINT): New macro.
      	(ADDRESSOF_REGNO, REGNO, SUBREG_WORD): New XCUINT.
      	(operand_subword, operand_subword_force): Word number is unsigned.
      	(choose_hard_reg_mode): Operands are unsigned.
      	(refers_to-regno_p, dead_or_set_regno_p): Regno arg is unsigned.
      	(find_regno_note, find_regno_fusage, replace_regs): Likewise.
      	(regno_use_in, combine_instructions, remove_death): Likewise.
      	(reg_scan, reg_scan_update): Likewise.
      	(extended_count): Return is unsigned.
      	* rtlanal.c (refers_to_regno_p): Args REGNO and ENDREGNO and vars I,
      	INNER_REGNO, and INNER_ENDREGNO now unsigned; new variable X_REGNO.
      	(reg_overlap_mentioned_p): REGNO and ENDREGNO now unsigned.
      	(reg_set_last_first_regno, reg_set_last_last_regno): Now unsigned.
      	(reg_reg_last_1): FIRS and LAST now unsigned.
      	(dead_or_set_p): REGNO, LAST_REGNO, and I now unsigned.
      	(dead_or_set_regno_p): Arg TEST_REGNO and vars REGNO and ENDREGNO
      	now unsigned.
      	(find_regno_note, regno_use_in): Arg REGNO now unsigned.
      	(find_regno_fusage): Likewise; also var REGNOTE now unsigned.
      	(find_reg_fusage): Variables REGNO, END_REGNO, and I now unsigned.
      	(replace_regs): Arg NREGS now unsigned.
      	* sdbout.c (sdbout_parms, sdbout_reg_parms): Don't check REGNO < 0.
      	* simplify-rtx.c (simplify_unary_operation): WIDTH now unsigned.
      	(simplify_binary_operation): Likewise.
      	(cselib_invalidate_regno): Arg REGNO and variables ENDREGNO, I, and
      	THIS_LAST now unsigned.
      	(cselib_record_set): Add cast.
      	* ssa.c (ssa_max_reg_num): Now unsigned.
      	(rename_block): REGNO now unsigned.
      	* stmt.c (expand_return): Bit positions unsigned HOST_WIDE_INT;
      	sizes now unsigned.
      	(all_cases_count): Just return -1 not -2.
      	COUNT, MINVAL, and LASTVAL now HOST_WIDE_INT.
      	Rework tests to use trees whenever possible.
      	Use host_integerp and tree_low_cst.
      	(mark_seen_cases): COUNT arg now HOST_WIDE_INT;
      	Likewise variable NEXT_NODE_OFFSET; XLO now unsigned.
      	(check_for_full_enumeration_handing): BYTES_NEEDED, I to HOST_WIDE_INT.
      	* stor-layout.c (mode_for_size): SIZE arg now unsigned.
      	(smallest_mode_for_size): Likewise.
      	(layout_decl): Simplify handing of a specified DECL_SIZE_UNIT.
      	KNOWN_ALIGN is now an alignment, so simplify code.
      	Don't turn off DECL_BIT_FIELD if field is BLKmode, but not type.
      	(start_record_layout): Renamed from new_record_layout_info.
      	Update to new fields.
      	(debug_rli, normalize_rli, rli_size_unit_so_far, rli_size_so_far):
      	New functions.
      	(place_union_field): Renamed from layout_union_field.
      	Update to use new fields in rli.
      	(place_field): Renamed from layout_field.
      	Major rewrite to use new fields in rli; pass alignment to layout_decl.
      	(finalize_record_size): Rework to use new fields in rli and handle
      	union.
      	(compute_record_mode): Rework to simplify and to use new DECL fields.
      	(finalize_type_size): Make rounding more consistent.
      	(finish_union_layout): Deleted.
      	(layout_type, case VOID_TYPE): Don't set TYPE_SIZE_UNIT either.
      	(layout_type, case RECORD_TYPE): Call new function names.
      	(initialize_sizetypes): Set TYPE_IS_SIZETYPE.
      	(set_sizetype): Set TYPE_IS_SIZETYPE earlier.
      	(get_best_mode): UNIT is now unsigned; remove casts.
      	* tree.c (bit_position): Compute from new fields.
      	(byte_position, int_byte_position): New functions.
      	(print_type_hash_statistics): Cast to remove warning.
      	(build_range_type): Use host_integerp and tree_low_cst to try to hash.
      	(build_index_type): Likewise; make subtype of sizetype.
      	(build_index_2_type): Pass sizetype to build_range_type.
      	(build_common_tree_nodes): Use size_int and bitsize_int to
      	initialize nodes; add bitsize_{zero,one,unit}_node.
      	* tree.h (DECL_FIELD_CONTEXT): Use FIELD_DECL_CHECK.
      	(DECL_BIT_FIELD_TYPE, DECL_QUALIFIER, DECL_FCONTEXT): Likewise.
      	(DECL_PACKED, DECL_BIT_FIELD): Likewise.
      	(DECL_FIELD_BITPOS): Deleted.
      	(DECL_FIELD_OFFSET, DECL_FIELD_BIT_OFFSET): New fields.
      	(DECL_RESULT, DECL_SAVED_INSNS): Use FUNCTION_DECL_CHECK.
      	(DECL_FRAME_SIZE, DECL_FUNCTION_CODE, DECL_NO_STATIC_CHAIN): Likewise.
      	(DECL_INLINE, DECL_BUILT_IN_NONANSI, DECL_IS_MALLOC): Likewise.
      	(DECL_BUILT_IN_CLASS, DECL_STATIC_CONSTRUCTOR): Likewise.
      	(DECL_STATIC_DESTRUCTOR, DECL_NO_CHECK_MEMORY_USAGE): Likewise.
      	(DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT, DECL_NO_LIMIT_STACK) Likewise.
      	(DECL_ORIGINAL_TYPE, TYPE_DECL_SUPPRESS_DEBUG): Use TYPE_DECL_CHECK.
      	(DECL_ARG_TYPE_AS_WRITEN, DECL_ARG_TYPE): Use PARM_DECL_CHECK.
      	(DECL_INCOMING_RTL, DECL_TRANSPARENT_UNION): Likewise.
      	(DECL_ALIGN): Adjust to new field in union.
      	(DECL_OFFSET_ALIGN): New field.
      	(DECL_ERROR_ISSUED, DECL_TOO_LATE): Use LABEL_DECL_CHECK.
      	(DECL_IN_TEXT_SECTION): Use VAR_DECL_CHECK.
      	(union tree_decl): Add struct for both aligns.
      	(enum tree_index): Add TI_BITSIZE_{ZERO,ONE,UNIT}.
      	(bitsize_zero_node, bitsize_one_node, bitsize_unit_node): Added.
      	(struct record_layout_info): Rework fields to have offset
      	alignment and byte and bit position.
      	(start_record_layout, place_field): Renamed from old names.
      	(rli_size_so_far, rli_size_unit_so_far, normalize_rli): New decls.
      	(byte_position, int_byte_position): Likewise.
      	(get_inner_reference): Change types of position and length.
      	* unroll.c (unroll_loop): New variable R; use for some loops.
      	MAX_LOCAL_REGNUM and MAXREGNUM now unsigned.
      	(calculate_giv_inc): Arg REGNO now unsigned.
      	(copy_loop_body): REGNO and SRC_REGNO now unsigned.
      	* varasm.c (assemble_variable): Clean up handling of size using
      	host_integerp and tree_low_cst.
      	(decode_addr_const): Use byte, not bit, position.
      	(output_constructor): bitpos and offsets are HOST_WIDE_INT;
      	use tree_low_cst and int_bit_position.
      	* objc/objc-act.c (build_ivar_list_initializer): Use byte_position.
      	* ch/actions.c (check_missing_cases): BYTES_NEEDED is HOST_WIDE_INT.
      	* ch/typeck.c (expand_constant_to_buffer): Use int_byte_position.
      	(extract_constant_from_buffer): Likewise.
      	* cp/class.c (build_vbase_pointer_fields): layout_field now
      	place_field.
      	(get_vfield_offset): Use byte_position.
      	(set_rtti_entry): Set OFFSET to ssizetype zero.
      	(get_binfo_offset_as_int): Deleted.
      	(dfs_record_base_offsets): Use tree_low_cst.
      	(dfs_search_base_offsets): Likewise.
      	(layout_nonempty_base_or_field): Reflect changes in RLI format
      	and call byte_position.
      	(layout_empty_base): Convert offset to ssizetype.
      	(build_base_field): use rli_size_unit_so_far.
      	(dfs_propagate_binfo_offsets): Do computation in proper type.
      	(layout_virtual_bases): Pass ssizetype to propagate_binfo_offsets.
      	(layout_class_type): Reflect changes in RLI names and fields.
      	(finish_struct_1): Set DECL_FIELD_OFFSET.
      	* cp/dump.c (dequeue_and_dump): Call bit_position.
      	* cp/expr.c (cplus_expand_constant): Use byte_position.
      	* cp/rtti.c (expand_class_desc): Use bitsize_one_node.
      	* cp/typeck.c (build_component_addr): Use byte_position and don't
      	special case for zero offset.
      	* f/com.c (ffecom_tree_canonize_ptr_): Use bitsize_zero_node.
      	(ffecom_tree_canonize_ref_): Likewise.
      	* java/class.c (make_field_value): Use byte_position.
      	* java/expr.c (JAVA_ARRAY_LENGTH_OFFSET): Use byte_position.
      	(java_array_data_offset): Likewise.
      	* java/java-tree.h (MAYBE_CREATE_TYPE_TYPE_LANG_SPECIFIC): Add case to
      	bzero call.
      
      From-SVN: r32742
      Richard Kenner committed
  21. 17 Mar, 2000 1 commit
    • * Clean up usages of TREE_INT_CST_LOW. · 665f2503
      	* c-parse.in (RESTORE_WARN_FLAGS): Use tree_low_cst.
      	* c-parse.y, c-parse.c, objc/objc-parse.y, objc/objc-parse.c:
      	Regenerated.
      	* c-tree.h (min_precision): Move declaration to here.
      	* c-typeck.c (build_binary_op): Use host_integerp and tree_low_cst.
      	(build_unary_op, add_pending_init): Use bit_position.
      	(pending_init_member, process_init_element): Likewise.
      	(really_start_incremental_init, push_init_level, pop_init_level):
      	Don't make copies of nodes or modify them in place, use consistent
      	types when tracking positions, and use tree routines computations.
      	(set_init_index, output_init_element): Likewise.
      	(output_pending_init_elements, process_init_element): Likewise.
      	* dbxout.c (dbxout_type_fields): Use bit_position, host_integerp,
      	tree_low_cst and int_bit_position; also minor cleanup.
      	(dbxout_type_method_1, dbxout_range_type, dbxout_type): Likewise.
      	(print_cst_octal): Precision is unsigned.
      	(dbxout_symbol): Ensure DECL_INITIAL is in-range and use tree_low_cst.
      	* dwarf2out.c (ceiling): Input and output are unsigned HOST_WIDE_INT.
      	(simple_type_align_in_bits): Result is unsigned int.
      	Use tree_int_low_cst and host_integerp.
      	(simple_type_size_in_bits): Result is unsigned HOST_WIDE_INT.
      	(field_byte_offset): Result is HOST_WIDE_INT.
      	Change types of internal variables so alignments are unsigned int,
      	offsets are HOST_WIDE_INT and sizes are unsigned HOST_WIDE_INT.
      	Use host_integerp, tree_low_cst, and int_bit_position.
      	(add_bit_offset_attribute): Likewise.
      	(add_data_member_location_attribute): Use tree_cst_low.
      	(add_bound_info): Use host_integerp, integer_zerop, and integer_onep.
      	(add_bit_size_attribute): Use tree_low_cst.
      	(add_pure_or_virtual_attribute, gen_enumeration_type_die): Likewise.
      	* dwarfout.c: Similar changes to dwarf2out.c.
      	* expr.c (expand_expr, case ARRAY_REF): Remove redundant code.
      	* genoutput.c (n_occurences): Return -1 for null string.
      	(strip_whitespace): Accept null string and make into function.
      	(scan_operands): Reflect above changes.
      	* sdbout.c (plain_type_1): Use host_integerp and tree_low_cst.
      	(sdbout_field_types, sdbout_one_type): Likewise; also use bit_position.
      	* ssa.c (rename_registers): Add missing cast of arg to bzero.
      	* tree.c (int_size_in_bytes): Check for too big to represent.
      	(bit_position, int_bit_position, host_integerp, tree_low_cst): New fns.
      	* tree.h (host_integerp, tree_low_cst, bit_position, int_bit_position):
      	New declarations.
      	(min_precision): Delete from here.
      	* varasm.c (decode_addr_const): Use host_integerp, bit_position,
      	and int_bit_position.
      	* objc/objc-act.c (encode_method_prototype): Sizes are HOST_WIDE_INT.
      	(encode_method_def): Likewise.
      	(build_ivar_list_initializer): Use int_bit_position.
      	(generate_shared_structures): Convert size.
      	(encode_type, encode_complete_bitfield): Use integer_zerop.
      	(encode_bitfield): Use tree_low_cst and int_bit_position.
      	* ch/typeck.c (min_precision): New function.
      	(build_chill_slice): Use host_integerp and tree_low_cst.
      	(expand_constant_to_buffer): Likewise and also int_bit_position.
      	LO is unsigned HOST_WIDE_INT
      	(build_chill_array_ref_1): Make `i' be HOST_WIDE_INT; use tree_low_cst.
      	(extract_constant_from_buffer): Sizes are now HOST_WIDE_INT.
      	Use host_integerp and tree_low_cst.
      	(build_chill_bin_type): Use host_integerp and tree_low_cst.
      	(layout_chill_range_type): Use tree_int_cst_sgn, compare_tree_int,
      	tree_low_cst, and min_precision.
      	(apply_chill_array_layout): Cleanups for types of variables
      	and use tree_int_cst_sgn, compare_tree_int, and tree_low_cst.
      	(apply_chill_field_layout): Likewise.
      	* cp/class.c (build_vbase_path): Use integer_zerop.
      	(build_vtable_entry): Use tree_low_cst.
      	(get_vfield_offset): Use bit_position.
      	(dfs_modify_vtables): New variable vindex_val; `i' is HOST_WIDE_INT.
      	Use tree_low_cst.
      	(check_bitfield_decl): Set DECL_SIZE using convert.
      	(build_base_field): Set DECL_SIZE and DECL_SIZE_UNIT using size_binop.
      	(layout_virtual_bases): DSIZE is unsigned HOST_WIDE_INT.
      	Use tree_low_cst.
      	(finish_struct_1): Use bit_position.
      	(dump_class_hierarchy): Use tree_low_cst.
      	* cp/cp-tree.h (min_precision): Add declaration.
      	* cp/decl.c (xref_tag, xref_basetypes): Use tree_low_cst.
      	* cp/error.c (dump_type_suffix): Use host_integerp and tree_low_cst.
      	(dump_expr): Use integer_zerop, host_integerp, and tree_low_cst.
      	* cp/expr.c (cplus_expand_constant): Use bit_position.
      	* cp/init.c (build_vec_init): Use host_integerp and tree_low_cst.
      	* cp/rtti.c (get_base_offset): Use bit_position.
      	* cp/typeck.c (build_binary_op): Use integer_zerop, compare_tree_int,
      	host_integerp, and tree_low_cst.
      	(pointer_int_sum): Use integer_zerop.
      	(build_component_addr): Use bit_position.
      	* java/class.c (make_field_value): Properly handle sizes.
      	(get_dispatch_vector): Use tree_low_cst and host_integerp.
      	(layout_class_method): Count using trees.
      	* java/decl.c (push_promoted_type): Set TYPE_{MIN,MAX}_VALUE with
      	copy_node.
      	* java/expr.c (java_array_data_offset): Use int_bit_position.
      	(build_newarray, build_anewarray): Use host_integerp and tree_low_cst.
      	(build_invokevirtual): Use tree_low_cst and do computations with trees.
      
      From-SVN: r32607
      Richard Kenner committed
  22. 10 Mar, 2000 1 commit
    • Changes in include: · d9d4fb43
      	* partition.h: New file.
      
      Changes in libiberty:
      
      	* Makefile.in (CFILES): Add partition.c.
      	(REQUIRED_OFILES): Add partition.o.
      	(partition.o): New rule.
      	* partition.c: New file.
      
      Changes in gcc:
      
      	* Makefile.in (ssa.o): New rule.
      	(OBJS): Add ssa.o.
      	(STAGESTUFF): Add *.ssa and *.ussa.
      	(mostlyclean): Delete *.ssa, *.ussa, */*.ssa, */*.ussa.
      	* rtl.def (PHI): New RTL expression.
      	* rtl.h (clear_log_links): New declaration.
      	(convert_to_ssa): Likewise.
      	(convert_from_ssa): Likewise.
      	* flow.c (split_edge): If the entry node falls through to the
      	split edge's source block, split the entry edge.
      	(clear_log_links): New function.
      	* toplev.c (ssa_dump): New variable.
      	(flag_ssa): Likewise.
      	(f_options): Add "ssa".
      	(compile_file): Create SSA dump files.
      	(rest_of_compilation): Go to and from SSA if enabled.
      	(decide_d_option): Handle -de for SSA dump files.
      	* ssa.c: New file.
      
      From-SVN: r32465
      Alex Samuel committed