1. 15 May, 2004 1 commit
    • rearnsha's avatar
      * arm.h (TARGET_APCS_32): Delete. · c1a66faf
      rearnsha authored
      (TARGET_MMU_TRAPS): Delete.
      (TARGET_CPU_CPP_BUILTINS): Unconditionally define __APCS_32__.  Never
      define __APCS_26__.
      (CPP_SPEC): Remove checking of -mapcs-{26,32}.
      (ARM_FLAG_APCS_32, ARM_FLAG_MMU_TRAPS): Delete.
      (TARGET_SWITCHES): Remove alignment_traps and apcs-{26,32} switches.
      (prog_mode_type): Delete.
      (PROMOTE_MODE): Always promote unsigned for HImode.
      (SECONDARY_INPUT_RELOAD_CLASS): Simplify.
      (MASK_RETURN_ADDR): Simplify.
      * arm.c (arm_prgmode): Delete.
      (arm_override_options, arm_gen_rotated_half_load): Simplify.
      (print_multi_reg, output_return_instruction): Simplify.
      (arm_output_epilogue, arm_final_prescan_insn): Simplify.
      (arm_return_addr): Simplify.
      * arm.md (prog_mode): Delete.
      (conds): Simplify.
      (zero_extendhisi2, extendhisi2, movhi, movhi_bytes): Simplify.
      (rotated_loadsi, movhi_insn_littleend, movhi_insn_bigend): Delete.
      (loadhi_si_bigend, loadhi_preinc, loadhi_shiftpreinc): Delete.
      (loadhi_shiftpredec): Delete.
      (peephole for post-increment on HImode load): Delete.
      * arm/crtn.asm: (FUNC_END): Simplify.
      * arm/lib1funcs.asm: Remove APCS-26 return macros.
      * arm/aof.h, arm/coff.h arm/elf.h arm/linux-elf.h arm/netbsd-elf.h
      * arm/netbsd.h arm/pe.h arm/semi.h arm/semiaof.h arm/unknown-elf.h
      * arm/vxworks.h arm/wince-pe.h: Tidy TARGET_DEFAULTS and
      MULTILIB_DEFAULTS as required.
      * arm/t-arm-elf arm/t-linux arm/t-pe arm/t-semi arm/t-wince-pe
      * arm/t-xscale-coff arm/t-xscale-elf arm/uclinux-elf: Tidy MULTILIB
      variables as required.
      * doc/invoke.texi (ARM Options): Remove obsolete flags.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@81881 138bc75d-0d04-0410-961f-82ee72b054a4
      c1a66faf
  2. 24 Mar, 2004 1 commit
    • pbrook's avatar
      * config.gcc <arm>: Add --with-abi= · f9273c43
      pbrook authored
      	* config/arm/arm-protos.h (arm_get_frame_size, thumb_get_frame_size,
      	thumb_far_jump_used): Remove prototypes.
      	(arm_needs_doubleword_align): Add prototype.
      	(thumb_compute_initial_elimination_offset): Ditto.
      	* config/arm/arm.c (arm_get_frame_offsets): New function.
      	(use_return_insn, output_return_instruction, arm_output_epilogue,
      	arm_output_function_epilogue, arm_compute_initial_elimination_offset,
      	arm_expand_prologue, thumb_expand_epilogue): Use it.
      	(arm_abi, target_abi_name, all_arm_abis): New variables.
      	(arm_override_options): Set them.  Set structure padding for AAPCS.
      	(arm_return_in_memory): Update ABI check.
      	(arm_init_cumulative_args): Initialize can_split.
      	(arm_needs_doubleword_align): New function.
      	(arm_function_arg): Don't split args after pushing to stack. Handle
      	doubleword/even reg alignment.
      	(arm_va_arg): Handle all doubleword aligned args.
      	(add_minpoolforward ref, dump_minpool, push_minpool_fix): Align based
      	on ABI, not CPU.
      	(arm_compute_save_reg0_reg12_mask): Fix comment.
      	(thumb_get_frame_size, thumb_get_frame_size): Remove.
      	(thumb_jump_far_used_p): Remove superfluous argument.  Return save
      	value for alignment.
      	(thumb_unexpanded_epilogue, thumb_output_function_prologue): Change
      	to match.
      	(thumb_compute_initial_elimination_offset): New function.
      	(thumb_expand_prologue): Use arm_get_frame_offsets.  Remove
      	unneccessary rounding.
      	* config/arm/arm.h (target_abi_name): Declare.
      	(ARM_DOUBLEWORD_ALIGN, DOUBLEWORD_ALIGNMENT, TARGET_IWMMXT_ABI,
      	arm_abi_type, ARM_DEFAULT_ABI): Define.
      	(ARM_FLAG_ATPCS): Remove.
      	(TARGET_OPTIONS, OPTION_DEFAULT_SPECS): Add -mabi=.
      	(BIGGEST_ALIGNMENT, PREFERRED_STACK_BOUNDARY, STACK_BOUNDARY): Use it.
      	(ADJUST_FIELD_ALIGN, DATA_ALIGNMENT, LOCAL_ALIGNMENT,
      	TYPE_NEEDS_IWMMXT_ALIGNMENT): Remove.
      	(LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P, FUNCTION_ARG_REGNO_P):
      	Contitionalize on ABI, not CPU.
      	(struct arm_stack_offsets): Define.
      	(struct machine_function): Add stack_offsets.  Remove frame_size.
      	(FUNCTION_ARG_PARTIAL_NREGS): Don't split if previous args have been
      	pushed.
      	(FUNCTION_ARG_ADVANCE, FUNCTION_ARG_BOUNDARY): Handle general
      	doubleword alignment.
      	(THUMB_INITIAL_ELIMINATION_OFFSET,
      	ARM_INITIAL_ELIMINATION_OFFSET): Remove.
      	(INITIAL_ELIMINATION_OFFSET): Call functions directly.
      	* config/arm/arm.md (align_8): Enable for all targets.
      	* config/arm/netbsd-elf.h (TARGET_DEFAULT): Remove TARGET_ATPCS.
      	(ARM_DEFAULT_ABI): Define.
      	* doc/invoke.texi <ARM>: Document -mabi=. Update documentation for
      	-mstructure-size-boundary.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@79921 138bc75d-0d04-0410-961f-82ee72b054a4
      f9273c43
  3. 05 Mar, 2004 1 commit
  4. 04 Feb, 2004 1 commit
    • kazu's avatar
      gcc/ · 0364c2b4
      kazu authored
      	* alloc-pool.h, c-convert.c, c-lang.c, c-tree.h,
      	caller-save.c, df.h, genconfig.c, global.c, lcm.c,
      	ra-rewrite.c, ra.c, regclass.c, regs.h, resource.c,
      	sched-rgn.c, config/arm/aof.h, config/arm/cirrus.md,
      	config/arm/fpa.md, config/arm/iwmmxt.md,
      	config/arm/netbsd-elf.h, config/arm/netbsd.h,
      	config/m68hc11/m68hc11.md, config/mips/iris5.h,
      	config/mn10300/mn10300.md, config/rs6000/altivec.md,
      	config/sparc/netbsd-elf.h: Update copyright.
      
      	cp/
      	* error.c, search.c: Update copyright.
      
      	java/
      	* typeck.c: Update copyright.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@77265 138bc75d-0d04-0410-961f-82ee72b054a4
      0364c2b4
  5. 03 Feb, 2004 1 commit
    • pbrook's avatar
      Merge from csl-arm-branch. · a2cd141b
      pbrook authored
      	2004-01-30  Paul Brook  <paul@codesourcery.com>
      
      	* aof.h (REGISTER_NAMES): Add vfp reg names
      	(ADDITIONAL_REGISTER_NAMES): Ditto.
      	* aout.h (REGISTER_NAMES): Ditto.
      	(ADDITIONAL_REGISTER_NAMES): Ditto.
      	* arm-protos.h: Update/Add Prototypes.
      	* arm.c (init_fp_table): Rename from init_fpa_table. Update users.
      	Only allow 0.0 for VFP.
      	(fp_consts_inited): Rename from fpa_consts_inited.  Update users.
      	(values_fp): Rename from values_fpa.  Update Users.
      	(arm_const_double_rtx): Rename from const_double_rtx_ok_for_fpa.
      	Update users.  Only check valid constants for this hardware.
      	(arm_float_rhs_operand): Rename from fpa_rhs_operand.  Update Users.
      	Only allow consts for FPA.
      	(arm_float_add_operand): Rename from fpa_add_operand.  Update users.
      	Only allow consts for FPA.
      	(use_return_insn): Check for saved VFP regs.
      	(arm_legitimate_address_p): Handle VFP DFmode addressing.
      	(arm_legitimize_address): Ditto.
      	(arm_general_register_operand): New function.
      	(vfp_mem_operand): New function.
      	(vfp_compare_operand): New function.
      	(vfp_secondary_reload_class): New function.
      	(arm_float_compare_operand): New function.
      	(vfp_print_multi): New function.
      	(vfp_output_fstmx): New function.
      	(vfp_emit_fstm): New function.
      	(arm_output_epilogue): Output VPF reg restore code.
      	(arm_expand_prologue): Output VFP reg save code.
      	(arm_print_operand): Add 'P'.
      	(arm_hard_regno_mode_ok): Return modes for VFP regs.
      	(arm_regno_class): Return classes for VFP regs.
      	(arm_compute_initial_elimination_offset): Include space for VFP regs.
      	(arm_get_frame_size): Ditto.
      	* arm.h (FIXED_REGISTERS): Add VFP regs.
      	(CALL_USED_REGISTERS): Ditto.
      	(CONDITIONAL_REGISTER_USAGE): Enable VFP regs.
      	(FIRST_VFP_REGNUM): Define.
      	(LAST_VFP_REGNUM): Define.
      	(IS_VFP_REGNUM): Define.
      	(FIRST_PSEUDO_REGISTER): Include VFP regs.
      	(HARD_REGNO_NREGS): Handle VFP regs.
      	(REG_ALLOC_ORDER): Add VFP regs.
      	(enum reg_class): Add VFP_REGS.
      	(REG_CLASS_NAMES): Ditto.
      	(REG_CLASS_CONTENTS): Ditto.
      	(CANNOT_CHANGE_MODE_CLASS) Handle VFP Regs.
      	(REG_CLASS_FROM_LETTER): Add 'w'.
      	(EXTRA_CONSTRAINT_ARM): Add 'U'.
      	(EXTRA_MEMORY_CONSTRAINT): Define.
      	(SECONDARY_OUTPUT_RELOAD_CLASS): Handle VFP regs.
      	(SECONDARY_INPUT_RELOAD_CLASS): Ditto.
      	(REGISTER_MOVE_COST): Ditto.
      	(PREDICATE_CODES): Add arm_general_register_operand,
      	arm_float_compare_operand and vfp_compare_operand.
      	* arm.md (various): Rename as above.
      	(divsf3): Enable when TARGET_VFP.
      	(divdf3): Ditto.
      	(movdfcc): Ditto.
      	(sqrtsf2): Ditto.
      	(sqrtdf2): Ditto.
      	(arm_movdi): Disable when TARGET_VFP.
      	(arm_movsi_insn): Ditto.
      	(movsi): Only split with general regs.
      	(cmpsf): Use arm_float_compare_operand.
      	(push_fp_multi): Restrict to TARGET_FPA.
      	(vfp.md): Include.
      	* vfp.md: New file.
      	* fpa.md (various): Rename as above.
      	* doc/md.texi: Document ARM w and U constraints.
      
      	2004-01-15  Paul Brook  <paul@codesourcery.com>
      
      	* config.gcc: Add with_fpu.  Allow with-float=softfp.
      	* config/arm/arm.c (arm_override_options): Rename *-s to *s.
      	Break out of loop when we find a float-abi.  Fix typo.
      	* config/arm/arm.h (OPTION_DEFAULT_SPECS): Add "fpu".
      	Set -mfloat-abi=.
      	* doc/install.texi: Document --with-fpu.
      
      	2003-01-14  Paul Brook  <paul@codesourcery.com>
      
      	* config.gcc (with_arch): Add armv6.
      	* config/arm/arm.h: Rename TARGET_CPU_*_s to TARGET_CPU_*s.
      	* config/arm/arm.c (arm_overrride_options): Ditto.
      
      	2004-01-08  Richard Earnshaw  <rearnsha@arm.com>
      
      	* arm.c (FL_ARCH3M): Renamed from FL_FAST_MULT.
      	(FL_ARCH6): Renamed from FL_ARCH6J.
      	(arm_arch3m): Renamed from arm_fast_multiply.
      	(arm_arch6): Renamed from arm_arch6j.
      	* arm.h: Update all uses of above.
      	* arm-cores.def: Likewise.
      	* arm.md: Likewise.
      
      	* arm.h (CPP_CPU_ARCH_SPEC): Emit __ARM_ARCH_6J__ define for armV6j,
      	not arm6j.  Add entry for arch armv6.
      
      	2004-01-07  Richard Earnshaw  <rearnsha@arm.com>
      
      	* arm.c (arm_emit_extendsi): Delete.
      	* arm-protos.h (arm_emit_extendsi): Delete.
      	* arm.md (zero_extendhisi2): Also handle zero-extension of
      	non-subregs.
      	(zero_extendqisi2, extendhisi2, extendqisi2): Likewise.
      	(thumb_zero_extendhisi2): Only match if not v6.
      	(arm_zero_extendhisi2, thumb_zero_extendqisi2, arm_zero_extendqisi2)
      	(thumb_extendhisi2, arm_extendhisi2, arm_extendqisi)
      	(thumb_extendqisi2): Likewise.
      	(thumb_zero_extendhisi2_v6, arm_zero_extendhisi2_v6): New patterns.
      	(thumb_zero_extendqisi2_v6, arm_zero_extendqisi2_v6): New patterns.
      	(thumb_extendhisi2_insn_v6, arm_extendhisi2_v6): New patterns.
      	(thumb_extendqisi2_v6, arm_extendqisi_v6): New patterns.
      	(arm_zero_extendhisi2_reg, arm_zero_extendqisi2_reg): Delete.
      	(arm_extendhisi2_reg, arm_extendqisi2_reg): Delete.
      	(arm_zero_extendhisi2addsi): Remove subreg.  Add attributes.
      	(arm_zero_extendqisi2addsi, arm_extendhisi2addsi): Likewise.
      	(arm_extendqisi2addsi): Likewise.
      
      	2003-12-31  Mark Mitchell  <mark@codesourcery.com>
      
      	Revert this change:
      	* config/arm/arm.h (THUMB_LEGTITIMIZE_RELOAD_ADDRESS): Reload REG
      	+ REG addressing modes.
      
      	* config/arm/arm.h (THUMB_LEGTITIMIZE_RELOAD_ADDRESS): Reload REG
      	+ REG addressing modes.
      
      	2003-12-30  Mark Mitchell  <mark@codesourcery.com>
      
      	* config/arm/arm.h (THUMB_LEGITIMATE_CONSTANT_P): Accept
      	CONSTANT_P_RTX.
      
      	2003-30-12  Paul Brook  <paul@codesourcery.com>
      
      	* longlong.h: protect arm inlines with !defined (__thumb__)
      
      	2003-30-12  Paul Brook  <paul@codesourcery.com>
      
      	* config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Always define __arm__.
      
      	2003-12-30  Nathan Sidwell  <nathan@codesourcery.com>
      
      	* builtins.c (expand_builtin_apply_args_1): Fix typo in previous
      	change.
      
      	2003-12-29  Nathan Sidwell  <nathan@codesourcery.com>
      
      	* builtins.c (expand_builtin_apply_args_1): Add pretend args size
      	to the virtual incoming args pointer for downward stacks.
      
      	2003-12-29  Paul Brook  <paul@codesourcery.com>
      
      	* config/arm/arm-cores.def: Add cost function.
      	* config/arm/arm.c (arm_*_rtx_costs): New functions.
      	(arm_rtx_costs): Remove
      	(struct processors): Add rtx_costs field.
      	(all_cores, all_architectures): Ditto.
      	(arm_override_options): Set targetm.rtx_costs.
      	(thumb_rtx_costs): New function.
      	(arm_rtx_costs_1): Remove cases handled elsewhere.
      	* config/arm/arm.h (processor_type): Add COSTS parameter.
      
      	2003-12-29  Nathan Sidwell  <nathan@codesourcery.com>
      
      	* config/arm/arm.md (generic_sched): arm926 has its own scheduler.
      	(arm926ejs.md): Include it.
      	* config/arm/arm926ejs.md: New pipeline description.
      
      	2003-12-24  Paul Brook  <paul@codesourcery.com>
      
      	* config/arm/arm.c (arm_arch6j): New variable.
      	(arm_override_options): Set it.
      	(arm_emit_extendsi): New function.
      	* config/arm/arm-protos.h (arm_emit_extendsi): Add prototype.
      	* config/arm/arm.h (arm_arch6j): Declare.
      	* config/arm/arm.md: Add sign/zero extend insns.
      
      	2003-12-23  Paul Brook  <paul@codesourcery.com>
      
      	* config/arm/arm.c (all_architectures): Add armv6.
      	* doc/invoke.texi: Document it.
      
      	2003-12-19  Paul Brook  <paul@codesourcery.com>
      
      	* config/arm/arm.md: Add load1 and load_byte "type" attrs.  Modify
      	insn patterns to match.
      	* config/arm/arm-generic.md: Ditto.
      	* config/arm/cirrus.md: Ditto.
      	* config/arm/fpa.md: Ditto.
      	* config/amm/iwmmxt.md: Ditto.
      	* config/arm/arm1026ejs.md: Ditto.
      	* config/arm/arm1135jfs.md: Ditto.  Add insn_reservation and bypasses
      	for 11_loadb.
      
      	2003-12-18  Nathan Sidwell  <nathan@codesourcery.com>
      
      	* config/arm/arm-protos.h (arm_no_early_alu_shift_value_dep): Declare.
      	* config/arm/arm.c (arm_adjust_cost): Check shift cost for
      	TYPE_ALU_SHIFT and TYPE_ALU_SHIFT_REG.
      	(arm_no_early_store_addr_dep, arm_no_early_alu_shift_dep,
      	arm_no_early_mul_dep): Correctly deal with conditional execution,
      	parallels and single shift operations.
      	(arm_no_early_alu_shift_value_dep): Define.
      	* arm.md (attr type): Replace 'normal' with 'alu',
      	'alu_shift' and 'alu_shift_reg'.
      	(attr core_cycles): Adjust.
      	(*addsi3_carryin_shift, andsi_not_shiftsi_si, *arm_shiftsi3,
      	*shiftsi3_compare0, *notsi_shiftsi, *notsi_shiftsi_compare0,
      	*not_shiftsi_compare0_scratch, *cmpsi_shiftsi, *cmpsi_shiftsi_swp,
      	*cmpsi_neg_shiftsi, *arith_shiftsi, *arith_shiftsi_compare0,
      	*arith_shiftsi_compare0_scratch, *sub_shiftsi,
      	*sub_shiftsi_compare0, *sub_shiftsi_compare0_scratch,
      	*if_shift_move, *if_move_shift, *if_shift_shift): Set type
      	attribute appropriately.
      	* config/arm/arm1026ejs.md (alu_op): Adjust.
      	(alu_shift_op, alu_shift_reg_op): New.
      	* config/arm/arm1136.md: Add better bypasses for early
      	registers. Remove load[234] and store[234] bypasses.
      	(11_alu_op): Adjust.
      	(11_alu_shift_op, 11_alu_shift_reg_op): New.
      
      	2003-12-15  Nathan Sidwell  <nathan@codesourcery.com>
      
      	* config/arm/arm-protos.h (arm_no_early_store_addr_dep,
      	arm_no_early_alu_shift_dep, arm_no_early_mul_dep): Declare.
      	* config/arm/arm.c (arm_no_early_store_addr_dep,
      	arm_no_early_alu_shift_dep, arm_no_early_mul_dep): Define.
      	* config/arm/arm1026ejs.md: Add load-store bypass.
      	* config/arm/arm1136jfs.md (11_alu_op): Take 2 cycles.
      	Add bypasses between instructions.
      
      	2003-12-10  Paul Brook  <paul@codesourcery.com>
      
      	* config/arm/arm.c (arm_fpu_model): New variable.
      	(arm_fload_abi): New variable.
      	(target_fpe_name): Rename from target_fp_name.
      	(target_fpu_name): New variable.
      	(arm_is_cirrus): Remove.
      	(fpu_desc): New struct.
      	(all_fpus): Define.
      	(pf_model_for_fpu): Define.
      	(all_loat_abis): Define.
      	(arm_override_options): Set fp arch flags based on -mfpu=
      	and -float-abi=.
      	(FIRST_FPA_REGNUM): Rename from FIRST_ARM_FP_REGNUM.
      	(LAST_FPA_REGNUM): Rename from LAST_ARM_FP_REGNUM.
      	(*): Use new TARGET_* flags.
      	* config/arm/arm.h (TARGET_ANY_HARD_FLOAT): Remove.
      	(TARGET_HARD_FLOAT): No longer implies TARGET_FPA.
      	(TARGET_SOFT_FLOAT): Ditto.
      	(TARGET_SOFT_FLOAT_ABI): New.
      	(TARGET_MAVERICK): Rename from TARGET_CIRRUS.  No longer implies
      	TARGET_HARD_FLOAT.
      	(TARGET_VFP): No longer implies TARGET_HARD_FLOAT.
      	(TARGET_OPTIONS): Add -mfpu=.
      	(FIRST_FPA_REGNUM): Rename from FIRST_ARM_FP_REGNUM.
      	(LAST_FPA_REGNUM): Rename from LAST_ARM_FP_REGNUM.
      	(arm_pf_model): Define.
      	(arm_float_abi_type): Define.
      	(fputype): Add FPUTYPE_VFP.  Change SOFT_FPA->NONE
      	* config/arm/arm.md: Use new TARGET_* flags.
      	* config/arm/cirrus.md: Ditto.
      	* config/arm/fpa.md: Ditto.
      	* config/arm/elf.h (ASM_SPEC): Pass -mfloat-abi= and -mfpu=.
      	* config/arm/semi.h (ASM_SPEC): Ditto.
      	* config/arm/netbsd-elf.h (SUBTARGET_ASM_FLOAT_SPEC): Specify vfp.
      	(FPUTYPE_DEFAULT): Set to VFP.
      	* doc/invoke.texi: Document -mfpu= and -mfloat-abi=.
      
      	2003-11-22  Phil Edwards  <phil@codesourcery.com>
      
      	PR target/12476
      	* config/arm/arm.c (arm_output_mi_thunk):  In Thumb mode, use
      	'bx' instead of 'b' to avoid branch range restrictions.  Output
      	the thunk immediately before the thunked-to function.
      	* config/arm/arm.h (ARM_DECLARE_FUNCTION_NAME):  Do not emit
      	.thumb_func if a thunk is being generated.  Emit .code 16 along
      	with .thumb_func if a thunk is not being generated.
      
      	2003-11-15  Nicolas Pitre <nico@cam.org>
      
      	* config/arm/arm.md (ashldi3, arm_ashldi3_1bit, ashrdi3,
      	arm_ashrdi3_1bit, lshrdi3, arm_lshrdi3_1bit): New patterns.
      	* config/arm/iwmmxt.md (ashrdi3_iwmmxt): Renamed from ashrdi3.
      	(lshrdi3_iwmmxt): Renamed from lshrdi3.
      	* config/arm/arm.c (IWMMXT_BUILTIN2): Renamed argument accordingly.
      
      	2003-11-12  Steve Woodford  <scw@wasabisystems.com>
      	    Ian Lance Taylor  <ian@wasabisystems.com>
      
      	* config/arm/lib1funcs.asm (ARM_DIV_BODY, ARM_MOD_BODY): Add new
      	code for __ARM_ARCH__ >= 5 && ! defined (__OPTIMIZE_SIZE__).
      
      	2003-11-05  Phil Edwards  <phil@codesourcery.com>
      
      	* config/arm/arm.md (insn):  Add new V6 instruction names.
      	(generic_sched):  New attr.
      	* config/arm/arm-generic.md:  Use generic_sched here.
      	* config/arm/arm1026ejs.md:  Do not model fetch/issue/decode
      	stages of pipeline.  Adjust latency counts accordingly.
      	* config/arm/arm1136jfs.md:  New file.
      
      	2003-10-28  Mark Mitchell  <mark@codesourcery.com>
      
      	* config/arm/arm.h (processor_type): New enumeration type.
      	(CPP_ARCH_DEFAULT_SPEC): Set appropriately for ARM 926EJ-S,
      	ARM1026EJ-S, ARM1136J-S, and ARM1136JF-S processor cores.
      	(CPP_CPU_ARCH_SPEC): Likewise.
      	* config/arm/arm.c (arm_tune): New variable.
      	(all_cores): Use cores.def.
      	(all_architectures): Add representative processor.
      	(arm_override_options): Restructure way in which tuning
      	information is deduced.
      	* arm.md: Update "insn" and "type" attributes throughout.
      	(insn): New attribute.
      	(type): Compute "mult" from "insn" attribute.  Add load2,
      	load3, load4 alternatives.
      	(arm automaton): Move to arm-generic.md.
      	* config/arm/arm-cores.def: New file.
      	* config/arm/arm-generic.md: Likewise.
      	* config/arm/arm1026ejs.md: Likewise.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@77171 138bc75d-0d04-0410-961f-82ee72b054a4
      a2cd141b
  6. 01 Feb, 2004 1 commit
    • kazu's avatar
      * config/arm/arm.c, config/arm/arm.h, config/arm/arm.md, · 1a83b3ff
      kazu authored
      	config/arm/linux-gas.h, config/arm/netbsd-elf.h,
      	config/arm/netbsd.h, config/arm/pe.c, config/avr/avr.c,
      	config/avr/avr.h, config/avr/avr.md, config/c4x/c4x.h,
      	config/cris/cris.h, config/fr30/fr30.h, config/frv/frv.c,
      	config/frv/frv.h, config/ip2k/ip2k.c, config/iq2000/iq2000.c,
      	config/iq2000/iq2000.h, config/m32r/m32r.c,
      	config/m68hc11/m68hc11.c, config/m68hc11/m68hc11.h,
      	config/m68hc11/m68hc11.md, config/m68k/m68k.md,
      	config/mcore/mcore.c, config/mcore/mcore.h,
      	config/mcore/mcore.md, config/mips/mips.c,
      	config/ns32k/ns32k.h, config/ns32k/ns32k.md,
      	config/rs6000/rs6000.c, config/s390/s390.c,
      	config/s390/s390.md, config/sparc/sparc.c, config/v850/v850.c,
      	config/xtensa/xtensa.h, config/xtensa/xtensa.md: Replace
      	"gen_rtx (FOO, " with "gen_rtx_FOO (".
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@77080 138bc75d-0d04-0410-961f-82ee72b054a4
      1a83b3ff
  7. 19 Jun, 2003 1 commit
    • zack's avatar
      * target.h (asm_out.file_start, file_start_app_off, · 92c473b8
      zack authored
      	file_start_file_directive): New hooks.
      	* target-def.h (TARGET_ASM_FILE_START_FILE_DIRECTIVE,
      	TARGET_ASM_FILE_START_APP_OFF, TARGET_ASM_FILE_START):
      	New hook-definition macros.
      	* doc/tm.texi: Document new hooks; remove docs of ASM_FILE_START.
      	* varasm.c (default_file_start): New.
      	* output.h: Prototype it.
      	* toplev.c (init_asm_output): Use targetm.asm_out.file_start.
      	* system.h: Poison ASM_FILE_START.
      
      	* config/alpha/alpha.c (alpha_write_verstamp): Delete.
      	(alpha_file_start): New, define if !TARGET_ABI_UNICOSMK.
      	(unicosmk_asm_file_start): Rename unicosmk_file_start,
      	make static, take no arguments.
      	(TARGET_ASM_FILE_START, TARGET_ASM_FILE_END,
      	TARGET_ASM_FILE_START_FILE_DIRECTIVE): Set as appropriate.
      	* config/alpha/unicosmk.h: Don't define ASM_FILE_START nor
      	TARGET_ASM_FILE_END.  Remove reference to ASM_FILE_START in
      	comment.
      	* config/arc/arc.c (arc_asm_file_start): Rename
      	arc_file_start, take no arguments, make static.
      	(TARGET_ASM_FILE...
      92c473b8
  8. 03 Jun, 2003 1 commit
    • jakub's avatar
      * configure.in (HAVE_LD_PIE): Check for ld -pie. · c3ce66b0
      jakub authored
      	* config.in: Rebuilt.
      	* configure: Rebuilt.
      	* toplev.c (flag_pie, flag_shlib): New variables.
      	(f_options): Add -fpie and -fPIE.
      	(parse_options_and_default_flags): Set flag_pic if -fpie/-fPIE.
      	Set flag_shlib if flag_pic and not -fpie/-fPIE.
      	* flags.h (flag_pic, flag_shlib): Add.
      	* varasm.c (default_binds_local_p): Use flag_shlib instead of
      	flag_pic.
      	* gcc.c (LINK_PIE_SPEC): Define.
      	(LINK_COMMAND_SPEC): Use LINK_PIE_SPEC.
      	(option_map): Add --pie -> -pie mapping.
      	* config/sol2.h (ASM_SPEC): Handle -fpie the same way as -fpic
      	and -fPIE the same way as -fPIC.
      	* config/openbsd.h (ASM_SPEC): Likewise.
      	* config/frv/frv.h (ASM_SPEC): Likewise.
      	* config/arm/linux-gas.h (SUBTARGET_CPP_SPEC): Likewise.
      	* config/arm/semi.h (ASM_SPEC): Likewise.
      	* config/arm/netbsd-elf.h (SUBTARGET_EXTRA_ASM_SPEC): Likewise.
      	* config/freebsd-spec.h (FBSD_CPP_SPEC): Likewise.
      	* config/i386/beos-elf.h (CC1_SPEC): Likewise.
      	* config/i386/freebsd-aout.h (ASM_SPEC): Likewise.
      	* config/m68k/linux.h (CPP_SPEC): Likewise.
      	* config/m68k/netbsd.h (ASM_SPEC): Likewise.
      	* config/m68k/openbsd.h (ASM_SPEC): Likewise.
      	* config/m68k/netbsd-elf.h (ASM_SPEC): Likewise.
      	* config/mips/linux.h (SUBTARGET_CPP_SPEC): Likewise.
      	* config/mips/openbsd.h (SUBTARGET_ASM_SPEC): Likewise.
      	* config/pa/pa-linux.h (CPP_SPEC): Likewise.
      	* config/netbsd-aout.h (ASM_SPEC): Likewise.
      	* config/rs6000/sysv4.h (ASM_SPEC, CPP_SYSV_SPEC): Likewise.
      	* config/rs6000/vxworks.h (CPP_SPEC): Likewise.
      	* config/sparc/linux.h (CPP_SUBTARGET_SPEC, ASM_SPEC): Likewise.
      	* config/sparc/linux64.h (CPP_SUBTARGET_SPEC, ASM_SPEC): Likewise.
      	* config/sparc/sparc.h (ASM_SPEC): Likewise.
      	* config/sparc/sp64-elf.h (ASM_SPEC): Likewise.
      	* config/sparc/sysv4.h (ASM_SPEC): Likewise.
      	* config/sparc/netbsd-elf.h (ASM_SPEC): Likewise.
      	* config/sparc/openbsd64.h (ASM_SPEC): Likewise.
      	* config/cris/linux.h (CRIS_ASM_SUBTARGET_SPEC): Likewise.
      	* config/linux.h (STARTFILE_SPEC, ENDFILE_SPEC): Handle -pie.
      	Simplify.
      	* config/alpha/elf.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
      	* config/i386/linux64.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
      	* config/ia64/linux.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
      	* config/rs6000/sysv4.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
      	* config/rs6000/linux64.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
      	* config/sparc/linux.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
      	* config/sparc/linux64.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
      	* doc/invoke.texi: Document -pie, -fpie and -fPIE options.
      
      
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@67359 138bc75d-0d04-0410-961f-82ee72b054a4
      c3ce66b0
  9. 10 Feb, 2003 1 commit
  10. 31 Jan, 2003 1 commit
  11. 21 Nov, 2002 1 commit