- 11 Apr, 1997 4 commits
-
-
From-SVN: r13859
Doug Evans committed -
From-SVN: r13858
Doug Evans committed -
* m32r/m32r.h (UPPER16_P): Fix calculation. * m32r/m32r.c (two_insn_const_operand): New function. (m32r_print_operand): Handle 'X'. * m32r/m32r.md (movsi): Tweak. (*movsi_insn): Output hex value of constants too. (movsi define_split): Add. (andsi3,orsi3,xorsi3): Output hex value of constants too. From-SVN: r13857
Doug Evans committed -
<niklas@appli.se>) From-SVN: r13849
Ian Lance Taylor committed
-
- 10 Apr, 1997 1 commit
-
-
(sne+1): New define_split for new sne pattern. From-SVN: r13848
Jim Wilson committed
-
- 09 Apr, 1997 2 commits
-
-
If size is negative, negate and subtract it instead of adding it. From-SVN: r13847
Jim Wilson committed -
make sure the stack is aligned at all times. From-SVN: r13846
Joern Rennecke committed
-
- 08 Apr, 1997 1 commit
-
-
* mn10300.h (RETURN_ADDR_RTX): Define. * mn10300.c (count_tst_insns): New function. (expand_prologue): Load zero into data and/or address registers if any are free and the function has optimizable tst insns. (output_tst): If a suitable register is known to have the value zero, use it instead of searching for a suitable register. * mn10300.h (zero_dreg, zero_areg): Declare. (FRAME_POINTER_NEEDED): Frame pointers are not needed if the outgoing argument size is zero. * mn10300.md (movXX): Optimize loading zero i register if possible. Optimize loading a DF/DI mode value into an address register from a constant memory address. (addsi3): Provide alternative which doesn't require a matching inout operand. (return): Optimize consecutive return instructions. From-SVN: r13845
Jeff Law committed
-
- 07 Apr, 1997 4 commits
-
-
From-SVN: r13844
Doug Evans committed -
(CC1_SPEC): Add subtarget_cc1_spec. (EXTRA_SPECS): Add subtarget_cc1_spec. From-SVN: r13843
Joern Rennecke committed -
(STARTFILE_SPEC, LINK_SPEC): Support -static. From-SVN: r13842
Joern Rennecke committed -
(LINK_SPEC, STARTFILE_SPEC): Support -static. From-SVN: r13841
Joern Rennecke committed
-
- 06 Apr, 1997 2 commits
-
-
(incscc): Use a match_operand with cc_register to match the condition code register. (decscc, *condbranch, *condbranch_reversed, *mov_scc): Likewise. (*mov_negscc, *mov_notscc, *cond_return): Likewise. (*cond_return_inverted, *ior_scc, *cond_move): Likewise. (insv): New expand. (andsi_notsi_si): Renamed from *andsi_notsi_si. (andsi_not_shiftsi_si): New insn. (*minmax_arithsi): Don't match this insn if operand1 is an eliminable register. ({sin,cos}*): Delete, since the ARM always emulates these its faster to call a library function. (movsicc, *movsicc_insn): Make operand0 an s_register_operand, and operand3 an arm_not_operand. Use cc_register to match the condition code register. (mov[sd]fcc*): Make operand[0,2] s_register_operands, and operand3 the nonmemory_operand. Use cc_register to match the condition code register. (*ifcompare_plus_move): Move before *ifcompare_arith_move. Just do a split for the output. (*ifcompare_move_plus): Similarly, but relative to *ifcompare_move_arith. (*if_plus_move, *if_move_plus): New patterns. (*ifcompare_arith_arith): Simplify the alternatives down to just one, and split the insn before output. (*if_arith_arith, *if_arith_move, *if_move_arith): New patterns. (*ifcompare_move_not, *ifcompare_not_move): Simplify and split the insn before output. (*if_move_not, *if_not_move): New patterns. (*ifcompare_shift_move, *ifcompare_move_shift): Simplify and split the insn before output. (*if_shift_move, *if_move_shift): New patterns. (*ifcompare_shift_shift): Simplify and split the insn before output. (*if_shift_shift): New pattern. (*ifcompare_not_arith, *ifcompare_arith_not): Simplify and split the insn before output. (*if_not_arith, *if_arith_not): New patterns. (*ifcompare_neg_move, *ifcompare_move_neg): Simplify and split the insn before output. (*if_neg_move, *if_move_neg): New patterns.. From-SVN: r13840
Richard Earnshaw committed -
From-SVN: r13839
Michael Meissner committed
-
- 03 Apr, 1997 6 commits
-
-
From-SVN: r13838
Jim Wilson committed -
mn10300.c (can_use_return_insn): Add size of fixed stack space for function calls into the size of the frame. * mn10300.c (can_use_return_insn): Add size of fixed stack space for function calls into the size of the frame. */ (expand_prologue, expand_epilogue): Likewise. (initial_offset): Corresponding changes.. * mn10300.h (OUTGOING_REG_PARM_STACK_SPACE): No longer define. (STACK_POINTER_OFFSET): Define. * mn10300.md (call, call_value expanders): Don't adjust the stack pointer here anymore. * mn10300.md (ashlsi3): Remove some alternatives which are no longer needed or desired. From-SVN: r13837
Jeff Law committed -
multi-reg hard register. From-SVN: r13836
Jim Wilson committed -
each dynamic parameter type. From-SVN: r13835
Jim Wilson committed -
LABEL_REF, and CONST operands. From-SVN: r13834
Jim Wilson committed -
From-SVN: r13833
Jim Wilson committed
-
- 02 Apr, 1997 6 commits
-
-
From-SVN: r13832
Michael Meissner committed -
From-SVN: r13831
Mike Stump committed -
libgcc2.c (find_exception_table): Fix to logic to deal with functions that are in their own section... * libgcc2.c (find_exception_table): Fix to logic to deal with functions that are in their own section, such as template instantiations, that cause overlapping EH tables. From-SVN: r13830
Mike Stump committed -
From-SVN: r13829
Jeff Law committed -
From-SVN: r13828
Jeff Law committed -
* ginclude/stdarg.h: Include va-mn10300.h. * ginclude/varargs.h: Likewise. * ginclude/va-mn10300.h: New file. * mn10300/mn10300.c (expand_prologue): If current_function_varargs is nonzero, then flush d0/d1 back into the stack. (mn10300_builtin_saveregs): New function. (function_arg, function_arg_partial_nregs): New functions. (initial_offset): Tweak now that the RP save area is allocated and deallocated around each call again. * mn10300/mn10300.h (FIRST_PARM_OFFSET): Now 4. (FRAME_POINTER_REQUIRED): Require a frame pointer for all non-leaf functions. (REG_PARM_STACK_SPACE): Now 8 bytes. (FUNCTION_ARG_REGNO_P): Update for new parameter passing conventions. (CUMULATIVE_ARGS, INIT_CUMULATIVE_ARGS): Likewise. (FUNCTION_ARG_ADVANCE, FUNCTION_ARG): Likewise. (FUNCTION_ARG_PARTIAL_NREGS): Likewise. (TRAMPOLINE_TEMPLATE): Don't clobber d0 anymore. (TRAMPOLINE_SIZE, INITIALIZE_TRAMPOLINE): Corresponding changes. (EXPAND_BUILTIN_SAVEREGS): Define. * mn10300/mn10300.md (call, call_value patterns): Allocate and deallocate a stack slot for the return pointer around each call. * mn10300/mn10300.h (RTX_COSTS): Refine. (CASE_VALUES_THRESHHOLD, NO_FUNCTION_CSE): Likewise. * mn10300/mn10300.c (output_tst): New function. * mn10300/mn10300.md (movdi, movdf): Improve code to load constants into registers. (tst insns): Use output_tst to optimize some cases. Add versions to encourage more zero extensions instead of sign extensions of HImode and QImode values. (divsi3, udivsi3): Remove patterns. Replaced by... (divmodsi4, udivmodsi4): New expanders/patterns. (andsi3): Optimize "and" operations with certain constants. From-SVN: r13827
Jeff Law committed
-
- 01 Apr, 1997 2 commits
-
-
From-SVN: r13826
Jeff Law committed -
From-SVN: r13825
Joern Rennecke committed
-
- 28 Mar, 1997 12 commits
-
-
From-SVN: r13824
Doug Evans committed -
* toplev.c (branch_prob_dump, profile_arc_flag, flag_test_coverage, flag_branch_probabilities, branch_prob_dump_file, branch_prob_time): New variables. (f_options): Add profile-arcs, test-coverage, and branch-probabilities. (compile_file): Set branch_prob_time. Pass flag_test_coverage to init_emit_once. Handle branch_prob_dump. Call init_branch_prob. Call end_branch_prob. Call output_func_start_profiler. (rest_of_compilation): Handle branch_prob_dump. Call new branch_prob pass. (main): Set branch_prob_dump. From-SVN: r13823
Doug Evans committed -
* sched.c (update_flow_info): Handle REG_EXEC_COUNT and REG_BR_PROB notes. From-SVN: r13822
Doug Evans committed -
* rtl.c (note_insn_name): Add NOTE_REPEATED_LINE_NUMBER. (reg_note_name): Add REG_BR_PROB and REG_EXEC_COUNT. From-SVN: r13821
Doug Evans committed -
* rtl.h (enum reg_note): Add REG_BR_PROB and REG_EXEC_COUNT. (REG_BR_PROB_BASE): Define. (NOTE_REPEATED_LINE_NUMBER): Define. From-SVN: r13820
Doug Evans committed -
* reorg.c (mostly_true_jump): Use REG_BR_PROB notes when flag_branch_probabilities. From-SVN: r13819
Doug Evans committed -
From-SVN: r13818
Doug Evans committed -
jump.c (jump_optimize, [...]): Disable some optimizations when flag_test_coverage and there is a line number... * jump.c (jump_optimize, follow_jumps, mark_jump_label): Disable some optimizations when flag_test_coverage and there is a line number note in the way. (invert_jump): Add REG_BR_PROB when flag_branch_probabililties. From-SVN: r13817
Doug Evans committed -
* integrate.c (expand_inline_function): Output NOTE_REPEATED_LINE_NUMBER after inlined call. From-SVN: r13816
Doug Evans committed -
* function.c (expand_function_end): Output NOTE_REPEATED_LINE_NUMBER for last line of function. From-SVN: r13815
Doug Evans committed -
* flags.h (profile_arc_flag, flag_test_coverage, flag_branch_probabilities): Declare. From-SVN: r13814
Doug Evans committed -
* final.c (LONG_TYPE_SIZE): Define. (count_instrumented_arcs): New variable. (end_final, profile_after_prologue, leaf_function_p): Add support for profile_arc_flag. (add_bb): Only call CC_STATUS_INIT if HAVE_cc0. From-SVN: r13813
Doug Evans committed
-