OSDN Git Service

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