1 Fri Dec 19 09:32:57 1997 Jeffrey A Law (law@cygnus.com)
3 * stmt.c (expand_asm_operands): If an ASM has no outputs, then treat
6 Wed Dec 3 01:13:45 1997 Jeffrey A Law (law@cygnus.com)
8 * version.c: Update for egcs-1.0 release.
10 Mon Dec 1 15:36:13 1997 Jeffrey A Law (law@cygnus.com)
12 * version.c: Bump for snapshot.
14 Tue Nov 25 14:08:12 1997 Jim Wilson <wilson@cygnus.com>
16 * mips.md (fix_truncdfsi2, fix_truncsfsi2, fix_truncdfdi2,
17 fix_truncsfdi2): Change *.
19 Sun Nov 30 19:59:20 1997 Jason Merrill <jason@yorick.cygnus.com>
21 * stmt.c (expand_decl_cleanup): Update thisblock after eh_region_start.
23 Sat Nov 29 12:44:57 1997 David Edelsohn <edelsohn@mhpcc.edu>
25 * rs6000.c (function_arg_partial_nregs): Undo Nov. 26 patch.
27 * rs6000/aix41.h (ASM_CPU_SPEC): Define.
29 Fri Nov 28 10:00:27 1997 Jeffrey A Law (law@cygnus.com)
31 * sh/elf.h (PREFERRED_DEBUGGING_TYPE): Prefer stabs again.
33 * arm.md (movsfcc, movdfcc): Fix "patch" lossage.
35 * configure.in: Fix NCR entries.
37 Thu Nov 27 12:20:19 1997 Jeffrey A Law (law@cygnus.com)
39 * version.c: Bump for snapshot.
41 * flow.c (find_basic_blocks): Handle cfg issues for rethrows and
42 nested exceptions correctly.
44 * unroll.c (find_splittable_givs): Don't split givs with a dest_reg
45 that was created by loop.
47 Thu Nov 27 09:34:58 1997 Jason Merrill <jason@yorick.cygnus.com>
49 * expr.c (preexpand_calls): Don't look past a TRY_CATCH_EXPR.
51 * except.c (expand_start_all_catch): One more do_pending_stack_adjust.
53 Thu Nov 27 09:32:39 1997 Richard Earnshaw (rearnsha@arm.com)
55 * arm.md (movsfcc): If not TARGET_HARD_FLOAT, ensure operand[3]
58 Wed Nov 26 13:04:46 1997 Michael Meissner <meissner@cygnus.com>
60 * rs6000.c (SMALL_DATA_REG): Register to use for small data relocs.
61 (print_operand): Use SMALL_DATA_REG for the register involved in
62 small data relocations.
63 (print_operand_address): Ditto.
65 * rs6000/linux.h (LINK_SPEC): Pass -dynamic-linker /lib/ld.so.1 if
66 -dynamic linker is not used.
68 * rs6000.md (call insns): For local calls, use @local suffix under
69 System V. Don't use @plt under Solaris.
71 * rs6000.c (output_function_profiler): Put label address in r0, and
72 store LR in 4(sp) for System V/eabi.
74 * rs6000.h (ASM_OUTPUT_REG_{PUSH,POP}): Keep stack aligned to 16
75 byte boundary, and maintain stack backchain.
77 (patches originally from Geoffrey Keating)
78 * rs6000.c (function_arg): Excess floating point arguments don't
79 go into GPR registers after exhausting FP registers under the
81 (function_arg_partial_nregs): Ditto.
83 * rs6000.md (call insns): If -fPIC or -mrelocatable, add @plt
86 Wed Nov 26 13:04:46 1997 Jason Merrill <jason@yorick.cygnus.com>
88 * toplev.c (main): Complain about -gdwarfn.
90 Tue Nov 25 22:43:30 1997 Jason Merrill <jason@yorick.cygnus.com>
92 * dwarf2out.c (outout_call_frame_info): Ensure that the info has
95 * libgcc2.c (__throw): Initialize HANDLER.
97 * dwarfout.c (output_type): If finalizing, write out nested types
98 of types we've already written.
100 Tue Nov 25 10:00:42 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
102 * sh/elf.h (PREFERRED_DEBUGGING_TYPE): Undefine before including
105 * sh/elf.h (PREFERRED_DEBUGGING_TYPE): Don't redefine.
107 * sh/elf.h (HANDLE_SYSV_PRAGMA): Undefine.
109 * sh/elf.h: (LINK_SPEC): Use shlelf.
110 (USER_LABEL_PREFIX, LOCAL_LABEL_PREFIX, ASM_FILE_START): Redefine.
112 * sh.h: dwarf patches from Fred Fish.
114 * va-sh.h (__va_arg_sh1): Define.
116 SH3E doesn't use any integer registers for subsequent arguments
117 once a non-float value was passed in the stack.
118 * sh.h (PASS_IN_REG_P): Fix SH3E case.
120 Tue Nov 25 10:00:42 1997 Richard Henderson (rth@cygnus.com)
122 * alpha.h (CONST_OK_FOR_LETTER): Fix 'L' handling.
124 Tue Nov 25 10:00:42 1997 Jeffrey A Law (law@cygnus.com)
126 * configure.in (alphaev56*-*-*): Disable MASK_BYTE_OPS until
127 ev56 support works correctly.
129 * crtstuff.c (do_global_dtors_aux): Handle multiple calls better.
131 Sun Nov 23 13:01:48 1997 Jeffrey A Law (law@cygnus.com)
133 * version.c: Bump for snapshot.
135 Sat Nov 22 18:58:20 1997 Jeffrey A Law (law@cygnus.com)
137 * pa-hpux10.h (NEW_HP_ASSEMBLER): Define.
138 * pa.h (LEGITIMATE_CONSTANT_P): Reject LABEL_REFs if not using
139 gas and not using the new HP assembler.
141 Fri Nov 21 15:20:05 1997 Jeffrey A Law (law@cygnus.com)
143 * Makefile.in (program_transform_cross_name): Clean up "-e" confusion.
144 (GCC_INSTALL_NAME, GCC_CROSS_NAME): Likewise.
146 * i386.h (TARGET_CMOV): Disable conditional moves for this release.
148 Fri Nov 21 12:18:51 1997 Jason Merrill <jason@yorick.cygnus.com>
150 * except.h: Add outer_context_label_stack.
151 * except.c: Likewise.
152 (expand_start_all_catch): Push the outer_context for the try block
153 onto outer_context_label_stack.
154 (expand_end_all_catch): Use it and pop it.
156 Fri Nov 21 10:13:11 1997 Robert Lipe (robertl@dgii.com)
158 * i386/sco5.h (HAVE_ATEXIT): Revert last change.
160 Thu Nov 20 16:11:50 1997 Richard Henderson <rth@cygnus.com>
162 * alpha.c (alpha_emit_set_const_1): Handle narrow hosts better.
164 Thu Nov 20 16:11:50 1997 Klaus Kaempf <kkaempf@progis.de>
166 * alpha/vms.h (ASM_OUTPUT_ADDR_VEC_ELT): Add an L for the local label
167 to correspond with the change to ASM_GENERATE_INTERNAL_LABEL.
169 Thu Nov 20 14:42:15 1997 Jason Merrill <jason@yorick.cygnus.com>
171 * except.c (output_exception_table): Don't bother with
174 Thu Nov 20 16:11:50 1997 Jeffrey A Law (law@cygnus.com)
176 * pa.md (pre_stwm, post_stwm, pre_ldwm, post_ldwm): Base register
177 is an in/out operand.
178 (zero extended variants of stwm/stwm patterns): Similarly.
180 * mips/x-iris (FIXPROTO_DEFINES): Add -D_SGI_SOURCE.
182 Thu Nov 20 13:19:32 1997 Jason Merrill <jason@yorick.cygnus.com>
184 * dwarf2out.c (ASM_OUTPUT_DWARF_OFFSET4): Rename from VALUE4.
186 (ASM_OUTPUT_DEFINE_LABEL_DIFFERENCE_SYMBOL): Use assemble_name.
187 (output_call_frame_info): Emit a \n after using it.
189 Thu Nov 20 00:38:46 1997 Dave Love <d.love@dl.ac.uk>
191 * configure.in: Add AC_ARG_ENABLE for Haifa as documentation.
193 Wed Nov 19 12:03:04 1997 Philippe De Muyter <phdm@macqel.be>
195 * dwarf2out.c (CIE_LENGTH_LABEL, FDE_LENGTH_LABEL): New macros.
196 (ASM_OUTPUT_DWARF_VALUE4): New macro.
197 (ASM_OUTPUT_DEFINE_LABEL_DIFFERENCE_SYMBOL): Define if SET_ASM_OP is
199 (output_call_frame_info): Do not output forward label differences
200 if ASM_OUTPUT_DEFINE_LABEL_DIFFERENCE_SYMBOL is defined.
201 * m68k/mot3300.h (SET_ASM_OP): Define when not using gas.
203 Tue Nov 18 22:50:24 1997 Jim Wilson <wilson@cygnus.com>
205 * mips/mips.c (save_restore_insns): If gp_offset or fp_offset are
206 large_int, emit two insns instead of one splitable insn.
207 * dwarf2out.c (dwarf2out_frame_debug): When set cfa_store_offset
208 from cfa_temp_value, use cfa_offset. Abort if cfa_reg is not SP.
210 Fri Nov 7 15:33:11 1997 Robert Lipe (robertl@dgii.com)
212 * i386/sco5.h (HAVE_ATEXIT): Delete definition.
214 Sun Nov 16 23:52:48 1997 Jeffrey A Law (law@cygnus.com)
216 * cse.c (cse_insn): Don't look at JUMP_LABEL field of a conditionl
218 (cse_end_of_basic_block): Similarly.
220 Sun Nov 16 23:01:40 1997 J. Kean Johnston <jkj@sco.com>
222 * i386/sco5.h (ASM_OUTPUT_ALIGNED_BSS): Define.
223 (SELECT_RTX_SECTION): Define.
224 (LIBGCC_SPEC, LIB_SPEC): Do the right thing for PIC.
226 Sun Nov 16 22:47:03 1997 Manfred Hollstein <manfred@s-direktnet.de>
228 * Makefile.in (compare, compare-lean): Define $stage for each
230 (gnucompare, gnucompare-lean): Likewise.
232 Sun Nov 16 22:02:16 1997 Richard Henderson (rth@cygnus.com)
234 * alpha/win-nt.h (TRAMPOLINE_TEMPLATE): Fix offsets.
236 * alpha.h (ASM_OUTPUT_ADDR_DIFF_ELT): Add an L for the local label
237 to correspond with the change to ASM_GENERATE_INTERNAL_LABEL.
239 Fri Nov 14 08:01:25 1997 Jeffrey A Law (law@cygnus.com)
241 * version.c: Bump for snapshot.
243 1997-11-14 Paul Eggert <eggert@twinsun.com>
245 Fix some confusion with IEEE minus zero.
247 * real.h (REAL_VALUES_IDENTICAL): New macro.
249 * expr.c (is_zeros_p): Don't consider -0.0 to be all zeros.
250 * fold-const.c (operand_equal_p): Don't consider -0.0 to be
252 * tree.c (simple_cst_equal): Don't consider -0.0 to have the
253 same tree structure as 0.0.
255 * varasm.c (immed_real_const_1): Use new REAL_VALUES_IDENTICAL
256 macro instead of doing it by hand.
258 Fri Nov 14 07:24:20 1997 Richard Henderson <rth@cygnus.com>
260 * expr.c (expand_builtin_setjmp): Set
261 current_function_has_nonlocal_label.
262 * stupid.c (stupid_life_analysis): If has_nonlocal_label, kill
263 call-saved registers across calls.
265 * alpha.md (exception_receiver): Remove.
266 (nonlocal_goto_receiver_osf): New
267 (nonlocal_goto_receiver_vms): Renamed from nonlocal_goto_receiver.
268 (nonlocal_goto_receiver): New, select _osf or _vms.
270 * alpha.c (output_prolog [*]): Prefix entry labels with '$' to
271 keep them from being propogated to the object file.
272 (alpha_write_linkage): Likewise.
273 * alpha.md (call_vms): Likewise.
274 (call_value_vms): Likewise.
275 (unnamed osf call insns): Likewise.
277 * alpha.h (ASM_OUTPUT_INTERNAL_LABEL): Don't omit L from local label.
278 (ASM_GENERATE_INTERNAL_LABEL): Likewise.
280 * alpha.c (call_operand): Any reg is valid for WinNT.
281 * alpha.md (call_nt, call_value_nt): Don't force address into $27.
282 (anon nt calls): Add 'R' alternative.
283 * alpha/win-nt.h (TRAMPOLINE_TEMPLATE, TRAMPOLINE_SIZE,
284 INITIALIZE_TRAMPOLINE): Handle lack of original $27 and 32-bit ptrs.
286 Thu Nov 13 12:53:44 1997 Jim Wilson <wilson@cygnus.com>
288 * mips.h (GO_IF_LEGITIMATE_ADDRESS): Delete code swapping xplus0 and
289 xplus1 when xplus0 is not a register.
291 Thu Nov 13 11:51:32 1997 David Edelsohn <edelsohn@mhpcc.edu>
293 * rs6000.md (lshrdi3_power): Delete '&' from first alternative and
294 swap instruction order.
296 Thu Nov 13 11:47:55 1997 Michael Meissner <meissner@cygnus.com>
298 * rs6000.c (num_insns_constant): Use REAL_VALUE_FROM_CONST_DOUBLE to
299 pick apart floating point values, instead of using CONST_DOUBLE_LOW
300 and CONST_DOUBLE_HIGH.
302 * rs6000.md (define_splits for DF constants): Use the appropriate
303 REAL_VALUE_* interface to pick apart DF floating point constants in
304 a machine independent fashion.
306 Thu Nov 13 11:41:42 1997 Jeffrey A Law (law@cygnus.com)
308 * flow.c (find_basic_blocks): During marking phase, if we encounter
309 an insn with a REG_LABEL note, make the target block live and
310 create an edge from the insn to the target block. Do not make
311 edges from all blocks to the target block.
313 * m68k/x-next (OTHER_FIXINCLUDES_DIRS): Include /NextDeveloper/Headers.
315 * configure.in: Tweak NCR entries.
316 * configure: Rebuilt.
318 Wed Nov 12 09:37:01 1997 Jeffrey A Law (law@cygnus.com)
320 * except.c: Do not include "assert.h".
321 (save_eh_status): Turn asserts into conditional aborts.
322 (restore_eh_status, scan_region): Likewise.
323 * dwarfout.c: Do not include "assert.h".
324 (bit_offset_attribute): Turn asserts into conditional aborts.
325 (bit_size_attribute, output_inlined_enumeration_type_die): Likewise.
326 (output_inlined_structure_type_die): Likewise.
327 (output_inlined_union_type_die): Likewise
328 (output_tagged_type_instantiation): Likewise.
329 (dwarfout_file_scope_decl): Likewise.
330 * dwarf2out.c: Do not include "assert.h"
331 (expand_builtin_dwarf_reg_size): Turn asserts into conditional aborts.
332 (reg_save, initial_return_save, dwarf2out_frame_debug): Likewise.
333 (add_child_die, modified_type_die, add_bit_offset_attribute): Likewise.
334 (add_bit_size_attribute, scope_die_for): Likewise.
335 (output_pending_types_for_scope): Likewise.
336 (get_inlined_enumeration_type_die): Likewise.
337 (get_inlined_structure_type_die): Likewise.
338 (get_inlined_union_type_die, gen_subprogram_die): Likewise.
339 (gen_tagged_type_instantiation_die): Likewise.
341 * flow.c (find_basic_blocks): Refine further to get a more correct
342 cfg, especially in the presense of exception handling, computed
343 gotos, and other non-trivial cases. Call abort if an inaccuracy
344 is detected in the cfg.
346 Mon Nov 10 03:02:19 1997 Jason Merrill <jason@yorick.cygnus.com>
348 * stmt.c (expand_decl_cleanup_no_eh): New fn.
350 * except.c (expand_leftover_cleanups): do_pending_stack_adjust.
352 Sun Oct 19 09:07:38 1997 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
354 * stmt.c (using_eh_for_cleanups_p): New variable.
355 (using_eh_for_cleanups): New function.
356 (expand_decl_cleanup): Don't call expand_eh_region_start_tree
357 unless using EH for cleanups.
359 Mon Nov 10 00:05:56 1997 Jeffrey A Law (law@cygnus.com)
361 * alias.c (MAX_ALIAS_LOOP_PASSES): Define.
362 (init_alias_analysis): Break out of loops after MAX_ALIAS_LOOP_PASSES.
364 Sun Nov 9 02:07:16 1997 Jeffrey A Law (law@cygnus.com)
366 * fixinc.svr4 (__STDC__): Add another case.
368 Sun Nov 9 02:00:29 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
370 * a29k.h (ELIGIBLE_FOR_EPILOGUE_DELAY): Avoid loads from varying
371 addresses in the epilogue delay slot.
373 Sun Nov 9 01:40:40 1997 Manfred Hollstein (manfred@s-direktnet.de)
375 * m88k/dgux.h (ASM_CPU_SPEC): Reformatted to suppress wrong whitespace
376 in generated `specs' file.
378 Fri Nov 7 16:23:20 1997 Jim Wilson (wilson@cygnus.com)
380 * flags.h (flag_rerun_loop_opt): Declare.
381 * loop.c (invariant_p, case LABEL_REF): Check flag_rerun_loop_opt.
382 * toplev.c (flag_rerum_loop_opt): Delete static.
384 Fri Nov 7 10:22:24 1997 Jason Merrill <jason@yorick.cygnus.com>
386 * frame.c (add_fdes, count_fdes): Go back to checking pc_begin for
389 Wed Nov 5 01:42:12 1997 Jeffrey A Law (law@cygnus.com)
391 * version.c: Bump for snapshot.
393 * alias.c (find_base_value): Only return the known base value for
396 Tue Nov 4 16:07:15 1997 Jeffrey A Law (law@cygnus.com)
398 * fixincludes: Fix "hypot" prototype in NeXT math.h.
400 * Makefile.in (USE_ALLOCA): Always include alloca.o.
401 (USE_HOST_ALLOCA): Likewise.
403 * alias.c (find_base_value): When copying arguments, return the
404 tenative value for a hard register.
406 Tue Nov 4 14:12:30 1997 Richard Henderson (rth@cygnus.com)
407 Jim Wilson (wilson@cygnus.com)
409 * alpha.c (summarize_insn): Handle ASM_OPERANDS. Don't recurse
410 for SUBREG, just fall through.
412 * alpha.c (alpha_handle_trap_shadows): Init sum.defd to zero.
414 * alpha.md (attr trap): Make TRAP_YES non-zero for sanity's sake.
416 * combine.c (try_combine): When setting elim_i1, check if newi2pat
419 * combine.c (try_combine): When setting elim_i2, check whether newi2pat
420 sets i2dest. When calling distribute_notes for i3dest_killed, pass
423 Mon Nov 3 14:36:50 1997 Jeffrey A Law (law@cygnus.com)
425 * configure.in (sco5): Use cpio to install header files.
427 Sun Nov 2 23:30:31 1997 Manfred Hollstein <manfred@s-direktnet.de>
429 * aclocal.m4 (conftestdata_from, conftestdata_to): Names shortened to
431 * configure: Rebuild.
433 Sun Nov 2 22:53:16 1997 Richard Earnshaw (rearnsha@arm.com)
435 * arm.c (load_multiple_sequence): Support SUBREG of MEM.
436 (store_multiple_sequence): Likewise.
438 Sun Nov 2 19:44:00 1997 Robert Lipe (robertl@dgii.com)
440 * i386/sco5.h: enable -gstabs once again.
442 Sun Nov 2 19:27:21 1997 Jeffrey A Law (law@cygnus.com)
444 * arm.c (output_move_double): Allocate 3 entries in otherops array.
446 Sat Nov 1 21:43:00 1997 Mike Stump (mrs@wrs.com)
448 * except.c (expand_ex_region_start_for_decl): Emit EH_REGION_BEG
449 notes for sjlj exceptions too.
450 (expand_eh_region_end): Similarly for EH_REGION_END notes.
451 (exception_optimize): Optimize EH regions for sjlj exceptions too.
452 * final.c (final_scan_insn): Don't output labels for EH REGION
453 notes if doing sjlj exceptions.
455 Sat Nov 1 19:15:28 1997 Jeffrey A Law (law@cygnus.com)
457 * alias.c (init_alias_analysis): Handle -fno-alias-check when
458 optimizing correctly.
460 * expr.c (expand_builtin_setjmp): Don't emit a SETJMP note
461 or set current_function_calls_setjmp anymore.
463 * flow.c (find_basic_blocks): If we delete the label for an
464 exception handler, remove it from the EH label list and remove
465 the EH_BEGIN/EH_END notes for that EH region.
467 Sat Nov 1 16:44:49 1997 Jason Merrill (jason@cygnus.com)
469 * flow.c (find_basic_blocks): Generate correct flow control
470 information when exception handling notes are present.
472 Sat Nov 1 13:42:19 1997 Jeffrey A Law (law@cygnus.com)
474 * dwarf2out.c (output_call_frame_info): Fix length argument
476 (output_die, output_pubnames, output_line_info): Likewise.
478 Fri Oct 31 07:10:09 1997 Jeffrey A Law (law@cygnus.com)
480 * version.c: Bump for snapshot.
482 * dwarf2out.c (output_call_frame_info): Use ASM_OUTPUT_ASCII to
483 output ASCII by default. Only use ASM_OUTPUT_DWARF_STRING if
484 flag_debug_asm is on.
485 (output_die, output_pubnames, output_line_info): Likewise.
487 * alias.c (init_alias_analysis): Add struct_value_incoming_rtx
488 and static_chain_rtx into the potential base values array if
491 * alias.c (new_reg_base_value): New array of potential base values.
492 (unique_id): Now file scoped static.
493 (find_base_value, case REG): Return the value in reg_base_value
494 array for the REG if it exists. Else, return the value from
495 new_reg_base_value if copying args and REG is a hard register.
496 (find_base_value, case PLUS): If either operand of the PLUS is
497 a REG, try to get its base value. Handle base + index and
499 (record_set): Use new_reg_base_value instead of reg_base_value.
500 (init_alias_analysis): Allocate space for new_reg_base_value too.
501 Rework code to iterate over the insns propagating base value
502 information until nothing changes.
504 * global.c (global_alloc): Free the conflict matrix after
507 Fri Oct 31 01:45:31 1997 Jason Merrill <jason@yorick.cygnus.com>
509 * libgcc2.c (L_eh): Define __eh_pc.
510 Replace __eh_type with generic pointer __eh_info.
512 Fri Oct 31 00:34:55 1996 J"orn Rennecke <amylaar@cygnus.co.uk>
514 * expr.c (expand_increment): When enqueing a postincrement for a MEM,
515 use copy_to_reg if address is not a general_operand.
517 Fri Oct 31 00:16:55 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
519 * profile.c (output_func_start_profiler): Clear flag_inline_functions
520 for the duration of the call to rest_of_compilation.
522 Thu Oct 30 14:40:10 1997 Doug Evans <devans@canuck.cygnus.com>
524 * configure.in (sparc-*-elf*): Use sparc/elf.h, sparc/t-elf.
526 (sparc*-*-*): Recognize --with-cpu=v9.
527 * sparc/elf.h: New file.
528 * sparc/t-elf: New file.
530 Thu Oct 30 13:26:12 1997 Jeffrey A Law (law@cygnus.com)
532 * mn10300.c (const_8bit_operand): New function.
533 (mask_ok_for_mem_btst): New funtion.
534 * mn10300.md (btst patterns with mem operands): Use new functions
535 to avoid creating btst instructions with invalid operands.
537 Wed Oct 29 16:57:19 1997 Michael Meissner <meissner@cygnus.com>
539 * rs6000/xm-sysv4.h: Include xm-linux.h instead of xm-svr4.h if we
540 are running on PowerPC Linux.
542 Wed Oct 29 13:10:11 1997 Gavin Koch <gavin@cygnus.com>
544 * config/mips/elf64.h (PREFERRED_DEBUGGING_TYPE): Only define
545 if not previously defined.
547 Tue Oct 28 23:55:27 1997 Doug Evans (devans@cygnus.com)
549 * function.c (assign_parms): Correct mode of stack_parm if
550 entry_parm underwent a mode conversion.
552 1997-10-28 Brendan Kehoe <brendan@lisa.cygnus.com>
554 * global.c (global_alloc): Use xmalloc instead of alloca for
555 CONFLICTS, since max_allocno * allocno_row_words alone can be more
556 than 2.5Mb sometimes.
558 Tue Oct 28 15:29:15 1997 Richard Henderson <rth@cygnus.com>
560 * reload1.c (eliminate_regs [SET]): If [SUBREG] widened the mode of
561 DEST for the spill, adjust mode of SRC to compensate.
563 Tue Oct 28 14:36:45 1997 Richard Henderson <rth@cygnus.com>
565 * alpha.md (reload_inqi): Check for MEM before strict_memory_address_p,
566 since any_memory_operand() allows pseudos during reload.
567 (reload_inhi, reload_outqi, reload_outhi): Likewise.
569 Tue Oct 28 11:53:14 1997 Jim Wilson <wilson@cygnus.com>
571 * m68k.md (btst patterns): Add 5200 support.
573 Tue Oct 28 11:58:40 1997 Toon Moene <toon@moene.indiv.nluug.nl>
575 * fold-const.c (fold): For ((a * C1) / C3) or (((a * C1) + C2) / C3)
576 optimizations, look inside dividend to determine if the expression
577 can be simplified by using EXACT_DIV_EXPR.
579 Tue Oct 28 10:19:01 1997 Jason Merrill <jason@yorick.cygnus.com>
582 * dwarf2out.c (output_call_frame_info): Use l1 instead of ".".
584 Tue Oct 28 00:32:14 1997 Richard Henderson <rth@cygnus.com>
586 * alpha.c (summarize_insn [SUBREG]): Propogate SET.
588 Mon Oct 27 23:59:26 1997 Richard Henderson <rth@cygnus.com>
590 * alpha.c (alpha_handle_trap_shadows): Don't call get_attr_trap
593 Mon Oct 27 21:25:20 1997 Richard Henderson <rth@cygnus.com>
595 * alpha.md (movqi, movhi): Make sure new insns created during reload
596 won't need reloading themselves.
597 (reload_inqi, reload_inhi, reload_outqi, reload_outhi): Likewise.
599 Mon Oct 27 16:11:10 1997 Jeffrey A Law (law@cygnus.com)
601 * mn10300.h (GO_IF_LEGITIMATE_ADDRESS): Disable reg+reg.
603 Sun Oct 26 13:50:44 1997 Richard Henderson <rth@cygnus.com>
605 * alpha.c (alpha_sa_mask [VMS]): Don't include $26 in the mask.
606 Patch from Klaus Kaempf <kkaempf@progis.de>.
608 Sun Oct 26 13:31:47 1997 Jim Wilson (wilson@cygnus.com)
610 * expr.c (expand_expr, case INDIRECT_REF): Optimize a reference
611 to an element in a constant string.
613 Sun Oct 26 11:41:49 1997 Jason Merrill <jason@yorick.cygnus.com>
615 * dwarf2out.c (output_call_frame_info): The CIE pointer is now a 32
616 bit PC-relative offset. The exception range table pointer is now in
618 * frame.c (dwarf_cie, dwarf_fde): Rename CIE_pointer to CIE_delta.
619 (count_fdes, add_fdes, get_cie): Adjust.
620 (cie_info, extract_cie_info, __frame_state_for): Adjust eh_ptr uses.
623 * frame.c (count_fdes, add_fdes): Skip linked once FDE entries.
625 Sun Oct 26 11:52:01 1997 Richard Henderson <rth@cygnus.com>
627 * alias.c (memrefs_conflict_p): Treat arg_pointer_rtx just
628 like stack_pointer_rtx.
630 Sun Oct 26 11:32:16 1997 Manfred Hollstein <manfred@s-direktnet.de>
632 * Makefile.in (bootstrap-lean): Combined with `normal' bootstrap
633 targets using "$@" to provide support for similar but not identical
634 targets without having to duplicate code.
635 (bootstrap4): New goal.
637 * Makefile.in (compare, compare-lean, compare3): Combined to one
638 ruleset determining actions to be performed via $@.
639 (compare4, compare4-lean): New targets.
640 (gnucompare, gnucompare3): Combined to one ruleset determining
641 actions to be performed via $@. Also, note which files failed
642 the comparison test in .bad_compare.
643 (gnucompare-lean, gnucompare3-lean, gnucompare4-lean): New targets.
645 Sun Oct 26 10:06:11 1997 Toon Moene <toon@moene.indiv.nluug.nl>
647 * fold-const (fold): Also simplify FLOOR_DIV_EXPR to EXACT_DIV_EXPR
648 if the dividend is a multiple of the divisor.
650 Sun Oct 26 09:21:40 1997 Jeffrey A Law (law@cygnus.com)
652 * Makefile.in (LIBGCC2_CFLAGS): Add -fexceptions.
654 * alias.c (find_base_term): Handle PRE_INC, PRE_DEC, POST_INC,
657 * alias.c (true_dependence): Fix typo.
659 * toplev.c (flag_rerun_loop_opt): New variable.
660 (f_options): Handle -frerun-loop-opt.
661 (rest_of_compilation): If -frerun-loop-opt, then run the loop
663 (main): Enable -frerun-loop-opt by default for -O2 or greater.
665 * loop.c (simplify_giv_expr): Adding two invariants results
668 Sun Oct 26 09:15:15 1997 Richard Henderson <rth@cygnus.com>
670 * expr.c (get_inner_reference): Remove the array bias after
671 converting the index to Pmode.
673 Sat Oct 25 12:20:58 1997 Jeffrey A Law (law@cygnus.com)
675 * mn10300.h (TARGET_SWITCHES): Add -mmult-bug and -mno-mult-bug.
676 (TARGET_MULT_BUG): Define.
677 (TARGET_DEFAULT): Default to TARGET_MULT_BUG.
678 * mn10300.md (mulsi3): Handle TARGET_MULT_BUG.
680 Fri Oct 24 17:40:34 1997 Jeffrey A Law (law@cygnus.com)
682 * mn10200.c (indirect_memory_operand): Delete unused function.
683 * mn10200.h (EXTRA_CONSTRAINT): Handle 'R'.
684 * mn10200.md (bset, bclr insns): Handle output in a reg too.
686 Fri Oct 24 15:54:57 1997 Richard Henderson <rth@cygnus.com>
688 * alpha.md (call patterns): Revert Oct 16 change; if we are to elide
689 the callee's ldgp, we must do it ourselves, and we use the jsr tag
690 for more than scheduling.
692 Fri Oct 24 13:23:04 1997 Doug Evans <devans@canuck.cygnus.com>
694 * sparc/sparc.h (ASM_SPEC): Delete asm_arch.
696 Fri Oct 24 13:19:40 1997 Jeffrey A Law (law@cygnus.com)
698 * mn10300.c (symbolic_operand, legitimize_address): New functions.
699 * mn10300.h (LEGITIMIZE_ADDRESS): Call legitimize_address.
700 (GO_IF_LEGITIMATE_ADDRESS): Don't allow base + symbolic.
702 Thu Oct 23 09:35:12 1997 Jeffrey A Law (law@cygnus.com)
704 * version.c: Bump for snapshot.
706 Thu Oct 23 08:03:59 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
708 * dbxout.c (dbxout_start_new_source_file): Use output_quoted_string
711 Wed Oct 22 00:34:12 1997 Jeffrey A Law (law@cygnus.com)
713 * toplev.c (flag_exceptions): Default value is 2.
714 (compile_file): If flag_exceptions still has the value 2, then
717 * rs6000.c (struct machine_function): Add pic_offset_table_rtx.
718 (rs6000_save_machine_status): Save pic_offset_table_rtx.
719 (rs6000_restore_machine_status: Restore pic_offset_table_rtx.
721 * local-alloc.c (block_alloc): Don't lose if two SCRATCH expressions
724 * rs6000.md (*movsi_got_internal_mem): New pattern.
725 (*movsi_got_internal_mem splitter): New define_split.
727 Tue Oct 21 18:14:03 1997 Jim Wilson <wilson@cygnus.com>
729 * obstack.h (obstack_empty_p): Fix spurious space after backslash.
731 Tue Oct 21 18:34:01 1997 Geoffrey KEATING <geoffk@ozemail.com.au>
733 * rs6000.c: Avoid creating a stack frame under SYSV ABI if we
734 only need to save LR.
736 Tue Oct 21 10:06:40 1997 Jeffrey A Law (law@cygnus.com)
738 * mn10300.md (movqi, movhi): Avoid using address registers as
739 destinations unless absolutely necessary.
741 * mn10200.c (expand_prologue): Fix typo.
743 * mn10200.h (GO_IF_LEGITIMATE_ADDRESS): Do not allow indexed
745 * mn10200.md (neghi2): Provide an alternative which works if
746 the input and output register are the same.
748 * mn10300.c (print_operand): Handle 'S'.
749 * mn10300.md (ashlsi3, lshrsi3, ashrsi3): Use %S for
750 shift amount in last alternative
752 * mn10300.c (expand_epilogue): Rework to handle register restores
753 in "ret" and "retf" instructions correctly.
755 Mon Oct 20 16:47:08 1997 Jim Wilson <wilson@cygnus.com>
757 * expmed.c (extract_bit_field): Don't make flag_force_mem disable
758 extzv for memory operands.
760 * cse.c (simplify_ternary_operation, case IF_THEN_ELSE): Collapse
761 redundant conditional moves to single operand.
763 Mon Oct 20 15:30:26 1997 Nick Clifton <nickc@cygnus.com>
765 * v850.h: Move define of __v850__ from CPP_PREDEFINES
768 * xm-v850.h: Use __v850 rather than __v850__ to
771 Mon Oct 20 14:15:02 1997 Jim Wilson <wilson@cygnus.com>
773 * mips/mips.c (compute_frame_size): Not a leaf function if
776 Mon Oct 20 14:16:38 1997 Geoffrey KEATING <geoffk@ozemail.com.au>
778 * rs6000/t-ppccomm: Use -msdata=none for crtstuff.
780 Mon Oct 20 12:28:17 1997 Doug Evans <devans@canuck.cygnus.com>
782 * sparc/sparc.h (SPARC_V9,SPARC_ARCH64): Delete.
783 (DEFAULT_ARCH32_P): New macro.
784 (TARGET_ARCH{32,64}): Allow compile time or runtime selection.
785 (enum cmodel): Declare.
786 (sparc_cmodel_string,sparc_cmodel): Declare.
787 (SPARC_DEFAULT_CMODEL): Provide default.
788 (TARGET_{MEDLOW,MEDANY}): Renamed to TARGET_CM_{MEDLOW,MEDANY}.
789 (TARGET_FULLANY): Deleted.
790 (TARGET_CM_MEDMID): New macro.
791 (CPP_CPU_DEFAULT_SPEC): Renamed from CPP_DEFAULT_SPEC.
792 (ASM_CPU_DEFAULT_SPEC): Renamed from ASM_DEFAULT_SPEC.
793 (CPP_PREDEFINES): Take out stuff now handled by %(cpp_arch).
795 (CPP_ARCH{,32,64,_DEFAULT}_SPEC): New macros.
796 (CPP_{ENDIAN,SUBTARGET}_SPEC): New macros.
797 (ASM_ARCH{,32,64,_DEFAULT}_SPEC): New macros.
798 (ASM_SPEC): Add %(asm_arch).
799 (EXTRA_SPECS): Rename cpp_default to cpp_cpu_default.
800 Rename asm_default to asm_cpu_default.
801 Add cpp_arch32, cpp_arch64, cpp_arch_default, cpp_arch, cpp_endian,
802 cpp_subtarget, asm_arch32, asm_arch64, asm_arch_default, asm_arch.
803 (NO_BUILTIN_{PTRDIFF,SIZE}_TYPE): Define ifdef SPARC_BI_ARCH.
804 ({PTRDIFF,SIZE}_TYPE): Provide 32 and 64 bit values.
805 (MASK_INT64,MASK_LONG64): Delete.
806 (MASK_ARCH64): Renamed to MASK_64BIT.
807 (MASK_{MEDLOW,MEDANY,FULLANY,CODE_MODEL}): Delete.
808 (EMBMEDANY_BASE_REG): Renamed from MEDANY_BASE_REG.
809 (TARGET_SWITCHES): Always provide 64 bit options.
810 (ARCH64_SWITCHES): Delete.
811 (TARGET_OPTIONS): New option -mcmodel=.
812 (INT_TYPE_SIZE): Always 32.
813 (MAX_LONG_TYPE_SIZE): Define ifdef SPARC_BI_ARCH.
814 (INIT_EXPANDERS): sparc64_init_expanders renamed to sparc_init_....
815 (FUNCTION_{,BLOCK_}PROFILER): Delete TARGET_EMBMEDANY support.
816 (PRINT_OPERAND_PUNCT_VALID_P): Add '_'.
817 * sparc/linux-aout.h (CPP_PREDEFINES): Take out stuff handled by
819 (CPP_SUBTARGET_SPEC): Renamed from CPP_SPEC.
820 * sparc/linux.h: Likewise.
821 * sparc/linux64.h (SPARC_V9,SPARC_ARCH64): Delete.
822 (ASM_CPU_DEFAULT_SPEC): Renamed from ASM_DEFAULT_SPEC.
823 (TARGET_DEFAULT): Delete MASK_LONG64, MASK_MEDANY, add MASK_64BIT.
824 (SPARC_DEFAULT_CMODEL): Define.
825 (CPP_PREDEFINES): Take out stuff handled by CPP_SPEC.
826 (CPP_SUBTARGET_SPEC): Renamed from CPP_SPEC.
827 (LONG_DOUBLE_TYPE_SIZE): Define.
828 (ASM_SPEC): Add %(asm_arch).
829 * sparc/sol2.h (CPP_PREDEFINES): Take out stuff handled by CPP_SPEC.
830 (CPP_SUBTARGET_SPEC): Renamed from CPP_SPEC.
831 (TARGET_CPU_DEFAULT): Add ultrasparc case.
832 * sparc/sp64-aout.h (SPARC_V9,SPARC_ARCH64): Delete.
833 (TARGET_DEFAULT): MASK_ARCH64 renamed to MASK_64BIT.
834 (SPARC_DEFAULT_CMODEL): Define.
835 * sparc/sp64-elf.h (SPARC_V9,SPARC_ARCH64): Delete.
836 (TARGET_DEFAULT): MASK_ARCH64 renamed to MASK_64BIT. Delete
837 MASK_LONG64, MASK_MEDANY.
838 (SPARC_DEFAULT_CMODEL): Define.
839 (CPP_PREDEFINES): Delete.
840 (CPP_SUBTARGET_SPEC): Renamed from CPP_SPEC.
841 (ASM_SPEC): Add %(asm_arch).
842 (LONG_DOUBLE_TYPE_SIZE): Define.
843 (DWARF2_DEBUGGING_INFO): Define.
844 * sparc/splet.h (CPP_SPEC): Delete.
845 * sparc/sysv4.h (CPP_PREDEFINES): Take out stuff handled by CPP_SPEC.
846 (FUNCTION_BLOCK_PROFILER): Delete TARGET_EMBMEDANY support.
847 (BLOCK_PROFILER): Likewise.
848 * sparc/sparc.c (sparc_cmodel_string,sparc_cmodel): New globals.
849 (sparc_override_options): Handle code model selection.
850 (sparc_init_expanders): Renamed from sparc64_init_expanders.
851 * sparc/sparc.md: TARGET_<code_model> renamed to TARGET_CM_....
852 TARGET_MEDANY renamed to TARGET_CM_EMBMEDANY.
853 (sethi_di_embmedany_{data,text}): Renamed from sethi_di_medany_....
854 (sethi_di_fullany): Delete.
856 Mon Oct 20 02:00:18 1997 Klaus Kaempf <kkaempf@progis.de>
857 Jeff Law <law@cygnus.com>
858 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
860 * alpha/vms.h (DIVSI3_LIBCALL): OTS$ functions are upper case.
861 (DIVDI3_LIBCALL, UDIVSI3_LIBCALL, UDIVDI3_LIBVALL): Likewise.
862 (MODSI3_LIBCALL, MODDI3_LIBCALL): Likewise.
863 (UMODSI3_LIBCALL, UMODDI3_LIBCALL): Likewise.
864 * alpha/alpha.md (arg_home): Likewise.
866 * alpha/alpha.c (vmskrunch): Delete
867 * alpha/vms.h (ENCODE_SECTION_INFO, ASM_DECLARE_FUNCTION_NAME): Delete.
868 * alpha.c (output_prolog, VMS): Use alloca for entry_label and don't
869 truncate to 64 characters.
871 * make-l2.com: Support openVMS/Alpha.
873 * vmsconfig.com: Fix to work on openVMS/Alpha and openVMS/VAX.
875 Sun Oct 19 19:00:35 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
877 * longlong.h (count_leading_zeros): Add missing casts to USItype.
879 Sun Oct 19 18:44:06 1997 Jeffrey A Law (law@cygnus.com)
881 * i386/bsd386.h (ASM_COMMENT_START): Define.
883 Sat Oct 18 13:47:15 1997 Jason Merrill <jason@yorick.cygnus.com>
885 * tree.c (restore_tree_status): Also free up temporary storage
886 when we finish a toplevel function.
887 (dump_tree_statistics): Print stats for backend obstacks.
889 Sat Oct 18 12:47:31 1997 Doug Evans <dje@canuck.cygnus.com>
891 * expr.c (use_group_regs): Don't call use_reg for MEMs.
893 Sat Oct 18 09:49:46 1997 Jason Merrill <jason@yorick.cygnus.com>
895 * libgcc2.c (__throw): Don't copy the return address.
896 * dwarf2out.c (expand_builtin_dwarf_reg_size): Ignore return address.
898 * except.c (exceptions_via_longjmp): Initialize to 2 (uninitialized).
899 * toplev.c (main): Initialize exceptions_via_longjmp.
901 * tree.c: Add extra_inline_obstacks.
902 (save_tree_status): Use it.
903 (restore_tree_status): If this is a toplevel inline obstack and we
904 didn't want to save anything on it, recycle it.
905 (print_inline_obstack_statistics): New fn.
906 * function.c (pop_function_context_from): Pass context to
908 * obstack.h (obstack_empty_p): New macro.
910 Sat Oct 18 00:43:59 1997 Jeffrey A Law (law@cygnus.com)
912 * i386/freebsd.h (ASM_COMMENT_START): Fix.
914 Fri Oct 17 23:48:52 1997 Jim Wilson (wilson@cygnus.com)
916 * v850.c (ep_memory_offset): New function.
917 (ep_memory_operand, substitute_ep_register, v850_reorg): Call it.
919 * v850.h (CONST_OK_FOR_*): Add and correct comments.
920 (CONSTANT_ADDRESS_P): Add comment.
921 (EXTRA_CONSTRAINT): Define 'U'.
922 * v850.md: Add comments on bit field instructions.
923 (addsi3): Delete &r/r/r alternative. Add r/r/U alternative.
924 (lshrsi3): Use N not J constraint.
926 * v850.md (v850_tst1+1): New define_split for tst1 instruction.
928 * v850.c (reg_or_0_operand): Call register_operand.
929 (reg_or_int5_operand): Likewise.
930 * v850.h (MASK_BIG_SWITCH, TARGET_BIG_SWITCH): New macros.
931 (TARGET_SWITCHES): Add "big-switch".
932 (ASM_OUTPUT_ADDR_VEC_ELT, ASM_OUTPUT_ADDR_DIFF_ELT, CASE_VECTOR_MODE,
933 ASM_OUTPUT_BEFORE_BASE_LABEL): Add support for TARGET_BIG_SWITCH.
934 (CASE_DROPS_THROUGH): Comment out.
935 (CASE_VECTOR_PC_RELATIVE, JUMP_TABLES_IN_TEXT_SECTION): Define.
936 * v850.md (cmpsi): Delete compare mode.
937 (casesi): New pattern.
939 * v850.h (CONST_OK_FOR_N): Delete redundant compare against zero.
940 * v850.md (ashlsi3): Use SImode not QImode for shift count.
943 * v850.c (print_operand): Add 'c', 'C', and 'z' support. Delete
944 unreachable switch statement after 'b' support. Remove "b" from
945 strings for 'b' support.
946 * v850.md (branch_normal, branch_invert): Change %b to b%b.
948 Fri Oct 17 23:33:20 1997 Jeffrey A Law (law@cygnus.com)
950 * Makefile.in (LIBGCC2_CFLAGS): Avoid a backslash then an
951 empty line if @inhibit_libc@ is empty.
953 Fri Oct 17 23:24:40 1997 Robert Lipe (robertl@dgii.com)
955 * i386/sco5.h: Let ELF use dwarf2 unwinding. COFF uses sjlj.
956 (EH_FRAME_SECTION_ASM_OP, EH_FRAME_SECTION_ASM_OP_ELF): Defined.
957 (EH_FRAME_SECTION_ASM_OP_COFF): Likewise.
958 (DWARF2_UNWIND_INFO): Let this track object file format.
959 (EXTRA_SECTIONS): Add in_eh.
960 (EH_FRAME_SECTION_ASM_OP, EH_FRAME_SECTION_ASM_OP_ELF): Define.
961 (EH_FRAME_SECTION_ASM_OP_COFF): Likewise.
963 Fri Oct 17 17:13:42 1997 David S. Miller <davem@tanya.rutgers.edu>
965 * sparc/linux64.h (LINK_SPEC): Dynamic linker is ld-linux64.so.2.
966 * sparc/sparc.h (FUNCTION_PROFILER): Fix format string when
968 * sparc/sparc.c (dwarf2out_cfi_label): Extern no longer needed.
969 (output_double_int): Output DI mode values correctly when
970 HOST_BITS_PER_WIDE_INT is 64.
971 (output_fp_move_quad): If TARGET_V9 and not TARGET_HARD_QUAD, use
972 fmovd so it works if a quad float ends up in one of the upper 32
974 * sparc/sparc.md (pic_{lo_sum,sethi}_di): New patterns
975 necessary for PIC support on sparc64.
977 Fri Oct 17 13:39:56 1997 Doug Evans <dje@canuck.cygnus.com>
979 * sparc/sp64-elf.h (TARGET_DEFAULT): Delete MASK_STACK_BIAS.
980 * sparc/sparc.h (PROMOTE_MODE): Promote small ints if arch64.
981 (PROMOTE_FUNCTION_ARGS,PROMOTE_FUNCTION_RETURN): Define.
982 (SPARC_FIRST_FP_REG, SPARC_FP_REG_P): New macros.
983 (SPARC_{OUTGOING,INCOMING}_INT_ARG_FIRST): New macros.
984 (SPARC_FP_ARG_FIRST): New macro.
985 (CONDITIONAL_REGISTER_USAGE): All v9 fp regs are volatile now.
986 (REG_ALLOC_ORDER,REG_LEAF_ALLOC_ORDER): Reorganize fp regs.
987 (NPARM_REGS): There are 32 fp argument registers now.
988 (FUNCTION_ARG_REGNO_P): Likewise.
989 (FIRST_PARM_OFFSET): Update to new v9 abi.
990 (REG_PARM_STACK_SPACE): Define for arch64.
991 (enum sparc_arg_class): Delete.
992 (sparc_arg_count,sparc_n_named_args): Delete.
993 (struct sparc_args): Redefine and use for arch32 as well as arch64.
994 (GET_SPARC_ARG_CLASS,ROUND_REG,ROUND_ADVANCE): Delete.
995 (FUNCTION_ARG_ADVANCE): Rewrite.
996 (FUNCTION_ARG,FUNCTION_INCOMING_ARG): Rewrite.
997 (FUNCTION_ARG_{PARTIAL_NREGS,PASS_BY_REFERENCE}): Rewrite.
998 (FUNCTION_ARG_CALLEE_COPIES): Delete.
999 (FUNCTION_ARG_{PADDING,BOUNDARY}): Define.
1000 (STRICT_ARGUMENT_NAMING): Define.
1001 (doublemove_string): Declare.
1002 * sparc/sparc.c (sparc_arg_count,sparc_n_named_args): Delete.
1003 (single_move_string): Use GEN_INT, and HOST_WIDE_INT.
1004 (doublemove_string): New function.
1005 (output_move_quad): Clean up some of the arch64 support.
1006 (compute_frame_size): Add REG_PARM_STACK_SPACE if arch64.
1007 Don't add 8 bytes of reserved space if arch64.
1008 (sparc_builtin_saveregs): Combine arch32/arch64 versions.
1009 (init_cumulative_args): New function.
1010 (function_arg_slotno): New static function.
1011 (function_arg,function_arg_partial_nregs): New functions.
1012 (function_arg_{pass_by_reference,advance}): New functions.
1013 (function_arg_padding): New function.
1014 * ginclude/va-sparc.h: Rewrite v9 support.
1016 Fri Oct 17 12:29:48 1997 Christian Iseli <Christian.Iseli@lslsun.epfl.ch>
1018 * regclass.c (record_address_regs): Look at REG_OK_FOR_{BASE,INDEX}_P
1019 for hard regs to determine base and index registers.
1021 * reload.c (debug_reload_to_stream): New function. Specify stream
1022 into which to write debug info.
1023 (debug_reload): Modify to call debug_reload_to_stream with stderr.
1025 Thu Oct 16 15:07:51 1997 Richard Henderson <rth@cygnus.com>
1027 * combine.c (can_combine_p): Don't combine with an asm whose
1028 output is a hard register.
1030 Thu Oct 16 15:43:26 1997 Mike Stump (mrs@wrs.com)
1032 * c-decl.c (start_struct): Ensure that structs with forward
1033 declarations are in fact packed when -fpack-struct is given.
1035 * stor-layout.c (layout_record): Ignore STRUCTURE_SIZE_BOUNDARY if
1036 we are packing a structure. This allows a structure with only
1037 bytes to be aligned on a byte boundary and have no padding on a
1040 Thu Oct 16 15:17:54 1997 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
1042 * rs6000.h (ROUND_TYPE_ALIGN): Don't blow up if no fields in record.
1044 Thu Oct 16 11:20:30 1997 Richard Henderson <rth@cygnus.com>
1046 * alpha.c (alpha_return_addr_rtx): New variable.
1047 (alpha_save_machine_status): New; save it.
1048 (alpha_restore_machine_status): New; restore it.
1049 (alpha_init_expanders): New; clear it.
1050 (alpha_return_addr): New; set it.
1051 (alpha_ra_ever_killed): New; if alpha_return_addr_rtx, regs_ever_live
1052 is overly conservative, so search the insns explicitly.
1053 (alpha_sa_mask [VMS]): Check alpha_ra_ever_killed.
1054 (alpha_sa_size [VMS && !VMS]): Likewise.
1055 * alpha.h (RETURN_ADDR_RTX): Call alpha_return_addr.
1056 (INIT_EXPANDERS): New definition.
1058 * alpha.c: Move REG_PV, REG_RA somewhere more visible in the file.
1059 (output_prolog [!VMS]): Use them.
1061 * alpha.c (output_prolog [!VMS]): Move gp detection to ...
1062 (alpha_does_function_need_gp): ... a new function. Refine the
1063 CALL_INSN test to just TYPE_JSR.
1064 * alpha.md (most call insns): Fix some jsr/ibr type transpositions.
1066 Thu Oct 16 09:36:47 1997 Jeffrey A Law (law@cygnus.com)
1068 * version.c: Bump for snapshot.
1070 Wed Oct 15 21:38:18 1997 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
1072 * pa.c (move_operand): Respect -mdisable-indexing.
1073 * pa.h (GO_IF_LEGITIMATE_ADDRESS): Likewise.
1075 Wed Oct 15 21:34:45 1997 David Edelsohn <edelsohn@mhpcc.edu>
1077 * rs6000.md (udivsi3, divsi3): Split into MQ and non-MQ cases for
1079 (umulsidi3,umulsi3_highpart): Ditto.
1080 (smulsi3_highpart_no_mq): Add !TARGET_POWER.
1082 Wed Oct 15 18:21:46 1997 Richard Henderson <rth@cygnus.com>
1084 * alpha.c (final_prescan_insn): Gut, remove and transform to ...
1085 (alpha_handle_trap_shadows): ... a new function. Handle the entire
1086 function in one go. Emit RTL for trapb, instead of printf directly.
1087 (alpha_reorg): New function. Call alpha_handle_trap_shadows.
1088 (trap_pending): Kill global variable.
1089 (output_epilog): Don't call final_prescan_insn.
1090 (struct shadow_summary): Elide $31 and $f31; now it fits in a word.
1091 * alpha.h (FINAL_PRESCAN_INSN): Remove.
1092 (MACHINE_DEPENENT_REORG): Define.
1093 * alpha.md (jsr patterns with trapb): Stupid and useless. Kill.
1096 Wed Oct 15 18:16:05 1997 Richard Henderson <rth@cygnus.com>
1098 Tune Haifa scheduler for Alpha:
1099 * alpha.h (ISSUE_RATE): Define.
1100 * alpha.c (alpha_adjust_cost): Handle EV5 mult delay; don't apply
1101 EV4 adjustments to EV5.
1102 * alpha.md: Remove all scaling from function unit delays. Rework
1103 EV5 function units to match the CPU.
1104 (umuldi3_highpart): EV5 added the IMULH insn class.
1106 Wed Oct 15 17:42:41 1997 Jeffrey A Law (law@cygnus.com)
1108 * pa.c (following_call): Fail if the CALL_INSN is an indirect
1111 Tue Oct 14 12:01:00 1997 Mark Mitchell <mmitchell@usa.net>
1113 * cplus-dem.c (demangle_signature): Don't look for return types on
1114 constructors. Handle member template constructors.
1116 Tue Oct 14 11:30:29 1997 Jason Merrill <jason@yorick.cygnus.com>
1118 * tree.c (expr_tree_cons, build_expr_list, expralloc): New fns.
1119 * tree.h: Declare them.
1121 Fri Oct 10 13:46:56 1997 Doug Evans <dje@canuck.cygnus.com>
1123 * configure.in: Handle --with-newlib.
1124 * Makefile.in (LIBGCC2_CFLAGS): Add @inhibit_libc@.
1126 * sparc/t-sp64 (LIBGCC2_CFLAGS): Delete.
1128 Wed Oct 8 14:37:44 1997 Jeffrey A Law (law@cygnus.com)
1130 * config/ptx4.h: Fix typo.
1132 Wed Oct 8 08:57:20 1997 Jeffrey A Law (law@cygnus.com)
1134 * version.c: Bump for snapshot.
1136 Tue Oct 7 16:27:34 1997 Manfred Hollstein <manfred@s-direktnet.de>
1138 * aclocal.m4: Substitute INSTALL.
1139 * configure: Re-built.
1141 Tue Oct 7 15:37:35 1997 Jeffrey A Law (law@cygnus.com)
1143 * integrate.c (save_for_inline_copying): Avoid undefined pointer
1145 (expand_inline_function): Likewise.
1147 * dwarf2out.c (output_call_frame_info): Reinstate last change
1148 using flag_debug_asm check instead of flag_verbose_asm.
1150 Tue Oct 7 12:57:26 1997 Jim Wilson <wilson@cygnus.com>
1152 * dwarf2out.c (output_call_frame_info): Remove last change.
1154 1997-10-04 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
1156 * frame.c (__frame_state_for): Execute the FDE insns until the
1157 current pc value is strictly bigger than the target pc value.
1159 Tue Oct 7 11:00:42 1997 Jason Merrill <jason@yorick.cygnus.com>
1161 * regclass.c (init_reg_modes): If we can't find a mode for the
1162 register, use the previous one.
1164 Tue Oct 7 10:55:34 1997 Richard Henderson <rth@cygnus.com>
1166 * haifa-sched.c (print_block_visualization): Call fprintf directly,
1167 don't sprintf through an alloca'ed buffer.
1169 Tue Oct 7 10:52:29 1997 Thomas Koenig (ig25@rz.uni-karlsruhe.de)
1171 * reload.c (decompose): Always initialize val.base.
1173 Tue Oct 7 10:19:26 1997 Manfred Hollstein (manfred@lts.sel.alcatel.de)
1175 * m68k/mot3300.h (ASM_OUTPUT_ALIGN): Accept any alignment
1176 instead of aborting.
1177 * dwarf2out.c (output_call_frame_info): Call app_enable and
1178 app_disable to let GNU as accept the generated comments.
1180 Tue Oct 7 11:41:21 1997 Michael Meissner <meissner@cygnus.com>
1182 * tree.h (get_file_function_name): Add declaration.
1183 * dwarf2out.c (output_call_frame_info): No need to cast
1184 get_file_function_name call anymore.
1185 * profile.c (toplevel): Remove get_file_function_name
1187 * c-lang.c (finish_file): Ditto.
1189 Tue Oct 7 10:01:45 1997 Chip Salzenberg <chip@rio.atlantic.net>
1191 * Makefile.in (program_transform_name): Let autoconf substitute
1194 Tue Oct 7 09:54:35 1997 Jeffrey A Law (law@cygnus.com)
1196 * haifa-sched.c (schedule_block): If the first real insn in a
1197 block has any special notes attached to it, remove them.
1199 Tue Oct 7 09:48:51 1997 Richard Henderson <rth@cygnus.com>
1201 * alpha.h (FLOAT_STORE_FLAG_VALUE): It's 2.0 not 0.5.
1203 Mon Oct 6 12:47:32 1997 Manfred Hollstein (manfred@lts.sel.alcatel.de)
1205 * m88k.c (m88k_begin_prologue): Remove superfluous backslash.
1207 Mon Oct 6 12:04:24 1997 Jeffrey A Law (law@cygnus.com)
1209 * Makefile.in (check-g77): New test target.
1210 (CHECK-TARGETS): Add check-g77.
1212 Fri Oct 3 11:56:36 1997 Jason Merrill <jason@yorick.cygnus.com>
1214 * toplev.c (rest_of_compilation): Defer all non-nested inlines.
1216 Fri Oct 3 15:49:27 1997 Michael Meissner <meissner@cygnus.com>
1218 * flow.c (print_rtl_with_bb): Cast alloca return value for
1221 Thu Oct 2 21:15:03 1997 Richard Henderson <rth@cygnus.com>
1223 * i386.h (RETURN_ADDR_RTX): New definition that works for
1224 __builtin_return_address(0) and -fomit-frame-pointer.
1226 Wed Oct 1 13:43:53 1997 Jim Wilson <wilson@cygnus.com>
1228 Bring over from FSF.
1229 Tue Aug 5 16:10:45 1997 Jason Merrill <jason@yorick.cygnus.com>
1231 * mips.c (function_arg): Handle passing a struct
1232 containing a double in a DFmode register without the PARALLEL.
1234 Wed Oct 1 11:13:25 1997 Ian Lance Taylor <ian@cygnus.com>
1236 * pexecute.c: Use spawn if __CYGWIN32__.
1238 * pexecute.c: Include "config.h" first, as per autoconf manual
1239 (from Paul Eggert <eggert@twinsun.com>).
1241 Wed Oct 1 01:44:36 1997 Philippe De Muyter <phdm@info.ucl.ac.be>
1243 * m68k/x-mot3300 (XCFLAGS): Disable as's long/short jump
1244 optimisation for f/expr.o and f/stb.o.
1246 Tue Sep 30 23:48:57 1997 Jeffrey A Law (law@cygnus.com)
1248 * cse.c (this_insn_cc0_mode): Initialize.
1250 Tue Sep 30 23:09:40 1997 Thomas Koenig <ig25@mvmap66.ciw.uni-karlsruhe.de>
1252 * cccp.c (expand_to_temp_buffer): Initialize all members of obuf.
1254 * haifa-sched.c (get_block_head_tail): Remove unneeded initialization.
1256 Tue Sep 30 23:06:43 1997 Richard Henderson <rth@cygnus.com>
1258 * alpha.md (beq): For registers and ints 0-255, use cmpeq+bne, since
1259 that pair will dual-issue on the 21164 and plus+beq won't.
1260 (bne): Likewise for cmpeq+beq.
1262 Tue Sep 30 16:07:58 1997 Jim Wilson <wilson@cygnus.com>
1264 * except.c (find_exception_handler_labels): Correct argument to free.
1266 Tue Sep 30 11:00:00 1997 Brendan Kehoe <brendan@lisa.cygnus.com>
1268 * except.c (find_exception_handler_labels): Free LABELS when we're
1271 Mon Sep 29 14:04:35 1997 Jeffrey A Law (law@cygnus.com)
1273 * version.c: Bump for snapshot.
1275 Mon Sep 29 10:51:53 1997 Jason Merrill <jason@yorick.cygnus.com>
1277 * flow.c (find_basic_blocks): Mark calls as potentially jumping
1280 Mon Sep 29 09:58:06 1997 Jeffrey A Law (law@cygnus.com)
1282 * configure.in: Substitute for "install" too.
1283 * configure: Rebuilt.
1285 Mon Sep 29 00:38:42 1997 Aaron Jackson <jackson@negril.msrce.howard.edu>
1287 * Makefile.in (bootstrap-lean, compare-lean): New targets.
1289 Mon Sep 29 00:18:16 1997 Richard Henderson (rth@cygnus.com)
1291 * alias.c (base_alias_check): Two symbols can conflict if they
1292 are accessed via AND.
1293 (memrefs_conflict_p): Likewise.
1295 * alpha.h (SETUP_INCOMING_VARARGS): Emit a blockage insn
1296 after flushing argument registers to the stack.
1298 * Makefile.in (mostlyclean): Remove .regmove files.
1300 Sun Sep 28 18:59:58 1997 Jason Merrill <jason@yorick.cygnus.com>
1302 * libgcc2.c (__throw): Fix thinko.
1304 Sun Sep 28 12:00:52 1997 Mark Mitchell <mmitchell@usa.net>
1306 * cplus-dem.c (demangle_template): Add new parameter. Handle new
1307 template-function mangling.
1308 (consume_count_with_underscores): New function.
1309 (demangle_signature): Handle new name-mangling scheme.
1311 Sun Sep 28 01:55:04 1997 Philippe De Muyter <phdm@info.ucl.ac.be>
1313 * flow.c (print_rtl_with_bb): Cast alloca return values for variables
1316 Sun Sep 28 01:05:16 1997 Jeffrey A Law (law@cygnus.com)
1318 * frame.c: Remove last change.
1319 * dwarf2.h: Remove last change.
1320 * tree.h: Add declarations of DWARF2 unwind info support
1323 Sat Sep 27 11:02:38 1997 Jason Merrill <jason@yorick.cygnus.com>
1325 * c-decl.c (init_decl_processing): Add __builtin_dwarf_reg_size.
1326 * tree.h (built_in_function): Likewise.
1327 * expr.c (expand_builtin): Likewise.
1328 * except.h: Likewise.
1329 * dwarf2out.c (expand_builtin_dwarf_reg_size): New fn.
1330 * libgcc2.c (copy_reg): New fn.
1333 Fri Sep 26 08:54:59 1997 Paul Eggert <eggert@twinsun.com>
1335 * c-typeck.c (build_binary_op): Warn about comparing signed vs
1336 unsigned if -W is specified and -Wno-sign-compare is not.
1337 * c-decl.c (warn_sign_compare): Initialize to -1.
1338 (c_decode_option): -Wall no longer implies -Wsign-compare.
1340 Fri Sep 26 09:00:13 1997 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
1342 * frame.c: Include gansidecl.h for PROTO.
1343 * dwarf2out.c: Move inclusion of dwarf2.h down so that PROTO is
1344 defined. Don't declare dwarf2out_cfi_label here.
1345 * dwarf2.h: Add declarations of DWARF2 unwind info support
1347 * m68k.c: Include dwarf2.h.
1348 (output_function_prologue): Add dwarf2 support.
1349 * m68k.h (INCOMING_RETURN_ADDR_RTX, DWARF_FRAME_REGNUM): New macros.
1350 (INCOMING_FRAME_SP_OFFSET): Likewise.
1352 * integrate.c (expand_inline_function): Make sure there is at
1353 least one insn that can be used as an insertion point.
1355 Wed Sep 24 21:34:06 1997 Jason Merrill <jason@yorick.cygnus.com>
1357 * dwarf2out.c: s/flag_verbose_asm/flag_debug_asm/
1359 Wed Sep 24 22:05:30 1997 Jeffrey A Law (law@cygnus.com)
1361 * version.c: Bump for snapshot.
1363 Wed Sep 24 17:36:23 1997 Doug Evans <dje@canuck.cygnus.com>
1365 Bring over from FSF.
1367 Wed Sep 24 19:17:08 1997 Doug Evans <dje@cygnus.com>
1369 * sparc/sparc.md (get_pc_via_call): Renamed from get_pc_sp32.
1370 (get_pc_via_rdpc): Renamed from get_pc_sp64.
1371 * sparc/sparc.c (finalize_pic): Update call to gen_get_pc_via_call.
1373 Wed Sep 24 18:38:22 1997 David S. Miller <davem@tanya.rutgers.edu>
1375 * sparc/sparc.h (ASM_CPU_SPEC): Pass -Av9a for v8plus, ultrasparc.
1376 (TARGET_OPTIONS): Add -malign-loops=, -malign-jumps=,
1378 (sparc_align_{loops,jumps,funcs}_string): Declare.
1379 (sparc_align_{loops,jumps,funcs}): Declare.
1380 (DEFAULT_SPARC_ALIGN_FUNCS): New macro.
1381 (FUNCTION_BOUNDARY): Use sparc_align_funcs.
1382 (STACK_BIAS): Define.
1383 (SPARC_SIMM*_P): Cast to unsigned HOST_WIDE_INT first, then perform
1385 (SPARC_SETHI_P): New macro.
1386 (CONST_OK_FOR_LETTER_P): Use it.
1387 (ASM_OUTPUT_ALIGN_CODE): Define.
1388 (ASM_OUTPUT_LOOP_ALIGN): Define.
1389 * sparc/sparc.c (sparc_align_{loops,jumps,funcs}_string): New globals.
1390 (sparc_align_{loops,jumps,funcs}): New globals.
1391 (sparc_override_options): Handle -malign-loops=, -malign-jumps=,
1393 (move_operand): Use SPARC_SETHI_P.
1394 (arith_double_operand): Cast to unsigned HOST_WIDE_INT first, then
1396 (arith11_double_operand): Likewise.
1397 (arith10_double_operand): Likewise.
1398 (finalize_pic): Finish sparc64 support.
1399 (emit_move_sequence): Use SPARC_SETHI_P. Simplify low part of
1400 64 bit constants if able.
1401 (output_fp_move_quad): Don't use fmovq unless TARGET_HARD_QUAD.
1402 (sparc_builtin_saveregs, sparc64 case): Don't save fp regs if
1404 * sparc/sparc.md (*): Use GEN_INT instead of gen_rtx.
1405 (get_pc_sp32): Use for sparc64 as well.
1406 (lo_sum_di_sp{32,64}): Fix handling on 64 bit hosts.
1407 (sethi_di_sp64_const): Likewise.
1408 (movtf_cc_sp64): Check TARGET_HARD_QUAD.
1409 (cmp_zero_extract_sp64): Use unsigned HOST_WIDE_INT in cast.
1410 (ashlsi3, ashldi3, ashrsi3, ashrdi3, lshrsi3, lshrdi3): Likewise.
1412 Tue Sep 23 19:02:46 1997 Doug Evans <dje@cygnus.com>
1414 * sparc/linux-aout.h (COMMENT_BEGIN): Delete.
1415 * sparc/linux.h (COMMENT_BEGIN): Likewise.
1416 * sparc/linux64.h (COMMENT_BEGIN): Likewise.
1418 Tue Sep 23 14:48:18 1997 David S. Miller <davem@tanya.rutgers.edu>
1420 Add sparc64 linux support.
1421 * configure.in (sparc64-*-linux*): Recognize. Add sparc/xm-sparc.h
1422 to xm_file list on 32-bit sparc-linux.
1423 * sparc/xm-sp64.h: New file.
1424 * sparc/linux64.h: New file.
1425 * sparc/xm-linux.h: Include some standard headers if not inhibit_libc.
1426 Don't include xm-sparc.h.
1427 * config/xm-linux.h (HAVE_PUTENV, HAVE_ATEXIT): Define.
1428 * glimits.h (LONG_MAX): Handle sparc64.
1430 Sat Sep 20 03:07:54 1997 Doug Evans <dje@cygnus.com>
1432 * sparc/sysv4.h (ASM_COMMENT_START): Delete.
1433 * sparc.h (ASM_COMMENT_START): Define.
1434 * sparc.c (output_function_prologue): Use it.
1435 (sparc_flat_output_function_{epi,pro}logue): Likewise.
1437 Wed Sep 17 15:04:19 1997 Doug Evans <dje@cygnus.com>
1439 * sparc/sysv4.h (ASM_OUTPUT_{FLOAT,DOUBLE,LONG_DOUBLE}): Delete,
1440 use sparc.h's copies.
1441 * sparc/sparc.h (ASM_OUTPUT_{FLOAT,DOUBLE,LONG_DOUBLE}): Print
1444 Mon Sep 8 08:45:19 1997 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
1446 * sparc.c (dwarf2out_cfi_label): Add declaration.
1447 (save_regs, output_function_prologue): Remove cast for it.
1448 (sparc_flat_{save_restore,output_function_prologue): Likewise.
1449 ({save,restore}_regs): No longer inline.
1451 Tue Sep 23 12:34:51 1997 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
1453 * fold-const.c (make_range): Correctly handle cases of converting
1454 from unsigned to signed type.
1456 Tue Sep 23 12:34:51 1997 Bernd Schmidt <crux@pool.informatik.rwth-aachen.de>
1458 * fold-const.c (merge_ranges): Make sure that if one range is subset
1459 of another, it will always be the second range. Correct (+,-) case to
1462 Tue Sep 23 08:32:51 1997 Jason Merrill <jason@yorick.cygnus.com>
1464 * final.c (final_end_function): Also do dwarf2 thing if
1465 DWARF2_DEBUGGING_INFO.
1466 (final_start_function): Likewise.
1468 Tue Sep 23 01:15:50 1997 David S. Miller <davem@tanya.rutgers.edu>
1470 * expmed.c (expand_divmod): If compute_mode is not the same as
1471 mode, handle the case where convert_modes() causes op1 to no
1472 longer be a CONST_INT.
1474 * reorg.c (dbr_schedule): At end of this pass, add REG_BR_PRED
1475 note holding get_jump_flags() calculation to all JUMP_INSNs.
1476 * rtl.h (enum reg_note): New note types REG_BR_PRED and REG_SAVE_AREA.
1477 * rtl.c (reg_note_name): Add new note types.
1479 Tue Sep 23 00:59:54 1997 Jeffrey A Law (law@cygnus.com)
1481 * rtlanal.c (computed_jump_p): Fix typo in last change.
1483 Tue Sep 23 00:42:44 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
1485 * loop.c (indirect_jump_in_function_p): Return 0
1488 Tue Sep 23 00:33:55 1997 Jeffrey A Law (law@cygnus.com)
1490 * rs6000/xm-rs6000.h: Fix thinko in last change.
1491 * rs6000/xm-sysv4.h: Likewise.
1493 Mon Sep 22 19:33:53 1997 Jim Wilson <wilson@cygnus.com>
1495 * mips.c (save_restore_insns): Only set RTX_FRAME_RELATED_P if store_p.
1497 Mon Sep 22 14:41:00 1997 Jeffrey A Law (law@cygnus.com)
1499 * reg-stack.c (find_blocks): Fix thinko in last change.
1501 1997-09-21 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
1503 * m68k.c (output_function_prologue): Add dwarf2 support.
1505 * m68k.h (INCOMING_RETURN_ADDR_RTX, DWARF_FRAME_REGNUM,
1506 INCOMING_FRAME_SP_OFFSET): New definitions.
1508 Mon Sep 22 11:36:42 1997 David S. Miller <davem@tanya.rutgers.edu>
1510 * combine.c (try_combine): Use NULL_RTX instead of '0' where
1511 appropriate in calls to gen_rtx().
1512 * cse.c (cse_main): Likewise.
1513 * emit-rtl.c (gen_label_rtx): Likewise.
1514 * expr.c (init_expr_once): Likewise.
1515 * haifa-sched.c (flush_pending_lists, sched_analyze_insn,
1516 sched_analyze, init_rgn_data_dependences,
1517 compute_block_backward_dependences): Likewise.
1518 * sched.c (schedule_insns): Likewise.
1519 * varasm.c (immed_double_const): Likewise.
1521 * sparc.h (INCOMING_FRAME_SP_OFFSET): Define to
1522 SPARC_STACK_BIAS for sake of dwarf2 on sparc64.
1524 Mon Sep 22 11:21:33 1997 J. Kean Johnston <jkj@sco.com>
1526 * i386/sco5.h: Make ELF default file format and add -mcoff/-melf..
1527 (MULTILIB_DEFAULTS): Define.
1528 (ASM_SPEC, CPP_SPEC): Handle -mcoff.
1529 (STARTFILE_SPEC, ENDFILE_SPEC, LINK_SPEC): Likewise.
1530 (LIBGCC_SPEC): Likewise.
1531 (MASK_COFF, TARGET_COFF, TARGET_ELF): Define.
1532 (SUBTARGET_SWITCHES): Add -mcoff and -melf.
1533 * i386/t-sco5 (CRTSTUFF_T_CFLAGS): Add -fPIC.
1534 (CRTSTUFF_T_CFLAGS_S): Tweak for COFF.
1535 (EXTRA_PARTS, TAROUTOPTS): Delete.
1536 (libgcc1-elf, libgcc2-elf, libgcc-elf targets): Delete.
1537 (MULTILIB_OPTIONS): Define.
1538 (MULTILIB_DIRNAMES, MULTILIB_EXCEPTIONS): Likewise.
1539 (MULTILIB_MATCHE, MULTILIB_EXTRA_OPTS): Likewise.
1541 Mon Sep 22 02:10:43 1997 Jeffrey A Law (law@cygnus.com)
1543 * version.c: Bump for snapshot.
1545 Sun Sep 21 17:45:45 1997 Jeffrey A Law (law@cygnus.com)
1547 * loop.c (loop_number): Delete function. Change all references
1548 to use uid_loop_num array.
1549 * loop.h (loop_number): Delete declaration.
1550 * unroll.c (unroll_loop): Change "loop_number" references to
1551 use uid_loop_num instead.
1553 * loop.c (loop_unroll_factor): Move outside #ifdef HAIFA
1555 (loop_unroll_iter): Remove unused variable and all references.
1556 (loop_optimize): Always allocate and clear space for loop_unroll_factor.
1557 (insert_bct): Fix minor formatting problems.
1558 * loop.h (loop_unroll_factor): Move decl outside #ifdef HAIFA.
1559 (loop_unroll_iter): Removed unused decl.
1560 * unroll.c (unroll_loop): Remove code to set loop_unroll_iter.
1561 Always record the unrolling factor.
1563 * cse.c (simplify_relational_operation): Set h0u just like h0s.
1564 Similarly for h1u and h1s.
1566 * flow.c (jmp_uses_reg_or_mem): Deleted unused function.
1567 (find_basic_blocks): Use computed_jump_p to determine if a
1568 particular JUMP_INSN is a computed jump.
1569 * reg-stack.c (find_blocks): Use computed_jump_p to determine
1570 if a particular JUMP_INSN is a computed jump.
1571 * rtlanal.c (jmp_uses_reg_or_mem): New function.
1572 (computed_jump_p): Likewise.
1573 * rtl.h (computed_jump_p): Declare.
1574 * genattrtab.c (pc_rtx): Define and initialize.
1575 * loop.c (loop_optimize): Always determine if the current
1576 function has a computed jump.
1577 (indirect_jump_in_function_p): Use computed_jump_p to determine
1578 if a particular JUMP_INSN is a computed jump.
1580 * loop.c (fix_bct_param): Delete unused function.
1581 (check_bct_param): Likewise.
1583 Sat Sep 20 16:22:06 1997 Jason Merrill <jason@yorick.cygnus.com>
1585 * frame.c (__deregister_frame): Check properly for initialized object.
1587 Fri Sep 19 20:51:03 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
1589 * alpha/linux.h (HANDLE_SYSV_PRAGMA): Defined.
1591 Fri Sep 19 18:53:50 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
1593 * jump.c (thread_jumps): check can_reverse_comparison_p before
1594 threading a reversed-condition jump.
1596 * sched.c (update_flow_info): Don't pass SCRATCH to dead_or_set_p.
1597 * haifa-sched.c (update_flow_info): Likewise.
1599 Thu Sep 18 21:13:40 1997 Jeffrey A Law (law@cygnus.com)
1601 * Makefile.in (BOOT_CFLAGS): Use -O2.
1603 * configure.in (strtoul, bsearch): Have autoconf check for these
1605 * configure, config.in: Rebuilt.
1607 * m68k/xm-mot3300.h (alloca): Properly declare if __STDC__.
1608 * mips/mips.h (alloca): Likewise.
1609 * rs6000/xm-rs6000.h (alloca): Likewise.
1610 * rs6000/xm-sysv4.h: Likewise.
1612 Thu Sep 18 14:22:22 1997 Jason Merrill <jason@yorick.cygnus.com>
1614 * final.c (final_scan_insn): Hand BARRIERs off to the dwarf2 code.
1615 * dwarf2out.c (dwarf2out_frame_debug): Pass the whole insn along.
1616 (dwarf2out_stack_adjust): A BARRIER resets the args space to 0.
1618 * except.c (end_eh_unwinder): Subtract 1 from return address.
1619 * libgcc2.c (__throw): Likewise.
1620 (find_exception_handler): Don't change PC here. Compare end with >.
1622 Thu Sep 18 10:43:07 1997 Nick Clifton <nickc@cygnus.com>
1624 * v850.c (compute_register_save_size): Correct register
1626 * v850.md (save_interrupt, return_interrupt): Correct
1628 * v850/lib1funcs.asm (save_interrupt): Correct register number.
1629 (return_interrupt): Use stack pointer, not element pointer.
1631 1997-09-18 Brendan Kehoe <brendan@lisa.cygnus.com>
1633 * configure.in, configure: Make sure to create the stage* and include
1634 symbolic links in each subdirectory.
1636 Thu Sep 18 01:47:06 1997 Jeffrey A Law (law@cygnus.com)
1638 * pa.md (reload_peepholes): Don't allow addresses with side
1639 effects for the memory operand.
1641 Wed Sep 17 18:19:53 1997 Jason Merrill <jason@yorick.cygnus.com>
1643 * libgcc2.c (find_exception_handler): Subtract one from our PC when
1644 looking for a handler, to avoid hitting the beginning of the next
1647 * except.c (expand_builtin_set_return_addr_reg): Use force_operand.
1649 Wed Sep 17 18:33:59 1997 Jeffrey A Law (law@cygnus.com)
1651 * mips/abi64.h (LONG_MAX_SPEC): Define.
1652 * mips.h (LONG_MAX_SPEC): Define.
1653 (CPP_SPEC): Include long_max_spec.
1654 (EXTRA_SPECS): Include long_max_spec.
1656 Wed Sep 17 14:11:38 1997 Jeffrey A Law (law@cygnus.com)
1658 * v850.c (construct_save_jarl): Fix thinko in last change.
1660 Wed Sep 17 09:53:07 1997 Jeffrey A Law (law@cygnus.com)
1662 * version.c: Bump for snapshot.
1664 Tue Sep 16 14:22:36 1997 Jason Merrill <jason@yorick.cygnus.com>
1666 * libgcc2.c (find_exception_handler): Not found is -1.
1668 * integrate.c (expand_inline_function): Move expand_start_bindings
1669 after expanding the arguments.
1671 Tue Sep 16 11:13:46 1997 Jim Wilson <wilson@cygnus.com>
1673 * expr.c (expand_expr): Remove previous incorrect change.
1674 If target and slot has no DECL_RTL, then call mark_addressable
1675 again for the slot after we give it RTL.
1677 Tue Sep 16 09:18:52 1997 Jason Merrill (jason@cygnus.com)
1679 * expr.c (expand_expr, case TARGET_EXPR): Call mark_addressable
1680 again for the slot after we give it RTL.
1682 Tue Sep 16 00:13:20 1997 Nick Clifton <nickc@cygnus.com>
1684 * v850.c (register_is_ok_for_epilogue,
1685 pattern_is_ok_for_epilogue, construct_restore_jr,
1686 pattern_is_ok_for_prologue, construct_save_jarl): New functions.
1688 * v850.h (pattern_is_ok_for_prologue,
1689 pattern_is_ok_for_epilogue, register_is_ok_for_epilogue): New
1692 * v850.md: Replace prologue and epilogue patterns with a
1693 match_parallel pattern.
1695 Mon Sep 15 22:53:01 1997 Jeffrey A Law (law@cygnus.com)
1697 * aclocal.m4: Add replacement for AC_PROG_INSTALL.
1698 * configure.in: Use EGCS_PROG_INSTALL.
1700 Mon Sep 15 22:40:55 1997 Jim Wilson (wilson@cygnus.com)
1702 * dwarf2out.c (gen_subprogram_die): Handle redefinition of an
1703 extern inline function.
1705 Mon Sep 15 22:40:55 1997 Richard Henderson (rth@cygnus.com)
1707 * dwarf2out.c (reg_loc_descriptor): Fix prototype.
1708 (concat_loc_descriptor): New function.
1709 (loc_descriptor): Call it.
1710 (add_AT_location_description): Also elide the descriptor if both
1711 halves of a CONCAT are pseudos.
1712 (add_location_or_const_value_attribute): Recognize CONCAT too.
1714 Mon Sep 15 15:24:00 1997 Richard Henderson <rth@cygnus.com>
1716 * alpha.md (movdi): Handle CONST_DOUBLE for TARGET_BUILD_CONSTANTS.
1718 * alpha/alpha.c (output_prolog): New variable sa_reg. Use it for
1719 out-or-range reg_offset.
1720 (output_epilog): Likewise.
1722 Mon Sep 15 15:39:26 1997 Jeffrey A Law (law@cygnus.com)
1724 * cse.c (simplify_relational_operation): If MODE specifies a
1725 mode wider than HOST_WIDE_INT, then the high word of a CONST_INT
1726 is derived from the sign bit of the low word.
1728 Mon Sep 15 11:43:38 1997 Jason Merrill <jason@yorick.cygnus.com>
1730 Support dwarf2 unwinding on PUSH_ROUNDING targets like the x86.
1732 * dwarf2.h: Add DW_CFA_GNU_args_size.
1733 * frame.c (execute_cfa_insn): Likewise.
1734 * dwarf2out.c (dwarf_cfi_name, output_cfi): Likewise.
1735 (dwarf2out_args_size, dwarf2out_stack_adjust): New fns.
1736 (dwarf2out_frame_debug): If this isn't a prologue or epilogue
1737 insn, hand it off to dwarf2out_stack_adjust.
1738 (dwarf2out_begin_prologue): Initialize args_size.
1739 * frame.h (struct frame_state): Add args_size.
1740 * libgcc2.c (__throw): Use args_size.
1741 * final.c (final_scan_insn): If we push args, hand off all insns
1742 to dwarf2out_frame_debug.
1743 * defaults.h (DWARF2_UNWIND_INFO): OK for !ACCUMULATE_OUTGOING_ARGS.
1745 * dwarf2out.c dwarf2out_frame_debug): Fix typo.
1746 Handle epilogue restore of SP from FP.
1747 * emit-rtl.c (gen_sequence): Still generate a sequence if the
1748 lone insn has RTX_FRAME_RELATED_P set.
1750 * frame.c (extract_cie_info): Handle "e" augmentation.
1751 * dwarf2out.c (ASM_OUTPUT_DWARF_*): Provide definitions in the
1752 absence of UNALIGNED_*_ASM_OP.
1753 (UNALIGNED_*_ASM_OP): Only provide defaults if OBJECT_FORMAT_ELF.
1754 (output_call_frame_info): Use "e" instead of "z" for augmentation.
1755 Don't emit augmentation fields length.
1756 (dwarf2out_do_frame): Move outside of #ifdefs.
1757 * defaults.h (DWARF2_UNWIND_INFO): Don't require unaligned data
1760 * sparc.h (UNALIGNED_INT_ASM_OP et al): Don't define here after all.
1761 * sparc/sysv4.h (UNALIGNED_INT_ASM_OP): Define here.
1762 * sparc/sunos4.h (DWARF2_UNWIND_INFO): Define to 0.
1763 * sparc/sun4gas.h: New file.
1764 * configure.in: Use sun4gas.h if SunOS 4 --with-gnu-as.
1766 * collect2.c (write_c_file_stat, write_c_file_glob): Declare
1767 __register_frame_table and __deregister_frame.
1769 1997-09-15 Brendan Kehoe <brendan@cygnus.com>
1771 * except.c (find_exception_handler_labels): Use xmalloc instead of
1772 alloca, since MAX_LABELNO - MIN_LABELNO can be more than 1 million
1775 Sun Sep 14 21:01:23 1997 Jeffrey A Law (law@cygnus.com)
1777 * Makefile.in: Various changes to build info files
1778 in the object tree rather than the source tree.
1780 Sun Sep 14 12:24:30 1997 Jeffrey A Law (law@cygnus.com)
1782 * fixinc.math: New file to fix math.h on some systems.
1783 * configure.in (freebsd, netbsd): Use fixinc.math on these
1785 * configure: Rebuilt.
1787 Sun Sep 14 11:11:05 1997 Jeffrey A Law (law@cygnus.com)
1789 * regmove.c (regmove_optimize): If we end up moving the
1790 original insn due to lifetime overlaps, make sure to move
1793 Sat Sep 13 15:51:11 1997 Manfred Hollstein <manfred@s-direktnet.de>
1795 * Makefile.in (INSTALL_{PROGRAM,DATA}): Use value found by configure.
1797 Sat Sep 13 12:57:26 1997 Jeffrey A Law (law@cygnus.com)
1799 * haifa-sched.c (add_branch_dependences): Make each insn in
1800 a SCHED_GROUP_P block explicitly depend on the previous insn.
1802 Fri Sep 12 13:49:58 1997 Jason Merrill <jason@yorick.cygnus.com>
1804 * except.h: Prototype dwarf2 hooks.
1807 Thu Sep 11 17:43:55 1997 Jim Wilson <wilson@cygnus.com>
1809 * configure.in (native_prefix): Delete.
1810 (mips-dec-netbsd): Don't set prefix.
1811 (*linux*): Don't set prefix.
1813 Thu Sep 11 15:48:32 1997 Fred Fish <fnf@ninemoons.com>
1815 * protoize.c: Include <varargs.h> only if HAVE_VARARGS_H is
1816 defined. If not defined, include <sys/varargs.h> if
1817 HAVE_SYS_VARARGS_H is defined.
1818 * configure.in: Test for varargs.h and sys/varargs.h.
1819 * configure: Regenerate with autoconf.
1820 * config.in: Regenerate with autoheader.
1822 * cpplib.c (quote_string): Cast first arg of sprintf call
1823 from "unsigned char *" to "char *".
1824 (output_line_command): Ditto.
1825 (macroexpand): Ditto.
1826 (do_line): Cast atoi arg from "unsigned char *" to "char *".
1828 Wed Sep 10 21:37:30 1997 Jeffrey A Law (law@cygnus.com)
1830 * version.c: Bump for snapshot.
1832 * Makefile.in (compare): Exit with nonzero status if there
1833 are comparison failures. Note which files failed the
1834 comparison test in .bad_compare.
1836 Wed Sep 10 17:05:46 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
1838 * config/alpha/elf.h (CPP_PREDEFINES): Remove -D__PIC__ -D__pic__.
1840 Wed Sep 10 16:37:28 1997 Fred Fish <fnf@ninemoons.com>
1842 * Makefile.in (LN, LN_S): New macros, use where appropriate.
1843 * aclocal.m4 (GCC_PROG_LN_S, GCC_PROG_LN): New tests.
1844 * configure.in: Use GCC_PROG_LN_S and GCC_PROG_LN.
1845 * configure: Regenerated.
1847 Thu Sep 11 11:09:43 1997 Jeffrey A Law (law@cygnus.com)
1849 * loop.c (strength_reduce): Fix typo.
1851 Wed Sep 10 16:01:15 1997 Jim Wilson <wilson@cygnus.com>
1853 * m88k/m88k.c (struct option): Rename to struct options.
1854 * m88k/dolph.h (INITIALIZE_TRAMPOLINE): Delete here.
1855 * m88k/sysv3.h (INITIALIZE_TRAMPOLINE): Delete ifdef and comments.
1856 * libgcc2.c (__enable_execute_stack): Check for __sysV88__ not
1857 __DOLPHIN__ or sysV88.
1859 Wed Sep 10 14:58:40 1997 Jim Wilson <wilson@cygnus.com>
1861 * emit-rtl.c (gen_lowpart_common): For a SUBREG, add in word when
1864 Wed Sep 10 15:19:22 1997 Jeffrey A Law (law@cygnus.com)
1866 * config.sub: Accept 'amigados' for backward compatability.
1868 Wed Sep 10 14:05:08 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
1870 * Makefile.in (testsuite/site.exp): New target.
1871 (check-gcc, check-g++): Depend on testsuite/site.exp.
1872 Don't stop for failure.
1874 Wed Sep 10 12:59:57 1997 Jason Merrill <jason@yorick.cygnus.com>
1876 * expr.c (expand_builtin): Only support __builtin_dwarf_fp_regnum()
1877 if DWARF2_UNWIND_INFO.
1879 Wed Sep 10 11:49:20 1997 Jason Merrill <jason@yorick.cygnus.com>
1881 Add support for exception handling using DWARF 2 frame unwind info.
1882 Currently works on SPARC and MIPS, and almost on x86.
1884 * libgcc2.c (get_reg, put_reg, get_return_addr, put_return_addr,
1885 next_stack_level, in_reg_window): Helper fns.
1886 (__throw): Implement for DWARF2_UNWIND_INFO.
1888 * expr.c (expand_builtin): Handle builtins used by __throw.
1889 * tree.h (enum built_in_function): Add builtins used by __throw.
1890 * c-decl.c (init_decl_processing): Declare builtins used by __throw.
1891 * dwarf2out.c (expand_builtin_dwarf_fp_regnum): Used by __throw.
1892 * except.c (expand_builtin_unwind_init): Hook for dwarf2 __throw.
1893 (expand_builtin_extract_return_addr): Likewise.
1894 (expand_builtin_frob_return_addr): Likewise.
1895 (expand_builtin_set_return_addr_reg): Likewise.
1896 (expand_builtin_eh_stub): Likewise.
1897 (expand_builtin_set_eh_regs): Likewise.
1898 (eh_regs): Choose two call-clobbered registers for passing back values.
1900 * frame.c, frame.h: New files for parsing dwarf 2 frame info.
1901 * Makefile.in (LIB2ADD): New variable. Add $(srcdir)/frame.c.
1902 (libgcc2.a): Use it instead of $(LIB2FUNCS_EXTRA) $(LANG_LIB2FUNCS)
1903 (stmp-multilib): Likewise.
1904 ($(T)crtbegin.o, $(T)crtend.o): Add -fno-exceptions.
1906 * except.c: #include "defaults.h".
1907 (exceptions_via_longjmp): Default depends on DWARF2_UNWIND_INFO.
1908 (emit_throw): Don't defeat assemble_external if DWARF2_UNWIND_INFO.
1909 (register_exception_table_p): New fn.
1910 (start_eh_unwinder): Don't do anything if DWARF2_UNWIND_INFO.
1911 (end_eh_unwinder): Likewise.
1913 * crtstuff.c: Wrap .eh_frame section, use EH_FRAME_SECTION_ASM_OP,
1914 call __register_frame and __deregister_frame as needed.
1915 * varasm.c (eh_frame_section): New fn if EH_FRAME_SECTION_ASM_OP.
1916 * dwarf2out.c (EH_FRAME_SECTION): Now a function-like macro. Check
1917 EH_FRAME_SECTION_ASM_OP.
1918 * sparc/sysv4.h (EH_FRAME_SECTION_ASM_OP): Define.
1919 * mips/iris6.h: (EH_FRAME_SECTION_ASM_OP): Define.
1920 (LINK_SPEC): Add __EH_FRAME_BEGIN__ to hidden symbols.
1922 * dwarf2out.c (output_call_frame_info): If no support for
1923 EXCEPTION_SECTION, mark the start of the frame info with a
1925 * collect2.c (frame_tables): New list.
1926 (is_ctor_dtor): Recognise frame entries.
1927 (scan_prog_file): Likewise.
1928 (main): Pass -fno-exceptions to sub-compile. Also do collection
1929 if there are any frame entries.
1930 (write_c_file_stat): Call __register_frame_table and
1931 __deregister_frame as needed.
1932 (write_c_file_glob): Likewise.
1934 * defaults.h (DWARF2_UNWIND_INFO): Default to 1 if supported.
1935 Also require unaligned reloc support.
1936 * sparc.h (UNALIGNED_SHORT_ASM_OP, UNALIGNED_INT_ASM_OP,
1937 UNALIGNED_DOUBLE_INT_ASM_OP): Define here.
1938 * sparc/sysv4.h: Not here.
1940 * toplev.c (compile_file): Call dwarf2out_frame_{init,finish}.
1941 * dwarf2out.c (dwarf2out_init): Don't call dwarf2out_frame_init.
1942 (dwarf2out_finish): Don't call dwarf2out_frame_finish.
1944 * libgcc2.c (L_eh): Reorganize, moving code shared by different
1945 EH implementations to the top.
1946 (find_exception_handler): Split out. Start from 0. Compare against
1948 (__find_first_exception_table_match): Use it.
1949 * except.c (output_exception_table): Don't do anything if there's
1950 no table. Don't output a first entry of zeroes.
1951 (eh_outer_context): Adjust properly.
1952 (add_eh_table_entry): Use xrealloc.
1953 * toplev.c (compile_file): Just call output_exception_table.
1955 Wed Sep 10 11:30:36 1997 Jason Merrill <jason@cygnus.com>
1957 * i386.c (ix86_prologue): Add dwarf2 support for !do_rtl case.
1959 Wed Sep 10 08:17:10 1997 Torbjorn Granlund <tege@pdc.kth..se>
1961 * except.c (eh_outer_context): Do masking using expand_and.
1963 Wed Sep 10 01:38:30 1997 Doug Evans <dje@cygnus.com>
1965 Add port done awhile ago for the ARC cpu.
1966 * arc/arc.h: New file.
1967 * arc/arc.c: New file.
1968 * arc/arc.md: New file.
1969 * arc/initfini.c: New file.
1970 * arc/lib1funcs.asm: New file.
1971 * arc/t-arc: New file.
1972 * arc/xm-arc.h: New file.
1973 * ginclude/va-arc.h: New file.
1974 * ginclude/stdarg.h: Include va-arc.h ifdef __arc__.
1975 * ginclude/varargs.h: Likewise.
1976 * Makefile.in (USER_H): Add va-arc.h.
1977 * configure.in (arc-*-elf*): Recognize.
1978 * longlong.h: Add ARC support.
1980 Wed Sep 10 01:32:54 1997 Jeffrey A Law (law@cygnus.com)
1982 * expr.c (clear_storage): Use CONST0_RTX instead of const0_rtx.
1983 when clearing non-BLKmode data.
1985 Wed Sep 10 00:29:29 1997 Manfred Hollstein <manfred@s-direktnet.de>
1987 * m88k/sysv3.h (INITIALIZE_TRAMPOLINE) Define.
1988 * libgcc2.c (__enable_execute_stack): Provide for sysV88 too.
1990 * xm-m88k.h (USG): Only define if it hasn't already been defined.
1992 * Makefile.in (risky-stage1): Delete gratutious whitespace.
1994 * Makefile.in (clean): Delete libgcc1-test.
1996 * Makefile.in (INSTALL): cd to $(srcdir) before running texinfo.
1998 Tue Sep 9 17:07:36 1997 Stan Cox <coxs@dg-rtp.dg.com>
2000 * m88k.c (m88k_expand_prologue): Set MEM_IN_STRUCT_P of va_list
2003 Tue Sep 9 09:50:02 1997 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
2005 * dwarf2out.c (output_call_frame_info): Call named_section.
2007 Tue Sep 9 09:12:17 1997 Jeffrey A Law (law@cygnus.com)
2009 * haifa-sched.c (print_value): Fix last change.
2011 Tue Sep 9 01:30:37 1997 Jason Merrill <jason@yorick.cygnus.com>
2013 * mips.h (DWARF_FRAME_REGNUM): Use the same numbering regardless of
2016 Mon Sep 8 16:32:43 1997 Jason Merrill <jason@yorick.cygnus.com>
2018 * mips.c (function_prologue): Set up the CFA when ABI_32.
2020 * sparc.c (save_regs): Check dwarf2out_do_frame instead of DWARF2_DEBUG
2021 for dwarf2 unwind info.
2022 (output_function_prologue, sparc_flat_output_function_prologue): Same.
2024 * final.c (final_end_function): Check dwarf2out_do_frame instead
2025 of DWARF2_DEBUG for dwarf2 unwind info.
2026 (final_scan_insn): Likewise.
2027 (final_start_function): Likewise. Initialize dwarf2 frame debug here.
2030 * expr.c (expand_builtin_return_addr): Only SETUP_FRAME_ADDRESSES if
2033 * varasm.c (exception_section): Check EXCEPTION_SECTION first.
2035 Mon Sep 8 15:15:11 1997 Nick Clifton <nickc@cygnus.com>
2037 * v850.h (ASM_SPEC): Pass on target processor.
2038 (CPP_PREDEFINES): Only define if not already specified.
2039 (TARGET_VERSION): Only define if not already specified.
2040 (MASK_CPU, MASK_V850, MASK_DEFAULT): Bits to specify target
2042 (EXTRA_SWITCHES): Extra entries in the switches array.
2043 (TARGET_DEFAULT): Set default target processor.
2045 Mon Sep 8 18:26:35 1997 Jim Wilson <wilson@cygnus.com>
2047 * m68k.h (MACHINE_STATE_SAVE, MACHINE_STATE_RESTORE): In MOTOROLA
2048 cases, add %# and %/, and add : to make them into extended asms.
2050 Sun Sep 7 23:57:50 1997 Weiwen Liu <liu@hepunix.physics.yale.edu>
2052 * alias.c (init_alias_analysis): Clean up incompatible pointer
2053 type warning in bzero.
2054 * regmove.c (regmove_optimize): Ditto.
2055 * haifa-sched.c (find_rgns): Ditto.
2057 * haifa-sched.c (print_value): Clean up ptr->int cast
2060 Sun Sep 7 23:18:32 1997 Fred Fish <fnf@ninemoons.com>
2062 * INSTALL: Change 'amigados' to 'amigaos' to match current usage.
2063 * install.texi (Configurations): Ditto.
2064 * config.sub: Ditto.
2066 Sun Sep 7 22:56:56 1997 Weiwen Liu (liu@hepvms.physics.yale.edu)
2068 * Makefile.in (sdbout.o): Depend on insn-config.h.
2070 Sun Sep 7 18:44:50 1997 Jim Wilson <wilson@cygnus.com>
2072 * m68k/m68k.h (TARGET_SWITCHES): For 68000, 68302, subtract MASK_68881.
2073 For 68303, 68332, cpu32, subtract MASK_68040_ONLY.
2075 Sun Sep 7 18:30:46 1997 Jason Merrill <jason@yorick.cygnus.com>
2077 * dwarf2out.c (dwarf2out_frame_debug): Assume that in a PARALLEL
2078 prologue insn, only the first elt is significant.
2079 (output_call_frame_info): For exception handling, always use 4-byte
2080 fields as specified by the dwarf2 spec.
2081 Don't skip trivial FDEs.
2083 Sun Sep 7 14:19:39 1997 Jeffrey A Law (law@cygnus.com)
2085 * version.c: Bump for snapshot.
2087 Sun Sep 7 14:17:36 1997 Torbjorn Granlund (tege@pdc.kth.se)
2089 * expmed.c (expand_divmod): Make op1_is_pow2 depend on unsignedp
2090 for negative constants. Promote EXACT_DIV_EXPR to TRUNC_DIV_EXPR
2093 Sun Sep 7 13:46:46 1997 Jeffrey A Law (law@cygnus.com)
2095 * final.c (shorten_branches): During first pass, assume worst
2096 possible alignment for ADDR_VEC and ADDR_VEC_DIFF insns.
2098 * Makefile.in (distclean): Remove various things left around
2099 by running the testsuite.
2101 Sun Sep 7 13:16:06 1997 Manfred Hollstein <manfred@s-direktnet.de>
2103 * configure.in (out_file): Emit definition to config.status in order
2104 to have a defined value for configure.lang.
2105 * configure: Re-built.
2107 Sun Sep 7 09:59:08 1997 Jan-Jaap van der Heijden (J.J.vanderHeijden@student.utwente.nl)
2109 * configure.in: Make symlink to as-new rather than as.new. Similarly
2111 * configure: Rebuilt.
2113 Fri Sep 5 16:54:55 1997 Jim Wilson <wilson@cygnus.com>
2115 * profile.c (output_func_start_profiler): Set DECL_EXTERNAL to zero.
2117 Fri Sep 5 16:16:44 1997 Christian Kuehnke <Christian.Kuehnke@arbi.Informatik.Uni-Oldenburg.DE>
2119 * sparc/sparc.md: Add ultrasparc scheduling support.
2120 * sparc/sparc.h (RTX_COSTS): For MULT give v9 a cost of 25 insns.
2122 Fri Sep 5 14:04:59 1997 Philippe De Muyter <phdm@info.ucl.ac.be>
2124 * integrate.c (save_for_inline_copying): Use 0, not NULL_PTR,
2125 as initial value for real_label_map.
2126 (copy_for_inline): Likewise.
2128 Fri Sep 5 13:36:44 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
2130 * sched.c (update_flow_info) When looking if to set found_split_dest
2131 or found_orig_dest, look at all parts of a PARALLEL.
2132 * haifa-sched.c (update_flow_info): Likewise.
2134 Fri Sep 5 10:08:44 1997 Jeffrey A Law (law@cygnus.com)
2136 * v850: New directory for v850 port.
2137 * v850/lib1funcs.asm: New file.
2138 * t-v850, v850.c, v850.h, v850.md, xm-v850.h: New files.
2139 * ginclude/va-v850.h: New file.
2140 * ginclude/varargs.h, ginclude/stdarg.h: Include va-mn10200.h.
2141 * configure.in (mn10200-*-*): New target.
2142 * configure: Rebuilt.
2143 * config.sub: Handle v850-elf.
2144 * Makefile.in (USER_H): Add va-mn10200.h.
2145 * invoke.texi: Document v850 stuff.
2147 Fri Sep 5 09:37:50 1997 Jim Wilson (wilson@cygnus.com)
2149 * sdbout.c (plain_type_1, case ARRAY_TYPE): Verify that TYPE_DOMAIN
2150 has integer TYPE_{MAX,MIN}_VALUE before using them.
2152 * m68k/m68k.h (MACHINE_STATE_SAVE, MACHINE_STATE_RESTORE): Add
2153 __HPUX_ASM__ versions.
2155 Fri Sep 5 09:08:44 1997 Jeffrey A Law (law@cygnus.com)
2157 * install.sh: Delete duplicate install script.
2159 Thu Sep 4 23:14:27 1997 Stan Cox (coxs@dg-rtp.dg.com)
2161 * reg-stack.c (subst_stack_regs): Pop the stack register for a
2162 computed goto which sets the same stack register.
2164 * reg-stack.c (compare_for_stack_reg): Swap only if the source and
2165 destination are both on the regstack.
2166 (subst_stack_regs_pat): Put the destination at the top of the regstack.
2168 Thu Sep 4 15:02:27 1997 Jim Wilson <wilson@cygnus.com>
2170 * mips.md (nonlocal_goto_receiver): Define.
2172 * profile.c (output_arc_profiler): Check next_insert_after for non
2173 NULL before deferencing it.
2175 * i386/t-sol2 (TARGET_LIBGCC2_CFLAGS): Define to -fPIC.
2177 Thu Sep 4 14:51:57 1997 Jeffrey A Law (law@cygnus.com)
2179 * i386.h (CPP_CPU_DEFAULT): Avoid using #elif.
2181 Thu Sep 4 15:01:49 1997 Michael Meissner <meissner@cygnus.com>
2183 * toplev.c (rest_of_compilation): For passes starting with
2184 flow_analysis, use print_rtl_with_bb instead of print_rtl.
2186 * print-rtl.c (print_rtl_single): Print a single rtl value to a
2189 * flow.c (print_rtl_with_bb): Print which insns start and end
2190 basic blocks. For the start of a basic block, also print the live
2193 Thu Sep 4 11:51:43 1997 Jim Wilson <wilson@cygnus.com>
2195 * toplev.c (main): Change #elif to #else/#ifdef
2197 * tlink.c: Include ctype.h.
2198 * ginclude/va-mips.h: Add _VA_MIPS_H_ENUM ifdef/define/endif.
2200 Thu Sep 4 11:17:16 1997 Mikeael Meissner (meissner@cygnus.com)
2202 * bitmap.c: Conditionally include stdlib.h.
2203 (free): Provide a declaration if NEED_DECLARATION_FREE.
2205 Thu Sep 4 09:58:53 1997 Joel Sherrill (joel@OARcorp.com)
2207 * i960/i960.h: Added default for SUBTARGET_SWITCHES macro.
2209 Thu Sep 4 09:53:20 1997 Jim Wilson (wilson@cygnus.com)
2211 * profile.c (output_arc_profiler): Verify next_insert_after is an
2212 INSN before and after skipping a stack pop.
2214 Thu Sep 4 07:39:19 1997 J"orn Rennecke <amylaar@cygnus.co.uk>
2216 * final.c (shorten_branches): Don't count the lengths of deleted
2219 Thu Sep 4 09:43:01 1997 Jeffrey A Law (law@cygnus.com)
2221 * version.c: Bump for snapshot.
2223 Thu Sep 4 11:04:21 1997 Michael Meissner <meissner@cygnus.com>
2225 * bitmap.h (EXECUTE_IF_AND_IN_BITMAP): New macro, to iterate over
2226 two bitmaps ANDed together.
2227 (bitmap_print): Declare.
2229 * bitmap.c (function_obstack): Don't declare any more.
2230 (bitmap_obstack): Obstack for allocating links from.
2231 (bitmap_obstack_init): New static to say whether to initialize
2233 (bitmap_element_allocate): Use bitmap_obstack to allocate from.
2234 (bitmap_release_memory): Free all memory allocated from
2237 * basic-block.h (EXECUTE_IF_AND_IN_REG_SET): New macro, invoke
2238 EXECUTE_IF_AND_IN_BITMAP.
2240 Wed Sep 3 10:39:42 1997 Jim Wilson <wilson@cygnus.com>
2242 * alias.c (true_dependence): Address with AND can alias scalars.
2243 (anti_dependence, output_dependence): Likewise.
2245 * alias.c (true_dependence): Test x for BLKmode, in addition to mem.
2247 Wed Sep 3 09:28:50 CDT 1997 Joel Sherrill (joel@OARcorp.com)
2249 * i386/go32-rtems.h, i386/rtems.h, i960/rtems.h, m68k/rtems.h,
2250 mips/rtems64.h, pa/rtems.h, rs6000/rtems.h, sh/rtems.h,
2251 sparc/rtems.h (subtarget_switches): Removed SUBTARGET_SWITCHES
2252 definitions. Use -qrtems instead of -mrtems.
2254 Wed Sep 3 09:05:41 1997 Robert Lipe (robert@dgii.com)
2256 * xm-sco5.h (sys_siglist): Define.
2257 (SYS_SIGLIST_DECLARED): Likewise.
2259 Tue Sep 2 23:33:33 1997 Jeffrey A Law (law@cygnus.com)
2261 * expr.c (convert_move): Handle truncation from TQFmode to QFmode.
2263 Wed Sep 3 02:09:30 1997 Torbjorn Granlund <tege@pdc.kth..se>
2265 * except.c (eh_outer_context): Expand masking operation using
2268 Tue Sep 2 18:09:39 1997 Jim Wilson <wilson@cygnus.com>
2270 * alpha.md (floatdisf2-1): New pattern.
2272 Tue Sep 2 18:41:55 1997 Jeffrey A Law (law@cygnus.com)
2274 * xm-svr4.h (SYS_SIGLIST_DECLARED): Define.
2275 * xm-news.h (SYS_SIGLIST_DECLARED): Likewise.
2276 * xm-sysv4.h (SYS_SIGLIST_DECLARED): Likewise.
2277 * gcc.texi: Note that if you define sys_siglist that you should
2278 also define SYS_SIGLIST_DECLARED.
2280 * mn10200.h (INITIALIZE_TRAMPOLINE): PC relative instructions
2281 are relative to the next instruction, not the current instruction.
2283 Tue Sep 2 14:22:43 1997 Jim Wilson <wilson@cygnus.com>
2285 * local-alloc.c (contains_replace_regs): New function.
2286 (update_equiv_regs): When adding a REG_EQUIV note for a set of a MEM,
2287 verify that there is no existing REG_EQUIV note, and add a call to
2288 contains_place_regs.
2290 Tue Sep 2 12:48:11 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
2292 * config/alpha/elf.h (CPP_PREDEFINES): Add -D__PIC__ -D__pic__.
2293 (STARTFILE_SPEC): Always use crtbegin.o%s
2294 (ENDFILE_SPEC): Always use crtend.o%s.
2296 Tue Sep 2 12:00:36 1997 Jim Wilson <wilson@cygnus.com>
2298 * alpha/alpha.h (PREFERRED_RELOAD_CLASS): Return NO_REGS if NO_REGS
2300 * emit-rtl.c (gen_lowpart_common): Add code to convert CONST_INT to
2301 SFmode for 64 bit hosts.
2303 Tue Sep 2 13:42:38 1997 Paul N. Hilfinger <hilfingr@CS.Berkeley.EDU>
2305 * fixincludes: Permits spaces between # and define. Discard C++
2306 comments in sys/pci.h on HP/UX 10.20.
2308 Mon Sep 1 22:13:18 1997 Jeffrey A Law (law@cygnus.com)
2310 * version.c: Bump for snapshot.
2312 * pa.c (restore_unscaled_index_insn_codes): New function.
2313 (record_unscaled_index_insn_codes): Likewise.
2314 (output_function_prologue): Call restore_unscaled_index_insn_codes.
2315 (output_function_epilogue): Free memory for unscaled_index_insn_codes.
2316 (pa_reorg): Call record_unscaled_index_insn_codes.
2318 * haifa-sched.c (move_insn): Handle notes correctly for insns
2319 with SCHED_GROUP_P set.
2321 Mon Sep 1 16:58:57 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
2323 * alpha/xm-linux.h (USE_BFD): Undef before define.
2325 Mon Sep 1 16:25:34 1997 Jim Wilson <wilson@cygnus.com>
2327 * cse.c (cse_insn): Don't record BLKmode values.
2329 Mon Sep 1 11:25:47 1997 Stephen Williams (steve@icarus.icarus.com)
2331 * i960.h (LINK_SPEC): Handle "-mjX" and "-mrp" switches.
2333 Mon Sep 1 08:29:46 1997 Jeffrey A Law (law@cygnus.com)
2335 * cccp.c (sys_errlist): Remove special 4.4bsd declaration.
2336 * collect2.c (sys_errlist): Likewise.
2337 * cpplib.c (sys_errlist): Likewise.
2338 * gcc.c (sys_errlist): Likewise.
2339 * protoize (sys_errlist): Likewise.
2340 * configure.in: Check for strerror.
2341 * xm-freebsd.h (HAVE_STRERROR): Remove definition.
2342 * xm-gnu.h (HAVE_STRERROR): Likewise.
2343 * xm-linux.h (HAVE_STRERROR): Likewise.
2344 * xm-netbsd.h (HAVE_STRERROR): Likewise.
2345 * xm-bsd386.h (HAVE_STRERROR): Likewise.
2346 * xm-cygwin32.h (HAVE_STRERROR): Likewise.
2347 * xm-dos.h (HAVE_STRERROR): Likewise.
2348 * xm-mingw32.h (HAVE_STRERROR): Likewise.
2349 * xm-pa.h (HAVE_STRERROR): Likewise.
2350 * xm-papro.h (HAVE_STRERROR): Likewise.
2351 * xm-sysv4.h (HAVE_STRERROR): Likewise.
2352 * configure, config.in: Rebuilt.
2354 * Makefile.in: Add several missing "else true" clauses.
2356 * collect2.c: Change DONT_DECLARE_SYS_SIGLIST to SYS_SIGLIST_DECLARED.
2357 * mips-tfile.c: Likewise.
2358 * gcc.texi: DONT_DECLARE_SYS_SIGLIST: Remove docs.
2359 * xm-linux.h (DONT_DECLARE_SYS_SIGLIST): Delete definition.
2360 * xm-freebsd.h, xm-bsd386.h, xm-sysv4.h, xm-sol2.h: Likewise.
2361 * configure.in: Check for sys_siglist declaration.
2362 * configure, config.in: Rebuilt.
2364 Mon Sep 1 08:04:07 1997 Joel Sherrill (joel@OARcorp.com)
2366 * i386/go32-rtems.h, i386/rtems.h, i960/rtems.h,
2367 m68k/rtems.h, mips/rtems64.h, pa/rtems.h, rs6000/rtems.h,
2368 sparc/rtems.h (subtarget_switches): Added -mrtems as a switch.
2369 * i960/i960.h: Added SUBTARGET_SWITCHES macro.
2370 * rs6000/sysv4.h (extra_subtarget_switches): Added new
2371 macro EXTRA_SUBTARGET_SWITCHES.
2372 * configure.in (sh*-*-rtems*): New target.
2373 * sh/rtems.h: New file.
2374 * sh/sh.h: Added SUBTARGET_SWITCHES macro.
2375 * configure: Rebuilt.
2377 Sat Aug 30 22:54:26 1997 Jim Wilson <wilson@cygnus.com>
2379 * unroll.c (calculate_giv_inc): Handle increment with code PLUS.
2381 Sat Aug 30 10:49:46 1997 David Edelsohn <edelsohn@mhpcc.edu>
2383 * rs6000.md: Make DF fused-add operations pay attention to
2386 Fri Aug 29 19:19:54 1997 Jim Wilson <wilson@cygnus.com>
2388 * i386/xm-sysv4.h (DONT_DECLARE_SYS_SIGLIST): Define.
2390 Fri Aug 29 16:13:51 1997 Jeffrey A Law (law@cygnus.com)
2392 * pa.md (reload_peepholes): Make sure operand is a REG before
2393 examining REGNO. Allow general registers too.
2395 Fri Aug 29 11:42:04 1997 Jim Wilson <wilson@cygnus.com>
2397 * varasm.c (mark_constants): Don't look inside CONST_DOUBLEs.
2399 Fri Aug 29 09:33:20 1997 Philipp Thomas (kthomas@lxi165.gwdg.de)
2401 * dwarf2out.c (build_abbrev_table): Use xrealloc, not xmalloc
2402 to reallocate abbrev_die_table.
2404 Thu Aug 28 15:14:46 1997 Jim Wilson <wilson@cygnus.com>
2406 * m68k/m68k.md (iorsi_zexthi_ashl16): Disable.
2408 1997-08-27 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
2410 * Makefile.in (config.status): Depend on version.c
2412 * expr.h (insn_gen_function): Reenable prototype.
2414 * expr.c (move_by_pieces_1, clear_by_pieces_1): Fix prototype of
2417 Thu Aug 28 13:01:43 1997 Jim Wilson <wilson@cygnus.com>
2419 * i386.c (ix86_expand_epilogue): Emit blockage instruction when pic.
2421 Thu Aug 28 07:03:15 1997 Jeffrey A Law (law@cygnus.com)
2423 * version.c: Bump for latest snapshot.
2425 * bc-optab.c: Conditionally include stdlib.h.
2426 (free): Provide a declaration if NEED_DECLARATION_FREE.
2427 * tree.c (free): Provide a declaration if NEED_DECLARATION_FREE.
2428 * rtl.h (free): Remove declaration.
2429 * tree.h (free): Remvoe declaration.
2431 * configure: Rebuilt.
2433 Wed Aug 27 21:32:20 1997 Jeffrey A Law (law@cygnus.com)
2435 * flags.h (flag_move_all_movables): Declare.
2436 (flag_reduce_all_givs): Likewise.
2437 * loop.c (move_movables): Handle flag_move_all_movables.
2438 (strength_reduce): Handle flag_reduce_all_givs.
2439 * toplev.c (flag_move_all_movables): Define.
2440 (flag_reduce_all_givs): Likewise.
2441 (f_options): Add -fmove-all-movables and -freduce-all-givs.
2442 * invoke.texi: Document new options, including alias stuff that
2443 wasn't included last time.
2445 Wed Aug 27 18:08:51 1997 Bob Manson (manson@cygnus.com)
2447 * t-h8300: Use TARGET_LIBGCC2_CFLAGS instead of LIBGCC2_CFLAGS.
2450 * t-vxworks68: Ditto.
2451 * t-vxworks960: Ditto.
2454 Wed Aug 27 16:35:29 1997 Richard Henderson <rth@cygnus.com>
2456 * alpha/xm-alpha.h (alloca): Define alloca to builtin_alloca for GNUC
2457 if not already defined, and USE_C_ALLOCA not defined.
2459 Wed Aug 27 16:08:43 1997 Jim Wilson <wilson@cygnus.com>
2461 * config.guess: Replace with script that uses ../config.guess.
2463 * config/alpha/elf.h (DEFAULT_VTABLE_THUNKS): New. Defined as 1
2464 if USE_GNULIBC_1 is not defined.
2466 Wed Aug 27 15:49:12 1997 Richard Henderson <rth@cygnus.com>
2468 * alpha/elf.h (LINK_SPEC): Conditionalize on USE_GNULIBC_1.
2469 * config.guess: Recognize alpha-linux-gnulibc1.
2470 * configure.in (alpha-*-linux-gnulibc1): New target.
2471 (alpha-*-linux-gnu*): Don't build crtbegin/end.
2473 Wed Aug 27 11:52:58 1997 Jim Wilson <wilson@cygnus.com>
2475 * m68k.md (iorsi3_internal): Readd ! TARGET_5200 check lost in
2478 Wed Aug 27 01:56:18 1997 Doug Evans <dje@seba.cygnus.com>
2480 * loop.c (combine_movables): Earlier insns don't match later ones.
2482 Wed Aug 27 01:24:25 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
2484 * config/linux.h (CC1_SPEC): Define it only if not defined.
2486 * config/m68k/linux.h (CC1_SPEC): Undefine it before include
2489 * config/linux.h (DEFAULT_VTABLE_THUNKS): New. Defined as 1 if
2490 USE_GNULIBC_1 is not defined.
2492 * config/rs6000/linux.h (DEFAULT_VTABLE_THUNKS): New. Defined as 1.
2494 * config/sparc/linux.h (DEFAULT_VTABLE_THUNKS): New. Defined
2495 as 1 if USE_GNULIBC_1 is not defined.
2497 Wed Aug 27 00:49:14 1997 Jeffrey A Law (law@cygnus.com)
2499 * reorg.c (dbr_schedule): Allow current_function_return_rtx
2500 to be something other than a REG.
2501 * function.c (expand_function_end): Fix current_function_return_rtx
2504 * t-freebsd (USER_H): Include EXTRA_HEADERS and LANG_EXTRA_HEADERS.
2505 * x-netbsd: Likewise
2506 * x-dgux (USER_H): Include EXTRA_HEADERS and LANG_EXTRA_HEADERS
2507 (INSTALL_HEADERS): Delete.
2508 * x-dguxbcs: Likewise.
2509 * x-hp3bsd44: Likewise
2512 Wed Aug 27 00:30:00 1997 Bernd Schmidt <crux@pool.informatik.rwth-aachen.de>
2514 * i386.md (pop): pop increments the stack pointer.
2515 (prologue_set_stack_ptr): New pattern.
2516 * i386.c (ix86_expand_prologue): Use prologue_set_stack_ptr
2519 Tue Aug 26 18:50:32 1997 Jim Wilson <wilson@cygnus.com>
2521 * reload.c (find_reloads, case '0'): Reject matching a non-offsettable
2522 address where an offsettable address is required.
2524 Tue Aug 26 17:54:56 1997 Michael P. Hayes (michaelh@ongaonga.chch.cri.nz>
2526 * loop.c (check_final_value): Don't miss a biv increment in a
2529 Tue Aug 26 12:03:49 1997 Jim Wilson (wilson@cygnus.com)
2531 * dwarfout.c (dwarfout_file_scope_decl, case TYPE_DECL): Check
2532 TYPE_DECL_IS_STUB instead of DECL_NAME.
2534 Mon Aug 25 23:27:10 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
2536 * objc/Make-lang.in ($(OBJC_O)): Also depend on cc1obj.
2538 Mon Aug 25 23:27:10 1997 Jim Meyering <meyering@eng.ascend.com>
2540 * objc/Make-lang.in ($(OBJC_O)): Also depend on $(GCC_PASSES).
2542 Mon Aug 25 13:12:24 1997 Jeffrey A Law (law@cygnus.com)
2544 * haifa-sched.c (find_pre_sched_live): Remove #if 0 code.
2545 (find_post_sched_live): Likewise.
2547 * haifa-sched.c (schedule_block): Remove old code to get arguments
2548 from hard regs into pseudos early.
2550 Mon Aug 25 08:55:00 1997 Jeffrey A Law (law@cygnus.com)
2552 * version.c: Bump for new snapshot.
2554 * local-alloc.c (update_equiv_regs): All the target to reject
2555 promotion of some REG_EQUAL to REG_EQUIV notes.
2556 * pa.h (DONT_RECORD_EQUIVALENCE): Define.
2558 * pa.c (secondary_reload_class): (mem (mem ... )) does not need
2561 * pa.c (hppa_builtin_saveregs): Emit a blockage insn after the
2562 store of the argument registers.
2564 Mon Aug 25 08:39:02 1997 Craig Burley (burley@gnu.ai.mit.edu)
2566 * fold-const.c (multiple_of_p): New function.
2567 (fold): Turn some cases of *_DIV_EXPR into EXACT_DIV_EXPR.
2569 Mon Aug 25 01:47:41 1997 Jeffrey A Law (law@cygnus.com)
2571 * expr.h (insn_gen_function): Temporarily remove prototype.
2573 Sun Aug 24 17:22:21 1997 Jim Wilson <wilson@cygnus.com>
2575 * Makefile.in (install-info): Don't cd into srcdir. Add srcdir to
2576 filenames. Use sed to extract base filename for install.
2578 Sat Aug 23 18:19:40 1997 John F. Carr <jfc@mit.edu>
2580 * unroll.c (find_splittable_givs): Only share if two givs have the
2581 same add and multiply values.
2583 Sat Aug 23 14:36:27 1997 Jim Wilson <wilson@cygnus.com>
2585 * m68k/next.h (GO_IF_INDEXABLE_BASE): Fix typo in undef.
2586 * m68k/m68kemb.h (LIB_SPEC): Add missing comment end before it.
2588 Sat Aug 23 00:18:22 1997 Jeffrey A Law (law@cygnus.com)
2590 * pa.c (pa_reorg): Always put begin_brtab and end_brtab insns
2591 around branch tables.
2592 * pa.md (begin_brtab, end_brtab): Only emit the .begin_brtab
2593 and .end_brtab directives if TARGET_GAS.
2595 Fri Aug 22 14:05:55 1997 Jim Wilson <wilson@cygnus.com>
2597 * alias.c (true_dependence): Pass x_addr not x to varies.
2599 * acconfig.h (NEED_DECLARATION_CALLOC): Add.
2600 * configure.in: Add GCC_NEED_DECLARATION call for calloc.
2601 * rs6000/xm-rs6000.h (malloc, realloc, calloc, free): Delete
2603 * config.in, configure: Regenerate.
2605 Thu Aug 21 23:52:16 1997 John F. Carr <jfc@mit.edu>
2607 * alias.c (find_base_value): Improve handling of PLUS, MINUS, and
2609 (record_set): Handle LO_SUM like PLUS.
2610 (init_alias_analysis): When following chains of base addresses,
2611 do not stop on reaching a hard register.
2613 Thu Aug 21 20:17:37 1997 Jeffrey A Law (law@cygnus.com)
2615 * version.c: Bump for new snapshot.
2617 Thu Aug 21 17:28:00 1997 Jim Wilson <wilson@cygnus.com>
2619 * alpha.h (ARCH_ASM_FILE_START): Define.
2620 (ASM_FILE_START): Use ARCH_ASM_FILE_START.
2621 * osf12.h, osf2or3.h (ARCH_ASM_FILE_START): Redefine to null string.
2623 Thu Aug 21 10:22:19 1997 Jeffrey A Law (law@cygnus.com)
2625 * Makefile.in (install-common): Put gcov comment at start of line.
2627 Wed Aug 20 22:47:33 1997 Jeffrey A Law (law@cygnus.com)
2629 * alias.c (init_alias_analysis): When simplifying the reg_base_value
2630 array, simplify entries for hard registers too.
2632 Wed Aug 20 12:35:47 1997 Dave Love <d.love@dl.ac.uk>
2634 * dwarf2.h (enum dwarf_call_frame_info): Remove trailing comma from
2637 Wed Aug 20 11:58:33 1997 Jim Wilson <wilson@cygnus.com>
2639 * stmt.c (start_cleanup_deferal, end_cleanup_deferal): Test
2640 block_stack before dereferencing it.
2642 Wed Aug 20 11:57:11 1997 Michael Meissner <meissner@cygnus.com>
2644 * rs6000.h (ISSUE_RATE): Define instead of MACHINE_issue_rate.
2646 Tue Aug 19 17:10:56 1997 Jason Merrill <jason@yorick.cygnus.com>
2648 * cplus-dem.c: Add 'extern' to prepends_underscore.
2650 Tue Aug 19 09:34:57 1997 Jeffrey A Law (law@cygnus.com)
2652 * haifa-sched.c (ISSUE_RATE): Renamed from MACHINE_issue_rate.
2653 (get_issue_rate): Delete.
2654 * pa.h (ISSUE_RATE): Define.
2656 * configure.in: Turn on haifa by default for the PA.
2657 * configure: Rebuilt.
2658 * pa.c (override_options): Accept -mschedule=7200 option.
2659 (pa_adjust_cost): No longer need to scale costs for newer
2661 * pa.h (enum processor_type): Add PROCESSOR_7200.
2662 * pa.md: Revamp scheduling parameters to work better with
2663 haifa. Add scheduling parameters for the 7200.
2665 * haifa-sched.c (move_insn): Reemit notes for SCHED_GROUP_P
2667 (schedule_block): When adjusting basic_block_{head,end}, account
2668 for movement of SCHED_GROUP_P insns too.
2670 * haifa-sched.c (debug_dependencies): Fix thinko.
2672 * Makefile.in (EXPECT, RUNTEST, RUNTESTFLAGS): Define.
2673 (site.exp, check, check-g++, check-gcc): New targets.
2675 * haifa-sched.c: Make lots of variables static.
2677 Tue Aug 19 07:18:34 1997 H.J. Lu (hjl@gnu.ai.mit.edu)
2679 * expr.h, real.h: Finish prototyping.
2681 Mon Aug 18 21:49:02 1997 Jim Wilson <wilson@cygnus.com>
2683 * reload.c (find_reloads): Add code to convert RELOAD_FOR_OPADDR_ADDR
2684 reloads to RELOAD_FOR_OPERAND_ADDRESS reloads.
2685 * reload1.c: Undo bugfix from Aug 11.
2687 Mon Aug 18 17:39:02 1997 Mike Meissner <meissner@cygnus.com>
2689 * configure.in ({powerpc,rs6000}*-*-*, --with-cpu): Remove single
2690 quotes around the name.
2691 * configure: Regenerate.
2693 Mon Aug 18 13:46:47 1997 Jim Wilson <wilson@cygnus.com>
2695 * Makefile.in (stmp-multilib-sub): Fix typo in last change.
2697 Thu Aug 7 10:33:13 1997 Manfred Hollstein <manfred@s-direktnet.de>
2699 * Makefile.in (sub-makes): Pass the current value of LANGUAGES down
2700 to sub-makes to avoid building more passes than the user might have
2701 requested on the command line.
2703 Sun Aug 17 15:42:17 1997 Dave Love (d.love@dl.ac.uk)
2705 * configure.in: Expurgate `broken_install' (install is
2708 * configure.lang: Substitute autoconfed ${INSTALL} (not currently
2711 Sat Aug 16 01:08:12 1997 Jeffrey A Law (law@cygnus.com)
2713 * loop.c (is_power_of_2, is_conditional_branch): Delete unused
2714 functions and declarations.
2715 (analyze_loop_iterations): Use condjump_p.
2716 (insert_bct): Likewise. Use exact_log2.
2718 Fri Aug 15 23:48:32 1997 Jeffrey A Law (law@cygnus.com)
2720 * haifa-sched.c (find_post_sched_live): Call FREE_REG_SET as needed.
2721 (schedule_region): Likewise.
2722 (schedule_insns): Likewise.
2724 * PROJECTS: Update with Haifa stuff.
2726 Fri Aug 15 12:49:56 1997 Jeffrey A Law (law@cygnus.com)
2728 * version.c: Change the version string to look like:
2729 egcs-2.90.00 970814 (gcc2-970802 experimental).
2731 * loop.c (is_conditional_branch): Make definition match declaration.
2733 * gcc.c: Take out experimental snapshot warning message.
2735 Fri Aug 15 13:43:39 1997 Michael Meissner <meissner@cygnus.com>
2737 * haifa-sched.c (debug_dependencies): Use GET_NOTE_INSN_NAME to
2738 print out the names of the notes. Print out the name of the insn
2739 that is not a note, and not an {,CALL_,JUMP_}INSN.
2741 Wed Aug 13 17:32:38 1997 Jason Merrill <jason@yorick.cygnus.com>
2743 * expr.c (expand_expr, case TARGET_EXPR): Call mark_addressable
2744 again for the slot after we give it RTL.
2746 Wed Aug 13 01:03:37 1997 Doug Evans <dje@canuck.cygnus.com>
2748 * configure.in (haifa configury): Fix typo.
2749 * configure: Regenerate.
2751 Tue Aug 12 10:20:36 1997 Jeffrey A Law (law@cygnus.com)
2753 * version.c: Bump version to "gcc-3.0.0 970802 experimental".
2755 * gcc.info*: Rebuilt.
2757 * COPYING.g77, README.g77: New files.
2758 * real.c (ereal_unto_float, ereal_unto_double): New functions.
2759 * real.h (ereal_unto_float, ereal_unto_double): Declare them.
2760 (REAL_VALUE_UNTO_TARGET_DOUBLE, REAL_VALUE_UNTO_TARGET_SINGLE): Define.
2762 Mon Aug 11 14:50:55 1997 Jeffrey A Law (law@cygnus.com)
2764 * Integrate Haifa instruction scheduler.
2765 * Makefile.in (ALL_CFLAGS): Add SCHED_CFLAGS. Prefix all references
2766 to sched with $(SCHED_CFLAGS.
2767 * configure.in: Handle --enable-haifa.
2768 * configure: Rebuilt.
2769 * flags.h: Add new flags for haifa instruction scheduler.
2770 * genattrtab.c (expand_units): For haifa, don't subtract one
2771 when computing blockage.
2772 * toplev.h (flag_schedule_interblock): Haifa scheduler flag.
2773 (flag_schedule_speculative): Ditto.
2774 (flag_schedule_speculative_load): Ditto.
2775 (flag_schedule_speculative_load_dangerous): Ditto.
2776 (flag_schedule_reverse_before_reload): Ditto.
2777 (flag_schedule_reverse_after_reload): Ditto.
2778 (flag_branch_on_count_reg): Ditto.
2779 (f_options): Add Haifa switches.
2780 (main): Turn off some Haifa options if appropriate macro is
2781 defined. Process Haifa switches.
2782 * unroll.c (iteration_info): No longer static, since Haifa
2784 (unroll_loop): Inform HAIFA scheduler about loop unrolling factor.
2785 * unroll.c (unroll_loop): Set loop_unroll_iter, loop_start_value.
2786 * loop.h (loop_unroll_factor, loop_number): Add HAIFA decls.
2787 * loop.h (loop_initial_value,loop_unroll_iter): New globals.
2788 * loop.c (loop_optimize): If HAIFA is defined, allocate additional
2789 storage for the Haifa scheduler.
2790 (mark_loop_jump): If HAIFA defined, set LABEL_OUTSIDE_LOOP_P and
2792 (strength_reduce): If HAIFA and HAVE_decrement_and_branch_on_count
2793 are defined, call analyze_loop_iterations and insert_bct to use
2795 (record_giv): Refine test for jumps out of loops if HAIFA is
2797 (analyze_loop_iterations): New function to identify if we can use
2799 (insert_bct): Insert countdown loop.
2800 (instrument_loop_bct): Low level code to insert countdown loop.
2801 (loop_number): Calculate UID of loop.
2802 (indirect_jump_in_function_p): Return true if an indirect jump is
2804 (is_power_of_2): Return true if value is a power of 2.
2805 (is_conditional_branch): Return true if insn is a conditional
2807 (fix_bct_param): Process -fbct-{min,max}-N switches.
2808 (check_bct_param): Return true if loop should be instrumented.
2809 * loop.c (loop_initial_value,loop_unroll_iter): New globals.
2810 (loop_optimize): Initialize.
2811 (get_condition_for_loop): Ditto.
2812 * loop.c (strength_reduce): Inside of code that uses #ifdef
2813 HAVE_decrement_and_branch_on_count code, test it to make sure the
2815 (instrument_loop_bct): Ditto.
2816 * haifa-sched.c: New file.
2819 * Integrate regmove pass.
2820 * Makefile.in (OBJS): Add regmove.o
2821 (regmove.o): Add dependencies.
2822 * flow.c (find_use_as_address): No longer static.
2823 * rtl.h (find_use_as_address): Declare.
2824 * toplev.c (regmove_dump, flag_regmove): Define.
2825 (f_options): Add -fregmove.
2826 (regmove_dump_file, regmove_time): Define.
2827 (fatal_insn): Close the regmove dump file.
2828 (compile_file): Initialize regmove_time; open/close the regmove dump
2829 file as needed. Print regmove time as needed.
2830 (rest_of_compilation): Run regmove pass if requested, dump
2831 RTL after regmove if requested.
2832 (main): If -O2 or more, turn on regmove. Handle dump switches.
2833 * regmove.c: New file.
2835 Mon Aug 11 14:15:02 1997 Jeffrey A Law (law@cygnus.com)
2837 * Integrate tlink patch from jason@cygnus.com
2838 * gcc.c (SWITCH_TAKES_ARG): Add 'V', 'B' and 'b'.
2839 (process_command): Increment n_switches for them. Don't discard
2840 their args. Validate them.
2841 (main): Escape " marks when creating COLLECT_GCC_OPTIONS.
2843 (process_command): Set include_prefixes from COMPILER_PATH.
2844 (main): Set COLLECT_GCC_OPTIONS sooner.
2845 * confiugre.in: Link ../ld/ld.new to collect-ld rather than real-ld.
2846 * tlink.c, hash.c, hash.h: New files.
2847 * Makefile.in (USE_COLLECT2): Always use collect2.
2848 (collect2): Depend on and link in hash.o and tlink.o.
2849 (tlink.o, hash.o): Add dependencies.
2851 Mon Aug 11 10:04:49 1997 Jeffrey A Law (law@cygnus.com)
2853 * Integrate alias analysis changes from jfc@mit.edu
2854 * Makefile.in (OBJS): Add alias.o
2855 (alias.o): Add dependencies.
2856 * alias.c: New file.
2857 * sched.c: Remove alias analysis code. It lives in alias.c now.
2858 (sched_analyze_2): Add new arguments to true_dependence.
2859 (schedule_insns): Always call init_alias_analysis.
2860 * calls.c (expand_call): Note calls to malloc, calloc, and realloc;
2861 mark return value from such functions as a pointer and keep track of
2862 them for alias analysis. If a return value from a function is a
2863 pointer, mark it as such.
2864 * combine.c (distribute_notes): Handle REG_NOALIAS.
2865 * cse.c (struct write_data): Delete. No longer needed.
2866 (invalidate): Don't call set_nonvarying_address_components anymore.
2867 Use true_dependence to decide if an entry should be removed from
2869 (invalidate_memory): Remove WRITES argument, simplify appropriately.
2871 (note_mem_written): Similarly for WRITE_PTR argument.
2872 (invalidate_from_clobbers): Similarly for W argument.
2873 (invalidate_for_call): Remove memory elements from the hash table.
2874 (refers_to_mem_p, cse_rtx_addr_varies_p): Deleted.
2875 (cse_rtx_varies_p): New function. Derived from old
2876 cse_rtx_addr_varies_p.
2877 (cse_insn): Remove WRITES_MEMORY and INIT variables and all references.
2878 Don't call note_mem_written anymore. Stack pushes invalidate the stack
2879 pointer if PUSH_ROUNDING is defined. No longer need to call
2880 cse_rtx_addr_varies_p to decide if a MEM should be invalidated.
2881 (skipped_writes_memory): Remove variable.
2882 (invalidate_skipped_set): Simplify and wewrite to use invalidate_memory.
2883 (invalidate_skipped_block): Simplify for new alias analysis code.
2884 (cse_set_around_loop): Likewise.
2885 (cse_main): Call init_alias_analysis.
2886 * flags.h (flag_alias_check, flag_argument_noalias): Declare.
2887 * toplev.c (flag_alias_check, flag_argument_noalias): Define.
2888 (f_options): Add new alias checking arguments.
2889 (main): Set flag_alias_check when optimizing.
2890 * local_alloc (validate_equiv_mem_from_store): Add new arguments
2892 (memref_referenced_p): Likewise.
2893 * loop.c (NUM_STORES): Increase to 30.
2894 (prescan_loop): Only non-constant calls set unknown_address_altered.
2895 (invariant_p): Add new arguments to true_dependence.
2896 (record_giv): Initialize unrolled and shared fields.
2897 (emit_iv_add_mult): Call record_base_value as needed.
2898 * loop.h (struct induction): Add unrolled and shared fields.
2899 * unroll.c (unroll_loop): Call record_base_value as needed.
2900 (copy_loop_body): Likewise.
2901 (final_biv_value): Likewise.
2902 (final_giv_value): Likewise.
2903 (find_splittable_regs): Likewise. Only create one new pseudo
2904 if we have multiple address GIVs that were combined with the same
2905 dst_reg GIV. Note when a new register is created due to unrolling.
2906 * rtl.c (reg_note_name): Add REG_NOALIAS.
2907 * rtl.h (enum reg_note): Similarly.
2908 (rtx_varies_p, may_trap_p, side_effects_p): Declare.
2909 (volatile_refs_p, volatile_insn_p, remove_note): Likewise.
2910 (note_stores, refers_to_regno_p, reg_overlap_mentioned_p): Likewise.
2911 (true_dependence, read_dependence, anti_dependence): Likewise.
2912 (output_dependence, init_alias_analysis, end_alias_analysis): Likewise.
2913 (mark_user_reg, mark_reg_pointer): Likewise.
2916 * Integrate reload bugfix from Wilon which enables the PA port
2918 * reload1.c (reload): Sum needs for both OPADDR_ADDR and and
2919 OPERAND_ADDRESS when computing how many registers an insn needs.
2920 (reload_reg_free_p): OPADDR_ADDR and OPERAND_ADDRESS reloads do
2922 (reload_reg_free_before_p): Treat OPERAND_ADDRESS reloads just like
2924 (reload_reg_reaches_end_p): For RELOAD_FOR_OPADDR_ADDR insns, registers
2925 in reload_reg_use_in_op_addr do not reach the end.
2926 do not reach the end.
2927 (reloads_conflict): RELOAD_FOR_OPADDR_ADDR conflicts with
2928 RELOAD_FOR_OPERAND_ADDRESS.
2930 Sun Aug 10 12:00:20 1997 Jeffrey A Law (law@cygnus.com)
2932 * egcs project officially starts.