OSDN Git Service

491b1ef817ac6dfede2d0a570f613e9822074dcc
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
1 2003-02-12  Aldy Hernandez  <aldyh@redhat.com>
2
3         * config/rs6000/spe.h: Add casts to the arguments of the following
4         macros: evfsabs, evfsnabs, evfsneg, evfsadd, evfssub, evfsmul,
5         evfsdiv, evfscfui, evfscfsi evfscfuf evfscfsf, evfsctui, evfsctsi,
6         evfsctuf, evfsctsf, evfsctuiz, evfsctsiz, __ev_get_upper*,
7         __ev_get_lower*, __ev_get_u32, __ev_get_s32, __ev_get_fs,
8         __ev_get_u16, __ev_get_s16.
9
10 2003-02-12  Kazu Hirata  <kazu@cs.umass.edu>
11
12         * config/h8300/h8300.md (a peephole2): New.
13
14 Wed Feb 12 22:47:18 CET 2003  Jan Hubicka  <jh@suse.cz>
15
16         * Makefile.in (CRTSTUFF_CFLAGS): Add -fno-unit-at-a-time
17         (OBJS): Add callgraph.o
18         (callgraph.o): New.
19         * c-decl.c (expand_body_1): Break out from ...
20         (expand_body): This one;  change calling convention
21         (finish_function): Move some of expand_body logic here.
22         (c_expand_deferred_function): Update call of expand_body
23         (c_expand_stmt): Use c_expand_body_1.
24         * c-lang.c (LANG_HOOKS_CALLGRAPH_EXPAND_FUNCTION): Define.
25         * c-objc-commin.c (c_objc_common_finish_file): Use callgraph code.
26         * c-tree.h (c_expand_body): Declare.
27         * callgraph.c: New file.
28         * flags.h (flag_unit_at_a_time): Declare.
29         * langhooks.h (LANG_HOOKS_CALLGRAPH_LOWER_FUNCTION,
30         LANG_HOOKS_CALLGRAPH_EXPAND_FUNCTION,
31         LANG_HOOKS_CALLGRAPH_INITIALIZER): New macros.
32         * langhooks.h (struct lang_hooks_for_callgraph): New.
33         (struct lang_hooks): Add callgraph field.
34         * toplev.c (flag_unit_at_a_time): New.
35         (lang_independent_options): Add flag_unit_at_a_time.
36         (process_options): Disable unit-at-a-time mode for frontends not
37         supporting callgraph.
38         * tree-inline.c (typedef struct inline_data): Add "decl"
39         (expand_call_inline): Update callgraph.
40         (optimize_inline_calls): Set id.decl.
41         * tree.h (cgraph_finalize_function, cgraph_finalize_compilation_unit,
42         cgraph_create_edges, dump_cgraph, cgraph_optimize, cgraph_remove_call
43         cgraph_calls_p): Declare.
44         * invoke.texi (-funit-at-a-time): Document
45
46 2003-02-12  Aldy Hernandez  <aldyh@redhat.com>
47
48         * config/rs6000/spe.h: Fix misc formatting.
49         (__ev_create_ufix32_fs): Cast ev argument.
50         (__ev_create_sfix32_fs): Same.
51         (__ev_get_sfix32_fs_internal): Cast arguments to builtins.
52         (__ev_get_ufix32_fs_internal): Same.
53
54
55 2003-02-12  Ranjit Mathew  <rmathew@hotmail.com>
56
57         * doc/tm.texi (MODIFY_JNI_METHOD_CALL): Document.
58         * config/i386/cygwin.h (MODIFY_JNI_METHOD_CALL): New macro.
59
60 2003-02-12  Zack Weinberg  <zack@codesourcery.com>
61
62         * cpplib.c (do_include_common): Move warnings for
63         #include_next and #import out to callers.  Use early-return
64         instead of nested ifs.  Don't do check_eol here.
65         (parse_include): Do check_eol here with the rest of the
66         parsing stuff.
67         (do_include_next, do_import): Now handle warnings.
68
69 2003-02-11  Gerald Pfeifer  <pfeifer@dbai.tuwien.ac.at>
70
71         * doc/install.texi (Specific): Update AVR- and Darwin-related URLs.
72
73 Wed Feb 12 15:19:42 CET 2003  Jan Hubicka  <jh@suse.cz>
74
75         * predict.c (estimate_probability):  Fix roundoff error.
76
77 2003-02-12  Kazu Hirata  <kazu@cs.umass.edu>
78
79         * config/h8300/h8300.md (a peephole2): Don't handle 65535.
80         (two peephole2): New.
81
82 2003-02-12  Kazu Hirata  <kazu@cs.umass.edu>
83
84         * config/h8300/h8300.md (several peephole2): Replace
85         find_regno_note with peep2_reg_dead_p.
86
87 2003-02-11  Richard Henderson  <rth@redhat.com>
88
89         * gcse.c (lookup_set): Remove unused argument PAT.  Update
90         both callers.
91
92 2003-02-11  Geoffrey Keating  <geoffk@apple.com>
93
94         * diagnostic.c (real_abort): New.
95         (diagnostic_report_diagnostic): Call real_abort on error.
96         * diagnostic.h (diagnostic_abort_on_error): New.
97         (struct diagnostic_context): Add abort_on_error field.
98         * toplev.c (setup_core_dumping): New.
99         (decode_d_option): Handle 'H' case.
100         * doc/invoke.texi (Debugging Options): Document -dH.
101
102 2003-02-11  Nathanael Nerode  <neroden@gcc.gnu.org>
103
104         * Makefile.in: Remove pointless setting of CXXFLAGS for dejagnu
105         which refers to obsolete directories.
106
107 2003-02-11  Richard Henderson  <rth@redhat.com>
108
109         * config/alpha/linux.h (TARGET_C99_FUNCTIONS): New.
110
111 Mon Oct 21 17:07:47 CEST 2002  Jan Hubicka  <jh@suse.cz>
112
113         * i386.c (contains_128bit_aligned_vector_p): New function.
114         (ix86_function_arg_boundary): Properly align vector modes.
115
116 2003-02-11  Bob Wilson  <bob.wilson@acm.org>
117
118         * config/xtensa/xtensa.md (set_frame_ptr): Change rtl to set reg a7.
119         * config/xtensa/xtensa.c (xtensa_reorg): Search for UNSPECV_SET_FP
120         as a SET pattern.
121
122 2003-02-11  Roger Sayle  <roger@eyesopen.com>
123
124         * builtins.c:  Fix failure caused by commiting wrong patch.
125
126 2003-02-11  Dale Johannesen  <dalej@apple.com>
127         * ra-build.c (compare_and_free_webs):  Relax checking.
128         * config/rs6000/darwin.h (HOT_TEXT_SECTION_NAME):  Define.
129         (UNLIKELY_EXECUTED_TEXT_SECTION_NAME):  Define.
130
131 2003-02-11  Falk Hueffner  <falk.hueffner@student.uni-tuebingen.de>
132
133         PR optimization/9651
134         * rtlanal.c (may_trap_p): Handle FIX.
135
136 2003-02-11  Dave Jones <davej@codemonkey.org.uk>
137
138         * config/i386/i386.c (override_options): Define c3-2 as a 686 with SSE.
139         * doc/invoke.texi: Extra alias.
140
141 2003-02-11  Geoffrey Keating  <geoffk@apple.com>
142
143         * config/rs6000/host-darwin.c: Fix comment.
144
145 2003-02-11  David Edelsohn  <edelsohn@gnu.org>
146
147         * config/rs6000/rs6000.md (divmodsi4): Use register_operand
148         predicate for mod result.
149
150 2003-02-11  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
151
152         * inclhack.def (hpux_long_double, hpux10_ctype_declarations1,
153         hpux10_ctype_declarations2, hpux_ctype_macros): New hacks.
154         * fixincl.x: Rebuilt.
155         * tests/base/stdlib.h: Update.
156         * tests/base/ctype.h: New file.
157
158 Tue Feb 11 20:44:45 CET 2003  Jan Hubicka  <jh@suse.cz>
159
160         * emit-rtl.c (emit_copy_of_insn_after): Copy insn recog cache too.
161
162 2003-02-11  Richard Henderson  <rth@redhat.com>
163
164         * config/i386/i386.c (ix86_expand_movstr): Fail if esi or edi
165         appropriated as globals.
166         (ix86_expand_clrstr): Similarly.
167         * config/i386/i386.md (cmpstrsi): Similarly.
168
169 2003-02-11  Kazu Hirata  <kazu@cs.umass.edu>
170
171         * config/h8300/h8300.md (a peephole2): Add a case of 255.
172
173 2003-02-11  Roger Sayle  <roger@eyesopen.com>
174
175         * optabs.h (enum optab_index): Add new OTI_pow and OTI_atan2.
176         (pow_optab, atan2_optab): Define corresponding macros.
177         * optabs.c (init_optabs): Initialize pow_optab and atan2_optab.
178         * genopinit.c (optabs): Implement pow_optab and atan2_optab
179         using pow?f3 and atan2?f3 patterns.
180         * builtins.c (expand_errno_check): New function to update errno
181         if necessary, split out from expand_builtin_mathfn.
182         (expand_builtin_mathfn): Use expand_errno_check.
183         (expand_builtin_mathfn_2): New function to handle expanding binary
184         math functions, reusing the code in expand_errno_check.
185         (expand_builtin): Handle the pow and atan2 math built-ins,
186         BUILT_IN_{POW,POWF,POWL,ATAN2,ATAN2F,ATAN2L} via the new function
187         expand_builtin_mathfn_2.
188
189         * doc/md.texi: Document new pow?f3 and atan2?f3 patterns.
190
191 Tue Feb 11 19:03:22 MET 2003  Jan Hubicka  <jh@suse.cz>
192
193         * combine.c (combine_simplify_rtx): Fix folding of
194         nested float_truncates.
195
196 2003-02-11  Kazu Hirata  <kazu@cs.umass.edu>
197
198         * config/h8300/h8300.md (a peephole2): Fix a typo.
199
200 2003-02-11  Richard Earnshaw  <rearnsha@arm.com>
201
202         * arm.mc (return_address_mask): Use CC_REGNUM for the condition code
203         register number.
204
205 2003-02-11  Kazu Hirata  <kazu@cs.umass.edu>
206
207         * config/h8300/h8300-protos.h: Add a prototype for
208         gtuleu_operator.
209         * config/h8300/h8300.c (gtuleu_operator): New.
210         * config/h8300/h8300.h (PREDICATE_CODES): Add gtuleu_operator.
211         * config/h8300/h8300.md (a peephole2): New.
212
213 Tue Feb 11 13:32:12 CET 2003  Jan Hubicka  <jh@suse.cz>
214
215         * sched-ebb.c (schedule_ebbs): Do not verify_flow_info.
216
217 Tue Feb 11 10:02:54 CET 2003  Jan Hubicka  <jh@suse.cz>
218
219         * predict.c (choose_function_section): Choose sections correctly.
220
221 2003-02-10  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
222
223         * reload1.c (first_label_num): New.
224         (reload): Index offsets_known_at and offsets_at using difference of
225         label number and first label number.  Don't use offset pointers.
226         (set_label_offsets, set_initial_label_offsets): Likewise.
227
228 2003-02-10  Roger Sayle  <roger@eyesopen.com>
229
230         * mips-tfile.c (init_file): Add missing initializers in the
231         "#ifdef __alpha" case.
232         (file_offset, max_file_offset): Declare as unsigned long.
233         (write_varray): Cast to "unsigned long" in comparisons against
234         either file_offset or max_file_offset.
235         (write_object): Likewise.
236         (read_seek): Likewise.
237         (copy_object): Likewise. Declare "ifd" as int to match its use
238         in add_ext_symbol, and avoid signed/unsigned conditional warning.
239
240 2003-02-10  Nick Clifton  <nickc@redhat.com>
241             Aldy Hernandez  <aldyh@redhat.com>
242
243         * config/rs6000/eabispe.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Do not
244         override options which have been specified on the command line.
245
246 2003-02-10  Kazu Hirata  <kazu@cs.umass.edu>
247
248         * config/h8300/h8300.md (abssf2): New.
249         (*abssf2_h8300): Likewise.
250         (*abssf2_h8300hs): Likewise.
251
252 2003-02-10  Phil Edwards  <pme@gcc.gnu.org>
253
254         * tree.c (build_tree_list):  Fix parameter names in comment.
255
256 2003-02-10  Janis Johnson  <janis187@us.ibm.com>
257
258         * config/rs6000/ppc64-fp.c: New file.
259         * config/rs6000/t-linux64 (LIB2FUNCS_EXTRA): Add ppc64-fp.c.
260
261 2003-02-10  Josef Zlomek  <zlomekj@suse.cz>
262
263         * Makefile.in (bb-reorder.o): Add dependency on $(FIBHEAP_H).
264         * bb-reorder.c (make_reorder_chain): Deleted.
265         (make_reorder_chain_1): Deleted.
266         (find_traces): New function.
267         (rotate_loop): New function.
268         (mark_bb_visited): New function.
269         (find_traces_1_round): New function.
270         (copy_bb): New function.
271         (bb_to_key): New function.
272         (better_edge_p): New function.
273         (connect_traces): New function.
274         (copy_bb_p): New function.
275         (get_uncond_jump_length): New function.
276         (reorder_basic_blocks): Use new functions (Software Trace Cache).
277         * cfgcleanup.c (outgoing_edges_match): Enable crossjumping across loop
278         boundaries.
279
280 2003-02-10  Aldy Hernandez  <aldyh@redhat.com>
281
282         * config/rs6000/rs6000.c (bdesc_2arg): Change spe_evxor to xorv2si3.
283
284 2003-02-09  Dan Nicolaescu  <dann@ics.uci.edu>
285
286         * tree.h (struct tree_decl): Remove unused live_range_rtl field.
287         (DECL_LIVE_RANGE_RTL): Remove.
288
289 2003-02-10  Nick Clifton  <nickc@redhat.com>
290
291         * config/arm/aof.h, config/arm/aout.h, config/arm/arm-modes.def,
292         config/arm/arm-protos.h, config/arm/arm.c, config/arm/arm.h,
293         config/arm/arm.md, config/arm/cirrus.md, config/arm/coff.h,
294         config/arm/conix-elf.h, config/arm/ecos-elf.h, config/arm/elf.h,
295         config/arm/freebsd.h, config/arm/linux-elf.h,
296         config/arm/linux-gas.h, config/arm/netbsd-elf.h,
297         config/arm/netbsd.h, config/arm/pe.c, config/arm/pe.h,
298         config/arm/rtems-elf.h, config/arm/semi.h, config/arm/semiaof.h,
299         config/arm/strongarm-coff.h, config/arm/strongarm-elf.h,
300         config/arm/strongarm-pe.h, config/arm/uclinux-elf.h,
301         config/arm/unknown-elf-oabi.h, config/arm/unknown-elf.h,
302         config/arm/xscale-elf.h: Replace occurances of "GNU CC" with "GCC"
303         and reformat as appropriate.
304
305 2003-02-10  Kazu Hirata  <kazu@cs.umass.edu>
306
307         * config/h8300/clzsi2.c: Remove.
308         * config/h8300/ctzsi2.c: Likewise.
309         * config/h8300/paritysi2.c: Likewise.
310         * config/h8300/popcountsi2.c: Likewise.
311         * config/h8300/t-h8300 (LIB2FUNCS_EXTRA): Remove clzsi2,
312         ctzsi2, paritysi2, and popcountsi2.
313
314 2003-02-10  Eric Botcazou  <ebotcazou@libertysurf.fr>
315             Christian Ehrhardt  <ehrhardt@mathematik.uni-ulm.de>
316
317         PR c/7741
318         * c-decl.c (duplicate_decls): Discard the initializer of the
319         new decl when the types are conflicting.
320
321 2003-02-10  Josef Zlomek  <zlomekj@suse.cz>
322
323         * Makefile.in (sreal.o): Added.
324         (predict.o): Depends on sreal.h instead of real.h.
325         * sreal.c: New file.
326         * sreal.h: New file.
327         * predict.c: Use sreal.c instead of real.c.
328
329 2003-02-10  Nick Clifton  <nickc@redhat.com>
330
331         * Contributed support for the Cirrus EP9312 "Maverick"
332         floating point co-processor.  Written by Aldy Hernandez
333         <aldyh@redhat.com>.
334         (config/arm/arm.c): Add Cirrus support.
335         (config/arm/arm.h): Likewise.
336         (config/arm/aout.h): Likewise.
337         (config/arm/arm.md): Likewise.
338         (config/arm/arm-protos.h): Likewise.
339         (config.gcc): Likewise.
340         (doc/invoke.texi): Describe new -mcpu value and new
341         -mcirrus-fix-invalid-insns switch,
342         (cirrus.md): New file.
343
344 Mon Feb 10 11:40:18 CET 2003  Jan Hubicka  <jh@suse.cz>
345
346         * combine.c (combine_simplify_rtx): Simplify using
347         (float_truncate (float x)) is (float x)
348         (float_extend (float_extend x)) is (float_extend x).
349
350 2003-02-10  Alan Modra  <amodra@bigpond.net.au>
351
352         * calls.c (try_to_integrate): Tidy stack_usage_map access.
353         (emit_library_call_value_1): Likewise.  Formatting.
354         (store_one_arg): Likewise.
355
356 2003-02-09  Nick Clifton  <nickc@redhat.com>
357             Aldy Hernandez  <aldyh@redhat.com>
358
359         * config/rs6000/spe.md: spe_evlhhesplat, spe_evlhhossplat,
360         spe_evlhhousplat, spe_evlwhsplat, spe_evlwwsplat, spe_evldd,
361         spe_evldh, spe_evldw, spe_evlwhe, spe_evlwhos, spe_evlwhou,
362         spe_evstdd, spe_evstdh, spe_evstdw, spe_evstdwx, spe_evstwhe,
363         spe_evstwho, spe_evstwwe, spe_evstwwo: Fix syntax to match newest
364         docs.  Add range test for immediate value.
365
366 2003-02-09  Aldy Hernandez  <aldyh@redhat.com>
367
368         Rename spe_evxor to xorv2si3.
369         (xorv4hi3): New.
370         (xorv1di3): New.
371
372 2003-02-10  Glen Nakamura  <glen@imodulo.com>
373
374         * doc/extend.texi (C++98 Thread-Local Edits): Add missing @item
375         tag.
376
377 Mon Feb 10 00:29:17 CET 2003  Jan Hubicka  <jh@suse.cz>
378
379         * i386.c (vector_move_operand): New predicate.
380         (ix86_expand_vector_move): Be happy about 0.
381         * i386.h (PREDICATE_CODES): Add sse-move_operand.
382         * i386.md (mov*_internal): Add 'C' alternative.
383
384 Sun Feb  9 23:58:33 CET 2003  Jan Hubicka  <jh@suse.cz>
385
386         * i386.md (floathi*): Deal with SSE.
387
388 Sun Feb  9 23:54:59 CET 2003  Jan Hubicka  <jh@suse.cz>
389
390         * simplify-rtx.c (simplify_unary_operation,
391         simplify_binary_operation):  Deal with vector modes
392         (simplify_ternary_operation):  Deal with no-op VEC_MERGE.
393
394 2002-02-09  Richard Sandiford  <rsandifo@redhat.com>
395
396         * toplev.c (rest_of_compilation): Recompute register usage after
397         split_all_insns.
398
399 2003-02-09  Richard Henderson  <rth@redhat.com>
400
401         * libgcc-std.ver (__clztf2): New.
402         (__ctztf2, __popcounttf2, __paritytf2): New.
403         * libgcc2.c (__clzSI2, __clzDI2, __ctzSI2, __ctzDI2, __popcountSI2,
404         __popcountDI2, __paritySI2, __parityDI2): Use UWmode and UDWmode;
405         adjust code to match the different type sizes.
406         * libgcc2.h (__clzSI2, __ctzSI2, __popcountSI2, __paritySI2,
407         __clzDI2, __ctzDI2, __popcountDI2, __parityDI2): New macros.
408
409         * optabs.c (init_integral_libfuncs): Don't hard-code SImode and
410         TImode; select word_mode and twice that.
411         (init_floating_libfuncs): Don't hard-code SFmode and TFmode;
412         select the modes from float, double, and long double.
413         (init_optabs): Remove duplicate initializations.
414
415 2003-02-09  Wolfgang Bangerth  <bangerth@ticam.utexas.edu>
416
417         * doc/install.texi: Squeeze and streamline section on
418         testing and regression checking.
419
420 Sun Feb  9 13:33:34 CET 2003  Jan Hubicka  <jh@suse.cz>
421
422         * i386.md (ahi?v*3): Set third operand type to TImode.
423         * i386.c (ix86_expand_binop_builtin): Extend operand when needed.
424
425         * simplify-rtx.c (simplify_subreg): Fix conversion from vector into
426         integer mode.
427
428         * rtl.def (VEC_MERGE, VEC_SELECT, VEC_CONCAT, VEC_DUPLICATE):
429         Change code so they are arithmetic expressions now.
430         * simplify-rtx.c (simplify_unary_operation, simplify_binary_operation,
431         simplify_ternary_operation): Deal with VEC_* expressions.
432
433         * i386.md (vmaskcmp, pinsrw, movd patterns):  Fix RTL representation.
434
435 Sat Feb  8 00:21:22 CET 2003  Jan Hubicka  <jh@suse.cz>
436
437         * cfgrtl.c (verify_flow_info):  Use control_flow_insn_p.
438         * reload1.c (fixup_abnormal_edges):  Split basic blocks when EH edges
439         possibly got duplicated.
440
441 2003-02-08  Richard Henderson  <rth@redhat.com>
442
443         * config/alpha/alpha.c (override_options): Turn off explicit
444         relocs until post-peep2 code duplication resolved.
445
446 2003-02-08  Kazu Hirata  <kazu@cs.umass.edu>
447
448         * optabs.c (expand_unop): Widen clz properly when clz is done
449         via libcall.
450
451 2003-02-08  Kazu Hirata  <kazu@cs.umass.edu>
452
453         * config/h8300/clzsi2.c: Replace "GNU CC" with "GCC".
454         * config/h8300/crti.asm: Likewise.
455         * config/h8300/crtn.asm: Likewise.
456         * config/h8300/ctzsi2.c: Likewise.
457         * config/h8300/fixunssfsi.c: Likewise.
458         * config/h8300/h8300-protos.h: Likewise.
459         * config/h8300/h8300.c: Likewise.
460         * config/h8300/h8300.h: Likewise.
461         * config/h8300/h8300.md: Likewise.
462         * config/h8300/paritysi2.c: Likewise.
463         * config/h8300/popcountsi2.c: Likewise.
464         * config/h8300/rtems.h: Likewise.
465
466 2003-02-08  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
467
468         * doc/invoke.texi: Documentation for my previous commit.
469         * doc/passes.texi: Ditto.
470
471 2003-02-08  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
472
473         * cfgloop.h (fix_loop_placement, can_duplicate_loop_p,
474         duplicate_loop_to_header_edge, loopify, remove_path, split_loop_bb):
475         Declare.
476         (DLTHE_FLAG_UPDATE_FREQ): New.
477         * cfgloopmanip.c (duplicate_loop, duplicate_subloops, copy_loops_to,
478         loop_redirect_edge, loop_delete_branch_edge, copy_bbs, remove_bbs,
479         rpe_enum_p, find_branch, alp_enum_p, add_loop, fix_loop_placements,
480         fix_bb_placement, fix_bb_placements, place_new_loop,
481         scale_loop_frequencies, scale_bbs_frequencies, record_exit_edges):
482         New static functions.
483         (fix_loop_placement, can_duplicate_loop_p,
484         duplicate_loop_to_header_edge, loopify, remove_path, split_loop_bb):
485         New functions.
486
487         * cfgloop.h (loop_optimizer_init, loop_optimizer_finalize,
488         unswitch_loops): Declare.
489         * loop-init.c: New file.
490         * loop-unswitch.c: New file.
491         * Makefile.in (loop-init.o, loop-unswitch.o): New.
492         * params.def (PARAM_MAX_UNSWITCH_INSNS, PARAM_MAX_UNSWITCH_LEVEL): New.
493         * toplev.c (DFI_loop2): New dump.
494         (flag_unswitch_loops): New.
495         (lang_independent_options): Add it.
496         (rest_of_compilation): Call new loop optimizer.
497         (parse_options_and_default_flags): Turn flag_unswitch_loops on with -O3.
498
499 2003-02-08  Kazu Hirata  <kazu@cs.umass.edu>
500
501         * config/h8300/clzsi2.c: New.
502         * config/h8300/ctzsi2.c: Likewise.
503         * config/h8300/paritysi2.c: Likewise.
504         * config/h8300/popcountsi2.c: Likewise.
505         * config/h8300/t-h8300 (LIB2FUNCS_EXTRA): Add above files.
506
507 2003-02-07  David Edelsohn  <edelsohn@gnu.org>
508
509         * config/rs6000/rs6000.h (CLZ_DEFINED_VALUE_AT_ZERO): Define.
510         * config/rs6000/rs6000.md (clzsi2): Rename from cntlzw2.
511         (ctzsi2): New pattern.
512         (ffssi2): Use clz instead of unspec.
513         (clzdi2): Rename from cntlzd2.
514         (ctzdi2): New pattern.
515         (ffsdi2): Use clz instead of unspec.
516
517 2003-02-07  Loren James Rittle  <ljrittle@acm.org>
518
519         * config/alpha/freebsd.h (LINK_SPEC): Weaken error to notice.
520         * config/ia64/freebsd.h (LINK_SPEC): Likewise.
521         * config/sparc/freebsd.h (LINK_SPEC): Likewise.
522         * config/i386/freebsd.h (LINK_SPEC): Add clause to mirror other arches.
523
524 2003-02-07  Wolfgang Bangerth  <bangerth@ticam.utexas.edu>
525
526         * doc/trouble.texi: Document pitfalls of two-stage name lookup.
527
528 2003-02-07  Richard Henderson  <rth@redhat.com>
529
530         PR 9226
531         * gcse.c (local_cprop_find_used_regs): New.
532         (local_cprop_pass): Use it.
533
534 2003-02-07  Fred Fish  <fnf@intrinsity.com>
535
536         * mips-tfile.c (parse_def): Parenthesize assignments to fix
537         precedence bugs.
538
539 2003-02-07  Segher Boessenkool  <segher@koffie.nl>
540
541         * genoutput.c (output_get_insn_name): Handle NOOP_MOVE_INSN_CODE.
542
543 2003-02-07  Roger Sayle  <roger@eyesopen.com>
544
545         * builtin-types.def (BT_FN_FLOAT_FLOAT_FLOAT): New built-in type.
546         (BT_FN_LONG_DOUBLE_LONG_DOUBLE_LONG_DOUBLE): Likewise.
547         (BT_FN_DOUBLE_DOUBLE_DOUBLE): Likewise.
548         * builtins.def: Define pow, powf, powl, atan2, atan2f and atan2l
549         builtin functions (and their __builtin_* variants).
550         * builtins.c (mathfn_built_in): Handle missing log{,f,l} cases.
551         (expand_builtin): Don't expand log{,f,l}, pow{,f,l} or atan2{,f,l}
552         when not optimizing.
553
554         * doc/extend.texi: Document new pow and atan2 builtins, and
555         their float and long double variants.  Realphabetize builtins.
556
557 Fri Feb  7 23:24:28 CET 2003  Jan Hubicka  <jh@suse.cz>
558
559         * i386.md (sse2_nandv2di3): Fix.
560
561 2003-03-07  Danny Smith  <dannysmith@users.sourceforge.net>
562
563         * config/i386/i386.h (MS_AGGREGATE_RETURN): New define.
564         * config/i386/cygwin.h (MS_AGGREGATE_RETURN): Override default
565         definition.
566         * config/i386/i386.h (ix86_return_in_memory): Return aggregate
567         types of up to 8 bytes via registers if MS_AGGREGATE_RETURN.
568
569 Fri Feb  7 22:22:40 CET 2003  Jan Hubicka  <jh@suse.cz>
570
571         * i386.md (movdi_rex64_1): Fix mmx<->int move opcode.
572
573 2003-02-07  Daniel Berlin  <dberlin@dberlin.org>
574
575         * cfg.c (dump_flow_info): Add back accidently deleted line.
576
577 2003-02-07  Andrey Petrov <petrov@netbsd.org>
578
579         * optabs.c (expand_float): Search wider integer modes first.
580
581 2003-02-07  Bob Wilson  <bob.wilson@acm.org>
582
583         * config/xtensa/xtensa.h (LIBGCC2_WORDS_BIG_ENDIAN): Set this
584         based on preprocessor flag.
585
586 2003-02-07  Roger Sayle  <roger@eyesopen.com>
587             Richard Henderson  <rth@redhat.com>
588
589         * gcse.c (implicit_sets): New.
590         (compute_hash_table_work): Include them in hash table.
591         (find_implicit_sets, fis_get_condition): New.
592         (one_cprop_pass): Allocate and free implicit_sets; call
593         find_implicit_sets before building hash table.
594
595 2003-02-07  Jason Thorpe  <thorpej@wasabisystems.com>
596
597         * config/t-netbsd (USER_H): Revert previous change.
598
599 2003-02-07  Gabor Greif  <ggreif@lucent.com>
600
601         * doc/c-tree.texi (Namespaces): Fix typo.
602
603 Fri Feb  7 02:18:57 CET 2003  Jan Hubicka  <jh@suse.cz>
604
605         * regrename.c (do_replace, find_oldest_value_reg,
606         copyprop_hardreg_forward_1): Update register attributes.
607
608 2003-02-06  Vladimir Makarov  <vmakarov@redhat.com>
609
610         * genautomata.c (VLA_PTR_CREATE, VLA_PTR_EXPAND, VLA_PTR_ADD,
611         VLA_HWINT_CREATE, VLA_HWINT_EXPAND, VLA_HWINT_ADD): Use temporay
612         variables starting with underscore.
613         (struct unit_usage): New structure.
614         (unit_usages, cycle_alt_unit_usages): New global variables.
615         (check_unit_distribution_in_reserv): Remove it.
616         (store_alt_unit_usage): New function.
617         (check_regexp_units_distribution): Rewrite it.
618
619 2003-02-06  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
620
621         * config.gcc (hppa*-*-linux*): Set MASK_NO_SPACE_REGS in
622         target_cpu_default.
623         * pa.c (attr_length_call): Add 8 to call length (long indirect PA 1.X)
624         if not MASK_NO_SPACE_REGS.
625         (output_call): Adjust return pointer, don't load new space register
626         into %sr0, and use %sr4 for call if TARGET_NO_SPACE_REGS is true.
627         (pa_asm_output_mi_thunk): Don't load new space register into %sr0 if
628         TARGET_NO_SPACE_REGS is true.
629         * pa.md (return_external_pic): Add TARGET_NO_SPACE_REGS to insn
630         conditions.
631         (epilogue): Always use return_internal if TARGET_NO_SPACE_REGS is true.
632         (interspace_jump): Add new pattern for when TARGET_NO_SPACE_REGS is
633         true.  Use bve when TARGET_64BIT is true.
634
635 2003-02-06  Richard Henderson  <rth@redhat.com>
636
637         * combine.c (nonzero_bits): Fix double break.
638
639 2003-02-06  Eric Botcazou <ebotcazou@libertysurf.fr>
640             Richard Henderson <rth@redhat.com>
641
642         PR c/9530
643         * config/i386/i386.c (ix86_function_ok_for_sibcall): Forbid sibcalls
644         from functions that return a float to functions that don't.
645
646 Thu Feb  6 00:18:38 CET 2003  Jan Hubicka  <jh@suse.cz>
647
648         * i386.c (x86_inter_unit_moves): New variable.
649         (ix86_secondary_memory_needed): Fix 64bit case, honor
650         TARGET_INTER_UNIT_MOVES
651         * i386.h (x86_inter_unit_moves): Declare.
652         (TARGET_INTER_UNIT_MOVES): New macro.
653         * i386.md (movsi_1): Cleanup constraints; disable
654         when not doing inter-unit moves.
655         (movsi_1_nointernunit): New.
656         (movdi_1_rex64): Fix constraints; deal with SSE->GPR moves.
657         (movdi_1_rex64_nointerunit): New.
658         (mivsf_1): disable when not doing inter-unit moves.
659         (movsf_1_nointerunit): New.
660
661         * basic-block.h (inside_basic_block_p):  Declare.
662         * cfgbuild.c (inside_basic_block_p): Make global.
663         * haifa-sched.c (unlink_other_notes0: Deal with NOT_INSN_BASIC_BLOCK.
664         * scheudle-ebb.c  (schedule_ebb): Return last basic block of trace;
665         update CFG.
666         (fix_basic_block_boundaries, add_missing_bbs): New.
667         (rank): Use profile.
668         (scheudle_ebbs): Rely on CFG; update coments.
669
670 2003-02-05  Geoffrey Keating  <geoffk@apple.com>
671
672         * Makefile.in (host_hook_obj): New.
673         (OBJS): Add $(host_hook_obj).
674         (host_default.o): New rule.
675         * config.gcc (host_hook_obj): New, default to host-default.o.
676         (powerpc-*-darwin*): Use host-darwin.o.
677         (out_host_hook_obj): New.
678         * configure: Regenerate.
679         * configure.in: Print information about out_host_hook_obj, substitute
680         into output files.
681         * host-default.c: New file.
682         * hosthooks.h: New file.
683         * toplev.c (general_init): Call host_hooks.extra_signals.
684         * config/rs6000/host-darwin.c: New file.
685         * config/rs6000/x-darwin: New file.
686         * doc/hostconfig.texi: Add documentation for new host hook.
687         Rearrange existing documentation.
688
689 2003-02-05  Roger Sayle  <roger@eyesopen.com>
690
691         * dwarf2out.c (mem_loc_descriptor): Replace ASM_SIMPLIFY_DWARF_ADDR
692         with *targetm.delegitimize_address.
693         (rtl_for_decl_location): Likewise.
694         * dwarfout.c (output_mem_loc_descriptor): Likewise.  Include target.h.
695         * Makefile.in (dwarf2out.c, dwarfout.c): Depend upon $(TARGET_H)
696
697         * config/i386/i386.h (ASM_SIMPLIFY_DWARF_ADDR): Remove definition.
698         * config/i386/i386-protos.h (i386_simplify_dwarf_addr): Remove
699         prototype.
700         * config/i386/i386.c (ix86_delegitimize_address): Renamed from
701         i386_simplify_dwarf_addr.  Made static.  Prototyped.
702         (TARGET_DELEGITIMIZE_ADDRESS): Update definition from
703         i386_simplify_dwarf_addr to ix86_delegitimize_address.
704         (ix86_find_base_term): Likewise.
705         (maybe_get_pool_constant): Likewise.
706
707         * config/s390/s390.h (ASM_SIMPLIFY_DWARF_ADDR): Remove definition.
708         * config/s390/s390-protos.h (s390_simplify_dwarf_addr): Remove
709         prototype.
710         * config/s390/s390.c (s390_delegitimize_address): Renamed from
711         s390_simplify_dwarf_addr.  Made static.  Prototyped.
712         (TARGET_DELEGITIMIZE_ADDRESS): Define as s390_delegitimize_address.
713
714 2003-02-05  Richard Henderson  <rth@redhat.com>
715
716         PR c/8602
717         * integrate.c (output_inline_function): Reset input_filename
718         and lineno from the decl before rest_of_compilation.
719
720 2003-02-05  Richard Henderson  <rth@redhat.com>
721
722         * defaults.h (CLZ_DEFINED_VALUE_AT_ZERO): New.
723         (CTZ_DEFINED_VALUE_AT_ZERO): New.
724         * doc/rtl.texi, doc/tm.texi: Document them.
725
726         * combine.c (nonzero_bits) [CLZ, CTZ]: Handle the definedness
727         of the value at zero properly.
728         * fold-const.c (tree_expr_nonnegative_p): Likewise.
729         * simplify-rtx.c (simplify_unary_operation): Likewise.
730
731         * config/alpha/alpha.h (CLZ_DEFINED_VALUE_AT_ZERO): New.
732         (CTZ_DEFINED_VALUE_AT_ZERO): New.
733
734         * config/arm/arm.c (TARGET_INIT_BUILTINS): Remove.
735         (TARGET_EXPAND_BUILTIN): Remove.
736         (def_builtin, arm_init_builtins, arm_expand_builtin): Remove.
737         * config/arm/arm.h (CLZ_DEFINED_VALUE_AT_ZERO): New.
738         (enum arm_builtins): Remove.
739         * config/arm/arm.md (UNSPEC_CLZ): Remove.
740         (clzsi2): Rename from clz; use clz instead of unspec.
741         (ctzsi2): New.
742         * config/arm/arm-protos.h: Update.
743
744 Wed Feb  5 23:12:57 CET 2003  Jan Hubicka  <jh@suse.cz>
745
746         * i386-protos.h (x86_emit_floatuns):  Declare.
747         * i386.c (x86_emit_floatuns): New global function.
748         * i386.md (floatunssisf2, floatunsdisf2,
749         floatunsdidf2):  New patterns.
750
751 2003-01-25  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
752
753         * cfgloopmanip.c (force_single_succ_latches): Fix missindentation.
754
755 2003-02-05  Hans Boehm <Hans.Boehm@hp.com>
756
757         * config/ia64/unwind-ia64.c: include coretypes.h, tm.h to get
758           config/ia64/linux.h
759
760 2002-02-05  Roger Sayle  <roger@eyesopen.com>
761
762         * cfgloop.h (flow_bb_inside_loop_p): Correct prototype again.
763
764 2003-02-05  Jakub Jelinek  <jakub@redhat.com>
765
766         PR optimization/8555
767         * config/i386/i386.md (sse_mov?fcc split): Handle op2 == op3 case
768         instead of aborting.
769
770 2003-02-04  Richard Henderson  <rth@redhat.com>
771
772         * config/i386/i386.md (UNSPEC_BSF): Remove.
773         (ffssi2): Split into cmove and no_cmove insns and splitters;
774         lose pentium float trick for now.
775         (ffssi_1): Add * to name; use CTZ instead of UNSPEC.
776         (ctzsi2, clzsi2, bsr): New.
777
778 2003-02-04  Richard Henderson  <rth@redhat.com>
779
780         * config/ia64/ia64.c (rtx_needs_barrier): Handle POPCOUNT,
781         UNSPEC_GETF_EXP; remove UNSPEC_POPCNT.
782         * config/ia64/ia64.md (UNSPEC_POPCNT): Remove.
783         (ffsdi2): Use popcount instead of unspec.
784         (popcountdi2): Rename from *popcnt.
785         (ctzdi2, clzdi2, getf_exp_tf): New.
786
787 2003-02-04  Kazu Hirata  <kazu@cs.umass.edu>
788
789         * genconfig.c (main): Generate CC0_P.
790         * rtl.h (CC0_P): Remove.
791
792 2003-02-04  Richard Henderson  <rth@redhat.com>
793
794         * libgcc2.h, libgcc2.c (__ffsSI2): New.
795         (__ffsDI2): Rename from __ffsdi2.
796         * mklibgcc.in (lib2funcs): Add _ffssi2.
797
798 2003-02-04  Richard Henderson  <rth@redhat.com>
799
800         * libgcc2.c (__paritysi2, __paritydi2): Replace last two reduction
801         rounds with a "bit table" lookup.
802
803 2003-02-04  Ulrich Weigand  <uweigand@de.ibm.com>
804
805         * reload.c (find_reloads): Do not use the mode specified in the insn
806         pattern as reload mode for address operands.  Do not generate optional
807         reloads for operands where a mandatory reload was already pushed.
808
809 2003-02-04  Richard Henderson  <rth@redhat.com>
810
811         * longlong.h [alpha] (count_leading_zeros, count_trailing_zeros): Use
812         builtins instead of inline assembly.
813
814 2003-02-04  Falk Hueffner  <falk.hueffner@student.uni-tuebingen.de>
815
816         PR c/9376
817         * libgcc2.c (__subvdi3): Fix typo.
818
819 Tue Feb  4 21:46:05 CET 2003  Jan Hubicka  <jh@suse.cz>
820
821         * i386.md (movti_rex64):  Fix constraint.
822
823 Tue Feb  4 18:40:42 CET 2003  Jan Hubicka  <jh@suse.cz>
824
825         * i386.md (vector push splitters):  Fix typo in resolving conflict.
826
827 2003-02-04  Rodney Brown  <rbrown64@csc.com.au>
828
829         * config/i386/i386.c (x86_function_profiler): Fix typo in format.
830
831 2003-02-04  Phil Edwards  <pme@gcc.gnu.org>
832
833         * doc/install.texi (*-*-linux-gnu):  Mention glibc requirements
834         for recent libstdc++.  Remove formatting cruft.
835
836 2003-02-04  Jakub Jelinek  <jakub@redhat.com>
837
838         * dwarf2out.c (dwarf2out_finish): Add AT_comp_dir
839         attribute even if input file name is absolute, but one of the
840         includes is relative.
841
842 2003-02-04  Joseph S. Myers  <jsm@polyomino.org.uk>
843
844         * doc/gcc.texi, doc/gccint.texi, doc/gcov.texi,
845         doc/include/fdl.texi, doc/invoke.texi: Update to GFDL 1.2.
846         * doc/install.texi: Update copyright dates.  Update to GFDL 1.2.
847
848 2003-02-03  Richard Henderson  <rth@redhat.com>
849
850         * libgcc2.c (__ffsdi2, __clzsi2, __clzdi2, __ctzsi2, __ctzdi2,
851         __popcountsi2, __popcountdi2, __paritysi2, __paritydi2): Change
852         return type to "int".  Shuffle declarations and undef int trap.
853         * libgcc2.h: Remove their declarations.
854         * optabs.c (expand_unop): Force outmode to int for bitops.
855
856 2003-02-03  Bob Wilson  <bob.wilson@acm.org>
857
858         * config/xtensa/xtensa.c (order_regs_for_local_alloc): Order the
859         coprocessor registers before floating-point registers.
860         * config/xtensa/xtensa.h (REG_ALLOC_ORDER): Adjust register numbers
861         to account for a previously removed register.
862         (SPEC_REG_FIRST, SPEC_REG_LAST, SPEC_REG_NUM, COUNT_REGISTER_REGNUM):
863         Delete unused macros.
864
865 Mon Feb  3 21:19:11 CET 2003  Jan Hubicka  <jh@suse.cz>
866
867         * i386.c (ix86_expand_store_builtin):  Always force op1 to register.
868         (mov*_internal): Fix predicates; require one of operands to not be
869         memory.
870         (SSE?MMX move expanders):  Fix predicates; force one of operands to
871         register.
872         (SSE/MMX push patterns): Reorganize; fix x86-64 code generation.
873         (movups/movupd/movdqu patterns): Force one of operands to not be
874         memory.
875
876 2002-02-03  Roger Sayle  <roger@eyesopen.com>
877
878         * hooks.c (hook_rtx_rtx_identity): Generic hook function that
879         takes a single rtx and returns it unmodified.
880         * hooks.h (hook_rtx_rtx_identity): Prototype here.
881         * target.h (struct gcc_target): Add "delegitimize_address"
882         field to target structure.
883         * target-def.h (TARGET_DELEGITIMIZE_ADDRESS):  Provide default
884         for delegitimize_address target using hook_rtx_rtx_identity.
885         (TARGET_INITIALIZER): Initialize delegitimize_address field
886         using TARGET_DELEGITIMIZE_ADDRESS macro.
887         * simplify-rtx.c (avoid_constant_pool_reference): Handle float
888         extensions of constant pool references.  Use delegitimize_address
889         to undo the obfuscation of "-fpic".
890         * Makefile.in (simplify-rtx.o): Add dependency on target.h.
891
892         * config/i386/i386.c (TARGET_DELEGITIMIZE_ADDRESS): Define as
893         i386_simplify_dwarf_addr.
894         (ix86_find_base_term): Simplify using i386_simplify_dwarf_addr.
895         (maybe_get_pool_constant): Likewise.
896
897 Mon Feb  3 16:01:17 CET 2003  Jan Hubicka  <jh@suse.cz>
898
899         * i386.c (ix86_expand_int_movcc):  Fix setcc sign bit case.
900
901 Mon Feb  3 01:30:11 CET 2003  Jan Hubicka  <jh@suse.cz>
902
903         * regclass.c (cannot_change_mode_set_regs): Correct argument order.
904
905 2003-02-02  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
906
907         * mips/_tilib.c: Don't include tsystem.h or defaults.h.  Don't
908         define LIBGCC2_WORDS_BIG_ENDIAN.  Include coretypes.h and tm.h.
909
910 2003-02-02  Andreas Schwab  <schwab@suse.de>
911
912         * varasm.c (asm_output_aligned_bss): Declare as possibly unused.
913
914 2003-02-02  Richard Earnshaw  <rearnsha@arm.com>
915
916         * arm.md (sibcall_epilogue): Set the "conds" to "clob".
917         (epilogue_insns): Likewise.
918
919 2003-02-02  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
920
921         * doc/install.texi (hppa*-hp-hpux11*): Update installation notes.
922
923 2003-02-02  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
924
925         * pa-protos.h (attr_length_millicode_call): Remove second argument.
926         (attr_length_indirect_call, attr_length_indirect_call,
927         attr_length_save_restore_dltp): New prototypes.
928         * pa.c (attr_length_millicode_call): Remove second argument.  Check
929         INSN_ADDRESSES_SET_P in distance calculation.
930         (output_millicode_call): Check INSN_ADDRESSES_SET_P before using
931         INSN_ADDRESSES.
932         (attr_length_call): Check INSN_ADDRESSES_SET_P in distance calculation.
933         (output_call): Check INSN_ADDRESSES_SET_P before using INSN_ADDRESSES.
934         Call attr_length_call directly.
935         (attr_length_indirect_call, output_indirect_call,
936         attr_length_save_restore_dltp): New functions.
937         * pa.md (attr_length_millicode_call): Drop second argument from all
938         patterns.
939         (return_internal_pic): Delete.
940         (return_external_pic): Remove use of PIC register and pic operand and
941         flag checks.
942         (epilogue): Use return_internal for both normal and pic code.
943         (call, call_value): Emit new 32-bit pic patterns for symref and
944         indirect calls.  Remove uses for arg pointer and pic register.
945         (call_symref_pic, call_symref_pic_post_reload, call_reg_pic,
946         call_reg_pic_post_reload, call_val_symref_pic,
947         call_val_symref_pic_post_reload, call_val_reg_pic,
948         call_val_reg_pic_post_reload): New pre and post reload insn patterns.
949         Implement define_split and define_peephole2 patterns for pre reload
950         patterns.
951         (call_symref_64bit, call_internal_reg_64bit, call_value_symref_64bit,
952         call_value_internal_reg_64bit): Shorten names.
953         (all call patterns): Explicitly indicate registers used and clobbered.
954         Use attr_length_indirect_call and attr_length_save_restore_dltp for
955         attribute length calculation.  Move code generation for indirect calls
956         to output_indirect_call.
957         (sibcall, sibcall_value): Don't restore PIC register.
958         (exception_receiver, builtin_setjmp_receiver): Add blockage after PIC
959         register retore.
960
961 2003-02-02  Gerald Pfeifer  <pfeifer@dbai.tuwien.ac.at>
962
963         * doc/install.texi (Testing): Simplify and compress instructions
964         concerning Dejagnu.
965
966 2003-02-01  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
967
968         * collect2.c (pexecute_pid): Rename to pid.
969         (collect_wait, collect_execute, scan_prog_file, scan_libraries): Use
970         pid.
971
972 2003-02-01  Geoffrey Keating  <geoffk@apple.com>
973
974         * doc/extend.texi (Function Attributes): Remove documentation
975         for PowerPC Windows NT function attributes..
976
977 2003-02-01  Daniel Jacobowitz  <drow@mvista.com>
978
979         * dwarf2out.c (gen_type_die): Check for typedefs before calling
980         for TYPE_MAIN_VARIANT.
981
982 2003-02-01  Richard Henderson  <rth@redhat.com>
983
984         * libgcc2.c: Include auto-host.h.
985         (ATTRIBUTE_HIDDEN): New.
986         (__clz_tab): Don't declare here for clz and ctz.
987         (__clzsi2, __clzdi2): Use count_leading_zeros.
988         (__ctzsi2, __ctzdi2): Use count_trailing_zeros.
989         (__popcount_tab): Mark ATTRIBUTE_HIDDEN.
990         (__paritysi2, __paritydi2): Use shifts instead of __popcount_tab.
991         * longlong.h (__clz_tab): Mark ATTRIBUTE_HIDDEN.
992
993 2003-02-01  Richard Henderson  <rth@redhat.com>
994
995         * config/i386/i386.md (addsi_1_zext splitter): Add TARGET_64BIT
996         to the conditional.
997         (ashlsi3_1_zext splitter): Likewise.
998
999 2003-02-01  Richard Henderson  <rth@redhat.com>
1000
1001         * optabs.c (expand_unop): Use word_mode for outmode of bit scaners.
1002         * libgcc2.c (__ffsdi2, __clzsi2, __clzdi2, __ctzsi2, __ctzdi2,
1003         __popcountsi2, __popcountdi2, __paritysi2 __paritydi2): Change
1004         return type to Wtype.
1005
1006         * libgcc-std.ver (GCC_3.4): Fix inheritance.
1007
1008         * config/i386/i386.md (ffssi2): Use nonimmediate_operand for
1009         expander input constraint.
1010
1011 2003-02-01  Falk Hueffner  <falk.hueffner@student.uni-tuebingen.de>
1012
1013         * optabs.h (optab_index): Add OTI_clz, OTI_ctz, OTI_popcount and
1014         OTI_parity.
1015         (clz_optab, ctz_optab, popcount_optab, parity_optab): New.
1016         * optabs.c (widen_clz, expand_parity): New.
1017         (expand_unop): Handle clz and parity.  Hardcode SImode as outmode
1018         for libcalls to clz, ctz, popcount, and parity.
1019         (init_optabs): Init clz_optab, ctz_optab, popcount_optab and
1020         parity_optab, and set up libfunc handlers.
1021         * libgcc2.c (__clzsi2, __clzdi2, __ctzsi2, __ctzdi2,
1022         __popcountsi2, __popcountdi2, __paritysi2 __paritydi2,
1023         __popcount_tab): New.
1024         * libgcc2.h: Declare them.
1025         * libgcc-std.ver (GCC_3.4): Add new functions from libgcc2.c.
1026         * genopinit.c (optabs): Add clz_optab, ctz_optab, popcount_optab
1027         and parity_optab.
1028         * builtin-types.def (BT_FN_INT_LONG, BT_FN_INT_LONGLONG): New.
1029         * builtins.def (BUILT_IN_CLZ, BUILT_IN_CTZ, BUILT_IN_POPCOUNT,
1030         BUILT_IN_PARITY, BUILT_IN_FFSL, BUILT_IN_CLZL, BUILT_IN_CTZL,
1031         BUILT_IN_POPCOUNTL, BUILT_IN_PARITYL, BUILT_IN_FFSLL,
1032         BUILT_IN_CLZLL, BUILT_IN_CTZLL, BUILT_IN_POPCOUNTLL,
1033         BUILT_IN_PARITYLL): New.
1034         * builtins.c (expand_builtin_unop): Rename from expand_builtin_ffs
1035         and add optab argument.
1036         (expand_builtin): Expand BUILT_IN_{FFS,CLZ,POPCOUNT,PARITY}*.
1037         * tree.def (CLZ_EXPR, CTZ_EXPR, POPCOUNT_EXPR, PARITY_EXPR): New.
1038         * expr.c (expand_expr): Handle them.
1039         * fold-const.c (tree_expr_nonnegative_p): Likewise.
1040         * rtl.def (CLZ, CTZ, POPCOUNT, PARITY): New.
1041         * reload1.c (eliminate_regs): Handle them.
1042         (elimination_effects): Likewise.
1043         * function.c (instantiate_virtual_regs_1): Likewise
1044         * genattrtab.c (check_attr_value): Likewise.
1045         * simplify-rtx.c (simplify_unary_operation): Likewise.
1046         * c-common.c (c_common_truthvalue_conversion): Handle POPCOUNT_EXPR.
1047         * combine.c (combine_simplify_rtx): Handle POPCOUNT and PARITY.
1048         (nonzero_bits): Handle CLZ, CTZ, POPCOUNT and PARITY.
1049         * config/alpha/alpha.md (clzdi2, ctzdi2, popcountdi2): New.
1050         * config/arm/arm.c (arm_init_builtins): Rename __builtin_clz to
1051         __builtin_arm_clz.
1052         * Makefile.in (LIB2FUNCS_1, LIB2FUNCS_2): Move...
1053         * mklibgcc.in (lib2funcs): ...here and merge.  Add new members.
1054         * doc/extend.texi (Other Builtins): Add new builtins.
1055         * doc/md.texi (Standard Names): Add new patterns.
1056
1057 2003-02-01  Ulrich Weigand  <uweigand@de.ibm.com>
1058
1059         * reload.c: Revert 2003-01-31 change.
1060
1061 Sat Feb  1 14:14:40 CET 2003  Jan Hubicka  <jh@suse.cz>
1062
1063         * combine.c (combine_simplify_rtx):  Use reversed_comparison_code_parts.
1064
1065 2003-02-01  Richard Sandiford  <rsandifo@redhat.com>
1066
1067         * flags.h (flag_volatile): Remove declaration.
1068         (flag_volatile_global, flag_volatile_static): Likewise.
1069         * c-typeck.c (build_indirect_ref): Don't check flag_volatile.
1070         * toplev.c (flag_volatile): Remove definition.
1071         (flag_volatile_global, flag_volatile_static): Likewise.
1072         (f_options): Remove corresponding entries here.
1073         * varasm.c (make_decl_rtl): Don't check flag_volatile_global
1074         or flag_volatile_static.
1075         * doc/invoke.texi: Remove documentation of -fvolatile,
1076         -fvolatile-global and -fvolatile-static.
1077
1078 2003-01-31  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
1079
1080         * pa.c (pa_output_function_prologue, pa_output_function_epilogue): Move
1081         updating of total_code_bytes from prologue to epilogue.
1082
1083 2003-01-31  Ulrich Weigand  <uweigand@de.ibm.com>
1084
1085         * reload.c (find_reloads): Do not use the mode specified in the insn
1086         pattern as reload mode for address operands.  Do not generate optional
1087         reloads for operands where a mandatory reload was already pushed.
1088         Generate optional reloads only in the final pass though find_reloads.
1089         (have_replacement_p): New function.
1090
1091 2003-01-31  Gerald Pfeifer  <pfeifer@dbai.tuwien.ac.at>
1092
1093         * doc/install.texi (Testing): Remove a reference to our obsolete
1094         /testresults web pages and strip redundant information concerning
1095         test results.
1096         (Binaries): Refer to Microsoft Windows instead of listing all
1097         possible variants.
1098
1099 Sat Feb  1 00:28:30 CET 2003  Jan Hubicka  <jh@suse.cz>
1100
1101         * loop.c (emit_prefetch_instructions):  Do conversion at right place in
1102         RTL chain.
1103
1104         * combine.c (simplify_set): Reverse order of ragumetns to
1105         REG_CANNOT_CHANGE_MODE_P
1106         * df.c (df_def_record_1): Likewise.
1107         * recog.c (register_operand): Likewise.
1108         * simplify-rtx.c (simplify_subreg): Likewise.
1109         * hard-reg-set.h (REG_CANNOT_CHANGE_MODE_P): Update use of
1110         CANNOT_CHANGE_MODE_CLASS.
1111         * regclass.c (cannot_change_mode_set_regs, invalid_mode_change_p):
1112         Likewise.
1113         * reload.c (push_reload): Likewise.
1114         * alpha.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
1115         * ia64.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
1116         * mips.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
1117         * mips-protos.h (mips_cannot_change_mode_class): Update prototype.
1118         * mips.c (mips_cannot_change_mode_class): Update.
1119         * pa64-regs.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
1120         * rs6000.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
1121         * s390.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
1122         * sh.h (CANNOT_CHANGE_MODE_CLASS): Update definition.
1123         * sh-protos.h (sh_cannot_change_mode_class): Update prototype.
1124         * sh.c (sh_cannot_change_mode_class): Update.
1125         * i386.h (CANNOT_CHANGE_MODE_CLASS): New.
1126         * tm.texi (CANNOT_CHANGE_MODE_CLASS): Update documentation.
1127
1128 2003-01-31  Geoffrey Keating  <geoffk@apple.com>
1129
1130         * config/darwin.h (LINK_COMMAND_SPEC): Update for Nathan's recent
1131         change to LINK_COMMAND_SPEC in gcc.c.
1132
1133 2003-01-31  Jan Hubicka  <jh@suse.cz>
1134
1135         PR c/9506
1136         * i386.c (override_options): Use DEFAULT_PCC_STRUCT_RETURN.
1137
1138 2003-01-31  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
1139
1140         * pa32-regs.h (REGNO_REG_CLASS, REG_CLASS_FROM_LETTER): Delete
1141         duplicated code.
1142
1143 2003-01-31  Nathan Sidwell  <nathan@codesourcery.com>
1144
1145         * tree.h (TYPE_BINFO_SIZE, TYPE_BINFO_SIZE_UNIT): Remove.
1146         (BINFO_ELTS): New #define.
1147         * stor-layout.c (finalize_record_size): Don't set them.
1148         * cp/cp-tree.h (BINFO_SUBVTT_INDEX, BINFO_VPTR_INDEX,
1149         BINFO_PRIMARY_BASE_OF): Use BINFO_ELTS.
1150         (BINFO_LANG_ELTS): New #define.
1151         * cp/tree.c (make_binfo): Use BINFO_LANG_ELTS.
1152         * java/class.c (make_class): Use BINFO_ELTS.
1153         (set_super_info): Likewse.
1154         (add_interface_do): Likewise.
1155         * objc/objc-act.c (start_class): Use BINFO_ELTS.
1156
1157 2003-01-31 Danny Smith <dannysmith@users.sourceforge.net>
1158
1159         * timevar.c (getrusage): Don't ever declare if not HAVE_GETRUSAGE.
1160         (times): Don't ever declare if not HAVE_TIMES.
1161         (clock): Don't ever declare if not HAVE_CLOCK.
1162
1163 2003-01-30  Richard Henderson  <rth@redhat.com>
1164
1165         * flow.c (update_life_info): Zap life info after cleanup_cfg.
1166         (regno_uninitialized): Use correct live at function entry set.
1167         (regno_clobbered_at_setjmp): Likewise.
1168
1169         * expr.c (store_expr): Promote all MEM intermediates to regs.
1170
1171 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
1172
1173         * config/arm/arm.c: Fix comment typos.
1174         * config/arm/arm.h: Likewise.
1175         * config/arm/netbsd-elf.h: Likewise.
1176         * config/arm/netbsd.h: Likewise.
1177
1178 2003-01-30  Geoffrey Keating  <geoffk@apple.com>
1179
1180         * gengtype.c (struct walk_type_data): Add needs_cast_p.
1181         (walk_type): Set needs_cast_p in walk_type_data.
1182         (write_types_process_field): Supply casts when required to suppress
1183         warnings.
1184         (write_root): Cast gt_pch_n_S to suppress warning.
1185         * Makefile.in: Remove -Wno-error from gtype-desc.o and c-decl.o.
1186         * config/rs6000/rs6000.c (print_operand): Mask off high bits only
1187         when they might exist.
1188         * config/rs6000/t-rs6000: Remove -Wno-error from varasm.o,
1189         insn-conditions.o, and rs6000.o.
1190
1191 2003-01-30  Richard Henderson  <rth@redhat.com>
1192
1193         * ggc-page.c (G.context_depth_allocations): New.
1194         (G.context_depth_collections): New.
1195         (alloc_page): Set G.context_depth_allocations.
1196         (ggc_collect): Set G.context_depth_collections.
1197         (ggc_push_context): Limit to HOST_BITS_PER_LONG contexts.
1198         (ggc_pop_context): Early exit for no allocations or collections.
1199
1200 2003-01-30  Richard Henderson  <rth@redhat.com>
1201
1202         * tree-inline.c (walk_tree): Streamline duplicate hash table lookup.
1203
1204 2003-01-30  Richard Earnshaw  <rearnsha@arm.com>
1205
1206         * arm.c (arm_compute_initial_elimination_offset): If optimizing for
1207         size, the link register is always saved if any other register is
1208         saved.
1209
1210 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
1211
1212         * config/h8300/h8300-protos.h: Update the prototype for
1213         compute_plussi_cc.
1214         (cpp_reader): Declare before it is used.
1215         * config/h8300/h8300.c (compute_plussi_cc): Change the return
1216         type to int.
1217         * config/h8300/h8300.md (monitor_prologue): Call abort() if we
1218         see an unknown H8 variant.
1219
1220 2003-01-30  Ralf Corsepius  <corsepiu@faw.uni-ulm.de>
1221
1222         PR target/9316
1223         * config/rs6000/rtems.h: Add CPP_OS_DEFAULT_SPEC.
1224         * config/rs6000/sysv4.h: Add CPP_OS_RTEMS_SPEC.
1225         * config/rs6000/t-rtems: New file. multilib variants to match OS.
1226         * config.gcc (powerpc-*-rtems*): Use rs6000/t-rtems instead of
1227         rs6000/t-ppcgas so we get the desired multilibs.
1228
1229 2003-01-30  Nick Clifton  <nickc@redhat.com>
1230
1231         * config/arm/arm.c (arm_output_epilogue): Update stack pointer
1232         when popping saved IP register off the stack.
1233
1234 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
1235
1236         * config/rs6000/aix43.h: Fix comment typos.
1237         * config/rs6000/aix51.h: Likewise.
1238         * config/rs6000/aix52.h: Likewise.
1239         * config/rs6000/altivec.h: Likewise.
1240         * config/rs6000/rs6000.c: Likewise.
1241         * config/rs6000/rs6000.h: Likewise.
1242         * config/rs6000/rs6000.md: Likewise.
1243         * config/rs6000/spe.md: Likewise.
1244
1245 2003-01-29  Mark Mitchell  <mark@codesourcery.com>
1246
1247         * c-common.c (builtin_define_float_constants): Define
1248         __<TYPE>_HAS_INFINITY__ and __<TYPE>_HAS_QUIET_NAN__.
1249
1250 2003-01-30  Kazu Hirata  <kazu@cs.umass.edu>
1251
1252         * config/sh/lib1funcs.asm: Fix comment typos.
1253         * config/sh/linux.h: Likewise.
1254         * config/sh/sh.c: Likewise.
1255         * config/sh/sh.md: Likewise.
1256
1257 2003-01-30  Loren James Rittle  <ljrittle@acm.org>
1258
1259         * objc/Make-lang.in (objc-parse.y): Find c-parse.in in $(srcdir).
1260
1261 2003-01-30  Alexandre Oliva  <aoliva@redhat.com>
1262
1263         * config/fp-bit.h (__make_dp): Declare if TMODES.
1264
1265 2003-01-29  Kazu Hirata  <kazu@cs.umass.edu>
1266
1267         * config/h8300/h8300.h (PREDICATE_CODES): Add entries for
1268         general_operand_src and general_operand_dst.
1269
1270 2003-01-29  David Edelsohn  <edelsohn@gnu.org>
1271
1272         * config/rs6000/rs6000.c (function_arg_pass_by_reference):
1273         Return true for variable sized types.
1274         (rs6000_va_arg): Handle variable sized types passed by reference
1275         on non-SVR4 ABI.
1276
1277 2003-01-29  Richard Earnshaw  <rearnsha@arm.com>
1278
1279         * arm.c (arm_legtimize_address): New function.
1280         * arm-protos.h (arm_legtimize_address): Add prototype.
1281         * arm.h (ARM_LEGITIMIZE_ADDRESS): Use arm_legitimize_address.
1282         (LEGITIMIZE_ADDRESS, THUMB_LEGITIMIZE_ADDRESS): Wrap with
1283         do ... while (0)
1284
1285 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
1286
1287         PR bootstrap/9296
1288         * gthr-rtems.h: Define __GTHREAD_MUTEX_INIT.  Apparently no code
1289         depended on it being defined until now.
1290
1291 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
1292
1293         PR target/9295
1294         * config/mips/rtems.h: Predefine __USE_INIT_FINI__ so generic
1295         RTEMS code knows which C++ initialization style the toolset
1296         configuration is using.
1297
1298 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
1299
1300         PR bootstrap/9293
1301         * config/m68k/t-crtstuff: Replace spaces with tabs, add
1302          $(MULTILIB_CFLAGS) as compiler option and multilib crtbegin/end.o.
1303
1304 2003-01-29  Joel Sherrill  <joel@OARcorp.com>
1305
1306         PR bootstrap/9292
1307         * config.gcc (hppa1.1-rtems):  Did not include t-rtems nor enable
1308         RTEMS threads.
1309         * config/pa/rtems.h (LIB_SPEC): Use -N when linking.
1310
1311 2003-01-29  Nick Clifton  <nickc@redhat.com>
1312
1313         * Makefile.in (c-parse.o): Locate source file in $(parsedir)
1314         not $(srcdir).
1315
1316 2003-01-29  Andrew Haley  <aph@redhat.com>
1317
1318         * tree-inline.c (walk_tree): Add CHAR_TYPE.
1319
1320 Wed Jan 29 10:26:12 CET 2003  Jan Hubicka  <jh@suse.cz>
1321
1322         * i386.md (subdi3_carry_rex64): Fix typo.
1323
1324 2003-01-28  Stan Shebs  <shebs@apple.com>
1325
1326         * coretypes.h (cpp_reader): Forward declare struct.
1327         * c-pragma.h (cpp_reader): Remove forward declaration.
1328         * hashtable.h (cpp_reader): Likewise.
1329         * scan.h (cpp_reader): Likewise.
1330         * tree.h (cpp_reader): Likewise.
1331         * config/darwin-protos.h (cpp_reader): Likewise.
1332         * config/arm/arm-protos.h (cpp_reader): Likewise.
1333         * config/rs6000/rs6000-protos.h: Remove GCC_CPPLIB_H ifdef, use
1334         struct cpp_reader in prototypes.
1335
1336 2003-01-28  Christian Cornelssen  <ccorn@cs.tu-berlin.de>
1337
1338         * doc/install.texi: Add documentation for installation into
1339         tooldirs and with DESTDIR.
1340
1341 2003-01-28  Richard Henderson  <rth@redhat.com>
1342
1343         * config.gcc (ia64*-*-aix*): Remove.
1344         * config/ia64/aix.h, config/ia64/t-aix: Remove file.
1345         * config/ia64/unwind-aix.c: Remove file.
1346
1347 2003-01-28  Andreas Schwab  <schwab@suse.de>
1348
1349         * config/m68k/m68k.md (tablejump+2): Don't sign extend an address
1350         register.
1351         * config/m68k/apollo68.h (ASM_RETURN_CASE_JUMP): Likewise.
1352         * config/m68k/coff.h (ASM_RETURN_CASE_JUMP): Likewise.
1353         * config/m68k/linux.h (ASM_RETURN_CASE_JUMP): Likewise.
1354         * config/m68k/m68kelf.h (ASM_RETURN_CASE_JUMP): Likewise.
1355         * config/m68k/mot3300.h (ASM_RETURN_CASE_JUMP): Likewise.
1356         * config/m68k/netbsd-elf.h (ASM_RETURN_CASE_JUMP): Likewise.
1357         * config/m68k/pbb.h (ASM_RETURN_CASE_JUMP): Likewise.
1358
1359 2003-01-28  Richard Sandiford  <rsandifo@redhat.com>
1360
1361         * combine.c (nonzero_bits): Fix check for negative divide operands.
1362
1363 2003-01-28  Richard Henderson  <rth@redhat.com>
1364
1365         * config/ia64/ia64.c (ia64_rwreloc_section_type_flags): New.
1366         * config/ia64/hpux.h (TARGET_SECTION_TYPE_FLAGS): New.
1367
1368 2003-01-28  Richard Henderson  <rth@redhat.com>
1369
1370         * cse.c (find_best_addr): Kill !ADDRESS_COST code.
1371
1372         * config/cris/cris.c (cris_address_cost): Make static.
1373         (TARGET_RTX_COSTS, TARGET_ADDRESS_COST): New.
1374         * config/cris/cris.h (ADDRESS_COST): Remove.
1375         * config/cris/cris-protos.h: Update.
1376
1377 2003-01-23  Mike Stump  <mrs@apple.com>
1378
1379         * regclass.c (init_reg_autoinc): New function.
1380         (regclass): Move initialization of forbidden_inc_dec_class from
1381         here...
1382         (init_regs): to here.  Avoids reinitialization for each function,
1383         saving compilation time.
1384
1385 2003-01-28  Jason Merrill  <jason@redhat.com>
1386
1387         * cpplib.h (struct cpp_options): Add warn_deprecated field.
1388         * cppinit.c (cpp_create_reader): Turn it on by default.
1389         * c-opts.c (c_common_decode_option): Set it.
1390         * cpplib.c (do_pragma_once): Only complain about #pragma once
1391         if warn_deprecated is set.
1392
1393 2003-01-28  Dale Johannesen  <dalej@apple.com>
1394
1395         * emit-rtl.c (const_double_htab_hash):  Use mode in the hash.
1396         * loop.c (scan_loop):  Move movables on -Os rich-register targets.
1397         * config/rs6000/rs6000.md (sibcall*):  Use match_operand for LR.
1398
1399 2003-01-28  Richard Henderson  <rth@redhat.com>
1400
1401         * target.h (targetm.address_cost): New.
1402         * target-def.h (TARGET_ADDRESS_COST): New.
1403         (TARGET_RTX_COSTS): Uncomment.  Oops.
1404         * cse.c (address_cost): Use new target hook.
1405         (default_address_cost): New.
1406         * output.h (default_address_cost): Declare.
1407         * hooks.c (hook_int_rtx_0): New.
1408         * hooks.h (hook_int_rtx_0): Declare.
1409         * loop.c (combine_givs_p): Remove if 0 code.
1410         * system.h (ADDRESS_COST): Poison.
1411
1412         * config/alpha/alpha.c, config/alpha/alpha.h, config/d30v/d30v.c,
1413         config/d30v/d30v.h, config/ia64/ia64.c, config/ia64/ia64.h,
1414         config/m32r/m32r.c, config/m32r/m32r.h, config/mcore/mcore.c,
1415         config/mcore/mcore.h, config/mmix/mmix.c, config/mmix/mmix.h,
1416         config/rs6000/rs6000.c, config/rs6000/rs6000.h, config/sparc/sparc.c,
1417         config/sparc/sparc.h, config/v850/v850.c, config/v850/v850.h,
1418         config/xtensa/xtensa.c, config/xtensa/xtensa.h
1419         (TARGET_ADDRESS_COST): Define as hook_int_rtx_0.
1420         (ADDRESS_COST): Remove.
1421
1422         * config/arc/arc-protos.h, config/arc/arc.c, config/arc/arc.h,
1423         config/avr/avr-protos.h, config/avr/avr.c, config/avr/avr.h,
1424         config/c4x/c4x-protos.h, config/c4x/c4x.c, config/c4x/c4x.h,
1425         config/dsp16xx/dsp16xx-protos.h, config/dsp16xx/dsp16xx.c,
1426         config/dsp16xx/dsp16xx.h, config/i386/i386-protos.h,
1427         config/i386/i386.c, config/i386/i386.h, config/i960/i960-protos.h,
1428         config/i960/i960.c, config/i960/i960.h, config/ip2k/ip2k-protos.h,
1429         config/ip2k/ip2k.c, config/ip2k/ip2k.h, config/mips/mips-protos.h,
1430         config/mips/mips.c, config/mips/mips.h,
1431         config/m68hc11/m68hc11-protos.h, config/m68hc11/m68hc11.c,
1432         config/m68hc11/m68hc11.h, config/ns32k/ns32k-protos.h,
1433         config/ns32k/ns32k.c, config/ns32k/ns32k.h, config/pa/pa-protos.h,
1434         config/pa/pa.c, config/pa/pa.h, config/s390/s390-protos.h,
1435         config/s390/s390.c, config/s390/s390.h, config/vax/vax-protos.h,
1436         config/vax/vax.c, config/vax/vax.h
1437         (foo_address_cost): Make static.
1438         (TARGET_ADDRESS_COST): New.
1439         (ADDRESS_COST): Remove.
1440
1441         * config/arm/arm.h, config/arm/arm.c, config/m88k/m88k.h,
1442         config/m88k/m88k.c, config/romp/romp.h, config/romp/romp.c,
1443         config/sh/sh.c, config/sh/sh.h, config/stormy16/stormy16.c,
1444         config/stormy16/stormy16.h
1445         (ADDRESS_COST): Move code ...
1446         (foo_address_cost): ... here.
1447         (TARGET_ADDRESS_COST): New.
1448
1449         * config/m32r/m32r.c (m32r_address_cost): Remove.
1450         * config/m32r/m32r-protos.h: Update.
1451
1452         * config/mmix/mmix.c (mmix_address_cost): Remove.
1453         * config/mmix/mmix-protos.h: Update.
1454
1455         * config/mn10300/mn10300.c (mn10300_address_cost_1): Rename from
1456         mn10300_address_cost; move unsig allocation ...
1457         (mn10300_address_cost): ... here.
1458         (TARGET_ADDRESS_COST): New.
1459         * config/mn10300/mn10300-protos.h: Update.
1460         * config/mn10300/mn10300.h (ADDRESS_COST): Remove.
1461
1462         * doc/tm.texi: Update.
1463
1464 2003-01-28  Vladimir Makarov  <vmakarov@redhat.com>
1465
1466         * haifa-sched.c (schedule_insn): Return necessary cycle advance
1467         after issuing the insn.
1468         (rank_for_schedule): Make a insn with /S the highest priority
1469         insn.
1470         (move_insn): Ignore schedule groups.  Clear SCHED_GROUP_P.
1471         (choose_ready): Check SCHED_GROUP_P.
1472         (schedule_block): Advance cycle after issuing insn if it is
1473         necessary.  Don't reorder insns if there is an insn with /S.
1474         (set_priorities): Ignore schedule groups.
1475
1476         * sched-deps.c (remove_dependence, group_leader): Remove the
1477         functions.
1478         (add_dependence): Ignore schedule groups.
1479         (set_sched_group_p): Don't make copy of dependencies from previous
1480         insn of the schedule group.  Add anti-dependency to the previous
1481         insn of the schedule group.
1482         (compute_forward_dependences): Ignore schedule groups.
1483
1484         * sched-ebb.c (init_ready_list): Ignore schedule groups.
1485
1486         * sched-rgn.c (init_ready_list): Ditto.
1487         (can_schedule_ready_p): Ditto.
1488
1489 2003-01-28  Vladimir Makarov  <vmakarov@redhat.com>
1490
1491         * config/i386/i386.md (*movsi_1): Use movdqa to move one xmm
1492         register to another one.
1493
1494 2003-01-28  Richard Henderson  <rth@redhat.com>
1495
1496         * calls.c (default_must_pass_in_stack): Fix typo in !type case.
1497
1498 2003-01-28  Roger Sayle  <roger@eyesopen.com>
1499
1500         * cse.c (cse_insn): Avoid redundant REG_EQUAL notes.
1501
1502 2003-01-28  Richard Sandiford  <rsandifo@redhat.com>
1503
1504         * config/sh/sh.h (CLASS_MAX_NREGS): If TARGET_SHMEDIA, and the given
1505         class contains a floating-point register, return the size of the
1506         mode in half words.
1507
1508 Tue Jan 28 12:15:13 CET 2003  Jan Hubicka  <jh@suse.cz>
1509
1510         * i386.c (ix86_carry_flag_operator):  New predicate.
1511         (fcmov_operator): Fix whitespace.
1512         (ix86_expand_carry_flag_compare):  Deal with floating point.
1513         (ix86_expand_int_movcc): Deal with fp; update insn expansion
1514         (ix86_expand_int_addcc): Likewise.
1515         (ix86_expand_strlensi_unroll_1): likewsie.
1516         * i386.h (PREDICATE_CODES): Add ix86_carry_flag_operator.
1517         * i386.md (add?i_carry_rex64): Use new predicate.
1518         (sub?i3_carry_rex64): Likewise.
1519         (x86_mov?icc_0_m1*): Likewise.
1520
1521 2003-01-28  Andreas Schwab  <schwab@suse.de>
1522
1523         * cfgloopmanip.c (create_preheader): Initialize src to avoid
1524         warning.
1525
1526         * expmed.c (emit_store_flag): Fix cast to avoid sign
1527         comparison warning.
1528
1529         * combine.c (force_to_mode): Add cast to fix warning when
1530         STORE_FLAG_VALUE is negative.
1531
1532 2003-01-27  Richard Henderson  <rth@redhat.com>
1533
1534         * Makefile.in (cse.o): Depend on TARGET_H.
1535         * cse.c (rtx_cost): Use targetm.rtx_costs.
1536         * system.h (CONST_COSTS RTX_COSTS DEFAULT_RTX_COSTS): Poison.
1537         * doc/tm.texi: Update.
1538
1539         * target.h (targetm.rtx_costs): New.
1540         * target-def.h (TARGET_RTX_COSTS): New.
1541         * hooks.c (hook_bool_rtx_int_int_intp_false): New.
1542         * hooks.h: Update.
1543
1544         * config/alpha/alpha.c (alpha_rtx_cost_data): New.
1545         (alpha_rtx_costs, TARGET_RTX_COSTS): New.
1546         * config/alpha/alpha.h (PROCESSOR_MAX): New.
1547         (CONST_COSTS, RTX_COSTS): Remove.
1548
1549         * config/arc/arc.c, config/arc/arc.h, config/c4x/c4x.c,
1550         config/c4x/c4x.h, config/cris/cris.c, config/cris/cris.h,
1551         config/d30v/d30v.c, config/d30v/d30v.h, config/dsp16xx/dsp16xx.c,
1552         config/dsp16xx/dsp16xx.h, config/frv/frv.c, config/frv/frv.h,
1553         config/h8300/h8300.c, config/h8300/h8300.h, config/i370/i370.c,
1554         config/i370/i370.h, config/i386/i386.c, config/i386/i386.h,
1555         config/i960/i960.c, config/i960/i960.h, config/ia64/ia64.c,
1556         config/ia64/ia64.h, config/m32r/m32r.c, config/m32r/m32r.h,
1557         config/m68k/m68k.c, config/m68k/m68k.h, config/m88k/m88k.c,
1558         config/m88k/m88k.h, config/mcore/mcore.c, config/mcore/mcore.h,
1559         config/mips/mips.c, config/mips/mips.h, config/mn10200/mn10200.c,
1560         config/mn10200/mn10200.h, config/mn10300/mn10300.c,
1561         config/mn10300/mn10300.h, config/ns32k/ns32k.c, config/ns32k/ns32k.h,
1562         config/pa/pa.c, config/pa/pa.h, config/pdp11/pdp11.c,
1563         config/pdp11/pdp11.h, config/romp/romp.c, config/romp/romp.h,
1564         config/rs6000/rs6000.c, config/rs6000/rs6000.h, config/s390/s390.c,
1565         config/s390/s390.h, config/sh/sh.c, config/sh/sh.h,
1566         config/stormy16/stormy16.c, config/stormy16/stormy16.h,
1567         config/v850/v850.c, config/v850/v850.h,
1568         config/xtensa/xtensa.c, config/xtensa/xtensa.h
1569         (CONST_COSTS, RTX_COSTS): Move code ...
1570         (foo_rtx_costs, TARGET_RTX_COSTS): ... here.
1571
1572         * config/arm/arm.c (arm_rtx_costs_1): Rename from arm_rtx_costs.
1573         (arm_rtx_costs, TARGET_RTX_COSTS): New.
1574         * config/arm/arm-protos.h: Update.
1575         * config/arm/arm.h (DEFAULT_RTX_COSTS): Remove.
1576
1577         * config/avr/avr.h (CONST_COSTS): Move code ...
1578         * config/avr/avr.c (avr_rtx_costs): ... here.
1579         (default_rtx_costs): Make static.
1580         * config/avr/avr-protos.h: Update.
1581
1582         * config/h8300/h8300.c (const_costs): Make static.
1583         (h8300_and_costs, h8300_shift_costs): Likewise.
1584         * config/h8300/h8300-protos.h: Update.
1585
1586         * config/ip2k/ip2k.h (DEFAULT_RTX_COSTS): Remove.
1587         (CONST_COSTS): Move code ...
1588         * config/ip2k/ip2k.c (ip2k_rtx_costs): ... here.  Rename from
1589         default_rtx_costs; update for signature change.
1590         * config/ip2k/ip2k-protos.h: Update.
1591
1592         * config/m68hc11/m68hc11.h (RTX_COSTS): Remove.
1593         (CONST_COSTS): Move code ...
1594         * config/m68hc11/m68hc11.c (m68hc11_rtx_costs): ... here.
1595         (TARGET_RTX_COSTS): New.
1596         (m68hc11_rtx_costs_1): Rename from m68hc11_rtx_costs; make static.
1597         * config/m68hc11/m68hc11-protos.h: Update.
1598
1599         * config/m68k/m68k.c (const_int_cost): Make static.
1600         * config/m68k/m68k-protos.h: Update.
1601
1602         * config/mcore/mcore.c (mcore_const_costs): Make static.
1603         (mcore_and_cost, mcore_ior_cost): Likewise.
1604         * config/mcore/mcore-protos.h: Update.
1605
1606         * config/mmix/mmix.c (mmix_rtx_costs, TARGET_RTX_COSTS): New.
1607         (mmix_rtx_cost_recalculated): Remove.
1608         * config/mmix/mmix.h (DEFAULT_RTX_COSTS): Remove.
1609         * config/mmix/mmix-protos.h: Update.
1610
1611         * config/sh/sh.c (shiftcosts): Make static.
1612         (addsubcosts, andcosts, multcosts): Likewise.
1613         * config/sh/sh-protos.h: Update.
1614
1615         * config/sparc/sparc.c (TARGET_RTX_COSTS): New.
1616         (sparc_rtx_costs): Make static; update for change in signature.
1617         * config/sparc/sparc.h (RTX_COSTS_CASES, RTX_COSTS): Remove.
1618         * config/sparc/sparc-protos.h: Update.
1619
1620         * config/v850/v850.c (const_costs): Make static.
1621         * config/v850/v850-protos.h: Update.
1622
1623         * config/vax/vax.h (RTX_COSTS): Remove.
1624         (CONST_COSTS): Move code ...
1625         * config/vax/vax.c (vax_rtx_costs_1): ... here; rename
1626         from vax_rtx_cost.
1627         (vax_rtx_costs, TARGET_RTX_COSTS): New.
1628
1629 2003-01-27  Richard Henderson  <rth@redhat.com>
1630
1631         * config/vax/vax.h (ASM_OUTPUT_MI_THUNK): Remove.  Really.
1632         * config/vax/vax-protos.h: Update.  Really.
1633
1634 2003-01-28  Alexandre Oliva  <aoliva@redhat.com>
1635
1636         * config/mips/mips.h (UNITS_PER_HWFPVALUE): Renamed from...
1637         (UNITS_PER_FPVALUE): Defined as the width of a long double, or
1638         zero if no hardware floating point.
1639         (LONG_DUBLE_TYPE_SIZE): Set to 128 on N32 and N64.
1640         (MAX_FIXED_MODE_SIZE): Define to LONG_DOUBLE_TYPE_SIZE.
1641         (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): Define.
1642         (BIGGEST_ALIGNMENT): Same as LONG_DOUBLE_TYPE_SIZE.
1643         (FUNCTION_VALUE_REGNO_P): Set for FP_RETURN+2 on N32 and N64.
1644         * config/mips/mips.c (mips_arg_info): Pass TFmode values in
1645         even FP registers on N32 and N64.
1646         (mips_setup_incoming_varargs): Use UNITS_PER_HWFPVALUE.
1647         (mips_va_start): Adjust alignment of ARG_POINTER_REGNUM.
1648         (mips_va_arg): Use UNITS_PER_HWFPVALUE.  Impose additional
1649         even-register-like alignment to 128-bit arguments.
1650         (save_restore_insns): Use UNITS_PER_HWFPVALUE.
1651         (mips_function_value): Likewise.  Return TFmode in $f0 and $f2
1652         on N32 or N64.
1653         * config/mips/_tilib.c (__negti2, __ashlti3, __lshrti3): New.
1654         * config/mips/t-iris6 (LIB2FUNCS_EXTRA): Add _tilib.c.
1655         (TPBIT): Set to tp-bit.c.
1656         (tp-bit.c): Create out of fp-bit.c.
1657
1658 2003-01-28  Gabriel Dos Reis  <gdr@integrable-solutions.net>
1659
1660         * c-parse.in: Remove '%expect 32' directive in objc mode.
1661
1662 2003-01-27  Nathan Sidwell  <nathan@codesourcery.com>
1663
1664         * Makefile.in (LIB2FUNCS_ST): Remove _gcov.
1665         (LIBGCOV): New variable.
1666         (libgcc.mk): Add LIBGCOV.
1667         (LIBGCC_DEPS): Add libgcov.c.
1668         (libgcov.a): New target.
1669         (clean): Remove libgcov.a.
1670         (install-libgcc): Do libgcov too.
1671         (stage1-start, stage2-start, stage3-start, stage4-start): Deal
1672         with libgcov.a.
1673         * libgcc2.c (L_gcov): Move into ...
1674         * libgcov.c: ... here. New file.
1675         * mklibgcc.in: Add libgcov rules.
1676         * gcc.c (LINK_COMMAND_SPEC): Add -lgcov when profiling.
1677
1678         * doc/invoke.texi (profile-arcs, test-coverage): Update and
1679         clarify.
1680
1681         * profile.c (index_counts_file): Remove duplicate check for open file.
1682
1683 2003-01-27  Jerry Quinn  <jlquinn@optonline.net>
1684
1685         * gcc/doc/invoke.texi (Optimization Options): Group together
1686         optional and experimental flags.  Move trapv and bounds-check
1687         out of this section.  Group floating point flags together.
1688         (Code Gen Options): Move trapv and bounds-check to here.
1689
1690 2003-01-27  Josef Zlomek  <zlomekj@suse.cz>
1691
1692         * gcse.c (constprop_register): Check NEXT_INSN (insn) != NULL.
1693
1694 2003-01-27  Richard Earnshaw  <rearnsha@arm.com>
1695
1696         PR optimization/9090
1697         * function.c (purge_addressof_1): After pushing an addressed register
1698         onto the stack, simplify the result.
1699
1700 2003-01-27  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
1701
1702         * doc/extend.texi: Fix typo.
1703
1704 2003-01-27  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
1705
1706         * doc/cppopts.texi: Fix typo.
1707         * doc/objc.texi: Likewise.
1708         * doc/passes.texi: Likewise.
1709
1710 2003-01-27  Alexandre Oliva  <aoliva@redhat.com>
1711
1712         * real.c (ibm_extended_format): Add 53 to minimum exponent.
1713         (encode_ibm_extended): Adjust.
1714
1715 2003-01-26  Gabriel Dos Reis  <gdr@soliton.integrable-solutions.net>
1716
1717         * timevar.def (TV_OVERLOAD, TV_TEMPLATE_INSTANTIATION): New
1718         timevar_id enumerations.
1719
1720 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
1721
1722         * combine.c: Fix formatting.
1723
1724 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
1725
1726         * doc/gccint.texi: Update the copyright.
1727
1728 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
1729
1730         * doc/cpp.texi: Fix typos.
1731         * doc/extend.texi: Likewise.
1732         * doc/gty.texi: Likewise.
1733         * doc/install.texi: Likewise.
1734         * doc/passes.texi: Likewise.
1735         * doc/rtl.texi: Likewise.
1736         * doc/tm.texi: Likewise.
1737
1738 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
1739
1740         * config/ia64/fde-glibc.c: Fix comment typos.
1741         * config/ia64/hpux.h: Likewise.
1742         * config/ia64/ia64.c: Likewise.
1743         * config/ia64/ia64.h: Likewise.
1744         * config/ia64/unwind-ia64.c: Likewise.
1745
1746 2003-01-26  Kazu Hirata  <kazu@cs.umass.edu>
1747
1748         * config/i386/i386-modes.def: Fix comment typos.
1749         * config/i386/i386.c: Likewise.
1750         * config/i386/i386.md: Likewise.
1751
1752 2003-01-26  Steven Bosscher  <s.bosscher@student.tudelft.nl>
1753
1754         * config/avr/avr.h, config/cris/aout.h, config/elfos.h,
1755         config/i386/freebsd-aout.h, config/mips/iris6.h: Undefine
1756         ASM_FINISH_DECLARE_OBJECT before defining it.
1757         * toplev.c (rest_of_decl_compilation):  Don't define
1758         ASM_FINISH_DECLARE_OBJECT.  Only use it if it is defined.
1759         (rest_of_type_compilation): Don't ATTRIBUTE_UNUSED function
1760         parameters for DWARF2 targets because they _are_ used.
1761
1762 2003-01-26  Alexandre Oliva  <aoliva@redhat.com>
1763
1764         * fp-bit.h: Define macros for TFmode floating-point constants
1765         in IBM-extended TFmode types.
1766         (TMODES): Define if __LDBL_MANT_DIG__ has the newly-supported
1767         widths.
1768         * config/fp-bit.c (pack_d, unpack_d): Support IBM-extended
1769         TFmode type.
1770
1771         * config/fp-bit.h: Define macros for TFmode floating-point
1772         constants in IEEE quad TFmode type.  Declare functions according
1773         to L_ macros.
1774         (TMODES): Define if __LDBL_MANT_DIG__ is 113.
1775         (TFtype, TItype, UTItype): Define if TMODES is defined.
1776         (MAX_UDI_INT, MAX_DI_INT, BITS_PER_DI): Likewise.
1777         (F_T_BITOFF, D_T_BITOFF): Define.
1778         (IMPLICIT_1, IMPLICIT_2): Cast constants to types that are
1779         guaranteed to be wide enough.
1780         * config/fp-bit.c: Check for L_ macros for tf functions.
1781         (__thenan_tf): New.
1782         (nan): Adjust.
1783         (pack_d, unpack_d): Support IEEE 854 quad type.
1784         (_fpmul_parts): Support TFmode.  Compute exponent adjustment
1785         from FRAC_NBITS, FRAC_BITS and NGARDS.
1786         (usi_to_float): Cast constants to be shifted to fractype
1787         instead of assuming long long is wide enough.
1788         (sf_to_tf, df_to_tf, __make_tp, tf_to_df, tf_to_sf): New.
1789
1790 2003-01-26  Andreas Jaeger  <aj@suse.de>
1791
1792         * df.c: Remove prototype of unused function df_regno_rtl_debug.
1793
1794 2003-01-26  Alexandre Oliva  <aoliva@redhat.com>
1795
1796         * Makefile.in (FPBIT_FUNCS): Added _sf_to_tf.
1797         (DBBIT_FUNCS): Added _df_to_tf.
1798         (TPBIT_FUNCS): New.
1799         (libgcc.mk): Pass TPBIT and TPBIT_FUNCS down.
1800         (LIBGCC_DEPS): Added TPBIT.
1801         * mklibgcc.in: Support TPBIT and TPBIT_FUNCS.
1802
1803         * optabs.c (expand_binop) <add, sub>: Return xtarget if we haven't
1804         been able to move the result to target.
1805
1806         * expr.c (emit_group_store): Initialize dst with CONST0_RTX
1807         for the appropriate mode.
1808
1809         * calls.c (emit_library_call_value_1): Handle return values
1810         in a PARALLEL.
1811
1812         * rtl.c (get_mode_alignment): Moved to...
1813         * stor-layout.c: ... here.
1814
1815         * print-rtl.c (print_rtx): Don't print MEM details in
1816         GENERATOR_FILEs.
1817
1818 2003-01-26  Michael Hayes  <mph@paradise.net.nz>
1819
1820         * df.h: Update comments, tidy formatting.
1821         (DF_FORWARD, DF_REVERSE, DF_UNION, DF_INTERSECTION): Rename from FORWARD,
1822         REVERSE, UNION, INTERSECTION.  All uses updated.
1823         (OLD_DF_INTERFACE): Remove.
1824         (struct insn_info): Remove commented out insn field.
1825         * df.c: Update comments, tidy formatting.
1826         (df_def_table_realloc): Remove.
1827
1828
1829 2003-01-26  Alan Modra  <amodra@bigpond.net.au>
1830
1831         * calls.c (save_fixed_argument_area): Tidy.
1832         (restore_fixed_argument_area): Tidy.  Set alignment of stack_area.
1833         (expand_call): Comment typo fixes.  Don't init low_to_save.  Start
1834         call chain loop at 1 if !try_tail_call.  Formatting.
1835         (emit_library_call_value_1): Don't init low_to_save or high_to_save.
1836         Use save_fixed_argument_area and restore_fixed_argument_area.
1837
1838 2003-01-26  Michael Hayes  <m.hayes@elec.canterbury.ac.nz>
1839
1840         * df.c (df_uses_record): Handle CC0.
1841
1842 2003-01-25  Ulrich Weigand  <uweigand@de.ibm.com>
1843
1844         * reload.c (maybe_memory_address_p): New function.
1845         (find_reloads_address): Use it instead of memory_address_p.
1846
1847 2003-01-25  Kaz Kojima  <kkojima@gcc.gnu.org>
1848
1849         * final.c (shorten_branches): Align the address of code label
1850         when computing initial lengths and addresses.
1851
1852 2003-01-25  Kazu Hirata  <kazu@cs.umass.edu>
1853
1854         * config/m68hc11/m68hc11.md: Fix a comment typo.
1855
1856 2003-01-25  Andreas Jaeger  <aj@suse.de>
1857
1858         * config/i386/i386.c (x86_output_mi_thunk): Correct test for
1859         TARGET_MACHO.
1860
1861 2003-01-25  Roger Sayle  <roger@eyesopen.com>
1862
1863         * gcse.c (bypass_last_basic_block): New global variable.
1864         (bypass_block):  Use redirect_edge_and_branch_force to redirect
1865         fall-through edges.  Use bypass_last_basic_block to determine
1866         which blocks have valid PRE information.
1867         (bypass_conditional_jumps): Initialize bypass_last_basic_block.
1868
1869 Sat Jan 25 22:31:59 CET 2003  Jan Hubicka  <jh@suse.cz>
1870
1871         * gcse.c (local_cprop_pass): Update reg_sets table when needed.
1872
1873 Sat Jan 25 21:04:33 CET 2003  Jan Hubicka  <jh@suse.cz>
1874                               Eric Botcazou <ebotcazou@libertysurf.fr>
1875         PR opt/8492
1876         * gcse.c (one_cprop_pass): Delete unreachable blocks.
1877
1878 2003-01-25  Richard Henderson  <rth@redhat.com>
1879
1880         * config/ia64/ia64.c (ia64_rwreloc_select_rtx_section): Rename
1881         from ia64_aix_select_rtx_section.
1882         (ia64_rwreloc_select_section): Simlarly; use default*_1 function
1883         instead of saving and restoring flag_pic.
1884         (ia64_rwreloc_unique_section): Similarly.
1885         * config/ia64/aix.h (TARGET_ASM_SELECT_SECTION,
1886         TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_RTX_SECTION): Update.
1887         * config/ia64/hpux.h (TARGET_ASM_SELECT_SECTION,
1888         TARGET_ASM_UNIQUE_SECTION, TARGET_ASM_SELECT_RTX_SECTION): New.
1889
1890 2003-01-25  Kazu Hirata  <kazu@cs.umass.edu>
1891
1892         * config/h8300/h8300.c (h8300_shift_needs_scratch_p): Update a
1893         comment.
1894
1895 2002-01-25  Richard Henderson  <rth@redhat.com>
1896
1897         * config/m68k/m68k-none.h (ASM_SPEC): Adjust inter-option spacing.
1898
1899 2002-01-25  Kelley Cook <kelleycook@comcast.net>
1900
1901         * ggc-simple.c (debug_ggc_tree): Add PTR cast.
1902
1903 2003-01-25  Segher Boessenkool  <segher@koffie.nl>
1904
1905         * bitmap.h (BITMAP_WORD): New typedef: fundamental storage
1906         type for bitmaps.  Use unsigned long.
1907         (nBITMAP_WORD_BITS): New macro.
1908         (BITMAP_WORD_BITS): New macro.
1909         (rest of file): Use it.
1910         * bitmap.c: Use it.
1911
1912 2003-01-25  Richard Henderson  <rth@redhat.com>
1913
1914         2002-02-19  Robert Lipe  <robertlipe@usa.net>
1915         * config/i386/t-sco5gas: (CRTSTUFF_T_CFLAGS_S): Delete -mcoff.
1916
1917 2002-01-25  Roger Sayle  <roger@eyesopen.com>
1918
1919         * builtins.c (purge_builtin_constant_p): Scan insn stream
1920         sequentially rather than by basic block.
1921         * function.c (purge_addressof): Simplify test with INSN_P.
1922
1923 2003-01-25  Kazu Hirata  <kazu@cs.umass.edu>
1924
1925         * combine.c (simplify_comparison, case AND): Remove a redundant test.
1926
1927 2002-01-25  Roger Sayle  <roger@eyesopen.com>
1928
1929         * function.h (struct function): New field calls_constant_p.
1930         (current_function_calls_constant_p): New macro for above.
1931         * function.c (prepare_function_start): Initialize calls_eh_return
1932         and calls_constant_p.
1933         * builtins.c (expand_builtin_constant_p): Set calls_constant_p.
1934         * toplev.c (rest_of_compilation): Only call purge_builtin_constant_p
1935         when the current_function_calls_constant_p.
1936         * integrate.c (expand_inline_function): Set calls_constant_p if
1937         the function being inlined has calls_constant_p set.
1938
1939 2002-01-25  Roger Sayle  <roger@eyesopen.com>
1940
1941         * cse.c (fold_rtx): Instantiate CONSTANT_P_RTX to 0 when not
1942         optimizing, even if flag_gcse is true.
1943         * toplev.c (rest_of_compilation): purge_builtin_constant_p
1944         only needs to be called when "optimize > 0 && flag_gcse".
1945
1946 2003-01-25  Roger Sayle  <roger@eyesopen.com>
1947
1948         * stmt.c (emit_case_bit_tests): New routine to implement suitable
1949         switch statements using the equivalent of "if ((1<<x) & cst) ... ".
1950         (case_bit_test_cmp): New comparison function for "qsort" to order
1951         case_bit_tests by decreasing number of destination nodes.
1952         (lshift_cheap_p): New function to determine if "1 << x" is cheap.
1953         (expand_end_case_type): Use emit_case_bit_tests to implement
1954         suitable switch statments.
1955         (CASE_USE_BIT_TESTS): New target macro to disable the above.
1956         * Makefile.in (stmt.o): Add dependency on optab.h.
1957         * doc/tm.texi (CASE_USE_BIT_TESTS): Document new target macro.
1958
1959 2003-01-23  Andreas Schwab  <schwab@suse.de>
1960
1961         * config/ia64/crtend.asm [HAVE_INITFINI_ARRAY]: Make
1962         __do_global_ctors_aux hidden global and don't put it in
1963         .init_array.
1964         * config/ia64/crtbegin.asm [HAVE_INITFINI_ARRAY]: Put it here
1965         instead so that it comes first.
1966
1967 Sat Jan 25 16:11:22 CET 2003  Jan Hubicka  <jh@suse.cz>
1968
1969         * df.c (read_modify_subreg_p):  When osize == UNITS_PER_WORD,
1970         subreg is read/modify.
1971
1972 Sat Jan 25 15:55:08 CET 2003  Jan Hubicka  <jh@suse.cz>
1973
1974         * i386.c (ix86_expand_movstr, ix86_expand_clrstr): Consistently
1975         do libcall for large blocks.
1976         * i386.md (comi patterns): Set type to ssecomi.
1977         (sse2_unpck?pd): Fix mode of vec_select.
1978
1979         * cse.c: Include except.h
1980         (cse_set_around_loop):  Do not create new basic blocks.
1981         * Makefile.in (cse.o): Add dependnecy on except.h
1982
1983 Sat Jan 25 12:05:17 CET 2003  Jan Hubicka  <jh@suse.cz>
1984
1985         * builtins.c (fold_trunc_transparent_mathfn): New function.
1986         (fold_builtin): Use it.
1987         * convert.c (convert_to_real): Re-enable code to convert
1988         math functions; add support for floor familly functions.
1989
1990 2003-01-25  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1991
1992         * Makefile.in (cfgloop.o, cfgloopanal.o, cfgloopmanip.o): Add
1993         dependencies on coretypes.h and $(TM_H).
1994
1995 Sat Jan 25 11:10:03 CET 2003  Jan Hubicka  <jh@suse.cz>
1996
1997         * builtins.c (fold_trunc_transparent_mathfn):  Undo accidental commit.
1998
1999 2002-01-24  Stuart Hastings  <stuart@apple.com>
2000
2001         * config/i386/i386.c (x86_output_mi_thunk): Add Darwin/x86 support.
2002
2003 2003-01-25  Michael Hayes  <m.hayes@elec.canterbury.ac.nz>
2004
2005         * config/c4x/c4x.md (UNSPEC_BU): New constants.
2006         (UNSPEC_RPTS, UNSPEC_LSH, UNSPEC_CMPHI, UNSPEC_RCPF): Likewise.
2007         (UNSPEC_RND, UNSPEC_RPTB_FILL, UNSPEC_LOADHF_INT): Likewise.
2008         (UNSPEC_STOREHF_INT, UNSPEC_RSQRF, UNSPEC_LOADQF_INT): Likewise.
2009         (UNSPEC_STOREQF_INT, UNSPEC_LDIV, UNSPEC_PUSH_ST):  Likewise.
2010         (UNSPEC_POP_ST, UNSPEC_PUSH_DP, UNSPEC_POP_DP):  Likewise.
2011         (UNSPEC_POPQI, UNSPEC_POPQF, UNSPEC_ANDN_ST):  Likewise.
2012         (UNSPEC_RPTB_INIT, UNSPEC_TOIEEE, UNSPEC_FRIEEE):  Likewise.
2013
2014 Fri Jan 24 23:44:12 CET 2003  Jan Hubicka  <jh@suse.cz>
2015
2016         * emit-rtl.c (reg_attrs_htab): New static variable.
2017         (reg_attrs_htab_hash, reg_attrs_htab_eq, get_reg_attrs): New static
2018         functions.
2019         (reg_rtx): Do not maintain regno_decl.
2020         (gen_rtx_REG_offset, set_reg_attrs_from_mem, set_delc_rtx,
2021         set_mem_attrs_from_reg): New global function.
2022         (init_emit): Do not initialize regno_decl.
2023         (init_emit_once): initialize reg_attrs_htab.
2024         * final.c (alter_subreg): Do not replace REG by SUBREG.
2025         (gen_mem_expr_from_op): Improve output.
2026         (output_asm_operands): Likewise.
2027         * function.c (assign_params): Do not set REGNO_DECL.
2028         * function.h (struct function): Kill regno_decl.
2029         (REGNO_DECL): Kill.
2030         * gengtype.c (adjust_field_rtx_def): Handle new field of reg.
2031         * print_rtl.c (print_rtx): Output REG information.
2032         * regclass.c (reg_scan_mark_refs): Update attrs.
2033         * reload1.c (alter_reg): Likewise.
2034         * simplify_rtx.c (simplify_subreg): Likewise.
2035         * stmt.c (expand_decl): Likewise.
2036         * rtl.def (REG): Add new field.
2037         * rtl.h (struct reg_attrs): New.
2038         (rtunion_def): At rtreg.
2039         (X0MEMATTR): Add checking.
2040         (X0REGATTR, REG_ATTRS, REG_EXPR, REG_OFFSET): New macro.
2041         (set_reg_attrs_from_mem, set_mem_attrs_from_reg, gen_rtx_REG_offset):
2042         Declare.
2043         * tree.h (SET_DECL_RTL): Call set_decl_rtl.
2044
2045 2003-01-24  Bob Wilson  <bob.wilson@acm.org>
2046
2047         * config/xtensa/xtensa.c: Remove unused include of machmode.h.
2048         (xtensa_emit_call, print_operand): Fix printf format strings
2049         to avoid compile warnings.
2050         (xtensa_function_prologue, xtensa_function_epilogue): Change type
2051         of "size" argument to HOST_WIDE_INT to fix compile warnings.
2052         * config/xtensa/xtensa-protos.h
2053         (xtensa_function_prologue, xtensa_function_epilogue): Ditto.
2054
2055 Fri Jan 24 23:03:32 CET 2003  Jan Hubicka  <jh@suse.cz>
2056
2057         * builtins.c (DEF_BUILTIN): Accept 10 arguments.
2058         (implicit_built_in_decls): New global array.
2059         (mathfn_built_in): New global function.
2060         (fold_trunc_transparent_mathfn): New static function
2061         (expand_builtin_strstr, expand_bultin_strchr,
2062         expand_builtin_strpbrk, expand_builtin_strcpy,
2063         expand_builtin_strncpy, expand_bultin_strcmp,
2064         expand_bultin_strncat, expand_builtin_fputs): Use
2065         implicint_built_in_decls.
2066         (fold_builtin): Fold floor/trunc/round/ceil/nearbyint.
2067         * builtins.def: Fix comments.
2068         (DEF_GCC_BUILTIN, DEF_FALLBACK_BUILTIN, DEF_EXT_FALLBACK_BUILTIN,
2069         DEF_LIB_BUILTIN, DEF_LIB_ALWAYS_BUILTIN, DEF_EXT_LIB_BUILTIN,
2070         DEF_C99_BULTIN, DEF_FRONT_END_LIB_BUILTIN,
2071         DEF_EXT_FRONT_END_LIB_BUILTIN): Pass implicit as needed.
2072         (DEF_C99_C90RES_BULTIN): New.
2073         (*f, *l builtins): Update.
2074         * c-common.c (DEF_BUILTIN): Initialize implicit array.
2075         (c_expand_builtin_printf, c_expand_builtin_fprintf): Update.
2076         * convert.c (strip_float_extensions): New global function.
2077         * tree.h (DEF_BUILTIN): Accept 10 arguments.
2078         (implicit_built_in_decls, mathfn_built_in, strip_float_extension):
2079         Declare.
2080         * java/builtins.c (define_builtin): Handle implicit.
2081         (DEF_BUILTIN): Update.
2082         * tm.texi (TARGET_C99_FUNCTIONS): Document.
2083         * defaults.h (TARGET_C99_FUNCTIONS): Default to 0.
2084         * config/linux.h (TARGET_C99_FUNCTIONS): Default to 1
2085         when using glibc2.
2086
2087 2003-01-24  Bob Wilson  <bob.wilson@acm.org>
2088
2089         * config.gcc (xtensa-*-elf*): Removed assignments to with_newlib,
2090         extra_parts, and fixincludes.  Add xtensa/t-elf tmake_file.
2091         (xtensa-*-linux*): Add xtensa/t-linux tmake_file.
2092         * config/xtensa/crti.asm: New file.
2093         * config/xtensa/crtn.asm: New file.
2094         * config/xtensa/t-elf: New file.
2095         * config/xtensa/t-linux: New file.
2096         * config/xtensa/t-xtensa: Add rules for crti.o and crtn.o.
2097         Move various CFLAGS settings to new t-elf file.
2098
2099 2003-01-24  Richard Henderson  <rth@redhat.com>
2100
2101         PR optimization/4382
2102         * tree-inline.c (find_builtin_longjmp_call_1): New.
2103         (find_builtin_longjmp_call): New.
2104         (inlinable_function_p): Use it.
2105
2106 2003-01-24  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
2107
2108         * config/i386/i386-protos.h (function_arg_pass_by_reference): Declare.
2109         * config/i386/i386.h (FUNCTION_ARG_PASS_BY_REFERENCE): Use it.
2110         * config/i386/i386.c (function_arg_pass_by_reference): New.
2111         (ix86_va_arg): Support arguments passed by reference.
2112
2113 2003-01-24  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
2114
2115         * cfgloopanal.c: New file.
2116         * cfgloopmanip.c: New file.
2117         * Makefile.in (cfgloopanal.o, cfgloopmanip.o): New.
2118         (toplev.o, loop.o, doloop.o, unroll.o, cfgloop.o, predict.o,
2119         cfglayout.o): Add dependency on cfgloop.h.
2120         (cfgloop.o): Add flags.h dependency.
2121         * basic-block.h (BB_IRREDUCIBLE_LOOP, BB_SUPERBLOCK): New flags.
2122         (VLS_EXPECT_PREHEADERS, VLS_EXPECT_SIMPLE_LATCHES): Removed.
2123         (struct loop, struct loops, flow_loops_find, flow_loops_update,
2124         flow_loops_free, flow_loops_dump, flow_loop_dump,
2125         flow_loop_scan, flow_loop_tree_node_add, flow_loop_tree_node_remove,
2126         LOOP_TREE,,LOOP_PRE_HEADER, LOOP_ENTRY_EDGES, LOOP_EXIT_EDGES,
2127         LOOP_ALL, flow_loop_outside_edge_p, flow_loop_nested_p,
2128         flow_bb_inside_loop_p, get_loop_body, loop_preheader_edge,
2129         loop_latch_edge, add_bb_to_loop, remove_bb_from_loops,
2130         find_common_loop, verify_loop_structure): Declarations moved to ...
2131         * cfgloop.h: New file.
2132         * bb-reorder.c (reorder_basic_blocks): Modified.
2133         * cfglayout.c: Include cfgloop.h.
2134         (cleanup_unconditional_jumps, cfg_layout_redirect_edge,
2135         cfg_layout_duplicate_bb, cfg_layout_initialize): Update loop structure.
2136         (break_superblocks): New static function.
2137         (cfg_layout_finalize): Use it.
2138         (cfg_layout_split_block): New function.
2139         * cfglayout.h (struct reorder_block_def): Add copy and duplicated
2140         fields.
2141         (cfg_layout_initialize, cfg_layout_redirect_edge): Declaration
2142         changed.
2143         (cfg_layout_split_block): Declare.
2144         * cfgloop.c: Include cfgloop.h and flags.h.
2145         (flow_loop_dump, flow_loops_free, flow_loop_exit_edges_find,
2146         get_loop_body): Avoid signed versus unsigned comparison warnings.
2147         (make_forwarder_block, flow_loops_find, loop_preheader_edge,
2148         loop_latch_edge): Modified.
2149         (verify_loop_structure): Modified to use flags stored in loop structure;
2150         check irreducible loops.
2151         (cancel_loop, cancel_loop_tree): New functions.
2152         (estimate_probability): Use loop analysis code for predictions.
2153         (estimate_loops_at_level):  Avoid signed versus unsigned comparison
2154         warnings.
2155         * doloop.c: Include cfgloop.h.
2156         * loop.c: Include cfgloop.h.
2157         * predict.c: Include cfgloop.h.
2158         * toplev.c: Include cfgloop.h.
2159         * unroll.c: Include cfgloop.h.
2160         * tracer.c (tracer): Modified.
2161
2162 2003-01-24  Kazu Hirata  <kazu@cs.umass.edu>
2163
2164         * config/h8300/h8300.c (get_shift_alg): Fix a typo.
2165
2166 2003-01-24  Ulrich Weigand  <uweigand@de.ibm.com>
2167
2168         * configure.in (HAVE_AS_TLS): Add s390-*-* and s390x-*-* cases.
2169         * configure: Regenerate.
2170
2171         * config/s390/s390-protos.h (tls_symbolic_operand): Add prototype.
2172         (tls_symbolic_reference_mentioned_p): Add prototype.
2173         (s390_tls_get_offset): Add prototype.
2174         (emit_pic_move): Remove prototype, replace by ...
2175         (emit_symbolic_move): .. this new prototype.
2176
2177         * config/s390/s390.c (TARGET_HAVE_TLS): Conditionally define.
2178         (tls_model_chars): New global variable.
2179         (s390_encode_section_info): Encode TLS model.
2180         Use targetm.binds_local_p to check for local symbols.
2181         (s390_strip_name_encoding): New function.
2182         (TARGET_STRIP_NAME_ENCODING): Define.
2183
2184         (get_thread_pointer): New function.
2185         (legitimize_tls_address): New function.
2186         (legitimize_address): Call it.
2187         (emit_pic_move): Remove, replace by ...
2188         (emit_symbolic_move): ... this new function.
2189
2190         (larl_operand): Handle TLS operands.
2191         (legitimate_constant_p): Likewise.
2192         (s390_decompose_address): Likewise.
2193         (s390_cannot_force_const_mem): New function.
2194         (TARGET_CANNOT_FORCE_CONST_MEM): Define.
2195
2196         (s390_output_symbolic_const): Handle TLS unspecs.
2197         (print_operand): New code 'J'.
2198         (machine_function): Add struct member 'some_ld_name'.
2199         (get_some_local_dynamic_name, get_some_local_dynamic_name_1): New.
2200
2201         (enum s390_builtin): New type.
2202         (code_for_builtin_64, code_for_builtin_31): New global variables.
2203         (s390_init_builtins, s390_expand_builtin): New functions.
2204         (TARGET_INIT_BUILTINS, TARGET_EXPAND_BUILTIN): Define.
2205
2206         * config/s390/s390.h (TLS_SYMBOLIC_CONST): New macro.
2207         (ASM_OUTPUT_LABELREF): Define.
2208         (ASM_OUTPUT_SPECIAL_POOL_ENTRY): Handle TLS constants.
2209
2210         * config/s390/s390.md: Define TLS UNSPEC constants.
2211         ("movdi", "movsi"): Handle TLS operands.
2212         ("get_tp_64", "get_tp_31", "set_tp_64", "set_tp_31"): New insns.
2213         ("*tls_load_64", "*tls_load_31"): New insns.
2214         ("call_value_tls", "call_value_tls_exp"): New expanders.
2215         ("brasl_tls", "bras_tls", "basr_tls_64", "basr_tls_31",
2216         "bas_tls_64", "bas_tls_31"): New insns.
2217
2218 2003-01-24  Nathan Sidwell  <nathan@codesourcery.com>
2219
2220         * config/rs6000/rs6000.c (rs6000_parse_abi_options): Make sure
2221         spe ABI is configured, if requested.
2222
2223 2003-01-24  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
2224
2225         * doc/passes.texi: Fix typo.
2226
2227 2003-01-24  Andreas Schwab  <schwab@suse.de>
2228
2229         * stor-layout.c (excess_unit_span): Only define if used.
2230
2231 2003-01-24  Jerry Quinn  <jlquinn@optonline.net>
2232
2233         * gcc/doc/invoke.texi (Optimization Options): List -O levels
2234         for each optimization flag.
2235
2236 2003-01-24  Kazu Hirata  <kazu@cs.umass.edu>
2237
2238         * config/h8300/h8300.md (*andsi3_ashift_n_lower): New.
2239
2240 2003-01-24  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
2241
2242         * doc/bugreport.texi: Use @command instead of @code for commands.
2243         * doc/collect2.texi: Likewise.
2244         * doc/headerdirs.texi: Likewise.
2245         * doc/invoke.texi: Likewise.
2246         * doc/standards.texi: Likewise.
2247         * doc/tm.texi: Likewise.
2248         * doc/trouble.texi: Likewise.
2249
2250 2003-01-24  Nick Clifton  <nickc@redhat.com>
2251
2252         * config/arm/arm.c (use_return_insn): Do not use a single return
2253         instruction for interrupt handelrs which have to create a stack
2254         frame.
2255         (arm_expand_prologue): Do not pre-bias the return address of
2256         interrupt handlers which create a stack frame.
2257
2258 2003-01-24  Nick Clifton  <nickc@redhat.com>
2259
2260         * Add sh2e support:
2261
2262         2002-08-12  Alexandre Oliva  <aoliva@redhat.com>
2263
2264                 * config/sh/sh.c (output_branch) [TARGET_SH2E]: Handle
2265                 med_cbranches.  Fix logic in short_cbranches.
2266
2267         2002-04-03  Alexandre Oliva  <aoliva@redhat.com>
2268
2269                 * config/sh/sh.md (delay for cbranch): Don't annul delay
2270                 slots on SH2e.
2271                 * config/sh/sh.c (sh_insn_length_adjustment): Add 2 for
2272                 cbranch with unfilled delay slot on SH2e.
2273                 (output_branch): Fill with a nop the delay slot of a
2274                 branch that required a delay slot but didn't get one.
2275
2276         2002-04-02  Alexandre Oliva  <aoliva@redhat.com>
2277
2278                 * doc/invoke.texi (SH options): Document -m2e.
2279                 * config/sh/crt1.asm: Add __SH2E__ Next to __SH3E__.
2280                 * config/sh/lib1funcs.asm: Likewise.
2281                 * config/sh/sh.c: Replace all uses of TARGET_SH3E with SH2E.
2282                 * config/sh/sh.h (CPP_SPEC): Define __SH2E__ for -m2e, and
2283                 not __sh1__.
2284                 (CONDITIONAL_REGISTER_USAGE): Don't disable FP regs from
2285                 SH2E up.
2286                 (SH3E_BIT): Renamed to...
2287                 (SH_E_BIT): ... this.  Replace all uses.
2288                 (TARGET_SH2E): Define from SH_E_BIT and TARGET_SH2.
2289                 Replace all uses of TARGET_SH3E with TARGET_SH2E.
2290                 (TARGET_SWITCHES): Added 2e.
2291                 (OVERRIDE_OPTIONS): Set sh_cpu for SH2E.
2292                 (processor_type): Added PROCESSOR_SH2E.
2293                 * config/sh/sh.md: Replace all uses of TARGET_SH3E with
2294                 TARGET_SH2E, except in sqrtsf2_i.
2295                 (attribute cpu): Added sh2e.
2296                 * config/sh/t-sh (MULTILIB_OPTIONS): Replace m3e with m2e.
2297                 (MULTILIB_MATCHES): Use m2e multilib for m3e.
2298                 * config.gcc: Add sh2e target support.
2299
2300 2003-01-24  Phil Edwards  <pme@gcc.gnu.org>
2301
2302         Rename -W to -Wextra.
2303         * c-decl.c:  Update comments.
2304         * c-typeck.c:  Likewise.
2305         * flags.h:  Likewise.
2306         * function.c:  Likewise.
2307         * stmt.c:  Likewise.
2308         * toplev.c:  Update comments.
2309         (W_options):  Add 'extra'.
2310         (display_help):  Remove '-W'.
2311         (decode_W_option):  Special warn_uninitialized treatment in the case
2312         of -Wextra.
2313         * doc/invoke.texi:  Update with new entries.
2314
2315 2003-01-23  Richard Henderson  <rth@redhat.com>
2316
2317         * ifcvt.c (noce_process_if_block): Re-add check vs X being changed
2318         in no-else-block case.  Add commentary.
2319
2320 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2321
2322         * configure.in: Revert last change.
2323
2324 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2325
2326         * configure.in: Don't include ansidecl.h in tconfig.h.
2327         * gcov-io.h (PARAMS, ATTRIBUTE_UNUSED: Define if IN_LIBGCC2.
2328         * unwind-dw2-fde.h (last_fde): Use __attribute__, not
2329         ATTRIBUTE_UNUSED.
2330
2331         * configure: Regenerate.
2332
2333 2003-01-23  Franz Sirl  <Franz.Sirl-kernel@lauterbach.com>
2334
2335         PR java/6748
2336         * config/rs6000/linux.h (MD_FALLBACK_FRAME_STATE_FOR): Don't destroy
2337         regs->nip. Fix rt_sigreturn frame layout. Add support for newer
2338         kernels.
2339
2340 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2341
2342         * cpplex.c (cpp_interpret_charconst): Squelch warning with cast.
2343
2344 2003-01-23  Ulrich Weigand  <uweigand@de.ibm.com>
2345
2346         * genattrtab.c (write_attr_get): Mark 'insn' paramter
2347         as ATTRIBUTE_UNUSED.
2348
2349 2003-01-23  Richard Earnshaw  <rearnsha@arm.com>
2350
2351         * arm.c (thumb_base_register_rtx_p): New function.
2352         (thumb_index_register_rtx_p): New function.
2353         (thumb_legitimate_address_p): New function.
2354         (thumb_legitimate_offset_p): New function.
2355         * arm.h (REG_STRICT_P): Define according to setting of REG_OK_STRICT.
2356         (ARM_GO_IF_LEGITIMATE_ADDRESS): Use REG_STRICT_P to avoid duplicate
2357         definitions.
2358         (THUMB_GO_IF_LEGITIMATE_ADDRESS): Use thumb_legitimate_address_p.
2359         (THUMB_LEGITIMATE_OFFSET): Delte.
2360         (THUMB_LEGITIMIZE_RELOAD_ADDRESS): Use thumb_legitimate_offset.
2361         * arm-protos.h (thumb_legitimate_address_p): Add prototype.
2362         (thumb_legitimate_offset_p): Likewise.
2363
2364 2003-01-23  Andreas Schwab  <schwab@suse.de>
2365
2366         * unwind.h (_Unwind_GetTextRelBase): Mark parameter as unused.
2367
2368 2003-01-23  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2369
2370         * fixinc/Makefile.in (FL_LIST): Revert last change.
2371
2372 2003-01-23  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
2373
2374         PR other/7341
2375         * invoke.texi (ftest-coverage): Fix broken cross-reference.
2376         Change @code to @command for gcov command.
2377
2378         * gcc.texi: Adjust title of gcov section.
2379         Adjust copyright.
2380         * gcov.texi: Likewise.
2381
2382 2003-01-22  Roger Sayle  <roger@eyesopen.com>
2383
2384         PR optimization/8423
2385         * cse.c (fold_rtx): Only eliminate a CONSTANT_P_RTX to 1 when
2386         its argument is constant, or 0 if !flag_gcse.
2387         * simplify-rtx.c (simplify_rtx): Convert CONSTANT_P_RTX to 1
2388         if it's argument is constant.
2389         * gcse.c (want_to_gcse_p): Ignore CONSTANT_P_RTX nodes.
2390         (hash_scan_set): Don't record CONSTANT_P_RTX expressions.
2391         (do_local_cprop): Don't propagate CONSTANT_P_RTX constants.
2392         * builtins.c (purge_builtin_constant_p): New function to force
2393         instantiation of any remaining CONSTANT_P_RTX nodes.
2394         * rtl.h (purge_builtin_constant_p): Prototype here.
2395         * toplev.c (rest_of_compilation): Invoke purge_builtin_constant_p
2396         pass after GCSE and before loop.
2397         (flag_gcse): No longer static.
2398         * flags.h (flag_gcse): Prototype here.
2399
2400 2003-01-22  Ulrich Weigand  <uweigand@de.ibm.com>
2401
2402         * config/s390/s390.h (HARD_REGNO_MODE_OK): Fix warning regression
2403         introduced by last change.
2404
2405 2003-01-22  Andreas Schwab  <schwab@suse.de>
2406
2407         * ra-rewrite.c (rewrite_program2): Initialize bb to avoid warning.
2408
2409 2003-01-22  Kazu Hirata  <kazu@cs.umass.edu>
2410
2411         * config/h8300/h8300.c (h8300_shift_needs_scratch_p): Don't
2412         request a scratch reg on H8S when the shift count is 8.
2413
2414 2003-01-22  Ulrich Weigand  <uweigand@de.ibm.com>
2415
2416         * config/s390/s390-protos.h (preferred_la_operand_p):
2417         Remove second parameter.
2418         * config/s390/s390.c (preferred_la_operand_p): Likewise.
2419         * config/s390/s390.h (FRAME_REGNO_P, FRAME_REG_P): New macros.
2420         (HARD_REGNO_MODE_OK): Use FRAME_REGNO_P.
2421         * config/s390/s390.md ("*la_cc_64", "*la_cc_31", splitters): Remove.
2422         Add peepholes to transform ADD to LOAD ADDRESS.
2423
2424 2003-01-22  Richard Earnshaw  <rearnsha@arm.com>
2425
2426         * arm.c (arm_address_register_rtx_p): New function.
2427         (arm_legitimate_address_p): New function.
2428         (arm_legitimate_index_p): New function.
2429         (legitimize_pic_address): Use arm_legitimate_index_p.
2430         * arm-protos.h (arm_legtimate_address_p): Add prototype.
2431         * arm.h (ARM_GO_IF_LEGITIMATE_INDEX): Delete.
2432         (ARM_GO_IF_LEGITIMATE_ADDRESS): Call arm_legitimate_address_p.
2433
2434 2003-01-22  Hartmut Penner  <hpenner@de.ibm.com>
2435
2436         * config/s390/s390.md (floatdfdi2): Insn has type 'itof'.
2437         * config/s390/2064.md (define_bypass): Correct 'Load' and
2438         'Load-address' bypass values.
2439
2440 2003-01-22  Andreas Schwab  <schwab@suse.de>
2441
2442         * config/ia64/t-ia64 (insn-attrtab.o-warn): Define as -Wno-error.
2443
2444 2003-01-21  Zack Weinberg  <zack@codesourcery.com>
2445
2446         * genautomata.c (output_internal_insn_latency_func,
2447         output_print_reservation_func): Short circuit when there is no
2448         automaton to generate code for.
2449
2450 2003-01-21  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2451
2452         * Makefile.in (ssa-ccp.o): Depend on coretypes.h $(TM_H).
2453         (df.o): Delete duplicate dependency on coretypes.h $(TM_H).
2454
2455 2003-01-21  Geoffrey Keating  <geoffk@apple.com>
2456
2457         * config/rs6000/rs6000.md: Remove warning.
2458         (builtin_setjmp_receiver): Likewise.
2459         * config/darwin.c (update_stubs): Slightly improve terrible hack
2460         with identifiers.  Add comment pointing out problems with it.
2461         (update_non_lazy_ptrs): Likewise.
2462
2463 2003-01-21  Richard Henderson  <rth@redhat.com>
2464
2465         * dwarf2out.c (lookup_filename): Fix printf format warning.
2466         * system.h (fread_unlocked, fwrite_unlocked): Undef.
2467
2468         * fixinc/Makefile.in (FL_LIST): Add $($@-warn) hook.
2469         (fixincl.o-warn, gnu-regex.o-warn): New.
2470         * fixinc/fixfixes.c (FIX_PROC_HEAD): Mark parameters unused.
2471         * fixinc/fixtests.c (TEST_FOR_FIX_PROC_HEAD): Likewise.
2472         * fixinc/fixincl.c (process): Fix printf format warning.
2473
2474 2003-01-21  Ulrich Weigand  <uweigand@de.ibm.com>
2475
2476         * dwarf2out (output_file_names): Don't crash if called
2477         with empty file_table.
2478
2479 2003-01-21  Zack Weinberg  <zack@codesourcery.com>
2480
2481         * genautomata.c (output_internal_insn_latency_func): Add
2482         missing break statement to generated code.
2483
2484 2003-01-21  Roger Sayle  <roger@eyesopen.com>
2485
2486         * stmt.c (same_case_target_p): New function to determine whether
2487         two case labels branch to the same target.  Split out from...
2488         (group_case_nodes): ... here.  Use same_case_target_p instead.
2489         (strip_default_case_nodes): Remove explicit case nodes
2490         that branch to the default destination.
2491         (expand_end_case_type): Call strip_default_case_nodes after
2492         group_case_nodes, to simplify the case-list before we count it.
2493         Only generate table_label RTX when actually needed.  Try to share
2494         thiscase->exit_label and thiscase->data.case_stmt.default_label
2495         when a switch has no explicit default case.  Simplify test for
2496         constant index.
2497
2498 2003-01-21  Kazu Hirata  <kazu@cs.umass.edu>
2499
2500         * config/h8300/h8300.md (*negsf2_h8300): Use \\t instead of
2501         \t.
2502         (*negsf2_h8300hs): Likewise.
2503         (*addsi3_lshiftrt_16_zexthi): Likewise.
2504         (*iorhi3_lshiftrt_8): Likewise.
2505
2506 2003-01-21  Ulrich Weigand  <uweigand@de.ibm.com>
2507
2508         * dwarf2out.c (fde_table_in_use): Mark GTY.
2509         (dwarf2out_cfi_label_num): New variable, marked GTY.
2510         (dwarf2out_cfi_label): Use it instead of static label_num.
2511         * emit-rtl.c (label_num): Mark GTY.
2512
2513 2003-01-21  Kazu Hirata  <kazu@cs.umass.edu>
2514
2515         * config/h8300/h8300.c (output_plussi): Support H8/300.
2516         (compute_plussi_length): Likewise.
2517         (compute_plussi_cc): Likewise.
2518         * config/h8300/h8300.md (addsi_h8300): Use output_plussi to
2519         output assembly instructions.
2520
2521 2003-01-21  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2522
2523         * calls.c (fix_unsafe_tree): Prototype.
2524
2525         * Makefile.in (GCC_WARN_CFLAGS): Add $(WERROR) $($@-warn)
2526         (gtype-desc.o-warn, c-decl.o-warn, varasm.o-warn, gcc.o-warn,
2527         insn-conditions.o-warn, out_object_file, gengtype-yacc.o-warn,
2528         c-parse.o-warn): Add -Wno-error.
2529         (STAGE2_FLAGS_TO_PASS): Add WERROR="@WERROR@".
2530
2531         * configure.in (--enable-werror): Add new flag.
2532         * doc/install.texi (--enable-werror): Document.
2533         * configure: Regenerate.
2534
2535         * objc/Make-lang.in (objc/objc-parse.o-warn): Add -Wno-error.
2536
2537 2003-01-21  Andreas Schwab  <schwab@suse.de>
2538
2539         * genautomata.c (output_internal_insn_latency_func): Fix missing
2540         close paren in output.
2541
2542 2003-01-21  Zack Weinberg  <zack@codesourcery.com>
2543
2544         * genautomata.c: Space savings in generated code:
2545         (output_dfa_insn_code_func): Split out the table-enlargement
2546         path to an out-of-line static function, dfa_insn_code_enlarge.
2547         (output_internal_insn_latency_func): Use a lookup table for the
2548         default latencies.
2549         (output_print_reservation_func): Use a lookup table for the
2550         strings.
2551
2552 2003-01-21  Christian Ehrhardt  <ehrhardt@mathematik.uni-ulm.de>
2553
2554         PR opt/7507
2555         * calls.c (fix_unsafe_tree): Split out from ...
2556         (expand_call): ... here.  Use it on the function address too.
2557
2558 2003-01-20  Richard Henderson  <rth@redhat.com>
2559
2560         * expr.h (default_must_pass_in_stack): Move decl outside ifdef.
2561
2562 2003-01-20  Richard Henderson  <rth@redhat.com>
2563
2564         PR opt/7154
2565         * stmt.c (expand_asm_operands): Validize memory operands.
2566
2567 2003-01-20  Richard Henderson  <rth@redhat.com>
2568
2569         PR opt/8848
2570         * ifcvt.c (noce_process_if_block): Correct arguments to
2571         modified_between_p for no-else-block case.
2572
2573 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
2574
2575         * config/h8300/h8300.c (const_costs): Remove a warning.
2576         (output_plussi): Likewise.
2577         (compute_plussi_length): Likewise.
2578         (compute_plussi_cc): Likewise.
2579
2580 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
2581
2582         * config/h8300/h8300.md (addsi_h8300): Remove the last
2583         alternative.
2584
2585 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
2586
2587         * config/h8300/h8300.c (get_shift_alg): Remove redundant code.
2588
2589 2003-01-20  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2590
2591         * system.h (__NO_STRING_INLINES): Define.
2592
2593 2003-01-20  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
2594
2595         * ifcvt.c (noce_emit_store_flag): Don't emit store flag if mode of x
2596         is not a scalar int mode.
2597
2598 2003-01-20  Roger Sayle  <roger@eyesopen.com>
2599
2600         * cse.c (cse_insn): Avoid RTL sharing when updating the RETVAL
2601         insn's notes following a substitution inside a libcall.
2602
2603 2003-01-20  Zack Weinberg  <zack@codesourcery.com>
2604
2605         * configure.in: Check for system-provided 'uchar' type.
2606         * configure, config.in: Regenerate.
2607         * cpphash.h: Only typedef 'uchar' if the system doesn't.
2608
2609 2003-01-20  Richard Henderson  <rth@redhat.com>
2610
2611         * expr.h (MUST_PASS_IN_STACK): Move implementation...
2612         * calls.c (default_must_pass_in_stack): ... here.
2613
2614 2003-01-20  Vladimir Makarov  <vmakarov@redhat.com>
2615
2616         * genattrtab.h (INSN_ALTS_FUNC_NAME): Move it from genautomata.c.
2617
2618         * genautomata.c (INSN_ALTS_FUNC_NAME): Move it into genattrtab.h.
2619
2620         * genattr.c (main): Output default definition of AUTOMATON_ALTS.
2621         Wrap up definition of `insn_alts'.
2622
2623         * genattrtab.c (main): Wrap up `insn_alts'.
2624
2625 2003-01-20  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2626
2627         * collect2.c (ldgetname): Check HAVE_DECL_LDGETNAME before
2628         prototyping.
2629         * configure.in: Check for <ldfcn.h> and ldgetname() prototype.
2630
2631         * config.in, configure: Regenerate.
2632
2633 2003-01-20  Nick Clifton  <nickc@redhat.com>
2634
2635         * config/arm/arm.md (sibcall_epilogue): Add an
2636         UNSPEC_PROLOGUE_USE to prevent the link register from being
2637         considered dead.
2638
2639 Mon Jan 20 14:36:23 CET 2003  Jan Hubicka  <jh@suse.cz>
2640
2641         * i386.md (SSE cmov splitter):  Handle memory operand in operand 5.
2642
2643 2003-01-20  Andreas Schwab  <schwab@suse.de>
2644
2645         * system.h: Don't declare strsignal if the decl test hasn't been
2646         run yet.
2647
2648 2003-01-20  Kazu Hirata  <kazu@cs.umass.edu>
2649
2650         * config/h8300/h8300.c (notice_update_cc): Don't assume that
2651         recog_data.operands[0] is always associated with cc0.
2652
2653 2003-01-19  David Edelsohn  <edelsohn@gnu.org>
2654
2655         * collect2.c (ldgetname): Expand declaration to prototype.
2656         * read-rtl.c (atoll): Add prototype.
2657         * system.h (strsignal): Also declare if no declaration found.
2658
2659 2003-01-19  Alexandre Oliva  <aoliva@redhat.com>
2660
2661         * config.gcc (mips64*-*-linux*): Added.
2662         * config/mips/linux64.h, config/mips/t-linux64: New file.
2663         * config/mips/iris6.h (MIPS_TFMODE_FORMAT): Define.
2664         * config/mips/mips.c (override_options): Use it.
2665         * config/mips/mips.h (TARGET_SWITCHES): Added...
2666         (SUBTARGET_TARGET_SWITCHES): New, empty by default.
2667         * Makefile.in (SPECS): New.
2668         (STAGESTUFF, specs, mostlyclean, install-common): Use it.
2669         * gcc.c (process_command): Move self-spec processing past spec
2670         file loading.
2671         * doc/tm.texi (DRIVER_SELF_SPECS): Document the change.
2672         * doc/fragments.texi (MULTILIB_EXTRA_OPTS): Document need for
2673         CRTSTUFF_T_CFLAGS.
2674         (SPECS): Document.
2675         * doc/invoke.texi (-mabi-fake-default): Document.
2676
2677 2003-01-19  Stephane Carrez  <stcarrez@nerim.fr>
2678
2679         * config/m68hc11/m68hc11.c (stack_push_word, stack_pop_word,
2680         z_reg, z_reg_qi): Declare static and GTY().
2681         (da_reg): Remove.
2682         (create_regs_rtx): Don't create da_reg.
2683         ("gt-m68hc11.h"): Include for GTY roots.
2684         * config/m68hc11/m68hc11.h (ix_reg, iy_reg, d_reg): Declare extern
2685         and GTY() here.
2686         (m68hc11_compare_op0, m68hc11_compare_op1): Likewise.
2687         (m68hc11_soft_tmp_reg): Likewise.
2688         * config/m68hc11/m68hc11-protos.h: Remove above declarations.
2689
2690 2003-01-18  Kazu Hirata  <kazu@cs.umass.edu>
2691
2692         * basic-block.h: Fix comment formatting.
2693         * calls.c: Likewise.
2694         * combine.c: Likewise.
2695         * convert.c: Likewise.
2696         * gcov.c: Likewise.
2697         * haifa-sched.c: Likewise.
2698         * libgcc2.c: Likewise.
2699         * loop.c: Likewise.
2700         * profile.c: Likewise.
2701         * system.h: Likewise.
2702
2703 2003-01-18  Roger Sayle  <roger@eyesopen.com>
2704
2705         * config/pa/pa.md (muldi3): Avoid invalid sharing of SUBREG RTXs.
2706
2707 2003-01-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2708
2709         * ra-build.c (undef_to_size_word): Avoid `switch' warning.
2710
2711 2003-01-17  Dale Johannesen  <dalej@apple.com>
2712
2713         * config/rs6000/rs6000.md (*floatsidf2_internal):  Add earlyclobbers.
2714           (*floatunssidf2_internal):  Ditto.
2715
2716 2003-01-17  Kazu Hirata  <kazu@cs.umass.edu>
2717
2718         * alias.c: Fix comment typos.
2719         * basic-block.h: Likewise.
2720         * c-common.c: Likewise.
2721         * c-common.h: Likewise.
2722         * c-decl.c: Likewise.
2723         * c-opts.c: Likewise.
2724         * c-pragma.c: Likewise.
2725         * c-pretty-print.h: Likewise.
2726         * cfg.c: Likewise.
2727         * cfganal.c: Likewise.
2728         * cfgbuild.c: Likewise.
2729         * cfgcleanup.c: Likewise.
2730         * cfglayout.c: Likewise.
2731         * cfgrtl.c: Likewise.
2732         * convert.c: Likewise.
2733         * cpphash.h: Likewise.
2734         * cpplex.c: Likewise.
2735         * cpplib.h: Likewise.
2736         * df.h: Likewise.
2737         * diagnostic.c: Likewise.
2738         * diagnostic.h: Likewise.
2739         * dwarf2.h: Likewise.
2740
2741 2003-01-17  Stan Shebs  <shebs@apple.com>
2742
2743         * config/darwin-protos.h: Forward-declare struct cpp_reader.
2744
2745 2003-01-17  Douglas B Rupp  <rupp@gnat.com>
2746
2747         * config/alpha/alpha.c (alpha_need_linkage): Fix obvious
2748         mistake in last checkin.
2749
2750 2003-01-17  Kazu Hirata  <kazu@cs.umass.edu>
2751
2752         * et-forest.c: Fix comment typos.
2753         * et-forest.h: Likewise.
2754         * except.c: Likewise.
2755         * expr.c: Likewise.
2756         * flags.h: Likewise.
2757         * flow.c: Likewise.
2758         * gcc.c: Likewise.
2759         * gcse.c: Likewise.
2760         * genattrtab.c: Likewise.
2761         * genautomata.c: Likewise.
2762         * gengtype.c: Likewise.
2763         * genrecog.c: Likewise.
2764         * global.c: Likewise.
2765         * gthr-rtems.h: Likewise.
2766
2767 2003-01-17  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2768
2769         * i386.c (x86_function_profiler): Fix format specifier.
2770
2771 2003-01-17  Richard Henderson  <rth@redhat.com>
2772
2773         * gengtype.c (walk_type): Allow paramN_is.
2774
2775 2003-01-17  Nick Clifton  <nickc@redhat.com>
2776
2777         * config/i960/t-960bare (i960-c.o): Add missing newline escape.
2778
2779 2003-01-16  Richard Henderson  <rth@redhat.com>
2780
2781         * config/alpha/linux-elf.h (LIB_SPEC): Adjust inter-option spacing.
2782
2783 2003-01-16  Richard Henderson  <rth@redhat.com>
2784
2785         * config/alpha/alpha.c (alpha_sr_alias_set): Mark GTY.
2786         (alpha_next_sequence_number): Likewise.
2787         (alpha_this_literal_sequence_number): Likewise.
2788         (alpha_this_gpdisp_sequence_number): Likewise.
2789         (struct alpha_funcs, alpha_funcs_num): Likewise.
2790         (struct alpha_links): Fix branch merge error.
2791         (alpha_need_linkage, alpha_use_linkage): Use GC for alpha_funcs.
2792
2793 2003-01-17  Alexandre Oliva  <aoliva@redhat.com>
2794
2795         * config/mips/mips.h: Don't use #elif.  Reported by Kaveh
2796         R. Ghazi.
2797
2798 2003-01-16  Kazu Hirata  <kazu@cs.umass.edu>
2799
2800         * ifcvt.c: Fix comment typos.
2801         * lcm.c: Likewise.
2802         * libgcc2.c: Likewise.
2803         * local-alloc.c: Likewise.
2804         * loop.c: Likewise.
2805         * predict.c: Likewise.
2806         * ra-build.c: Likewise.
2807         * ra.c: Likewise.
2808         * ra-colorize.c: Likewise.
2809         * ra.h: Likewise.
2810         * ra-rewrite.c: Likewise.
2811         * regmove.c: Likewise.
2812         * reload.h: Likewise.
2813         * rtlanal.c: Likewise.
2814         * toplev.c: Likewise.
2815         * tree.h: Likewise.
2816         * unwind-dw2-fde-glibc.c: Likewise.
2817         * vmsdbgout.c: Likewise.
2818
2819 2003-01-16  Richard Henderson  <rth@redhat.com>
2820
2821         * dwarf2out.c (struct file_table): Remove.
2822         (FILE_TABLE_INCREMENT): Remove.
2823         (file_table): Make a varray; mark for GC.  Update all users.
2824         (file_table_last_lookup_index): Extract from struct file_table.
2825         (output_file_names): Fix unsigned compare warnings.
2826         (add_name_attribute): Remove inline marker.
2827         (add_comp_dir_attribute): Split out from gen_compile_unit_die.
2828         (lookup_filename): Don't manage size of file_table.
2829         (init_file_table): Allocate file_table with GC.
2830         (dwarf2out_init): Don't record main_input_filename here.
2831         (dwarf2out_finish): Do it here instead.
2832
2833 2003-01-16  Bruce Korb  <bkorb@gnu.org>
2834
2835         * gcc/fixinc/inclhack.def(limits_ifndef): QNX needs a bypass, too.
2836
2837 2003-01-16  Kaz Kojima  <kkojima@gcc.gnu.org>
2838
2839         * config/sh/sh.c (sh_initialize_trampoline): Emit rotrdi3_mextr
2840         instead of rotldi3_mextr.
2841
2842 2003-01-16  Vladimir Makarov  <vmakarov@redhat.com>
2843
2844         * haifa-sched.c (move_insn): Restore moving all schedule group.
2845         (set_priorities): Restore taking SCHED_GROUP_P into account.
2846
2847         * sched-deps.c (add_dependence): Restore processing the last group
2848         insn.
2849         (remove_dependence, group_leader): Restore the functions.
2850         (set_sched_group_p): Restore adding dependencies from previous insn
2851         in the group.
2852         (compute_forward_dependences): Restore usage of group_leader.
2853
2854         * sched-ebb.c (init_ready_list): Restore taking SCHED_GROUP_P into
2855         account.
2856
2857         * sched-rgn.c (init_ready_list): Restore taking SCHED_GROUP_P into
2858         account.
2859         (can_schedule_ready_p): Ditto.
2860         (add_branch_dependences): Restore skipping over the group insns.
2861
2862 2003-01-16  Stephane Carrez  <stcarrez@nerim.fr>
2863
2864         * config/m68hc11/m68hc11.c (m68hc11_check_z_replacement): Fix handling
2865         68HC12 pre/post inc/dec side effects.
2866
2867 2003-01-16  Stephane Carrez  <stcarrez@nerim.fr>
2868
2869         * config/m68hc11/m68hc11.h (MASK_M6812): Define.
2870
2871 Thu Jan 16 21:50:25 2003  J"orn Rennecke <amylaar@onetel.net.uk>
2872
2873         * sh.md (mshflo_w_x): Fix description of operation.
2874
2875 2003-01-16  Zack Weinberg  <zack@codesourcery.com>
2876
2877         * config/rs6000/rs6000.h: Mention Altivec registers in
2878         commentary.  Fix typo.
2879
2880 2003-01-16  David Edelsohn  <edelsohn@gnu.org>
2881
2882         * config/rs6000/rs6000.md (movti_string): Remove clobber.
2883         * config/rs6000/rs6000.c (rs6000_emit_move, TImode): Explicitly
2884         generate PARALLEL with clobber for TARGET_POWER.
2885
2886 2003-01-16  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2887
2888         * ra-colorize.c (colorize_one_web): Initialize variable.
2889         * regmove.c (fixup_match_1): Likewise.
2890         * reload1.c (reload_as_needed): Likewise.
2891         * sdbout.c (SET_KNOWN_TYPE_TAG): Add cast.
2892
2893 2003-01-16  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
2894
2895         * cfgloop.c (flow_loops_find): Fix handling of abnormal edges.
2896
2897 2003-01-16  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2898
2899         * dbxout.c (lastfile, cwd): Fix `unused' warning.
2900         * dwarf2out.c (fde_table_in_use, current_funcdef_fde,
2901         dw_cfi_oprnd1_desc, dw_cfi_oprnd2_desc, next_die_offset,
2902         is_main_source, file_table, decl_die_table_in_use,
2903         abbrev_die_table_in_use, line_info_table_in_use,
2904         separate_line_info_table_in_use, pubname_table_in_use,
2905         arange_table_in_use, ranges_table_in_use,
2906         current_function_has_inlines): Likewise.
2907         * flow.c (life_analysis): Likewise.
2908         * genemit.c (gen_insn): Likewise.
2909         * protoize.c (cplus_suffix): Likewise.
2910
2911         * arm.c (ROUND_UP_WORD): Renamed from ROUND_UP.
2912         * arm.h (ROUND_UP_WORD): Likewise.
2913
2914         * arm.h (CONDITIONAL_REGISTER_USAGE): Avoid signed/unsigned
2915         warning.
2916         * emit-rtl.c (gen_rtx_REG, set_mem_attributes_minus_bitpos,
2917         init_emit_once): Likewise.
2918         * flow.c (mark_regs_live_at_end, calculate_global_regs_live):
2919         Likewise.
2920         * function.c (assign_stack_temp_for_type): Likewise.
2921         * loop.c (loop_invariant_p): Likewise.
2922         * recog.c (push_operand): Likewise.
2923         * regclass.c (init_reg_sets_1): Likewise.
2924         * reload.c (update_auto_inc_notes): Likewise.
2925         * reload1.c (reload_as_needed, emit_input_reload_insns): Likewise.
2926         * stmt.c (expand_asm_operands): Likewise.
2927         * stor-layout.c (start_record_layout): Likewise.
2928
2929 2003-01-16  Herman A.J. ten Brugge <hermantenbrugge@home.nl>
2930
2931         * config/c4x/c4x.md (epilogue): Correct last patch.
2932
2933 2003-01-15  Richard Henderson  <rth@redhat.com>
2934
2935         * config/alpha/alpha.c (find_lo_sum_using_gp): Rename from find_lo_sum;
2936         also check that GP is being used.
2937         (alpha_find_lo_sum_using_gp): New.
2938         (alpha_does_function_need_gp): Use get_attr_usegp.
2939         * config/alpha/alpha-protos.h: Update.
2940         * config/alpha/alpha.md (attr usegp): New.  Annotate patterns
2941         as needed.
2942
2943 2003-01-15  Roger Sayle  <roger@eyesopen.com>
2944
2945         * gcse.c (one_cprop_pass): Change function arguments to take both
2946         cprop_jumps and bypass_jumps flags instead of just alter_jumps.
2947         (gcse_main): Update calls to one_cprop_pass, disabling bypassing.
2948         (bypass_jumps): New function to perform separate jump bypassing pass.
2949         * rtl.h (bypass_jumps): Add function prototype.
2950         * timevar.def (TV_BYPASS): New timing variable.
2951         * toplev.c (enum dump_file_index): Add new entry DFI_bypass.
2952         (dump_file): New entry for the bypass RTL dump file.
2953         (rest_of_compilation): Insert new jump bypassing optimization
2954         pass after loop.
2955         * doc/passes.texi: Document new pass.
2956
2957 2003-01-15  John David Anglin  <dave@hiauly1.hia.nrc.ca>
2958
2959         * som.h (SUPPORTS_WEAK, SUPPORTS_ONE_ONLY, MAKE_DECL_ONE_ONLY,
2960         ASM_WEAKEN_LABEL, GTHREAD_USE_WEAK): Define.
2961         * pa.h (TARGET_SOM_SDEF): Define.
2962         * pa-hpux11.h (TARGET_SOM_SDEF): Define.
2963
2964 2003-01-16  Stephane Carrez  <stcarrez@nerim.fr>
2965
2966         * config/m68hc11/m68hc11.c (expand_prologue): Use push/pop to
2967         allocate 4-bytes of locals on 68HC11.
2968         (expand_epilogue): Likewise.
2969         (m68hc11_memory_move_cost): Increase cost of HI/QI soft registers.
2970
2971 2003-01-15  Stephane Carrez  <stcarrez@nerim.fr>
2972
2973         * config/m68hc11/m68hc11.h (ASM_SPEC): Handle -m68hcs12; Pass -mshort
2974         and -mshort-double to the assembler to specify the ABI.
2975         (LINK_SPEC): Likewise.
2976         (CPP_SPEC): Pass HCS12 specific define.
2977         (MASK_M68S12): New define.
2978         (TARGET_M68S12): Likewise.
2979         (TARGET_SWITCHES): New options -m68hcs12 and -m68S12.
2980         (TARGET_VERSION): Update.
2981         * config/m68hc11/m68hc12.h (CPP_SPEC): Pass HCS12 specific define.
2982         (LINK_SPEC): Update.
2983         (ASM_SPEC): Update.
2984         * config/m68hc11/m68hc11.c (m68hc11_asm_file_start): Update.
2985         * doc/invoke.texi (M68hc1x Options): Document -m68hcs12.
2986
2987 2003-01-15  Stephane Carrez  <stcarrez@nerim.fr>
2988
2989         * config/m68hc11/m68hc11.md ("return"): Use emit_jump_insn to emit
2990         the return code.
2991
2992 2003-01-15  Josef Zlomek  <zlomekj@suse.cz>
2993
2994         * cfganal.c (set_edge_can_fallthru_flag): Clear the EDGE_CAN_FALLTHRU
2995         flag before setting it.
2996
2997 2003-01-15  Roger Sayle  <roger@eyesopen.com>
2998
2999         * c-semantics.c (genrtl_while_stmt):  Improve initial RTL generation
3000         when loop condition is known true, i.e.  "while (1) { ... }".
3001         (genrtl_for_stmt): Similarly for "for" statements.
3002
3003 2003-01-15  Roger Sayle  <roger@eyesopen.com>
3004
3005         * real.c (real_sqrt): Return a bool result indicating whether
3006         a floating point exception or trap should be raised.
3007         * real.h (real_sqrt): Update function prototype.
3008         * builtins.c (fold_builtin): Only fold non-trapping square
3009         roots unless we're ignoring errno and trapping math.
3010
3011 2003-01-15  John David Anglin  <dave.anglin@nrc.gc.ca>
3012
3013         * expr.h (emit_conditional_add): Add PARAMS to declaration.
3014         * gengtype-lex.l (malloc, realloc): Move defines after include of
3015         system.h.  Remove duplicate include of system.h.
3016
3017 2003-01-15  Roger Sayle  <roger@eyesopen.com>
3018
3019         PR middle-end/9009
3020         * optabs.c (expand_unop):  When manipulating the FP sign bit
3021         using integer operations, account for targets with different
3022         integer and FP word orders.
3023         (expand_abs): Likewise.
3024
3025 2003-01-15  David Edelsohn  <edelsohn@gnu.org>
3026
3027         * config/rs6000/rs6000.c (rs6000_gen_section_name): Do not include
3028         file extension in section name.
3029
3030 2003-01-15  Richard Earnshaw  <rearnsha@arm.com>
3031
3032         * flow.c (find_auto_inc): Also try to generate a PRE_MODIFY with
3033         constant offset.
3034
3035 2003-01-15  Richard Earnshaw  <rearnsha@arm.com>
3036
3037         * arm.h (HAVE_PRE_MODIFY_DISP, HAVE_PRE_MODIFY_REG): Define.
3038         (HAVE_POST_MODIFY_DISP, HAVE_POST_MODIFY_REG): Define.
3039         (ARM_GO_IF_LEGITIMATE_ADDRESS): Handle pre/post-modify addresses.
3040         (ARM_PRINT_OPERAND_ADDRESS): Likewise.
3041
3042 Wed Jan 15 12:23:21 CET 2003  Jan Hubicka  <jh@suse.cz>
3043
3044         PR f/9258
3045         * global.c (struct allocno): Add no_stack_reg.
3046         (global_conflicts): Set no_stack_reg.
3047         (find_reg): Use it.
3048
3049         * convert.c (convert_to_real): Fold - and abs only when profitable.
3050         * fold-const.c (fold): Fold truncates in - and abs.
3051
3052 2003-01-15  Josef Zlomek  <zlomekj@suse.cz>
3053
3054         Segher Boessenkool  <segher@koffie.nl>
3055
3056         * predict.c (real_inv_br_prob_base): New variable.
3057         (propagate_freq): Use multiply by reciprocal instead of
3058         division.  Don't divide by 1.0 at all.
3059         (estimate_bb_frequencies): Similar.
3060
3061 2003-01-15  Alexandre Oliva  <aoliva@redhat.com>
3062
3063         * configure.in (libgcc_visibility): Force disabled on IRIX 6 too.
3064         * configure: Rebuilt.
3065
3066 2003-01-15  Hartmut Penner  <hpenner@de.ibm.com>
3067
3068         * config/s390/s390.c (s390_safe_attr_type): New function.
3069         (s390_use_dfa_pipeline_interface): New function, return true for z900.
3070         (s390_issue_rate): New function.
3071         (s390_agen_dep_p): New function.
3072         (addr_generation_dependency_p): Use 's390_safe_attr_type'.
3073         (s390_adjust_cost): Return 'cost' if new DFA is used.
3074         (s390_adjust_priority): Delete function.
3075         * config/s390/s390-protos.h: (s390_agen_dep_p): New prototype.
3076         * config/s390/s390.md (atype attribute): Attribute 'atype' default
3077         determined by 'op_type'.
3078         (type attribute): Added more type attributes.
3079         * config/s390/2064.md: New DFA description for z900 pipeline.
3080
3081 2003-01-15  Alexandre Oliva  <aoliva@redhat.com>
3082
3083         * config/i386/i386.c (ix86_expand_vector_move): Validize constant
3084         forced to memory.  Fixes PR bootstrap/9036.
3085
3086         * config/mips/mips.h (CRT_CALL_STATIC_FUNCTION): Define so as
3087         to set $gp before the call.
3088
3089 2003-01-14  Richard Henderson  <rth@redhat.com>
3090
3091         * config/alpha/alpha.c (alpha_expand_mov): Use correct mode
3092         for force_const_mem.
3093
3094 2003-01-14  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
3095
3096         * genattr.c (main): Rearrange output to avoid prototype warning.
3097         * genautomata.c (transform_3): Fix ambiguous-else warning.
3098         * local-alloc.c (requires_inout): Add parentheses around
3099         assignment used as truth-value.
3100         * timevar.c: Move system includes above local includes.  Include
3101         toplev.h
3102         * Makefile.in (timevar.o): Depend on toplev.h.
3103
3104 2003-01-14  Denis Chertykov  <denisc@overta.ru>
3105
3106         * config/ip2k/ip2k.h (VALID_MACHINE_DECL_ATTRIBUTE): Remove.
3107         (VALID_MACHINE_TYPE_ATTRIBUTE): Remove.
3108
3109         * config/ip2k/ip2k.c (ip2k_attribute_table): New table of
3110         attributes.
3111         (TARGET_ATTRIBUTE_TABLE): New macro.
3112         (valid_machine_type_attribute): Remove.
3113         (valid_machine_decl_attribute): Remove.
3114         (ip2k_handle_progmem_attribute): New function.
3115         (ip2k_handle_fndecl_attribute): New function.
3116
3117 2003-01-10  Andrew Haley  <aph@redhat.com>
3118
3119         * config/i386/linux64.h (MD_FALLBACK_FRAME_STATE_FOR): Rename
3120         registers to be in correct order.  Add rip.
3121
3122 2003-01-14  Kazu Hirata  <kazu@cs.umass.edu>
3123
3124         * config/h8300/h8300.md (*andsi3_lshiftrt_9_sb): New.
3125         (*iorsi3_and_lshiftrt_9_sb): Likewise.
3126
3127 Tue Jan 14 00:45:33 CET 2003  Jan Hubicka  <jh@suse.cz>
3128
3129         * convert.c (strip_float_extensions):  Look for narrowest type handling
3130         FP constants.
3131
3132         * fold-const.c (fold):  Fold (double)float1 CMP (double)float2 into
3133         float1 CMP float2.
3134         * convert.c (strip_float_extensions): Make global.
3135         * tree.h (strip_float_extensions): Declare.
3136
3137 2003-01-14  Gabriel Dos Reis  <gdr@integrable-solutions.net>
3138
3139         * timevar.def: define TV_NAME_LOOKUP.
3140         * timevar.c (timevar_pop): Be verbose when aborting.
3141
3142 2003-01-13  Andreas Schwab  <schwab@suse.de>
3143
3144         * Makefile.in ($(parsedir)/gengtype-lex.c): Don't change to
3145         $(parsedir), just move the temporary file at the end.
3146         ($(parsedir)/gengtype-yacc.c): Likewise.
3147
3148 2003-01-13  Alexandre Oliva  <aoliva@redhat.com>
3149
3150         * aclocal.m4 (gcc_AC_PROG_GNAT): Don't try to prepend
3151         ${ac_tool_prefix} to ADAC or CC.  Protect them from word
3152         splitting.
3153         * configure: Rebuilt.
3154
3155 2003-01-13  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
3156
3157         * config/sparc/gmon-sol2.c (moncontrol, monstartup, _mcleanup,
3158         internal_mcount): Don't use PARAMS.
3159         (monstartup, _mcleanup, internal_mcount, moncontrol): Convert to
3160         ISO C style.
3161         (internal_mcount): Use __attribute__, not ATTRIBUTE_UNUSED.
3162
3163 2003-01-13  Andreas Schwab  <schwab@suse.de>
3164
3165         * config/rs6000/sysv4.h (ASM_OUTPUT_ALIGNED_LOCAL): Output type
3166         directive.
3167
3168 2003-01-13  Kazu Hirata  <kazu@cs.umass.edu>
3169
3170         * config/h8300/h8300.md (*andsi3_lshift_n_sb): New.
3171         (*iorsi3_and_lshiftrt_n_sb): Likewise.
3172
3173 2003-01-12  Mark Mitchell  <mark@codesourcery.com>
3174
3175         PR c++/9264
3176         * c-lex.c (c_lex): Set the token value to error_mark_node for
3177         invalid numeric constants.
3178
3179 2003-01-12  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
3180
3181         * c-pch.c (asm_file_startpos): Change to `long'.
3182         (pch_init): Use ftell, not ftello.
3183         (c_common_write_pch): Use ftell/fseek, not ftello/fseeko.
3184         Use `long' instead of `off_t'.
3185         (c_common_read_pch): Likewise.
3186         * ggc-common.c (gt_pch_save): Use long/ftell instead of
3187         off_t/ftello.
3188
3189 2003-01-12  Alan Modra  <amodra@bigpond.net.au>
3190
3191         * expr.c (expand_expr <RDIV_EXPR>): Correct recursive call args.
3192
3193 2003-01-11  Richard Earnshaw  (rearnsha@arm.com)
3194
3195         * arm-protos.h (struct cpp_reader): Add declaration.
3196
3197 Sat Jan 11 11:02:58 CET 2003  Jan Hubicka  <jh@suse.cz>
3198
3199         PR target/9068
3200         * i386.c (output_fp_compare): Fix typo.
3201
3202 2003-01-10  David Edelsohn  <edelsohn@gnu.org>
3203
3204         * config/rs6000/rs6000.c (common_mode_defined): Mark for PCH.
3205
3206 2003-01-10  Geoffrey Keating  <geoffk@apple.com>
3207
3208         * Makefile.in (parsedir): New variable.
3209         (docobjdir): New variable.
3210         (c-parse.o, c-parse.c, c-parse.y, gengtype-lex.o, gengtype-yacc.o,
3211         gengtype-lex.c, gengtype-yacc.c): Use parsedir.
3212         (info, cpp.info, gcc.info, gccint.info, gccinstall.info,
3213         cppinternals.info, generated-manpages, gcov.1, cpp.1, gcc.1, gfdl.7,
3214         gpl.7, fsf-funding.7, maintainer-clean, install-info, install-man):
3215         Use docobjdir.
3216         * objc/Make-lang.in (objc/objc-parse.c, objc/objc-parse.y,
3217         objc.maintainer-clean): Use parsedir.
3218
3219         * varasm.c (struct constant_descriptor_rtx): Remove unused
3220         `label' field.
3221
3222         * toplev.c (documented_lang_options): Document -Winvalid-pch.
3223
3224 2003-01-10  Richard Henderson  <rth@redhat.com>
3225
3226         * config/alpha/alpha.h (NO_PROFILE_COUNTERS): Set.
3227         (ASM_OUTPUT_REG_PUSH, ASM_OUTPUT_REG_POP): Kill.
3228
3229 2003-01-10  Richard Henderson  <rth@redhat.com>
3230
3231         * combine.c (make_compound_operation): Use SCALAR_INT_MODE_P,
3232         not INTEGRAL_MODE_P when widening extensions.
3233
3234 2003-01-10  Richard Henderson  <rth@redhat.com>
3235
3236         * config/alpha/alpha.c (decl_has_samegp): True for !TREE_PUBLIC.
3237
3238 2003-01-10  Geoffrey Keating  <geoffk@apple.com>
3239
3240         * ggc-page.c (ggc_collect): Avoid overflow computing
3241         min_expand.
3242
3243         * Makefile.in (RANLIB_FOR_TARGET): Use RANLIB when native.
3244         (RANLIB_TEST_FOR_TARGET): Delete.  Don't pass down to sub-makes.
3245         Remove calls.
3246         * mklibgcc.in: Remove uses of RANLIB_TEST_FOR_TARGET.
3247
3248 Fri Jan 10 22:05:35 CET 2003  Jan Hubicka  <jh@suse.cz>
3249
3250         * ifcvt.c (noce_try_addcc): Do not call emit_conditional_add
3251         with weird operands.
3252
3253 2003-01-10  Dale Johannesen <dalej@apple.com>
3254
3255         * calls.c (load_register_parameters):  Add is_sibcall, sibcall_failure
3256         parameters.  Call check_sibcall_argument_overlap if indicated.
3257         (check_sibcall_argument_overlap):  Add mark_stored_args_map
3258         parameter.  Don't mark parameter area as clobbered if not set.
3259         (expand_call):  Adjust calls to above.
3260
3261 2003-01-10 Kelley Cook <kelleycook@comcast.net>
3262
3263         * configure.in (linker read-only and read-write section mixing):
3264         Squelch some assembler warnings.
3265         * configure: Likewise.
3266
3267 2003-01-10  Hartmut Penner  <hpenner@de.ibm.com>
3268
3269         * doc/invoke.texi: Document -mtune, delete -mcpu
3270         option for S/390 and zSeries.
3271         * config/s390/s390.c (s390_tune_string) New variable.
3272         (s390_cpu_string) Delete variable.
3273         (override_options): Use s390_tune_string instead of
3274         s390_cpu_string.
3275         * config/s390/s390.h: (TARGET_OPTIONS) '-mtune' instead of '-mcpu'.
3276
3277 2003-01-10  Kazu Hirata  <kazu@cs.umass.edu>
3278
3279         * config/h8300/h8300.md (*iorsi3_ashift_31): New.
3280
3281 2003-01-10  Josef Zlomek  <zlomekj@suse.cz>
3282
3283         * jump.c (next_nonnote_insn_in_loop): New function.
3284         (copy_loop_headers): Use next_nonnote_insn_in_loop instead of
3285         next_nonnote_insn.
3286         (duplicate_loop_exit_test). Likewise.
3287
3288 2003-01-09  Geoffrey Keating  <geoffk@apple.com>
3289
3290         Merge from pch-branch:
3291
3292         2003-01-06  Geoffrey Keating  <geoffk@apple.com>
3293
3294         * ggc-page.c (ggc_pch_read): Update the statistics after a PCH
3295         load.
3296
3297         2002-12-24  Geoffrey Keating  <geoffk@apple.com>
3298
3299         * cpplib.c (count_registered_pragmas): New function.
3300         (save_registered_pragmas): New function.
3301         (_cpp_save_pragma_names): New function.
3302         (restore_registered_pragmas): New function.
3303         (_cpp_restore_pragma_names): New function.
3304         * cpphash.h (_cpp_save_pragma_names): Prototype.
3305         (_cpp_restore_pragma_names): Likewise.
3306         * cpppch.c (struct save_macro_item): Split from save_macro_data.
3307         (struct save_macro_data): New field 'saved_pragmas'.
3308         (save_macros): Update for changes to struct save_macro_data.
3309         (cpp_prepare_state): Call _cpp_save_pragma_names, update
3310         for changes to struct save_macro_data.
3311         (cpp_read_state): Call _cpp_restore_pragma_names, update
3312         for changes to struct save_macro_data.
3313
3314         * cpppch.c (cpp_read_state): Restore the hashtable references
3315         in the cpp_reader.
3316
3317         * tree.h (built_in_decls): Mark for PCH.
3318
3319         * dbxout.c (lastfile): Don't mark for PCH.
3320
3321         * ggc.h: Document PCH calls into memory managers.
3322
3323         2002-12-18  Geoffrey Keating  <geoffk@apple.com>
3324
3325         * doc/invoke.texi (Precompiled Headers): Document the
3326         directory form of PCH.
3327         * cppfiles.c (validate_pch): New function.
3328         (open_file_pch): Search suitably-named directories for PCH files.
3329
3330         2002-12-14  Geoffrey Keating  <geoffk@apple.com>
3331
3332         * doc/gty.texi (GTY Options): Document chain_next, chain_prev,
3333         reorder options.
3334         (Type Information): Mention that the information is also
3335         used to implement PCH.
3336         * doc/passes.texi (Passes): Improve documentation of
3337         language-specific files.
3338
3339         2002-12-11  Geoffrey Keating  <geoffk@apple.com>
3340
3341         * gengtype.c (struct write_types_data): Add reorder_note_routine field.
3342         (struct walk_type_data): Add reorder_fn field.
3343         (walk_type): Process 'reorder' option.
3344         (write_types_process_field): Reorder parameters to gt_pch_note_object,
3345         call reorder_note_routine.
3346         (write_func_for_structure): Reorder parameters to gt_pch_note_object.
3347         (ggc_wtd): Update for change to struct write_types_data.
3348         (pch_wtd): Likewise.
3349         * ggc.h (gt_pch_note_object): Reorder parameters.
3350         (gt_handle_reorder): New definition.
3351         (gt_pch_note_reorder): New prototype.
3352         * ggc-common.c (struct ptr_data): Add reorder_fn.
3353         (gt_pch_note_object): Reorder parameters.
3354         (gt_pch_note_reorder): New.
3355         (gt_pch_save): Call reorder_fn.
3356         * stringpool.c (gt_pch_n_S): Update for change to gt_pch_note_object.
3357
3358         * dbxout.c (cwd): Don't mark for PCH.
3359
3360         2002-12-09  Geoffrey Keating  <geoffk@apple.com>
3361
3362         * gengtype.c (finish_root_table): Fix some warnings.
3363         (write_root): Handle TYPE_STRING.
3364         * ggc.h (gt_ggc_m_S): Add prototype.
3365         * stringpool.c (gt_ggc_m_S): New function.
3366
3367         2002-11-30  Geoffrey Keating  <geoffk@apple.com>
3368
3369         * dwarf2out.c (dw2_string_counter): New.
3370         (AT_string_form): Use it.
3371         (same_dw_val_p): Update for removal of hashtable.h hash tables.
3372
3373         2002-11-22  Geoffrey Keating  <geoffk@apple.com>
3374
3375         * dbxout.c: Include gt-dbxout.h.
3376         (lastfile): Mark for PCH/GGC.
3377         (cwd): Likewise.
3378         (struct typeinfo): Likewise.
3379         (typevec): Likewise.
3380         (typevec_len): Likewise.
3381         (next_type_number): Likewise.
3382         (struct dbx_file): Likewise.
3383         (current_file): Likewise.
3384         (next_file_number): Likewise.
3385         (dbxout_init): Allocate typevec, struct dbx_file with GGC.
3386         (dbxout_start_source_file): Allocate struct dbx_file with GGC.
3387         (dbxout_end_source_file): Don't free struct dbx_file.
3388         (dbxout_type): Use GGC to allocate typevec.
3389         * Makefile.in (dbxout.o): Depend on gt-dbxout.h, $(GGC_H).
3390         (GTFILES): Add dbxout.c.
3391         (gt-dbxout.h): New rule.
3392
3393         * Makefile.in (c-pch.o): Add debug.h as dependency.
3394         * c-pch.c: Include debug.h.
3395         (pch_init): Call start_source_file to keep nesting right.
3396         (c_common_read_pch): Add orig_name parameter.  Call
3397         start_source_file debug hook.  Call end_source_file debug hook.
3398         * c-common.h (c_common_read_pch): Update prototype.
3399         * cpplib.h (struct cpp_callbacks): Add fourth field to read_pch
3400         callback.
3401         * cppfiles.c (struct include_file): Add new field `header_name'.
3402         (find_or_create_entry): Default it to `name'.
3403         (open_file_pch): Set it to the original header file searched for.
3404         (stack_include_file): Don't stack an empty buffer, just handle
3405         PCH files immediately.  Pass header_name field to read_pch callback.
3406
3407         2002-11-19  Geoffrey Keating  <geoffk@apple.com>
3408
3409         * function.c (funcdef_no): Mark to be saved in a PCH.
3410
3411         2002-11-15  Geoffrey Keating  <geoffk@apple.com>
3412
3413         * ggc-page.c (ggc_pch_read): Remove unused 'bmap_size'.
3414
3415         * cpppch.c (cpp_read_state): Correct size reallocated for 'defn'.
3416
3417         2002-11-14  Geoffrey Keating  <geoffk@apple.com>
3418
3419         * optabs.h (code_to_optab): Add GTY marker.
3420
3421         2002-11-13  Geoffrey Keating  <geoffk@apple.com>
3422
3423         * Makefile.in (GTFILES): Add cpplib.h.
3424         * c-common.h (struct c_common_identifier): Don't skip 'node' field.
3425         * c-decl.c (build_compound_literal): Don't use var_labelno.
3426         * cpplib.h (struct cpp_hashnode): Use gengtype to mark.
3427         * dwarf2asm.c (dw2_force_const_mem): Don't use const_labelno.
3428         * varasm.c (const_labelno): Use gengtype to mark.
3429         (var_labelno): Likewise.
3430         (in_section): Likewise.
3431         (in_named_name): Likewise.
3432         (struct in_named_entry): Likewise.
3433         (in_named_htab): Likewise.
3434         (set_named_section_flags): Use GGC to allocate struct in_named_entry.
3435         (init_varasm_once): Use GGC to allocate in_named_htab.
3436         * config/darwin.c (current_pic_label_num): Mark for PCH.
3437
3438         2002-11-11  Geoffrey Keating  <geoffk@apple.com>
3439
3440         * ggc-simple.c (init_ggc_pch): New stub procedure.
3441         (ggc_pch_count_object): Likewise.
3442         (ggc_pch_total_size): Likewise.
3443         (ggc_pch_this_base): Likewise.
3444         (ggc_pch_alloc_object): Likewise.
3445         (ggc_pch_prepare_write): Likewise.
3446         (ggc_pch_write_object): Likewise
3447         (ggc_pch_finish): Likewise.
3448         (ggc_pch_read): Likewise.
3449
3450         2002-11-08  Geoffrey Keating  <geoffk@apple.com>
3451
3452         * c-pch.c (c_common_write_pch): Write the macro definitions after
3453         the GCed data.
3454         (c_common_read_pch): Call cpp_prepare_state.  Restore the macro
3455         definitions after the GCed data.
3456         * cpplib.c (save_macros): New.
3457         (reset_ht): New.
3458         (cpp_write_pch_deps): Split out of cpp_write_pch.
3459         (cpp_write_pch_state): Split out of cpp_write_pch.
3460         (cpp_write_pch): Delete.
3461         (struct save_macro_data): Delete.
3462         (cpp_prepare_state): New.
3463         (cpp_read_state): Erase and restore initial macro definitions.
3464         * cpplib.h (struct save_macro_data): Forward-declare.
3465         (cpp_write_pch_deps): Prototype.
3466         (cpp_write_pch_state): Prototype.
3467         (cpp_write_pch): Delete prototype.
3468         (cpp_prepare_state): Prototype.
3469         (cpp_read_state): Add fourth argument.
3470
3471         2002-11-04  Geoffrey Keating  <geoffk@apple.com>
3472
3473         * gengtype.c (adjust_field_rtx_def): Don't use skip on valid fields.
3474         (write_array): Remove warning.
3475
3476         * gengtype.c (contains_scalar_p): New.
3477         (finish_root_table): Add the table to all languages, even if it's
3478         empty.
3479         (write_roots): Output gt_pch_scalar_rtab.
3480         * ggc-common.c (gt_pch_save): Write out scalars.
3481         (gt_pch_restore): Read scalars back.
3482
3483         * ggc-page.c (OBJECTS_IN_PAGE): New macro.
3484         (struct page_entry): Delete pch_page field.
3485         (ggc_recalculate_in_use_p): Use OBJECTS_IN_PAGE.
3486         (clear_marks): Likewise.
3487         (sweep_pages): Likewise.
3488         (poison_pages): Likewise.
3489         (ggc_print_statistics): Likewise.
3490         (ggc_pch_read): Don't free objects read from a PCH.
3491         Properly set up in_use_p and page_tails.
3492
3493         2002-10-25  Geoffrey Keating  <geoffk@apple.com>
3494
3495         * gengtype.c (struct write_types_data): New.
3496         (struct walk_type_data): Make `cookie' const; add extra
3497         prev_val item; add `orig_s' field.
3498         (walk_type): Update prev_val[3].
3499         (write_types_process_field): New.
3500         (write_func_for_structure): Take write_types_data structure.
3501         (write_types): New.
3502         (ggc_wtd): New.
3503         (pch_wtd): New.
3504         (write_types_local_process_field): New.
3505         (gc_mark_process_field): Delete.
3506         (write_local_func_for_structure): New.
3507         (gc_mark_func_name): Delete.
3508         (write_gc_types): Delete.
3509         (write_local): New.
3510         (finish_root_table): Don't include 'ggc_' in PFX.
3511         (write_root): Rename from write_root.  Fill pchw field of structures.
3512         (write_array): New.
3513         (write_roots): Rename from write_gc_roots.  Split out to write_array.
3514         Update to changes to other routines.  Write gt_pch_cache_rtab table.
3515         (main): Write PCH walking routines.
3516         * ggc-common.c: Include toplev.h, sys/mman.h.
3517         (ggc_mark_roots): For cache hashtables, also mark the hash table
3518         and the array of entries.
3519         (saving_htab): New.
3520         (struct ptr_data): New.
3521         (POINTER_HASH): New.
3522         (gt_pch_note_object): New.
3523         (saving_htab_hash): New.
3524         (saving_htab_eq): New.
3525         (struct traversal_state): New.
3526         (call_count): New.
3527         (call_alloc): New.
3528         (compare_ptr_data): New.
3529         (relocate_ptrs): New.
3530         (write_pch_globals): New.
3531         (struct mmap_info): New.
3532         (gt_pch_save): New.
3533         (gt_pch_restore): New.
3534         * ggc-page.c (ROUND_UP_VALUE): New.
3535         (ROUND_UP): New.
3536         (struct page_entry): Add field `pch_page'.
3537         (init_ggc): Use ROUND_UP.
3538         (struct ggc_pch_data): Declare.
3539         (init_ggc_pch): New.
3540         (ggc_pch_count_object): New.
3541         (ggc_pch_total_size): New.
3542         (ggc_pch_this_base): New.
3543         (ggc_pch_alloc_object): New.
3544         (ggc_pch_prepare_write): New.
3545         (ggc_pch_write_object): New.
3546         (ggc_pch_finish): New.
3547         (ggc_pch_read): New.
3548         * ggc.h (gt_pointer_operator): New.
3549         (gt_note_pointers): New.
3550         (gt_pch_note_object): New prototype.
3551         (gt_pointer_walker): New.
3552         (struct ggc_root_tab): Use gt_pointer_walker, add `pchw' field.
3553         (LAST_GGC_ROOT_TAB): Update.
3554         (gt_pch_cache_rtab): Declare.
3555         (gt_pch_scalar_rtab): Declare.
3556         (struct ggc_cache_tab): Use gt_pointer_walker, add `pchw' field.
3557         (LAST_GGC_CACHE_TAB): Update.
3558         (gt_pch_save_stringpool): Declare.
3559         (gt_pch_restore_stringpool): Declare.
3560         (gt_pch_p_S): Declare.
3561         (gt_pch_n_S): Declare.
3562         (struct ggc_pch_data): Forward-declare.
3563         (init_ggc_pch): Declare.
3564         (ggc_pch_count_object): Declare.
3565         (ggc_pch_total_size): Declare.
3566         (ggc_pch_this_base): Declare.
3567         (ggc_pch_alloc_object): Declare.
3568         (ggc_pch_prepare_write): Declare.
3569         (ggc_pch_write_object): Declare.
3570         (ggc_pch_finish): Declare.
3571         (ggc_pch_read): Declare.
3572         (gt_pch_save): Declare.
3573         (gt_pch_restore): Declare.
3574         * fold-const.c (size_int_type_wide): Allocate size_htab using GGC.
3575         * emit-rtl.c (init_emit_once): Allocate const_int_htab,
3576         const_double_htab, mem_attrs_htab using GGC.
3577         * c-pch.c: Include ggc.h.
3578         (pch_init): Allow reading PCH file back.
3579         (c_common_write_pch): Call gt_pch_save.
3580         (c_common_read_pch): Call gt_pch_restore.
3581         * c-parse.in (init_reswords): Delete now-untrue comment.
3582         Allocate ridpointers using GGC.
3583         * c-objc-common.c (c_objc_common_finish_file): Write PCH before
3584         calling expand_deferred_fns.
3585         * c-common.h (ridpointers): Mark for GTY machinery.
3586         * Makefile.in (stringpool.o): Update dependencies.
3587         (c-pch.o): Update dependencies.
3588         (ggc-common.o): Update dependencies.
3589         * stringpool.c: Include gt-stringpool.h.
3590         (gt_pch_p_S): New.
3591         (gt_pch_n_S): New.
3592         (struct string_pool_data): New.
3593         (spd): New.
3594         (gt_pch_save_stringpool): New.
3595         (gt_pch_restore_stringpool): New.
3596         * tree.c (init_ttree): Make type_hash_table allocated using GC.
3597
3598         2002-10-04  Geoffrey Keating  <geoffk@apple.com>
3599
3600         * gengtype.c (adjust_field_rtx_def): Don't pass size_t to printf.
3601         (output_mangled_typename): Don't pass size_t to printf.
3602
3603         * tree.h (union tree_type_symtab): Add tag to `address' field.
3604         (union tree_decl_u2): Add tag to 'i' field.
3605         * varasm.c (union rtx_const_un): Add tags to all fields.
3606         * gengtype.c (struct walk_type_data): New.
3607         (output_escaped_param): Take struct walk_type_data parameter.
3608         (write_gc_structure_fields): Delete.
3609         (walk_type): New.
3610         (write_gc_marker_routine_for_structure): Delete.
3611         (write_func_for_structure): New.
3612         (gc_mark_process_field): New.
3613         (gc_mark_func_name): New.
3614         (gc_counter): Delete.
3615         (write_gc_types): Use write_func_for_structure.
3616         (write_gc_roots): Use walk_type.
3617
3618         2002-10-02  Geoffrey Keating  <geoffk@apple.com>
3619
3620         * ggc-common.c (ggc_mark_roots): Delete 'x'.
3621         (ggc_splay_dont_free): Fix warning about unused 'x'.
3622         (ggc_print_common_statistics): Remove warnings.
3623
3624         2002-10-01  Mike Stump  <mrs@apple.com>
3625
3626         * ggc-common.c (ggc_splay_alloc): Actually return the allocated area.
3627         * gengtype.c (write_gc_structure_fields): Handle param[digit]_is.
3628
3629         2002-09-01  Geoffrey Keating  <geoffk@redhat.com>
3630             Catherine Moore  <clm@redhat.com>
3631
3632         * Makefile (c-pch.o): Update dependencies.
3633         (LIBCPP_OBJS): Add cpppch.o.
3634         (cpppch.o): New.
3635         * c-common.c (c_common_init): Don't call pch_init here.
3636         * c-common.h (c_common_read_pch): Update prototype.
3637         * c-lex.c (c_common_parse_file): Call pch_init here.
3638         * c-opts.c (COMMAND_LINE_OPTIONS): Add -Winvalid-pch, -fpch-deps.
3639         (c_common_decode_option): Handle them.
3640         * c-pch.c: Include c-pragma.h.
3641         (save_asm_offset): Delete.
3642         (pch_init): Move contents of save_asm_offset into here, call
3643         cpp_save_state.
3644         (c_common_write_pch): Call cpp_write_pch.
3645         (c_common_valid_pch): Warn only when -Winvalid-pch.  Call
3646         cpp_valid_state.
3647         (c_common_read_pch): Add NAME parameter.  Call cpp_read_state.
3648         * cppfiles.c (stack_include_file): Update for change to
3649         parameters of cb.read_pch.
3650         * cpphash.h (struct cpp_reader): Add `savedstate' field.
3651         * cpplib.h (struct cpp_options): Add `warn_invalid_pch' and
3652         `restore_pch_deps' fields.
3653         (struct cpp_callbacks): Add NAME parameter to `read_pch'.
3654         (cpp_save_state): Prototype.
3655         (cpp_write_pch): Prototype.
3656         (cpp_valid_state): Prototype.
3657         (cpp_read_state): Prototype.
3658         * cpppch.c: New file.
3659         * flags.h (version_flag): Remove prototype.
3660         * mkdeps.c (deps_save): New.
3661         (deps_restore): New.
3662         * mkdeps.h (deps_save): Prototype.
3663         (deps_restore): Prototype.
3664         * toplev.c (late_init_hook): Delete.
3665         (version_flag): Make static again.
3666         (compile_file): Don't call late_init_hook.
3667         * toplev.h (late_init_hook): Delete.
3668         * doc/cppopts.texi: Document -fpch-deps.
3669         * doc/invoke.texi (Warning Options): Document -Winvalid-pch.
3670
3671         2002-08-27  Geoffrey Keating  <geoffk@redhat.com>
3672
3673         * c-pch.c (c_common_write_pch): Rename from c_write_pch, change
3674         callers.
3675         (c_common_valid_pch): Rename from c_valid_pch, change callers.
3676         (c_common_read_pch): Rename from c_read_pch, change callers.
3677
3678         * c-opts.c (COMMAND_LINE_OPTIONS): Allow -output-pch= to have
3679         a space between it and its argument.
3680
3681         2002-08-24  Geoffrey Keating  <geoffk@redhat.com>
3682
3683         * c-pch.c: New file.
3684         * toplev.h (late_init_hook): Declare.
3685         * toplev.c (late_init_hook): Define.
3686         (version_flag): Make globally visible.
3687         (compile_file): Call late_init_hook.
3688         (init_asm_output): Make output file seekable.
3689         * gcc.c (default_compilers): Update c-header rule.
3690         * flags.h (version_flag): Declare.
3691         * cpplib.h (struct cpp_callbacks): Add 'valid_pch' and 'read_pch'
3692         fields.
3693         * cppfiles.c (struct include_file): Add 'pch' field.
3694         (INCLUDE_PCH_P): New.
3695         (open_file_pch): New.
3696         (stack_include_file): Handle PCH files specially.
3697         (find_include_file): Call open_file_pch instead of open_file.
3698         (_cpp_read_file): Explain why open_file is used instead of
3699         open_file_pch.
3700         * c-opts.c (c_common_decode_option): Correct OPT__output_pch case.
3701         * c-objc-common.c (c_objc_common_finish_file): Call c_write_pch.
3702         * c-lex.c (init_c_lex): Set valid_pch and read_pch fields
3703         in cpplib callbacks.
3704         * c-common.c (pch_file): Correct comment.
3705         (allow_pch): Define.
3706         (c_common_init): Call pch_init.
3707         * c-common.h (allow_pch): Declare.
3708         (pch_init): Declare.
3709         (c_valid_pch): Declare.
3710         (c_read_pch): Declare.
3711         (c_write_pch): Declare.
3712         * Makefile.in (c-pch.o): New.
3713         (C_AND_OBJC_OBJS): Add c-pch.o.
3714         * doc/invoke.texi (Precompiled Headers): Add index entries,
3715         complete truncated paragraph.
3716
3717         2002-08-17  Geoffrey Keating  <geoffk@redhat.com>
3718
3719         * c-common.c: (pch_file): Define.
3720         * c-common.h (pch_file): Declare.
3721         * c-opts.c (COMMAND_LINE_OPTIONS): Add --output-pch=.
3722         (missing_arg): Require --output-pch= to have an argument.
3723         (c_common_decode_option): Handle --output-pch=.
3724         * gcc.c: Document new %V.
3725         (default_compilers): Handle compiling C header files.
3726         (do_spec_1): Implement %V.
3727         (main): Handle "gcc foo.h" without trying to run linker.
3728         * doc/invoke.texi (Invoking GCC): Add new menu item for PCH.
3729         (Overall Options): Document what the driver does with header files,
3730         document new -x option possibilities.
3731         (Invoking G++): More documentation for PCH.
3732         (Precompiled Headers): New.
3733
3734         2002-08-09  Geoffrey Keating  <geoffk@redhat.com>
3735
3736         * ggc.h: Don't include varray.h.  Rearrange functions to be more
3737         organized.
3738         (ggc_add_root): Delete.
3739         (ggc_mark_rtx): Delete.
3740         (ggc_mark_tree): Delete.
3741         (struct ggc_statistics): Remove contents.
3742         * ggc-common.c: Remove unneeded includes.
3743         (struct ggc_root): Delete.
3744         (roots): Delete.
3745         (ggc_add_root): Delete.
3746         (ggc_mark_roots): Don't mark `roots'.  Call ggc_mark_stringpool.
3747         (ggc_print_common_statistics): Remove most of the contents.
3748         * Makefile.in (GGC_H): No longer uses varray.h.
3749         (ggc-common.o): Update dependencies.
3750         (c-parse.o): Add varray.h to dependencies.
3751         (c-common.o): Add varray.h.
3752         * stringpool.c (mark_ident): Use mangled name for tree marker routine.
3753         (mark_ident_hash): Rename to ggc_mark_stringpool.
3754         (init_stringpool): Don't use ggc_add_root.
3755         * c-parse.in: Include varray.h.
3756         * c-common.c: Include varray.h.
3757         * objc/Make-lang.in (objc-act.o): Add varray.h.
3758         * objc/objc-act.c: Include varray.h.
3759
3760         2002-07-25  Geoffrey Keating  <geoffk@redhat.com>
3761
3762         * dwarf2out.c (dw_cfi_oprnd2_desc): Fix ISO-only function definition.
3763         (dw_cfi_oprnd1_desc): Likewise.
3764
3765         2002-07-17  Geoffrey Keating  <geoffk@redhat.com>
3766
3767         * config/alpha/alpha.c (struct alpha_links): Use gengtype to mark;
3768         move out of ifdef.
3769         (alpha_links): Use gengtype to mark; move out of ifdef.
3770         (mark_alpha_links_node): Delete.
3771         (mark_alpha_links): Delete.
3772         (alpha_need_linkage): Use GGC to allocate splay tree, struct
3773         alpha_links, strings.  Don't use ggc_add_root.
3774         * ggc-common.c (ggc_splay_alloc): New.
3775         (ggc_splay_dont_free): New.
3776         * ggc.h (ggc_mark_rtx): Update for changed name mangling.
3777         (ggc_mark_tree): Likewise.
3778         (splay_tree_new_ggc): New.
3779         (ggc_splay_alloc): Declare.
3780         (ggc_splay_dont_free): Declare.
3781         * dwarf2asm.c: Include gt-dwarf2asm.h.
3782         (mark_indirect_pool_entry): Delete.
3783         (mark_indirect_pool): Delete.
3784         (indirect_pool): Use gengtype to mark.
3785         (dw2_force_const_mem): Don't use ggc_add_root.
3786         * Makefile.in (dwarf2asm.o): Depend on gt-dwarf2asm.h.
3787         (GTFILES): Add SPLAY_TREE_H, dwarf2asm.c.
3788         (gt-dwarf2asm.h): Depend on s-gtype.
3789
3790         2002-07-08  Geoffrey Keating  <geoffk@redhat.com>
3791
3792         * tree.h (union tree_type_symtab): Mark `die' field.
3793         * Makefile.in (dwarf2out.o): Update dependencies.
3794         * dwarf2out.c: Use GGC to allocate all structures.  Convert to htab_t
3795         hash tables.
3796         (dw_cfi_oprnd1_desc): New function.
3797         (dw_cfi_oprnd2_desc): New function.
3798         (indirect_string_alloc): Delete.
3799         (debug_str_do_hash): New function.
3800         (debug_str_eq): New function.
3801         (mark_limbo_die_list): Delete.
3802         (dwarf2out_init): Don't call ggc_add_root.
3803
3804 2003-01-09  Vladimir Makarov  <vmakarov@redhat.com>
3805
3806         The following changes are merged from itanium-sched-branch:
3807
3808         2003-01-08  David Edelsohn  <edelsohn@gnu.org>
3809
3810         * doc/md.texi: Clarify assignment of units to automata description.
3811
3812         2003-01-08  Vladimir Makarov  <vmakarov@redhat.com>
3813
3814         * genautomata.c (unit_decl): Remove members
3815         `the_same_automaton_unit' and
3816         `the_same_automaton_message_reported_p'.
3817         (process_unit_to_form_the_same_automaton_unit_lists,
3818         form_the_same_automaton_unit_lists_from_regexp,
3819         form_the_same_automaton_unit_lists, the_same_automaton_lists):
3820         Remove them.
3821         (annotation_message_reported_p): New global variable.
3822         (check_unit_distribution_in_reserv,
3823         check_regexp_units_distribution): New functions.
3824         (check_unit_distributions_to_automata): Rewrite it.
3825
3826         2003-01-04  Vladimir Makarov  <vmakarov@redhat.com>
3827
3828         * genautomata.c (form_the_same_automaton_unit_lists_from_regexp):
3829         Use continue instead of break if cycle is too big.
3830
3831         2002-12-20  Vladimir Makarov  <vmakarov@redhat.com>
3832
3833         * genautomata.c (check_unit_distributions_to_automata): Output at
3834         most one message for a unit.
3835         (process_unit_to_form_the_same_automaton_unit_lists): Check
3836         automaton of units instead of units themself.
3837
3838         * doc/md.texi: Describe the constraint about assigning unit to
3839         automata.
3840
3841         2002-12-20  Jan Hubicka  <jH@suse.cz>
3842                     Vladimir Makarov  <vmakarov@redhat.com>
3843
3844         * genautomata.c (unit_decl): Add new members `min_occ_cycle_num'
3845         and `in_set_p'.
3846         (gen_cpu_unit): Initialize the new members.
3847         (process_regexp_cycles): Calculate minimal finish cycle too.  Set
3848         up `min_occ_cycle_num'.
3849         (evaluate_max_reserv_cycles): Change the function call.
3850         (CLEAR_BIT): New macro.
3851         (states_union, state_shift): Use the mask.
3852         (initiate_excl_sets, form_reserv_sets_list): Set up `in_set_p'.
3853         (form_reservs_matter): New function.
3854         (make_automaton): Call the function and use the mask.
3855         (estimate_one_automaton_bound): Take `min_occ_cycle_num' into
3856         account.
3857
3858         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
3859
3860         * config/ia64/itanium2.md (lfetch): Change the insn reservation.
3861
3862         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
3863
3864         * config/ia64/ia64.c (bundling): Try to insert 2 nops for M insn
3865         for Itanium.
3866
3867         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
3868
3869         * config/ia64/ia64.c (ia64_override_options): Make itanium2 as
3870         default cpu.
3871
3872         2002-12-17  Vladimir Makarov  <vmakarov@redhat.com>
3873                 2002-10-31  Dale Johannesen <dalej@apple.com>
3874
3875         * haifa-sched.c (find_set_reg_weight): New function.
3876         (find_insn_reg_weight): Use the new function.
3877         (schedule_block): Do sorting ready queue always
3878         after insn issue.
3879
3880         2002-11-27  Vladimir Makarov  <vmakarov@redhat.com>
3881
3882         * config/ia64/ia64.c (bundling): Use MFI template instead of MLX.
3883
3884         2002-11-19  Vladimir Makarov  <vmakarov@redhat.com>
3885
3886         * haifa-sched.c (choice_entry): New structure.
3887         (choice_stack, cycle_issued_insns): New variables.
3888         (max_issue): Rewrite it.
3889         (choose_ready): Set up ready_try for unknown insns too.
3890         (schedule_block): Allocate and free choice_stack.  Set up
3891         and modify cycle_issued_insns.
3892
3893         * config/ia64/ia64.c (issue_nops_and_insn): Combine insn issue
3894         with and without filling the bundle.
3895         (bundling): Combine calls of issue_nops_and_insn.
3896
3897         2002-10-17  Vladimir Makarov  <vmakarov@redhat.com>
3898
3899         * config/ia64/itanium1.md: New file.
3900
3901         * config/ia64/itanium2.md: New file.
3902
3903         * config/ia64/ia64.md: Move DFA descriptions into the new files.
3904         Remove the old pipeline description.
3905
3906         * config/ia64/ia64.c (ia64_override_options): Add aliases of
3907         itanium processor names.
3908
3909         2002-10-16  Vladimir Makarov  <vmakarov@redhat.com>
3910
3911         * config/ia64/ia64.c (bundling): Print states for Itanium2 too.
3912         (ia64_reorg):  Set up queried unit codes for Itanium2 too.
3913
3914         * config/ia64/ia64.md: Add descriptions for Itanium2.
3915
3916         2002-10-08  Vladimir Makarov  <vmakarov@redhat.com>
3917
3918         * config/ia64/ia64.h (processor_type): New enumeration.
3919         (ia64_tune, ia64_tune_string): New external declarations.
3920         (TARGET_OPTIONS): Add option `tune='.
3921
3922         * config/ia64/ia64.c (ia64_tune, ia64_tune_string): New global
3923         variables.
3924         (ia64_override_options): Set up `ia64_tune'.
3925         (ia64_sched_reorder2): Set up `clocks' only for Itanium.
3926         (ia64_dfa_new_cycle): Set up `add_cycles' only for Itanium.
3927         (bundling): Add nops for MM-insns only for Itanium.
3928         (ia64_reorg): Allocate and free `clocks' and `add_cycles' only for
3929         Itanium.
3930
3931         * config/ia64/ia64.md (cpu): New attribute.
3932         (DFA description): Enable it only for Itanium.
3933
3934         2002-10-08  Vladimir Makarov  <vmakarov@redhat.com>
3935                     Richard Henderson  <rth@redhat.com>
3936
3937         * config/ia64/ia64.h (MASK_TUNE_STOP_BITS): Rename it to
3938         MASK_EARLY_STOP_BITS.
3939         (TARGET_TUNE_STOP_BITS): Rename it to TARGET_EARLY_STOP_BITS.
3940         (TARGET_SWITCHES): Rename option `tune-stop-bits' to
3941         `early-stop-bits'.
3942
3943         * config/ia64/ia64.c (ia64_dfa_new_cycle,
3944         final_emit_insn_group_barriers): Use TARGET_EARLY_STOP_BITS
3945         instead of TARGET_TUNE_STOP_BITS.
3946
3947         * doc/invoke.texi: Rename option `-mtune-stop-bits' to
3948         `-mearly-stop-bits'.
3949
3950         * config/ia64/ia64.c (automata_option "v"): Comment it.
3951
3952         2002-10-07  Vladimir Makarov  <vmakarov@redhat.com>
3953
3954         * config/ia64/ia64.h (MASK_TUNE_STOP_BITS, TARGET_TUNE_STOP_BITS):
3955         New macros.
3956         (TARGET_SWITCHES): Add entries for the new option.
3957
3958         * config/ia64/ia64.c (dfa_stop_insn, last_scheduled_insn, rtx
3959         dfa_pre_cycle_insn, ia64_nop): Don't make them as roots for GC.
3960         (stops_p, stop_before_p, clocks_length, clocks, add_cycles): New
3961         global variables.
3962         (ia64_sched_reorder2): Set up `clocks'.
3963         (ia64_variable_issue): Set up `stops_p' and reset `stop_before_p'.
3964         (ia64_dfa_new_cycle): Set up add_cycle.  Permit sorting ready
3965         queue when TARGET_TUNE_STOP_BITS.
3966         (bundling): Insert additional nops for MM-insns.
3967         (final_emit_insn_group_barriers): Add insertion of stop bits
3968         according `stops_p'.
3969         (ia64_reorg): Initiate the new varibales.
3970
3971         * doc/invoke.texi: Add description of option `-mtune-stop-bits'.
3972
3973         2002-10-02  Vladimir Makarov  <vmakarov@redhat.com>
3974
3975         * haifa-sched.c (schedule_block): Modify INSN_TICK of depended
3976         insns at the end of block insn scheduling.
3977
3978         2002-09-30  Vladimir Makarov  <vmakarov@redhat.com>
3979
3980         * sched-deps.c (remove_dependence, group_leader): Remove it.
3981         (add_dependence): Add dependence to group leader to.
3982         (set_sched_group_p): Add dependence to the first insn of the
3983         schedule group too.
3984         (sched_analyze_insn): Make dependence to jump as anti-dependence.
3985         Change true dependence by anti-dependence when
3986         `reg_pending_barrier'.
3987
3988         * sched-rgn.c (init_ready_list, can_schedule_ready_p,
3989         add_branch_dependences): Ignore schedule groups.
3990
3991         * sched-ebb.c (init_ready_list): Ditto.
3992
3993         * (move_insn, set_priorities): Ditto.
3994
3995         * config/ia64/ia64.c (ia64_sched_init): Check that schedule group
3996         flag is clear after reload.
3997         (adjust_cost): Change cost only for output dependencies.
3998
3999         * config/ia64/ia64.md: Add more insns into bypass for MM-insns.
4000
4001         2002-09-26  Vladimir Makarov  <vmakarov@redhat.com>
4002
4003         * Makefile.in (sched-ebb.o): Add `$(TARGET_H)' to the entry.
4004
4005         * target.h (gcc_target): Add member
4006         `dependencies_evaluation_hook'.
4007
4008         * target-def.h (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK): New
4009         macro.
4010         (TARGET_SCHED): Add initiatialization of the new member.
4011
4012         * sched-ebb.c: Include `target.h'.
4013         (schedule_ebb): Call `dependencies_evaluation_hook'.
4014
4015         * sched-rgn.c (schedule_region): Call
4016         `dependencies_evaluation_hook'.
4017
4018         * config/ia64/ia64.c (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK):
4019         New macro.
4020         (ia64_dependencies_evaluation_hook): New function.
4021
4022         * doc/tm.texi (TARGET_SCHED_DEPENDENCIES_EVALUATION_HOOK):
4023         Describe the new hook.
4024
4025         2002-09-25  Vladimir Makarov  <vmakarov@redhat.com>
4026
4027         * target.h (gcc_target): Add members
4028         `first_cycle_multipass_dfa_lookahead_guard' and `dfa_new_cycle'.
4029
4030         * target-def.h (TARGET_SCHED_DFA_NEW_CYCLE,
4031         TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD): New
4032         macros.
4033         (TARGET_SCHED): Add initiatialization of the new members.
4034
4035         * haifa-sched.c (schedule_insn): Update last_clock_var for the 1st
4036         insn scheduling too.
4037         (choose_ready): Use `first_cycle_multipass_dfa_lookahead_guard' to
4038         initialize `ready_try'.
4039         (schedule_block): Use `dfa_new_cycle'.  Sort `ready' only unless
4040         `dfa_new_cycle' says not to do it.
4041
4042         * config/ia64/ia64.md: Add DFA Itanium 1 description for insn
4043         bundling.
4044
4045         * config/ia64/ia64.h (CPU_UNITS_QUERY): New macro.
4046
4047         * config/ia64/ia64.c: Include `hashtab.h'.
4048         (ia64_first_cycle_multipass_dfa_lookahead_guard,
4049         ia64_dfa_new_cycle, final_emit_insn_group_barriers,
4050         ia64_dfa_sched_reorder, get_free_bundle_state, free_bundle_state,
4051         initiate_bundle_states, finish_bundle_states, bundle_state_hash,
4052         bundle_state_eq_p, insert_bundle_state,
4053         initiate_bundle_state_table, finish_bundle_state_table,
4054         try_issue_nops, try_issue_insn, issue_nops_and_insn, get_max_pos,
4055         get_template, get_next_important_insn, bundling): New functions.
4056         (ia64_internal_sched_reorder): Remove it.
4057         (TARGET_SCHED_FIRST_CYCLE_MULTIPASS_DFA_LOOKAHEAD_GUARD,
4058         TARGET_SCHED_DFA_NEW_CYCLE): New macros.
4059         (ia64_safe_itanium_requires_unit0): Remove it.
4060         (group_barrier_needed_p): Place group barrier right before a real
4061         insn.
4062         (bundle, ia64_packet, NR_PACKETS, type_names, packets, packets):
4063         Remove them.
4064         (bundle_name): New variable.
4065         (_0mii_, _0mmi_, _0mfi_, _0mmf_, _0bbb_, _0mbb_, _0mib_, _0mmb_,
4066         _0mfb_, _0mlx_, _1mii_, _1mmi_, _1mfi_, _1mmf_, _1bbb_, _1mbb_,
4067         _1mib_, _1mmb_, _1mfb_, _1mlx_, pos_1, pos_2, pos_3, pos_4, pos_5,
4068         pos_6, dfa_stop_insn, last_scheduled_insn, dfa_state_size,
4069         temp_dfa_state, prev_cycle_state): New global variables.
4070         (insn_matches_slot, maybe_rotate, finish_last_head,