OSDN Git Service

Correct ChangeLog entry.
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
1 2003-01-31  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
2
3         * pa.c (pa_output_function_prologue, pa_output_function_epilogue): Move
4         updating of total_code_bytes from prologue to epilogue.
5
6 2003-01-31  Ulrich Weigand  <uweigand@de.ibm.com>
7
8         * reload.c (find_reloads): Do not use the mode specified in the insn
9         pattern as reload mode for address operands.  Do not generate optional
10         reloads for operands where a mandatory reload was already pushed.
11         Generate optional reloads only in the final pass though find_reloads.
12         (have_replacement_p): New function.
13
14 2003-01-31  Gerald Pfeifer  <pfeifer@dbai.tuwien.ac.at>
15
16         * doc/install.texi (Testing): Remove a reference to our obsolete
17         /testresults web pages and strip redundant information concerning
18         test results.
19         (Binaries): Refer to Microsoft Windows instead of listing all
20         possible variants.
21
22 Sat Feb  1 00:28:30 CET 2003  Jan Hubicka  <jh@suse.cz>
23
24         * loop.c (emit_prefetch_instructions):  Do conversion at right place in
25         RTL chain.
26
27         * combine.c (simplify_set): Reverse order of ragumetns to
28         REG_CANNOT_CHANGE_MODE_P
29         * df.c (df_def_record_1): Likewise.
30         * recog.c (register_operand): Likewise.
31         * simplify-rtx.c (simplify_subreg): Likewise.
32         * hard-reg-set.h (REG_CANNOT_CHANGE_MODE_P): Update use of
33         CANNOT_CHANGE_MODE_CLASS.
34         * regclass.c (cannot_change_mode_set_regs, invalid_mode_change_p):
35         Likewise.
36         * reload.c (push_reload): Likewise.
37         * alpha.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
38         * ia64.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
39         * mips.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
40         * mips-protos.h (mips_cannot_change_mode_class): Update prototype.
41         * mips.c (mips_cannot_change_mode_class): Update.
42         * pa64-regs.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
43         * rs6000.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
44         * s390.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
45         * sh.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
46         * sh-protos.h (sh_cannot_change_mode_class): Update prototype.
47         * sh.c (sh_cannot_change_mode_class): Update.
48         * i386.h (CANNOT_CHANGE_MODE_CLASS): New.
49         * tm.texi (CANNOT_CHANGE_MODE_CLASS): Update documentation.
50
51 2003-01-31  Geoffrey Keating  <geoffk@apple.com>
52
53         * config/darwin.h (LINK_COMMAND_SPEC): Update for Nathan's recent
54         change to LINK_COMMAND_SPEC in gcc.c.
55
56 2003-01-31  Jan Hubicka  <jh@suse.cz>
57
58         PR c/9506
59         * i386.c (override_options): Use DEFAULT_PCC_STRUCT_RETURN.
60
61 2003-01-31  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
62
63         * pa32-regs.h (REGNO_REG_CLASS, REG_CLASS_FROM_LETTER): Delete
64         duplicated code.
65
66 2003-01-31  Nathan Sidwell  <nathan@codesourcery.com>
67
68         * tree.h (TYPE_BINFO_SIZE, TYPE_BINFO_SIZE_UNIT): Remove.
69         (BINFO_ELTS): New #define.
70         * stor-layout.c (finalize_record_size): Don't set them.
71         * cp/cp-tree.h (BINFO_SUBVTT_INDEX, BINFO_VPTR_INDEX,
72         BINFO_PRIMARY_BASE_OF): Use BINFO_ELTS.
73         (BINFO_LANG_ELTS): New #define.
74         * cp/tree.c (make_binfo): Use BINFO_LANG_ELTS.
75         * java/class.c (make_class): Use BINFO_ELTS.
76         (set_super_info): Likewse.
77         (add_interface_do): Likewise.
78         * objc/objc-act.c (start_class): Use BINFO_ELTS.
79
80 2003-01-31 Danny Smith <dannysmith@users.sourceforge.net>
81
82         * timevar.c (getrusage): Don't ever declare if not HAVE_GETRUSAGE.
83         (times): Don't ever declare if not HAVE_TIMES.
84         (clock): Don't ever declare if not HAVE_CLOCK.
85
86 2003-01-30  Richard Henderson  <rth@redhat.com>
87
88         * flow.c (update_life_info): Zap life info after cleanup_cfg.
89         (regno_uninitialized): Use correct live at function entry set.
90         (regno_clobbered_at_setjmp): Likewise.
91
92         * expr.c (store_expr): Promote all MEM intermediates to regs.
93
94 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
95
96         * config/arm/arm.c: Fix comment typos.
97         * config/arm/arm.h: Likewise.
98         * config/arm/netbsd-elf.h: Likewise.
99         * config/arm/netbsd.h: Likewise.
100
101 2003-01-30  Geoffrey Keating  <geoffk@apple.com>
102
103         * gengtype.c (struct walk_type_data): Add needs_cast_p.
104         (walk_type): Set needs_cast_p in walk_type_data.
105         (write_types_process_field): Supply casts when required to suppress
106         warnings.
107         (write_root): Cast gt_pch_n_S to suppress warning.
108         * Makefile.in: Remove -Wno-error from gtype-desc.o and c-decl.o.
109         * config/rs6000/rs6000.c (print_operand): Mask off high bits only
110         when they might exist.
111         * config/rs6000/t-rs6000: Remove -Wno-error from varasm.o,
112         insn-conditions.o, and rs6000.o.
113
114 2003-01-30  Richard Henderson  <rth@redhat.com>
115
116         * ggc-page.c (G.context_depth_allocations): New.
117         (G.context_depth_collections): New.
118         (alloc_page): Set G.context_depth_allocations.
119         (ggc_collect): Set G.context_depth_collections.
120         (ggc_push_context): Limit to HOST_BITS_PER_LONG contexts.
121         (ggc_pop_context): Early exit for no allocations or collections.
122
123 2003-01-30  Richard Henderson  <rth@redhat.com>
124
125         * tree-inline.c (walk_tree): Streamline duplicate hash table lookup.
126
127 2003-01-30  Richard Earnshaw  <rearnsha@arm.com>
128
129         * arm.c (arm_compute_initial_elimination_offset): If optimizing for
130         size, the link register is always saved if any other register is
131         saved.
132
133 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
134
135         * config/h8300/h8300-protos.h: Update the prototype for
136         compute_plussi_cc.
137         (cpp_reader): Declare before it is used.
138         * config/h8300/h8300.c (compute_plussi_cc): Change the return
139         type to int.
140         * config/h8300/h8300.md (monitor_prologue): Call abort() if we
141         see an unknown H8 variant.
142
143 2003-01-30  Ralf Corsepius  <corsepiu@faw.uni-ulm.de>
144
145         PR target/9316 
146         * config/rs6000/rtems.h: Add CPP_OS_DEFAULT_SPEC.
147         * config/rs6000/sysv4.h: Add CPP_OS_RTEMS_SPEC.
148         * config/rs6000/t-rtems: New file. multilib variants to match OS.
149         * config.gcc (powerpc-*-rtems*): Use rs6000/t-rtems instead of
150         rs6000/t-ppcgas so we get the desired multilibs.
151
152 2003-01-30  Nick Clifton  <nickc@redhat.com>
153
154         * config/arm/arm.c (arm_output_epilogue): Update stack pointer
155         when popping saved IP register off the stack.
156
157 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
158
159         * config/rs6000/aix43.h: Fix comment typos.
160         * config/rs6000/aix51.h: Likewise.
161         * config/rs6000/aix52.h: Likewise.
162         * config/rs6000/altivec.h: Likewise.
163         * config/rs6000/rs6000.c: Likewise.
164         * config/rs6000/rs6000.h: Likewise.
165         * config/rs6000/rs6000.md: Likewise.
166         * config/rs6000/spe.md: Likewise.
167
168 2003-01-29  Mark Mitchell  <mark@codesourcery.com>
169
170         * c-common.c (builtin_define_float_constants): Define
171         __<TYPE>_HAS_INFINITY__ and __<TYPE>_HAS_QUIET_NAN__.
172
173 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
174
175         * config/sh/lib1funcs.asm: Fix comment typos.
176         * config/sh/linux.h: Likewise.
177         * config/sh/sh.c: Likewise.
178         * config/sh/sh.md: Likewise.
179
180 2003-01-30  Loren James Rittle  <ljrittle@acm.org>
181
182         * objc/Make-lang.in (objc-parse.y): Find c-parse.in in $(srcdir).
183
184 2003-01-30  Alexandre Oliva  <aoliva@redhat.com>
185
186         * config/fp-bit.h (__make_dp): Declare if TMODES.
187
188 2003-01-29  Kazu Hirata  <kazu@cs.umass.edu>
189
190         * config/h8300/h8300.h (PREDICATE_CODES): Add entries for
191         general_operand_src and general_operand_dst.
192
193 2003-01-29  David Edelsohn  <edelsohn@gnu.org>
194
195         * config/rs6000/rs6000.c (function_arg_pass_by_reference):
196         Return true for variable sized types.
197         (rs6000_va_arg): Handle variable sized types passed by reference
198         on non-SVR4 ABI.
199
200 2003-01-29  Richard Earnshaw  <rearnsha@arm.com>
201
202         * arm.c (arm_legtimize_address): New function.
203         * arm-protos.h (arm_legtimize_address): Add prototype.
204         * arm.h (ARM_LEGITIMIZE_ADDRESS): Use arm_legitimize_address.
205         (LEGITIMIZE_ADDRESS, THUMB_LEGITIMIZE_ADDRESS): Wrap with
206         do ... while (0)
207
208 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
209
210         PR bootstrap/9296
211         * gthr-rtems.h: Define __GTHREAD_MUTEX_INIT.  Apparently no code
212         depended on it being defined until now.
213
214 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
215
216         PR target/9295
217         * config/mips/rtems.h: Predefine __USE_INIT_FINI__ so generic
218         RTEMS code knows which C++ initialization style the toolset
219         configuration is using.
220
221 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
222
223         PR bootstrap/9293
224         * config/m68k/t-crtstuff: Replace spaces with tabs, add 
225          $(MULTILIB_CFLAGS) as compiler option and multilib crtbegin/end.o.
226
227 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
228
229         PR bootstrap/9292
230         * config.gcc (hppa1.1-rtems):  Did not include t-rtems nor enable
231         RTEMS threads.
232         * config/pa/rtems.h (LIB_SPEC): Use -N when linking.
233
234 2003-01-29  Nick Clifton  <nickc@redhat.com>
235
236         * Makefile.in (c-parse.o): Locate source file in $(parsedir)
237         not $(srcdir).
238
239 2003-01-29  Andrew Haley  <aph@redhat.com>
240
241         * tree-inline.c (walk_tree): Add CHAR_TYPE.
242
243 Wed Jan 29 10:26:12 CET 2003  Jan Hubicka  <jh@suse.cz>
244
245         * i386.md (subdi3_carry_rex64): Fix typo.
246
247 2003-01-28  Stan Shebs  <shebs@apple.com>
248
249         * coretypes.h (cpp_reader): Forward declare struct.
250         * c-pragma.h (cpp_reader): Remove forward declaration.
251         * hashtable.h (cpp_reader): Likewise.
252         * scan.h (cpp_reader): Likewise.
253         * tree.h (cpp_reader): Likewise.
254         * config/darwin-protos.h (cpp_reader): Likewise.
255         * config/arm/arm-protos.h (cpp_reader): Likewise.
256         * config/rs6000/rs6000-protos.h: Remove GCC_CPPLIB_H ifdef, use
257         struct cpp_reader in prototypes.
258
259 2003-01-28  Christian Cornelssen  <ccorn@cs.tu-berlin.de>
260
261         * doc/install.texi: Add documentation for installation into
262         tooldirs and with DESTDIR.
263
264 2003-01-28  Richard Henderson  <rth@redhat.com>
265
266         * config.gcc (ia64*-*-aix*): Remove.
267         * config/ia64/aix.h, config/ia64/t-aix: Remove file.
268         * config/ia64/unwind-aix.c: Remove file.
269
270 2003-01-28  Andreas Schwab  <schwab@suse.de>
271
272         * config/m68k/m68k.md (tablejump+2): Don't sign extend an address
273         register.
274         * config/m68k/apollo68.h (ASM_RETURN_CASE_JUMP): Likewise.
275         * config/m68k/coff.h (ASM_RETURN_CASE_JUMP): Likewise.
276         * config/m68k/linux.h (ASM_RETURN_CASE_JUMP): Likewise.
277         * config/m68k/m68kelf.h (ASM_RETURN_CASE_JUMP): Likewise.
278         * config/m68k/mot3300.h (ASM_RETURN_CASE_JUMP): Likewise.
279         * config/m68k/netbsd-elf.h (ASM_RETURN_CASE_JUMP): Likewise.
280         * config/m68k/pbb.h (ASM_RETURN_CASE_JUMP): Likewise.
281
282 2003-01-28  Richard Sandiford  <rsandifo@redhat.com>
283
284         * combine.c (nonzero_bits): Fix check for negative divide operands.
285
286 2003-01-28  Richard Henderson  <rth@redhat.com>
287
288         * config/ia64/ia64.c (ia64_rwreloc_section_type_flags): New.
289         * config/ia64/hpux.h (TARGET_SECTION_TYPE_FLAGS): New.
290
291 2003-01-28  Richard Henderson  <rth@redhat.com>
292
293         * cse.c (find_best_addr): Kill !ADDRESS_COST code.
294
295         * config/cris/cris.c (cris_address_cost): Make static.
296         (TARGET_RTX_COSTS, TARGET_ADDRESS_COST): New.
297         * config/cris/cris.h (ADDRESS_COST): Remove.
298         * config/cris/cris-protos.h: Update.
299
300 2003-01-23  Mike Stump  <mrs@apple.com>
301
302         * regclass.c (init_reg_autoinc): New function.
303         (regclass): Move initialization of forbidden_inc_dec_class from
304         here...
305         (init_regs): to here.  Avoids reinitialization for each function,
306         saving compilation time.
307
308 2003-01-28  Jason Merrill  <jason@redhat.com>
309
310         * cpplib.h (struct cpp_options): Add warn_deprecated field.
311         * cppinit.c (cpp_create_reader): Turn it on by default.
312         * c-opts.c (c_common_decode_option): Set it.
313         * cpplib.c (do_pragma_once): Only complain about #pragma once
314         if warn_deprecated is set.
315
316 2003-01-28  Dale Johannesen  <dalej@apple.com>
317
318         * emit-rtl.c (const_double_htab_hash):  Use mode in the hash.
319         * loop.c (scan_loop):  Move movables on -Os rich-register targets.
320         * config/rs6000/rs6000.md (sibcall*):  Use match_operand for LR.
321
322 2003-01-28  Richard Henderson  <rth@redhat.com>
323
324         * target.h (targetm.address_cost): New.
325         * target-def.h (TARGET_ADDRESS_COST): New.
326         (TARGET_RTX_COSTS): Uncomment.  Oops.
327         * cse.c (address_cost): Use new target hook.
328         (default_address_cost): New.
329         * output.h (default_address_cost): Declare.
330         * hooks.c (hook_int_rtx_0): New.
331         * hooks.h (hook_int_rtx_0): Declare.
332         * loop.c (combine_givs_p): Remove if 0 code.
333         * system.h (ADDRESS_COST): Poison.
334
335         * config/alpha/alpha.c, config/alpha/alpha.h, config/d30v/d30v.c,
336         config/d30v/d30v.h, config/ia64/ia64.c, config/ia64/ia64.h,
337         config/m32r/m32r.c, config/m32r/m32r.h, config/mcore/mcore.c,
338         config/mcore/mcore.h, config/mmix/mmix.c, config/mmix/mmix.h,
339         config/rs6000/rs6000.c, config/rs6000/rs6000.h, config/sparc/sparc.c,
340         config/sparc/sparc.h, config/v850/v850.c, config/v850/v850.h,
341         config/xtensa/xtensa.c, config/xtensa/xtensa.h
342         (TARGET_ADDRESS_COST): Define as hook_int_rtx_0.
343         (ADDRESS_COST): Remove.
344
345         * config/arc/arc-protos.h, config/arc/arc.c, config/arc/arc.h,
346         config/avr/avr-protos.h, config/avr/avr.c, config/avr/avr.h,
347         config/c4x/c4x-protos.h, config/c4x/c4x.c, config/c4x/c4x.h,
348         config/dsp16xx/dsp16xx-protos.h, config/dsp16xx/dsp16xx.c,
349         config/dsp16xx/dsp16xx.h, config/i386/i386-protos.h,
350         config/i386/i386.c, config/i386/i386.h, config/i960/i960-protos.h,
351         config/i960/i960.c, config/i960/i960.h, config/ip2k/ip2k-protos.h,
352         config/ip2k/ip2k.c, config/ip2k/ip2k.h, config/mips/mips-protos.h,
353         config/mips/mips.c, config/mips/mips.h, 
354         config/m68hc11/m68hc11-protos.h, config/m68hc11/m68hc11.c,
355         config/m68hc11/m68hc11.h, config/ns32k/ns32k-protos.h, 
356         config/ns32k/ns32k.c, config/ns32k/ns32k.h, config/pa/pa-protos.h,
357         config/pa/pa.c, config/pa/pa.h, config/s390/s390-protos.h,
358         config/s390/s390.c, config/s390/s390.h, config/vax/vax-protos.h,
359         config/vax/vax.c, config/vax/vax.h
360         (foo_address_cost): Make static.
361         (TARGET_ADDRESS_COST): New.
362         (ADDRESS_COST): Remove.
363
364         * config/arm/arm.h, config/arm/arm.c, config/m88k/m88k.h,
365         config/m88k/m88k.c, config/romp/romp.h, config/romp/romp.c,
366         config/sh/sh.c, config/sh/sh.h, config/stormy16/stormy16.c,
367         config/stormy16/stormy16.h
368         (ADDRESS_COST): Move code ...
369         (foo_address_cost): ... here.
370         (TARGET_ADDRESS_COST): New.
371
372         * config/m32r/m32r.c (m32r_address_cost): Remove.
373         * config/m32r/m32r-protos.h: Update.
374
375         * config/mmix/mmix.c (mmix_address_cost): Remove.
376         * config/mmix/mmix-protos.h: Update.
377
378         * config/mn10300/mn10300.c (mn10300_address_cost_1): Rename from
379         mn10300_address_cost; move unsig allocation ...
380         (mn10300_address_cost): ... here.
381         (TARGET_ADDRESS_COST): New.
382         * config/mn10300/mn10300-protos.h: Update.
383         * config/mn10300/mn10300.h (ADDRESS_COST): Remove.
384
385         * doc/tm.texi: Update.
386
387 2003-01-28  Vladimir Makarov  <vmakarov@redhat.com>
388
389         * haifa-sched.c (schedule_insn): Return necessary cycle advance
390         after issuing the insn.
391         (rank_for_schedule): Make a insn with /S the highest priority
392         insn.
393         (move_insn): Ignore schedule groups.  Clear SCHED_GROUP_P.
394         (choose_ready): Check SCHED_GROUP_P.
395         (schedule_block): Advance cycle after issuing insn if it is
396         necessary.  Don't reorder insns if there is an insn with /S.
397         (set_priorities): Ignore schedule groups.
398
399         * sched-deps.c (remove_dependence, group_leader): Remove the
400         functions.
401         (add_dependence): Ignore schedule groups.
402         (set_sched_group_p): Don't make copy of dependencies from previous
403         insn of the schedule group.  Add anti-dependency to the previous
404         insn of the schedule group.
405         (compute_forward_dependences): Ignore schedule groups.
406
407         * sched-ebb.c (init_ready_list): Ignore schedule groups.
408
409         * sched-rgn.c (init_ready_list): Ditto.
410         (can_schedule_ready_p): Ditto.
411         
412 2003-01-28  Vladimir Makarov  <vmakarov@redhat.com>
413
414         * config/i386/i386.md (*movsi_1): Use movdqa to move one xmm
415         register to another one.
416
417 2003-01-28  Richard Henderson  <rth@redhat.com>
418
419         * calls.c (default_must_pass_in_stack): Fix typo in !type case.
420
421 2003-01-28  Roger Sayle  <roger@eyesopen.com>
422
423         * cse.c (cse_insn): Avoid redundant REG_EQUAL notes.
424
425 2003-01-28  Richard Sandiford  <rsandifo@redhat.com>
426
427         * config/sh/sh.h (CLASS_MAX_NREGS): If TARGET_SHMEDIA, and the given
428         class contains a floating-point register, return the size of the
429         mode in half words.
430
431 Tue Jan 28 12:15:13 CET 2003  Jan Hubicka  <jh@suse.cz>
432
433         * i386.c (ix86_carry_flag_operator):  New predicate.
434         (fcmov_operator): Fix whitespace.
435         (ix86_expand_carry_flag_compare):  Deal with floating point.
436         (ix86_expand_int_movcc): Deal with fp; update insn expansion
437         (ix86_expand_int_addcc): Likewise.
438         (ix86_expand_strlensi_unroll_1): likewsie.
439         * i386.h (PREDICATE_CODES): Add ix86_carry_flag_operator.
440         * i386.md (add?i_carry_rex64): Use new predicate.
441         (sub?i3_carry_rex64): Likewise.
442         (x86_mov?icc_0_m1*): Likewise.
443
444 2003-01-28  Andreas Schwab  <schwab@suse.de>
445
446         * cfgloopmanip.c (create_preheader): Initialize src to avoid
447         warning.
448
449         * expmed.c (emit_store_flag): Fix cast to avoid sign
450         comparison warning.
451
452         * combine.c (force_to_mode): Add cast to fix warning when
453         STORE_FLAG_VALUE is negative.
454
455 2003-01-27  Richard Henderson  <rth@redhat.com>
456
457         * Makefile.in (cse.o): Depend on TARGET_H.
458         * cse.c (rtx_cost): Use targetm.rtx_costs.
459         * system.h (CONST_COSTS RTX_COSTS DEFAULT_RTX_COSTS): Poison.
460         * doc/tm.texi: Update.
461         
462         * target.h (targetm.rtx_costs): New.
463         * target-def.h (TARGET_RTX_COSTS): New.
464         * hooks.c (hook_bool_rtx_int_int_intp_false): New.
465         * hooks.h: Update.
466
467         * config/alpha/alpha.c (alpha_rtx_cost_data): New.
468         (alpha_rtx_costs, TARGET_RTX_COSTS): New.
469         * config/alpha/alpha.h (PROCESSOR_MAX): New.
470         (CONST_COSTS, RTX_COSTS): Remove.
471
472         * config/arc/arc.c, config/arc/arc.h, config/c4x/c4x.c,
473         config/c4x/c4x.h, config/cris/cris.c, config/cris/cris.h,
474         config/d30v/d30v.c, config/d30v/d30v.h, config/dsp16xx/dsp16xx.c,
475         config/dsp16xx/dsp16xx.h, config/frv/frv.c, config/frv/frv.h,
476         config/h8300/h8300.c, config/h8300/h8300.h, config/i370/i370.c,
477         config/i370/i370.h, config/i386/i386.c, config/i386/i386.h,
478         config/i960/i960.c, config/i960/i960.h, config/ia64/ia64.c,
479         config/ia64/ia64.h, config/m32r/m32r.c, config/m32r/m32r.h,
480         config/m68k/m68k.c, config/m68k/m68k.h, config/m88k/m88k.c,
481         config/m88k/m88k.h, config/mcore/mcore.c, config/mcore/mcore.h,
482         config/mips/mips.c, config/mips/mips.h, config/mn10200/mn10200.c,
483         config/mn10200/mn10200.h, config/mn10300/mn10300.c,
484         config/mn10300/mn10300.h, config/ns32k/ns32k.c, config/ns32k/ns32k.h,
485         config/pa/pa.c, config/pa/pa.h, config/pdp11/pdp11.c,
486         config/pdp11/pdp11.h, config/romp/romp.c, config/romp/romp.h,
487         config/rs6000/rs6000.c, config/rs6000/rs6000.h, config/s390/s390.c,
488         config/s390/s390.h, config/sh/sh.c, config/sh/sh.h,
489         config/stormy16/stormy16.c, config/stormy16/stormy16.h,
490         config/v850/v850.c, config/v850/v850.h,
491         config/xtensa/xtensa.c, config/xtensa/xtensa.h
492         (CONST_COSTS, RTX_COSTS): Move code ...
493         (foo_rtx_costs, TARGET_RTX_COSTS): ... here.
494
495         * config/arm/arm.c (arm_rtx_costs_1): Rename from arm_rtx_costs.
496         (arm_rtx_costs, TARGET_RTX_COSTS): New.
497         * config/arm/arm-protos.h: Update.
498         * config/arm/arm.h (DEFAULT_RTX_COSTS): Remove.
499
500         * config/avr/avr.h (CONST_COSTS): Move code ...
501         * config/avr/avr.c (avr_rtx_costs): ... here.
502         (default_rtx_costs): Make static.
503         * config/avr/avr-protos.h: Update.
504
505         * config/h8300/h8300.c (const_costs): Make static.
506         (h8300_and_costs, h8300_shift_costs): Likewise.
507         * config/h8300/h8300-protos.h: Update.
508
509         * config/ip2k/ip2k.h (DEFAULT_RTX_COSTS): Remove.
510         (CONST_COSTS): Move code ...
511         * config/ip2k/ip2k.c (ip2k_rtx_costs): ... here.  Rename from
512         default_rtx_costs; update for signature change.
513         * config/ip2k/ip2k-protos.h: Update.
514
515         * config/m68hc11/m68hc11.h (RTX_COSTS): Remove.
516         (CONST_COSTS): Move code ...
517         * config/m68hc11/m68hc11.c (m68hc11_rtx_costs): ... here.
518         (TARGET_RTX_COSTS): New.
519         (m68hc11_rtx_costs_1): Rename from m68hc11_rtx_costs; make static.
520         * config/m68hc11/m68hc11-protos.h: Update.
521
522         * config/m68k/m68k.c (const_int_cost): Make static.
523         * config/m68k/m68k-protos.h: Update.
524
525         * config/mcore/mcore.c (mcore_const_costs): Make static.
526         (mcore_and_cost, mcore_ior_cost): Likewise.
527         * config/mcore/mcore-protos.h: Update.
528
529         * config/mmix/mmix.c (mmix_rtx_costs, TARGET_RTX_COSTS): New.
530         (mmix_rtx_cost_recalculated): Remove.
531         * config/mmix/mmix.h (DEFAULT_RTX_COSTS): Remove.
532         * config/mmix/mmix-protos.h: Update.
533
534         * config/sh/sh.c (shiftcosts): Make static.
535         (addsubcosts, andcosts, multcosts): Likewise.
536         * config/sh/sh-protos.h: Update.
537
538         * config/sparc/sparc.c (TARGET_RTX_COSTS): New.
539         (sparc_rtx_costs): Make static; update for change in signature.
540         * config/sparc/sparc.h (RTX_COSTS_CASES, RTX_COSTS): Remove.
541         * config/sparc/sparc-protos.h: Update.
542
543         * config/v850/v850.c (const_costs): Make static.
544         * config/v850/v850-protos.h: Update.
545
546         * config/vax/vax.h (RTX_COSTS): Remove.
547         (CONST_COSTS): Move code ...
548         * config/vax/vax.c (vax_rtx_costs_1): ... here; rename
549         from vax_rtx_cost.
550         (vax_rtx_costs, TARGET_RTX_COSTS): New.
551
552 2003-01-27  Richard Henderson  <rth@redhat.com>
553
554         * config/vax/vax.h (ASM_OUTPUT_MI_THUNK): Remove.  Really.
555         * config/vax/vax-protos.h: Update.  Really.
556
557 2003-01-28  Alexandre Oliva  <aoliva@redhat.com>
558
559         * config/mips/mips.h (UNITS_PER_HWFPVALUE): Renamed from...
560         (UNITS_PER_FPVALUE): Defined as the width of a long double, or
561         zero if no hardware floating point.
562         (LONG_DUBLE_TYPE_SIZE): Set to 128 on N32 and N64.
563         (MAX_FIXED_MODE_SIZE): Define to LONG_DOUBLE_TYPE_SIZE.
564         (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Define.
565         (BIGGEST_ALIGNMENT): Same as LONG_DOUBLE_TYPE_SIZE.
566         (FUNCTION_VALUE_REGNO_P): Set for FP_RETURN+2 on N32 and N64.
567         * config/mips/mips.c (mips_arg_info): Pass TFmode values in
568         even FP registers on N32 and N64.
569         (mips_setup_incoming_varargs): Use UNITS_PER_HWFPVALUE.
570         (mips_va_start): Adjust alignment of ARG_POINTER_REGNUM.
571         (mips_va_arg): Use UNITS_PER_HWFPVALUE.  Impose additional
572         even-register-like alignment to 128-bit arguments.
573         (save_restore_insns): Use UNITS_PER_HWFPVALUE.
574         (mips_function_value): Likewise.  Return TFmode in $f0 and $f2
575         on N32 or N64.
576         * config/mips/_tilib.c (__negti2, __ashlti3, __lshrti3): New.
577         * config/mips/t-iris6 (LIB2FUNCS_EXTRA): Add _tilib.c.
578         (TPBIT): Set to tp-bit.c.
579         (tp-bit.c): Create out of fp-bit.c.
580
581 2003-01-28  Gabriel Dos Reis  <gdr@integrable-solutions.net>
582
583         * c-parse.in: Remove '%expect 32' directive in objc mode.
584
585 2003-01-27  Nathan Sidwell  <nathan@codesourcery.com>
586
587         * Makefile.in (LIB2FUNCS_ST): Remove _gcov.
588         (LIBGCOV): New variable.
589         (libgcc.mk): Add LIBGCOV.
590         (LIBGCC_DEPS): Add libgcov.c.
591         (libgcov.a): New target.
592         (clean): Remove libgcov.a.
593         (install-libgcc): Do libgcov too.
594         (stage1-start, stage2-start, stage3-start, stage4-start): Deal
595         with libgcov.a.
596         * libgcc2.c (L_gcov): Move into ...
597         * libgcov.c: ... here. New file.
598         * mklibgcc.in: Add libgcov rules.
599         * gcc.c (LINK_COMMAND_SPEC): Add -lgcov when profiling.
600
601         * doc/invoke.texi (profile-arcs, test-coverage): Update and
602         clarify.
603         
604         * profile.c (index_counts_file): Remove duplicate check for open file.
605
606 2003-01-27  Jerry Quinn  <jlquinn@optonline.net>
607
608         * gcc/doc/invoke.texi (Optimization Options): Group together
609         optional and experimental flags.  Move trapv and bounds-check
610         out of this section.  Group floating point flags together.
611         (Code Gen Options): Move trapv and bounds-check to here.
612
613 2003-01-27  Josef Zlomek  <zlomekj@suse.cz>
614
615         * gcse.c (constprop_register): Check NEXT_INSN (insn) != NULL.
616
617 2003-01-27  Richard Earnshaw  <rearnsha@arm.com>
618
619         PR optimization/9090
620         * function.c (purge_addressof_1): After pushing an addressed register
621         onto the stack, simplify the result.
622
623 2003-01-27  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
624
625         * doc/extend.texi: Fix typo.
626
627 2003-01-27  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
628
629         * doc/cppopts.texi: Fix typo.
630         * doc/objc.texi: Likewise.
631         * doc/passes.texi: Likewise.
632
633 2003-01-27  Alexandre Oliva  <aoliva@redhat.com>
634
635         * real.c (ibm_extended_format): Add 53 to minimum exponent.
636         (encode_ibm_extended): Adjust.
637
638 2003-01-26  Gabriel Dos Reis  <gdr@soliton.integrable-solutions.net>
639
640         * timevar.def (TV_OVERLOAD, TV_TEMPLATE_INSTANTIATION): New
641         timevar_id enumerations.
642
643 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
644
645         * combine.c: Fix formatting.
646
647 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
648
649         * doc/gccint.texi: Update the copyright.
650
651 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
652
653         * doc/cpp.texi: Fix typos.
654         * doc/extend.texi: Likewise.
655         * doc/gty.texi: Likewise.
656         * doc/install.texi: Likewise.
657         * doc/passes.texi: Likewise.
658         * doc/rtl.texi: Likewise.
659         * doc/tm.texi: Likewise.
660
661 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
662
663         * config/ia64/fde-glibc.c: Fix comment typos.
664         * config/ia64/hpux.h: Likewise.
665         * config/ia64/ia64.c: Likewise.
666         * config/ia64/ia64.h: Likewise.
667         * config/ia64/unwind-ia64.c: Likewise.
668
669 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
670
671         * config/i386/i386-modes.def: Fix comment typos.
672         * config/i386/i386.c: Likewise.
673         * config/i386/i386.md: Likewise.
674
675 2003-01-26  Steven Bosscher  <s.bosscher@student.tudelft.nl>
676
677         * config/avr/avr.h, config/cris/aout.h, config/elfos.h,
678         config/i386/freebsd-aout.h, config/mips/iris6.h: Undefine
679         ASM_FINISH_DECLARE_OBJECT before defining it.
680         * toplev.c (rest_of_decl_compilation):  Don't define
681         ASM_FINISH_DECLARE_OBJECT.  Only use it if it is defined.
682         (rest_of_type_compilation): Don't ATTRIBUTE_UNUSED function
683         parameters for DWARF2 targets because they _are_ used.
684
685 2003-01-26  Alexandre Oliva  <aoliva@redhat.com>
686
687         * fp-bit.h: Define macros for TFmode floating-point constants
688         in IBM-extended TFmode types.
689         (TMODES): Define if __LDBL_MANT_DIG__ has the newly-supported
690         widths.
691         * config/fp-bit.c (pack_d, unpack_d): Support IBM-extended
692         TFmode type.
693
694         * config/fp-bit.h: Define macros for TFmode floating-point
695         constants in IEEE quad TFmode type.  Declare functions according
696         to L_ macros.
697         (TMODES): Define if __LDBL_MANT_DIG__ is 113.
698         (TFtype, TItype, UTItype): Define if TMODES is defined.
699         (MAX_UDI_INT, MAX_DI_INT, BITS_PER_DI): Likewise.
700         (F_T_BITOFF, D_T_BITOFF): Define.
701         (IMPLICIT_1, IMPLICIT_2): Cast constants to types that are
702         guaranteed to be wide enough.
703         * config/fp-bit.c: Check for L_ macros for tf functions.
704         (__thenan_tf): New.
705         (nan): Adjust.
706         (pack_d, unpack_d): Support IEEE 854 quad type.
707         (_fpmul_parts): Support TFmode.  Compute exponent adjustment
708         from FRAC_NBITS, FRAC_BITS and NGARDS.
709         (usi_to_float): Cast constants to be shifted to fractype
710         instead of assuming long long is wide enough.
711         (sf_to_tf, df_to_tf, __make_tp, tf_to_df, tf_to_sf): New.
712
713 2003-01-26  Andreas Jaeger  <aj@suse.de>
714
715         * df.c: Remove prototype of unused function df_regno_rtl_debug.
716
717 2003-01-26  Alexandre Oliva  <aoliva@redhat.com>
718
719         * Makefile.in (FPBIT_FUNCS): Added _sf_to_tf.
720         (DBBIT_FUNCS): Added _df_to_tf.
721         (TPBIT_FUNCS): New.
722         (libgcc.mk): Pass TPBIT and TPBIT_FUNCS down.
723         (LIBGCC_DEPS): Added TPBIT.
724         * mklibgcc.in: Support TPBIT and TPBIT_FUNCS.
725
726         * optabs.c (expand_binop) <add, sub>: Return xtarget if we haven't
727         been able to move the result to target.
728
729         * expr.c (emit_group_store): Initialize dst with CONST0_RTX
730         for the appropriate mode.
731
732         * calls.c (emit_library_call_value_1): Handle return values
733         in a PARALLEL.
734
735         * rtl.c (get_mode_alignment): Moved to...
736         * stor-layout.c: ... here.
737
738         * print-rtl.c (print_rtx): Don't print MEM details in
739         GENERATOR_FILEs.
740
741 2003-01-26  Michael Hayes  <mph@paradise.net.nz>
742
743         * df.h: Update comments, tidy formatting.
744         (DF_FORWARD, DF_REVERSE, DF_UNION, DF_INTERSECTION): Rename from FORWARD,
745         REVERSE, UNION, INTERSECTION.  All uses updated.
746         (OLD_DF_INTERFACE): Remove.
747         (struct insn_info): Remove commented out insn field.
748         * df.c: Update comments, tidy formatting.
749         (df_def_table_realloc): Remove.
750
751
752 2003-01-26  Alan Modra  <amodra@bigpond.net.au>
753
754         * calls.c (save_fixed_argument_area): Tidy.
755         (restore_fixed_argument_area): Tidy.  Set alignment of stack_area.
756         (expand_call): Comment typo fixes.  Don't init low_to_save.  Start
757         call chain loop at 1 if !try_tail_call.  Formatting.
758         (emit_library_call_value_1): Don't init low_to_save or high_to_save.
759         Use save_fixed_argument_area and restore_fixed_argument_area.
760
761 2003-01-26  Michael Hayes  <m.hayes@elec.canterbury.ac.nz>
762
763         * df.c (df_uses_record): Handle CC0.
764
765 2003-01-25  Ulrich Weigand  <uweigand@de.ibm.com>
766
767         * reload.c (maybe_memory_address_p): New function.
768         (find_reloads_address): Use it instead of memory_address_p.
769
770 2003-01-25  Kaz Kojima  <kkojima@gcc.gnu.org>
771
772         * final.c (shorten_branches): Align the address of code label
773         when computing initial lengths and addresses.
774
775 2003-01-25  Kazu Hirata  <kazu@cs.umass.edu>
776
777         * config/m68hc11/m68hc11.md: Fix a comment typo.
778
779 2003-01-25  Andreas Jaeger  <aj@suse.de>
780
781         * config/i386/i386.c (x86_output_mi_thunk): Correct test for
782         TARGET_MACHO.
783
784 2003-01-25  Roger Sayle  <roger@eyesopen.com>
785
786         * gcse.c (bypass_last_basic_block): New global variable.
787         (bypass_block):  Use redirect_edge_and_branch_force to redirect
788         fall-through edges.  Use bypass_last_basic_block to determine
789         which blocks have valid PRE information.
790         (bypass_conditional_jumps): Initialize bypass_last_basic_block.
791
792 Sat Jan 25 22:31:59 CET 2003  Jan Hubicka  <jh@suse.cz>
793
794         * gcse.c (local_cprop_pass): Update reg_sets table when needed.
795
796 Sat Jan 25 21:04:33 CET 2003  Jan Hubicka  <jh@suse.cz>
797                               Eric Botcazou <ebotcazou@libertysurf.fr>
798         PR opt/8492
799         * gcse.c (one_cprop_pass): Delete unreachable blocks.
800
801 2003-01-25  Richard Henderson  <rth@redhat.com>
802
803         * config/ia64/ia64.c (ia64_rwreloc_select_rtx_section): Rename
804         from ia64_aix_select_rtx_section.
805         (ia64_rwreloc_select_section): Simlarly; use default*_1 function
806         instead of saving and restoring flag_pic.
807         (ia64_rwreloc_unique_section): Similarly.
808         * config/ia64/aix.h (TARGET_ASM_SELECT_SECTION,
809         TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_RTX_SECTION): Update.
810         * config/ia64/hpux.h (TARGET_ASM_SELECT_SECTION,
811         TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_RTX_SECTION): New.
812
813 2003-01-25  Kazu Hirata  <kazu@cs.umass.edu>
814
815         * config/h8300/h8300.c (h8300_shift_needs_scratch_p): Update a
816         comment.
817
818 2002-01-25  Richard Henderson  <rth@redhat.com>
819
820         * config/m68k/m68k-none.h (ASM_SPEC): Adjust inter-option spacing.
821
822 2002-01-25  Kelley Cook <kelleycook@comcast.net>
823
824         * ggc-simple.c (debug_ggc_tree): Add PTR cast.
825
826 2003-01-25  Segher Boessenkool  <segher@koffie.nl>
827
828         * bitmap.h (BITMAP_WORD): New typedef: fundamental storage
829         type for bitmaps.  Use unsigned long.
830         (nBITMAP_WORD_BITS): New macro.
831         (BITMAP_WORD_BITS): New macro.
832         (rest of file): Use it.
833         * bitmap.c: Use it.
834
835 2003-01-25  Richard Henderson  <rth@redhat.com>
836
837         2002-02-19  Robert Lipe  <robertlipe@usa.net>
838         * config/i386/t-sco5gas: (CRTSTUFF_T_CFLAGS_S): Delete -mcoff.
839
840 2002-01-25  Roger Sayle  <roger@eyesopen.com>
841
842         * builtins.c (purge_builtin_constant_p): Scan insn stream
843         sequentially rather than by basic block.
844         * function.c (purge_addressof): Simplify test with INSN_P.
845
846 2003-01-25  Kazu Hirata  <kazu@cs.umass.edu>
847
848         * combine.c (simplify_comparison, case AND): Remove a redundant test.
849
850 2002-01-25  Roger Sayle  <roger@eyesopen.com>
851
852         * function.h (struct function): New field calls_constant_p.
853         (current_function_calls_constant_p): New macro for above.
854         * function.c (prepare_function_start): Initialize calls_eh_return
855         and calls_constant_p.
856         * builtins.c (expand_builtin_constant_p): Set calls_constant_p.
857         * toplev.c (rest_of_compilation): Only call purge_builtin_constant_p
858         when the current_function_calls_constant_p.
859         * integrate.c (expand_inline_function): Set calls_constant_p if
860         the function being inlined has calls_constant_p set.
861
862 2002-01-25  Roger Sayle  <roger@eyesopen.com>
863
864         * cse.c (fold_rtx): Instantiate CONSTANT_P_RTX to 0 when not
865         optimizing, even if flag_gcse is true.
866         * toplev.c (rest_of_compilation): purge_builtin_constant_p
867         only needs to be called when "optimize > 0 && flag_gcse".
868
869 2003-01-25  Roger Sayle  <roger@eyesopen.com>
870
871         * stmt.c (emit_case_bit_tests): New routine to implement suitable
872         switch statements using the equivalent of "if ((1<<x) & cst) ... ".
873         (case_bit_test_cmp): New comparison function for "qsort" to order
874         case_bit_tests by decreasing number of destination nodes.
875         (lshift_cheap_p): New function to determine if "1 << x" is cheap.
876         (expand_end_case_type): Use emit_case_bit_tests to implement
877         suitable switch statments.
878         (CASE_USE_BIT_TESTS): New target macro to disable the above.
879         * Makefile.in (stmt.o): Add dependency on optab.h.
880         * doc/tm.texi (CASE_USE_BIT_TESTS): Document new target macro.
881
882 2003-01-23  Andreas Schwab  <schwab@suse.de>
883
884         * config/ia64/crtend.asm [HAVE_INITFINI_ARRAY]: Make
885         __do_global_ctors_aux hidden global and don't put it in
886         .init_array.
887         * config/ia64/crtbegin.asm [HAVE_INITFINI_ARRAY]: Put it here
888         instead so that it comes first.
889
890 Sat Jan 25 16:11:22 CET 2003  Jan Hubicka  <jh@suse.cz>
891
892         * df.c (read_modify_subreg_p):  When osize == UNITS_PER_WORD,
893         subreg is read/modify.
894
895 Sat Jan 25 15:55:08 CET 2003  Jan Hubicka  <jh@suse.cz>
896
897         * i386.c (ix86_expand_movstr, ix86_expand_clrstr): Consistently
898         do libcall for large blocks.
899         * i386.md (comi patterns): Set type to ssecomi.
900         (sse2_unpck?pd): Fix mode of vec_select.
901
902         * cse.c: Include except.h
903         (cse_set_around_loop):  Do not create new basic blocks.
904         * Makefile.in (cse.o): Add dependnecy on except.h
905
906 Sat Jan 25 12:05:17 CET 2003  Jan Hubicka  <jh@suse.cz>
907
908         * builtins.c (fold_trunc_transparent_mathfn): New function.
909         (fold_builtin): Use it.
910         * convert.c (convert_to_real): Re-enable code to convert
911         math functions; add support for floor familly functions.
912
913 2003-01-25  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
914
915         * Makefile.in (cfgloop.o, cfgloopanal.o, cfgloopmanip.o): Add
916         dependencies on coretypes.h and $(TM_H).
917
918 Sat Jan 25 11:10:03 CET 2003  Jan Hubicka  <jh@suse.cz>
919
920         * builtins.c (fold_trunc_transparent_mathfn):  Undo accidental commit.
921
922 2002-01-24  Stuart Hastings  <stuart@apple.com>
923
924         * config/i386/i386.c (x86_output_mi_thunk): Add Darwin/x86 support.
925
926 2003-01-25  Michael Hayes  <m.hayes@elec.canterbury.ac.nz>
927
928         * config/c4x/c4x.md (UNSPEC_BU): New constants.
929         (UNSPEC_RPTS, UNSPEC_LSH, UNSPEC_CMPHI, UNSPEC_RCPF): Likewise.
930         (UNSPEC_RND, UNSPEC_RPTB_FILL, UNSPEC_LOADHF_INT): Likewise.
931         (UNSPEC_STOREHF_INT, UNSPEC_RSQRF, UNSPEC_LOADQF_INT): Likewise.
932         (UNSPEC_STOREQF_INT, UNSPEC_LDIV, UNSPEC_PUSH_ST):  Likewise.
933         (UNSPEC_POP_ST, UNSPEC_PUSH_DP, UNSPEC_POP_DP):  Likewise.
934         (UNSPEC_POPQI, UNSPEC_POPQF, UNSPEC_ANDN_ST):  Likewise.
935         (UNSPEC_RPTB_INIT, UNSPEC_TOIEEE, UNSPEC_FRIEEE):  Likewise.
936
937 Fri Jan 24 23:44:12 CET 2003  Jan Hubicka  <jh@suse.cz>
938
939         * emit-rtl.c (reg_attrs_htab): New static variable.
940         (reg_attrs_htab_hash, reg_attrs_htab_eq, get_reg_attrs): New static
941         functions.
942         (reg_rtx): Do not maintain regno_decl.
943         (gen_rtx_REG_offset, set_reg_attrs_from_mem, set_delc_rtx,
944         set_mem_attrs_from_reg): New global function.
945         (init_emit): Do not initialize regno_decl.
946         (init_emit_once): initialize reg_attrs_htab.
947         * final.c (alter_subreg): Do not replace REG by SUBREG.
948         (gen_mem_expr_from_op): Improve output.
949         (output_asm_operands): Likewise.
950         * function.c (assign_params): Do not set REGNO_DECL.
951         * function.h (struct function): Kill regno_decl.
952         (REGNO_DECL): Kill.
953         * gengtype.c (adjust_field_rtx_def): Handle new field of reg.
954         * print_rtl.c (print_rtx): Output REG information.
955         * regclass.c (reg_scan_mark_refs): Update attrs.
956         * reload1.c (alter_reg): Likewise.
957         * simplify_rtx.c (simplify_subreg): Likewise.
958         * stmt.c (expand_decl): Likewise.
959         * rtl.def (REG): Add new field.
960         * rtl.h (struct reg_attrs): New.
961         (rtunion_def): At rtreg.
962         (X0MEMATTR): Add checking.
963         (X0REGATTR, REG_ATTRS, REG_EXPR, REG_OFFSET): New macro.
964         (set_reg_attrs_from_mem, set_mem_attrs_from_reg, gen_rtx_REG_offset):
965         Declare.
966         * tree.h (SET_DECL_RTL): Call set_decl_rtl.
967
968 2003-01-24  Bob Wilson  <bob.wilson@acm.org>
969
970         * config/xtensa/xtensa.c: Remove unused include of machmode.h.
971         (xtensa_emit_call, print_operand): Fix printf format strings
972         to avoid compile warnings.
973         (xtensa_function_prologue, xtensa_function_epilogue): Change type
974         of "size" argument to HOST_WIDE_INT to fix compile warnings.
975         * config/xtensa/xtensa-protos.h
976         (xtensa_function_prologue, xtensa_function_epilogue): Ditto.
977
978 Fri Jan 24 23:03:32 CET 2003  Jan Hubicka  <jh@suse.cz>
979
980         * builtins.c (DEF_BUILTIN): Accept 10 arguments.
981         (implicit_built_in_decls): New global array.
982         (mathfn_built_in): New global function.
983         (fold_trunc_transparent_mathfn): New static function
984         (expand_builtin_strstr, expand_bultin_strchr,
985         expand_builtin_strpbrk, expand_builtin_strcpy,
986         expand_builtin_strncpy, expand_bultin_strcmp,
987         expand_bultin_strncat, expand_builtin_fputs): Use
988         implicint_built_in_decls.
989         (fold_builtin): Fold floor/trunc/round/ceil/nearbyint.
990         * builtins.def: Fix comments.
991         (DEF_GCC_BUILTIN, DEF_FALLBACK_BUILTIN, DEF_EXT_FALLBACK_BUILTIN,
992         DEF_LIB_BUILTIN, DEF_LIB_ALWAYS_BUILTIN, DEF_EXT_LIB_BUILTIN,
993         DEF_C99_BULTIN, DEF_FRONT_END_LIB_BUILTIN,
994         DEF_EXT_FRONT_END_LIB_BUILTIN): Pass implicit as needed.
995         (DEF_C99_C90RES_BULTIN): New.
996         (*f, *l builtins): Update.
997         * c-common.c (DEF_BUILTIN): Initialize implicit array.
998         (c_expand_builtin_printf, c_expand_builtin_fprintf): Update.
999         * convert.c (strip_float_extensions): New global function.
1000         * tree.h (DEF_BUILTIN): Accept 10 arguments.
1001         (implicit_built_in_decls, mathfn_built_in, strip_float_extension):
1002         Declare.
1003         * java/builtins.c (define_builtin): Handle implicit.
1004         (DEF_BUILTIN): Update.
1005         * tm.texi (TARGET_C99_FUNCTIONS): Document.
1006         * defaults.h (TARGET_C99_FUNCTIONS): Default to 0.
1007         * config/linux.h (TARGET_C99_FUNCTIONS): Default to 1
1008         when using glibc2.
1009
1010 2003-01-24  Bob Wilson  <bob.wilson@acm.org>
1011
1012         * config.gcc (xtensa-*-elf*): Removed assignments to with_newlib,
1013         extra_parts, and fixincludes.  Add xtensa/t-elf tmake_file.
1014         (xtensa-*-linux*): Add xtensa/t-linux tmake_file.
1015         * config/xtensa/crti.asm: New file.
1016         * config/xtensa/crtn.asm: New file.
1017         * config/xtensa/t-elf: New file.
1018         * config/xtensa/t-linux: New file.
1019         * config/xtensa/t-xtensa: Add rules for crti.o and crtn.o.
1020         Move various CFLAGS settings to new t-elf file.
1021
1022 2003-01-24  Richard Henderson  <rth@redhat.com>
1023
1024         PR optimization/4382
1025         * tree-inline.c (find_builtin_longjmp_call_1): New.
1026         (find_builtin_longjmp_call): New.
1027         (inlinable_function_p): Use it.
1028
1029 2003-01-24  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1030
1031         * config/i386/i386-protos.h (function_arg_pass_by_reference): Declare.
1032         * config/i386/i386.h (FUNCTION_ARG_PASS_BY_REFERENCE): Use it.
1033         * config/i386/i386.c (function_arg_pass_by_reference): New.
1034         (ix86_va_arg): Support arguments passed by reference.
1035
1036 2003-01-24  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1037
1038         * cfgloopanal.c: New file.
1039         * cfgloopmanip.c: New file.
1040         * Makefile.in (cfgloopanal.o, cfgloopmanip.o): New.
1041         (toplev.o, loop.o, doloop.o, unroll.o, cfgloop.o, predict.o,
1042         cfglayout.o): Add dependency on cfgloop.h.
1043         (cfgloop.o): Add flags.h dependency.
1044         * basic-block.h (BB_IRREDUCIBLE_LOOP, BB_SUPERBLOCK): New flags.
1045         (VLS_EXPECT_PREHEADERS, VLS_EXPECT_SIMPLE_LATCHES): Removed.
1046         (struct loop, struct loops, flow_loops_find, flow_loops_update,
1047         flow_loops_free, flow_loops_dump, flow_loop_dump,
1048         flow_loop_scan, flow_loop_tree_node_add, flow_loop_tree_node_remove,
1049         LOOP_TREE,,LOOP_PRE_HEADER, LOOP_ENTRY_EDGES, LOOP_EXIT_EDGES,
1050         LOOP_ALL, flow_loop_outside_edge_p, flow_loop_nested_p,
1051         flow_bb_inside_loop_p, get_loop_body, loop_preheader_edge,
1052         loop_latch_edge, add_bb_to_loop, remove_bb_from_loops,
1053         find_common_loop, verify_loop_structure): Declarations moved to ...
1054         * cfgloop.h: New file.
1055         * bb-reorder.c (reorder_basic_blocks): Modified.
1056         * cfglayout.c: Include cfgloop.h.
1057         (cleanup_unconditional_jumps, cfg_layout_redirect_edge,
1058         cfg_layout_duplicate_bb, cfg_layout_initialize): Update loop structure.
1059         (break_superblocks): New static function.
1060         (cfg_layout_finalize): Use it.
1061         (cfg_layout_split_block): New function.
1062         * cfglayout.h (struct reorder_block_def): Add copy and duplicated
1063         fields.
1064         (cfg_layout_initialize, cfg_layout_redirect_edge): Declaration
1065         changed.
1066         (cfg_layout_split_block): Declare.
1067         * cfgloop.c: Include cfgloop.h and flags.h.
1068         (flow_loop_dump, flow_loops_free, flow_loop_exit_edges_find,
1069         get_loop_body): Avoid signed versus unsigned comparison warnings.
1070         (make_forwarder_block, flow_loops_find, loop_preheader_edge,
1071         loop_latch_edge): Modified.
1072         (verify_loop_structure): Modified to use flags stored in loop structure;
1073         check irreducible loops.
1074         (cancel_loop, cancel_loop_tree): New functions.
1075         (estimate_probability): Use loop analysis code for predictions.
1076         (estimate_loops_at_level):  Avoid signed versus unsigned comparison
1077         warnings.
1078         * doloop.c: Include cfgloop.h.
1079         * loop.c: Include cfgloop.h.
1080         * predict.c: Include cfgloop.h.
1081         * toplev.c: Include cfgloop.h.
1082         * unroll.c: Include cfgloop.h.
1083         * tracer.c (tracer): Modified.
1084
1085 2003-01-24  Kazu Hirata  <kazu@cs.umass.edu>
1086
1087         * config/h8300/h8300.c (get_shift_alg): Fix a typo.
1088
1089 2003-01-24  Ulrich Weigand  <uweigand@de.ibm.com>
1090
1091         * configure.in (HAVE_AS_TLS): Add s390-*-* and s390x-*-* cases.
1092         * configure: Regenerate.
1093
1094         * config/s390/s390-protos.h (tls_symbolic_operand): Add prototype.
1095         (tls_symbolic_reference_mentioned_p): Add prototype.
1096         (s390_tls_get_offset): Add prototype.
1097         (emit_pic_move): Remove prototype, replace by ...
1098         (emit_symbolic_move): .. this new prototype.
1099
1100         * config/s390/s390.c (TARGET_HAVE_TLS): Conditionally define.
1101         (tls_model_chars): New global variable.
1102         (s390_encode_section_info): Encode TLS model.
1103         Use targetm.binds_local_p to check for local symbols.
1104         (s390_strip_name_encoding): New function.
1105         (TARGET_STRIP_NAME_ENCODING): Define.
1106
1107         (get_thread_pointer): New function.
1108         (legitimize_tls_address): New function.
1109         (legitimize_address): Call it.
1110         (emit_pic_move): Remove, replace by ...
1111         (emit_symbolic_move): ... this new function.
1112
1113         (larl_operand): Handle TLS operands.
1114         (legitimate_constant_p): Likewise.
1115         (s390_decompose_address): Likewise.
1116         (s390_cannot_force_const_mem): New function.
1117         (TARGET_CANNOT_FORCE_CONST_MEM): Define.
1118
1119         (s390_output_symbolic_const): Handle TLS unspecs.
1120         (print_operand): New code 'J'.
1121         (machine_function): Add struct member 'some_ld_name'.
1122         (get_some_local_dynamic_name, get_some_local_dynamic_name_1): New.
1123
1124         (enum s390_builtin): New type.
1125         (code_for_builtin_64, code_for_builtin_31): New global variables.
1126         (s390_init_builtins, s390_expand_builtin): New functions.
1127         (TARGET_INIT_BUILTINS, TARGET_EXPAND_BUILTIN): Define.
1128
1129         * config/s390/s390.h (TLS_SYMBOLIC_CONST): New macro.
1130         (ASM_OUTPUT_LABELREF): Define.
1131         (ASM_OUTPUT_SPECIAL_POOL_ENTRY): Handle TLS constants.
1132
1133         * config/s390/s390.md: Define TLS UNSPEC constants.
1134         ("movdi", "movsi"): Handle TLS operands.
1135         ("get_tp_64", "get_tp_31", "set_tp_64", "set_tp_31"): New insns.
1136         ("*tls_load_64", "*tls_load_31"): New insns.
1137         ("call_value_tls", "call_value_tls_exp"): New expanders.
1138         ("brasl_tls", "bras_tls", "basr_tls_64", "basr_tls_31",
1139         "bas_tls_64", "bas_tls_31"): New insns.
1140
1141 2003-01-24  Nathan Sidwell  <nathan@codesourcery.com>
1142
1143         * config/rs6000/rs6000.c (rs6000_parse_abi_options): Make sure
1144         spe ABI is configured, if requested.
1145
1146 2003-01-24  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
1147
1148         * doc/passes.texi: Fix typo.
1149
1150 2003-01-24  Andreas Schwab  <schwab@suse.de>
1151
1152         * stor-layout.c (excess_unit_span): Only define if used.
1153
1154 2003-01-24  Jerry Quinn  <jlquinn@optonline.net>
1155
1156         * gcc/doc/invoke.texi (Optimization Options): List -O levels
1157         for each optimization flag.
1158
1159 2003-01-24  Kazu Hirata  <kazu@cs.umass.edu>
1160
1161         * config/h8300/h8300.md (*andsi3_ashift_n_lower): New.
1162
1163 2003-01-24  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
1164
1165         * doc/bugreport.texi: Use @command instead of @code for commands.
1166         * doc/collect2.texi: Likewise.
1167         * doc/headerdirs.texi: Likewise.
1168         * doc/invoke.texi: Likewise.
1169         * doc/standards.texi: Likewise.
1170         * doc/tm.texi: Likewise.
1171         * doc/trouble.texi: Likewise.
1172
1173 2003-01-24  Nick Clifton  <nickc@redhat.com>
1174
1175         * config/arm/arm.c (use_return_insn): Do not use a single return
1176         instruction for interrupt handelrs which have to create a stack
1177         frame.
1178         (arm_expand_prologue): Do not pre-bias the return address of
1179         interrupt handlers which create a stack frame.
1180
1181 2003-01-24  Nick Clifton  <nickc@redhat.com>
1182
1183         * Add sh2e support:
1184
1185         2002-08-12  Alexandre Oliva  <aoliva@redhat.com>
1186
1187                 * config/sh/sh.c (output_branch) [TARGET_SH2E]: Handle
1188                 med_cbranches.  Fix logic in short_cbranches.
1189
1190         2002-04-03  Alexandre Oliva  <aoliva@redhat.com>
1191
1192                 * config/sh/sh.md (delay for cbranch): Don't annul delay
1193                 slots on SH2e.
1194                 * config/sh/sh.c (sh_insn_length_adjustment): Add 2 for
1195                 cbranch with unfilled delay slot on SH2e.
1196                 (output_branch): Fill with a nop the delay slot of a
1197                 branch that required a delay slot but didn't get one.
1198
1199         2002-04-02  Alexandre Oliva  <aoliva@redhat.com>
1200
1201                 * doc/invoke.texi (SH options): Document -m2e.
1202                 * config/sh/crt1.asm: Add __SH2E__ Next to __SH3E__.
1203                 * config/sh/lib1funcs.asm: Likewise.
1204                 * config/sh/sh.c: Replace all uses of TARGET_SH3E with SH2E.
1205                 * config/sh/sh.h (CPP_SPEC): Define __SH2E__ for -m2e, and
1206                 not __sh1__.
1207                 (CONDITIONAL_REGISTER_USAGE): Don't disable FP regs from
1208                 SH2E up.
1209                 (SH3E_BIT): Renamed to...
1210                 (SH_E_BIT): ... this.  Replace all uses.
1211                 (TARGET_SH2E): Define from SH_E_BIT and TARGET_SH2.
1212                 Replace all uses of TARGET_SH3E with TARGET_SH2E.
1213                 (TARGET_SWITCHES): Added 2e.
1214                 (OVERRIDE_OPTIONS): Set sh_cpu for SH2E.
1215                 (processor_type): Added PROCESSOR_SH2E.
1216                 * config/sh/sh.md: Replace all uses of TARGET_SH3E with
1217                 TARGET_SH2E, except in sqrtsf2_i.
1218                 (attribute cpu): Added sh2e.
1219                 * config/sh/t-sh (MULTILIB_OPTIONS): Replace m3e with m2e.
1220                 (MULTILIB_MATCHES): Use m2e multilib for m3e.
1221                 * config.gcc: Add sh2e target support.
1222
1223 2003-01-24  Phil Edwards  <pme@gcc.gnu.org>
1224
1225         Rename -W to -Wextra.
1226         * c-decl.c:  Update comments.
1227         * c-typeck.c:  Likewise.
1228         * flags.h:  Likewise.
1229         * function.c:  Likewise.
1230         * stmt.c:  Likewise.
1231         * toplev.c:  Update comments.
1232         (W_options):  Add 'extra'.
1233         (display_help):  Remove '-W'.
1234         (decode_W_option):  Special warn_uninitialized treatment in the case
1235         of -Wextra.
1236         * doc/invoke.texi:  Update with new entries.
1237
1238 2003-01-23  Richard Henderson  <rth@redhat.com>
1239
1240         * ifcvt.c (noce_process_if_block): Re-add check vs X being changed
1241         in no-else-block case.  Add commentary.
1242
1243 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1244
1245         * configure.in: Revert last change.
1246
1247 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1248
1249         * configure.in: Don't include ansidecl.h in tconfig.h.
1250         * gcov-io.h (PARAMS, ATTRIBUTE_UNUSED: Define if IN_LIBGCC2.
1251         * unwind-dw2-fde.h (last_fde): Use __attribute__, not
1252         ATTRIBUTE_UNUSED.
1253
1254         * configure: Regenerate.
1255
1256 2003-01-23  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
1257
1258         PR java/6748
1259         * config/rs6000/linux.h (MD_FALLBACK_FRAME_STATE_FOR): Don't destroy
1260         regs->nip. Fix rt_sigreturn frame layout. Add support for newer
1261         kernels.
1262
1263 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1264
1265         * cpplex.c (cpp_interpret_charconst): Squelch warning with cast.
1266
1267 2003-01-23  Ulrich Weigand  <uweigand@de.ibm.com>
1268
1269         * genattrtab.c (write_attr_get): Mark 'insn' paramter
1270         as ATTRIBUTE_UNUSED.
1271
1272 2003-01-23  Richard Earnshaw  <rearnsha@arm.com>
1273
1274         * arm.c (thumb_base_register_rtx_p): New function.
1275         (thumb_index_register_rtx_p): New function.
1276         (thumb_legitimate_address_p): New function.
1277         (thumb_legitimate_offset_p): New function.
1278         * arm.h (REG_STRICT_P): Define according to setting of REG_OK_STRICT.
1279         (ARM_GO_IF_LEGITIMATE_ADDRESS): Use REG_STRICT_P to avoid duplicate
1280         definitions.
1281         (THUMB_GO_IF_LEGITIMATE_ADDRESS): Use thumb_legitimate_address_p.
1282         (THUMB_LEGITIMATE_OFFSET): Delte.
1283         (THUMB_LEGITIMIZE_RELOAD_ADDRESS): Use thumb_legitimate_offset.
1284         * arm-protos.h (thumb_legitimate_address_p): Add prototype.
1285         (thumb_legitimate_offset_p): Likewise.
1286
1287 2003-01-23  Andreas Schwab  <schwab@suse.de>
1288
1289         * unwind.h (_Unwind_GetTextRelBase): Mark parameter as unused.
1290
1291 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1292
1293         * fixinc/Makefile.in (FL_LIST): Revert last change.
1294
1295 2003-01-23  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
1296
1297         PR other/7341
1298         * invoke.texi (ftest-coverage): Fix broken cross-reference.
1299         Change @code to @command for gcov command.
1300
1301         * gcc.texi: Adjust title of gcov section.
1302         Adjust copyright.
1303         * gcov.texi: Likewise.
1304
1305 2003-01-22  Roger Sayle  <roger@eyesopen.com>
1306
1307         PR optimization/8423
1308         * cse.c (fold_rtx): Only eliminate a CONSTANT_P_RTX to 1 when
1309         its argument is constant, or 0 if !flag_gcse.
1310         * simplify-rtx.c (simplify_rtx): Convert CONSTANT_P_RTX to 1
1311         if it's argument is constant.
1312         * gcse.c (want_to_gcse_p): Ignore CONSTANT_P_RTX nodes.
1313         (hash_scan_set): Don't record CONSTANT_P_RTX expressions.
1314         (do_local_cprop): Don't propagate CONSTANT_P_RTX constants.
1315         * builtins.c (purge_builtin_constant_p): New function to force
1316         instantiation of any remaining CONSTANT_P_RTX nodes.
1317         * rtl.h (purge_builtin_constant_p): Prototype here.
1318         * toplev.c (rest_of_compilation): Invoke purge_builtin_constant_p
1319         pass after GCSE and before loop.
1320         (flag_gcse): No longer static.
1321         * flags.h (flag_gcse): Prototype here.
1322
1323 2003-01-22  Ulrich Weigand  <uweigand@de.ibm.com>
1324
1325         * config/s390/s390.h (HARD_REGNO_MODE_OK): Fix warning regression
1326         introduced by last change.
1327
1328 2003-01-22  Andreas Schwab  <schwab@suse.de>
1329
1330         * ra-rewrite.c (rewrite_program2): Initialize bb to avoid warning.
1331
1332 2003-01-22  Kazu Hirata  <kazu@cs.umass.edu>
1333
1334         * config/h8300/h8300.c (h8300_shift_needs_scratch_p): Don't
1335         request a scratch reg on H8S when the shift count is 8.
1336
1337 2003-01-22  Ulrich Weigand  <uweigand@de.ibm.com>
1338
1339         * config/s390/s390-protos.h (preferred_la_operand_p):
1340         Remove second parameter.
1341         * config/s390/s390.c (preferred_la_operand_p): Likewise.
1342         * config/s390/s390.h (FRAME_REGNO_P, FRAME_REG_P): New macros.
1343         (HARD_REGNO_MODE_OK): Use FRAME_REGNO_P.
1344         * config/s390/s390.md ("*la_cc_64", "*la_cc_31", splitters): Remove.
1345         Add peepholes to transform ADD to LOAD ADDRESS.
1346
1347 2003-01-22  Richard Earnshaw  <rearnsha@arm.com>
1348
1349         * arm.c (arm_address_register_rtx_p): New function.
1350         (arm_legitimate_address_p): New function.
1351         (arm_legitimate_index_p): New function.
1352         (legitimize_pic_address): Use arm_legitimate_index_p.
1353         * arm-protos.h (arm_legtimate_address_p): Add prototype.
1354         * arm.h (ARM_GO_IF_LEGITIMATE_INDEX): Delete.
1355         (ARM_GO_IF_LEGITIMATE_ADDRESS): Call arm_legitimate_address_p.
1356
1357 2003-01-22  Hartmut Penner  <hpenner@de.ibm.com>
1358
1359         * config/s390/s390.md (floatdfdi2): Insn has type 'itof'.
1360         * config/s390/2064.md (define_bypass): Correct 'Load' and
1361         'Load-address' bypass values.
1362
1363 2003-01-22  Andreas Schwab  <schwab@suse.de>
1364
1365         * config/ia64/t-ia64 (insn-attrtab.o-warn): Define as -Wno-error.
1366
1367 2003-01-21  Zack Weinberg  <zack@codesourcery.com>
1368
1369         * genautomata.c (output_internal_insn_latency_func,
1370         output_print_reservation_func): Short circuit when there is no
1371         automaton to generate code for.
1372
1373 2003-01-21  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1374
1375         * Makefile.in (ssa-ccp.o): Depend on coretypes.h $(TM_H).
1376         (df.o): Delete duplicate dependency on coretypes.h $(TM_H).
1377
1378 2003-01-21  Geoffrey Keating  <geoffk@apple.com>
1379
1380         * config/rs6000/rs6000.md: Remove warning.
1381         (builtin_setjmp_receiver): Likewise.
1382         * config/darwin.c (update_stubs): Slightly improve terrible hack
1383         with identifiers.  Add comment pointing out problems with it.
1384         (update_non_lazy_ptrs): Likewise.
1385
1386 2003-01-21  Richard Henderson  <rth@redhat.com>
1387
1388         * dwarf2out.c (lookup_filename): Fix printf format warning.
1389         * system.h (fread_unlocked, fwrite_unlocked): Undef.
1390
1391         * fixinc/Makefile.in (FL_LIST): Add $($@-warn) hook.
1392         (fixincl.o-warn, gnu-regex.o-warn): New.
1393         * fixinc/fixfixes.c (FIX_PROC_HEAD): Mark parameters unused.
1394         * fixinc/fixtests.c (TEST_FOR_FIX_PROC_HEAD): Likewise.
1395         * fixinc/fixincl.c (process): Fix printf format warning.
1396
1397 2003-01-21  Ulrich Weigand  <uweigand@de.ibm.com>
1398
1399         * dwarf2out (output_file_names): Don't crash if called
1400         with empty file_table.
1401
1402 2003-01-21  Zack Weinberg  <zack@codesourcery.com>
1403
1404         * genautomata.c (output_internal_insn_latency_func): Add
1405         missing break statement to generated code.
1406
1407 2003-01-21  Roger Sayle  <roger@eyesopen.com>
1408
1409         * stmt.c (same_case_target_p): New function to determine whether
1410         two case labels branch to the same target.  Split out from...
1411         (group_case_nodes): ... here.  Use same_case_target_p instead.
1412         (strip_default_case_nodes): Remove explicit case nodes
1413         that branch to the default destination.
1414         (expand_end_case_type): Call strip_default_case_nodes after
1415         group_case_nodes, to simplify the case-list before we count it.
1416         Only generate table_label RTX when actually needed.  Try to share
1417         thiscase->exit_label and thiscase->data.case_stmt.default_label
1418         when a switch has no explicit default case.  Simplify test for
1419         constant index.
1420
1421 2003-01-21  Kazu Hirata  <kazu@cs.umass.edu>
1422
1423         * config/h8300/h8300.md (*negsf2_h8300): Use \\t instead of
1424         \t.
1425         (*negsf2_h8300hs): Likewise.
1426         (*addsi3_lshiftrt_16_zexthi): Likewise.
1427         (*iorhi3_lshiftrt_8): Likewise.
1428
1429 2003-01-21  Ulrich Weigand  <uweigand@de.ibm.com>
1430
1431         * dwarf2out.c (fde_table_in_use): Mark GTY.
1432         (dwarf2out_cfi_label_num): New variable, marked GTY.
1433         (dwarf2out_cfi_label): Use it instead of static label_num.
1434         * emit-rtl.c (label_num): Mark GTY.
1435
1436 2003-01-21  Kazu Hirata  <kazu@cs.umass.edu>
1437
1438         * config/h8300/h8300.c (output_plussi): Support H8/300.
1439         (compute_plussi_length): Likewise.
1440         (compute_plussi_cc): Likewise.
1441         * config/h8300/h8300.md (addsi_h8300): Use output_plussi to
1442         output assembly instructions.
1443
1444 2003-01-21  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1445
1446         * calls.c (fix_unsafe_tree): Prototype.
1447
1448         * Makefile.in (GCC_WARN_CFLAGS): Add $(WERROR) $($@-warn)
1449         (gtype-desc.o-warn, c-decl.o-warn, varasm.o-warn, gcc.o-warn,
1450         insn-conditions.o-warn, out_object_file, gengtype-yacc.o-warn,
1451         c-parse.o-warn): Add -Wno-error.
1452         (STAGE2_FLAGS_TO_PASS): Add WERROR="@WERROR@".
1453
1454         * configure.in (--enable-werror): Add new flag.
1455         * doc/install.texi (--enable-werror): Document.
1456         * configure: Regenerate.
1457
1458         * objc/Make-lang.in (objc/objc-parse.o-warn): Add -Wno-error.
1459
1460 2003-01-21  Andreas Schwab  <schwab@suse.de>
1461
1462         * genautomata.c (output_internal_insn_latency_func): Fix missing
1463         close paren in output.
1464
1465 2003-01-21  Zack Weinberg  <zack@codesourcery.com>
1466
1467         * genautomata.c: Space savings in generated code:
1468         (output_dfa_insn_code_func): Split out the table-enlargement
1469         path to an out-of-line static function, dfa_insn_code_enlarge.
1470         (output_internal_insn_latency_func): Use a lookup table for the
1471         default latencies.
1472         (output_print_reservation_func): Use a lookup table for the
1473         strings.
1474
1475 2003-01-21  Christian Ehrhardt  <ehrhardt@mathematik.uni-ulm.de>
1476
1477         PR opt/7507
1478         * calls.c (fix_unsafe_tree): Split out from ...
1479         (expand_call): ... here.  Use it on the function address too.
1480
1481 2003-01-20  Richard Henderson  <rth@redhat.com>
1482
1483         * expr.h (default_must_pass_in_stack): Move decl outside ifdef.
1484
1485 2003-01-20  Richard Henderson  <rth@redhat.com>
1486
1487         PR opt/7154
1488         * stmt.c (expand_asm_operands): Validize memory operands.
1489
1490 2003-01-20  Richard Henderson  <rth@redhat.com>
1491
1492         PR opt/8848
1493         * ifcvt.c (noce_process_if_block): Correct arguments to
1494         modified_between_p for no-else-block case.
1495
1496 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
1497
1498         * config/h8300/h8300.c (const_costs): Remove a warning.
1499         (output_plussi): Likewise.
1500         (compute_plussi_length): Likewise.
1501         (compute_plussi_cc): Likewise.
1502
1503 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
1504
1505         * config/h8300/h8300.md (addsi_h8300): Remove the last
1506         alternative.
1507
1508 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
1509
1510         * config/h8300/h8300.c (get_shift_alg): Remove redundant code.
1511
1512 2003-01-20  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1513
1514         * system.h (__NO_STRING_INLINES): Define.
1515
1516 2003-01-20  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
1517
1518         * ifcvt.c (noce_emit_store_flag): Don't emit store flag if mode of x
1519         is not a scalar int mode.
1520
1521 2003-01-20  Roger Sayle  <roger@eyesopen.com>
1522
1523         * cse.c (cse_insn): Avoid RTL sharing when updating the RETVAL
1524         insn's notes following a substitution inside a libcall.
1525
1526 2003-01-20  Zack Weinberg  <zack@codesourcery.com>
1527
1528         * configure.in: Check for system-provided 'uchar' type.
1529         * configure, config.in: Regenerate.
1530         * cpphash.h: Only typedef 'uchar' if the system doesn't.
1531
1532 2003-01-20  Richard Henderson  <rth@redhat.com>
1533
1534         * expr.h (MUST_PASS_IN_STACK): Move implementation...
1535         * calls.c (default_must_pass_in_stack): ... here.
1536
1537 2003-01-20  Vladimir Makarov  <vmakarov@redhat.com>
1538
1539         * genattrtab.h (INSN_ALTS_FUNC_NAME): Move it from genautomata.c.
1540
1541         * genautomata.c (INSN_ALTS_FUNC_NAME): Move it into genattrtab.h.
1542
1543         * genattr.c (main): Output default definition of AUTOMATON_ALTS.
1544         Wrap up definition of `insn_alts'.
1545
1546         * genattrtab.c (main): Wrap up `insn_alts'.
1547
1548 2003-01-20  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1549
1550         * collect2.c (ldgetname): Check HAVE_DECL_LDGETNAME before
1551         prototyping.
1552         * configure.in: Check for <ldfcn.h> and ldgetname() prototype.
1553
1554         * config.in, configure: Regenerate.
1555
1556 2003-01-20  Nick Clifton  <nickc@redhat.com>
1557
1558         * config/arm/arm.md (sibcall_epilogue): Add an
1559         UNSPEC_PROLOGUE_USE to prevent the link register from being
1560         considered dead.
1561
1562 Mon Jan 20 14:36:23 CET 2003  Jan Hubicka  <jh@suse.cz>
1563
1564         * i386.md (SSE cmov splitter):  Handle memory operand in operand 5.
1565
1566 2003-01-20  Andreas Schwab  <schwab@suse.de>
1567
1568         * system.h: Don't declare strsignal if the decl test hasn't been
1569         run yet.
1570
1571 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
1572
1573         * config/h8300/h8300.c (notice_update_cc): Don't assume that
1574         recog_data.operands[0] is always associated with cc0.
1575
1576 2003-01-19  David Edelsohn  <edelsohn@gnu.org>
1577
1578         * collect2.c (ldgetname): Expand declaration to prototype.
1579         * read-rtl.c (atoll): Add prototype.
1580         * system.h (strsignal): Also declare if no declaration found.
1581
1582 2003-01-19  Alexandre Oliva  <aoliva@redhat.com>
1583
1584         * config.gcc (mips64*-*-linux*): Added.
1585         * config/mips/linux64.h, config/mips/t-linux64: New file.
1586         * config/mips/iris6.h (MIPS_TFMODE_FORMAT): Define.
1587         * config/mips/mips.c (override_options): Use it.
1588         * config/mips/mips.h (TARGET_SWITCHES): Added...
1589         (SUBTARGET_TARGET_SWITCHES): New, empty by default.
1590         * Makefile.in (SPECS): New.
1591         (STAGESTUFF, specs, mostlyclean, install-common): Use it.
1592         * gcc.c (process_command): Move self-spec processing past spec
1593         file loading.
1594         * doc/tm.texi (DRIVER_SELF_SPECS): Document the change.
1595         * doc/fragments.texi (MULTILIB_EXTRA_OPTS): Document need for
1596         CRTSTUFF_T_CFLAGS.
1597         (SPECS): Document.
1598         * doc/invoke.texi (-mabi-fake-default): Document.
1599
1600 2003-01-19  Stephane Carrez  <stcarrez@nerim.fr>
1601
1602         * config/m68hc11/m68hc11.c (stack_push_word, stack_pop_word,
1603         z_reg, z_reg_qi): Declare static and GTY().
1604         (da_reg): Remove.
1605         (create_regs_rtx): Don't create da_reg.
1606         ("gt-m68hc11.h"): Include for GTY roots.
1607         * config/m68hc11/m68hc11.h (ix_reg, iy_reg, d_reg): Declare extern
1608         and GTY() here.
1609         (m68hc11_compare_op0, m68hc11_compare_op1): Likewise.
1610         (m68hc11_soft_tmp_reg): Likewise.
1611         * config/m68hc11/m68hc11-protos.h: Remove above declarations.
1612
1613 2003-01-18  Kazu Hirata  <kazu@cs.umass.edu>
1614
1615         * basic-block.h: Fix comment formatting.
1616         * calls.c: Likewise.
1617         * combine.c: Likewise.
1618         * convert.c: Likewise.
1619         * gcov.c: Likewise.
1620         * haifa-sched.c: Likewise.
1621         * libgcc2.c: Likewise.
1622         * loop.c: Likewise.
1623         * profile.c: Likewise.
1624         * system.h: Likewise.
1625
1626 2003-01-18  Roger Sayle  <roger@eyesopen.com>
1627
1628         * config/pa/pa.md (muldi3): Avoid invalid sharing of SUBREG RTXs.
1629
1630 2003-01-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1631
1632         * ra-build.c (undef_to_size_word): Avoid `switch' warning.
1633
1634 2003-01-17  Dale Johannesen  <dalej@apple.com>
1635
1636         * config/rs6000/rs6000.md (*floatsidf2_internal):  Add earlyclobbers.
1637           (*floatunssidf2_internal):  Ditto.
1638
1639 2003-01-17  Kazu Hirata  <kazu@cs.umass.edu>
1640
1641         * alias.c: Fix comment typos.
1642         * basic-block.h: Likewise.
1643         * c-common.c: Likewise.
1644         * c-common.h: Likewise.
1645         * c-decl.c: Likewise.
1646         * c-opts.c: Likewise.
1647         * c-pragma.c: Likewise.
1648         * c-pretty-print.h: Likewise.
1649         * cfg.c: Likewise.
1650         * cfganal.c: Likewise.
1651         * cfgbuild.c: Likewise.
1652         * cfgcleanup.c: Likewise.
1653         * cfglayout.c: Likewise.
1654         * cfgrtl.c: Likewise.
1655         * convert.c: Likewise.
1656         * cpphash.h: Likewise.
1657         * cpplex.c: Likewise.
1658         * cpplib.h: Likewise.
1659         * df.h: Likewise.
1660         * diagnostic.c: Likewise.
1661         * diagnostic.h: Likewise.
1662         * dwarf2.h: Likewise.
1663
1664 2003-01-17  Stan Shebs  <shebs@apple.com>
1665
1666         * config/darwin-protos.h: Forward-declare struct cpp_reader.
1667
1668 2003-01-17  Douglas B Rupp  <rupp@gnat.com>
1669
1670         * config/alpha/alpha.c (alpha_need_linkage): Fix obvious
1671         mistake in last checkin.
1672
1673 2003-01-17  Kazu Hirata  <kazu@cs.umass.edu>
1674
1675         * et-forest.c: Fix comment typos.
1676         * et-forest.h: Likewise.
1677         * except.c: Likewise.
1678         * expr.c: Likewise.
1679         * flags.h: Likewise.
1680         * flow.c: Likewise.
1681         * gcc.c: Likewise.
1682         * gcse.c: Likewise.
1683         * genattrtab.c: Likewise.
1684         * genautomata.c: Likewise.
1685         * gengtype.c: Likewise.
1686         * genrecog.c: Likewise.
1687         * global.c: Likewise.
1688         * gthr-rtems.h: Likewise.
1689
1690 2003-01-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1691
1692         * i386.c (x86_function_profiler): Fix format specifier.
1693
1694 2003-01-17  Richard Henderson  <rth@redhat.com>
1695
1696         * gengtype.c (walk_type): Allow paramN_is.
1697
1698 2003-01-17  Nick Clifton  <nickc@redhat.com>
1699
1700         * config/i960/t-960bare (i960-c.o): Add missing newline escape.
1701
1702 2003-01-16  Richard Henderson  <rth@redhat.com>
1703
1704         * config/alpha/linux-elf.h (LIB_SPEC): Adjust inter-option spacing.
1705
1706 2003-01-16  Richard Henderson  <rth@redhat.com>
1707
1708         * config/alpha/alpha.c (alpha_sr_alias_set): Mark GTY.
1709         (alpha_next_sequence_number): Likewise.
1710         (alpha_this_literal_sequence_number): Likewise.
1711         (alpha_this_gpdisp_sequence_number): Likewise.
1712         (struct alpha_funcs, alpha_funcs_num): Likewise.
1713         (struct alpha_links): Fix branch merge error.
1714         (alpha_need_linkage, alpha_use_linkage): Use GC for alpha_funcs.
1715
1716 2003-01-17  Alexandre Oliva  <aoliva@redhat.com>
1717
1718         * config/mips/mips.h: Don't use #elif.  Reported by Kaveh
1719         R. Ghazi.
1720
1721 2003-01-16  Kazu Hirata  <kazu@cs.umass.edu>
1722
1723         * ifcvt.c: Fix comment typos.
1724         * lcm.c: Likewise.
1725         * libgcc2.c: Likewise.
1726         * local-alloc.c: Likewise.
1727         * loop.c: Likewise.
1728         * predict.c: Likewise.
1729         * ra-build.c: Likewise.
1730         * ra.c: Likewise.
1731         * ra-colorize.c: Likewise.
1732         * ra.h: Likewise.
1733         * ra-rewrite.c: Likewise.
1734         * regmove.c: Likewise.
1735         * reload.h: Likewise.
1736         * rtlanal.c: Likewise.
1737         * toplev.c: Likewise.
1738         * tree.h: Likewise.
1739         * unwind-dw2-fde-glibc.c: Likewise.
1740         * vmsdbgout.c: Likewise.
1741
1742 2003-01-16  Richard Henderson  <rth@redhat.com>
1743
1744         * dwarf2out.c (struct file_table): Remove.
1745         (FILE_TABLE_INCREMENT): Remove.
1746         (file_table): Make a varray; mark for GC.  Update all users.
1747         (file_table_last_lookup_index): Extract from struct file_table.
1748         (output_file_names): Fix unsigned compare warnings.
1749         (add_name_attribute): Remove inline marker.
1750         (add_comp_dir_attribute): Split out from gen_compile_unit_die.
1751         (lookup_filename): Don't manage size of file_table.
1752         (init_file_table): Allocate file_table with GC.
1753         (dwarf2out_init): Don't record main_input_filename here.
1754         (dwarf2out_finish): Do it here instead.
1755
1756 2003-01-16  Bruce Korb  <bkorb@gnu.org>
1757
1758         * gcc/fixinc/inclhack.def(limits_ifndef): QNX needs a bypass, too.
1759
1760 2003-01-16  Kaz Kojima  <kkojima@gcc.gnu.org>
1761
1762         * config/sh/sh.c (sh_initialize_trampoline): Emit rotrdi3_mextr
1763         instead of rotldi3_mextr.
1764
1765 2003-01-16  Vladimir Makarov  <vmakarov@redhat.com>
1766
1767         * haifa-sched.c (move_insn): Restore moving all schedule group.
1768         (set_priorities): Restore taking SCHED_GROUP_P into account.
1769
1770         * sched-deps.c (add_dependence): Restore processing the last group
1771         insn.
1772         (remove_dependence, group_leader): Restore the functions.
1773         (set_sched_group_p): Restore adding dependencies from previous insn
1774         in the group.
1775         (compute_forward_dependences): Restore usage of group_leader.
1776
1777         * sched-ebb.c (init_ready_list): Restore taking SCHED_GROUP_P into
1778         account.
1779
1780         * sched-rgn.c (init_ready_list): Restore taking SCHED_GROUP_P into
1781         account.
1782         (can_schedule_ready_p): Ditto.
1783         (add_branch_dependences): Restore skipping over the group insns.
1784
1785 2003-01-16  Stephane Carrez  <stcarrez@nerim.fr>
1786
1787         * config/m68hc11/m68hc11.c (m68hc11_check_z_replacement): Fix handling
1788         68HC12 pre/post inc/dec side effects.
1789
1790 2003-01-16  Stephane Carrez  <stcarrez@nerim.fr>
1791
1792         * config/m68hc11/m68hc11.h (MASK_M6812): Define.
1793
1794 Thu Jan 16 21:50:25 2003  J"orn Rennecke <amylaar@onetel.net.uk>
1795
1796         * sh.md (mshflo_w_x): Fix description of operation.
1797
1798 2003-01-16  Zack Weinberg  <zack@codesourcery.com>
1799
1800         * config/rs6000/rs6000.h: Mention Altivec registers in
1801         commentary.  Fix typo.
1802
1803 2003-01-16  David Edelsohn  <edelsohn@gnu.org>
1804
1805         * config/rs6000/rs6000.md (movti_string): Remove clobber.
1806         * config/rs6000/rs6000.c (rs6000_emit_move, TImode): Explicitly
1807         generate PARALLEL with clobber for TARGET_POWER.
1808
1809 2003-01-16  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1810
1811         * ra-colorize.c (colorize_one_web): Initialize variable.
1812         * regmove.c (fixup_match_1): Likewise.
1813         * reload1.c (reload_as_needed): Likewise.
1814         * sdbout.c (SET_KNOWN_TYPE_TAG): Add cast.
1815
1816 2003-01-16  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1817
1818         * cfgloop.c (flow_loops_find): Fix handling of abnormal edges.
1819
1820 2003-01-16  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1821
1822         * dbxout.c (lastfile, cwd): Fix `unused' warning.
1823         * dwarf2out.c (fde_table_in_use, current_funcdef_fde,
1824         dw_cfi_oprnd1_desc, dw_cfi_oprnd2_desc, next_die_offset,
1825         is_main_source, file_table, decl_die_table_in_use,
1826         abbrev_die_table_in_use, line_info_table_in_use,
1827         separate_line_info_table_in_use, pubname_table_in_use,
1828         arange_table_in_use, ranges_table_in_use,
1829         current_function_has_inlines): Likewise.
1830         * flow.c (life_analysis): Likewise.
1831         * genemit.c (gen_insn): Likewise.
1832         * protoize.c (cplus_suffix): Likewise.
1833
1834         * arm.c (ROUND_UP_WORD): Renamed from ROUND_UP.
1835         * arm.h (ROUND_UP_WORD): Likewise.
1836
1837         * arm.h (CONDITIONAL_REGISTER_USAGE): Avoid signed/unsigned
1838         warning.
1839         * emit-rtl.c (gen_rtx_REG, set_mem_attributes_minus_bitpos,
1840         init_emit_once): Likewise.
1841         * flow.c (mark_regs_live_at_end, calculate_global_regs_live):
1842         Likewise.
1843         * function.c (assign_stack_temp_for_type): Likewise.
1844         * loop.c (loop_invariant_p): Likewise.
1845         * recog.c (push_operand): Likewise.
1846         * regclass.c (init_reg_sets_1): Likewise.
1847         * reload.c (update_auto_inc_notes): Likewise.
1848         * reload1.c (reload_as_needed, emit_input_reload_insns): Likewise.
1849         * stmt.c (expand_asm_operands): Likewise.
1850         * stor-layout.c (start_record_layout): Likewise.
1851
1852 2003-01-16  Herman A.J. ten Brugge <hermantenbrugge@home.nl>
1853
1854         * config/c4x/c4x.md (epilogue): Correct last patch.
1855
1856 2003-01-15  Richard Henderson  <rth@redhat.com>
1857
1858         * config/alpha/alpha.c (find_lo_sum_using_gp): Rename from find_lo_sum;
1859         also check that GP is being used.
1860         (alpha_find_lo_sum_using_gp): New.
1861         (alpha_does_function_need_gp): Use get_attr_usegp.
1862         * config/alpha/alpha-protos.h: Update.
1863         * config/alpha/alpha.md (attr usegp): New.  Annotate patterns
1864         as needed.
1865
1866 2003-01-15  Roger Sayle  <roger@eyesopen.com>
1867
1868         * gcse.c (one_cprop_pass): Change function arguments to take both
1869         cprop_jumps and bypass_jumps flags instead of just alter_jumps.
1870         (gcse_main): Update calls to one_cprop_pass, disabling bypassing.
1871         (bypass_jumps): New function to perform separate jump bypassing pass.
1872         * rtl.h (bypass_jumps): Add function prototype.
1873         * timevar.def (TV_BYPASS): New timing variable.
1874         * toplev.c (enum dump_file_index): Add new entry DFI_bypass.
1875         (dump_file): New entry for the bypass RTL dump file.
1876         (rest_of_compilation): Insert new jump bypassing optimization
1877         pass after loop.
1878         * doc/passes.texi: Document new pass.
1879
1880 2003-01-15  John David Anglin  <dave@hiauly1.hia.nrc.ca>
1881
1882         * som.h (SUPPORTS_WEAK, SUPPORTS_ONE_ONLY, MAKE_DECL_ONE_ONLY,
1883         ASM_WEAKEN_LABEL, GTHREAD_USE_WEAK): Define.
1884         * pa.h (TARGET_SOM_SDEF): Define.
1885         * pa-hpux11.h (TARGET_SOM_SDEF): Define.
1886
1887 2003-01-16  Stephane Carrez  <stcarrez@nerim.fr>
1888
1889         * config/m68hc11/m68hc11.c (expand_prologue): Use push/pop to
1890         allocate 4-bytes of locals on 68HC11.
1891         (expand_epilogue): Likewise.
1892         (m68hc11_memory_move_cost): Increase cost of HI/QI soft registers.
1893
1894 2003-01-15  Stephane Carrez  <stcarrez@nerim.fr>
1895
1896         * config/m68hc11/m68hc11.h (ASM_SPEC): Handle -m68hcs12; Pass -mshort
1897         and -mshort-double to the assembler to specify the ABI.
1898         (LINK_SPEC): Likewise.
1899         (CPP_SPEC): Pass HCS12 specific define.
1900         (MASK_M68S12): New define.
1901         (TARGET_M68S12): Likewise.
1902         (TARGET_SWITCHES): New options -m68hcs12 and -m68S12.
1903         (TARGET_VERSION): Update.
1904         * config/m68hc11/m68hc12.h (CPP_SPEC): Pass HCS12 specific define.
1905         (LINK_SPEC): Update.
1906         (ASM_SPEC): Update.
1907         * config/m68hc11/m68hc11.c (m68hc11_asm_file_start): Update.
1908         * doc/invoke.texi (M68hc1x Options): Document -m68hcs12.
1909
1910 2003-01-15  Stephane Carrez  <stcarrez@nerim.fr>
1911
1912         * config/m68hc11/m68hc11.md ("return"): Use emit_jump_insn to emit
1913         the return code.
1914
1915 2003-01-15  Josef Zlomek  <zlomekj@suse.cz>
1916
1917         * cfganal.c (set_edge_can_fallthru_flag): Clear the EDGE_CAN_FALLTHRU
1918         flag before setting it.
1919
1920 2003-01-15  Roger Sayle  <roger@eyesopen.com>
1921
1922         * c-semantics.c (genrtl_while_stmt):  Improve initial RTL generation
1923         when loop condition is known true, i.e.  "while (1) { ... }".
1924         (genrtl_for_stmt): Similarly for "for" statements.
1925
1926 2003-01-15  Roger Sayle  <roger@eyesopen.com>
1927
1928         * real.c (real_sqrt): Return a bool result indicating whether
1929         a floating point exception or trap should be raised.
1930         * real.h (real_sqrt): Update function prototype.
1931         * builtins.c (fold_builtin): Only fold non-trapping square
1932         roots unless we're ignoring errno and trapping math.
1933
1934 2003-01-15  John David Anglin  <dave.anglin@nrc.gc.ca>
1935
1936         * expr.h (emit_conditional_add): Add PARAMS to declaration.
1937         * gengtype-lex.l (malloc, realloc): Move defines after include of
1938         system.h.  Remove duplicate include of system.h.
1939
1940 2003-01-15  Roger Sayle  <roger@eyesopen.com>
1941
1942         PR middle-end/9009
1943         * optabs.c (expand_unop):  When manipulating the FP sign bit
1944         using integer operations, account for targets with different
1945         integer and FP word orders.
1946         (expand_abs): Likewise.
1947
1948 2003-01-15  David Edelsohn  <edelsohn@gnu.org>
1949
1950         * config/rs6000/rs6000.c (rs6000_gen_section_name): Do not include
1951         file extension in section name.
1952
1953 2003-01-15  Richard Earnshaw  <rearnsha@arm.com>
1954
1955         * flow.c (find_auto_inc): Also try to generate a PRE_MODIFY with
1956         constant offset.
1957
1958 2003-01-15  Richard Earnshaw  <rearnsha@arm.com>
1959
1960         * arm.h (HAVE_PRE_MODIFY_DISP, HAVE_PRE_MODIFY_REG): Define.
1961         (HAVE_POST_MODIFY_DISP, HAVE_POST_MODIFY_REG): Define.
1962         (ARM_GO_IF_LEGITIMATE_ADDRESS): Handle pre/post-modify addresses.
1963         (ARM_PRINT_OPERAND_ADDRESS): Likewise.
1964
1965 Wed Jan 15 12:23:21 CET 2003  Jan Hubicka  <jh@suse.cz>
1966
1967         PR f/9258
1968         * global.c (struct allocno): Add no_stack_reg.
1969         (global_conflicts): Set no_stack_reg.
1970         (find_reg): Use it.
1971
1972         * convert.c (convert_to_real): Fold - and abs only when profitable.
1973         * fold-const.c (fold): Fold truncates in - and abs.
1974
1975 2003-01-15  Josef Zlomek  <zlomekj@suse.cz>
1976
1977         Segher Boessenkool  <segher@koffie.nl>
1978
1979         * predict.c (real_inv_br_prob_base): New variable.
1980         (propagate_freq): Use multiply by reciprocal instead of
1981         division.  Don't divide by 1.0 at all.
1982         (estimate_bb_frequencies): Similar.
1983
1984 2003-01-15  Alexandre Oliva  <aoliva@redhat.com>
1985
1986         * configure.in (libgcc_visibility): Force disabled on IRIX 6 too.
1987         * configure: Rebuilt.
1988
1989 2003-01-15  Hartmut Penner  <hpenner@de.ibm.com>
1990
1991         * config/s390/s390.c (s390_safe_attr_type): New function.
1992         (s390_use_dfa_pipeline_interface): New function, return true for z900.
1993         (s390_issue_rate): New function.
1994         (s390_agen_dep_p): New function.
1995         (addr_generation_dependency_p): Use 's390_safe_attr_type'.
1996         (s390_adjust_cost): Return 'cost' if new DFA is used.
1997         (s390_adjust_priority): Delete function.
1998         * config/s390/s390-protos.h: (s390_agen_dep_p): New prototype.
1999         * config/s390/s390.md (atype attribute): Attribute 'atype' default
2000         determined by 'op_type'.
2001         (type attribute): Added more type attributes.
2002         * config/s390/2064.md: New DFA description for z900 pipeline.
2003
2004 2003-01-15  Alexandre Oliva  <aoliva@redhat.com>
2005
2006         * config/i386/i386.c (ix86_expand_vector_move): Validize constant
2007         forced to memory.  Fixes PR bootstrap/9036.
2008
2009         * config/mips/mips.h (CRT_CALL_STATIC_FUNCTION): Define so as
2010         to set $gp before the call.
2011
2012 2003-01-14  Richard Henderson  <rth@redhat.com>
2013
2014         * config/alpha/alpha.c (alpha_expand_mov): Use correct mode
2015         for force_const_mem.
2016
2017 2003-01-14  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2018
2019         * genattr.c (main): Rearrange output to avoid prototype warning.
2020         * genautomata.c (transform_3): Fix ambiguous-else warning.
2021         * local-alloc.c (requires_inout): Add parentheses around
2022         assignment used as truth-value.
2023         * timevar.c: Move system includes above local includes.  Include
2024         toplev.h
2025         * Makefile.in (timevar.o): Depend on toplev.h.
2026
2027 2003-01-14  Denis Chertykov  <denisc@overta.ru>
2028
2029         * config/ip2k/ip2k.h (VALID_MACHINE_DECL_ATTRIBUTE): Remove.
2030         (VALID_MACHINE_TYPE_ATTRIBUTE): Remove.
2031
2032         * config/ip2k/ip2k.c (ip2k_attribute_table): New table of
2033         attributes.
2034         (TARGET_ATTRIBUTE_TABLE): New macro.
2035         (valid_machine_type_attribute): Remove.
2036         (valid_machine_decl_attribute): Remove.
2037         (ip2k_handle_progmem_attribute): New function.
2038         (ip2k_handle_fndecl_attribute): New function.
2039
2040 2003-01-10  Andrew Haley  <aph@redhat.com>
2041
2042         * config/i386/linux64.h (MD_FALLBACK_FRAME_STATE_FOR): Rename
2043         registers to be in correct order.  Add rip.
2044
2045 2003-01-14  Kazu Hirata  <kazu@cs.umass.edu>
2046
2047         * config/h8300/h8300.md (*andsi3_lshiftrt_9_sb): New.
2048         (*iorsi3_and_lshiftrt_9_sb): Likewise.
2049
2050 Tue Jan 14 00:45:33 CET 2003  Jan Hubicka  <jh@suse.cz>
2051
2052         * convert.c (strip_float_extensions):  Look for narrowest type handling
2053         FP constants.
2054
2055         * fold-const.c (fold):  Fold (double)float1 CMP (double)float2 into
2056         float1 CMP float2.
2057         * convert.c (strip_float_extensions): Make global.
2058         * tree.h (strip_float_extensions): Declare.
2059
2060 2003-01-14  Gabriel Dos Reis  <gdr@integrable-solutions.net>
2061
2062         * timevar.def: define TV_NAME_LOOKUP.
2063         * timevar.c (timevar_pop): Be verbose when aborting.
2064
2065 2003-01-13  Andreas Schwab  <schwab@suse.de>
2066
2067         * Makefile.in ($(parsedir)/gengtype-lex.c): Don't change to
2068         $(parsedir), just move the temporary file at the end.
2069         ($(parsedir)/gengtype-yacc.c): Likewise.
2070
2071 2003-01-13  Alexandre Oliva  <aoliva@redhat.com>
2072
2073         * aclocal.m4 (gcc_AC_PROG_GNAT): Don't try to prepend
2074         ${ac_tool_prefix} to ADAC or CC.  Protect them from word
2075         splitting.
2076         * configure: Rebuilt.
2077
2078 2003-01-13  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2079
2080         * config/sparc/gmon-sol2.c (moncontrol, monstartup, _mcleanup,
2081         internal_mcount): Don't use PARAMS.
2082         (monstartup, _mcleanup, internal_mcount, moncontrol): Convert to
2083         ISO C style.
2084         (internal_mcount): Use __attribute__, not ATTRIBUTE_UNUSED.
2085
2086 2003-01-13  Andreas Schwab  <schwab@suse.de>
2087
2088         * config/rs6000/sysv4.h (ASM_OUTPUT_ALIGNED_LOCAL): Output type
2089         directive.
2090
2091 2003-01-13  Kazu Hirata  <kazu@cs.umass.edu>
2092
2093         * config/h8300/h8300.md (*andsi3_lshift_n_sb): New.
2094         (*iorsi3_and_lshiftrt_n_sb): Likewise.
2095
2096 2003-01-12  Mark Mitchell  <mark@codesourcery.com>
2097
2098         PR c++/9264
2099         * c-lex.c (c_lex): Set the token value to error_mark_node for
2100         invalid numeric constants.
2101
2102 2003-01-12  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2103
2104         * c-pch.c (asm_file_startpos): Change to `long'.
2105         (pch_init): Use ftell, not ftello.
2106         (c_common_write_pch): Use ftell/fseek, not ftello/fseeko.
2107         Use `long' instead of `off_t'.
2108         (c_common_read_pch): Likewise.
2109         * ggc-common.c (gt_pch_save): Use long/ftell instead of
2110         off_t/ftello.
2111
2112 2003-01-12  Alan Modra  <amodra@bigpond.net.au>
2113
2114         * expr.c (expand_expr <RDIV_EXPR>): Correct recursive call args.
2115
2116 2003-01-11  Richard Earnshaw  (rearnsha@arm.com)
2117
2118         * arm-protos.h (struct cpp_reader): Add declaration.
2119
2120 Sat Jan 11 11:02:58 CET 2003  Jan Hubicka  <jh@suse.cz>
2121
2122         PR target/9068
2123         * i386.c (output_fp_compare): Fix typo.
2124
2125 2003-01-10  David Edelsohn  <edelsohn@gnu.org>
2126
2127         * config/rs6000/rs6000.c (common_mode_defined): Mark for PCH.
2128
2129 2003-01-10  Geoffrey Keating  <geoffk@apple.com>
2130
2131         * Makefile.in (parsedir): New variable.
2132         (docobjdir): New variable.
2133         (c-parse.o, c-parse.c, c-parse.y, gengtype-lex.o, gengtype-yacc.o,
2134         gengtype-lex.c, gengtype-yacc.c): Use parsedir.
2135         (info, cpp.info, gcc.info, gccint.info, gccinstall.info,
2136         cppinternals.info, generated-manpages, gcov.1, cpp.1, gcc.1, gfdl.7,
2137         gpl.7, fsf-funding.7, maintainer-clean, install-info, install-man):
2138         Use docobjdir.
2139         * objc/Make-lang.in (objc/objc-parse.c, objc/objc-parse.y,
2140         objc.maintainer-clean): Use parsedir.
2141
2142         * varasm.c (struct constant_descriptor_rtx): Remove unused
2143         `label' field.
2144
2145         * toplev.c (documented_lang_options): Document -Winvalid-pch.
2146
2147 2003-01-10  Richard Henderson  <rth@redhat.com>
2148
2149         * config/alpha/alpha.h (NO_PROFILE_COUNTERS): Set.
2150         (ASM_OUTPUT_REG_PUSH, ASM_OUTPUT_REG_POP): Kill.
2151
2152 2003-01-10  Richard Henderson  <rth@redhat.com>
2153
2154         * combine.c (make_compound_operation): Use SCALAR_INT_MODE_P,
2155         not INTEGRAL_MODE_P when widening extensions.
2156
2157 2003-01-10  Richard Henderson  <rth@redhat.com>
2158
2159         * config/alpha/alpha.c (decl_has_samegp): True for !TREE_PUBLIC.
2160
2161 2003-01-10  Geoffrey Keating  <geoffk@apple.com>
2162
2163         * ggc-page.c (ggc_collect): Avoid overflow computing
2164         min_expand.
2165
2166         * Makefile.in (RANLIB_FOR_TARGET): Use RANLIB when native.
2167         (RANLIB_TEST_FOR_TARGET): Delete.  Don't pass down to sub-makes.
2168         Remove calls.
2169         * mklibgcc.in: Remove uses of RANLIB_TEST_FOR_TARGET.
2170
2171 Fri Jan 10 22:05:35 CET 2003  Jan Hubicka  <jh@suse.cz>
2172
2173         * ifcvt.c (noce_try_addcc): Do not call emit_conditional_add
2174         with weird operands.
2175
2176 2003-01-10  Dale Johannesen <dalej@apple.com>
2177
2178         * calls.c (load_register_parameters):  Add is_sibcall, sibcall_failure
2179         parameters.  Call check_sibcall_argument_overlap if indicated.
2180         (check_sibcall_argument_overlap):  Add mark_stored_args_map
2181         parameter.  Don't mark parameter area as clobbered if not set.
2182         (expand_call):  Adjust calls to above.
2183
2184 2003-01-10 Kelley Cook <kelleycook@comcast.net>
2185
2186         * configure.in (linker read-only and read-write section mixing):
2187         Squelch some assembler warnings.
2188         * configure: Likewise.
2189
2190 2003-01-10  Hartmut Penner  <hpenner@de.ibm.com>
2191
2192         * doc/invoke.texi: Document -mtune, delete -mcpu
2193         option for S/390 and zSeries.
2194         * config/s390/s390.c (s390_tune_string) New variable.
2195         (s390_cpu_string) Delete variable.
2196         (override_options): Use s390_tune_string instead of
2197         s390_cpu_string.
2198         * config/s390/s390.h: (TARGET_OPTIONS) '-mtune' instead of '-mcpu'.
2199
2200 2003-01-10  Kazu Hirata  <kazu@cs.umass.edu>
2201
2202         * config/h8300/h8300.md (*iorsi3_ashift_31): New.
2203
2204 2003-01-10  Josef Zlomek  <zlomekj@suse.cz>
2205
2206         * jump.c (next_nonnote_insn_in_loop): New function.
2207         (copy_loop_headers): Use next_nonnote_insn_in_loop instead of
2208         next_nonnote_insn.
2209         (duplicate_loop_exit_test). Likewise.
2210
2211 2003-01-09  Geoffrey Keating  <geoffk@apple.com>
2212
2213         Merge from pch-branch:
2214
2215         2003-01-06  Geoffrey Keating  <geoffk@apple.com>
2216
2217         * ggc-page.c (ggc_pch_read): Update the statistics after a PCH
2218         load.
2219
2220         2002-12-24  Geoffrey Keating  <geoffk@apple.com>
2221
2222         * cpplib.c (count_registered_pragmas): New function.
2223         (save_registered_pragmas): New function.
2224         (_cpp_save_pragma_names): New function.
2225         (restore_registered_pragmas): New function.
2226         (_cpp_restore_pragma_names): New function.
2227         * cpphash.h (_cpp_save_pragma_names): Prototype.
2228         (_cpp_restore_pragma_names): Likewise.
2229         * cpppch.c (struct save_macro_item): Split from save_macro_data.
2230         (struct save_macro_data): New field 'saved_pragmas'.
2231         (save_macros): Update for changes to struct save_macro_data.
2232         (cpp_prepare_state): Call _cpp_save_pragma_names, update
2233         for changes to struct save_macro_data.
2234         (cpp_read_state): Call _cpp_restore_pragma_names, update
2235         for changes to struct save_macro_data.
2236
2237         * cpppch.c (cpp_read_state): Restore the hashtable references
2238         in the cpp_reader.
2239
2240         * tree.h (built_in_decls): Mark for PCH.
2241
2242         * dbxout.c (lastfile): Don't mark for PCH.
2243
2244         * ggc.h: Document PCH calls into memory managers.
2245
2246         2002-12-18  Geoffrey Keating  <geoffk@apple.com>
2247
2248         * doc/invoke.texi (Precompiled Headers): Document the
2249         directory form of PCH.
2250         * cppfiles.c (validate_pch): New function.
2251         (open_file_pch): Search suitably-named directories for PCH files.
2252
2253         2002-12-14  Geoffrey Keating  <geoffk@apple.com>
2254
2255         * doc/gty.texi (GTY Options): Document chain_next, chain_prev,
2256         reorder options.
2257         (Type Information): Mention that the information is also
2258         used to implement PCH.
2259         * doc/passes.texi (Passes): Improve documentation of
2260         language-specific files.
2261
2262         2002-12-11  Geoffrey Keating  <geoffk@apple.com>
2263
2264         * gengtype.c (struct write_types_data): Add reorder_note_routine field.
2265         (struct walk_type_data): Add reorder_fn field.
2266         (walk_type): Process 'reorder' option.
2267         (write_types_process_field): Reorder parameters to gt_pch_note_object,
2268         call reorder_note_routine.
2269         (write_func_for_structure): Reorder parameters to gt_pch_note_object.
2270         (ggc_wtd): Update for change to struct write_types_data.
2271         (pch_wtd): Likewise.
2272         * ggc.h (gt_pch_note_object): Reorder parameters.
2273         (gt_handle_reorder): New definition.
2274         (gt_pch_note_reorder): New prototype.
2275         * ggc-common.c (struct ptr_data): Add reorder_fn.
2276         (gt_pch_note_object): Reorder parameters.
2277         (gt_pch_note_reorder): New.
2278         (gt_pch_save): Call reorder_fn.
2279         * stringpool.c (gt_pch_n_S): Update for change to gt_pch_note_object.
2280
2281         * dbxout.c (cwd): Don't mark for PCH.
2282
2283         2002-12-09  Geoffrey Keating  <geoffk@apple.com>
2284
2285         * gengtype.c (finish_root_table): Fix some warnings.
2286         (write_root): Handle TYPE_STRING.
2287         * ggc.h (gt_ggc_m_S): Add prototype.
2288         * stringpool.c (gt_ggc_m_S): New function.
2289
2290         2002-11-30  Geoffrey Keating  <geoffk@apple.com>
2291
2292         * dwarf2out.c (dw2_string_counter): New.
2293         (AT_string_form): Use it.
2294         (same_dw_val_p): Update for removal of hashtable.h hash tables.
2295
2296         2002-11-22  Geoffrey Keating  <geoffk@apple.com>
2297
2298         * dbxout.c: Include gt-dbxout.h.
2299         (lastfile): Mark for PCH/GGC.
2300         (cwd): Likewise.
2301         (struct typeinfo): Likewise.
2302         (typevec): Likewise.
2303         (typevec_len): Likewise.
2304         (next_type_number): Likewise.
2305         (struct dbx_file): Likewise.
2306         (current_file): Likewise.
2307         (next_file_number): Likewise.
2308         (dbxout_init): Allocate typevec, struct dbx_file with GGC.
2309         (dbxout_start_source_file): Allocate struct dbx_file with GGC.
2310         (dbxout_end_source_file): Don't free struct dbx_file.
2311         (dbxout_type): Use GGC to allocate typevec.
2312         * Makefile.in (dbxout.o): Depend on gt-dbxout.h, $(GGC_H).
2313         (GTFILES): Add dbxout.c.
2314         (gt-dbxout.h): New rule.
2315
2316         * Makefile.in (c-pch.o): Add debug.h as dependency.
2317         * c-pch.c: Include debug.h.
2318         (pch_init): Call start_source_file to keep nesting right.
2319         (c_common_read_pch): Add orig_name parameter.  Call
2320         start_source_file debug hook.  Call end_source_file debug hook.
2321         * c-common.h (c_common_read_pch): Update prototype.
2322         * cpplib.h (struct cpp_callbacks): Add fourth field to read_pch
2323         callback.
2324         * cppfiles.c (struct include_file): Add new field `header_name'.
2325         (find_or_create_entry): Default it to `name'.
2326         (open_file_pch): Set it to the original header file searched for.
2327         (stack_include_file): Don't stack an empty buffer, just handle
2328         PCH files immediately.  Pass header_name field to read_pch callback.
2329
2330         2002-11-19  Geoffrey Keating  <geoffk@apple.com>
2331
2332         * function.c (funcdef_no): Mark to be saved in a PCH.
2333
2334         2002-11-15  Geoffrey Keating  <geoffk@apple.com>
2335
2336         * ggc-page.c (ggc_pch_read): Remove unused 'bmap_size'.
2337
2338         * cpppch.c (cpp_read_state): Correct size reallocated for 'defn'.
2339
2340         2002-11-14  Geoffrey Keating  <geoffk@apple.com>
2341
2342         * optabs.h (code_to_optab): Add GTY marker.
2343
2344         2002-11-13  Geoffrey Keating  <geoffk@apple.com>
2345
2346         * Makefile.in (GTFILES): Add cpplib.h.
2347         * c-common.h (struct c_common_identifier): Don't skip 'node' field.
2348         * c-decl.c (build_compound_literal): Don't use var_labelno.
2349         * cpplib.h (struct cpp_hashnode): Use gengtype to mark.
2350         * dwarf2asm.c (dw2_force_const_mem): Don't use const_labelno.
2351         * varasm.c (const_labelno): Use gengtype to mark.
2352         (var_labelno): Likewise.
2353         (in_section): Likewise.
2354         (in_named_name): Likewise.
2355         (struct in_named_entry): Likewise.
2356         (in_named_htab): Likewise.
2357         (set_named_section_flags): Use GGC to allocate struct in_named_entry.
2358         (init_varasm_once): Use GGC to allocate in_named_htab.
2359         * config/darwin.c (current_pic_label_num): Mark for PCH.
2360
2361         2002-11-11  Geoffrey Keating  <geoffk@apple.com>
2362
2363         * ggc-simple.c (init_ggc_pch): New stub procedure.
2364         (ggc_pch_count_object): Likewise.
2365         (ggc_pch_total_size): Likewise.
2366         (ggc_pch_this_base): Likewise.
2367         (ggc_pch_alloc_object): Likewise.
2368         (ggc_pch_prepare_write): Likewise.
2369         (ggc_pch_write_object): Likewise
2370         (ggc_pch_finish): Likewise.
2371         (ggc_pch_read): Likewise.
2372
2373         2002-11-08  Geoffrey Keating  <geoffk@apple.com>
2374
2375         * c-pch.c (c_common_write_pch): Write the macro definitions after
2376         the GCed data.
2377         (c_common_read_pch): Call cpp_prepare_state.  Restore the macro
2378         definitions after the GCed data.
2379         * cpplib.c (save_macros): New.
2380         (reset_ht): New.
2381         (cpp_write_pch_deps): Split out of cpp_write_pch.
2382         (cpp_write_pch_state): Split out of cpp_write_pch.
2383         (cpp_write_pch): Delete.
2384         (struct save_macro_data): Delete.
2385         (cpp_prepare_state): New.
2386         (cpp_read_state): Erase and restore initial macro definitions.
2387         * cpplib.h (struct save_macro_data): Forward-declare.
2388         (cpp_write_pch_deps): Prototype.
2389         (cpp_write_pch_state): Prototype.
2390         (cpp_write_pch): Delete prototype.
2391         (cpp_prepare_state): Prototype.
2392         (cpp_read_state): Add fourth argument.
2393
2394         2002-11-04  Geoffrey Keating  <geoffk@apple.com>
2395
2396         * gengtype.c (adjust_field_rtx_def): Don't use skip on valid fields.
2397         (write_array): Remove warning.
2398
2399         * gengtype.c (contains_scalar_p): New.
2400         (finish_root_table): Add the table to all languages, even if it's
2401         empty.
2402         (write_roots): Output gt_pch_scalar_rtab.
2403         * ggc-common.c (gt_pch_save): Write out scalars.
2404         (gt_pch_restore): Read scalars back.
2405
2406         * ggc-page.c (OBJECTS_IN_PAGE): New macro.
2407         (struct page_entry): Delete pch_page field.
2408         (ggc_recalculate_in_use_p): Use OBJECTS_IN_PAGE.
2409         (clear_marks): Likewise.
2410         (sweep_pages): Likewise.
2411         (poison_pages): Likewise.
2412         (ggc_print_statistics): Likewise.
2413         (ggc_pch_read): Don't free objects read from a PCH.
2414         Properly set up in_use_p and page_tails.
2415
2416         2002-10-25  Geoffrey Keating  <geoffk@apple.com>
2417
2418         * gengtype.c (struct write_types_data): New.
2419         (struct walk_type_data): Make `cookie' const; add extra
2420         prev_val item; add `orig_s' field.
2421         (walk_type): Update prev_val[3].
2422         (write_types_process_field): New.
2423         (write_func_for_structure): Take write_types_data structure.
2424         (write_types): New.
2425         (ggc_wtd): New.
2426         (pch_wtd): New.
2427         (write_types_local_process_field): New.
2428         (gc_mark_process_field): Delete.
2429         (write_local_func_for_structure): New.
2430         (gc_mark_func_name): Delete.
2431         (write_gc_types): Delete.
2432         (write_local): New.
2433         (finish_root_table): Don't include 'ggc_' in PFX.
2434         (write_root): Rename from write_root.  Fill pchw field of structures.
2435         (write_array): New.
2436         (write_roots): Rename from write_gc_roots.  Split out to write_array.
2437         Update to changes to other routines.  Write gt_pch_cache_rtab table.
2438         (main): Write PCH walking routines.
2439         * ggc-common.c: Include toplev.h, sys/mman.h.
2440         (ggc_mark_roots): For cache hashtables, also mark the hash table
2441         and the array of entries.
2442         (saving_htab): New.
2443         (struct ptr_data): New.
2444         (POINTER_HASH): New.
2445         (gt_pch_note_object): New.
2446         (saving_htab_hash): New.
2447         (saving_htab_eq): New.
2448         (struct traversal_state): New.
2449         (call_count): New.
2450         (call_alloc): New.
2451         (compare_ptr_data): New.
2452         (relocate_ptrs): New.
2453         (write_pch_globals): New.
2454         (struct mmap_info): New.
2455         (gt_pch_save): New.
2456         (gt_pch_restore): New.
2457         * ggc-page.c (ROUND_UP_VALUE): New.
2458         (ROUND_UP): New.
2459         (struct page_entry): Add field `pch_page'.
2460         (init_ggc): Use ROUND_UP.
2461         (struct ggc_pch_data): Declare.
2462         (init_ggc_pch): New.
2463         (ggc_pch_count_object): New.
2464         (ggc_pch_total_size): New.
2465         (ggc_pch_this_base): New.
2466         (ggc_pch_alloc_object): New.
2467         (ggc_pch_prepare_write): New.
2468         (ggc_pch_write_object): New.
2469         (ggc_pch_finish): New.
2470         (ggc_pch_read): New.
2471         * ggc.h (gt_pointer_operator): New.
2472         (gt_note_pointers): New.
2473         (gt_pch_note_object): New prototype.
2474         (gt_pointer_walker): New.
2475         (struct ggc_root_tab): Use gt_pointer_walker, add `pchw' field.
2476         (LAST_GGC_ROOT_TAB): Update.
2477         (gt_pch_cache_rtab): Declare.
2478         (gt_pch_scalar_rtab): Declare.
2479         (struct ggc_cache_tab): Use gt_pointer_walker, add `pchw' field.
2480         (LAST_GGC_CACHE_TAB): Update.
2481         (gt_pch_save_stringpool): Declare.
2482         (gt_pch_restore_stringpool): Declare.
2483         (gt_pch_p_S): Declare.
2484         (gt_pch_n_S): Declare.
2485         (struct ggc_pch_data): Forward-declare.
2486         (init_ggc_pch): Declare.
2487         (ggc_pch_count_object): Declare.
2488         (ggc_pch_total_size): Declare.
2489         (ggc_pch_this_base): Declare.
2490         (ggc_pch_alloc_object): Declare.
2491         (ggc_pch_prepare_write): Declare.
2492         (ggc_pch_write_object): Declare.
2493         (ggc_pch_finish): Declare.
2494         (ggc_pch_read): Declare.
2495         (gt_pch_save): Declare.
2496         (gt_pch_restore): Declare.
2497         * fold-const.c (size_int_type_wide): Allocate size_htab using GGC.
2498         * emit-rtl.c (init_emit_once): Allocate const_int_htab,
2499         const_double_htab, mem_attrs_htab using GGC.
2500         * c-pch.c: Include ggc.h.
2501         (pch_init): Allow reading PCH file back.
2502         (c_common_write_pch): Call gt_pch_save.
2503         (c_common_read_pch): Call gt_pch_restore.
2504         * c-parse.in (init_reswords): Delete now-untrue comment.
2505         Allocate ridpointers using GGC.
2506         * c-objc-common.c (c_objc_common_finish_file): Write PCH before
2507         calling expand_deferred_fns.
2508         * c-common.h (ridpointers): Mark for GTY machinery.
2509         * Makefile.in (stringpool.o): Update dependencies.
2510         (c-pch.o): Update dependencies.
2511         (ggc-common.o): Update dependencies.
2512         * stringpool.c: Include gt-stringpool.h.
2513         (gt_pch_p_S): New.
2514         (gt_pch_n_S): New.
2515         (struct string_pool_data): New.
2516         (spd): New.
2517         (gt_pch_save_stringpool): New.
2518         (gt_pch_restore_stringpool): New.
2519         * tree.c (init_ttree): Make type_hash_table allocated using GC.
2520
2521         2002-10-04  Geoffrey Keating  <geoffk@apple.com>
2522
2523         * gengtype.c (adjust_field_rtx_def): Don't pass size_t to printf.
2524         (output_mangled_typename): Don't pass size_t to printf.
2525
2526         * tree.h (union tree_type_symtab): Add tag to `address' field.
2527         (union tree_decl_u2): Add tag to 'i' field.
2528         * varasm.c (union rtx_const_un): Add tags to all fields.
2529         * gengtype.c (struct walk_type_data): New.
2530         (output_escaped_param): Take struct walk_type_data parameter.
2531         (write_gc_structure_fields): Delete.
2532         (walk_type): New.
2533         (write_gc_marker_routine_for_structure): Delete.
2534         (write_func_for_structure): New.
2535         (gc_mark_process_field): New.
2536         (gc_mark_func_name): New.
2537         (gc_counter): Delete.
2538         (write_gc_types): Use write_func_for_structure.
2539         (write_gc_roots): Use walk_type.
2540
2541         2002-10-02  Geoffrey Keating  <geoffk@apple.com>
2542
2543         * ggc-common.c (ggc_mark_roots): Delete 'x'.
2544         (ggc_splay_dont_free): Fix warning about unused 'x'.
2545         (ggc_print_common_statistics): Remove warnings.
2546
2547         2002-10-01  Mike Stump  <mrs@apple.com>
2548
2549         * ggc-common.c (ggc_splay_alloc): Actually return the allocated area.
2550         * gengtype.c (write_gc_structure_fields): Handle param[digit]_is.
2551
2552         2002-09-01  Geoffrey Keating  <geoffk@redhat.com>
2553             Catherine Moore  <clm@redhat.com>
2554
2555         * Makefile (c-pch.o): Update dependencies.
2556         (LIBCPP_OBJS): Add cpppch.o.
2557         (cpppch.o): New.
2558         * c-common.c (c_common_init): Don't call pch_init here.
2559         * c-common.h (c_common_read_pch): Update prototype.
2560         * c-lex.c (c_common_parse_file): Call pch_init here.
2561         * c-opts.c (COMMAND_LINE_OPTIONS): Add -Winvalid-pch, -fpch-deps.
2562         (c_common_decode_option): Handle them.
2563         * c-pch.c: Include c-pragma.h.
2564         (save_asm_offset): Delete.
2565         (pch_init): Move contents of save_asm_offset into here, call
2566         cpp_save_state.
2567         (c_common_write_pch): Call cpp_write_pch.
2568         (c_common_valid_pch): Warn only when -Winvalid-pch.  Call
2569         cpp_valid_state.
2570         (c_common_read_pch): Add NAME parameter.  Call cpp_read_state.
2571         * cppfiles.c (stack_include_file): Update for change to
2572         parameters of cb.read_pch.
2573         * cpphash.h (struct cpp_reader): Add `savedstate' field.
2574         * cpplib.h (struct cpp_options): Add `warn_invalid_pch' and
2575         `restore_pch_deps' fields.
2576         (struct cpp_callbacks): Add NAME parameter to `read_pch'.
2577         (cpp_save_state): Prototype.
2578         (cpp_write_pch): Prototype.
2579         (cpp_valid_state): Prototype.
2580         (cpp_read_state): Prototype.
2581         * cpppch.c: New file.
2582         * flags.h (version_flag): Remove prototype.
2583         * mkdeps.c (deps_save): New.
2584         (deps_restore): New.
2585         * mkdeps.h (deps_save): Prototype.
2586         (deps_restore): Prototype.
2587         * toplev.c (late_init_hook): Delete.
2588         (version_flag): Make static again.
2589         (compile_file): Don't call late_init_hook.
2590         * toplev.h (late_init_hook): Delete.
2591         * doc/cppopts.texi: Document -fpch-deps.
2592         * doc/invoke.texi (Warning Options): Document -Winvalid-pch.
2593
2594         2002-08-27  Geoffrey Keating  <geoffk@redhat.com>
2595
2596         * c-pch.c (c_common_write_pch): Rename from c_write_pch, change
2597         callers.
2598         (c_common_valid_pch): Rename from c_valid_pch, change callers.
2599         (c_common_read_pch): Rename from c_read_pch, change callers.
2600
2601         * c-opts.c (COMMAND_LINE_OPTIONS): Allow -output-pch= to have
2602         a space between it and its argument.
2603
2604         2002-08-24  Geoffrey Keating  <geoffk@redhat.com>
2605
2606         * c-pch.c: New file.
2607         * toplev.h (late_init_hook): Declare.
2608         * toplev.c (late_init_hook): Define.
2609         (version_flag): Make globally visible.
2610         (compile_file): Call late_init_hook.
2611         (init_asm_output): Make output file seekable.
2612         * gcc.c (default_compilers): Update c-header rule.
2613         * flags.h (version_flag): Declare.
2614         * cpplib.h (struct cpp_callbacks): Add 'valid_pch' and 'read_pch'
2615         fields.
2616         * cppfiles.c (struct include_file): Add 'pch' field.
2617         (INCLUDE_PCH_P): New.
2618         (open_file_pch): New.
2619         (stack_include_file): Handle PCH files specially.
2620         (find_include_file): Call open_file_pch instead of open_file.
2621         (_cpp_read_file): Explain why open_file is used instead of
2622         open_file_pch.
2623         * c-opts.c (c_common_decode_option): Correct OPT__output_pch case.
2624         * c-objc-common.c (c_objc_common_finish_file): Call c_write_pch.
2625         * c-lex.c (init_c_lex): Set valid_pch and read_pch fields
2626         in cpplib callbacks.
2627         * c-common.c (pch_file): Correct comment.
2628         (allow_pch): Define.
2629         (c_common_init): Call pch_init.
2630         * c-common.h (allow_pch): Declare.
2631         (pch_init): Declare.
2632         (c_valid_pch): Declare.
2633         (c_read_pch): Declare.
2634         (c_write_pch): Declare.
2635         * Makefile.in (c-pch.o): New.
2636         (C_AND_OBJC_OBJS): Add c-pch.o.
2637         * doc/invoke.texi (Precompiled Headers): Add index entries,
2638         complete truncated paragraph.
2639
2640         2002-08-17  Geoffrey Keating  <geoffk@redhat.com>
2641
2642         * c-common.c: (pch_file): Define.
2643         * c-common.h (pch_file): Declare.
2644         * c-opts.c (COMMAND_LINE_OPTIONS): Add --output-pch=.
2645         (missing_arg): Require --output-pch= to have an argument.
2646         (c_common_decode_option): Handle --output-pch=.
2647         * gcc.c: Document new %V.
2648         (default_compilers): Handle compiling C header files.
2649         (do_spec_1): Implement %V.
2650         (main): Handle "gcc foo.h" without trying to run linker.
2651         * doc/invoke.texi (Invoking GCC): Add new menu item for PCH.
2652         (Overall Options): Document what the driver does with header files,
2653         document new -x option possibilities.
2654         (Invoking G++): More documentation for PCH.
2655         (Precompiled Headers): New.
2656
2657         2002-08-09  Geoffrey Keating  <geoffk@redhat.com>
2658
2659         * ggc.h: Don't include varray.h.  Rearrange functions to be more
2660         organized.
2661         (ggc_add_root): Delete.
2662         (ggc_mark_rtx): Delete.
2663         (ggc_mark_tree): Delete.
2664         (struct ggc_statistics): Remove contents.
2665         * ggc-common.c: Remove unneeded includes.
2666         (struct ggc_root): Delete.
2667         (roots): Delete.
2668         (ggc_add_root): Delete.
2669         (ggc_mark_roots): Don't mark `roots'.  Call ggc_mark_stringpool.
2670         (ggc_print_common_statistics): Remove most of the contents.
2671         * Makefile.in (GGC_H): No longer uses varray.h.
2672         (ggc-common.o): Update dependencies.
2673         (c-parse.o): Add varray.h to dependencies.
2674         (c-common.o): Add varray.h.
2675         * stringpool.c (mark_ident): Use mangled name for tree marker routine.
2676         (mark_ident_hash): Rename to ggc_mark_stringpool.
2677         (init_stringpool): Don't use ggc_add_root.
2678         * c-parse.in: Include varray.h.
2679         * c-common.c: Include varray.h.
2680         * objc/Make-lang.in (objc-act.o): Add varray.h.
2681         * objc/objc-act.c: Include varray.h.
2682
2683         2002-07-25  Geoffrey Keating  <geoffk@redhat.com>
2684
2685         * dwarf2out.c (dw_cfi_oprnd2_desc): Fix ISO-only function definition.
2686         (dw_cfi_oprnd1_desc): Likewise.
2687
2688         2002-07-17  Geoffrey Keating  <geoffk@redhat.com>
2689
2690         * config/alpha/alpha.c (struct alpha_links): Use gengtype to mark;
2691         move out of ifdef.
2692         (alpha_links): Use gengtype to mark; move out of ifdef.
2693         (mark_alpha_links_node): Delete.
2694         (mark_alpha_links): Delete.
2695         (alpha_need_linkage): Use GGC to allocate splay tree, struct
2696         alpha_links, strings.  Don't use ggc_add_root.
2697         * ggc-common.c (ggc_splay_alloc): New.
2698         (ggc_splay_dont_free): New.
2699         * ggc.h (ggc_mark_rtx): Update for changed name mangling.
2700         (ggc_mark_tree): Likewise.
2701         (splay_tree_new_ggc): New.
2702         (ggc_splay_alloc): Declare.
2703         (ggc_splay_dont_free): Declare.
2704         * dwarf2asm.c: Include gt-dwarf2asm.h.
2705         (mark_indirect_pool_entry): Delete.
2706         (mark_indirect_pool): Delete.
2707         (indirect_pool): Use gengtype to mark.
2708         (dw2_force_const_mem): Don't use ggc_add_root.
2709         * Makefile.in (dwarf2asm.o): Depend on gt-dwarf2asm.h.
2710         (GTFILES): Add SPLAY_TREE_H, dwarf2asm.c.
2711         (gt-dwarf2asm.h): Depend on s-gtype.
2712
2713         2002-07-08  Geoffrey Keating  <geoffk@redhat.com>
2714
2715         * tree.h (union tree_type_symtab): Mark `die' field.
2716         * Makefile.in (dwarf2out.o): Update dependencies.
2717         * dwarf2out.c: Use GGC to allocate all structures.  Convert to htab_t
2718         hash tables.
2719         (dw_cfi_oprnd1_desc): New function.
2720         (dw_cfi_oprnd2_desc): New function.
2721         (indirect_string_alloc): Delete.
2722         (debug_str_do_hash): New function.
2723         (debug_str_eq): New function.
2724         (mark_limbo_die_list): Delete.
2725         (dwarf2out_init): Don't call ggc_add_root.
2726
2727 2003-01-09  Vladimir Makarov  <vmakarov@redhat.com>
2728
2729         The following changes are merged from itanium-sched-branch:
2730
2731         2003-01-08  David Edelsohn  <edelsohn@gnu.org>
2732
2733         * doc/md.texi: Clarify assignment of units to automata description.
2734
2735         2003-01-08  Vladimir Makarov  <vmakarov@redhat.com>
2736
2737         * genautomata.c (unit_decl): Remove members
2738         `the_same_automaton_unit' and
2739         `the_same_automaton_message_reported_p'.
2740         (process_unit_to_form_the_same_automaton_unit_lists,
2741         form_the_same_automaton_unit_lists_from_regexp,
2742         form_the_same_automaton_unit_lists, the_same_automaton_lists):
2743         Remove them.
2744         (annotation_message_reported_p): New global variable.
2745         (check_unit_distribution_in_reserv,
2746         check_regexp_units_distribution): New functions.
2747         (check_unit_distributions_to_automata): Rewrite it.
2748
2749         2003-01-04  Vladimir Makarov  <vmakarov@redhat.com>
2750
2751         * genautomata.c (form_the_same_automaton_unit_lists_from_regexp):
2752         Use continue instead of break if cycle is too big.
2753
2754         2002-12-20  Vladimir Makarov  <vmakarov@redhat.com>
2755
2756         * genautomata.c (check_unit_distributions_to_automata): Output at
2757         most one message for a unit.
2758         (process_unit_to_form_the_same_automaton_unit_lists): Check
2759         automaton of units instead of units themself.
2760
2761         * doc/md.texi: Describe the constraint about assigning unit to
2762         automata.
2763
2764         2002-12-20  Jan Hubicka  <jH@suse.cz>
2765                     Vladimir Makarov  <vmakarov@redhat.com>
2766
2767         * genautomata.c (unit_decl): Add new members `min_occ_cycle_num'
2768         and `in_set_p'.
2769         (gen_cpu_unit): Initialize the new members.
2770         (process_regexp_cycles): Calculate minimal finish cycle too.  Set
2771         up `min_occ_cycle_num'.
2772         (evaluate_max_reserv_cycles): Change the function call.
2773         (CLEAR_BIT): New macro.
2774         (states_union, state_shift): Use the mask.
2775         (initiate_excl_sets, form_reserv_sets_list): Set up `in_set_p'.
2776         (form_reservs_matter): New function.
2777         (make_automaton): Call the function and use the mask.
2778         (estimate_one_automaton_bound): Take `min_occ_cycle_num' into
2779         account.
2780
2781         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
2782
2783         * config/ia64/itanium2.md (lfetch): Change the insn reservation.
2784
2785         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
2786
2787         * config/ia64/ia64.c (bundling): Try to insert 2 nops for M insn
2788         for Itanium.
2789
2790         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
2791
2792         * config/ia64/ia64.c (ia64_override_options): Make itanium2 as
2793         default cpu.
2794
2795         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
2796                 2002-10-31  Dale Johannesen <dalej@apple.com>
2797
2798         * haifa-sched.c (find_set_reg_weight): New function.
2799         (find_insn_reg_weight): Use the new function.
2800         (schedule_block): Do sorting ready queue always
2801         after insn issue.
2802
2803         2002-11-27  Vladimir Makarov  <vmakarov@redhat.com>
2804
2805         * config/ia64/ia64.c (bundling): Use MFI template instead of MLX.
2806
2807         2002-11-19  Vladimir Makarov  <vmakarov@redhat.com>
2808
2809         * haifa-sched.c (choice_entry): New structure.
2810         (choice_stack, cycle_issued_insns): New variables.
2811         (max_issue): Rewrite it.
2812         (choose_ready): Set up ready_try for unknown insns too.
2813         (schedule_block): Allocate and free choice_stack.  Set up
2814         and modify cycle_issued_insns.
2815
2816         * config/ia64/ia64.c (issue_nops_and_insn): Combine insn issue
2817         with and without filling the bundle.
2818         (bundling): Combine calls of issue_nops_and_insn.
2819
2820         2002-10-17  Vladimir Makarov  <vmakarov@redhat.com>
2821
2822         * config/ia64/itanium1.md: New file.
2823
2824         * config/ia64/itanium2.md: New file.
2825
2826         * config/ia64/ia64.md: Move DFA descriptions into the new files.
2827         Remove the old pipeline description.
2828
2829         * config/ia64/ia64.c (ia64_override_options): Add aliases of
2830         itanium processor names.
2831
2832         2002-10-16  Vladimir Makarov  <vmakarov@redhat.com>
2833
2834         * config/ia64/ia64.c (bundling): Print states for Itanium2 too.
2835         (ia64_reorg):  Set up queried unit codes for Itanium2 too.
2836
2837         * config/ia64/ia64.md: Add descriptions for Itanium2.
2838
2839         2002-10-08  Vladimir Makarov  <vmakarov@redhat.com>
2840
2841         * config/ia64/ia64.h (processor_type): New enumeration.
2842         (ia64_tune, ia64_tune_string): New external declarations.
2843         (TARGET_OPTIONS): Add option `tune='.
2844
2845         * config/ia64/ia64.c (ia64_tune, ia64_tune_string): New global
2846         variables.
2847         (ia64_override_options): Set up `ia64_tune'.
2848         (ia64_sched_reorder2): Set up `clocks' only for Itanium.
2849         (ia64_dfa_new_cycle): Set up `add_cycles' only for Itanium.
2850         (bundling): Add nops for MM-insns only for Itanium.
2851         (ia64_reorg): Allocate and free `clocks' and `add_cycles' only for
2852         Itanium.
2853
2854         * config/ia64/ia64.md (cpu): New attribute.
2855         (DFA description): Enable it only for Itanium.
2856
2857         2002-10-08  Vladimir Makarov  <vmakarov@redhat.com>
2858                     Richard Henderson  <rth@redhat.com>
2859
2860         * config/ia64/ia64.h (MASK_TUNE_STOP_BITS): Rename it to
2861         MASK_EARLY_STOP_BITS.
2862         (TARGET_TUNE_STOP_BITS): Rename it to TARGET_EARLY_STOP_BITS.
2863         (TARGET_SWITCHES): Rename option `tune-stop-bits' to
2864         `early-stop-bits'.
2865
2866         * config/ia64/ia64.c (ia64_dfa_new_cycle,
2867         final_emit_insn_group_barriers): Use TARGET_EARLY_STOP_BITS
2868         instead of TARGET_TUNE_STOP_BITS.
2869
2870         * doc/invoke.texi: Rename option `-mtune-stop-bits' to
2871         `-mearly-stop-bits'.
2872
2873         * config/ia64/ia64.c (automata_option "v"): Comment it.
2874
2875         2002-10-07  Vladimir Makarov  <vmakarov@redhat.com>
2876
2877         * config/ia64/ia64.h (MASK_TUNE_STOP_BITS, TARGET_TUNE_STOP_BITS):
2878         New macros.
2879         (TARGET_SWITCHES): Add entries for the new option.
2880
2881         * config/ia64/ia64.c (dfa_stop_insn, last_scheduled_insn, rtx
2882         dfa_pre_cycle_insn, ia64_nop): Don't make them as roots for GC.
2883         (stops_p, stop_before_p, clocks_length, clocks, add_cycles): New
2884         global variables.
2885         (ia64_sched_reorder2): Set up `clocks'.
2886         (ia64_variable_issue): Set up `stops_p' and reset `stop_before_p'.
2887         (ia64_dfa_new_cycle): Set up add_cycle.  Permit sorting ready
2888         queue when TARGET_TUNE_STOP_BITS.
2889         (bundling): Insert additional nops for MM-insns.
2890         (final_emit_insn_group_barriers): Add insertion of stop bits
2891         according `stops_p'.
2892         (ia64_reorg): Initiate the new varibales.
2893
2894         * doc/invoke.texi: Add description of option `-mtune-stop-bits'.
2895
2896         2002-10-02  Vladimir Makarov  <vmakarov@redhat.com>
2897
2898         * haifa-sched.c (schedule_block): Modify INSN_TICK of depended
2899         insns at the end of block insn scheduling.
2900
2901         2002-09-30  Vladimir Makarov  <vmakarov@redhat.com>
2902
2903         * sched-deps.c (remove_dependence, group_leader): Remove it.
2904         (add_dependence): Add dependence to group leader to.
2905         (set_sched_group_p): Add dependence to the first insn of the
2906         schedule group too.
2907         (sched_analyze_insn): Make dependence to jump as anti-dependence.
2908         Change true dependence by anti-dependence when
2909         `reg_pending_barrier'.
2910
2911         * sched-rgn.c (init_ready_list, can_schedule_ready_p,
2912         add_branch_dependences): Ignore schedule groups.
2913
2914         * sched-ebb.c (init_ready_list): Ditto.
2915
2916         * (move_insn, set_priorities): Ditto.
2917
2918         * config/ia64/ia64.c (ia64_sched_init): Check that schedule group
2919         flag is clear after reload.
2920         (adjust_cost): Change cost only for output dependencies.
2921
2922         * config/ia64/ia64.md: Add more insns into bypass for MM-insns.
2923
2924         2002-09-26  Vladimir Makarov  <vmakarov@redhat.com>
2925
2926         * Makefile.in (sched-ebb.o): Add `$(TARGET_H)' to the entry.
2927
2928         * target.h (gcc_target): Add member
2929         `dependencies_evaluation_hook'.
2930
2931         * target-def.h (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK): New
2932         macro.
2933         (TARGET_SCHED): Add initiatialization of the new member.
2934
2935         * sched-ebb.c: Include `target.h'.
2936         (schedule_ebb): Call `dependencies_evaluation_hook'.
2937
2938         * sched-rgn.c (schedule_region): Call
2939         `dependencies_evaluation_hook'.
2940
2941         * config/ia64/ia64.c (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK):
2942         New macro.
2943         (ia64_dependencies_evaluation_hook): New function.
2944
2945         * doc/tm.texi (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK):
2946         Describe the new hook.
2947
2948         2002-09-25  Vladimir Makarov  <vmakarov@redhat.com>
2949
2950         * target.h (gcc_target): Add members
2951         `first_cycle_multipass_dfa_lookahead_guard' and `dfa_new_cycle'.
2952
2953         * target-def.h (TARGET_SCHED_DFA_NEW_CYCLE,
2954         TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD): New
2955         macros.
2956         (TARGET_SCHED): Add initiatialization of the new members.
2957
2958         * haifa-sched.c (schedule_insn): Update last_clock_var for the 1st
2959         insn scheduling too.
2960         (choose_ready): Use `first_cycle_multipass_dfa_lookahead_guard' to
2961         initialize `ready_try'.
2962         (schedule_block): Use `dfa_new_cycle'.  Sort `ready' only unless
2963         `dfa_new_cycle' says not to do it.
2964
2965         * config/ia64/ia64.md: Add DFA Itanium 1 description for insn
2966         bundling.
2967
2968         * config/ia64/ia64.h (CPU_UNITS_QUERY): New macro.
2969
2970         * config/ia64/ia64.c: Include `hashtab.h'.
2971         (ia64_first_cycle_multipass_dfa_lookahead_guard,
2972         ia64_dfa_new_cycle, final_emit_insn_group_barriers,
2973         ia64_dfa_sched_reorder, get_free_bundle_state, free_bundle_state,
2974         initiate_bundle_states, finish_bundle_states, bundle_state_hash,
2975         bundle_state_eq_p, insert_bundle_state,
2976         initiate_bundle_state_table, finish_bundle_state_table,
2977         try_issue_nops, try_issue_insn, issue_nops_and_insn, get_max_pos,
2978         get_template, get_next_important_insn, bundling): New functions.
2979         (ia64_internal_sched_reorder): Remove it.
2980         (TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD,
2981         TARGET_SCHED_DFA_NEW_CYCLE): New macros.
2982         (ia64_safe_itanium_requires_unit0): Remove it.
2983         (group_barrier_needed_p): Place group barrier right before a real
2984         insn.
2985         (bundle, ia64_packet, NR_PACKETS, type_names, packets, packets):
2986         Remove them.
2987         (bundle_name): New variable.
2988         (_0mii_, _0mmi_, _0mfi_, _0mmf_, _0bbb_, _0mbb_, _0mib_, _0mmb_,
2989         _0mfb_, _0mlx_, _1mii_, _1mmi_, _1mfi_, _1mmf_, _1bbb_, _1mbb_,
2990         _1mib_, _1mmb_, _1mfb_, _1mlx_, pos_1, pos_2, pos_3, pos_4, pos_5,
2991         pos_6, dfa_stop_insn, last_scheduled_insn, dfa_state_size,
2992         temp_dfa_state, prev_cycle_state): New global variables.
2993         (insn_matches_slot, maybe_rotate, finish_last_head,
2994         rotate_one_bundle, rotate_one_bundles, nop_cycles_until,
2995         cycle_end_fill_slots, packet_matches_p, get_split, find_best_insn,
2996         find_best_packet, itanium_reorder, dump_current_packet,
2997         schedule_stop, gen_nop_type, ia64_emit_nops): Remove them.
2998         (sched_data, sched_ready, sched_types): Remove them.
2999         (ia64_sched_init): Initiate only `last_scheduled_insn' and call
3000         `init_insn_group_barriers'.
3001         (ia64_sched_reorder, ia64_sched_reorder2): Call
3002         ia64_dfa_sched_reorder.
3003         (ia64_variable_issue): Rewrite it.
3004         (bundle_state): New structure.
3005         (index_to_bundle_states, bundle_states_num,
3006         allocated_bundle_states_chain, free_bundle_state_chain): New
3007         global variables.
3008         (ia64_sched_finish): Add stop bits and call `bundling' after the
3009         2nd insn scheduling.
3010         (ia64_use_dfa_pipeline_interface): Return zero always.
3011         (ia64_first_cycle_multipass_dfa_lookahead): Return 6 for the 2nd
3012         insn scheduling.
3013         (ia64_init_dfa_pre_cycle_insn): Initialize `dfa_state_size',
3014         `temp_dfa_state', `prev_cycle_state', and `dfa_stop_insn'.
3015         (ia64_reorg): Add bundling insns.
3016
3017         * doc/tm.texi
3018         (TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD,
3019         TARGET_SCHED_DFA_NEW_CYCLE): Describe the new hooks.
3020
3021         2002-09-23  Vladimir Makarov  <vmakarov@redhat.com>
3022
3023         * config/ia64/ia64.md: Add Itanium1 DFA description.
3024         (itanium_class): Add `nop' and `pre_cycle'.  Add
3025         define_function_unit for `nop'.
3026         (nop): Change attribute `itanium_class'.
3027         (pre_cycle): New define_insn.
3028
3029         * config/ia64/ia64-protos.h (bundling_p): New external variable.
3030         (ia64_st_address_bypass_p, ia64_ld_address_bypass_p,
3031         ia64_produce_address_p): New function prototypes.
3032
3033         * config/ia64/ia64.c (bundling_p): New global variable.
3034         (ia64_use_dfa_pipeline_interface,
3035         ia64_first_cycle_multipass_dfa_lookahead,
3036         ia64_init_dfa_pre_cycle_insn, ia64_dfa_pre_cycle_insn): New
3037         functions.
3038         (TARGET_SCHED_USE_DFA_PIPELINE_INTERFACE,
3039         TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD,
3040         TARGET_SCHED_INIT_DFA_PRE_CYCLE_INSN,
3041         TARGET_SCHED_DFA_PRE_CYCLE_INSN): New macros.
3042         (ia64_sched_init, ia64_sched_reorder, ia64_sched_reorder2,
3043         ia64_variable_issue, ia64_sched_finish): Do nothing before reload.
3044         (dfa_pre_cycle_insn): New variable.
3045
3046         2002-09-20  Vladimir Makarov  <vmakarov@redhat.com>
3047
3048         * rtl.def (FINAL_PRESENCE_SET, FINAL_ABSENCE_SET): New
3049         constructions.
3050
3051         * genattrtab.h (gen_final_presence_set, gen_final_absence_set):
3052         New function prototypes.
3053
3054         * genattrtab.c (main): Process the new constructions.
3055
3056         * genautomata.c (gen_presence_absence_set,
3057         process_presence_absence_names, process_presence_absence_patterns,
3058         add_presence_absence, check_absence_pattern_sets): Add parameter
3059         `final_p'.
3060         (unit_decl): Add new members `final_presence_list' and
3061         `final_absence_list'.
3062         (unit_pattern_rel_decl): Add new member `final_p'.
3063         (gen_final_presence_set, gen_final_absence_set): New functions.
3064         (process_decls): Use member `final_p'.
3065         (temp_reserv): New global variable.
3066         (reserv_sets_are_intersected): Add processing `final_presence_set'
3067         and `final_absence_set'.
3068         (initiate_states): Allocate `temp_reserv'.
3069         (unit_final_presence_set_table, unit_final_absence_set_table): New
3070         gloabal variables.
3071         (initiate_presence_absence_pattern_sets): Initiate them.
3072         (NDFA_to_DFA): Fix typo.
3073         (output_description): Output `final_presence_set' and
3074         `final_absence_set'.
3075
3076         * doc/md.texi (final_presence_set, final_absence_set): Describe
3077         them.
3078
3079         2002-09-20  Vladimir Makarov  <vmakarov@redhat.com>
3080
3081         * genautomata.c (transform_3): Process a missing case (nothing on
3082         unit place).
3083
3084         2002-09-20  Vladimir Makarov  <vmakarov@redhat.com>
3085
3086         * rtl.def (DEFINE_QUERY_CPU_UNIT, AUTOMATA_OPTION): Change
3087         comments about queried units and the minimization.
3088
3089         * doc/md.texi: Ditto.
3090
3091         * genautomata.c (create_composed_state): Return nonzero if the new
3092         state has been created.
3093         (first_cycle_unit_presence): New function.
3094         (state_is_differed): Add new parameter.  Use the new function.
3095         Take queried units into account.
3096         (partition_equiv_class): Pass additional parameter to
3097         `state_is_differed'.
3098         (merge_states): Process composed states too.
3099         (build_automaton, create_automata, output_min_issue_delay_table,
3100         output_tables, output_statistics): Output more information.
3101         (output_reserved_units_table): Use function
3102         `first_cycle_unit_presence'.
3103         (output_tables): Output table of queried units even if the
3104         minimization is switched on.
3105         (write_automata): Output code for querying units even if the
3106         minimization is switched on.
3107
3108         2002-09-19  Vladimir Makarov  <vmakarov@redhat.com>
3109
3110         * rtl.def (PRESENCE_SET, ABSENCE_SET): Add comments about extended
3111         syntax of the constructions.
3112
3113         * doc/md.texi (PRESENCE_SET, ABSENCE_SET): Add description of
3114         extended syntax of the constructions.
3115
3116         * genautomata.c (unit_rel_decl): Rename it to
3117         `unit_pattern_rel_decl'.
3118         (pattern_set_el, pattern_reserv): New structures.
3119         (pattern_set_el_t, pattern_reserv_t): New types.
3120         (gen_presence_absence_set): New function.
3121         (process_presence_absence): Remove it.
3122         (process_presence_absence_names,
3123         process_presence_absence_patterns): New functions.
3124         (get_presence_absence_set): Remove it.
3125         (initiate_presence_absence_sets): Rename it on
3126         `initiate_presence_absence_pattern_sets'.  Use new function
3127         `form_reserv_sets_list'.
3128         (form_reserv_sets_list, check_presence_pattern_sets,
3129         check_absence_pattern_sets, output_pattern_set_el_list): New
3130         functions.
3131         (unit_decl): Change types of members `presence_list' and
3132         `absence_list'.
3133         (unit_rel_decl): Rename member `names_num' to `all_names_num'.
3134         (decl): Change types of members `excl', `presence', and `absence'.
3135         (get_str_vect): Rename `par_flag' to `paren_p'.  Add null element
3136         at the end of the vector.
3137         (gen_cpu_unit, gen_query_cpu_unit, gen_bypass, gen_excl_set,
3138         gen_automaton, gen_regexp_repeat, gen_regexp_allof,
3139         gen_regexp_oneof, gen_regexp_sequence): Use boolean values.
3140         (gen_presence_set, gen_absence_set): Use new function
3141         `gen_presence_absence_set'.
3142         (add_presence_absence): Process `pattern_list' instead of
3143         `source_list'.
3144         (process_decls): USe new functions
3145         `process_presence_absence_names' and
3146         `process_presence_absence_patterns'.
3147         (reserv_sets_are_intersected): Use new function
3148         `check_presence_pattern_sets'.
3149         (presence_set, absence_set): Remove them.
3150         (unit_presence_set_table, unit_absence_set_table): New global
3151         variables.
3152         (output_description): Use new function
3153         `output_pattern_set_el_list'.
3154         (generate): Use `initiate_presence_absence_pattern_sets'.
3155
3156         2002-09-18  Vladimir Makarov  <vmakarov@redhat.com>
3157
3158         * genattr.c (main): Add output of prototype of new interface
3159         function `dfa_clean_insn_cache'.
3160
3161         * genautomata.c (output_dfa_clean_insn_cache_func): New function.
3162         (DFA_CLEAN_INSN_CACHE_FUNC_NAME): New macro.
3163         (output_dfa_start_func): Use function `dfa_clean_insn_cache' in
3164         the generated code.
3165         (write_automata): Call the new function.
3166
3167 Thu Jan  9 22:47:38 CET 2003  Jan Hubicka  <jh@suse.cz>
3168
3169         * i386.md (unit, prefix_0f, memory attributes): Hanlde sseicvt
3170         correctly.
3171
3172 2003-01-09  Paolo Carlini  <pcarlini@unitus.it>
3173
3174         * doc/tm.texi (EXTRA_ADDRESS_CONSTRAINT): Fix typo.
3175
3176 Thu Jan  9 17:26:40 2003  J"orn Rennecke <joern.rennecke@superh.com>
3177
3178         * defaults.h (EXTRA_MEMORY_CONSTRAINT): Add STR argument.
3179         (EXTRA_ADDRESS_CONSTRAINT): Likewise.
3180         (CONSTRAINT_LEN): Provide default definition.
3181         (CONST_OK_FOR_CONSTRAINT_P): Likewise.
3182         (CONST_DOUBLE_OK_FOR_CONSTRAINT_P): Likewise.
3183         (EXTRA_CONSTRAINT_STR): Likewise.
3184         (REG_CLASS_FROM_CONSTRAINT): Define.
3185         * genoutput.c (check_constraint_len, constraint_len): New functions.
3186         (validate_insn_alternatives): Check CONSTRAINT_LEN for each
3187         constraint / modifier.
3188         (gen_insn): Call check_constraint_len.
3189         * local-alloc.c (block_alloc): Update to use new macros / pass
3190         second argument to EXTRA_{MEMORY,ADDRESS}_CONSTRAINT.
3191         * ra-build.c (handle_asm_insn): Likewise.
3192         * recog.c (asm_operand_ok, preprocess_constraints): Likewise.
3193         (constrain_operands, peep2_find_free_register): Likewise.
3194         * regclass.c (record_operand_costs, record_reg_classes): Likewise.
3195         * regmove.c (find_matches): Likewise.
3196         * reload.c (push_secondary_reload, find_reloads): Likewise.
3197         (alternative_allows_memconst): Likewise.
3198         * reload1.c (maybe_fix_stack_asms): Likewise.
3199         (reload_cse_simplify_operands): Likewise.
3200         * stmt.c (parse_output_constraint, parse_input_constraint): Likewise.
3201         * doc/tm.texi (CONSTRAINT_LEN, REG_CLASS_FROM_CONSTRAINT): Document.
3202         (CONST_OK_FOR_CONSTRAINT_P): Likewise.
3203         (CONST_DOUBLE_OK_FOR_CONSTRAINT_P, EXTRA_CONSTRAINT_STR): Likewise.
3204         (EXTRA_MEMORY_CONSTRAINT, EXTRA_ADDRESS_CONSTRAINT): Add STR argument.
3205         * config/s390/s390.h (EXTRA_MEMORY_CONSTRAINT): Likewise.
3206
3207         * sh.h (OVERRIDE_OPTIONS): Allow first scheduling pass for SH5.
3208
3209 2003-01-09  Kazu Hirata  <kazu@cs.umass.edu>
3210
3211         * config/h8300/h8300.md (*extzv_1_r_h8300): Correct the insn
3212         length.
3213         (*extzv_1_r_h8300hs): Likewise.
3214         (*extzv_1_r_inv_h8300): Likewise.
3215         (*extzv_1_r_inv_h8300hs): Likewise.
3216
3217 2003-01-09  Kazu Hirata  <kazu@cs.umass.edu>
3218
3219         * config/h8300/h8300.h (PREDICATE_CODES): New.
3220
3221 2003-01-09  Kazu Hirata  <kazu@cs.umass.edu>
3222
3223         * config/h8300/h8300.md (*addsi3_upper): New.
3224         (*iorsi3_shift): Likewise.
3225         (two splitters): Likewise.
3226         (*addsi3_shift): Likewise.
3227         (two splitters): Likewise.
3228
3229 2003-01-09  Josef Zlomek  <zlomj9am@artax.karlin.mff.cuni.cz>
3230
3231         * Makefile.in (optabs.o): Add dependency on basic-block.h.
3232         * basic-block.h (control_flow_insn_p): Fuction was exported.
3233         * cfgbuild.c (control_flow_insn_p): Fuction was made non-static.
3234         * optabs.c (emit_libcall_block): Emit REG_LIBCALL and REG_RETVAL
3235         notes only when the region is contained in a single basic block.
3236
3237 2003-01-09  Eric Botcazou  <ebotcazou@libertysurf.fr>
3238
3239         PR inline-asm/8832
3240         * tree.h (expand_asm): New prototype.
3241         * stmt.c (expand_asm): Set the MEM_VOLATILE_P flag if instructed
3242         to do so.
3243         * c-semantics (genrtl_asm_stmt): Pass the RID_VOLATILE qualifier
3244         down to expand_asm.
3245         * c-typeck.c (simple_asm_stmt): Set the RID_VOLATILE qualifier.
3246         * rtlanal.c (volatile_insn_p) [ASM_INPUT]: Test the MEM_VOLATILE_P flag.
3247         (volatile_refs_p) [ASM_INPUT]: Likewise.
3248         (side_effects_p) [ASM_INPUT]: Likewise.
3249
3250 Thu Jan  9 12:00:36 CET 2003  Jan Hubicka  <jh@suse.cz>
3251
3252         * i386.md (*mul*): FIx constraints; remove confused comment; fix
3253         athlon_decode attributes
3254         (imul/k8 optimization peep2s): New.
3255
3256         * athlon.md (athlon_ssecmp*): Handle ssecomi as well.
3257         * i386.md (type attribute): Add ssecomi.
3258         (unit, memory, prefix attributes): Handle ssecomi.
3259         (cvt?2? patterns): Fix athlon_decode attribute
3260         (comi patterns): Set attribute to ssecomi.
3261
3262         PR target/8343
3263         * m68k.md (umulsidi, mulsidi expanders): Use register operand.
3264
3265 2003-01-09  Richard Sandiford  <rsandifo@redhat.com>
3266
3267         * config/mips/mips.h (PREDICATE_CODES): Add ADDRESSOF for predicates
3268         that match register_operands.
3269         * config/mips/mips.c (reg_or_0_operand, true_reg_or_0_operand): Make
3270         register_operand the default case.
3271
3272 2003-01-09  Eric Botcazou  <ebotcazou@libertysurf.fr>
3273
3274         PR c/8032
3275         * c-typeck.c (process_init_element) [RECORD_TYPE]: For
3276         an empty element, do not advance the pointer to unfilled
3277         fields if there are pending initializers.
3278
3279 2003-01-09  Christian Cornelssen  <ccorn@cs.tu-berlin.de>
3280
3281         * Makefile.in (ORDINARY_FLAGS_TO_PASS): Also pass DESTDIR.
3282         (install-gcc-tooldir, install-cpp, installdirs,
3283         install-common, install-driver, install-info, install-man,
3284         install-headers, install-include-dir, install-headers-tar,
3285         install-headers-cpio, install-headers-cp, install-mkheaders,
3286         install-collect2, uninstall): Prepend $(DESTDIR) to
3287         destination paths in all (un)installation commands.
3288         (install-driver): Rewrite $(LN) commands to support DESTDIR
3289         with "ln" as well as with "ln -s".
3290         (installdirs): Simply use mkinstalldirs.
3291         (install-libgcc, install-multilib): Also pass DESTDIR.
3292         * mklibgcc.in: Prepend $(DESTDIR) to $(libsubdir) in the
3293         installation destination variable ldir.
3294         * config/alpha/t-osf4, config/arm/t-netbsd,
3295         config/ia64/t-hpux, config/mips/t-iris5-6,
3296         config/pa/t-hpux-shlib, config/rs6000/t-aix43,
3297         config/rs6000/t-aix52, config/t-slibgcc-elf-ver,
3298         config/t-slibgcc-sld: Prepend $$(DESTDIR) to $$(slibdir)
3299         in the definition of SHLIB_INSTALL.
3300         * config/arc/t-arc (install-multilib-arc): Prepend $(DESTDIR) to
3301         $(libsubdir) in the installation commands.
3302
3303 2003-01-08  Kaz Kojima  <kkojima@gcc.gnu.org>
3304
3305         * config/sh/sh.h (CASE_VECTOR_MODE): Use SImode for a
3306         non-optimizing compile.
3307         (ASM_OUTPUT_ADDR_VEC_ELT): Use .long for a non-optimizing
3308         compile.
3309
3310 2003-01-08  Douglas B Rupp  <rupp@gnat.com>
3311
3312         * config/i386/i386.c (ix86_attribute_table): Add new attributes
3313         ms_struct and gcc_struct.
3314         (ix86_handle_struct_attribute): New function.
3315         (ix86_ms_bitfield_layout_p): Update to take new attributes
3316         into account.
3317         * doc/extend.texi: Document new attributes.
3318         * testsuite/gcc.dg/bf-ms-attrib.c: New test.
3319
3320 2003-01-08  Danny Smith  <dannysmith@users.sourceforge.net>
3321
3322         PR optimization/8750
3323         * config/i386/i386.c (ix86_expand_prologue): Don't allow
3324         scheduling pass to move insns across __alloca call.
3325
3326 2003-01-08  Dale Johannesen  <dalej@apple.com>
3327
3328         * config/rs6000/rs6000.md:  Replace *store_multiple_string
3329         with *stmsi[3-8].
3330
3331 2003-01-08  Jeff Sturm  <jsturm@one-point.com>
3332
3333         PR target/9210
3334         * config/rs6000/rs6000.c (rs6000_elf_encode_section_info):
3335         Set SYMBOL_REF_FLAG on local data sym_ref.
3336
3337 2003-01-08  Dale Johannesen  <dalej@apple.com>
3338
3339         * function.c (assign_parms):  Don't set pretend_args_size if
3340           REG_PARM_STACK_SPACE.
3341           config/rs6000/rs6000.c (setup_incoming_varargs):  Don't set
3342           pretend_args_size.
3343
3344 2003-01-08  Nathanael Nerode  <neroden@gcc.gnu.org>
3345
3346         * gcc.hlp: Delete.
3347
3348 Thu Jan  9 00:57:15 CET 2003  Jan Hubicka  <jh@suse.cz>
3349
3350         * i386.c  (ix86_expand_int_addcc): Fix thinko.
3351
3352 2003-01-08  David Edelsohn  <edelsohn@gnu.org>
3353
3354         * config/rs6000/rs6000.h (FUNCTION_MODE): Always use SImode.
3355         * config/rs6000/rs6000.c (TARGET_ASM_CAN_OUTPUT_MI_THUNK): Redefine
3356         as hook_bool_tree_hwi_hwi_tree_true.
3357         (rs6000_emit_allocate_stack): Use TARGET_32BIT.
3358         (rs6000_emit_epilogue): Same.
3359         (rs6000_output_mi_thunk): Re-implement as RTL.
3360         * config/rs6000/xcoff.h (ASM_DECLARE_FUNCTION_NAME): Call
3361         xcoffout_declare_function if any debugging enabled.
3362
3363 2003-01-08  Chris Demetriou  <cgd@broadcom.com>
3364
3365         * config.gcc (mipsisa32r2-*-elf*, mipsisa32r2el-*-elf*): New
3366         targets, to support MIPS32 Release 2 (MIPS32R2) configurations.
3367         * config/mips/mips.h (enum processor_type): Rename
3368         PROCESSOR_R4KC to PROCESSOR_4KC, PROCESSOR_R5KC to
3369         PROCESSOR_5KC, and PROCESSOR_R20KC to PROCESSOR_20KC.
3370         Add PROCESSOR_M4K.
3371         (TARGET_MIPS4KC, TARGET_MIPS5KC): Update for the renaming.
3372         (ISA_MIPS32R2): New define.
3373         (GENERATE_MULT3_SI, ISA_HAS_CONDMOVE, ISA_HAS_8CC)
3374         (ISA_HAS_MADD_MSUB, ISA_HAS_CLZ_CLO)
3375         (ISA_HAS_PREFETCH): Add support for MIPS32R2.
3376         (MIPS_ISA_DEFAULT): Likewise.  Also, fix indentation.
3377         (TARGET_CPU_CPP_BUILTINS): Add support for MIPS32R2.  Add new
3378         predefine __mips_isa_rev for MIPS32, MIPS32R2, and MIPS64.
3379         (ISA_HAS_ROTR_SI): Add support for MIPS32R2, and avoid if
3380         compiling MIPS16 code.
3381         (ISA_HAS_ROTR_DI): Do not use if compiling MIPS16 code, and fix
3382         comment.
3383         (ISA_HAS_SEB_SEH): New define.
3384         (ASM_SPEC, LINK_SPEC): Pass -mips32r2 to assembler and linker.
3385         * config/mips/mips.c (mips_cpu_info_table): Adjust for enum
3386         processor_type value renaming.  Add support for MIPS32R2.
3387         Clean up comments, and move "sb1" entry with other MIPS64 CPU
3388         entries.
3389         (override_options): Reimplement -mipsN option handling so that
3390         it will work correctly for -mips32r2.  Avoid branch-likely
3391         instructions on MIPS32R2.
3392         * config/mips/mips.md (mulsi3_mult3): Add support for MIPS32R2.
3393         (extendhisi2): Use extendhisi2_hw if ISA_HAS_SEB_SEH.
3394         (extendqisi2): Use extendqisi2_hw if ISA_HAS_SEB_SEH.
3395         (extendhisi2_hw, extendqisi2_hw): New.
3396         * config/mips/netbsd.h (TARGET_CPU_CPP_BUILTINS): Add support
3397         for MIPS32R2.  Add new predefine __mips_isa_rev for MIPS32,
3398         MIPS32R2, and MIPS64.
3399         (LINK_SPEC): Pass -mips32r2 to linker.
3400         * config/mips/t-isa3264: Built -mips32r2 multilibs.
3401         * doc/invoke.texi (MIPS Options): Add -mips32r2, add support
3402         for mips32r2 in the -march description.  Alphabetically sort
3403         CPU names in the -march description.  Add long-missed -mips32
3404         and -mips64 to MIPS option summary.
3405
3406         * config.gcc: Update copyright years to include 2003.
3407         * config/mips/mips.c: Likewise.
3408         * config/mips/mips.h: Likewise.
3409         * config/mips/mips.md: Likewise.
3410         * config/mips/netbsd.h: Likewise.
3411         * doc/invoke.texi: Likewise.
3412
3413 2003-01-08  Andreas Schwab  <schwab@suse.de>
3414
3415         * aclocal.m4 (gcc_AC_INITFINI_ARRAY): Fix spelling of cache
3416         variable.
3417         * configure: Regenerated.
3418
3419 2003-01-08  Kazu Hirata  <kazu@cs.umass.edu>
3420
3421         * config/h8300/h8300.c (output_logical_op): Replace byte/word
3422         extraction of det with b0, b1, w0, w2, etc.
3423         (compute_logical_op_length): Likewise.
3424         (compute_logical_op_cc): Likewise.
3425
3426 2003-01-08  Kazu Hirata  <kazu@cs.umass.edu>
3427
3428         * config/h8300/h8300.h (CONSTANT_ADDRESS_P): Allow CONST and
3429         HIGH on all variants.
3430
3431 Wed Jan  8 14:06:34 CET 2003  Josef Zlomek <zlomj9am@artax.karlin.mff.cuni.cz>
3432
3433         * Makefile.in (PARTITION_H): New.
3434         (BASIC_BLOCK_H): Added hard-reg-set.h and $(PARTITION_H).
3435         * basic-block.h: Include hard-reg-set.h.
3436
3437 2003-01-08  Richard Earnshaw  <rearnsha@arm.com>
3438
3439         * arm.h (ENABLE_XF_PATTERNS): Delete.
3440         * arm.md (addxf3, subxf3, mulxf3, divxf3, modxf3, negxf2, absxf2)
3441         (sqrtxf2, floatsixf2, fix_truncxfsi2, truncxfsf2, truncxfdf2)
3442         (extendsfxf2, extenddfxf2, movxf, cmpxf, cmpxf_insn)
3443         (cmpxf_trap): Delete.
3444         (movxf_hard_insn): Remove test of ENABLE_XF_PATTERNS.
3445
3446 Wed Jan  8 12:10:57 CET 2003  Jan Hubicka  <jh@suse.cz>
3447
3448         * i386.md (adddi3_carry_rex64, subdi3_carry_rex64): Name pattern.
3449         (addhi3_carry, addqi3_carry, subhi3_carry, subqi3_carry): New patterns.
3450         (add??cc): New expanders.
3451         * i386.c (expand_int_addcc): New function.
3452         * i386-protos.h (expand_int_addcc): Declare.
3453
3454         * alias.c (memory_modified_1): New static function.
3455         (memory_modified): New static varaible.
3456         (memory_modified_in_insn_p): New global function.
3457         * rtl.h (memory_modified_in_insn_p): Declare.