Michael Meissner
07e6159a93
Add -mcpu={604e,801,823} support
...
From-SVN: r13901
1997-04-14 19:04:40 +00:00
Jim Wilson
9a893315ea
(get_last_value_validate): New argument insn.
...
Add check for memory reference clobbered by later store.
(record_value_for_reg, get_last_values): Pass in new argument.
From-SVN: r13900
1997-04-14 11:46:37 -07:00
Ian Lance Taylor
ba325ebaef
When clobbering a reg, check for later words of a multi word reg value
...
From-SVN: r13899
1997-04-14 01:03:03 +00:00
Doug Evans
a22ad97227
calls.c (expand_call): When copying unaligned values into a register...
...
* calls.c (expand_call): When copying unaligned values into a register,
zero out the register first rather than emitting a clobber.
From-SVN: r13898
1997-04-13 23:30:18 +00:00
Doug Evans
58a32c5c03
* expr.c (move_block_from_reg): Try using an integral mov operation first.
...
From-SVN: r13897
1997-04-13 23:29:50 +00:00
Ian Lance Taylor
ad5780142a
Get the modes right when setting reg_values for a reg to reg copy
...
From-SVN: r13896
1997-04-13 22:45:30 +00:00
Doug Evans
3e42d56b4b
integrate.c (copy_rtx_and_substitute): If FRAME_GROWS_DOWNWARD and regno == VIRTUAL_STACK_VARS_REGNUM...
...
* integrate.c (copy_rtx_and_substitute): If FRAME_GROWS_DOWNWARD
and regno == VIRTUAL_STACK_VARS_REGNUM, round size of stack slot up
before calling assign_stack_temp.
From-SVN: r13895
1997-04-13 21:24:37 +00:00
Richard Kenner
53c87bfd9c
(ASM_SPEC): Define.
...
(STRUCT_VALUE_REGNUM, STATIC_CHAIN_REGNUM, INITIALIZE_TRAMPOLINE):
Remove definitions, undoing the change of Mar 20 1996.
From-SVN: r13894
1997-04-13 15:34:53 -04:00
Richard Kenner
75ef7cf8da
(fake_f_rep): Add missing element name in cast.
...
From-SVN: r13893
1997-04-13 15:29:35 -04:00
Richard Kenner
d9d08379df
(layout_record, PCC_BITFIELD_TYPE_MATTERS): Fix sign bug in last change.
...
From-SVN: r13892
1997-04-13 15:20:03 -04:00
Richard Kenner
3879920c64
(output_move_qimode): Optimize pushing one byte if the source operand
...
does not use the stack pointer.
From-SVN: r13891
1997-04-13 15:15:21 -04:00
Richard Kenner
5716e64528
(movstricthi): Remove extraneous comparisons.
...
From-SVN: r13890
1997-04-13 15:04:36 -04:00
Richard Kenner
67cbb7a7d4
Initial revision
...
From-SVN: r13889
1997-04-13 15:02:08 -04:00
Richard Kenner
5887325513
(canon_reg, cse_insn): Don't examine insn_n_dups if recog_memoized
...
fails to find a match.
From-SVN: r13888
1997-04-13 14:51:22 -04:00
Richard Kenner
cfb3ee16db
(do_include): Diagnose #import and #include_next if pedantic and if not in a system header.
...
(do_include): Diagnose #import and #include_next if pedantic and if
not in a system header.
(do_warning): #warning now causes an error if -pedantic-errors is
given; this is needed since #warning isn't ANSI.
From-SVN: r13887
1997-04-13 14:30:13 -04:00
Ian Lance Taylor
31418d3513
Remove REG_DEAD notes when eliminating a set in the reload CSE pass
...
From-SVN: r13886
1997-04-13 18:20:27 +00:00
Richard Kenner
c7063b9a37
(fatal_perror, fatal, collect_wait): Use FATAL_EXIT_CODE.
...
From-SVN: r13885
1997-04-13 14:19:48 -04:00
Richard Kenner
1f0fcca5be
(print_usage, open_files): Use FATAL_EXIT_CODE.
...
From-SVN: r13884
1997-04-13 14:19:11 -04:00
Richard Kenner
920b13cc7e
(L_bb, L_exit): Use 0 rather than NULL for null pointers.
...
From-SVN: r13883
1997-04-13 14:12:05 -04:00
Richard Kenner
6780a54b7d
(rotl[shq]i3, rotl[hq]i3+1): Don't directly modify operand.
...
From-SVN: r13882
1997-04-13 13:17:56 -04:00
Richard Kenner
3ff78fe33a
(tstdi): Add missing parallel around the pattern.
...
From-SVN: r13881
1997-04-13 12:53:00 -04:00
Richard Kenner
c9666c0180
(cpp_lex) New arg skip_evaluation.
...
(cpp_parse_expr): Pass skip_evaluation to cpp_lex.
Abort if cpp_lex returns NAME.
(cpp_lex): Optionally warn about undefined identifiers that evaluate to 0.
From-SVN: r13880
1997-04-13 12:50:58 -04:00
Richard Kenner
dfb45725c9
(cpp_handle_options): Set warn_undef from -Wundef and -Wno-undef.
...
From-SVN: r13879
1997-04-13 12:50:30 -04:00
Richard Kenner
6ac34fdc71
(struct cpp_options): New member warn_undef.
...
(CPP_WARN_UNDEF): New macro.
From-SVN: r13878
1997-04-13 12:50:11 -04:00
Richard Kenner
69375a37de
cexp.y (warn_undef): New variable.
...
(exp): Optionally warn about undefined identifiers that evaluate to 0.
From-SVN: r13877
1997-04-13 12:49:45 -04:00
Richard Kenner
10c1b9f689
(warn_undef): New variable.
...
(main): Set warn_undef from -Wundef and -Wno-undef.
From-SVN: r13876
1997-04-13 12:49:07 -04:00
Richard Kenner
dab9b3bf3d
(c_decode_option): Ignore -Wundef, -Wno-undef.
...
From-SVN: r13875
1997-04-13 12:47:53 -04:00
Richard Kenner
c7710c1f46
(lang_options): Add -Wundef, -Wno-undef.
...
From-SVN: r13874
1997-04-13 12:47:38 -04:00
Richard Kenner
977cc2e118
Formerly cpp.texi.~30~
...
From-SVN: r13873
1997-04-13 12:47:14 -04:00
Richard Kenner
e5bad25ee5
Fix typo in comment.
...
From-SVN: r13872
1997-04-13 11:44:17 -04:00
Richard Kenner
9758e89fa8
Initial revision
...
From-SVN: r13871
1997-04-13 11:43:08 -04:00
Richard Kenner
a68b98cf6d
(lookup_field): Don't recurse unless FIELD is a RECORD_TYPE or
...
UNION_TYPE.
From-SVN: r13870
1997-04-13 10:59:54 -04:00
Richard Kenner
06140bdfa1
(validate_replace_rtx_1, case MINUS): New case.
...
From-SVN: r13869
1997-04-13 09:48:25 -04:00
Richard Kenner
eead6b5bda
(*return_addsi): Change condition to exclude both ints.
...
(*return_adddi): Likewise.
(*return_subsi): New pattern.
From-SVN: r13868
1997-04-13 09:47:25 -04:00
Richard Kenner
7c03e72e04
Clean up copyright notice.
...
From-SVN: r13867
1997-04-13 09:47:11 -04:00
Richard Kenner
4bf7135b9b
(eligible_for_delay_slot): Clean up and make to agree precisely with
...
patterns in MD file.
From-SVN: r13866
1997-04-13 09:46:34 -04:00
Richard Kenner
0b73ca18ad
(profile_function): Save the static chain register around the call to
...
the profiler function.
From-SVN: r13865
1997-04-13 08:44:41 -04:00
Richard Kenner
9886e013fd
(TARGET_VERSION): Redefine.
...
From-SVN: r13864
1997-04-13 08:20:20 -04:00
Richard Kenner
8dddd002b0
(reload): If function has nonlocal label, mark all caller-saved regs
...
as used.
From-SVN: r13863
1997-04-13 08:15:28 -04:00
Richard Kenner
1f027d54a1
(invariant_p, case REG): Pointers into frame are not invariants if
...
function has nonlocal gotos.
From-SVN: r13862
1997-04-13 08:15:13 -04:00
Doug Evans
51a96571d6
Delete some FIXMEs.
...
From-SVN: r13861
1997-04-11 21:14:47 +00:00
Doug Evans
efbbf34f32
Delete some FIXMEs.
...
From-SVN: r13860
1997-04-11 21:08:57 +00:00
Doug Evans
715af0cb5a
Delete "FIXME".
...
From-SVN: r13859
1997-04-11 21:03:35 +00:00
Doug Evans
9fd54896c1
(REG_ALLOC_ORDER): Restore to original setting.
...
From-SVN: r13858
1997-04-11 20:52:56 +00:00
Doug Evans
4d6c607f2e
m32r.h (UPPER16_P): Fix calculation.
...
* 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
1997-04-11 20:48:54 +00:00
Ian Lance Taylor
4e007b6eea
Recognize OpenBSD systems correctly (from Niklas Hallqvist
...
<niklas@appli.se>)
From-SVN: r13849
1997-04-11 20:40:28 +00:00
Jim Wilson
8bca10f462
(sne): Modified to use negc instead of xor.
...
(sne+1): New define_split for new sne pattern.
From-SVN: r13848
1997-04-10 15:39:01 -07:00
Jim Wilson
f3cd53755b
(output_stack_adjust): Reorganize code for readability.
...
If size is negative, negate and subtract it instead of adding it.
From-SVN: r13847
1997-04-09 15:44:46 -07:00
Joern Rennecke
20ec31d305
(output_stack_adjust): When splitting an adjustment into two parts,
...
make sure the stack is aligned at all times.
From-SVN: r13846
1997-04-09 18:50:38 +01:00
Jeff Law
74452ac323
mn10300.h (RETURN_ADDR_RTX): Define.
...
* 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
1997-04-08 12:41:49 -06:00