1. 30 Nov, 2008 1 commit
    • ebotcazou's avatar
      PR target/38287 · 0e517585
      ebotcazou authored
      	* config/sparc/sparc.md (divsi3 expander): Remove constraints.
      	(divsi3_sp32): Add new alternative with 'K' for operand #2.
      	(cmp_sdiv_cc_set): Factor common string.
      	(udivsi3_sp32): Add new alternative with 'K' for operand #2.
      	Add TARGET_V9 case.
      	(cmp_udiv_cc_set): Factor common string.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@142295 138bc75d-0d04-0410-961f-82ee72b054a4
      0e517585
  2. 06 Nov, 2008 1 commit
    • kazu's avatar
      PR target/35574 · 83c0aede
      kazu authored
      	* config/sparc/constraints.md (D): New.
      	* config/sparc/predicates.md (const_double_or_vector_operand):
      	New.
      	* config/sparc/sparc.c (sparc_extra_constraint_check): Handle the
      	'D' constraint.
      	* config/sparc/sparc.md (*movdf_insn_sp32_v9, *movdf_insn_sp64):
      	Use the 'D' constraint in addition to 'F' in some alternatives.
      	(DF splitter): Generalize for V64mode.
      	* doc/md.texi (SPARC): Document the 'D' constraint.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@141644 138bc75d-0d04-0410-961f-82ee72b054a4
      83c0aede
  3. 23 Sep, 2008 1 commit
    • ebotcazou's avatar
      * config/sparc/constraints.md: New file. · 187a5b29
      ebotcazou authored
      	* config/sparc/sparc.md: Include it.
      	* config/sparc/sparc-protos.h (memory_ok_for_ldd): Declare.
      	(sparc_extra_constraint_check): Delete.
      	* config/sparc/sparc.c (register_ok_for_ldd): Minor tweaks.
      	(memory_ok_for_ldd): New predicate.
      	(sparc_extra_constraint_check): Delete.
      	* config/sparc/sparc.h (REG_CLASS_FROM_LETTER): Likewise.
      	(CONST_OK_FOR_LETTER_P): Likewise.
      	(CONST_DOUBLE_OK_FOR_LETTER_P): Likewise.
      	(EXTRA_CONSTRAINT): Likewise.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@140619 138bc75d-0d04-0410-961f-82ee72b054a4
      187a5b29
  4. 21 Sep, 2008 1 commit
    • ebotcazou's avatar
      * config/sparc/sparc-protos.h (gen_compare_operator): Declare. · fa17c3f9
      ebotcazou authored
      	(sparc_emit_float_lib_cmp): Change return type.
      	* config/sparc/sparc.c (gen_compare_reg): Add comment about TFmode.
      	(gen_compare_operator): New function.
      	(sparc_emit_float_lib_cmp): Return the new operator to be used in
      	the comparison sequence.  Minor tweaks.
      	* config/sparc/sparc.md (seq, sne, sgt, slt, sge, sle): Assert
      	that the final operator and the result of sparc_emit_float_lib_cmp
      	match for software TFmode; use emit_insn in lieu of emit_jump_insn.
      	(beq, bne, bgt, blt, bge, ble, bunordered, bordered, bungt, bunlt,
      	buneq, bunge, bunle, bltgt): Assert that the final operator and the
      	result of sparc_emit_float_lib_cmp match for software TFmode.
      	(movqicc, movhicc, movsicc, movdicc): Merge into...
      	(mov<I:mode>cc): ...this.
      	(movsfcc, movdfcc, movtfcc): Merge into...
      	(mov<F:mode>cc): ...this.
      	(movqi_cc_sp64, movhi_cc_sp64, movsi_cc_sp64, movdi_cc_sp64): Merge
      	into...
      	(mov<I:mode>_cc_v9): ...this.
      	(movdi_cc_sp64_trunc): Delete.
      	(movqi_cc_reg_sp64, movhi_cc_reg_sp64, movsi_cc_reg_sp64,
      	movdi_cc_reg_sp64): Merge into...
      	(mov<I:mode>_cc_reg_sp64): ...this.
      	(movsf_cc_sp64): Rename into...
      	(movsf_cc_v9): ...this.
      	(movdf_cc_sp64): Rename into...
      	(movdf_cc_v9): ...this.
      	(movtf_cc_hq_sp64): Rename into...
      	(movtf_cc_hq_v9): ...this.
      	(movtf_cc_sp64): Rename into...
      	(movtf_cc_v9): ...this.  Adjust for renaming of movdf_cc_sp64.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@140530 138bc75d-0d04-0410-961f-82ee72b054a4
      fa17c3f9
  5. 01 Jun, 2008 1 commit
    • rsandifo's avatar
      gcc/ · 18b42941
      rsandifo authored
      	* rtl.h (emit_clobber, gen_clobber, emit_use, gen_use): Declare.
      	* emit-rtl.c (emit_clobber, gen_clobber, emit_use, gen_use): New
      	functions.  Do not emit uses and clobbers of CONCATs; individually
      	use and clobber their operands.
      	* builtins.c (expand_builtin_setjmp_receiver): Use emit_clobber,
      	gen_clobber, emit_use and gen_use.
      	(expand_builtin_longjmp, expand_builtin_nonlocal_goto): Likewise.
      	(expand_builtin_return): Likewise.
      	* cfgbuild.c (count_basic_blocks): Likewise.
      	* cfgrtl.c (rtl_flow_call_edges_add): Likewise.
      	* explow.c (emit_stack_restore): Likewise.
      	* expmed.c (extract_bit_field_1): Likewise.
      	* expr.c (convert_move, emit_move_complex_parts): Likewise.
      	(emit_move_multi_word, store_constructor): Likewise.
      	* function.c (do_clobber_return_reg, do_use_return_reg): Likewise.
      	(thread_prologue_and_epilogue_insns): Likewise.
      	* lower-subreg.c (resolve_simple_move): Likewise.
      	* optabs.c (widen_operand, expand_binop): Likewise.
      	(expand_doubleword_bswap, emit_no_conflict_block): Likewise.
      	* reload.c (find_reloads): Likewise.
      	* reload1.c (eliminate_regs_in_insn): Likewise.
      	* stmt.c (expand_nl_goto_receiver): Likewise.
      	* config/alpha/alpha.md (builtin_longjmp): Likewise.
      	* config/arc/arc.md (*movdi_insn, *movdf_insn): Likewise.
      	* config/arm/arm.c (arm_load_pic_register): Likewise.
      	(thumb1_expand_epilogue, thumb_set_return_address): Likewise.
      	* config/arm/arm.md (untyped_return): Likewise.
      	* config/arm/linux-elf.h (PROFILE_HOOK): Likewise.
      	* config/avr/avr.c (expand_prologue): Likewise.
      	* config/bfin/bfin.c (do_unlink): Likewise.
      	* config/bfin/bfin.md (<optab>di3, adddi3, subdi3): Likewise.
      	* config/cris/cris.c (cris_expand_prologue): Likewise.
      	* config/darwin.c (machopic_indirect_data_reference): Likewise.
      	(machopic_legitimize_pic_address): Likewise.
      	* config/frv/frv.c (frv_frame_access, frv_expand_epilogue): Likewise.
      	(frv_ifcvt_modify_insn, frv_expand_mdpackh_builtin): Likewise.
      	* config/i386/i386.c (ix86_expand_vector_move_misalign): Likewise.
      	(ix86_expand_convert_uns_didf_sse): Likewise.
      	(ix86_expand_vector_init_general): Likewise.
      	* config/ia64/ia64.md (eh_epilogue): Likewise.
      	* config/iq2000/iq2000.c (iq2000_expand_epilogue): Likewise.
      	* config/m32c/m32c.c (m32c_emit_eh_epilogue): Likewise.
      	* config/m32r/m32r.c (m32r_reload_lr): Likewise.
      	(config/iq2000/iq2000.c): Likewise.
      	* config/mips/mips.md (fixuns_truncdfsi2): Likewise.
      	(fixuns_truncdfdi2, fixuns_truncsfsi2, fixuns_truncsfdi2): Likewise.
      	(builtin_longjmp): Likewise.
      	* config/mn10300/mn10300.md (call, call_value): Likewise.
      	* config/pa/pa.md (nonlocal_goto, nonlocal_longjmp): Likewise.
      	* config/pdp11/pdp11.md (abshi2): Likewise.
      	* config/rs6000/rs6000.c (rs6000_emit_move): Likewise.
      	* config/s390/s390.c (s390_emit_prologue): Likewise.
      	* config/s390/s390.md (movmem_long, setmem_long): Likewise.
      	(cmpmem_long, extendsidi2, zero_extendsidi2, udivmoddi4): Likewise.
      	(builtin_setjmp_receiver, restore_stack_nonlocal): Likewise.
      	* config/sh/sh.c (prepare_move_operands): Likewise.
      	(output_stack_adjust, sh_expand_epilogue): Likewise.
      	(sh_set_return_address, sh_expand_t_scc): Likewise.
      	* config/sparc/sparc.c (load_pic_register): Likewise.
      	* config/sparc/sparc.md (untyped_return, nonlocal_goto): Likewise.
      	* config/spu/spu.c (spu_expand_epilogue): Likewise.
      	* config/v850/v850.c (expand_epilogue): Likewise.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@136251 138bc75d-0d04-0410-961f-82ee72b054a4
      18b42941
  6. 25 Apr, 2008 1 commit
    • hubicka's avatar
      · 18d50ae6
      hubicka authored
      	PR testsuite/35843
      	* cfgexpand.c (pass_expand): Turn into RTL pass.
      	* passes.c (execute_one_pass): Do pass typechecking after execution.
      	* tree-pass.h (pass_expand): Turn into RTL pass.
      
      	* function.h (struct rtl_data): Move here fields
      	accesses_prior_frames, calls_eh_return, saves_all_registers,
      	has_nonlocal_goto, has_asm_statement, is_thunk,
      	all_throwers_are_sibcalls, limit_stack, profile, uses_const_pool,
      	uses_pic_offset_table, uses_eh_lsda, tail_call_emit,
      	arg_pointer_save_area_init from struct function; turn into bool.
      	(struct function): Move
      	calls_eh_return, saves_all_registers, has_nonlocal_goto,
      	has_asm_statement, is_thunk, all_throwers_are_sibcalls, limit_stack,
      	profile, uses_const_pool, uses_pic_offset_table, uses_eh_lsda,
      	tail_call_emit, arg_pointer_save_area_init
      	into struct rtl_data.  Remove recursive_call_emit and gimplified flags.
      	(current_function_returns_struct, current_function_returns_pcc_struct,
      	current_function_calls_setjmp, current_function_calls_alloca,
      	current_function_accesses_prior_frames,
      	current_function_calls_eh_return, current_function_is_thunk,
      	current_function_stdarg, current_function_profile,
      	current_function_limit_stack, current_function_uses_pic_offset_table,
      	current_function_uses_const_pool, current_function_has_nonlocal_label,
      	current_function_saves_all_registers,
      	current_function_has_nonlocal_goto,
      	current_function_has_asm_statement): Remove accesor macros.
      	* ra-conflict.c (global_conflicts): Update.
      	* tree-tailcall.c (suitable_for_tail_opt_p): Update.
      	(suitable_for_tail_call_opt_p): Update.
      	* builtins.c (expand_builtin_return_addr): Update.
      	(expand_builtin_setjmp_setup): Update.
      	(expand_builtin_nonlocal_goto): Update.
      	* final.c (final_start_function): Update.
      	(profile_function): Update.
      	(leaf_function_p): Update.
      	(only_leaf_regs_used): Update.
      	* df-scan.c (df_get_exit_block_use_set): Update.
      	* dojump.c (clear_pending_stack_adjust): Update.
      	* tree-stdarg.c (gate_optimize_stdarg): Update.
      	* gimple-low.c (lower_function_body): Update.
      	* global.c (compute_regsets): Update.
      	(global_alloc): Update.
      	* dwarf2out.c (dwarf2out_begin_prologue): Update.
      	* expr.c (expand_assignment): Update.
      	* dse.c (dse_step0): Update.
      	(dse_step1): Update.
      	* c-decl.c (store_parm_decls): Update.
      	* local-alloc.c (combine_regs): Update.
      	(find_free_reg): Update.
      	* function.c (assign_parms_augmented_arg_list): Update.
      	(assign_parm_find_data_types): Update.
      	(assign_parms): Update.
      	(allocate_struct_function): Update.
      	(expand_function_start): Update.
      	(expand_function_end): Update.
      	(get_arg_pointer_save_area): Update.
      	(thread_prologue_and_epilogue_insns): Update.
      	(rest_of_match_asm_constraints): Update.
      	* stor-layout.c (variable_size): Update.
      	* gcse.c (gcse_main): Update.
      	(bypass_jumps): Update.
      	* gimplify.c (gimplify_function_tree): Update.
      	* calls.c (emit_call_1): Update.
      	(expand_call): Update.
      	* bt-load.c (compute_defs_uses_and_gen): Update.
      	* except.c (sjlj_assign_call_site_values): Update.
      	(sjlj_emit_function_enter): Update.
      	(can_throw_external): Update.
      	(set_nothrow_function_flags): Update.
      	(expand_builtin_unwind_init): Update.
      	(expand_eh_return): Update.
      	(convert_to_eh_region_ranges): Update.
      	(output_function_exception_table): Update.
      	* emit-rtl.c (gen_tmp_stack_mem): Update.
      	* cfgexpand.c (expand_used_vars): Update.
      	(tree_expand_cfg): Update.
      	* cfgcleanup.c (rest_of_handle_jump): Update.
      	* explow.c (allocate_dynamic_stack_space): Update.
      	* varasm.c (assemble_start_function): Update.
      	(force_const_mem): Update.
      	(mark_constant_pool): Update.
      	* tree-optimize.c (tree_rest_of_compilation): Update.
      	* stack-ptr-mod.c (notice_stack_pointer_modification): Update.
      	* tree-cfg.c (notice_special_calls): Update.
      	(is_ctrl_altering_stmt): Update.
      	(tree_can_make_abnormal_goto): Update.
      	(tree_purge_dead_abnormal_call_edges): Update.
      	* config/alpha/predicates.md: Update.
      	* config/alpha/alpha.c (alpha_sa_mask): Update.
      	(alpha_sa_size): Update.
      	(alpha_does_function_need_gp): Update.
      	(alpha_expand_prologue): Update.
      	(alpha_start_function): Update.
      	(alpha_output_function_end_prologue): Update.
      	(alpha_expand_epilogue): Update.
      	* config/frv/frv.c (frv_stack_info): Update.
      	(frv_expand_epilogue): Update.
      	* config/s390/s390.c (s390_regs_ever_clobbered): Update.
      	(s390_register_info): Update.
      	(s390_frame_info): Update.
      	(s390_init_frame_layout): Update.
      	(s390_can_eliminate): Update.
      	(save_gprs): Update.
      	* config/spu/spu.c (spu_split_immediate): Update.
      	(need_to_save_reg): Update.
      	(spu_expand_prologue): Update.
      	(spu_expand_epilogue): Update.
      	* config/sparc/sparc.md: Update.
      	* config/sparc/sparc.c (eligible_for_return_delay): Update.
      	(sparc_tls_got): Update.
      	(legitimize_pic_address): Update.
      	(sparc_emit_call_insn): Update.
      	(sparc_expand_prologue): Update.
      	(output_return): Update.
      	(print_operand): Update.
      	(sparc_function_ok_for_sibcall): Update.
      	* config/sparc/sparc.h (EXIT_IGNORE_STACK): Update.
      	* config/m32r/m32r.md: Update.
      	* config/m32r/m32r.c (MUST_SAVE_RETURN_ADDR): Update.
      	(m32r_compute_frame_size): Update.
      	(m32r_expand_prologue): Update.
      	(m32r_expand_epilogue): Update.
      	(m32r_legitimize_pic_address): Update.
      	* config/m32r/m32r.h (FRAME_POINTER_REQUIRED): Update.
      	* config/i386/linux.h (SUBTARGET_FRAME_POINTER_REQUIRED): Update.
      	* config/i386/i386.c (ix86_frame_pointer_required): Update.
      	(gen_push): Update.
      	(ix86_save_reg): Update.
      	(ix86_compute_frame_layout): Update.
      	(ix86_expand_prologue): Update.
      	(ix86_expand_epilogue): Update.
      	* config/sh/sh.c (output_stack_adjust): Update.
      	(calc_live_regs): Update.
      	(sh5_schedule_saves): Update.
      	(sh_expand_prologue): Update.
      	(sh_expand_epilogue): Update.
      	(sh_setup_incoming_varargs): Update.
      	(sh_allocate_initial_value): Update.
      	(sh_get_pr_initial_val): Update.
      	* config/sh/sh.h (SHMEDIA_REGS_STACK_ADJUST): Update.
      	* config/sh/sh.md (label:): Update.
      	* config/avr/avr.c (out_movhi_mr_r): Update.
      	* config/crx/crx.h (enum): Update.
      	* config/xtensa/xtensa.h (along): Update.
      	* config/stormy16/stormy16.c Update.
      	(xstormy16_compute_stack_layout): Update.
      	* config/fr30/fr30.c (MUST_SAVE_RETURN_POINTER): Update.
      	(fr30_expand_prologue): Update.
      	* config/cris/cris.c (cris_conditional_register_usage): Update.
      	(cris_reg_saved_in_regsave_area): Update.
      	(cris_initial_frame_pointer_offset): Update.
      	(cris_simple_epilogue): Update.
      	(cris_expand_prologue): Update.
      	(cris_expand_epilogue): Update.
      	(cris_expand_pic_call_address): Update.
      	(cris_asm_output_symbol_ref): Update.
      	(cris_asm_output_label_ref): Update.
      	* config/cris/cris.md Update.
      	* config/iq2000/iq2000.c (compute_frame_size): Update.
      	(iq2000_expand_epilogue): Update.
      	* config/mt/mt.h (save_direction): Update.
      	* config/mn10300/mn10300.c (mn10300_function_value): Update.
      	* config/ia64/ia64.c (ia64_compute_frame_size): Update.
      	(ia64_secondary_reload_class): Update.
      	* config/m68k/m68k.c (m68k_save_reg): Update.
      	(m68k_expand_prologue): Update.
      	(m68k_expand_epilogue): Update.
      	(legitimize_pic_address): Update.
      	* config/rs6000/rs6000.c (rs6000_got_register): Update.
      	(first_reg_to_save): Update.
      	(first_altivec_reg_to_save): Update.
      	(compute_vrsave_mask): Update.
      	(compute_save_world_info): Update.
      	(rs6000_stack_info): Update.
      	(spe_func_has_64bit_regs_p): Update.
      	(rs6000_ra_ever_killed): Update.
      	(rs6000_emit_eh_reg_restore): Update.
      	(rs6000_emit_allocate_stack): Update.
      	(rs6000_emit_prologue): Update.
      	(rs6000_emit_epilogue): Update.
      	(rs6000_output_function_epilogue): Update.
      	(output_profile_hook): Update.
      	(rs6000_elf_declare_function_name): Update.
      	* config/rs6000/rs6000.h (rs6000_args): Update.
      	* config/rs6000/rs6000.md: Update.
      	* config/mcore/mcore.c (mcore_expand_prolog): Update.
      	* config/arc/arc.c (arc_output_function_epilogue): Update.
      	* config/arc/arc.h (FRAME_POINTER_REQUIRED): Update.
      	* config/darwin.c (machopic_function_base_name): Update.
      	* config/score/score3.c (score3_compute_frame_size): Update.
      	(rpush): Update.
      	(rpop): Update.
      	(score3_epilogue): Update.
      	* config/score/score7.c (score7_compute_frame_size): Update.
      	(score7_prologue): Update.
      	(score7_epilogue): Update.
      	* config/score/score.h (FRAME_POINTER_REQUIRED): Update.
      	* config/arm/linux-elf.h (SUBTARGET_FRAME_POINTER_REQUIRED): Update.
      	* config/arm/arm.c (use_return_insn): Update.
      	(require_pic_register): Update.
      	(arm_load_pic_register): Update.
      	(arm_compute_save_reg0_reg12_mask): Update.
      	(arm_compute_save_reg_mask): Update.
      	(thumb1_compute_save_reg_mask): Update.
      	(output_return_instruction): Update.
      	(arm_output_function_prologue): Update.
      	(arm_output_epilogue): Update.
      	(arm_get_frame_offsets): Update.
      	(arm_expand_prologue): Update.
      	(thumb_pushpop): Update.
      	(thumb_exit): Update.
      	(thumb1_expand_prologue): Update.
      	(thumb1_expand_epilogue): Update.
      	(arm_unwind_emit): Update.
      	(arm_output_fn_unwind): Update.
      	* config/arm/arm.h (FRAME_POINTER_REQUIRED): Update.
      	* config/arm/arm.md: Update.
      	* config/pa/pa.md: Update.
      	* config/pa/pa.c (legitimize_pic_address): Update.
      	(compute_frame_size): Update.
      	(hppa_expand_prologue): Update.
      	(hppa_expand_epilogue): Update.
      	(borx_reg_operand): Update.
      	* config/pa/pa.h (FRAME_POINTER_REQUIRED): Update.
      	(HARD_REGNO_RENAME_OK): Update.
      	* config/mips/mips.c (mips_global_pointer): Update.
      	(mips_save_reg_p): Update.
      	(mips_compute_frame_info): Update.
      	(mips_frame_pointer_required): Update.
      	(mips_expand_prologue): Update.
      	(mips_expand_epilogue): Update.
      	(mips_can_use_return_insn): Update.
      	(mips_reorg_process_insns): Update.
      	* config/v850/v850.c (compute_register_save_size): Update.
      	* config/mmix/mmix.h (FRAME_POINTER_REQUIRED): Update.
      	* config/mmix/mmix.c (along): Update.
      	(mmix_expand_epilogue): Update.
      	* config/bfin/bfin.c (legitimize_pic_address): Update.
      	(must_save_p): Update.
      	(stack_frame_needed_p): Update.
      	(add_to_reg): Update.
      	(bfin_expand_prologue): Update.
      	* stmt.c (expand_asm_operands): Update.
      	* reload1.c (reload): Update.
      	(init_elim_table): Update.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@134682 138bc75d-0d04-0410-961f-82ee72b054a4
      18d50ae6
  7. 19 Oct, 2007 1 commit
    • davem's avatar
      2007-10-18 David S. Miller <davem@davemloft.net> · d6ecc3a3
      davem authored
      	Add Niagara-2 support.
      	* doc/invoke.texi: Document -m{cpu,tune}=niagara2.
      	* config.gcc: Add niagara2 to cpu and tune lists for sparc.
      	* config/sparc/sparc.md (sparc_cpu_attr): Add niagara2.
      	(include): Add inclusion of niagara2.md
      	* config/sparc/sparc.c (niagara2_costs): New.
      	(sparc_override_options): Add niagara2 entry to cpu_default[]
      	and cpu_table[].  Set align_functions to 32 on Niagara2.  Use
      	niagara2_costs when PROCESSOR_NIAGARA2.  Handle Niagara2 for
      	PARAM_SIMULTANEOUS_PREFETCHES and PARAM_L1_CACHE_LINE_SIZE.
      	(sparc_initialize_trampoline): Handle niagara2 like niagara.
      	(sparc64_initialize_trampoline): Likewise.
      	(sparc_use_sched_lookahead): Likewise.
      	(sparc_issue_rate): Likewise.
      	* config/sparc/sol2-bi.h: Handle TARGET_CPU_niagara2 and
      	mcpu=niagara2
      	* config/sparc/sparc.h (TARGET_CPU_niagara2): Define.
      	({CPP,ASM}_CPU64_DEFAULT_SPEC): Set appropriately for
      	TARGET_CPU_niagara2.
      	(PROCESSOR_NIAGARA2): New.
      	(REGISTER_MOVE_COST): Handle PROCESSOR_NIAGARA2.
      	(BRANCH_COST): Likewise.
      	* config/sparc/linux64.h: Handle TARGET_CPU_niagara2.
      	* config/sparc/sol2.h: Likewise.
      	* config/sparc/niagara2.md: New file.
      
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@129472 138bc75d-0d04-0410-961f-82ee72b054a4
      d6ecc3a3
  8. 22 Aug, 2007 1 commit
    • hp's avatar
      * doc/md.texi (Iterators): Renamed from Macros. All contents · fd781bb2
      hp authored
      	changed to reflect rename of respectively define_code_macro and
      	define_mode_macro to define_code_iterator and define_mode_iterator.
      	(Mode Iterators, Code Iterators): Similar.
      	* read-rtl.c (struct iterator_group, struct iterator_traverse_data)
      	(uses_mode_iterator_p, apply_mode_iterator, uses_code_iterator_p)
      	(apply_iterator_to_string, uses_iterator_p, apply_iterator_traverse)
      	(initialize_iterators, find_iterator, check_code_iterator)
      	(map_attr_string, apply_mode_maps, apply_iterator_to_rtx, add_mapping)
      	(read_mapping, read_rtx_1): Similar.
      	* config/alpha/sync.md, config/alpha/alpha.md, config/frv/frv.md,
      	config/s390/s390.md, config/m32c/blkmov.md, config/m32c/m32c.md,
      	config/spu/spu.md, config/sparc/sparc.md, config/sparc/sync.md,
      	config/i386/i386.md, config/i386/mmx.md, config/i386/sse.md,
      	config/i386/sync.md, config/crx/crx.md, config/xtensa/xtensa.md,
      	config/cris/cris.c, config/cris/cris.md, config/ia64/sync.md,
      	config/ia64/div.md, config/ia64/vect.md, config/ia64/ia64.md,
      	config/m68k/m68k.md, config/rs6000/spe.md, config/rs6000/altivec.md,
      	config/rs6000/sync.md, config/rs6000/rs6000.md,
      	config/arm/vec-common.md, config/arm/neon.md, config/arm/iwmmxt.md,
      	config/arm/arm.md, config/mips/mips-dsp.md, config/mips/mips.md,
      	config/vax/vax.md, config/bfin/bfin.md: Similar.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@127715 138bc75d-0d04-0410-961f-82ee72b054a4
      fd781bb2
  9. 02 Aug, 2007 1 commit
    • nickc's avatar
      * config/host-hpux.c: Change copyright header to refer to version 3 of the GNU · 038d1e19
      nickc authored
        General Public License and to point readers at the COPYING3 file and the FSF's
        license web page.
      * config/alpha/predicates.md, config/alpha/vms-ld.c,
      config/alpha/linux.h, config/alpha/alpha.opt,
      config/alpha/linux-elf.h, config/alpha/vms.h, config/alpha/elf.h,
      config/alpha/vms-unwind.h, config/alpha/ev4.md,
      config/alpha/ev6.md, config/alpha/alpha.c, config/alpha/vms-cc.c,
      config/alpha/alpha.h, config/alpha/sync.md,
      config/alpha/openbsd.h, config/alpha/alpha.md,
      config/alpha/alpha-modes.def, config/alpha/ev5.md,
      config/alpha/alpha-protos.h, config/alpha/freebsd.h,
      config/alpha/osf5.h, config/alpha/netbsd.h, config/alpha/vms64.h,
      config/alpha/constraints.md, config/alpha/osf.h,
      config/alpha/xm-vms.h, config/alpha/unicosmk.h, config/linux.h,
      config/frv/predicates.md, config/frv/frv.h, config/frv/linux.h,
      config/frv/frv.md, config/frv/frv.opt, config/frv/frv-modes.def,
      config/frv/frv-asm.h, config/frv/frv-protos.h,
      config/frv/f...
      038d1e19
  10. 10 Jul, 2007 1 commit
    • ian's avatar
      Replace no_new_pseudos in backends. · e1ba4a27
      ian authored
      	* rtl.h (can_create_pseudo_p): Define.
      	* config/darwin.c (machopic_indirect_data_reference): Use
      	can_create_pseudo_p () instead of no_new_pseudos.
      	(machopic_indirect_data_reference): Likewise.
      	(machopic_legitimize_pic_address): Likewise.
      	* config/alpha/alpha.c (alpha_legitimize_address): Likewise.
      	(alpha_emit_set_const_1): Likewise.
      	(alpha_emit_set_const): Likewise.
      	(alpha_emit_conditional_move): Likewise.
      	(alpha_split_conditional_move): Likewise.
      	* config/alpha/alpha.md (various splitters): Likewise.
      	(movti): Likewise.
      	* config/arm/arm.c (legitimize_pic_address): Likewise.
      	(arm_load_pic_register): Likewise.
      	* config/arm/arm.md (addsi3, subsi3, andsi3, iorsi3): Likewise.
      	(movdi, movsi, movhi, movqi, movsf, movdf): Likewise.
      	* config/bfin/bfin.c (legitimize_pic_address): Likewise.
      	* config/cris/cris.c (cris_expand_pic_call_address): Likewise.
      	* config/cris/cris.md (movsi): Likewise.
      	* config/frv/frv.md (symGOT2reg_hilo): Likewise.
      	(symGOTOFF2reg_hilo): Likewise.
      	(symGPREL2reg, symGPREL2reg_hilo): Likewise.
      	* config/h8300/h8300.md (insv, extzv): Likewise.
      	* config/i386/i386.c (ix86_expand_move): Likewise.
      	(ix86_expand_vector_move): Likewise.
      	(ix86_prepare_fp_compare_args): Likewise.
      	(ix86_expand_carry_flag_compare): Likewise.
      	* config/i386/i386.md (tls_dynamic_gnu2_32): Likewise.
      	(tls_dynamic_gnu2_combine_32): Likewise.
      	(tls_dynamic_gnu2_64, tls_dynamic_gnu2_combine_64): Likewise.
      	* config/ia64/ia64.c (ia64_expand_move): Likewise.
      	(ia64_expand_movxf_movrf): Likewise.
      	* config/m32c/m32c.c (m32c_prepare_move): Likewise.
      	(m32c_split_move): Likewise.
      	(m32c_expand_insv): Likewise.
      	* config/m68k/m68k.md (movsi): Likewise.
      	* config/mips/mips.c (mips_force_temporary): Likewise.
      	(mips_split_symbol): Likewise.
      	(mips_move_integer): Likewise.
      	(mips_legitimize_const_move): Likewise.
      	* config/mn10300/mn10300.md (movsi): Likewise.
      	* config/pa/pa.c (emit_move_sequence): Likewise.
      	* config/rs6000/rs6000.c (rs6000_emit_move): Likewise.
      	(rs6000_got_register): Likewise.
      	(create_TOC_reference): Likewise.
      	(rs6000_machopic_legitimize_pic_address): Likewise.
      	* config/rs6000/rs6000.md (add<mode>3): Likewise.
      	(various splitters): Likewise.
      	(iorsi3, xorsi3, iordi3, xordi3): Likewise.
      	(movsi_got): Likewise.
      	* config/s390/s390.c (emit_symbolic_move): Likewise.
      	* config/s390/s390.md (movhi, movqi): Likewise.
      	(load_multiple, store_multiple): Likewise.
      	* config/score/score.c (score_force_temporary): Likewise.
      	* config/sh/sh.c (prepare_move_operands): Likewise.
      	(prepare_cbranch_operands): Likewise.
      	(emit_fpu_switch): Likewise.
      	(fpscr_set_from_mem): Likewise.
      	* config/sh/sh.md (movdicc, movsicc, movsicc_umin): Likewise.
      	(adddi3, subsi3): Likewise.
      	(various splitters): Likewise.
      	(divsi_inv_fp_combine): Likewise.
      	(symGOT_load, symGOTOFF2reg, symDTPOFF2reg): Likewise.
      	(seq, slt, sle, sgt, sge, sgtu, sltu, sleu, sgeu): Likewise.
      	(sne): Likewise.
      	* config/sh/predicates.md (xor_operand): Likewise.
      	* config/sparc/sparc.c (legitimize_tls_address): Likewise.
      	* config/sparc/sparc.md (movsi_pic_label_ref): Likewise.
      	(movdi_pic_label_ref): Likewise.
      	* config/spu/spu.c (spu_split_immediate): Likewise.
      	* config/alpha/alpha.md (various splitters): Remove test
      	!no_new_pseudos || reload_completed.
      	* config/ia64/ia64.c (ia64_output_mi_thunk): Don't set
      	no_new_pseudos.
      	* config/m68k/m68k.c (m68k_output_mi_thunk): Likewise.
      	* config/mips/mips.c (mips_output_mi_thunk): Likewise.
      	* config/rs6000/rs6000.c (rs6000_output_mi_thunk): Likewise.
      	* config/score/score.c (th_output_mi_thunk): Likewise.
      	* config/sh/sh.c (sh_output_mi_thunk): Likewise.
      	* config/sparc/sparc.c (sparc_output_mi_thunk): Likewise.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@126517 138bc75d-0d04-0410-961f-82ee72b054a4
      e1ba4a27
  11. 10 May, 2007 1 commit
    • rsandifo's avatar
      gcc/ · 723e1902
      rsandifo authored
      	* config.gcc (sparc-wrs-vxworks): New target.
      	* config/sparc/vxworks.h, config/sparc/t-vxworks: New files.
      	* config/sparc/sparc-protos.h (sparc_emit_call_insn): Declare.
      	* config/sparc/sparc.h: Include vxworks-dummy.h.
      	(PRINT_OPERAND_ADDRESS): Extend SYMBOL_REF handling to
      	include LABEL_REFs too.
      	* config/sparc/sparc.c (sparc_expand_move): Don't assume that
      	_GLOBAL_OFFSET_TABLE_ - label_ref is a link-time constant on
      	VxWorks.
      	(legitimize_pic_address): Handle LABEL_REFs like SYMBOL_REFs
      	on VxWorks.
      	(load_pic_register): Use gen_vxworks_load_got for VxWorks.
      	(sparc_emit_call_insn): New function.
      	(sparc_function_ok_for_sibcall): Restrict sibcalls to locally-binding
      	functions when generating VxWorks PIC.
      	* config/sparc/sparc.md (vxworks_load_got): New pattern.
      	(call, call_value): Use sparc_emit_call_insn instead of
      	emit_call_insn.
      
      libgcc/
      	* config.host (sparc-wrs-vxworks): New target.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@124595 138bc75d-0d04-0410-961f-82ee72b054a4
      723e1902
  12. 20 Feb, 2007 1 commit
    • kazu's avatar
      * config/c4x/c4x.md, config/cris/cris.c, config/crx/crx.c, · 5b865faf
      kazu authored
      	config/fr30/fr30.md, config/i386/i386.h,
      	config/iq2000/iq2000.h, config/iq2000/predicates.md,
      	config/pa/milli64.S, config/pa/pa.c, config/pa/pa.h,
      	config/pa/pa.md, config/pa/pa32-regs.h, config/pa/pa64-regs.h,
      	config/pdp11/pdp11.c, config/pdp11/pdp11.h,
      	config/rs6000/altivec.md, config/rs6000/rs6000.c,
      	config/s390/s390-modes.def, config/sparc/netbsd-elf.h,
      	config/sparc/sparc.c, config/sparc/sparc.h,
      	config/sparc/sparc.md, config/spu/constraints.md,
      	config/spu/spu.c, config/stormy16/stormy16.md: Follow spelling
      	conventions.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@122151 138bc75d-0d04-0410-961f-82ee72b054a4
      5b865faf
  13. 04 Apr, 2006 1 commit
    • carlos's avatar
      gcc/ · d8c09ceb
      carlos authored
      2006-04-04  Carlos O'Donell  <carlos@codesourcery.com>
      
      	* doc/tm.texi (TARGET_STRUCT_VALUE_RTX): Document
      	new value 2 for incoming.
      	* function.c (expand_function_start): Call struct_value_rtx
      	with incoming as 2.
      	* config/sparc/sparc.md: Comment updated_return.
      	* config/sparc/sparc.opt: Add -mstd-struct-return option.
      	* config/sparc/sparc.c (sparc_struct_value_rtx): Use standard
      	struct return if sparc_std_struct_return and incoming is 2.
      	(print_operand): Do not adjust return if
      	sparc_std_struct_return.
      
      gcc/testsuite/
      
      2006-04-04  Carlos O'Donell  <carlos@codesourcery.com>
      
      	* gcc.target/sparc/struct-ret-check.c: New test.
      
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@112672 138bc75d-0d04-0410-961f-82ee72b054a4
      d8c09ceb
  14. 02 Mar, 2006 1 commit
    • davem's avatar
      Sun Niagara specific optimizations. · 6dbce0cb
      davem authored
      	* config.gcc: Recognize niagara as target.
      	* config/sparc/sparc.h (SPARC_RELAXED_ORDERING): Mention Niagara.
      	(TARGET_CPU_niagara): Define.
      	(CPP_CPU64_DEFAULT_SPEC): Define __sparc_v9__ for Niagara.
      	(ASM_CPU64_DEFAULT_SPEC): Pass -Av9b for Niagara.
      	(CPP_CPU_SPEC): Handle -mcpu=niagara.
      	(ASM_CPU_SPEC): Likewise.
      	(PROCESSOR_NIAGARA): New enum entry.
      	(REGISTER_MOVE_COST): Handle Niagara.
      	(BRANCH_COST, PREFETCH_BLOCK, SIMULTANEOUS_PREFETCHES): Likewise.
      	* config/sparc/sparc.c (niagara_costs): New processor_costs entry.
      	(sparc_override_options): Recognize "niagara", set appropriate
      	default MASK_* values for it, and align functions to 32-bytes
      	by default just like ULTRASPARC/ULTRASPARC3.
      	(sparc_initialize_trampoline): Handle niagara like ultrasparc.
      	(sparc64_initialize_trampoline): Likewise.
      	(sparc_use_sched_lookahead): Use zero for niagara.
      	(sparc_issue_rate): Use one for niagara.
      	* config/sparc/niagara.md: New file.
      	* config/sparc/sparc.md: Include it.
      	* config/sparc/sol2-bi.h (CPP_CPU64_DEFAULT_SPEC,
      	ASM_CPU32_DEFAULT_SPEC, ASM_CPU64_DEFAULT_SPEC): Set appropriately
      	when default cpu is niagara.
      	(CPP_CPU_SPEC): Handle -mcpu=niagara.
      	(ASM_CPU_SPEC): Likewise.
      	* config/sparc/sol2.h (ASM_CPU_DEFAULT_SPEC): Set appropriately
      	when default cpu is niagara.
      	(ASM_CPU_SPEC): Handle -mcpu=niagara.
      	* config/sparc/linux64.h: Handle a default of TARGET_CPU_niagara
      	just like v9/ultrasparc/ultrasparc3.
      	* doc/invoke.texi: Add documentation for "niagara" and improve
      	existing documentation for ultrasparc variants.
      
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@111648 138bc75d-0d04-0410-961f-82ee72b054a4
      6dbce0cb
  15. 16 Feb, 2006 1 commit
  16. 03 Jan, 2006 1 commit
    • jakub's avatar
      Merge from gomp-branch. · 6c6e47a5
      jakub authored
      	* config/sparc/sync.md: New file.
      	* config/sparc/sparc.md (UNSPECV_MEMBAR, UNSPECV_CAS, UNSPECV_SWAP,
      	UNSPECV_LDSTUB): New constants.
      	* config/sparc/sparc.c (sparc_expand_compare_and_swap_12): New function.
      	* config/sparc/predicates.md (memory_reg_operand): New predicate.
      	* config/sparc/sparc-protos.h (sparc_expand_compare_and_swap_12): New
      	prototype.
      
      	* gcc.dg/ia64-sync-1.c: On sparc*-*-*, pass -mcpu=v9.
      	* gcc.dg/ia64-sync-2.c: Likewise.
      	* gcc.dg/ia64-sync-3.c: Likewise.
      	* gcc.dg/ia64-sync-4.c: Likewise.
      	* gcc.dg/sync-2.c: Likewise.
      	* lib/target-supports.exp (sync_char_short, sync_int_long): Indicate
      	that sparc64-*-* and sparcv9-*-* supports sync builtins.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@109271 138bc75d-0d04-0410-961f-82ee72b054a4
      6c6e47a5
  17. 30 Nov, 2005 1 commit
  18. 07 Jul, 2005 1 commit
  19. 06 Jul, 2005 1 commit
    • jakub's avatar
      * config/sparc/sparc.h (sparc_compare_emitted): New extern. · fc5cceaf
      jakub authored
      	* config/sparc/sparc.c (sparc_compare_emitted): New variable.
      	(gen_compare_reg): If sparc_compare_emitted is set, clear it
      	and return its previous value.
      	(emit_v9_brxx_insn): Assert sparc_compare_emitted is NULL.
      	* config/sparc/sparc.md (UNSPEC_SP_SET, UNSPEC_SP_TEST): New
      	constants.
      	(stack_protect_set, stack_protect_test): New expanders.
      	(stack_protect_setsi, stack_protect_setdi, stack_protect_testsi,
      	stack_protect_testdi): New insns.
      	* config/sparc/linux.h (TARGET_THREAD_SSP_OFFSET): Define.
      	* config/sparc/linux64.h (TARGET_THREAD_SSP_OFFSET): Define.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@101653 138bc75d-0d04-0410-961f-82ee72b054a4
      fc5cceaf
  20. 25 Jun, 2005 1 commit
  21. 26 May, 2005 1 commit
    • kazu's avatar
      * c-common.c, c-parser.c, cfgbuild.c, cfghooks.c, cfghooks.h, · 442e3cb9
      kazu authored
      	cfgrtl.c, cgraphunit.c, ddg.c, expr.h, gcse.c, ggc-page.c,
      	ggc-zone.c, gimplify.c, ipa-inline.c, longlong.h, targhooks.c,
      	tree-flow-inline.h, tree-pass.h, tree-ssa-dse.c,
      	tree-ssa-loop-im.c, tree-ssa-loop-ivopts.c,
      	tree-ssa-operands.c, tree-vect-analyze.c,
      	tree-vect-transform.c, tree-vectorizer.c, tree.c,
      	config/arm/arm.c, config/bfin/bfin.c, config/frv/frv.c,
      	config/frv/frv.md, config/i386/i386.c, config/i386/sse.md,
      	config/m68hc11/m68hc11.c, config/m68hc11/m68hc11.h,
      	config/mcore/mcore.c, config/mips/mips.c, config/mips/mips.md,
      	config/rs6000/darwin-ldouble.c, config/rs6000/rs6000.c,
      	config/rs6000/rs6000.h, config/sh/sh.c, config/sh/sh.md,
      	config/sh/ushmedia.h, config/sparc/sparc.c,
      	config/sparc/sparc.md, config/stormy16/stormy-abi: Fix comment
      	typos.  Follow spelling conventions.
      	* doc/invoke.texi, doc/tm.texi, doc/tree-ssa.texi: Fix typos.
      	Follow spelling conventions.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@100218 138bc75d-0d04-0410-961f-82ee72b054a4
      442e3cb9
  22. 23 May, 2005 1 commit
    • ebotcazou's avatar
      * config/sparc/sparc-protos.h (sparc_expand_move): New prototype. · b6a32a23
      ebotcazou authored
      	* config/sparc/sparc.c (sparc_expand_move): New function.
      	(sparc_emit_set_const64): Rewrite assert condition on entry.
      	(legitimate_constant_p) <CONST_VECTOR>: New case.
      	(legitimize_pic_address): Use TARGET_ARCH64 to select the mode.
      	* config/sparc/sparc.md (movqi, movhi, movsi, movdi, movV32,
      	movV64, movtf): Use nonimmediate_operand for the first operand.
      	Rewrite.  Only invoke sparc_expand_move.
      	* config/sparc/predicates.md (input_operand): Reorder tests.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@100077 138bc75d-0d04-0410-961f-82ee72b054a4
      b6a32a23
  23. 17 May, 2005 1 commit
  24. 12 May, 2005 1 commit
    • ebotcazou's avatar
      * config/sparc/sparc.h: Remove dead code. · d88ab5ca
      ebotcazou authored
      	* config/sparc/sparc.c (sparc_compute_frame_size): Use
      	FIRST_PARM_OFFSET for the size of the register window area.
      	(emit_save_regs): Rename into emit_save_or_restore_regs.
      	Add 'action' parameter.  Use 4095 as upper bound for the offset.
      	Pass 'action' to save_or_restore_regs.
      	(emit_restore_regs): Delete.
      	(sparc_expand_prologue): Call emit_save_or_restore_regs.
      	(sparc_expand_epilogue): Likewise.
      	* config/sparc/sparc.md (mode macro P): Move.
      	(movdi_insn_sp32_v9, movdi_insn_sp32): Swap.
      	(mov<V32:mode> expander): Move to the top of the V32 section.
      	(movdf_insn_sp32_v9_no_fpu, movdf_insn_sp32_v9): Swap.
      	(movtf_insn_sp64_hq, movtf_insn_sp64): Swap.
      	(sibcall_epilogue): Move.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@99609 138bc75d-0d04-0410-961f-82ee72b054a4
      d88ab5ca
  25. 10 May, 2005 1 commit
    • ebotcazou's avatar
      * config/sparc/sparc.c (fp_sethi_p): Test !SPARC_SIMM13_P and · c3f211ea
      ebotcazou authored
      	remove redundant test.
      	(fp_mov_p): Accept 0.
      	(fp_high_losum_p): Remove redundant test.
      	* config/sparc/predicates.md (const_high_operand): Explicitly test
      	(not small_int_operand).
      	(fp_const_high_losum_operand): New.
      	* config/sparc/sparc.md (movsi_insn): Do not emit 'clr'.  Reorder.
      	(movdi_insn_sp32_v9): Use canonical predicates.
      	(movdi_insn_sp32): Test !TARGET_V9 instead of !TARGET_ARCH64.
      	(movdi_insn_sp64_novis): Delete.
      	(movdi_insn_sp64_vis): Rename into movdi_insn_sp64.
      	(movsf_insn_novis): Delete.
      	(movsf_insn_vis): Rename into movsf_insn.
      	(movsf_no_f_insn): Rename into movsf_insn_no_fpu.
      	(movsf_lo_sum): Use fp_const_high_losum_operand.
      	(movsf_high): Likewise.
      	(movsf_high_losum splitter): Likewise.
      	(mov<V32:mode> expander): Use register_or_zero_operand.
      	(mov<V64:mode> expander): Likewise.
      	(movdf_insn_sp32): Use register_or_zero_operand.
      	(movdf_no_e_insn_sp32): Use register_or_zero_operand.
      	Rename into movdf_insn_sp32_no_fpu.
      	(movdf_no_e_insn_v9_sp32): Use register_or_zero_operand.
      	Rename into movdf_insn_sp32_v9_no_fpu.
      	(movdf_insn_v9only_novis): Delete.
      	(movdf_insn_v9only_vis): Rename into movdf_insn_sp32_v9.
      	(movdf_insn_sp64_novis): Delete.
      	(movdf_insn_sp64_vis): Rename into movdf_insn_sp64.
      	(movdf_no_e_insn_sp64): Use register_or_zero_operand.
      	Rename into movdf_insn_sp64_no_fpu.
      	(movtf expander): Use register_or_zero_operand.
      	(movtf_insn_sp32): Delete.
      	(movtf_insn_vis_sp32): Use register_or_zero_operand.
      	Rename into movtf_insn_sp32.
      	(movtf_no_e_insn_sp32): Use register_or_zero_operand.
      	Rename into movtf_insn_sp32_no_fpu.
      	(movtf_insn_hq_sp64): Delete.
      	(movtf_insn_hq_vis_sp64): Use register_or_zero_operand.
      	Rename into movtf_insn_sp64_hq.
      	(movtf_insn_sp64): Delete.
      	(movtf_insn_vis_sp64): Use register_or_zero_operand.
      	Rename into movtf_insn_sp64.
      	(movtf_no_e_insn_sp64): Use register_or_zero_operand.
      	Rename into movtf_insn_sp64_no_fpu.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@99506 138bc75d-0d04-0410-961f-82ee72b054a4
      c3f211ea
  26. 03 May, 2005 1 commit
    • ebotcazou's avatar
      * config/sparc/predicates.md (const_compl_high_operand): New. · 35f85e39
      ebotcazou authored
      	* config/sparc/sparc.c (sparc_emit_set_safe_HIGH64): Rename into
      	gen_safe_HIGH64.
      	(sparc_emit_set_const64_quick1): Adjust for above change.
      	(sparc_emit_set_const64_quick2): Likewise.
      	(sparc_emit_set_const64_longway): Likewise.
      	(sparc_emit_set_const64): Likewise.
      	* config/sparc/sparc.md (movhi_const64_special, movsi_const64_special,
      	movdi_const64_special): Delete.
      	(logical constant splitters): Use const_compl_high_operand.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@99160 138bc75d-0d04-0410-961f-82ee72b054a4
      35f85e39
  27. 22 Apr, 2005 1 commit
    • ebotcazou's avatar
      * config/sparc/predicates.md (arith_double_operand): Use · 3bb6b41e
      ebotcazou authored
      	trunc_int_for_mode if HOST_BITS_PER_WIDE_INT >=64.
      	* config/sparc/sparc.md (movqi, movhi, movsi, movqi): Use gen_int_mode.
      	(DImode, DFmode constant splitters): Likewise.  Remove code for
      	TARGET_ARCH64 && HOST_BITS_PER_WIDE_INT < 64.
      	(logical constant splitters): Use const_int_operand predicate.
      	(lshrsi3_extend): Remove code for TARGET_ARCH64 &&
      	HOST_BITS_PER_WIDE_INT < 64.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@98560 138bc75d-0d04-0410-961f-82ee72b054a4
      3bb6b41e
  28. 21 Apr, 2005 3 commits
    • kazu's avatar
      * config/sparc/predicates.md, config/sparc/sparc.md: Fix · 2bd0405c
      kazu authored
      	comment typos.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@98502 138bc75d-0d04-0410-961f-82ee72b054a4
      2bd0405c
    • ebotcazou's avatar
      Revert unrelated changes from latest commit. · 0e255165
      ebotcazou authored
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@98496 138bc75d-0d04-0410-961f-82ee72b054a4
      0e255165
    • ebotcazou's avatar
      * config/sparc/sparc.c (reg_or_0_operand, const1_operand, · 27b36d57
      ebotcazou authored
      	fp_zero_operand, fp_register_operand, intreg_operand,
      	fcc_reg_operand, fcc0_reg_operand, icc_or_fcc_reg_operand,
      	call_operand, call_operand_address, tgd_symbolic_operand,
      	tld_symbolic_operand, tie_symbolic_operand, tle_symbolic_operand,
      	symbolic_operand, symbolic_memory_operand, label_ref_operand,
      	sp64_medium_pic_operand, data_segment_operand,
      	text_segment_operand, splittable_symbolic_memory_operand,
      	reg_or_nonsymb_mem_operand, splittable_immediate_memory_operand,
      	eq_or_neq, normal_comp_operator, noov_compare_op,
      	noov_compare64_op, v9_regcmp_op, extend_op, cc_arithop,
      	cc_arithopn, arith_operand, arith_4096_operand, arith_add_operand,
      	const64_operand, const64_high_operand, arith11_operand,
      	arith10_operand, arith_double_operand, arith_double_4096_operand,
      	arith_double_add_operand, arith11_double_operand,
      	arith10_double_operand, small_int, small_int_or_double,
      	uns_small_int, uns_arith_operand, clobbered_register,
      	input_operand, compare_operand): Delete.
      	(sparc_emit_set_const32): Use predicates in assertion.  Remove special
      	code for TARGET_ARCH64 && HOST_BITS_PER_WIDE_INT != 64.
      	(sparc_emit_set_const64): Call gcc_unreachable if H_B_P_W_I == 32.
      	(GEN_HIGHINT64, GEN_INT64): Delete.
      	(sparc_emit_set_safe_HIGH64, gen_safe_SET64, gen_safe_OR64,
      	gen_safe_XOR64): Adjust for above deletion.
      	(sparc_emit_set_const64): Support only H_B_P_W_I == 64 and CONST_INTs.
      	Use 'unsigned HOST_WIDE_INT' instead of 'long' for bitmask.
      	(legitimate_constant_p): Use const_zero_operand instead.
      	(sparc_extra_constraint_check): Likewise.
      	* config/sparc/sparc.h (CONST_DOUBLE_OK_FOR_LETTER_P): Remove 'O'.
      	(PREFERRED_RELOAD_CLASS): Use const_zero_operand.
      	(PREDICATE_CODES): Delete.
      	* config/sparc/sparc.md: Include predicates.md.
      	(All patterns): Adjust for new predicate names.
      	(cmpdi, cmpdi_sp64): Use arith_operand predicate.
      	(movhi_const64_special, movsi_const64_special): Add 'K' constraint.
      	(movdi): Use general_operand predicate.
      	(movdi_sp64_dbl): Delete.
      	(movdi_const64_special): Add 'N' constraint.
      	(movdicc): Use arith10_operand predicate.
      	(movdi_cc_sp64, movdi_cc_sp64_trunc): Use arith11_operand predicate.
      	(movdi_cc_reg_sp64): Use arith10_operand predicate.
      	(movdi_cc_reg_sp64_trunc): Delete.
      	(cmp_zero_extract, cmp_zero_extract_sp64): Use small_int_operand.
      	(adddi3_insn_sp32, addx, cmp_cc_plus, cmp_ccx_plus, cmp_cc_plus_set,
      	cmp_ccx_plus_set): Use register_operand predicate.
      	(adddi3_sp64, cmp_ccx_plus_set): Use arith_operand predicate.
      	(subdi3_sp32): Delete.
      	(subdi3_insn_sp32): Change to define_insn_and_split.
      	(subdi3_sp64, cmp_minus_ccx, cmp_minus_ccx_set): Use arith_operand.
      	(muldi3, muldi3_sp64, muldi3_v8plus): Likewise.
      	(smulsi3_highpart_v8plus, const_smulsi3_highpart_v8plus,
      	umulsi3_highpart_v8plus, const_umulsi3_highpart_v8plus): Use
      	small_int_operand predicate.
      	(divdi3, udivdi3): Use arith_operand predicate.
      	(udivsi3, udivsi3_sp32, udivsi3_sp64): Use nonimmediate_operand.
      	(and<V64I>3_sp64, ior<V64I>3_sp64, xor<V64I:mode>3_sp64,
      	xor_not_<V64I:mode>_sp64) : Use arith_operand predicate.
      	(xordi3_sp64_dbl): Delete.
      	(cmp_ccx_arith_op, cmp_ccx_arith_op_set, cmp_ccx_xor_not,
      	cmp_ccx_xor_not_set, cmp_ccx_arith_op_not, cmp_ccx_arith_op_not_set,
      	cmp_ccx_neg, cmp_ccx_set_neg, one_cmpl<V64I>2_sp64, cmp_ccx_not,
      	cmp_ccx_set_not): Use arith_operand predicate.
      	(ashrsi3_extend2, lshrsi3_extend2 et al.): Use small_int_operand.
      	* config/sparc/predicates.md: New file.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@98494 138bc75d-0d04-0410-961f-82ee72b054a4
      27b36d57
  29. 12 Apr, 2005 1 commit
  30. 11 Apr, 2005 1 commit
  31. 18 Jan, 2005 2 commits
    • ebotcazou's avatar
      * config/sparc/sparc.c (load_pic_register): Emit the appropriate · f787e26b
      ebotcazou authored
      	variant of the load_pcrel_sym pattern.
      	* config/sparc/sparc.md (P macro): Move to the top.
      	(load_pcrel_sym): Macroize using P.
      	(save_register_window): Likewise.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@93859 138bc75d-0d04-0410-961f-82ee72b054a4
      f787e26b
    • kazu's avatar
      * config/darwin.c, config/darwin.h, config/freebsd-spec.h, · 2be1b07e
      kazu authored
      	config/alpha/alpha.c, config/arm/vfp.md,
      	config/i386/emmintrin.h, config/i386/i386-modes.def,
      	config/i386/i386-protos.h, config/i386/i386.h,
      	config/i386/pmmintrin.h, config/i386/ppro.md,
      	config/i386/predicates.md, config/i386/xmmintrin.h,
      	config/i860/i860.c, config/ia64/ia64-modes.def,
      	config/ia64/ia64-protos.h, config/ia64/ia64.h,
      	config/ia64/ia64.md, config/ia64/itanium1.md,
      	config/ia64/itanium2.md, config/ia64/predicates.md,
      	config/iq2000/iq2000.h, config/mips/linux64.h,
      	config/rs6000/aix41.h, config/rs6000/aix43.h,
      	config/rs6000/aix52.h, config/rs6000/darwin-fallback.c,
      	config/rs6000/rs6000.c, config/rs6000/rs6000.h,
      	config/rs6000/spe.md, config/sh/sh.md, config/sparc/linux.h,
      	config/sparc/linux64.h, config/sparc/litecoff.h,
      	config/sparc/sp64-elf.h, config/sparc/sparc.c,
      	config/sparc/sparc.h, config/sparc/sparc.md,
      	config/sparc/sysv4-only.h: Update copyright.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@93829 138bc75d-0d...
      2be1b07e
  32. 04 Jan, 2005 1 commit
  33. 26 Nov, 2004 1 commit
    • ebotcazou's avatar
      * target.h (struct gcc_target): New field 'dwarf_handle_frame_unspec'. · d15ee1a5
      ebotcazou authored
      	* target_def.h (TARGET_DWARF_HANDLE_FRAME_UNSPEC): Define to 0.
      	(TARGET_INITIALIZER): Add TARGET_DWARF_HANDLE_FRAME_UNSPEC.
      	* dwarf2out.c (dwarf2out_frame_debug_expr): Allow REG->REG move
      	to a fixed reg if the source is the Return Address register.
      	Implement new Rule 15.
      	* doc/tm.texi (Frame Layout): Document TARGET_DWARF_HANDLE_FRAME_UNSPEC.
      	* config/sparc/sparc.c (TARGET_DWARF_HANDLE_FRAME_UNSPEC): Define to
      	sparc_dwarf_handle_frame_unspec.
      	(gen_save_register_window): New function.
      	(emit_stack_pointer_increment): Rename into gen_stack_pointer_inc.
      	(emit_stack_pointer_decrement): Rename into gen_stack_pointer_dec.
      	(expand_prologue): Adjust calls to emit_stack_pointer_{in,de}crement.
      	Set RTX_FRAME_RELATED_P on the appropriate insns and members of insns.
      	(sparc_asm_function_prologue): Do not emit call frame debugging info.
      	(emit_and_preserve): Adjust calls to emit_stack_pointer_{in,de}crement.
      	(sparc_expand_epilogue): Likewise.
      	(sparc_dwarf_handle_frame_unspec): New function.
      	* config/sparc/sparc.md (save_register_window): Remove.
      	(save_register_windowdi): Rewrite modelled on the callframe debug info.
      	(save_register_windowsi): Likewise.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@91346 138bc75d-0d04-0410-961f-82ee72b054a4
      d15ee1a5
  34. 23 Nov, 2004 1 commit
    • phython's avatar
      2004-11-22 James A. Morrison <phython@gcc.gnu.org · 5e8cda9b
      phython authored
              * config/sparc/sparc.c: Include insn-codes.h and langhooks.h.
              (sparc_init_builtins): New function.
              (sparc_init_vis_builtins): Create builtin functions for VIS
              instructions.
              (sparc_expand_builtin): Expand builtin functions for VIS instructions.
              (TARGET_INIT_BUILTINS): Define to sparc_init_builtins.
              (TARGET_EXPAND_BUILTIN): Define to sparc_expand_builtin.
              (def_builtin): New macro for creating builtin functions.
              (P): New mode macro for pointer types.
              (UNSPEC_FPACK16, UNSPEC_FPACK32, UNSPEC_FPACKFIX, UNSPEC_FEXPAND,
              UNSPEC_FPMERGE, UNSPEC_MUL16AL, UNSPEC_MUL8UL, UNSPEC_MULDUL,
              UNSPEC_ALIGNDATA, UNSPEC_ALIGNADDR, UNSPEC_PDIST): New constants.
              (fpack16_vis, fpackfix_vis, fpack32_vis, fexpand_vis, fpmerge_vis,
              fmul8x16_vis, fmul8x16au_vis, fmul8x16al_vis, fmul8sux16_vis,
              fmul8ulx16_vis, fmuld8sux16_vis, fmuld8ulx16_vis, pdist_vis,
              faligndata<V64:mode>_vis, alignaddr<P:mode>_vis): New patterns.
      
      testsuite:
              * gcc.target/sparc/align.c, gcc.target/sparc/combined-2.c,
              gcc.target/sparc/fpack16.c, gcc.target/sparc/fpack32.c,
              gcc.target/sparc/fpackfix.c, gcc.target/fexpand.c,
              gcc.target/sparc/fpmerge.c, gcc.target/sparc/fpmul.c,
              gcc.target/sparc/pdist.c: New tests.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@91057 138bc75d-0d04-0410-961f-82ee72b054a4
      5e8cda9b
  35. 13 Nov, 2004 1 commit
    • ebotcazou's avatar
      PR target/18230 · 690f1a75
      ebotcazou authored
      	* config/sparc/sparc.c (sparc_rtx_costs): Handle the NAND vector
      	patterns.
      	* config/sparc/sparc.md (V64I): New macro for 64-bit modes.
      	(V32I): New macro for 32-bit modes.
      	(anddi3, anddi_sp32, anddi_sp64, and_not_di_sp32, and_not_di_sp64,
      	iordi3, iordi3_sp32, iordi_sp64, or_not_di_sp32, or_not_di_sp64,
      	xordi3, xordi3_sp32, xordi3_sp64, {AND, IOR, XOR} DI splitter,
      	xor_not_di_sp32, xordi_not_di_sp64, one_cmpldi2, one_cmpldi_sp32,
      	one_cmpldi_sp64): Use V64I instead of DI.
      	(andsi3, andsi_sp32, andsi_sp64, and_not_si, iorsi3, or_not_si,
      	xorsi3, xor_not_si, one_cmplsi2): Use V32I instead of SI.
      	(addv2si3, addv4hi3, addv2hi3): Remove % modifier.
      	(nandv64i_vis, nandv32i_vis): New patterns.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@90578 138bc75d-0d04-0410-961f-82ee72b054a4
      690f1a75
  36. 10 Nov, 2004 1 commit
  37. 09 Nov, 2004 1 commit
    • ebotcazou's avatar
      PR target/18230 · 14935712
      ebotcazou authored
      	* doc/md.texi (SPARC constraints): Document 'Y' constraint.
      	* config/sparc/sparc-modes.def: Add vector modes of 4 and 8 bytes.
      	* config/sparc/sparc.c (sparc_vector_mode_supported_p): New function.
      	(TARGET_VECTOR_MODE_SUPPORTED_P): Set to sparc_vector_mode_supported_p.
      	(fp_zero_operand): Accept MODE_VECTOR_INT modes.
      	(input_operand): Accept CONST_VECTOR with MODE_VECTOR_INT modes.
      	(sparc_cannot_force_const_mem): Return false for CONST_VECTOR.
      	(sparc_init_modes): Set sparc_mode_class to SF_MODE or DF_MODE for
      	MODE_VECTOR_INT modes.
      	(sparc_extra_constraint_check): Add new constraint 'Y'.
      	* config/sparc/sparc.h: Define UNITS_PER_SIMD_WORD to 8 for TARGET_VIS.
      	* config/sparc/sparc.md (V32): New mode macro for 32-bit modes.
      	(V64): New mode macro for 64-bit modes.
      	(movsf): Use V32 for mode instead of SF.
      	(movsf_insn_vis): Use V32 for mode instead of SF.  Add 'Y' constraint
      	alongside 'G' constraint.
      	(movdf): Use V64 for mode instead of DF.
      	(movdf_insn_v9only_vis, modf_insn_sp64_vis): Use V64 for mode instead
      	of DF.  Add 'Y' constraint alongside 'G' constraint.
      	(multi-isn and misaligned mems DFmode splitters): Use V64 for mode
      	instead of DF.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@90348 138bc75d-0d04-0410-961f-82ee72b054a4
      14935712