OSDN Git Service

dbcdf5495c6ad9c830163cc08ceae41b6aa996e2
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
1 2004-03-13  Dara Hazeghi  <dhazeghi@yahoo.com>
2
3         * doc/install.texi: Note status of -fnew-ra.
4
5 2004-03-13  Eric Botcazou  <ebotcazou@libertysurf.fr>
6
7         PR middle-end/14470
8         * expr.c (store_expr): Call emit_queue before generating the move
9         from the temporary to the original target.  Protect the temporary
10         from emit_queue.
11
12 2004-03-13  Jakub Jelinek  <jakub@redhat.com>
13
14         PR target/14533
15         * config/s390/s390.c (legitimize_pic_address): Don't abort on UNSPEC
16         other than UNSPEC_GOTOFF.
17
18 2004-03-13  Richard Earnshaw  <rearnsha@arm.com>
19
20         * arm.c (arm_legitimate_address_p): New argument, OUTER.  Pass through
21         to arm_legitimate_index_p.  Update all callers with SET as default
22         value.
23         (arm_legitimate_index_p): New argument, OUTER.  Restrict the index
24         range if OUTER is a sign-extend operation on QImode.  Correctly
25         reject shift operations on sign-extended QImode addresses.
26         (bad_signed_byte_operand): Delete.
27         (arm_extendqisi_mem_op): New function.
28         * arm.h (EXTRA_CONSTRAINT_ARM): Delete.  Replace with...
29         (EXTRA_CONSTRAINT_STR_ARM): ... this.  Handle extended address
30         constraints.
31         (CONSTRAINT_LEN): New.
32         (EXTRA_CONSTRAINT): Delete.  Replace with...
33         (EXTRA_CONSTRAINT_STR): ... this.
34         (PREDICATE_CODES): Remove bad_signed_byte_operand.
35         * arm.md (extendqihi_insn): Use new constraint Uq.  Rework.  Length
36         is now always default.
37         (define_splits for bad sign-extend loads): Delete.
38         (arm_extendqisi, arm_extendqisi_v5): Likewise.
39         * arm/vfp.md (arm_movsi_vfp, arm_movdi_vfp, movsf_vfp, movdf_vfp):
40         Rework 'U' constraint to 'Uv'.
41         * arm-protos.h: Remove bad_signed_byte_operand.  Add
42         arm_extendqisi_mem_op.
43         * doc/md.texi (ARM constraints): Rename VFP constraint (now Uv).
44         Add Uq constraint.
45
46 2004-03-13  Alan Modra  <amodra@bigpond.net.au>
47
48         * config/rs6000/rs6000.c (rs6000_va_arg): Replace SPLIT_COMPLEX_ARGS
49         with targetm version.
50
51         PR target/14567
52         * config/rs6000/rs6000.h (UNITS_PER_ARG, RS6000_ARG_SIZE): Delete.
53         (HARD_REGNO_MODE_OK): Disallow TFmode for fp31.
54         * config/rs6000/rs6000.c (rs6000_arg_size): New function.
55         Update all users of RS6000_ARG_SIZE.
56         (function_arg_advance): Count fregno using mode size.
57         (function_arg): Handle long double split over regs and memory.
58         (function_arg_partial_nregs): Likewise.
59         (rs6000_va_arg): Repackage complex args.
60
61 2004-03-13  Dean Ferreyra <dferreyra@igc.org>
62
63         PR target/14047
64         * config/avr/avr.c (avr_progmem_p): Add "attributes" parameter.
65         (avr_insert_attributes): Pass "attributes" to avr_progmem_p.
66         * config/avr/avr-protos.h (avr_progmem_p): Change prototype.
67
68 2004-03-12  Jakub Jelinek  <jakub@redhat.com>
69
70         * config/rs6000/rs6000-protos.h (rs6000_output_dwarf_dtprel): Add
71         prototype.
72         * config/rs6000/rs6000.c (rs6000_output_dwarf_dtprel): New.
73         * config/rs6000/rs6000.h (ASM_OUTPUT_DWARF_DTPREL): Define.
74
75 2003-03-12  Andrew Pinski  <apinski@apple.com>
76
77         * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_use_address):
78         Use ret instead of result. Use addr instead of base.
79
80 2004-03-12  David Edelsohn  <edelsohn@gnu.org>
81
82         * doc/install.texi (*-ibm-aix*): Document assembler and achiver
83         fixes required by libstdc++ and update installation instructions
84         for libstdc++.a.
85
86 2004-03-12  Danny Smith  <dannysmith@users.sourceforge.net>
87
88         * config/i386/winnt.c (i386_pe_strip_name_encoding_full): Strip
89         leading '@' on fastcall symbols before stripping suffix.
90
91 2004-03-12  Roger Sayle  <roger@eyesopen.com>
92
93         * combine.c (unmentioned_reg_p): New function to check whether an
94         expression is a "specialization" of another, i.e. that there are
95         no registers or memory references mentioned in the first that don't
96         appear in the second.
97         (unmentioned_reg_p_1): New helper subroutine of unmentioned_reg_p.
98         (combine_instructions): Also try combining instructions using the
99         REG_EQUAL note from a preceding log-linked instruction.
100
101 2004-03-12  Roger Sayle  <roger@eyesopen.com>
102
103         * config/i386/i386.c (ix86_split_ashrdi): Optimize shift by 63.
104
105 2004-03-12  Matt Austern  <austern@apple.com>
106
107         * target.h (struct gcc_target): New target hook, unwind_label.
108         * target-def.h (TARGET_ASM_EMIT_UNWIND_LABEL): New hook.
109         * output.h (default_emit_unwind_label): New function.
110         * default.h (TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY): New macro.
111         (TARGET_USES_WEAK_UNWIND_INFO): New target macro.
112         (TARGET_SUPPORTS_HIDDEN): New target macro.
113         * dwarf2out.c (struct dw_fde_struct): Add field for function decl
114         that corresponds to this FDE.
115         (FRAME_BEGIN_LABEL): Allow target to override default label.
116         (output_call_frame_info): If FDEs are linknonce, then use extra
117         indirection for FDE encoding, output a label for each FDE, and
118         output an empty label for each function without an FDE.
119         (dwarf2out_begin_prologue): Set up decl field when creating an FDE.
120         * varasm.c (globalize_decl): Call ASM_MAKE_LABEL_LINKONCE for
121         decls with DECL_ONE_ONLY set, if that macro is defined.
122         (make_decl_one_only): Don't use DECL_COMMON if we're compiling
123         for a SUPPORTS_ONE_ONLY target.
124         * config/darwin-protos.h (darwin_unique_section): Declare.
125         (darwin_asm_named_section): Likewise.
126         (darwin_section_type_flags): Likewise.
127         (darwin_non_lazy_pcrel): Likewise.
128         (darwin_emit_unwind_label): Likewise.
129         (darwin_make_decl_one_only): Likewise.
130         * config/darwin.c (machopic_finish): Get rid of tweak that
131         eliminate stubs for symbols that are defined.
132         (darwin_encode_section_info): Don't treat weak functions as defined.
133         (darwin_make_decl_one_only): Define.
134         (darwin_asm_named_section): Likewise.
135         (darwin_section_type_flags): Likewise.
136         (darwin_unique_section): Likewise.
137         (darwin_emit_unwind_label): Likewise.
138         (darwin_non_lazy_pcrel): Likewise.
139         (darwin_asm_output_dwarf_delta): Difference between two labels is
140         local only if both labels are local.
141         * config/darwin.h (MAKE_DECL_ONE_ONLY): Define.
142         (ASM_MAKE_LABEL_LINKONCE): Likewise.
143         (TARGET_SUPPORTS_HIDDEN): Likewise.
144         (TARGET_USES_WEAK_UNWIND_INFO): Likewise.
145         (TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY): Likewise.
146         (FRAME_BEGIN_LABEL): Likewise.
147         (ASM_DECLARE_OBJECT_NAME): Make references to weak symbols indirect.
148         (ASM_DECLARE_FUNCTION_NAME): Likewise.
149         (darwin_eh_frame_section): Give __eh_frame section the coalesced flag.
150         (TARGET_ASM_UNIQUE_SECTION): Define.
151         (EH_FRAME_SECTION_NAME): Define.
152         (EH_FRAME_SECTION_ATTR): Likewise.
153         (ASM_MAYBE_OUTPUT_ENCODED_ADDR_RTX): Likewise.
154         (TARGET_ASM_NAMED_SECTION): Likewise.
155         (TARGET_SECTION_TYPE_FLAGS): Likewise.
156         * doc/tm.texi: Document TARGET_USES_WEAK_UNWIND_INFO,
157         TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY, TARGET_SUPPORTS_HIDDEN,
158         TARGET_ASM_EMIT_UNWIND_LABEL.
159         
160 2004-03-12  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
161
162         * builtins.c (expand_builtin_mathfn): Add pow10* to the
163         existing exp10* case.
164         (expand_builtin): Likewise.
165
166 2004-03-12  Eric Botcazou  <ebotcazou@libertysurf.fr>
167
168         * doc/tm.texi (registers) <Values in Registers>: Add
169         entry for REGMODE_NATURAL_SIZE.
170
171 2004-03-12  Richard Henderson  <rth@redhat.com>
172
173         PR target/14547
174         * target.h (struct gcc_target): Move calls substructure before
175         booleans.  Add split_complex_arg.
176         * function.c (assign_parms, split_complex_args): Use it.
177         * calls.c (expand_call): Likewise.
178         (split_complex_values): Likewise.  Check for splittable types
179         before allocating memory.
180         (split_complex_types): Likewise.
181         * system.h (SPLIT_COMPLEX_ARGS): Poison.
182         * expr.h (SPLIT_COMPLEX_ARGS): Remove.
183         * target-def.h (TARGET_SPLIT_COMPLEX_ARG): New.
184         * config/alpha/alpha.c (alpha_split_complex_arg): New.
185         (TARGET_SPLIT_COMPLEX_ARG): New.
186         * config/alpha/alpha.h (SPLIT_COMPLEX_ARGS): Remove.
187         * config/rs6000/rs6000.c (TARGET_SPLIT_COMPLEX_ARG): New.
188         (rs6000_override_options): Zap it for non-AIX.
189         (rs6000_function_value): Use targetm.calls.split_complex_arg.
190         * config/rs6000/rs6000.h (SPLIT_COMPLEX_ARGS): Remove.
191         * config/xtensa/xtensa.c (TARGET_SPLIT_COMPLEX_ARG): New.
192         * config/xtensa/xtensa.h (SPLIT_COMPLEX_ARGS): Remove.
193         * doc/tm.texi (TARGET_SPLIT_COMPLEX_ARG): Modify from old
194         SPLIT_COMPLEX_ARGS entry.
195
196 2004-03-11  Richard Henderson  <rth@redhat.com>
197
198         * config/alpha/alpha.c (xfloating_ops, vax_cvt_ops): New.
199         (alpha_lookup_xfloating_lib_func): Use them, return rtx.
200         (alpha_emit_xfloating_arith): Update to match.
201         (alpha_emit_xfloating_compare): Likewise.
202         (alpha_emit_xfloating_cvt): Likewise.
203         (alpha_emit_xfloating_libcall): Take already built symbol,
204         mark call const.
205         * config/alpha/alpha.md (extendsftf2, extenddftf2): Take
206         op1 in a register.
207
208 2004-03-11  Richard Henderson  <rth@redhat.com>
209
210         PR target/14539
211         * config/alpha/alpha.h (STACK_BOUNDARY): Set to 128.
212
213         * simplify-rtx.c (simplify_relational_operation): Fix typo.
214
215 2004-03-11  Richard Henderson  <rth@redhat.com>
216
217         PR middle-end/14477
218         * except.c (remove_unreachable_regions): Look thru CALL_PLACEHOLDER.
219
220 2004-03-11  Ulrich Weigand  <uweigand@de.ibm.com>
221
222         PR target/14262
223         * calls.c (load_register_parameters): If BLOCK_REG_PADDING is not
224         defined, pass small BLKmode values in registers in the low-order part.
225
226 2004-03-11  Ulrich Weigand  <uweigand@de.ibm.com>
227
228         * combine.c (if_then_else_cond): Check for NULL return value of
229         simplify_gen_subreg.
230
231 2004-03-11  Richard Sandiford  <rsandifo@redhat.com>
232
233         PR target/14496
234         * config/mips/mips.h (UNITS_PER_FPVALUE): Fix value for
235         TARGET_SINGLE_FLOAT.
236
237 2004-03-11  Steve Ellcey  <sje@cup.hp.com>
238
239         * config/ia64/hpux.h (TARGET_INIT_LIBFUNCS): Add undef.
240         * config/ia64/ia64.h (TARGET_INIT_LIBFUNCS): Add define.
241         * config/ia64/ia64.c (ia64_init_libfuncs): New.
242         (ia64_hpux_init_libfuncs): Add call to ia64_init_libfuncs.
243
244 2004-03-11  Roger Sayle  <roger@eyesopen.com>
245
246         * fold-const.c (negate_expr_p) <RSHIFT_EXPR>: We can optimize
247         -((int)X>>C) where C is an integer constant one bit less than the
248         size of X into (unsigned)X>>C.  Similarly for unsigned->signed.
249         (negate_expr) <RSHIFT_EXPR>: Implement the above transformations.
250
251         * simplify-rtx.c (simplify_unary_operation): Also implement the
252         above transformations at the RTL level.
253
254 2004-03-11  Alan Modra  <amodra@bigpond.net.au>
255
256         * real.c (encode_ibm_extended): Do round low word.
257
258 2004-03-11  Ben Elliston  <bje@wasabisystems.com>
259
260         * config/arm/arm.md (is_xscale): Comment this attribute and move
261         it a bit further up in the file, closer to related attributes.
262
263 2004-03-11  Eric Botcazou  <ebotcazou@libertysurf.fr>
264
265         * config/host-solaris.c (sol_gt_pch_use_address): Add
266         missing terminating marker to comment.
267
268 2004-03-11  Richard Sandiford  <rsandifo@redhat.com>
269
270         * config/mips/mips.md: Use move_operand in splitters for 64-bit moves.
271         (movdi, movsi, movhi, movqi, movsf, movdf): Remove predicates.
272         (*movdi_32bit_mips16, *movsi_mips16, *movhi_mips16, *movqi_mips16)
273         (*movsf_mips16, *movdf_mips16):  Name unnamed patterns.  Use
274         move_operand as source predicate in all cases.
275         (*movdi_32bit): Renamed from movdi_internal.  Remove 'F' constraint.
276         Test reg_or_0_operand.  Use move_operand as source predicate.
277         (*movdi_64bit): Renamed from movdi_internal2.  Test reg_or_0_operand.
278         (*movdi_64bit_mips16): Renamed from movdi_internal2_mips16.
279         (*movsi_internal): Renamed from movsi_internal.  Test reg_or_0_operand.
280         (movhi, movqi, movsf, movdf): Use mips_legitimize_move.
281         (*movhi_internal): Renamed from movhi_internal.  Test reg_or_0_operand.
282         Use move_operand as source predicate.  Remove 'K' constraint.
283         (*movqi_internal): Likewise movqi_internal.
284         (*movsf_hardfloat): Renamed from movsf_internal1.  Test
285         reg_or_0_operand.  Use move_operand as source predicate.
286         (*movsf_softfloat): Likewise movsf_internal2.
287         (*movdf_hardfloat_64bit): Likewise movsf_internal1a.
288         (*movdf_hardfloat_32bit): Likewise movsf_internal1b.
289         (*movdf_softfloat): Likewise movdf_internal2.
290         * config/mips/mips.c (move_operand): Match arbitrary CONST_INTs
291         for DImode if !TARGET_64BIT.
292         (mips_legitimize_move): Simplify accordingly.
293
294 2004-03-11  Josef Zlomek  <zlomekj@suse.cz>
295
296         PR/14362
297         * var-tracking.c (struct variable_def): Added field refcount.
298         (variable_htab_free): Decrease the refcount and delete variable
299         only if there are no more references.
300         (unshare_variable): New function.
301         (vars_copy_1): Increase refcount instead of copying the variable.
302         (variable_union): Share the variables where possible, unshare
303         the variables if needed.
304         (variable_different_p): Return false if var1 and var2 are
305         the same structure.
306         (variable_was_changed): Init the refcount of new variable.
307         (set_frame_base_location): Unshare variable if needed.
308         (set_variable_part): Init the refcount of new variable.
309         Unshare the variables if needed.
310         (delete_variable_part): Unshare the variables if needed.
311         (emit_notes_for_differences_1): Init the refcount of new variable.
312         (vt_add_function_parameters): Do not add function parameters to
313         IN set of ENTRY_BLOCK_PTR because it is unused anyway.
314         (vt_initialize): Do not add frame_base_decl to IN set of
315         ENTRY_BLOCK_PTR because it is unused anyway.
316
317 2004-03-11  Josef Zlomek  <zlomekj@suse.cz>
318
319         * var-tracking.c (vars_copy_1): Cleanup and speedup chain operations.
320         (vars_copy): Likewise.
321         (variable_union): Likewise.
322         (set_variable_part): Likewise.
323         (delete_variable_part): Likewise.
324
325 2004-03-11  Kazu Hirata  <kazu@cs.umass.edu>
326
327         * c-typeck.c, combine.c, cse.c, dominance.c, et-forest.h,
328         ggc-page.c, var-tracking.c, config/fp-bit.c, config/c4x/c4x.c,
329         config/cris/cris.c, config/i386/ppro.md, config/i860/i860.c,
330         config/i860/i860.h, config/m32r/m32r.h, config/m32r/xm-m32r.h,
331         config/m68hc11/m68hc11.h, config/m68hc11/m68hc11.md,
332         config/mips/mips.c, config/mmix/mmix.c, config/ns32k/ns32k.h,
333         config/pa/pa.c, config/pa/pa32-regs.h, config/pa/pa64-regs.h,
334         config/pdp11/pdp11.h, config/rs6000/rs6000.c,
335         config/stormy16/stormy16.c: Fix comment typos and formatting.
336
337 2004-03-11  Nathanael Nerode  <neroden@gcc.gnu.org>
338
339         * configure: Regenerate, since I forgot to while committing Paolo's
340         changes.
341
342 2004-03-08  Paolo Bonzini  <bonzini@gnu.org>
343
344         PR ada/14131
345         Move language detection to the top level.
346         * configure.ac: Remove code to detect languages,
347         it now lives exclusively in the top level.
348         * aclocal.m4 (gcc_AC_PROG_GNAT): Moved to the
349         top level, renamed to ACX_PROG_GNAT.
350
351 2004-03-10  Richard Henderson  <rth@redhat.com>
352
353         * c-pch.c (c_common_no_more_pch): Update for gt_pch_use_address
354         extra arguments.
355         * config.host (*-*-solaris2*, *-*-linux*): Add out_host_hook_obj
356         and host_xmake_file fragments.
357         * ggc-common.c (gt_pch_save): Update for gt_pch_get_address change.
358         (gt_pch_restore): Similarly for gt_pch_use_address.
359         (default_gt_pch_get_address): New.
360         (mmap_gt_pch_get_address): Split out of gt_pch_save.
361         (default_gt_pch_use_address): Split out of gt_pch_restore.
362         (mmap_gt_pch_use_address): Likewise.
363         * hooks.c (hook_voidp_size_t_null): Remove.
364         (hook_bool_voidp_size_t_false): Remove.
365         * hooks.h: Likewise.
366         * hosthooks-def.h (HOST_HOOKS_GT_PCH_GET_ADDRESS): Use one of the
367         default_ or mmap_ definitions.
368         (HOST_HOOKS_GT_PCH_USE_ADDRESS): Likewise.
369         * hosthooks.h (struct host_hooks): Update gt_pch_get_address
370         and gt_pch_use_address.
371         * config/host-linux.c, config/host-solaris.c: New files.
372         * config/x-linux, config/x-solaris: New files.
373         * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_get_address): 
374         Update for changed definition.
375         (darwin_rs6000_gt_pch_use_address): Likewise.
376         * doc/hostconfig.texi: Update docs.
377
378 2004-03-10  Richard Henderson  <rth@redhat.com>
379
380         PR c/14517
381         * c-decl.c (grokdeclarator): Don't warn for duplicate qualifiers
382         except for pedantic c90 mode.
383
384 2004-03-10  Kelley Cook  <kcook@gcc.gnu.org>
385
386         * configure.ac: Bump AC_PREREQ to 2.59.
387         * configure: Regenerate.
388
389 2004-03-10  Uros Bizjak  <uros@kss-loka.si>
390
391         * optabs.h (enum optab_index): Add new OTI_exp10 and OTI_exp2.
392         (exp10_optab, exp2_optab): Define corresponding macros.
393         * optabs.c (init_optabs): Initialize exp10_optab and exp2_optab.
394         * genopinit.c (optabs): Implement exp10_optab and exp2_optab
395         using exp10?f2 and exp2?f2 patterns.
396         * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_EXP10{,F,L}
397         using exp10_optab, and BUILT_IN_EXP2{,F,L} using exp2_optab.
398         (expand_builtin): Expand BUILT_IN_EXP10{,F,L} and BUILT_IN_EXP2{,F,L}
399         using expand_builtin_mathfn if flag_unsafe_math_optimizations is set.
400
401         * config/i386/i386.md (exp10sf2, exp10df2, exp10xf2, exp2sf2,
402         exp2df2, exp2xf2): New patterns to implement exp10, exp10f, exp10l,
403         exp2, exp2f and exp2l built-ins as inline x87 intrinsics.
404
405 2004-03-10  Anthony Green  <green@redhat.com>
406
407         * doc/invoke.texi (ARM Options): Fix -mpfu typo.
408
409 2004-03-10  David Edelsohn  <edelsohn@gnu.org>
410
411         * config/rs6000/aix.h (TARGET_OS_CPP_BUILTINS): Rename to ...
412         (TARGET_OS_AIX_CPP_BUILTINS): this.  Conditionally define
413         __LONGDOUBLE128.
414         * config/rs6000/aix41.h (TARGET_OS_CPP_BUILTINS): Use
415         TARGET_OS_AIX_CPP_BUILTINS.
416         * config/rs6000/aix43.h (TARGET_OS_CPP_BUILTINS): Same.
417         * config/rs6000/aix51.h (TARGET_OS_CPP_BUILTINS): Same.
418         * config/rs6000/aix52.h (TARGET_OS_CPP_BUILTINS): Same.
419         * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Revert
420         previous change.
421
422 2004-03-10  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
423
424         * fold-const.c (tree_expr_nonnegative_p): Add more builtin cases.
425
426 2004-03-10  David Edelsohn  <edelsohn@gnu.org>
427
428         * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Define
429         __LONGDOUBLE128 on AIX.
430
431 2004-03-10  Andrew Haley  <aph@redhat.com>
432
433         PR optimization/14381
434         * function.c (expand_function_end): Emit a blockage insn before
435         the epilogue when -fnon-call-exceptions is used.
436
437         * except.c (expand_start_all_catch): Make comment more accurate.
438
439 2004-03-08  Joel Sherrill  <joel@oarcorp.com>
440
441         PR target/14480
442         * config/rs6000/t-rtems: Add missing file on branch.
443
444 2004-03-10  Ulrich Weigand  <uweigand@de.ibm.com>
445
446         * dbxout.c (dbxout_symbol_location): Do not output references
447         to optimized-out constant pool symbols.
448
449 2004-03-10  Andreas Schwab  <schwab@suse.de>
450
451         * config/ia64/ia64.md (divsi3, udivsi3): Remove unused variable
452         twon34_r.
453
454 2004-03-09  James E Wilson  <wilson@specifixinc.com>
455
456         * alias.c (alias_sets_might_conflict_p): New.
457         * c-typeck.c (build_c_cast): Call it if warn_strict_aliasing > 1.
458         * common.opt (Wstrict-aliasing=): New.
459         * flags.h (warn_strict_aliasing): Change type to int.
460         * opts.c (warn_strict_aliasing): Change type to int.
461         (common_handle_option): Handle OPT_Wstrict_aliasing_.
462         * tree.h (alias_sets_might_conflict_p): Declare it.
463         * doc/invoke.tex (-Wstrict-aliasing=2): Document it.
464
465 2004-03-10  Roman Zippel  <zippel@linux-m68k.org>
466
467         PR bootstrap/12371
468         * config/m68k/m68k.h (FIXED_REGISTERS): Add arg pointer.
469         (CALL_USED_REGISTERS): Likewise.
470         (REG_CLASS_CONTENTS): Likewise.
471         (REG_ALLOC_ORDER): New.
472         (REGNO_REG_CLASS): Use regno_reg_class.
473         * config/m68k/m68k.c: Add regno_reg_class array.
474
475 2004-03-09  Steve Ellcey  <sje@cup.hp.com>
476
477         * config/ia64/ia64.md (divsi3): Fix algorithm.
478           (udivsi3): Ditto.
479           (setf_exp_xf): Remove '*' from name.
480         * testsuite/gcc.dg/20040309-1.c: New test.
481
482 2004-03-09  Ian Lance Taylor  <ian@wasabisystems.com>
483
484         * system.h (SUNOS4_SHARED_LIBRARIES): Poison.
485         * collect2.c: Remove SUNOS4_SHARED_LIBRARIES code.
486         * config/sparc/aout.h (TARGET_ASM_SELECT_SECTION): Don't define.
487         * config/sparc/sparc.c (sparc_aout_select_section): Remove.
488         (sparc_aout_select_rtx_section): Don't check
489         SUNOS4_SHARED_LIBRARIES.
490         * config/sparc/sparc.h (SUNOS4_SHARED_LIBRARIES): Don't define.
491
492 2004-03-10  Hans-Peter Nilsson  <hp@axis.com>
493
494         PR other/14474
495         * doc/md.texi (Pattern Ordering, Dependent Patterns)
496         (Jump Patterns, Looping Patterns): Wrap in separate "@ifset
497         INTERNALS".
498
499 2004-03-09  Zack Weinberg  <zack@codesourcery.com>
500
501         * config/ia64/hpux.h (MULTILIB_DEFAULTS): Define.
502         (LIBGCC_SPEC): Update to match.
503
504 2004-03-09  Zack Weinberg  <zack@codesourcery.com>
505
506         * c-decl.c (last_function_parms, last_function_parm_tags)
507         (last_function_parm_others, current_function_parms)
508         (current_function_parm_tags, current_function_parm_others):
509         Delete.
510         (ARG_INFO_PARMS, ARG_INFO_TAGS, ARG_INFO_TYPES, ARG_INFO_OTHERS):
511         New macros.
512         (grokdeclarator): For function definitions, save the arg-info
513         block from the declarator in DECL_ARGUMENTS.
514         (grokparms): Do not write to last_function_parm*.  Use ARG_INFO_*
515         macros to operate on arg-info block.  Can assume ARG_INFO_PARMS
516         contains only PARM_DECLs.  Improve diagnostics.
517         (get_parm_info): Use ARG_INFO_* macros.  Improve comments and
518         diagnostics.  Disable some expensive checks if not ENABLE_CHECKING.
519         (store_parm_decls_newstyle): Take the function to operate on,
520         and an arg-info block, as arguments; don't get anything from
521         current_function_* globals.
522         (store_parm_decls_oldstyle): Likewise.
523         (store_parm_decls): Pass fndecl and its arg-info block down to
524         store_parm_decls_newstyle/oldstyle.  Send functions with empty
525         argument lists through store_parm_decls_newstyle to reduce
526         overhead.
527         (pushdecl): Comment on the problems with the call to copy_node.
528         Clear DECL_ARGUMENTS of the old node after copying it, if it
529         is an arg-info block instead of a chain of decls.
530         (start_function): Do not manipulate current_function_parm* or
531         last_function_parm*.
532
533 2004-03-09  Roger Sayle  <roger@eyesopen.com>
534             Andrew Pinski  <pinskia@physics.uc.edu>
535
536         * ifcvt.c (noce_try_sign_mask): New function to transform
537         "x = (y < 0) ? z : 0" into the equivalent "x = (y >> C) & z".
538         (noce_process_if_block): Call noce_try_sign_mask.
539
540 2004-03-09  Andrew Pinski  <apinski@apple.com>
541
542         * c-typeck.c (tagged_types_tu_compatible_p):
543         Fix typo.
544
545 2004-03-09  Roger Sayle  <roger@eyesopen.com>
546
547         * simplify-rtx.c (simplify_const_relational_operation): New function
548         renamed from simplify_relational_operation.
549         (simplify_relational_operation): Change prototype to accept an
550         additional mode argument.  Call simplify_const_relational_operation.
551         (simplify_gen_relational): Update simplify_relational_operation call.
552         (simplify_ternary_operation): Update simplify_relational_operation
553         subroutine call to use simplify_const_relational_operation instead.
554
555         * rtl.h (simplify_const_relational_operation): Prototype here.
556         (simplify_relational_operation): Add addtional mode argument.
557
558         * combine.c (combine_simplify_rtx): Update calls to
559         simplify_relational_operation.
560         (simplify_set): Likewise.
561         (gen_binary): Likewise.
562         * cse.c (fold_rtx): Likewise.
563         * dojump.c (compare_from_rtx): Likewise.
564         (do_compare_rtx_and_jump): Likewise.
565         * integrate.c (subst_constants): Likewise.
566         * unroll.c (simplify_cmp_and_jump_insns): Likewise.
567
568 2004-03-09  Kazu Hirata  <kazu@cs.umass.edu>
569
570         * config/m32r/m32r.md: Remove all define_peephole's.
571
572 2004-03-09  Alan Modra  <amodra@bigpond.net.au>
573
574         * config/rs6000/rs6000.md: Remove trailing whitespace.
575
576 2004-03-08  Eric Christopher  <echristo@redhat.com>
577
578         * Makefile.in (site.exp): Add libiconv variable definition.
579
580 2004-03-09  Hans-Peter Nilsson  <hp@axis.com>
581
582         * configure: Regenerate for config/accross.m4 correction.
583
584 2004-03-08  Joel Sherrill  <joel@oarcorp.com>
585
586         PR target/14480
587         * config/rs6000/t-rtems: Add missing file on branch.
588
589 2004-03-08  Roger Sayle  <roger@eyesopen.com>
590
591         PR middle-end/14289
592         * c-typeck.c (c_mark_addressable): A register variable should
593         be considered global if its not automatic, i.e. TREE_PUBLIC,
594         TREE_STATIC or DECL_EXTERNAL.
595         * function.c (put_var_into_stack): Call abort when placing a
596         hard register into the stack, if x_parm_reg_stack_loc is NULL.
597
598 2004-03-08  Ulrich Weigand  <uweigand@de.ibm.com>
599
600         * config/s390/s390.md ("*extendqidi2_short_displ"): Add CC clobber.
601         ("*extendqisi2_short_displ"): Likewise.
602
603 2004-03-08  Kazu Hirata  <kazu@cs.umass.edu>
604
605         * config/pdp11/pdp11.c (comparison_operator_index): Remove.
606         (comp_operator): Likewise.
607         * config/pdp11/pdp11-protos.h: Remove corresponding
608         prototypes.
609
610 2004-03-08  Eric Botcazou  <ebotcazou@act-europe.fr>
611
612         * expr.c (highest_pow2_factor_for_type): Rename into
613         highest_pow2_factor_for_target.  Use DECL_ALIGN instead of
614         TYPE_ALIGN when the target is a COMPONENT_REF.
615         (expand_assignment): Ajust call to highest_pow2_factor_for_type.
616
617 2004-03-08  Alan Modra  <amodra@bigpond.net.au>
618
619         * config/rs6000/rs6000.c: Formatting fix.
620         (legitimate_offset_address_p): Correct offset range check.
621
622         * config/rs6000/rs6000.c (rs6000_override_options): Don't override
623         -msoft-float by -mcpu.  Consolidate similar code for MASK_MULTIPLE
624         and MASK_STRING.
625
626 2004-03-07  Aldy Hernandez  <aldyh@redhat.com>
627
628         * config/rs6000/rs6000.md (ashrdi3): Do not call ashrdi3_no_power
629         for little endian.
630         ("ashrdi3_no_power"): Disable for little endian.
631         (ashrdi3): Same.
632
633 2004-03-07  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
634
635         * fold-const.c (tree_expr_nonnegative_p): Reformat checks for
636         builtins.
637
638 2004-03-08  Hans-Peter Nilsson  <hp@axis.com>
639
640         PR target/14471
641         * configure.ac (Target-specific assembler checks) <cris-*-*>: New
642         case, checking for -no-mul-bug-abort option.
643         * configure, config.in: Regenerate.
644         * doc/invoke.texi (CRIS Options): Document -mmul-bug-workaround
645         and -mno-mul-bug-workaround.
646         * config/cris/cris.md ("smulsi3_highpart", "umulsi3_highpart")
647         ("mulsidi3", "umulsidi3"): Prefix output template with "%!".
648         ("umulhisi3", "umulqihi3", "mulsi3", "mulqihi3", "mulhisi3"):
649         Ditto.  Make attribute "slottable" dependent on TARGET_MUL_BUG.
650         * config/cris/mulsi3.asm (__Mul) [__CRIS_arch_version >= 10]: Make
651         sure mulu.d is not last on cache-line.
652         * config/cris/cris.h (ASM_SPEC): Translate -mno-mul-bug-workaround
653         into -no-mul-bug-abort depending on HAVE_AS_MUL_BUG_ABORT_OPTION.
654         (TARGET_MASK_MUL_BUG, TARGET_MUL_BUG): New macros.
655         (TARGET_SWITCHES): New options -mmul-bug-workaround and
656         -mno-mul-bug-workaround.
657         (TARGET_DEFAULT): Include TARGET_MASK_MUL_BUG.
658         (PRINT_OPERAND_PUNCT_VALID_P): Include '!'.
659         * config/cris/cris.c (cris_operand_extend_operator): Clarify
660         relation to MULT in head comment.
661         (cris_op_str): Abort for MULT.
662         (cris_print_operand) <case '!'>: New case.
663
664 2004-03-08  Alan Modra  <amodra@bigpond.net.au>
665
666         PR debug/11983
667         * dwarf2out.c (enum dw_val_class): Rename dw_val_class_float to
668         dw_val_class_vec.  Replace use throughout file.
669         (dw_float_const): Delete.
670         (dw_vec_const): New.
671         (dw_val_struct_union): Rename val_float to val_vec.  Replace use
672         throughout file.
673         (add_AT_vec): Rename from add_AT_float.  Add elt_size param.
674         (same_dw_val_p): Adjust vec comparison.  Use memcmp.
675         (size_of_die): Adjust dw_val_class_vec sizing.
676         (output_die): Output dw_val_class_vec.
677         (insert_int, extract_int, insert_float): New functions.
678         (add_const_value_attribute): Use insert_float for CONST_DOUBLE.
679         Handle CONST_VECTOR.
680         (add_location_or_const_value_attribute): Handle CONST_VECTOR.
681
682 2004-03-07  Aldy Hernandez  <aldyh@redhat.com>
683
684         * config/rs6000/rs6000.c (rs6000_parse_abi_options): SPE and
685         AltiVec abi cannot co-exist.
686
687         * config/rs6000/eabispe.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Same.
688
689 2004-03-07  Jan Hubicka  <jh@suse.cz>
690
691         * except.c (emit_to_new_bb_before):  Break fallthru edges.
692
693 2004-03-07  Stephane Carrez  <stcarrez@nerim.fr>
694
695         * config/m68hc11/m68hc11.md ("*lshrsi3_const"): Disable for 68HC12.
696         ("*lshrsi3"): Also accept an immediate for 68HC12.
697         ("*ashrsi3_const"): Likewise.
698         ("*ashrsi3"): Likewise.
699         ("*ashlsi3_const"): Likewise.
700         ("*ashlsi3"): Likewise.
701         ("cmphi_1_hc12"): Compare two hard register by pushing them and
702         comparing with a pop; don't use a split for that.
703         ("cmphi split"): Disable compare split for 68HC12.
704
705         * config/m68hc11/m68hc11.c (m68hc11_notice_update_cc): Invalidate
706         the status operands if they have side effects.
707
708 2004-03-07  Kazu Hirata  <kazu@cs.umass.edu>
709
710         * defaults.h (LEGITIMIZE_ADDRESS): Provide a default
711         definition.
712         * config/arc/arc.h, config/fr30/fr30.h, config/frv/frv.h,
713         config/h8300/h8300.h, config/ia64/ia64.h,
714         config/mcore/mcore.h, config/mmix/mmix.h,
715         config/ns32k/ns32k.h, config/pdp11/pdp11.h,
716         config/stormy16/stormy16.h, config/v850/v850.h,
717         config/vax/vax.h (LEGITIMIZE_ADDRESS): Remove.
718         * doc/tm.texi (LEGITIMIZE_ADDRESS): Mention the default
719         definition.
720
721 2004-03-07  Roger Sayle  <roger@eyesopen.com>
722
723         * fold-const.c (fold) <IOR_EXPR>: Fold x | x as x.
724         <XOR_EXPR>: Fold x ^ x as zero.
725         <AND_EXPR>: Fold x & x as x.
726
727 2004-03-07  Roger Sayle  <roger@eyesopen.com>
728
729         * fold-const.c (fold) <EQ_EXPR>: Rewrite optimization to transform
730         "foo++ == const" into "++foo == const+incr".
731
732 2004-03-07  Richard Sandiford  <rsandifo@redhat.com>
733
734         * config/mips/mips.c (mips_in_small_data_p): Return false if
735         TARGET_ABICALLS.
736
737 2004-03-06  Stephane Carrez  <stcarrez@nerim.fr>
738
739         * config/m68hc11/m68hc11.c (m68hc11_gen_movhi): Use 2,-sp to push
740         the stack register.
741         (expand_prologue): Don't make an interrupt or a trap handler a far
742         symbol.
743         (m68hc11_initial_elimination_offset): Likewise.
744
745 2004-03-06  Richard Henderson  <rth@redhat.com>
746
747         * config/alpha/alpha.c (alpha_in_small_data_p): False for functions.
748
749 2004-03-06  Kazu Hirata  <kazu@cs.umass.edu>
750
751         * config/ns32k/ns32k-protos.h: Add a prototype for
752         ns32k_notice_update_cc.
753         * config/ns32k/ns32k.c (ns32k_notice_update_cc): New.
754         * config/ns32k/ns32k.h (NOTICE_UPDATE_CC): Call
755         ns32k_notice_update_cc.
756
757 2004-03-06  Ulrich Weigand  <uweigand@de.ibm.com>
758
759         * config/s390/s390.md ("load_multiple", "*load_multiple_di",
760         "*load_multiple_si"): Allow only if reload_completed.
761         ("store_multiple", "*store_multiple_di", "*store_multiple_si"):
762         Likewise.
763
764 2004-03-06  Kazu Hirata  <kazu@cs.umass.edu>
765
766         * config/vax/vax-protos.h: Add a prototype for
767         vax_notice_update_cc.
768         * config/vax/vax.c (vax_notice_update_cc): New.
769         * config/vax/vax.h (NOTICE_UPDATE_CC): Call
770         vax_notice_update_cc.
771
772 2004-03-06  David Edelsohn  <edelsohn@gnu.org>
773
774         * collect2.c (main): Only export initfunc and finifunc if
775         LD_INIT_SWITCH not defined.
776         (scan_prog_file): Only export constructors and destructors if
777         LD_INIT_SWITCH not defined.  Only export symbols not found in
778         shared objects.
779
780 2004-03-06  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
781
782         * pa.md (icacheflush): Reorder operands to make match_scratch operand
783         last.
784         * pa.h (INITIALIZE_TRAMPOLINE): Remove unnecessary scratch argument
785         from calls to gen_icacheflush.
786
787 2004-03-06  Richard Henderson  <rth@redhat.com>
788
789         * config/alpha/alpha.h (MASK_LONG_DOUBLE_128): New.
790         (TARGET_LONG_DOUBLE_128): New.
791         (TARGET_SWITCHES): Add long-double-{128,64}.
792         (TARGET_HAS_XFLOATING_LIBS): Default to TARGET_LONG_DOUBLE_128.
793         (LONG_DOUBLE_TYPE_SIZE): Honor TARGET_LONG_DOUBLE_128.
794         (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): New.
795         (WIDEST_HARDWARE_FP_SIZE): New.
796         (TARGET_CPU_CPP_BUILTINS): Define __LONG_DOUBLE_128__.
797         * config/alpha/alpha.c (override_options): Clear MASK_LONG_DOUBLE_128
798         if TARGET_VAX_FLOAT.
799         * config/alpha/osf5.h (LONG_DOUBLE_TYPE_SIZE): Remove.
800         (TARGET_DEFAULT): Set MASK_LONG_DOUBLE_128.
801
802 2004-03-06  Richard Henderson  <rth@redhat.com>
803
804         * config/alpha/alpha.c (alpha_swapped_comparison_operator): Fix
805         botched rtx class conversion.
806
807 2004-03-06  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
808
809         * tree.h (BUILTIN_EXP10_P, BUILTIN_EXPONENT_P, BUILTIN_SQRT_P,
810         BUILTIN_CBRT_P, BUILTIN_ROOT_P): New macros.
811
812         * builtins.c (fold_builtin_logarithm, fold_builtin): Use new
813         macros.
814         * fold-const.c (fold_mathfn_compare, fold): Likewise.
815
816 2004-03-06  Eric Botcazou  <ebotcazou@libertysurf.fr>
817
818         PR target/14343
819         * config/i386/i386.md (movv2di_internal): Conditionalize on
820         TARGET_SSE, not TARGET_SSE2.
821
822 2004-03-05  Chris Demetriou  <cgd@broadcom.com>
823
824         * config.gcc (mips64orion-*-elf*, mips64orionel-*-elf*): Delete
825         duplicated line.
826
827 2004-03-05  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
828
829         * builtins.c: Consistently use logN not log* in comments.
830
831 2004-03-05  Andreas Krebbel  <krebbel1@de.ibm.com>
832
833         * rtl.h (mem_expr_equal_p): Function prototype added.
834         * cfgcleanup.c (merge_memattrs): New function.
835         (flow_find_cross_jump): Call merge_memattrs for matching insns.
836         * emit-rtl.c (mem_expr_equal_p): New function.
837
838 2004-03-05  Ziemowit Laski  <zlaski@apple.com>
839
840         * objc/objc-act.c (synth_module_prologue): Const-qualify
841         objc_selector type if using the GNU runtime; fix generated
842         signatures for objc_msg_lookup and objc_msg_lookup_super
843         to match what GNU ObjC headers provide; reformat and clean up.
844         (synth_self_and_ucmd_args): Use previously constructed (and
845         hence possibly const-qualified) objc_selector type.
846
847 2004-03-05  Kazu Hirata  <kazu@cs.umass.edu>
848
849         * doc/tm.texi (HARD_REGNO_RENAME_OK): Document.
850
851 2004-03-05  Jason Merrill  <jason@redhat.com>
852
853         * tree.h (TYPE_HASH): Use TYPE_UID.
854         (TREE_HASH): New macro with old definition of TYPE_HASH.
855         * tree.c (build_type_attribute_variant): Use iterative_hash_object.
856         (build_array_type, build_function_type): Likewise.
857         (build_method_type_directly): Likewise.
858         (build_offset_type, build_complex_type): Likewise.
859         (type_hash_list, attribute_hash_list): Likewise. Now static.
860         * except.c: s/TYPE_HASH/TREE_HASH/.
861
862 2004-03-05  Bob Wilson  <bob.wilson@acm.org>
863
864         * config/xtensa/xtensa.c (function_arg): Handle 16-byte aligned args.
865         (xtensa_va_start): Initialize __va_stk to ($arg_ptr - 32).  Adjust
866         __va_ndx by 2 words when referencing an argument on the stack.
867         (xtensa_va_arg): Handle 16-byte aligned args.  Adjust __va_ndx by 2
868         words when an arg on the stack is first seen.
869
870 2004-03-05  Paul Brook  <paul@codesourcery.com>
871
872         * arm.h (ARM_FLAG_VFP): Remove.
873         (ARM_FLAG_ATPCS, CIRRUS_FIX_INVALID_INSNS): Renumber.
874         * netbsd-elf.h (ARM_FLAG_VFP): Remove.
875
876 2004-03-05  Paul Brook  <paul@codesourcery.com>
877
878         * function.c (assign_parms): Include pretend alignment offset.
879
880 2004-03-05  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
881
882         * stor-layout.c (layout_type, case FUNCTION_TYPE): Make size
883         FUNCTION_BOUNDARY, not POINTER_SIZE * 2.
884
885 2004-03-05  Ian Lance Taylor  <ian@wasabisystems.com>
886
887         * configure.ac: When passing --enable-languages to subdir
888         configure when host != build, make sure we don't pass an empty
889         value.
890         * configure: Regenerate.
891
892 2004-03-05  Nathan Sidwell  <nathan@codesourcery.com>
893
894         PR 13577
895         * gcc.c (cc1_options): Robustify -auxbase-strip from multiple -o
896         options.
897
898 2004-03-05  Paolo Bonzini  <bonzini@gnu.org>
899
900         * simplify-rtx.c (simplify_relational_operation): If
901         flag_wrapv is set, do not move terms between the two
902         side of a relational operator.
903
904 2004-03-05  Paolo Bonzini  <bonzini@gnu.org>
905
906         * rtlanal.c: Include target.h and output.h
907         (rtx_cost, address_cost, default_address_cost): Move from...
908         * cse.c (rtx_cost, address_cost, default_address_cost):
909         ... this file.
910         * rtl.h (rtx_cost, address_cost): Move under rtlanal.c.
911         * Makefile.in: Adjust dependencies.
912
913 2004-03-05  Paolo Bonzini <bonzini@gnu.org>
914
915         * cse.c (cse_end_of_basic_block): Make static.
916         * local-alloc.c (function_invariant_p): Move to
917         reload1.c.
918         * loop.c (libcall_other_reg, record_excess_regs):
919         Make static.
920         * reload1.c (function_invariant_p): Moved here
921         from local-alloc.c, made static.
922         * rtl.h (cse_end_of_basic_block, function_invariant_p,
923         libcall_other_reg, record_excess_regs): Remove
924         declarations.
925
926 2004-03-05  Kazu Hirata  <kazu@cs.umass.edu>
927
928         * config/m32r/m32r.c (signed_comparison_operator): Add a
929         missing parenthesis.
930
931 2004-03-04  Ian Lance Taylor  <ian@wasabisystems.com>
932
933         * ggc-common.c (gt_pch_restore): Don't unmap addr unless we are
934         going to call mmap again.  Read the file into the right place.
935         Give a fatal error if we have to relocate.
936
937 2004-03-04  Bob Wilson  <bob.wilson@acm.org>
938
939         * config/xtensa/xtensa.c (xtensa_return_in_msb): New function.
940         (TARGET_RETURN_IN_MSB): Define to xtensa_return_in_msb.
941
942 2004-03-05  Hans-Peter Nilsson  <hp@axis.com>
943
944         PR other/14354
945         * config/fp-bit.c (_fpdiv_parts): Do not round when pack_d would
946         round the same.  When rounding, clear bits that would cause a
947         second rounding in pack_d.
948         (_fpmul_parts): Ditto.  Remove #if 0:d code.
949
950 2004-03-04  Ziemowit Laski  <zlaski@apple.com>
951
952         PR c++/14425, c++/14426
953         * config/rs6000/altivec.h (vec_splat_s8, vec_splat_s16,
954         vec_splat_s32, vec_splat_u8, vec_splat_u16, vec_splat_u32):
955         Change C++ definitions to accept a 'const int' argument;
956         the prototypes already do.
957         * config/rs6000/rs6000.c (rs6000_common_init_builtins):
958         Rename v4si_ftype_char, v8hi_ftype_char, v16qi_ftype_char,
959         v4sf_ftype_v4si_char, v4si_ftype_v4sf_char, v4si_ftype_v4si_char,
960         v8hi_ftype_v8hi_char, v16qi_ftype_v16qi_char,
961         v16qi_ftype_v16qi_v16qi_char, v8hi_ftype_v8hi_v8hi_char,
962         v4si_ftype_v4si_v4si_char and v4sf_ftype_v4sf_v4sf_char to
963         end in ..._int; change them to accept an int instead of a char
964         as the last parameter.
965
966 2004-03-04  Phil Edwards  <phil@codesourcery.com>
967
968         * genmultilib:  Change '=' to '-' when translating option names
969         to directory names.
970
971 2004-03-04  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
972
973         * expr.c (expand_expr_real, case COMPONENT_REF): Get proper type of
974         stack slot for temp used for result of BLKmode but in integral mode.
975
976 2004-03-04  Jan Hubicka  <jh@suse.cz>
977
978         * reload.c (find_reloads): Reorganize if seqeunce to switch.
979
980         * cfgrtl.c (rtl_redirect_edge_and_branch):  Set the source BB as dirty.
981         (cfglayout_redirect_edge_and_branch):  Set the source BB as dirty.
982
983 2004-03-04  Steve Ellcey  <sje@cup.hp.com>
984
985         * config/ia64/ia64.md (divdf3_internal_thr): Fix algorithm.
986         * testsuite/gcc.dg/20040303-1.c: New test.
987
988 2004-03-04  Steven Bosscher  <stevenb@suse.de>
989
990         * ppro.md: Rewrite as a DFA pipeline description.
991         * i386.md: Remove all uses of the ppro_uops attribute.
992         * i386.c: (ix86_safe_ppro_uops, ix86_dump_ppro_packet,
993         ix86_reorder_insn, ix86_sched_reorder_ppro, ix86_sched_init,
994         ix86_sched_reorder, ix86_variable_issue,
995         struct ix86_sched_data, TARGET_SCHED_VARIABLE_ISSUE,
996         TARGET_SCHED_INIT, TARGET_SCHED_REORDER): Remove.
997         (ia32_use_dfa_pipeline_interface): Add TARGET_PENTIUMPRO.
998         (ia32_multipass_dfa_lookahead): Add TARGET_PENTIUMPRO.
999         * athlon.md (athlon_ssecmp_load): Fix comment
1000
1001 2004-03-04  Stuart Hastings  <stuart@apple.com>
1002
1003         * gcc/doc/invoke.texi: Document -mlongcall for Darwin/PPC.
1004
1005 2004-03-04  Stuart Hastings  <stuart@apple.com>
1006
1007         * gcc/config/i386/darwin.h: Darwin/x86 doesn't support CPUs before
1008         686, tell Darwin assembler to allow prefetch insns, non-empty def
1009         of SUBTARGET_OPTION_TRANSLATE_TABLE.
1010
1011 2004-03-04  DJ Delorie  <dj@redhat.com>
1012
1013         PR optimization/14282
1014         * sched-deps.c (sched_analyze_insn): Allow a stack adjustment
1015         between a call and the assignment of its return value.
1016
1017 2004-03-04  Kazu Hirata  <kazu@cs.umass.edu>
1018
1019         * config/h8300/h8300.c: Put a comment for every function.
1020
1021 2004-03-04  Kazu Hirata  <kazu@cs.umass.edu>
1022
1023         * config/h8300/h8300.md: Add comments about peephole2's.
1024
1025 2004-03-04  Steven Bosscher  <stevenb@suse.de>
1026
1027         * i386.h (TARGET_CPU_DEFAULT_nocona): Fix value.
1028
1029 2004-03-04  Jan Hubicka  <jh@suse.cz>
1030
1031         * cfgcleanup.c (thread_jump): Update call of cselib_init.
1032         * cselib.c (cselib_record_memory): New static variable.
1033         (cselib_lookup_mem, cselib_record_set, cselib_record_sets):
1034         Give up on memories when asked for.
1035         (cselib_init): Accept new argument.
1036         * cselib.h (cselib_init): Update prototype.
1037         * gcse.c (local_cprop_pass): Update call of cselib_init.
1038         * loop.c (load_mems): Update call of cselib_init.
1039         * postreload.c (reload_cse_regs_1): Update call of cselib_init.
1040         * sched-deps.c (sched_analyze): Update call of cselib_init.
1041
1042 2004-03-04  David Edelsohn  <edelsohn@gnu.org>
1043             GP <gp@qnx.com>
1044
1045         * config/rs6000/rs6000.c (output_function_profiler): Append @plt
1046         when compiling PIC.
1047
1048 2004-03-04  Josef Zlomek  <zlomekj@suse.cz>
1049
1050         PR/14362
1051         * var-tracking.c (track_expr_p): Do not track variables which
1052         should be ignored for debugging purposes.
1053
1054 2004-03-04  Alan Modra  <amodra@bigpond.net.au>
1055
1056         * real.c (encode_ibm_extended): Don't bother rounding low double.
1057         * c-cppbuiltin.c (builtin_define_float_constants): Tweak MAX
1058         when fmt->pnan < fmt->p.
1059
1060 2004-03-04  Eric Christopher  <echristo@redhat.com>
1061
1062         * config/mips/mips.h (FUNCTION_ARG_REGNO_P): Fix to check
1063         only range of valid arg registers and fixed_regs.
1064
1065 2004-03-04  Alan Modra  <amodra@bigpond.net.au>
1066
1067         PR target/14406
1068         * config/rs6000/rs6000.md (abstf2, abstf2+1): Delete define_insn.
1069         (abstf2, abstf2_internal): New define_expand.
1070
1071 2004-03-04  Eric Botcazou  <ebotcazou@libertysurf.fr>
1072
1073         PR optimization/14235
1074         * expr.c (convert_move): Copy the source to a new pseudo
1075         when converting from a sub-word source to a larger-than-word
1076         register which conflicts with the source.
1077
1078 2004-03-03  Zack Weinberg  <zack@codesourcery.com>
1079
1080         PR 13728
1081         * c-decl.c (diagnose_mismatched_decls): Issue an error for two
1082         parameters with the same name, unless one is a forward decl.
1083         Do not issue a redundant-redeclaration warning for forward
1084         decls of parameters.
1085
1086 2004-03-04  David Edelsohn  <edelsohn@gnu.org>
1087
1088         * doc/install.texi (*-ibm-aix*): Document use of Bash to speed up
1089         configuration.
1090
1091 2004-03-03  Ian Lance Taylor  <ian@wasabisystems.com>
1092
1093         * ggc-zone.c (ggc_pch_write_object): Don't align file pointer.
1094
1095 2004-03-04  Alan Modra  <amodra@bigpond.net.au>
1096
1097         * target-def.h (TARGET_OPTF): Delete.
1098         * c-opts.c (TARGET_OPTF): Define.
1099
1100 2004-03-04  Jan Hubicka  <jh@suse.cz>
1101
1102         * cselib.c (cselib_finish): Fix another miss-application of my previous
1103         patch.
1104
1105 2004-03-03  Mike Stump  <mrs@apple.com>
1106
1107         Add framework support for darwin.
1108
1109         * c-incpath.c: Include target.h and machmode.h.
1110         (add_path): Use a consistent style for cpp_dir.  Initialize
1111         p->construct to 0.
1112         (add_cpp_dir_path): New.
1113         (register_include_chains): Add use of extra_includes callback.
1114         (hook_void_int): Add.
1115         (target_c_incpath): Add.
1116         * c-incpath.h (add_cpp_dir_path): New.
1117         (target_c_incpath_s): Add.
1118         (target_c_incpath): Add.
1119         (C_INCPATH_INIT): Add.
1120         * c-opts.c (c_common_missing_argument,
1121         c_common_handle_option): Add -F argument processing.
1122         * c.opt: Add -F argument processing.
1123         * gcc.c (trad_capable_cpp): Add -F argument processing.
1124         * cppfiles.c (find_file_in_dir): Update to use construct
1125         callback.
1126         (search_path_exhausted, cpp_get_path, cpp_get_buffer,
1127         cpp_get_prev): New.
1128         (_cpp_find_file): Use search_path_exhausted.
1129         (make_cpp_dir): Initialize construct to 0.
1130         * cpplib.h (missing_header_cb
1131         cpp_get_path, cpp_get_buffer, cpp_get_file, cpp_get_prev): New.
1132         (cpp_callbacks): Add missing_header
1133         (cpp_dir): Add construct.
1134         * target-def.h: (TARGET_OPTF): New.
1135         * hooks.c (hook_void_int, hook_void_charptr): Add.
1136         * hooks.h (hook_void_int, hook_void_charptr): Add.
1137         * Makefile.in (c-incpath.o) : Add $(TARGET_H) and
1138         $(MACHMODE_H) dependencies.
1139         * doc/invoke.texi (Darwin Options): Document -F.
1140         * doc/tm.texi (TARGET_EXTRA_INCLUDES): Add.
1141         (TARGET_OPTF): Add.
1142         * fix-header.c (target_c_incpath): Add.
1143
1144         * config/darwin-c.c: Add c-incpath.h include.
1145         (using_frameworks, find_subframework_file,
1146         find_subframework_header, add_system_framework_path,
1147         frameworks_in_use, num_frameworks, max_frameworks,
1148         add_framework, find_framework, struct framework_header,
1149         framework_header_dirs, framework_construct_pathname,
1150         find_subframework_file, add_system_framework_path,
1151         add_framework_path, framework_defaults,
1152         darwin_register_frameworks, find_subframework_header): Add.
1153         * config/darwin.h (TARGET_EXTRA_INCLUDES, TARGET_OPTF): New.
1154         (TARGET_OPTION_TRANSLATE_TABLE): Add -framework support.
1155         (CPP_SPEC): Add __APPLE_CC__ support.
1156         * t-darwin (darwin-c.o): Add c-incpath.h dependency.
1157
1158 2004-03-04  Jan Hubicka  <jh@suse.cz>
1159
1160         * cselib.c (cselib_finish): Fix miss-application of my previous
1161         patch.
1162
1163 2004-03-03  Kazu Hirata  <kazu@cs.umass.edu>
1164
1165         * hooks.c (hook_tree_tree_identity): New.
1166         * hooks.h: Add a prototype for hook_tree_tree_identity.
1167         * stmt.c (expand_asm_operands): Use targetm.md_asm_clobbers
1168         instead of MD_ASM_CLOBBERS.
1169         * system.h (MD_ASM_CLOBBERS): Poison.
1170         * target-def.h (TARGET_MD_ASM_CLOBBERS): New.
1171         (TARGET_INITIALIZER): Add TARGET_MD_ASM_CLOBBERS.
1172         * target.h (gcc_target): Add md_asm_clobbers.
1173         * config/i386/i386.c (TARGET_MD_ASM_CLOBBERS): New.
1174         (ix86_md_asm_clobbers): New.
1175         * config/i386/i386.h (MD_ASM_CLOBBERS): Remove.
1176         * doc/tm.texi (MD_ASM_CLOBBERS): Change to
1177         TARGET_MD_ASM_CLOBBERS.
1178
1179 2004-03-03  Stuart Hastings  <stuart@apple.com>
1180
1181         * gcc/config.gcc: Arrange for Darwin/x86 to build libgcc_eh.a.
1182
1183 2004-03-03  Eric Botcazou  <ebotcazou@libertysurf.fr>
1184
1185         * config/sparc/sparc.c (noov_compare64_op): Fix typo.
1186
1187         * config/sparc/sparc.h (ASM_FLOAT): Delete.
1188         (ASM_DOUBLE): Likewise.
1189         (ASM_LONGDOUBLE): Likewise.
1190         * config/sparc/pbd.h (ASM_INT_OP): Delete.
1191
1192 2003-03-03  Richard Henderson  <rth@redhat.com>
1193
1194         PR opt/13862
1195         * cselib.c (cselib_record_sets): Don't record multiple sets in
1196         asm insns.
1197
1198 2004-03-03  Mostafa Hagog  <mustafa@il.ibm.com>
1199
1200         * common.opt: Add description of the new -fgcse-after-reload flag.
1201
1202         * flags.h (flag_gcse_after_reload): Declaration of global variable.
1203
1204         * gcse.c (reg_used_on_edge ,reg_set_between_after_reload_p,
1205         reg_used_between_after_reload_p, rtx get_avail_load_store_reg,
1206         is_jump_table_basic_block, bb_has_well_behaved_predecessors,
1207         get_bb_avail_insn, hash_scan_set_after_reload,
1208         compute_hash_table_after_reload, eliminate_partially_redundant_loads,
1209         gcse_after_reload, get_bb_avail_insn): New functions to implement
1210         gcse-after-reload.
1211         (gcse_after_reload_main): New function, the main entry point to
1212         gcse-after-reload.
1213
1214         * rtl.h (gcse_after_reload_main): Declaration of the new function.
1215
1216         * opts.c (common_handle_option): Handle the -fgcse-after-reload flag.
1217
1218         * toplev.c (flag_gcse_after_reload): Initialization.
1219
1220         * passes.c (rest_of_handl_gcse2): Call gcse_after_reload_main.
1221
1222         * params.def (PARAM_GCSE_AFTER_RELOAD_PARTIAL_FRACTION,
1223         PARAM_GCSE_AFTER_RELOAD_CRITICAL_FRACTION): New parameters for tuning
1224         the gcse after reload optimization.
1225
1226         * params.h (GCSE_AFTER_RELOAD_PARTIAL_FRACTION,
1227         GCSE_AFTER_RELOAD_CRITICAL_FRACTION): Two macros to access the tuning
1228         parameters.
1229
1230         * doc/invoke.texi: Documentation for the new flag gcse-after-reload.
1231
1232 2004-03-03  Nicolas Pitre <nico@cam.org>
1233
1234         * config/arm/ieee754-df.S (muldf3, divdf3): Fix denormalization of
1235         small negative values.
1236
1237 2004-03-03  Jan Hubicka  <jh@suse.cz>
1238
1239         * cselib.c (hash_table):  Remove GTY marker.
1240         (reg_values): Turn into array.
1241         (used_regs): Likewise.
1242         (n_used_regs): New static variable.
1243         (reg_values_old): Kill.
1244         (clear_table): Update uses of arrays.
1245         (cselib_lookup): Likewise.
1246         (cselib_record_set): Likewise.
1247         (cselib_init): Likewise.
1248         (cselib_finish): Likewise.
1249         (cselib_udpate_varray_sizes): Kill.
1250         * cselib.h (cselib_update_varray_sizes): Kill.
1251
1252 2004-03-03  Paul Brook  <paul@codesourcery.com>
1253
1254         * flow.c (ior_reg_cond, and_reg_cond): Remove stray ")".
1255
1256 2004-03-03  Jan Hubicka  <jh@suse.cz>
1257
1258         * ggc-common.c (ggc_alloc_cleared_stat, ggc_realloc_stat):
1259         Rename from ...; make statistics transparent.
1260         (ggc_alloc_cleared, ggc_realloc_stat): ... these.
1261         (loc_descriptor): New structure.
1262         (hash_descriptor, eq_descriptor, loc_descriptor, cmp_statistics,
1263         add_statistics):
1264         New static function.
1265         (ggc_record_overhead, dump_statistics): New global function.
1266         * ggc-none.c (ggc_alloc_types_stat, ggc_alloc_stat, ggc_alloc_zone_stat,
1267         ggc_alloc_cleared_stat, ggc_realloc_stat, ggc_alloc_typed_stat): Rename
1268         from ...; accept locations
1269         (ggc_alloc_types, ggc_alloc, ggc_alloc_zone, ggc_alloc_cleared,
1270         ggc_realloc, ggc_alloc_typed):  ... this one.
1271         from ...; accept locations
1272         * ggc-page.c (ggc_alloc_typed_stat, ggc_alloc_zone_stat,
1273         ggc_alloc_stat): Rename from ... ; pass locations
1274         * ggc-page.c (ggc_alloc_typed, ggc_alloc_zone, ggc_alloc):
1275         ... this one.
1276         (ggc_alloc_stat): Record overehead.
1277         * ggc.h (ggc_alloc_types, ggc_alloc, ggc_alloc_zone, ggc_alloc_cleared,
1278         ggc_realloc, ggc_alloc_typed):  Turn to macros
1279         (ggc_alloc_types_stat, ggc_alloc_stat, ggc_alloc_zone_stat,
1280         ggc_alloc_cleared_stat, ggc_realloc_stat, ggc_alloc_typed_stat): Declare.
1281         (dump_ggc_loc_satistics, ggc_record_overehead): Declare.
1282         * langhooks.h (lhd_make_node): Declare.
1283         (LANG_HOOKS_MAKE_TYPE): Default to new function,
1284         * langhooks.c (lhd_make_node): New.
1285         * rtl.c (rtx_alloc_stat, swallow_copy_rtx_stat): Rename from ... ; pass
1286         locations.
1287         (rtx_alloc, swallow_copy_rtx): ... this one.
1288         * rtl.h (rtx_alloc, swallow_copy_rtx): Turn to macros.
1289         * rtl.c (rtx_alloc_stat, swallow_copy_rtx_stat): Declare.
1290         * toplpev.c (finalize): Dump stats.
1291         * tree.c (make_node_stat, copy_node_stat, make_tree_vec_stat,
1292         build_tree_list_stat, tree_cons_stat, build?_stat,  build_decl_stat):
1293         Rename from ... ; pass locators.
1294         (make_node, copy_node, make_tree_vec, build_tree_list, tree_cons,
1295         build?,  build_decl): Declare.
1296         * tree.h (make_node_stat, copy_node_stat, make_tree_vec_stat,
1297         build_tree_list_stat, tree_cons_stat, build?_stat,  build_decl_stat):
1298         Declare.
1299         (make_node, copy_node, make_tree_vec, build_tree_list, tree_cons,
1300         build?,  build_decl): New macros.
1301         * Makefile.in (RTL_H, TREE_H): Add statistics.h dependency.
1302         * statistics.h: New file.
1303
1304 2004-03-03  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
1305             Richard Sandiford  <rsandifo@redhat.com>
1306
1307         * config/mips/mips.h (MASK_FIX_SB1): Bump.
1308         (MASK_FIX_R4400, TARGET_FIX_R4400): New macros.
1309         (TARGET_SWITCHES): Add -mfix-r4400 and -mno-fix-r4400.
1310         * config/mips/mips.c (mips_output_division): Fill the branch delay
1311         slot with a nop if TARGET_FIX_R4000.  Extend R4000 workarounds to
1312         TARGET_FIX_R4400.
1313         (mips_output_division): Adjust accordingly.
1314         (override_options): Make -march=r4400 imply -mfix-r4400 by default.
1315         * doc/invoke.texi: Document -mfix-r4400 and new errata workarounds.
1316
1317 2004-03-03  Paolo Bonzini  <bonzini@gnu.org>
1318
1319         * alias.c (rtx_equal_for_memref_p): Use predicates
1320         to test rtx classes and new rtx class codes, possibly
1321         splitting conditionals that tested against '<' and 'o'.
1322         * caller-save.c (save_call_clobbered_regs): Likewise.
1323         * combine.c (contains_muldiv, find_split_point, subst,
1324         combine_simplify_rtx, simplify_if_then_else,
1325         simplify_set, simplify_logical, expand_compound_operation,
1326         make_compound_operation, if_then_else_cond, known_cond,
1327         apply_distributive_law, cached_nonzero_bits,
1328         cached_num_sign_bit_copies, simplify_shift_const,
1329         gen_binary, simplify_comparison, update_table_tick,
1330         record_value_for_reg, get_lsat_value_validate): Likewise.
1331         * cse.c (mention_regs, find_best_addr, find_comparison_args,
1332         fold_rtx, cse_insn, invalidate_memory, cse_basic_block):
1333         Likewise.
1334         * emit-rtl.c (copy_insn_1): Likewise.
1335         * expr.c (force_operand): Likewise.
1336         * final.c (final_scan_insn, get_mem_expr_from_op): Likewise.
1337         * flow.c (notice_stack_pointer_modification_1,
1338         invalidate_mems_from_autoinc, ior_reg_cond, not_reg_cond,
1339         and_reg_cond, elim_reg_cond): Likewise.
1340         * function.c (update_epilogue_consts): Likewise.
1341         * genattrtab.c (attr_rtx_1): Likewise.
1342         * genopinit.c (gen_insn): Likewise.
1343         * integrate.c (subst_constants): Likewise.
1344         * jump.c (reversed_comparison_code_parts,
1345         reversed_comparison_code, delete_related_insns,
1346         rtx_renumbered_equal_p): Likewise.
1347         * local-alloc.c (block_alloc): Likewise.
1348         * loop.c (rtx_equal_for_prefetch_p, maybe_eliminate_biv,
1349         canonicalize_condition): Likewise.
1350         * loop-iv.c (simplify_using_conditions, iv_number_of_iterations):
1351         Likewise.
1352         * optabs.c (add_equal_node, expand_binop): Likewise.
1353         * predict.c (estimate_probability): Likewise.
1354         * ra-debug.c (ra_print_rtx_2op, ra_print_rtx): Likewise.
1355         * recog.c (validate_replace_rtx_1, comparison_operator,
1356         offsettable_address_p, constrain_operands): Likewise.
1357         * reg-stack.c (swap_rtx_condition_1, subst_stack_regs_pat):
1358         Likewise.
1359         * regclass.c (scan_one_insn): Likewise.
1360         * regmove.c (stable_and_no_regs_but_for_p): Likewise.
1361         * regrename.c (kill_autoinc_value): Likewise.
1362         * reload.c (find_reusable_reload, find_reloads,
1363         reg_overlap_mentioned_for_reload_p): Likewise.
1364         * reload1.c (gen_reload, delete_address_reloads_1): Likewise.
1365         * rtl.c (copy_rtx): Likewise.
1366         * rtl.h (CONSTANT_P, INSN_P): Likewise.
1367         * rtlanal.c (commutative_operand_precedence): Likewise.
1368         * sched-deps.c (conditions_mutex_p): Likewise.
1369         * sched-rgn.c (is_cfg_nonregular): Likewise.
1370         * simplify-rtx.c (simplify_gen_binary,
1371         simplify_gen_relational, simplify_replace_rtx,
1372         simplify_unary_operation, simplify_binary_operation,
1373         simplify_ternary_operation, simplify_rtx): Likewise.
1374         * unroll.c (reg_dead_after_loop): Likewise.
1375         * config/alpha/alpha.c (alpha_swapped_comparison_operator,
1376         print_operand): Likewise.
1377         * config/arc/arc.c (proper_comparison_operator): Likewise.
1378         * config/arm/arm.c (arm_arm_address_cost, arm_select_cc_mode):
1379         Likewise.
1380         * config/avr/avr.c (_reg_unused_after): Likewise.
1381         * config/frv/frv.c (frv_ifcvt_modify_tests,
1382         frv_ifcvt_modify_insn, frv_pack_insn): Likewise.
1383         * config/i386/i386.c (ix86_comparison_operator,
1384         ix86_carry_flag_operator, fcmov_comparison_operator,
1385         arith_or_logical_operator, print_operand,
1386         ix86_expand_binary_operator, ix86_binary_operator_ok):
1387         Likewise.
1388         * config/i386/i386.md: Likewise.
1389         * config/ia64/ia64.c (not_postinc_memory_operand,
1390         ia64_print_operand, update_set_flags, errata_emit_nops):
1391         Likewise.
1392         * config/ia64/ia64.h (PREFERRED_RELOAD_CLASS,
1393         CONSTRAINT_OK_FOR_S): Likewise.
1394         * config/ip2k/ip2k.c (mdr_resequence_xy_yx,
1395         mdr_try_move_dp_reload, ip2k_check_can_adjust_stack_ref,
1396         ip2k_xexp_not_uses_reg_for_mem, ip2k_xexp_not_uses_reg_p,
1397         ip2k_composite_xexp_not_uses_reg_p, ip2k_unary_operator):
1398         Likewise.
1399         * config/iq2000/iq2000.c (cmp_op, symbolic_expression_p,
1400         eqne_comparison_operator, signed_comparison_operator):
1401         Likewise.
1402         * config/mips/mips.c (cmp_op, symbolic_expression_p):
1403         Likewise.
1404         * config/mmix/mmix (mmix_foldable_comparison_operator,
1405         mmix_comparison_operator): Likewise.
1406         * config/pa/pa.c (hppa_legitimize_address): Likewise.
1407         * config/rs6000/rs6000.c (stmw_operation,
1408         branch_comparison_operator, trap_comparison_operator,
1409         ccr_bit): Likewise.
1410         * config/rs6000/rs6000.h (SELECT_CC_MODE): Likewise.
1411         * config/s390/s390.c (s390_alc_comparison,
1412         s390_slb_comparison):L Likewise.
1413         * config/sh/sh.c (gen_block_redirect, reg_unused_after):
1414         Likewise.
1415         * config/sparc/sparc.c (eq_or_neq, normal_comp_operator,
1416         noov_compare_op, noov_compare64_op, v9_regcmp_op,
1417         emit_hard_tfmode_operation, reg_unused_after)
1418         * doc/md.texi, doc/rtl.texi: Likewise.
1419
1420         * ra-debug.c: Add 2004 to list of copyright years.
1421         * unroll.c: Likewise.
1422
1423         * combine.c (simplify_logical): Remove dummy test,
1424         (apply_distributive_law): Fix typo in comment.
1425         GET_CODE (x) == AND so x is a commutative binary op.
1426         * jump.c (delete_related_insns): simplify loop
1427         condition, move testing of RTX codes inside the loop.
1428         (rtx_renumbered_equal_p): do not use RTX_CODE.
1429         * rtl.c (rtx_class): Declare as enum rtx_class.
1430         * rtl.def (EQ, NE, UNEQ, LTGT, UNORDERED, ORDERED):
1431         Move to RTX_COMM_COMPARE class.
1432         (HIGH, SYMBOL_REF, LABEL_REF, CONST, CONST_INT, CONST_DOUBLE):
1433         Move to RTX_CONST_OBJ class.
1434         * rtl.h (enum rtx_class): New declaration,
1435         (RTX_OBJ_MASK, RTX_OBJ_RESULT, RTX_COMPARE_MASK,
1436         RTX_COMPARE_RESULT, RTX_ARITHMETIC_MASK, RTX_ARITHMETIC_RESULT,
1437         RTX_BINARY_MASK, RTX_BINARY_RESULT, RTX_COMMUTATIVE_MASK,
1438         RTX_COMMUTATIVE_RESULT, RTX_NON_COMMUTATIVE_RESULT,
1439         RTX_EXPR_FIRST, RTX_EXPR_LAST, UNARY_P, BINARY_P,
1440         ARITHMETIC_P, COMMUTATIVE_ARITHMETIC_P, COMPARISON_P,
1441         SWAPPABLE_OPERANDS_P, NON_COMMUTATIVE_P, COMMUTATIVE_P,
1442         OBJECT_P): New macros.
1443         * config/sparc/sparc.c (noov_compare_op): Remove register
1444         from parameter.
1445
1446 2004-03-03  Kazu Hirata  <kazu@cs.umass.edu>
1447
1448         * target.h: Remove texi jargons in comments.
1449
1450 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1451
1452         * config/h8300/lib1funcs.asm (___fixunssfsi): Change the
1453         threshold to 0x4f.
1454
1455         Revert:
1456         2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
1457         * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
1458         as well.
1459         * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
1460         * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
1461
1462 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1463
1464         * doc/md.texi (cbranchmode4): New.
1465
1466 2004-03-02  Eric Christopher  <echristo@redhat.com>
1467
1468         * config/mips/mips16.S: Change fixsfsi and fixdfsi to
1469         fix_trunc.
1470         * config/mips/mips.c (mips_init_libfuncs): Change accordingly.
1471         * config/mips/t-elf (LIB1ASMFUNCS): Ditto.
1472         * config/mips/t-isa3264 (LIB1ASMFUNCS): Ditto.
1473         * config/mips/t-r3900 (LIB1ASMFUNCS): Ditto.
1474
1475 2004-03-02  Richard Henderson  <rth@redhat.com>
1476
1477         PR middle-end/11767
1478         * coverage.c (coverage_counter_ref): Set MEM_NOTRAP_P.
1479         * optabs.c (prepare_cmp_insn): Force trapping memories to registers
1480         before the compare, if flag_non_call_exceptions.
1481
1482 2004-03-02  Richard Henderson  <rth@redhat.com>
1483
1484         PR middle-end/14327
1485         * stmt.c (expand_computed_goto): Do do_pending_stack_adjust before
1486         emitting the label, not after.
1487
1488 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
1489
1490         * config/m68hc11/m68hc11.c (m68hc11_addr_mode): New variable.
1491         (m68hc11_mov_addr_mode): Likewise.
1492         (m68hc11_override_options): Initialize them based on target.
1493         (register_indirect_p): Allow a MEM for indirect addressing modes and
1494         use flags to control what is allowed.
1495         (m68hc11_small_indexed_indirect_p): Use m68hc11_mov_addr_mode for
1496         supported addressing modes.
1497         (m68hc11_register_indirect_p): Use m68hc11_addr_mode.
1498         (go_if_legitimate_address_internal): Likewise.
1499         (m68hc11_indirect_p): Likewise and check the mode.
1500         (print_operand): Allow a (MEM (MEM)) and generate indirect addressing.
1501
1502 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1503
1504         * builtins.c (BUILTIN_SETJMP_FRAME_VALUE): Remove.
1505         (expand_builtin_setjmp_setup): Use
1506         targetm.builtin_setjmp_frame_value instead of
1507         BUILTIN_SETJMP_FRAME_VALUE.
1508         * system.h (BUILTIN_SETJMP_FRAME_VALUE): Poison.
1509         * target-def.h (TARGET_BUILTIN_SETJMP_FRAME_VALUE): New.
1510         (TARGET_INITIALIZER): Add TARGET_BUILTIN_SETJMP_FRAME_VALUE.
1511         * target.h (gcc_target): Add builtin_setjmp_frame_value.
1512         * targhooks.c (default_builtin_setjmp_frame_value): New.
1513         * targhooks.h: Add a prototype for
1514         default_builtin_setjmp_frame_value.
1515         * doc/tm.texi (BUILTIN_SETJMP_FRAME_VALUE): Change to
1516         TARGET_BUILTIN_SETJMP_FRAME_VALUE.
1517
1518 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
1519
1520         * config/m68hc11/m68hc11.md (move peephole2): New peepholes to optimize
1521         sequences of moves.
1522         (add peepholes): New peepholes to optimize sequences adding small
1523         constants.
1524         (bset peepholes): New peepholes to transform an OR in a bset form
1525         (bclr peepholes): Likewise for bclr form.
1526         (cmp peepholes): New peepholes to avoid register copies when comparing.
1527
1528 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
1529
1530         * config/m68hc11/m68hc11.md ("*pushdi_internal"): New insn and split
1531         to separate push from moves.
1532         ("*pushdf_internal"): Likewise.
1533         ("*pushsf_internal"): Likewise.
1534         ("*pushsi_internal"): Likewise.
1535         ("movdi_internal"): Use define_insn_and_split; non push operand.
1536         ("movdf_internal"): Likewise.
1537         ("movsf_internal"): Likewise.
1538         ("movsi_internal"): Likewise.
1539         ("*movhi_68hc12", "*addhi3_68hc12"): Fix and tune constraints
1540         ("*addhi3", "*subhi3", "*andhi3_mem", "*iorhi3_mem"): Likewise.
1541         ("*ashlsi3_const1", "*lshrsi3_const1"): Likewise.
1542
1543 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
1544
1545         * config/m68hc11/m68hc11.md ("tstqi_z_used"): Use define_insn_and_split.
1546         ("cmphi_z_used", "cmpqi_z_used"): Likewise.
1547         ("movstrictsi", "movstricthi", "movstrictqi"): Likewise.
1548         ("anddi3", "andsi3", "iordi3", "iorsi3"): Likewise.
1549         ("xordi3", "xorsi3", "*logicalsi3_zexthi"): Likewise.
1550         ("*logicalsi3_zextqi", "*logicalhi3_zexthi_ashift8"): Likewise.
1551         ("logicalhi3_zexthi", "*logicalsi3_silshr16"): Likewise.
1552         ("*logicalsi3_silshl16", "*logicalsi3_silshl16_zext"): Likewise.
1553         ("*ashldi3_const32", "*ashldi3_const1", "addsi_silshr16"): Likewise.
1554         ("addsi_andshr16", "*ashlsi3_const16_zexthi"): Likewise.
1555         ("*lshrdi3_const32", "*lshrdi_const1"): Likewise.
1556
1557 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
1558
1559         * config/m68hc11/m68hc11.md (SOFT_TMP_REGNUM): Define.
1560         (SOFT_XY_REGNUM): Define.
1561         (cmp split): Use the above instead of hard coded numbers.
1562         (8-bit op split): No need to check the mode; allow Q_REG.
1563         (ashift split): Adjust the first operand if it uses the SP and we
1564         are pushing the shifted value.
1565         (plus shift split): Fix when a source is in register D+X.
1566         ("doloop_end"): Pass dummy arguments to gen_rtx_NE.
1567
1568 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
1569
1570         * config/m68hc11/m68hc11.c (m68hc11_check_z_replacement): Fix when
1571         comparing with Z register.
1572
1573 2004-03-02  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1574
1575         * cfgloop.h (struct loop_desc): Removed.
1576         (struct loop): Fields simple, desc and has_desc removed.
1577         (simple_loop_p, count_loop_iterations): Declaration removed.
1578         * cfgloopanal.c (struct unmark_altered_insn_data): Removed.
1579         (unmark_altered, blocks_invariant_registers, unmark_altered_insn
1580         blocks_single_set_registers, invariant_rtx_wrto_regs_p_helper,
1581         invariant_rtx_wrto_regs_p, test_for_iteration, constant_iterations,
1582         simple_loop_exit_p, variable_initial_value, variable_initial_values,
1583         simple_condition_p, simple_increment, count_strange_loop_iterations,
1584         inverse, fits_in_mode_p, simple_loop_p, count_loop_iterations):
1585         Removed.
1586         * loop-iv.c (check_simple_exit, find_simple_exit): Update comments.
1587
1588 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1589
1590         * genattrtab.c: Don't handle MATCH_INSN.
1591         * genrecog.c: Likewise.
1592         * gensupport.c: Likewise.
1593         * rtl.def (match_insn): Remove.
1594         * doc/md.texi (match_insn, match_insn2): Remove.
1595
1596 2004-03-02  Mark Mitchell  <mark@codesourcery.com>
1597
1598         * doc/c-tree.texi (DECL_ASSEMBLER_NAME): Mention that using this
1599         macro results in memory allocation.
1600
1601 2004-03-02  David O'Brien  <obrien@FreeBSD.org>
1602
1603         * config/freebsd-spec.h (FBSD_DYNAMIC_LINKER): Add.
1604         * config/alpha/freebsd.h (SUBTARGET_EXTRA_SPECS): Define
1605         %(fbsd_dynamic_linker),
1606         (LINK_SPEC): Use %(fbsd_dynamic_linker), and sync style with
1607         config/i386/freebsd.h
1608         * config/arm/freebsd.h: Ditto.
1609         * config/i386/freebsd.h: Ditto.
1610         * config/i386/freebsd64.h: Ditto.
1611         * config/ia64/freebsd.h: Ditto.
1612         * config/rs6000/sysv4.h: Ditto.
1613         * config/sparc/freebsd.h: Ditto.
1614
1615 2004-03-02  Loren James Rittle  <ljrittle@acm.org>
1616
1617         * gcc/doc/install.texi (*-*-freebsd*): Update target information.
1618
1619 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1620
1621         * rtl.def (define_combine): Remove.
1622
1623 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1624
1625         * config/h8300/h8300.md: Tweak formatting.
1626
1627 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1628
1629         * config/h8300/h8300.md (*cmphi_h8300): Rename to
1630         *cmphi_h8300_znvc.
1631         (*cmphi_h8300hs): Rename to *cmphi_h8300hs_znvc.
1632
1633 2004-03-01  Mark Mitchell  <mark@codesourcery.com>
1634
1635         PR bootstrap/14356
1636         * gcc.c (process_command): Remove const-qualification from argv.
1637         (main): Likewise.
1638
1639 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
1640
1641         * config/h8300/h8300.md (pushqi1_h8300hs): Rename to
1642         pushqi1_h8300hs_advanced.  Adjust its caller.
1643         (pushhi1_h8300hs): Rename to pushhi1_h8300hs_advanced.
1644         Adjust its caller.
1645
1646 2004-03-02  Nicolas Roche  <roche@act-europe.fr>
1647
1648         * Makefile.in (install-libgcc, install-multilib): Pass
1649         mkinstalldirs var to libgcc.mk.
1650
1651 2004-03-01  Kazu Hirata  <kazu@cs.umass.edu>
1652
1653         * system.h (DBX_OUTPUT_STANDARD_TYPES): Poison.
1654         * doc/tm.texi (DBX_OUTPUT_STANDARD_TYPES): Remove.
1655
1656 2004-03-01  Kazu Hirata  <kazu@cs.umass.edu>
1657
1658         * config/h8300/h8300.c (gtle_operator): Accept GT and LE.
1659         * config/h8300/h8300.md: Split several peephole2's, each into
1660         two.
1661
1662 2004-03-02  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1663
1664         * dominance.c (recount_dominator): Handle postdominators.
1665
1666 2004-03-01  Richard Sandiford  <rsandifo@redhat.com>
1667
1668         * config/mips/mips-protos.h (enum mips_symbol_type): Move from mips.h.
1669         (NUM_SYMBOL_TYPES): Likewise.
1670         (SYMBOL_64_HIGH, SYMBOL_64_MID, SYMBOL_64_LOW): New symbol types.
1671         (mips_unspec_address): Declare.
1672         (mips_gotoff_page, mips_gotoff_global): Delete.
1673         * config/mips/mips.h (PREDICATE_CODES): Add general_symbolic_operand.
1674         * config/mips/mips.c (enum mips_symbol_type, NUM_SYMBOL_TYPES): Delete.
1675         (mips_symbolic_constant_p, mips_symbolic_address_p)
1676         (mips_symbol_insns): Handle new symbol types.
1677         (general_symbolic_operand): New predicate.
1678         (mips_unspec_address): Make extern.
1679         (mips_gotoff_page, mips_gotoff_global): Delete.
1680         (override_options): Allow -mabi=64 -mno-abicalls -mexplicit-relocs.
1681         Handle new symbol types.
1682         * config/mips/mips.md (*lea_high64, *lea64): New patterns.
1683         (*xgot_hi[sd]i, *xgot_lo[sd]i, *got_disp[sd]i, *got_disp[sd]i): Call
1684         mips_unspec_address directly.
1685         * doc/invoke.texi: Remove the -mabi=64 -mno-abicalls exception from
1686         the documentation of -mexplicit-relocs.
1687
1688 2004-03-01  Jeff Law  <law@redhat.com>
1689
1690         * fold-const.c (fold): An equality comparison of a non-weak object
1691         against zero has a known result.  Similarly an equality comparison
1692         of the address of two non-weak, unaliased symbols has a known result.
1693
1694         * ggc-page.c (struct page_entry): New field PREV.
1695         (ggc_alloc): Update PREV field appropriately.
1696         (sweep_pages): Likewise.
1697         (ggc_free): Likewise.  Use PREV field rather than loop to
1698         improve ggc_free performance.
1699
1700 2004-03-01  Richard Sandiford  <rsandifo@redhat.com>
1701
1702         * config/mips/mips.c (mips_output_division): Use the division
1703         instruction to fill the delay slot of a zero check.
1704         (mips_idiv_insns): Adjust accordingly.
1705
1706 2004-03-01  Nathanael Nerode  <neroden@gcc.gnu.org>
1707
1708         * config.gcc: Create a default tmake_file for linux, and use
1709         it in all but two linux clauses.  Comment those two.
1710
1711 2004-03-01  Paolo Bonzini  <bonzini@gnu.org>
1712
1713         * combine.c (try_combine):  Do not refer to is_replaced.
1714         (gen_lowpart_for_combine):  Perverse subregs now have a
1715         more politically correct name.
1716         * cse.c (cse_insn): Likewise.
1717         * jump.c: Fix bogus reference to delete_insn.
1718
1719 2004-02-29  Mark Mitchell  <mark@codesourcery.com>
1720
1721         PR debug/14328
1722         * dwarf2out.c (gen_enumeration_type_die): Output all enumeration
1723         constants as signed values.
1724
1725         PR middle-end/13448
1726         * c-tree.h (readonly_warning): Rename to ...
1727         (readonly_error): ... this.
1728         * c-typeck.c (build_unary_op): Adjust accordingly.
1729         (readonly_warning): Rename to ...
1730         (readonly_error): ... this and issue errors, not warnings.
1731         (build_modify_expr): Call readonly_error, not readonly_warning.
1732         (c_expand_asm_operands): Likewise.
1733         * tree-inline.c (optimize_inline_calls): Do not inline functions
1734         after errors have occurred.
1735
1736 2004-02-29  Nathanael Nerode  <neroden@gcc.gnu.org>
1737
1738         * configure.ac: Rearrange some threading code for clarity;
1739         add section comment.
1740         * configure: Regenerate.
1741
1742 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
1743
1744         * passes.c, config/frv/frv.c, config/sh/sh.c: Fix comment
1745         typos.
1746         * doc/cppopts.texi: Fix a typo.
1747
1748 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
1749
1750         * config/i386/i386.md: Fix formatting.
1751
1752 2004-02-29  Nathanael Nerode  <neroden@gcc.gnu.org>
1753
1754         * configure.ac: Add some comments delineating sections of code.
1755
1756         * doc/install.texi: Note that libada uses autoconf 2.57 also.
1757
1758         * doc/install.texi: Fix idiot typo in previous commit.
1759
1760         * doc/install.texi: Update for conversion of intl to autoconf 2.57.
1761
1762 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
1763
1764         * config/h8300/h8300.md: Add comments about peephole2's.
1765
1766 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
1767
1768         * config/h8300/h8300.md: Tweak operand numbers of some
1769         peephole2's.
1770
1771 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
1772
1773         * config/h8300/h8300.md: Tweak comments about peephole2's.
1774
1775 2004-02-29  Waldek Hebisch  <hebisch@math.uni.wroc.pl>
1776
1777         PR middle-end/14203
1778         * function.c (uninitialized_vars_warning): Use DECL_RTL_SET_P
1779         instead of testing whether DECL_RTL is not NULL.
1780
1781 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
1782
1783         * config/sh/sh.c: Fix formatting.
1784
1785 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
1786
1787         * config/sh/sh.c: Convert to ISO-C.
1788
1789 2004-02-28  Andrew Pinski  <pinskia@physics.uc.edu>
1790
1791         * c-typeck.c (tagged_types_tu_compatible_p): Fix pasto in
1792         my previous patch.
1793
1794         * config/darwin.h (machopic_finish): Output stub even if the
1795         symbol is already defined.
1796
1797 2004-02-28  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
1798
1799         * pa64-hpux.h (LIB_SPEC): Fix linking under HP-UX 11.00 with -p and -pg.
1800
1801 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
1802
1803         * genattr.c (main): Don't define
1804         TRADITIONAL_PIPELINE_INTERFACE or DFA_PIPELINE_INTERFACE.
1805         * system.h (TRADITIONAL_PIPELINE_INTERFACE): Poison.
1806         (DFA_PIPELINE_INTERFACE): Likewise.
1807         * doc/tm.texi (TRADITIONAL_PIPELINE_INTERFACE): Remove.
1808         (DFA_PIPELINE_INTERFACE): Likewise.
1809
1810 2004-02-28  Richard Sandiford  <rsandifo@redhat.com>
1811
1812         * config/mips/mips.md (tstsi, tstdi): Delete.
1813
1814 2004-02-28  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
1815
1816         * config/mips/mips.c (override_options): Remove an obsolete
1817         duplicate definition of the "e" constraint.
1818         * config/mips/mips.h: Update a comment accordingly.
1819
1820 2004-02-28  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
1821
1822         * config/mips/mips.md: Complete the unfinished R4000
1823         multiply/shift errata workaround.  Improve documentation.
1824         (hazard): Use TARGET_FIX_R4000 to decide whether an "imul" instruction
1825         has a hilo hazard.
1826         (mulsi3, mulsi3_internal, mulsi3_r4000): Use TARGET_FIX_R4000.
1827         (muldi3, muldi3_internal): Likewise.
1828         (muldi3_internal2): Remove, replacing with...
1829         (muldi3_mult3, muldi3_r4000): ...these new patterns.
1830         (mulsidi3): Take the errata into account.
1831         (mulsidi3_32bit): Remove, replacing with...
1832         (mulsidi3_32bit_internal, mulsidi3_32bit_r4000): ...these new patterns.
1833         (mulsidi3_64bit, mulsidi3_64bit_parts): Disable if TARGET_FIX_R4000.
1834         (umulsidi3): Take the errata into account.
1835         (umulsidi3_32bit): Remove, replacing with..
1836         (umulsidi3_32bit_internal, umulsidi3_32bit_r4000): ...these patterns.
1837         (umulsi3_highpart, umulsi3_highpart_internal): Disable if
1838         TARGET_FIX_R4000.
1839         (smulsi3_highpart, smulsi3_highpart_internal): Likewise.
1840         (smuldi3_highpart, umuldi3_highpart): Likewise.
1841         * doc/invoke.texi: Document the errata workaround.
1842
1843 2004-02-28  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
1844
1845         * config/mips/mips-protos.h (mips_idiv_insns): Declare.
1846         * config/mips/mips.h (MASK_FIX_SB1): Bump.
1847         (MASK_FIX_R4000, TARGET_FIX_R4000): New macros.
1848         (TARGET_SWITCHES): Add -mfix-r4000 and -mno-fix-r4000.
1849         * config/mips/mips.c (mips_idiv_insns): New function.
1850         (override_options): Make -march=r4000 imply -mfix-r4000 by default.
1851         (mips_output_division): Add a workaround for the R4000 divide/shift
1852         errata.
1853         * config/mips/mips.md (length): Use mips_idiv_insns() to calculate
1854         the length of an "idiv" instruction.
1855         * doc/invoke.texi: Document the new switches.
1856
1857 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
1858
1859         * doc/tm.texi (IS_COSTLY_DEPENDENCE): Change to
1860         TARGET_SCHED_IS_COSTLY_DEPENDENCE.
1861
1862 2004-02-28  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1863
1864         PR optimization/14229
1865         * cfgrtl.c (rtl_tidy_fallthru_edge): Do not fail for !onlyjump jump.
1866
1867 2004-02-28  Eric Botcazou  <ebotcazou@act-europe.fr>
1868
1869         * fold-const.c (fold): Strip NOPs that change the signedness
1870         for RSHIFT too.  Expand comment.
1871
1872 2004-02-27  Ian Lance Taylor  <ian@wasabisystems.com>
1873
1874         PR optimization/7871
1875         * flow.c (mark_set_1): Don't add LOG_LINKS for global registers
1876         from or to call insns.
1877
1878 2004-02-27  Eric Botcazou  <ebotcazou@libertysurf.fr>
1879
1880         PR optimization/7871
1881         * flow.c (propagate_one_insn): Interpret calls as setting global
1882         registers, not merely clobbering them.
1883
1884 2004-02-27  Dale Johannesen  <dalej@apple.com>
1885
1886         * config/darwin.c (machopic_output_possible_stub_label):  Remove.
1887         config/darwin-protos.h:  Ditto.
1888         config/darwin.h:  Remove call to it.
1889         * combine.c (distribute_notes): Do not place a REG_DEAD note
1890         when value is both set and used.
1891
1892 2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
1893
1894         * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
1895         as well.
1896         * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
1897         * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
1898
1899 2004-02-27  Andrew Pinski  <apinski@apple.com>
1900
1901         * c-typeck.c (tagged_types_tu_compatible_p) <ENUMERAL_TYPE>:
1902         Speedup common case of the type values being in the same order.
1903
1904 2004-02-27  Steve Ellcey  <sje@cup.hp.com>
1905
1906         * config/ia64/ia64.h (no-inline-float-divide): New option.
1907         * config/ia64/ia64.h (no-inline-int-divide): New option.
1908         * config/ia64/ia64.h (no-inline-sqrt): New option.
1909         (TARGET_DEFAULT): Add MASK_INLINE_FLOAT_DIV_THR to define.
1910         * config/ia64/hpux.h (TARGET_DEFAULT): Ditto.
1911         * config/ia64/ia64.c (ia64_override_options): Modify error
1912         checking for inlined division/sqrt.
1913
1914 2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
1915
1916         * bb-reorder.c, cfgbuild.c, diagnostic.c, explow.c, profile.c,
1917         ra-build.c, read-rtl.c, tracer.c, unwind-dw2-fde-glibc.c,
1918         value-prof.c, config/darwin-protos.h, config/frv/frv-abi.h,
1919         config/i386/pmmintrin.h, config/pa/pa-hpux.h: Update
1920         copyright.
1921
1922 2004-02-27  Paul Brook  <paul@codesourcery.com>
1923
1924         * function.c (assign_parms): Don't count pretend args for alignment.
1925
1926 2004-02-27  Richard Henderson  <rth@redhat.com>
1927
1928         * passes.c: New file.
1929         * Makefile.in (OBJS-common): Add it.
1930         * diagnostic.c (rtl_dump_and_exit): Move decl ...
1931         * flags.h (rtl_dump_and_exit): ... here.
1932         * output.h (size_directive_output, last_assemble_variable_decl):
1933         Move from toplev.c.
1934         * rtl.h (reg_alloc): Move from toplev.c.
1935         * toplev.c (HAVE_conditional_execution, DUMPFILE_FORMAT,
1936         struct dump_file_info, enum dump_file_index, dump_file_tbl,
1937         open_dump_file, close_dump_file, rest_of_decl_compilation,
1938         rest_of_type_compilation, rest_of_handle_final,
1939         rest_of_handle_delay_slots, rest_of_handle_stack_regs,
1940         rest_of_handle_variable_tracking, rest_of_handle_machine_reorg,
1941         rest_of_handle_new_regalloc, rest_of_handle_old_regalloc,
1942         rest_of_handle_regrename, rest_of_handle_reorder_blocks,
1943         rest_of_handle_sched, rest_of_handle_sched2, rest_of_handle_regmove,
1944         rest_of_handle_tracer, rest_of_handle_if_conversion,
1945         rest_of_handle_if_after_combine, rest_of_handle_web,
1946         rest_of_handle_branch_prob,
1947         rest_of_handle_value_profile_transformations, rest_of_handle_cfg,
1948         rest_of_handle_addressof, rest_of_handle_sibling_calls,
1949         rest_of_handle_jump_bypass, rest_of_handle_inlining,
1950         rest_of_handle_null_pointer, rest_of_handle_combine,
1951         rest_of_handle_life, rest_of_handle_cse, rest_of_handle_cse2,
1952         rest_of_handle_gcse, rest_of_handle_loop_optimize,
1953         rest_of_handle_loop2, rest_of_compilation): Move to passes.c.
1954         (decode_d_option): Use enable_rtl_dump_file.
1955         (compile_file, finalize, do_compile): Move profile+combine+graph
1956         cleanup to finish_optimization_passes.
1957         * toplev.h (init_optimization_passes, finish_optimization_passes,
1958         enable_rtl_dump_file): Declare.
1959
1960 2004-02-27  Eric Botcazou  <ebotcazou@act-europe.fr>
1961             Roger Sayle  <roger@eyesopen.com>
1962
1963         * fold-const.c (fold): Revert 2004-02-25 change.  Use the original
1964         operands to build a tree with swapped operands.
1965         * expr.c (expand_expr_real) <MAX_EXPR>: Consistently use the
1966         'unsignedp' predicate to specify the signedness.
1967
1968 2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
1969
1970         * c-decl.c, c-ppoutput.c, combine.c, cppfiles.c, dwarf2out.c,
1971         expr.c, fold-const.c, gcc.c, haifa-sched.c, loop-iv.c,
1972         params.def, read-rtl.c, rtl.c, rtlanal.c, toplev.c: Fix
1973         comment typos and formatting.  Follow spelling conventions.
1974
1975 2004-02-26  Aldy Hernandez  <aldyh@redhat.com>
1976
1977         * config/rs6000/rs6000.md: Add fixuns_truncsfsi2 and
1978         fix_truncsfsi2.
1979
1980         * config/rs6000/spe.md: Delete spe_efsctuiz.
1981         Add spe_fixuns_truncsfsi2.
1982         Add spe_fix_truncsfsi2.
1983
1984 2004-02-26  Eric Christopher  <echristo@redhat.com>
1985
1986         * c-lex.c (c_lex_string_translate): New variable.
1987         (lex_string): Use to determine string translation.
1988         * c-pragma.h: Prototype.
1989         * c-parse.in (start_string_translation): New. Set above.
1990         (stop_string_translation): Ditto.
1991         (attribute, attribute_list, asm_def, asm_stmt,
1992         asm_operand): Use above functions.
1993         * cp/parser.c (cp_parser_declaration): Translate strings
1994         unless token is RID_EXTERN. Set c_lex_string_translate
1995         for recursive use.
1996         (cp_parser_asm_definition): Only translate argument strings
1997         to asms.
1998         (cp_parser_asm_operand_list): Ditto.
1999         (cp_parser_attribute_list): Do not translate attribute strings.
2000
2001 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
2002
2003         * stmt.c (expand_start_case_dummy): Remove.
2004         * tree.h: Remove the corresponding prototype.
2005
2006 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
2007
2008         * builtins.c (apply_args_register_offset): Remove.
2009         * tree.h: Remove the corresponding prototype.
2010
2011 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
2012
2013         * stor-layout.c (is_pending_size): Remove.
2014         * tree.h: Remove the corresponding prototype.
2015
2016 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
2017
2018         * recog.c (validate_replace_src): Remove.
2019         * recog.h: Remove the corresponding prototype.
2020
2021 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
2022
2023         * calls.c: Don't reference FINAL_REG_PARM_STACK_SPACE or
2024         MAYBE_REG_PARM_STACK_SPACE.
2025         * function.c: Likewise.
2026         * system.h (FINAL_REG_PARM_STACK_SPACE): Poison.
2027         (MAYBE_REG_PARM_STACK_SPACE): Likewise.
2028         * doc/tm.texi (FINAL_REG_PARM_STACK_SPACE): Remove.
2029         (MAYBE_REG_PARM_STACK_SPACE): Likewise.
2030
2031 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
2032
2033         * c-decl.c (c_expand_deferred_function): Remove.
2034         * c-tree.h: Remove the corresponding prototype.
2035
2036 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
2037
2038         * postreload.c (reload_cse_move2add): Generate just a PLUS
2039         instead of an entire SET.
2040
2041 2004-02-26  Jan Hubicka  <jh@suse.cz>
2042
2043         * config.gcc: Add support for nocoma/prescott/pentium-m/pentium3m
2044         /pentium4m.
2045         * i386.c (override_options): Add support for new CPUs.
2046         * i386.h (TARGET_CPU_DEFAULT_NAMES): New names.
2047         (TARGET_CPU_DEFAULT_pentium_m, TARGET_CPU_DEFAULT_pentium4e): New
2048         constants.
2049         * invoke.texi: Extend documentation of -mtune/-march for new CPUs.
2050
2051 2004-02-26  Bob Wilson  <bob.wilson@acm.org>
2052
2053         * config/xtensa/xtensa.h (TARGET_CPU_CPP_BUILTINS): Define __xtensa__.
2054
2055 2004-02-26  Eric Botcazou  <ebotcazou@act-europe.fr>
2056
2057         * config/sparc/sparc-protos.h (sparc_emit_floatunsdi): Add 'mode'.
2058         (sparc_emit_fixunsdi): New prototype.
2059         * config/sparc/sparc.c (sparc_emit_floatunsdi): Use 'mode' argument.
2060         (sparc_emit_fixunsdi): New function.
2061         * config/sparc/sparc.md (floatunsdisf2): Use 'general_operand' for
2062         operand 1.  Pass SFmode to sparc_emit_floatunsdi.
2063         (floatunsdidf2): Use 'general_operand' for operand 1.  Pass DFmode
2064         to sparc_emit_floatunsdi.
2065         (fixuns_truncsfdi2): New expander.
2066         (fixuns_truncdfdi2): Likewise.
2067
2068 2004-02-26  Alan Modra  <amodra@bigpond.net.au>
2069
2070         * gcse.c (delete_null_pointer_checks_1): Do not delete CC setter
2071         unless HAVE_cc0.
2072
2073 2004-02-25  Richard Henderson  <rth@redhat.com>
2074
2075         * explow.c (force_reg): Call mark_reg_pointer as appropriate.
2076         * config/alpha/alpha.c (alpha_emit_conditional_branch): Don't
2077         use (op0-op1) == 0 if op0 is a pointer.
2078         * config/alpha/alpha.md (cmpdi): Use some_operand.
2079         (three comparison combine splits): Remove.
2080
2081 2004-02-25  Richard Henderson  <rth@redhat.com>
2082
2083         PR c/12794
2084         * c-common.c (handle_alias_attribute): Reject the attribute if
2085         current_function_decl is set.
2086
2087 2004-02-25  Kelley Cook  <kcook@gcc.gnu.org>
2088
2089         * config.gcc: Add comment describing extra_gcc_objs.
2090         i[34567]86-*-cygwin*): Replace host_extra_gcc_objs with extra_gcc_objs.
2091         * configure.ac (extra_gcc_objs): New substitution variable.
2092         (host_extra_gcc_objs): Don't substitute.
2093         * configure: Regenerate.
2094         * Makefile.in: Use extra_gcc_objs.
2095
2096 2004-02-25  Kelley Cook  <kcook@gcc.gnu.org>
2097
2098         * doc/contrib.texi: Add an entry for myself.
2099
2100 2004-02-25  Jan Hubicka  <jh@suse.cz>
2101
2102         * basic-block.h (make_eh_edge, break_superblocks): Declare.
2103         * cfgbuild.c (make_eh_edge):  Make global.
2104         * cfglayout.c (break_superblocks): Likewise; fix memory leak.
2105         * except.c (build_post_landing_pads, connect_post_landing_pads,
2106         dw2_build_landing_pads, sjlj_emit_function_enter,
2107         sjlj_emit_function_exit, sjlj_emit_dispatch_table,
2108         sjlj_build_landing_pads): Update CFG.
2109         (emit_to_new_bb_before): New function.
2110         (finish_eh_generation): Do not rebuild the CFG.
2111
2112 2004-02-25  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
2113
2114         * config.gcc (hppa*-*-*, parisc*-*-*): Add MASK_BIG_SWITCH to all
2115         target_cpu_default defines.
2116         * pa-hpux.h (TARGET_DEFAULT): Add MASK_BIG_SWITCH to define.
2117         * pa.h (TARGET_DEFAULT): Likewise.
2118
2119 2004-02-25  Eric Botcazou  <ebotcazou@act-europe.fr>
2120
2121         * fold-const.c (fold): Treat MAX_EXPR and MIN_EXPR like
2122         comparisons with regard to signedness.
2123
2124 2004-02-25  Richard Earnshaw  <rearnsha@arm.com>
2125
2126         * arm.c (thumb_legitimize_address): New function.
2127         * arm-protos.h: Prototype it.
2128         * arm.h (THUMB_LEGITIMIZE_ADDRESS): Define.
2129         (LEGITIMIZE_ADDRESS): Use it.
2130
2131 2004-02-25  J"orn Rennecke <joern.rennecke@superh.com>
2132
2133         * reload1.c (reload): Only spill eliminable register with multiple
2134         adjacent elimination alternatives if all alternatives fail.
2135
2136 2004-02-25  Richard Earnshaw  <rearnsha@arm.com>
2137
2138         * arm.c (arm_legitimate_index_p): For QImode the range of an offset
2139         is -4095...+4095 inclusive.
2140
2141 2004-02-25  Eric Botcazou  <ebotcazou@libertysurf.fr>
2142
2143         * doc/install.texi (sparc-sun-solaris2* specific notes): Document
2144         the bootstrap failure with Sun CC 5.4 and 5.5.
2145
2146 2004-02-24  Kazu Hirata  <kazu@cs.umass.edu>
2147
2148         * cse.c (cse_change_cc_mode_insns): Stop at any instruction
2149         which modifies NEWREG.
2150         (cse_condition_code_reg): Update the mode of CC_REG in
2151         CC_SRC_INSN on our own.
2152
2153 2004-02-24  Michael Matz  <matz@suse.de>
2154
2155         * config/i386/i386.c (ix86_comp_type_attributes): Check for
2156         regparm attributes.
2157
2158 2004-02-24  Richard Henderson  <rth@redhat.com>
2159
2160         * toplev.c (dump_file_tbl): Rename from dump_file.
2161         * bb-reorder.c, bt-load.c, cfgcleanup.c, cfglayout.c, cfgloopanal.c,
2162         cfgloopmanip.c, cfgrtl.c, config/arm/arm.c, config/frv/frv.c,
2163         config/i386/i386.c, config/ia64/ia64.c, config/mips/mips.c,
2164         config/sh/sh.c, cse.c, flow.c, ifcvt.c, loop-iv.c, loop-unroll.c,
2165         loop-unswitch.c, output.h, predict.c, profile.c, ra-build.c,
2166         ra-colorize.c, ra-debug.c, ra-rewrite.c, ra.c, regrename.c, reload1.c,
2167         toplev.c, tracer.c, value-prof.c, var-tracking.c, web.c:
2168         s/rtl_dump_file/dump_file/g.
2169
2170 2004-02-24  Aldy Hernandez  <aldyh@redhat.com>
2171
2172         * config/rs6000/spe.md (spe_fix_truncsfsi2): Delete.
2173         (spe_fixuns_truncsfsi2): Delete.
2174
2175         * config/rs6000/rs6000.md (fix_truncsfsi2): Delete.
2176         (fixuns_truncsfsi2): Delete.
2177
2178 2004-02-24  Josef Zlomek  <zlomekj@suse.cz>
2179
2180         PR/14240
2181         * rtlanal.c (replace_label): Fix replacing labels in constant pool.
2182
2183 2004-02-24  Geoffrey Keating  <geoffk@apple.com>
2184
2185         * config/darwin.h (TARGET_HAS_F_SETLKW): Define.
2186
2187 2004-02-24  Jason Merrill  <jason@redhat.com>
2188
2189         * tree.c (check_qualified_type): New fn.
2190         (get_qualified_type): Use it.  If type already has the desired
2191         quals, just return it.
2192         * tree.h: Declare it.
2193
2194 2003-02-24  Sanjiv Kumar Gupta  <sanjivg@noida.hcltech.com>
2195
2196         * target-def.h (TARGET_SCHED_INIT_GLOBAL,
2197         TARGET_SCHED_FINISH_GLOBAL): New macros.
2198
2199         * target.h (md_init_global, md_finish_global): Function
2200         declarations corresponding to new target macros.
2201
2202         * haifa-sched.c (sched_init, sched_finish): Allow target to
2203         call the new schedular hooks.
2204
2205         * flow.c (recompute_reg_usage): Add PROP_DEATH_NOTES flag in
2206         call to update_life_info.
2207
2208         * config/sh/sh.h (OVERRIDE_OPTIONS): Re-enable
2209         flag_schedule_insns for SH4.
2210
2211         * config/sh/sh.c (sh_md_init_global, sh_md_finish_global,
2212         find_set_regmode_weight, find_insn_regmode_weight,
2213         find_regmode_weight), sh_md_init, sh_dfa_new_cycle,
2214         sh_variable_issue, high_pressure, ready_reorder,
2215         rank_for_reorder, swap_reorder, sh_reorder, sh_reorder2): New
2216         functions used to throttle the insn movement in first
2217         scheduling pass for SH.
2218
2219         * gcc/doc/tm.texi: Document TARGET_SCHED_INIT_GLOBAL and
2220         TARGET_SCHED_FINISH_GLOBAL.
2221
2222 2004-02-24  Alexandre Oliva  <aoliva@redhat.com>
2223
2224         Implement FR-V FDPIC ABI support for frv-uclinux and frv-linux.
2225         2004-02-05  Alexandre Oliva  <aoliva@redhat.com>
2226         * config/frv/frv.c (frv_emit_movsi): Use GOT relocations for
2227         symbols in sections named by the user.
2228         2004-01-30  Alexandre Oliva  <aoliva@redhat.com>
2229         * config/frv/linux.h (TARGET_OS_CPP_BUILTINS): New.
2230         2004-01-27  Alexandre Oliva  <aoliva@redhat.com>
2231         * config.gcc (frv-*-*linux*): Handle like *-*-linux*.
2232         * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Remove, obviated by
2233         the above.
2234         2004-01-20  Alexandre Oliva  <aoliva@redhat.com>
2235         * config/frv/frv.md (symGOT2reg_hilo, symGOTOFF2reg_hilo): Add
2236         one more pseudo to further improve code generation.
2237         2004-01-19  Alexandre Oliva  <aoliva@redhat.com>
2238         * config/frv/frv.md (movdi_ldd): Introduce explicit indirection
2239         inside UNSPEC.
2240         2004-01-16  Alexandre Oliva  <aoliva@redhat.com>
2241         * config/frv/frv.c (frv_legitimate_address_p): Added
2242         allow_double_reg_p argument.  Adjust all callers.  Use it to
2243         decide whether to enable double-register indirect addressing.
2244         (frv_funcdesc_alias_set): Remove.
2245         (frv_expand_fdpic_call): Force non-SYMBOL_REF operand into
2246         register.  Emit movdi_ldd.
2247         (ldd_address_operand): New.
2248         * config/frv/frv-protos.h (frv_legitimate_address_p): Adjust.
2249         * config/frv/frv.h (GO_IF_LEGITIMATE_ADDRESS): Likewise.
2250         (PREDICATE_CODES): Add ldd_address_operand.
2251         * config/frv/frv.md (movdi_ldd): New.
2252         (symGOT2reg_hilo, symGOTOFF2reg_hilo): Use separate pseudo for
2253         intermediate computations if possible.
2254         (symGOTOFF2reg_i): Fix harmless typo.
2255         2003-12-18  Alexandre Oliva  <aoliva@redhat.com>
2256         * unwind-dw2-fde-glibc.c (_Unwind_IteratePhdrCallback): Cast
2257         relocated p_vaddr to vaddr type.
2258         * config/frv/frv-protos.h (frv_expand_fdpic_call): Return void.
2259         * config/frv/frv.c (frv_get_funcdesc_alias_set): New.
2260         (frv_expand_fdpic_call): Propagate incoming MEM's expr to funcdesc
2261         MEM, or use a funcdesc alias set.  Use regular move instead of
2262         ldd.
2263         (dbl_memory_one_insn_operand): Recognize function descriptors by
2264         type or by alias set, and don't split them.
2265         * config/frv/frv.md (call, call_value): Never use call_internal
2266         for fdpic.
2267         (call_internal, call_value_internal): Never match for FDPIC.
2268         (call_fdpicdi, call_fdpicsi, call_value_fdpicdi,
2269         call_value_fdpicsi): Require FDPIC.
2270         (ldd): Removed.
2271         2003-12-17  Alexandre Oliva  <aoliva@redhat.com>
2272         * config/frv/frv.h (CRT_GET_RFIB_DATA): Define for __FRV_FDPIC__.
2273         * unwind-dw2-fde-glibc.c: Don't include elf-fdpic.h any more.
2274         (_Unwind_IteratePhdrCallback): Adjust type of load_base for FRV
2275         FDPIC.  Compute data base address.
2276         * config/frv/linux.h (SUBTARGET_DRIVER_SELF_SPECS): Enable -mfdpic
2277         before the other self-specs are processed.
2278         * config/frv/t-linux (CRTSTUFF_T_CFLAGS, TARGET_LIBGCC2_CFLAGS):
2279         Build with -fPIC.
2280         2003-12-15  Alexandre Oliva  <aoliva@redhat.com>
2281         * unwind-dw2-fde-glibc.c: Don't include bits/elf-fdpic.h if
2282         inhibit_libc is defined.
2283         2003-12-12  Alexandre Oliva  <aoliva@redhat.com>
2284         * unwind-dw2-fde-glibc.c: Include bits/elf-fdpic.h for
2285         __FRV_FDPIC__.
2286         (__RELOC_POINTER): Define.
2287         (_Unwind_IteratePhdrCallback): Use it.
2288         * config/frv/frv.h (Twrite): Define.
2289         (TRANSFER_FROM_TRAMPOLINE): Use it.
2290         * config/frv/linux.h (INVOKE__main): Undefine.
2291         (Twrite): Override.
2292         2003-12-05  Richard Sandiford  <rsandifo@redhat.com>
2293         * doc/invoke.texi (-mlong-calls, -mlinked-fp): Document FRV options.
2294         (-mlibrary-pic): Emphasize that this option generates EABI code.
2295         (-mcpu): Add fr550.
2296         (-mpack): Remove.
2297         2003-11-30  Alexandre Oliva  <aoliva@redhat.com>
2298         * config/frv/frv.c (int_2word_operand): Reject LABELs, SYMBOL_REFs
2299         and CONSTs in FDPIC mode.
2300         * gcc/config.gcc (with_cpu): Default to fr400 on frv-*-*linux*.
2301         2003-11-29  Richard Sandiford  <rsandifo@redhat.com>
2302         * config/frv/frv.c (move_source_operand): Don't accept symbolic
2303         constants.
2304         * config/frv/frv.md (*movhi_internal, *movsi_internal): Use an 'n'
2305         rather than 'i' constraint for the 2-instruction alternative.
2306         (*movsi_2word): New, incorporating existing int_2word_operand splitter.
2307         2003-11-29  Richard Sandiford  <rsandifo@redhat.com>
2308         * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Q): Renamed from
2309         EXTRA_CONSTRAINT_FOR_Y.
2310         (EXTRA_CONSTRAINT): Remove handling of 'Y'.
2311         * config/frv/frv.md (*movsi_internal): Remove 'Q' constraint.
2312         (addsi3): Change 'Y' constraint to 'Q'.
2313         2003-11-27  Richard Sandiford  <rsandifo@redhat.com>
2314         * reload.c (CONST_POOL_OK_P): New macro.
2315         (find_reloads): Use it to decide whether a constant can be forced
2316         into memory.
2317         * config/frv/frv.h (LEGITIMATE_PIC_OPERAND_P): Return true if the
2318         constant satisfies got12_operand.
2319         (frv_cannot_force_const_mem): Always return true for TARGET_FDPIC.
2320         (frv_legitimate_address_p): Check for valid unspec offsets using
2321         got12_operand rather than frv_legitimate_fdpic_operand_p.
2322         (frv_legitimate_fdpic_operand_p): Delete.
2323         (frv_emit_movsi): Abort if we try to use the FDPIC register during
2324         or after reload.
2325         (frv_legitimate_constant_p): Return LEGITIMATE_PIC_OPERAND_P if
2326         TARGET_FDPIC.
2327         * config/frv/frv.md (*movdf_double): Add alternatives for CONST_DOUBLE.
2328         2003-11-19  Richard Sandiford  <rsandifo@redhat.com>
2329         * config/frv/frv-protos.h (fdpic_operand, fdpic_got12_operand)
2330         (frv_fdpic_fptr_operand): Don't declare here.
2331         * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Y): Call got12_operand
2332         rather than fdpic_got12_operand.
2333         (PREDICATE_CODES): Remove symbolic_operand entry.  Add entries for
2334         got12_operand and const_unspec_operand.
2335         * config/frv/frv.c (got12_operand): Renamed from fdpic_got12_operand.
2336         (gpr_or_int12_operand, dbl_memory_one_insn_operand): Update calls.
2337         (symbolic_operand): Remove.
2338         (const_unspec_operand): New predicate.
2339         * config/frv/frv.md (*movsi_got): Use got12_operand.
2340         (*movsi_high_got, *movsi_lo_sum_got): Use const_unspec_operand.
2341         2003-11-18  Richard Sandiford  <rsandifo@redhat.com>
2342         * config/frv/frv-protos.h (frv_output_addr_const_extra): Remove.
2343         * config/frv/frv.h (OUTPUT_ADDR_CONST_EXTRA): Remove definition.
2344         * config/frv/frv.c (frv_unspec): New structure.
2345         (frv_small_data_reloc_p, frv_const_unspec_p): New functions.
2346         (frv_print_operand_memory_reference): Use frv_const_unspec_p to
2347         validate CONST indices.  Use frv_output_const_unspec to print them.
2348         (frv_print_operand): Update call to unspec_got_name.  Use
2349         frv_output_const_unspec to print constant unspecs.
2350         (frv_legitimate_fdpic_operand_p): Return true if frv_const_unspec_p.
2351         Reject UNSPECs otherwise.
2352         (unspec_got_name): Take the relocation number as argument, not an
2353         rtx containing it.
2354         (frv_output_addr_const_extra): Remove, replacing with...
2355         (frv_output_const_unspec): ...this new function.
2356         (frv_find_base_term): Use frv_const_unspec_p & frv_small_data_reloc_p.
2357         (gpr_or_int12_operand): Use fdpic_got12_operand.
2358         (dbl_memory_one_insn_operand): Likewise.
2359         (fdpic_got12_operand): Use frv_const_unspec_p.
2360         (frv_emit_movsi): Use frv_const_unspec_p to check for CONSTs that
2361         are already legitimate.  Use frv_small_data_reloc_p when deciding
2362         whether to use HIGH/LO_SUM for R_FRV_GOTOFF12 and R_FRV_GPREL12.
2363         2003-11-18  Alexandre Oliva  <aoliva@redhat.com>
2364         * config/frv/t-linux (SHLIB_MAPFILES): Override so as to export...
2365         * config/frv/libgcc-frv.ver: ... frv-specific symbols.  New file.
2366         * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
2367         label, for real this time.
2368         * config/frv/frv.c (frv_local_funcdesc_p): Update to new
2369         representation of visibility.
2370         (fdpic_got12_operand, symbolic_operand): Mark unused arguments as
2371         such.
2372         2003-11-17  Richard Sandiford  <rsandifo@redhat.com>
2373         * config/frv/frv.h (MASK_LINKED_FP, TARGET_LINKED_FP): New macros.
2374         (TARGET_SWITCHES): Add -mlinked-fp and -mno-linked-fp.
2375         * config/frv/frv.c (frv_override_options): Set MASK_LINKED_FP unless
2376         it was explicitly disabled.
2377         (frv_stack_info): There is no need to save the link register in every
2378         frame unless TARGET_LINKED_FP is true.
2379         (frv_frame_pointer_required): If !TARGET_LINKED_FP, only require a
2380         frame pointer if the stack pointer might change value.
2381         (frv_return_addr_rtx): Check and process "count" argument.
2382         2003-11-14  Richard Sandiford  <rsandifo@redhat.com>
2383         * config/frv/frv-protos.h (frv_legitimize_address): Remove.
2384         (frv_find_base_term): Declare.
2385         * config/frv/frv.h (LEGITIMIZE_ADDRESS): Do nothing.
2386         (FIND_BASE_TERM): Define.
2387         (PREDICATE_CODES): Remove pic_register_operand, pic_symbolic_operand,
2388         small_data_register_operand, small_data_symbolic_operand.  Add
2389         symbolic_operand.
2390         * config/frv/frv.c (const_small_data_p, plus_small_data_p): Delete.
2391         (frv_print_operand_memory_reference, output_move_single): Remove
2392         special handling for unlegitimized sdata addresses.
2393         (frv_legitimate_address_p): Don't allow sums of SDA_BASE_REG
2394         and symbolic addresses.
2395         (frv_legitimize_address, frv_legitimize_fdpic_address): Delete.
2396         (frv_find_base_term): New function.
2397         (int_2word_operand): Check specifically for symbolic address constants.
2398         (pic_register_operand, pic_symbolic_operand): Delete.
2399         (small_data_register_operand, small_data_symbolic_operand): Delete.
2400         (dbl_memory_one_insn_operand): Don't call plus_small_data_p.
2401         Allow UNSPEC_GOT constants if !TARGET_FDPIC.
2402         (move_source_operand): Only accept CONSTs if they're a two-insn
2403         symbolic constant.
2404         (fdpic_got12_operand): Don't require TARGET_FDPIC.
2405         (frv_emit_movsi): Legitimize sdata and -mlibrary-pic addresses
2406         using gen_symGOTOFF2reg*.
2407         (frv_ifcvt_rewrite_mem): Remove (plus gr16 ...) special cases.
2408         (frv_rtx_costs): Give all MEM addresses a cost of 0.  Give MEMs
2409         themselves a cost of 3 insns.
2410         * config/mips/mips.md (*movsi_got): Allow for !TARGET_FDPIC too.
2411         Change predicate to symbolic_operand.
2412         (*movsi_high_got, *movsi_lo_sum_got): Likewise.
2413         (*movsi_lda_sdata): Delete.
2414         (*movsi_pic, movsi_high_pic, movsi_lo_sum_pic): Delete.
2415         2003-11-05  Alexandre Oliva  <aoliva@redhat.com>
2416         * config.gcc: Add t-slibgcc-elf-ver and support --with-cpu for
2417         frv-*-*linux*.
2418         * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
2419         label.
2420         * config/frv/frv.h (DRIVER_SELF_SPECS): Add blank before
2421         -multilib-library-pic.
2422         (LINK_SPEC): Add -z text for -mfdpic.
2423         * config/frv/frvbegin.c (__ROFIXUP_LIST__): Don't define on FDPIC.
2424         * config/frv/frvend.c (__ROFIXUP_END__): Likewise.
2425         * config/frv/linux.h (STARTFILE_SPEC, ENDFILE_SPEC, LINK_SPEC):
2426         Override.
2427         (OPTION_DEFAULT_SPECS, HAS_INIT_SECTION, INIT_SECTION_ASM_OP,
2428         FINI_SECTION_ASM_OP, CRT_CALL_STATIC_FUNCTION): Define.
2429         * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Use
2430         crtstuff-generated files.
2431         2003-10-31  Alexandre Oliva  <aoliva@redhat.com>
2432         * config.gcc: Add frv-*-*linux*.
2433         * config/frv/linux.h, config/frv/t-linux: New.
2434         2003-10-06  Alexandre Oliva  <aoliva@redhat.com>
2435         * config/frv/frv.h (LINK_SPEC): Pass -melf32frvfd to the linker
2436         when -mfdpic even if a linker script is explicitly listed.
2437         2003-10-02  Alexandre Oliva  <aoliva@redhat.com>
2438         * config/frv/frv.c (frv_override_options): Clear asm_out
2439         unaligned_op for SImode on FDPIC.
2440         (frv_emit_movsi): Use compute_reloc_for_constant to compute the
2441         argument passed to decl_readonly_section.
2442         (frv_assemble_integer): Revert 2003-09-30's change, but make the
2443         whole block run with FDPIC even with -fno-PIC.
2444         2003-10-02  Alexandre Oliva  <aoliva@redhat.com>
2445         * config/frv/frv.c (frv_cannot_force_const_mem): Don't force
2446         symbol or label plus offset to memory.
2447         (frv_emit_movsi): Emit GPREL only if -mgprel-ro.  Emit 32-bit
2448         GOTOFF and GPREL for LABEL_REF.
2449         * config/frv/frv.h (DRIVER_SELF_SPECS): Add -mgprel-ro with
2450         -mfdpic unless -mno-gprel-ro, -fpic or -fpie.
2451         (MASK_GPREL_RO, TARGET_GPREL_RO): New.
2452         (TARGET_SWITCHES): Added gprel-ro and no-gprel-ro.
2453         * doc/invoke.texi: Document them.
2454         2003-09-30  Alexandre Oliva  <aoliva@redhat.com>
2455         * config/frv/frv-protos.h (frv_gen_GPsym2reg): Declare.
2456         (frv_splittable_got_operand): Removed.
2457         * config/frv/frv.c (frv_cannot_force_const_mem): Reject HIGH and
2458         LO_SUM.  Add comments.
2459         (frv_override_options): Moved enabling of FDPIC to
2460         DRIVER_SELF_SPECS.  Don't enable MASK_DWORD.
2461         (frv_local_funcdesc_p): Remove unnecessary heck for flag_pie.
2462         (frv_legitimize_fdpic_address): Don't duplicate logic in
2463         frv_emit_movsi.
2464         (frv_gen_GPsym2reg): New.
2465         (unspec_got_name): Added gprel.
2466         (frv_expand_fdpic_call): Add support for inlining PLTs.
2467         (fdpic_fptr_operand): Renamed from frv_fdpic_fptr_operand.
2468         (gpr_or_int12_operand): Added GPREL12.
2469         (pic_symbolic_operand): Match even if !flag_pic for FDPIC.
2470         (small_data_symbolic_operand): Fail if FDPIC.
2471         (fdpic_splittable_got_operand): Removed.
2472         (fdpic_got12_operand): Added GPREL12.
2473         (frv_emit_movsi): Reorganize to avoid duplication.  Emit GPREL
2474         when appropriate.  Fix sdata GOTOFF.
2475         (frv_legitimate_constant_p): Require legitimate PIC operand for
2476         FDPIC with pic, but only a legitimate fdpic operand for non-pic.
2477         (frv_assemble_integer): Move FDPIC funcdesc handling out of
2478         flag_pic case.
2479         (frv_asm_out_constructor, frv_asm_out_destructor): Abort if
2480         frv_assemble_integer fails.
2481         * config/frv/frv.h (DRIVER_SELF_SPECS): New.
2482         (SUBTARGET_DRIVER_SELF_SPECS): New.
2483         (ASM_SPEC): Don't pass -mno-fdpic.
2484         (LINK_SPEC): Pass -melf32frvfd for FDPIC.
2485         (MASK_INLINE_PLT, TARGET_INLINE_PLT): New.
2486         (TARGET_SWITCHES): Add -minline-plt, -mno-inline-plt and
2487         -multilib-library-pic.
2488         (PREDICATE_CODES): Added fdpic_operand, fdpic_fptr_operand,
2489         condexec_si_media_operator, condexec_sf_add_operator and
2490         condexec_sf_conv_operator.  Removed condexec_sf_binary_operator
2491         and condexec_sf_unary_operator.
2492         * config/frv/frv.md (R_FRV_GPREL12, R_FRV_GPRELHI, R_FRV_GPRELLO):
2493         New.
2494         (movsi_got, movsi_high_got, movsi_lo_sum_got): Move before
2495         movsi_internal.  Give them internal names.  movsi_got has type
2496         int.
2497         (fdpic got splitters): Remove.
2498         (symGPREL2reg, symGPREL2reg_hilo): New.
2499         * config/frv/t-frv (MULTILIB_MATCHES): Don't map -fpic and -fPIC
2500         to -mlibrary-pic.  Map -multilib-library-pic to it.
2501         * doc/invoke.texi: -mfdpic, -minline-plt, -multilib-library-pic:
2502         Document.
2503         2003-09-28  Alexandre Oliva  <aoliva@redhat.com>
2504         * config/frv/frv.c (frv_function_symbol_referenced_p): Declare.
2505         (TARGET_CANNOT_FORCE_CONST_MEM): Define to...
2506         (frv_cannot_force_const_mem): New function.
2507         (const_small_data_p, plus_small_data_p): Update comments on sdata
2508         on FDPIC.
2509         (frv_override_options): Set flag_pie for FDPIC too.
2510         (frv_conditional_register_usage): Mark gr16 and gr17 as non-fixed,
2511         call-saved registers on FDPIC.
2512         (frv_stack_info): Don't preserve the PIC register on FDPIC, and
2513         don't force LR to be preserved.
2514         (frv_expand_prologue): Likewise.
2515         (frv_asm_output_mi_thunk): Use 12-bit funcdesc gotoff for -fpic.
2516         (frv_frame_pointer_required): Don't force it just because the
2517         FDPIC register is used.
2518         (frv_legitimate_address_p) <CONST>: Accept a legitimate FDPIC
2519         operand only if !condexec_p.
2520         (frv_legitimize_address): Return the FDPIC-legitimized address.
2521         Don't match small data here on FDPIC.
2522         (frv_legitimate_fdpic_operand_p): Don't accept unadorned function
2523         symbols.  Use TRUE/FALSE instead of 1/0.
2524         (frv_local_funcdesc_p): New.
2525         (frv_legitimize_fdpic_address): Rewrite to use GOTOFF and 12-bit
2526         immediates when possible.
2527         (pic_symbolic_operand): Accept SYMBOL_REFs and CONSTs in FDPIC.
2528         (dbl_memory_one_insn_operand): Accept addresses that add a REG and
2529         an UNSPEC_GOT.
2530         (frv_emit_movsi): Handle FDPIC before small data.  Use GOTOFF and
2531         12-bit immediates when possible.
2532         (frv_legitimate_constant_p): In FDPIC, reject SImode operands that
2533         are not legitimate pic operands.
2534         (frv_in_small_data_p): Re-enable for FDPIC.
2535         * config/frv/frv.h (SDA_BASE_REG): Remove comment about FDPIC.
2536         (FRV_GLOBAL_P): Removed.
2537         * config/frv/frv.md: Add modes to CONSTs.
2538         (movsi_got): New.
2539         (movsi_lo_sum_got): Use separate matches instead of match_dup.
2540         (movsi_high_pic, movsi_lo_sum_pic): Match on non-FDPIC only.
2541         (fdpic splittable operations): Match on flag_pic != 1.
2542         2003-09-22  Alexandre Oliva  <aoliva@redhat.com>
2543         * config/frv/frv.c (frv_asm_out_constructor,
2544         frv_asm_out_destructor): Pass to frv_assemble_integer the size in
2545         bytes, not bits.
2546         2003-09-19  Alexandre Oliva  <aoliva@redhat.com>
2547         * config/frv/frv.c (frv_assemble_integer): Reject complex
2548         expressions referencing function SYMBOL_REFs.
2549         * config/frv/frv.c (frv_function_symbol_referenced_p): New.
2550         (move_source_operand): Reject CONSTs that reference function
2551         SYMBOL_REFs on FDPIC.
2552         (frv_emit_movsi): If we get such a CONST, break it up.
2553         * config/frv/frv.h (CPP_SPEC): Define __FRV_FDPIC__ for -mfdpic.
2554         (TRANSFER_FROM_TRAMPOLINE): Use different definitions for FDPIC.
2555         * config/frv/frv.c (frv_print_operand) <I>: Recognize PLUS without
2556         MEM.
2557         (frv_assemble_integer): Don't use funcdesc for LABEL_REFs.
2558         (frv_trampoline_size): Increase for FDPIC.
2559         * config/frv/frv.h (TRAMPOLINE_ALIGNMENT): Bump to 64 for FDPIC.
2560         (TRANSFER_FROM_TRAMPOLINE): Handle FDPIC trampolines.
2561         * config/frv/frv.c (frv_legitimize_fdpic_address, frv_emit_movsi):
2562         Disable use of GOTOFF for now.
2563         (const_small_data_p, plus_small_data_p, frv_in_small_data_p):
2564         Disable use of small data in FDPIC for now.
2565         (frv_asm_output_mi_thunk): Implement for FDPIC.
2566         * config/frv/frv.h (SDA_BASE_REG): Set to -1 with FDPIC.
2567         * config/frv/frv.c (frv_asm_out_constructor): Use
2568         frv_assemble_integer for FDPIC pointers.
2569         (frv_asm_out_destructor): Likewise.
2570         * config/frv/frv.md (ldd): Fix order of operands.  Use
2571         address_operand for input.
2572         2003-09-18  DJ Delorie  <dj@redhat.com>
2573         * config/frv/frv.c (frv_legitimate_fdpic_operand_p): Remove UNSPEC_PIC.
2574         (unspec_got_name): Correct typo.
2575         (frv_emit_movsi): Pre-expand splittable GOTs.
2576         (frv_expand_fdpic_call): Rename gen_lddi to gen_ldd.
2577         * config/frv/frv.md (lddi): Fix syntax error, rename to ldd.
2578         (symGOT2reg_hilo, symGOTOFF2reg_hilo): New.
2579         * config/frv/t-frv: Add -mfdpic multilibs.
2580         * config/frv/frv.h (ASM_SPEC): Pass -mfdpic/-mno-fdpic.
2581         (TARGET_SWITCHES): Add -mno-fdpic, fix documentation.
2582         * config/frv/frv.c (frv_override_options): -mfdpic assumes
2583         flag_pic, default to 32-bit pics, require DWORD ops.
2584         (frv_override_options): Add W and Z constraints.
2585         (frv_expand_prologue): No pic prologue for -mfdpic.
2586         (frv_asm_output_mi_thunk): Support -mfdpic (soon).
2587         (frv_print_operand_memory_reference): Handle GOT constants.
2588         (frv_legitimate_address_p): Allow GOT constants.
2589         (frv_legitimize_address): Handle GOT addresses too.
2590         (frv_legitimate_fdpic_operand_p): New.
2591         (frv_legitimize_fdpic_address): New.
2592         (unspec_got_name): New.
2593         (frv_output_addr_const_extra): New.
2594         (frv_expand_fdpic_call): New.
2595         (frv_fdpic_fptr_operand): New.
2596         (gpr_or_int12_operand): Handle GOT operands.
2597         (int_2word_operand): Handle GOT operands.
2598         (fdpic_operand): New.
2599         (fdpic_splittable_got_operand): New.
2600         (fdpic_got12_operand): New.
2601         (frv_emit_movsi): Handle GOT operands.
2602         (frv_assemble_integer): -mfdpic doesn't use rofixups.
2603         (frv_print_operand): Support 'g' code for GOT operands.
2604         * config/frv/frv-protos.h: Add prototypes as needed.
2605         * config/frv/frv.md (R_FRV_GOT12, R_FRV_GOTHI, R_FRV_GOTLO,
2606         R_FRV_FUNCDESC, R_FRV_FUNCDESC_GOT12, R_FRV_FUNCDESC_GOTHI,
2607         R_FRV_FUNCDESC_GOTLO, R_FRV_FUNCDESC_VALUE,
2608         R_FRV_FUNCDESC_GOTOFF12, R_FRV_FUNCDESC_GOTOFFHI,
2609         R_FRV_FUNCDESC_GOTOFFLO, R_FRV_GOTOFF12, R_FRV_GOTOFFHI,
2610         R_FRV_GOTOFFLO): New.
2611         (movsi_high_got, movsi_lo_sum_got): New.
2612         (*movsi_pic): Don't use this splitter for -mfdpic.
2613         (addsi3): Allow GOT references also.
2614         (call, call_value): Handle -mfdpic separately.
2615         (call_fdpicdi, call_fdpicsi, lddi, call_value_fdpicdi,
2616         call_value_fdpicsi): New.
2617         (symGOT2reg, symGOT2reg_i, got splitters, symGOTOFF2reg,
2618         symGOTOFF2reg_i): New.
2619         * config/frv/frv.h (MASK_FDPIC): New.
2620         (TARGET_FDPIC): New.
2621         (TARGET_SWITCHES): Add -mfdpic.
2622         (FDPIC_FPTR_REGNO): New.
2623         (FDPIC_REGNO): New.
2624         (OUR_FDPIC_REG): New.
2625         (enum reg_class): Add FDPIC_REGS, FDPIC_FPTR_REGS, and
2626         FDPIC_CALL_REGS.
2627         (REG_CLASS_NAMES): Likewise.
2628         (REG_CLASS_CONTENTS): Likewise.
2629         (EXTRA_CONSTRAINT_FOR_Y): New, for 12-bit GOTs.
2630         (EXTRA_CONSTRAINT): Add it here.
2631         (FRV_GLOBAL_P): New.
2632         (OUTPUT_ADDR_CONST_EXTRA): New.
2633
2634 2004-02-24  Kazu Hirata  <kazu@cs.umass.edu>
2635
2636         * config/sparc/sparc.h: Remove commented-out definitions of
2637         TARGET_EDOM and GEN_ERRNO_RTX.
2638
2639 2004-02-24  Kazu Hirata  <kazu@cs.umass.edu>
2640
2641         * df.c, df.h, ra-build.c, ra-rewrite.c, ra.c, web.c: Replace
2642         df_analyse with df_analyze.
2643
2644 2004-02-24  Alan Modra  <amodra@bigpond.net.au>
2645
2646         * gcse.c (delete_null_pointer_checks_1): Set stop_insn to end, not
2647         beginning of block.
2648
2649 2004-02-23  James E Wilson  <wilson@specifixinc.com>
2650
2651         * calls.c (precompute_arguments): Update comment.
2652
2653 2004-02-23  Kazu Hirata  <kazu@cs.umass.edu>
2654
2655         * et-forest.c: Replace et_occurences with et_occurrences.
2656
2657 2004-02-23  Kazu Hirata  <kazu@cs.umass.edu>
2658
2659         * cfgloop.h, loop-iv.c, loop-unswitch.c: Replace iv_analyse
2660         with iv_analyze.
2661
2662 2004-02-23  Kelley Cook  <kcook@gcc.gnu.org>
2663
2664         * config/i386/i386.c: Rename pni to sse3.
2665         * config/i386/i386.h: Likewise.
2666         * config/i386/i386.md: Likewise.
2667         * config/i386/pmmintrin.h: Likewise.
2668         * doc/extend.texi: Likewise.
2669         * doc/invoke.texi: Likewise.
2670
2671 2004-02-23  Zack Weinberg  <zack@codesourcery.com>
2672             Kazu Hirata  <kazu@cs.umass.edu>
2673
2674         Remove -fwritable-strings.
2675         * c-common.c (fix_string_type): Don't check
2676         flag_writable_strings.
2677         (fix_string_type): Likewise.
2678         * c-opts.c (set_std_c89): Don't initialize
2679         flag_writable_strings.
2680         (set_std_c99): Likewise.
2681         * common.opt (fwritable-strings): Remove.
2682         * flags.h: Remove the external declaration of
2683         flag_writable_strings.
2684         * opts.c (common_handle_option) <OPT_fwritable_strings>:
2685         Remove.
2686         * toplev.c (flag_writable_strings): Remove.
2687         (f_options): Remove an entry for writable-strings.
2688         * varasm.c (const_hash_1) <STRING_CST>: Don't check
2689         flag_writable_strings.
2690         (compare_constant) <STRING_CST>: Likewise.
2691         (build_constant_desc): Likewise.
2692         * config/darwin.c (machopic_select_section): Likewise.
2693         * config/arm/arm.c (AOF_ASSEMBLER): Likewise.
2694         * config/arm/pe.c (arm_pe_encode_section_info): Likewise.
2695         * config/iq2000/iq2000.c (iq2000_select_section): Likewise.
2696         * config/mips/mips.c (mips_select_section): Likewise.
2697         (mips_encode_section_info): Likewise.
2698         * config/pa/pa.c (pa_select_section): Likewise.
2699         * config/pa/pa.h (TEXT_SPACE_P): Likewise.
2700         * config/v850/v850.c (v850_select_section): Likewise.
2701         * doc/invoke.texi (-fwritable-strings): Remove.
2702         (-fno-const-strings): Don't mention -fwritable-strings.
2703         * doc/trouble.texi: Don't mention -fwritable-strings.
2704
2705 2003-02-23  Nathanael Nerode  <neroden@gcc.gnu.org>
2706
2707         * doc/install.texi: Update for switch of boehm-gc to autoconf 2.57.
2708
2709 2004-02-23  Dale Johannesen  <dalej@apple.com>
2710
2711         * config/rs6000.md (movsf_hardfloat): Add POWER form of nop.
2712         (movdf_hardfloat64):  Ditto.
2713         (movdf_softfloat64):  Ditto.
2714
2715 2004-02-23  Fariborz Jahanian <fjahanian@apple.com>
2716         * config/rs6000/rs6000.c (function_arg): call to
2717         rs6000_mixed_function_arg for DFmode moved to allow
2718         normal DFmode incoming register assignment.
2719
2720 2004-02-23  Dale Johannesen  <dalej@apple.com>
2721
2722         * config/rs6000.md (movsf_hardfloat): Accept CTR-to-CTR copy.
2723         (movdf_hardfloat64):  Ditto.
2724
2725 2004-02-23  Kazu Hirata  <kazu@cs.umass.edu>
2726
2727         * convert.c, gcov-io.c, libgcov.c, sched-int.h, sibcall.c,
2728         config/rs6000/linux.h, config/rs6000/rs6000-c.c: Update
2729         copyright.
2730
2731 2004-02-23  Andrew Pinski  <pinskia@physics.uc.edu>
2732
2733         PR c/14156
2734         * c-typeck.c (c_expand_return): Change check for VAR_DECL
2735         to use DECL_P instead.
2736
2737         * config/rs6000/linux.h (OS_MISSING_POWERPC64): Define.
2738         * config/rs6000/linux64.h (OS_MISSING_POWERPC64): Define.
2739
2740 2004-02-23  Kazu Hirata  <kazu@cs.umass.edu>
2741
2742         * Makefile.in (opts.o): Depend on target.h.
2743         * opts.c (decode_options): Use targetm.default_short_enums
2744         instead of DEFAULT_SHORT_ENUMS.
2745         * system.h (DEFAULT_SHORT_ENUMS): Poison.
2746         * target-def.h (TARGET_DEFAULT_SHORT_ENUMS): New.
2747         (TARGET_INITIALIZER): Add TARGET_DEFAULT_SHORT_ENUMS.
2748         * target.h (gcc_target): Add default_short_enums.
2749         * config/cris/cris.h: Remove a comment about
2750         DEFAULT_SHORT_ENUMS.
2751         * config/ip2k/ip2k.h: Likewise.
2752         * doc/tm.texi (DEFAULT_SHORT_ENUMS): Change to
2753         TARGET_DEFAULT_SHORT_ENUMS.  Update the description.
2754
2755 2004-02-23  Eric Botcazou  <ebotcazou@libertysurf.fr>
2756             Falk Hueffner  <falk@debian.org>
2757
2758         PR c/14188
2759         * builtins.c (expand_builtin_va_arg): Emit an informative message
2760         if a trap is generated.
2761         * c-typeck.c (build_function_call): Likewise.
2762
2763 2004-02-22  Jakub Jelinek  <jakub@redhat.com>
2764
2765         * gcov-io.c (gcov_open) [GCOV_LOCKED]: Use open + fdopen instead of
2766         fopen.
2767         * libgcov.c: Include sys/stat.h.
2768         * config/rs6000/linux.h (TARGET_HAS_F_SETLKW): Define.
2769         * config/rs6000/linux64.h (TARGET_HAS_F_SETLKW): Define.
2770         * config/sparc/linux.h (TARGET_HAS_F_SETLKW): Define.
2771         * config/sparc/linux64.h (TARGET_HAS_F_SETLKW): Define.
2772
2773 2004-02-22  Kazu Hirata  <kazu@cs.umass.edu>
2774
2775         * reorg.c: Remove comments about dead ports.
2776
2777 2004-02-22  Christopher Faylor  <cgf@redhat.com>
2778
2779         * config.gcc (i[34567]86-*-pe|i[34567]86-*-cygwin*): *Really* specify
2780         extra host object file when targetting cygwin rather than generic
2781         object files.
2782
2783 2004-02-22  Josef Zlomek  <zlomekj@suse.cz>
2784
2785         Merge from tree-ssa:
2786         2003-11-20  Richard Henderson  <rth@redhat.com>
2787
2788                 * tree-inline.c (insert_decl_map): New.
2789                 (remap_decl, remap_type, remap_block, copy_body_r,
2790                 initialize_inlined_parameters, declare_return_variable,
2791                 remap_save_expr): Use it.
2792
2793         * function.c (copy_body_r): Add mapping from id->ret_label to
2794         id->ret_label.  Revert test for ret_label.
2795
2796 2004-02-22  Jakub Jelinek  <jakub@redhat.com>
2797
2798         * genoutput.c (process_template): Strip trailing whitespace in @
2799         templates and issue a warning if there was any.
2800
2801 2004-02-21  Christopher Faylor  <cgf@redhat.com>
2802
2803         * config.gcc (i[34567]86-*-pe|i[34567]86-*-cygwin*): Specify extra host
2804         object file when targetting cygwin.
2805         * config/i386/t-cygwin (EXTRA_GCC_OBJS): Remove definition since it is
2806         overridden by top-level Makefile.
2807
2808 2004-02-21  Roger Sayle  <roger@eyesopen.com>
2809
2810         * config/i386/i386.c (standard_80387_constant_p): Also prefer
2811         the x87's load constant instructions when optimizing for size.
2812
2813 2004-02-21  Kazu Hirata  <kazu@cs.umass.edu>
2814
2815         * combine.c (SHIFT_COUNT_TRUNCATED): Remove.
2816         * defaults.h (SHIFT_COUNT_TRUNCATED): Provide the default.
2817         * expmed.c: Assume SHIFT_COUNT_TRUNCATED is always defined.
2818         * fold-const.c: Likewise.
2819         * simplify-rtx.c: Likewise.
2820
2821 2004-02-21  Alan Modra  <amodra@bigpond.net.au>
2822
2823         * combine.c (can_combine_p): Don't ignore SETs marked with
2824         REG_EH_REGION notes.
2825         (try_combine): When attemting to fix unrecognized insns, don't
2826         split a PARALLEL that contains the original i2.
2827
2828 2004-02-21  Ziemowit Laski  <zlaski@apple.com>
2829
2830         * config/darwin.h (TARGET_OPTION_TRANSLATE_TABLE): Refer to
2831         SUBTARGET_OPTION_TRANSLATE_TABLE for architecture-specific options.
2832         * config/i386/darwin.h (SUBTARGET_OPTION_TRANSLATE_TABLE): Define it.
2833         * config/rs6000/altivec.h: #error out if '-maltivec' not specified.
2834         (vector, pixel, bool): #define to __vector, __pixel and __bool.
2835         (__un_args_eq, __bin_args_eq, __tern_args_eq): Move to C-specific
2836         portion of header.
2837         (__altivec_link_error_invalid_argument): Remove prototype; will use
2838         __builtin_altivec_compiletime_error("vec_*") instead.
2839         (vec_*): Fix/complete set of available operation overloads given the
2840         existence of distinct 'vector bool ...' and 'vector pixel' types; tighten
2841         cv-correctness of pointer arguments; in C, always check for correct
2842         argument types before macro expansion.
2843         * config/rs6000/darwin.h (SUBTARGET_OPTION_TRANSLATE_TABLE): New macro
2844         defining Darwin/PowerPC-specific '-f[no-]altivec' and
2845         '-W[no-]altivec-long-deprecated' switches.
2846         * config/rs6000/rs6000-c (rs6000_cpu_cpp_builtins): Pre-define
2847         '__vector', '__pixel' and '__bool' macros using
2848         '__attribute__((altivec(...)))' types.
2849         * config/rs6000/rs6000.c (bool_char_type_node, bool_short_type_node,
2850         bool_int_type_node, pixel_type_node, bool_V16QI_type_node,
2851         bool_V8HI_type_node, bool_V4SI_type_node, pixel_V8HI_type_node):
2852         New type nodes.
2853         (rs6000_warn_altivec_long, rs6000_warn_altivec_long_switch): New, for
2854         handling '-W[no-]altivec-long-deprecated'.
2855         (rs6000_override_options): Handle '-W[no-]altivec-long-deprecated'.
2856         (rs6000_expand_binop_builtin, rs6000_expand_ternop_builtin,
2857         altivec_expand_dst_builtin): Remove casts from integer literals.
2858         (altivec_expand_builtin): Likewise; handle expansion of new
2859         '__builtin_altivec_compiletime_error' function.
2860         (rs6000_init_builtins): Initialize 'vector bool ...' and 'vector pixel'
2861         types, and make them distinct from other vector types; register
2862         '__builtin_altivec_compiletime_error' function.
2863         (print_operand): For 'P', print a full target register name instead of
2864         merely its number.
2865         (rs6000_attribute_table): Add "altivec" attribute.
2866         (rs6000_handle_altivec_attribute): New function.
2867         * config/rs6000/rs6000.h (TARGET_OPTIONS): Describe
2868         '-m[no-]-warn-altivec-long' (which '-W[no-]altivec-long-deprecated'
2869         maps to).
2870         (rs6000_warn_altivec_long, rs6000_warn_altivec_long_switch): Forward
2871         declare.
2872         (ALTIVEC_BUILTIN_COMPILETIME_ERROR): New built-in enumeration.
2873
2874 2004-02-20  James E Wilson  <wilson@specifixinc.com>
2875
2876         * config/ia64/ia64.md (shift_mix4left+1): Delete reload_completed
2877         check.
2878         (shift_mix4left+2): Delete redundant pattern.
2879
2880 2004-02-20  Kazu Hirata  <kazu@cs.umass.edu>
2881
2882         * alias.c (OUTGOING_REGNO): Don't define the default.
2883         * builtins.c (OUTGOING_REGNO): Likewise.
2884         (INCOMING_REGNO): Likewise.
2885         (apply_args_register_offset): Always use OUTGOING_REGNO.
2886         * combine.c (OUTGOING_REGNO): Likewise.
2887         * sibcall.c (OUTGOING_REGNO): Likewise.
2888         * defaults.h (INCOMING_REGNO): Provide the default.
2889         (OUTGOING_REGNO): Likewise.
2890
2891 2004-02-21  Jan Hubicka  <jh@suse.cz>
2892
2893         * params.def (max-peeled-insns, max-completely-peeled-insns,
2894         max-once-peeled-insns): Set to 400.
2895
2896 2004-02-20  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
2897
2898         PR c++/12007
2899         * dbxout.c (dbxout_parms): Check that DECL_RTL and DECL_INCOMING_RTL
2900         are set for parameters before outputing debugging information.
2901
2902 2004-02-20  Falk Hueffner  <falk@debian.org>
2903
2904         PR target/14201
2905         * config/alpha/alpha.md (*fix_truncsfsi_ieee): Fix typoed operand
2906         numbers.
2907
2908 2004-02-20  Per Bothner  <per@bothner.com>
2909
2910         * input.h:  Don't #include line-map.h.  It may cause link problems
2911         with undefined linemap_line_start when line-map.h is included but
2912         line-map.o is not linked, as currently happens with gengtype on
2913         compilers that don't support inline.
2914         * toplev.c:  So we do have to explicitly #include line-map.h here.
2915
2916 2004-02-20  Richard Henderson  <rth@redhat.com>
2917
2918         * doc/invoke.texi: Add -Wvariadic-macros.
2919
2920 2004-02-20  Kazu Hirata  <kazu@cs.umass.edu>
2921
2922         * haifa-sched.c (sched_emit_insn): Remove.
2923         * sched-int.h: Remove the corresponding prototype.
2924
2925 2004-02-20  Kazu Hirata  <kazu@cs.umass.edu>
2926
2927         Revert:
2928         2004-02-19  Kazu Hirata  <kazu@cs.umass.edu>
2929         * opts.c (decode_options): Don't use DEFAULT_SHORT_ENUMS.
2930         * system.h (DEFAULT_SHORT_ENUMS): Poison.
2931         * config/cris/cris.h: Remove a comment about
2932         DEFAULT_SHORT_ENUMS.
2933         * config/ip2k/ip2k.h: Likewise.
2934         * doc/tm.texi (DEFAULT_SHORT_ENUMS): Remove.
2935
2936 2004-02-20  Mohan Embar  <gnustuff@thisiscool.com>
2937             Tom Tromey  <tromey@redhat.com>
2938
2939         * doc/install.texi: Moved --disable-libgcj and
2940         --with-system-zlib documentation to new section for
2941         Java-specific options.
2942         Added explicit Cross-Compiler-Specific Options subheading.
2943         Added section for Java-specific options.
2944
2945 2004-02-20  Matt Kraai  <kraai@alumni.cmu.edu>
2946
2947         * doc/install.texi (Building the Ada compiler): Remove
2948         example.
2949
2950 2004-02-20  James E Wilson  <wilson@specifixinc.com>
2951
2952         * toplev.c (dump_file_index, dump_file): Put ce3 before rnreg.
2953
2954 2004-02-20  Kazu Hirata  <kazu@cs.umass.edu>
2955
2956         * gcc.c (process_command): Allow translation of the copyright
2957         symbol but not the rest of the copyright message.
2958         * gcov.c (print_version): Likewise.  Allow translation of the
2959         message about warranty.
2960
2961 2004-02-20  Hans-Peter Nilsson  <hp@axis.com>
2962
2963         * config/cris/cris.md ("*andsi_movu"): Correct parentheses in
2964         predicate.
2965         ("*andsi_clear"): Tweak constraints to not match postincrement.
2966         Adjust the predicate to exclude a volatile memory reference.
2967         ("*andhi_clear"): Ditto.  Rename from "*andhi_clear_signed".
2968         ("*andhi_clear_unsigned"): Remove, non-matching pattern.
2969
2970 2004-02-19  Matt Kraai  <kraai@alumni.cmu.edu>
2971
2972         * move-if-change: Remove.
2973         * Makefile.in (s-mlib, c-parse.y, s-check, s-gencheck)
2974         (s-specs, s-options, s-config, s-conditions, s-flags, s-codes)
2975         (s-constants, s-emit, s-recog, s-opinit, s-extract, s-peep)
2976         (s-attr, s-attrtab, s-output, s-genrtl, s-modes, s-preds)
2977         (s-gtyp-gen, s-iov): Use the top level move-if-change.
2978         * objc/Make-lang.in (objc/objc-parse.y): Likewise.
2979
2980 2004-02-19  James E Wilson  <wilson@specifixinc.com>
2981
2982         * config/i386/i386.md (doloop_end_internal): Use nonimmediate_operand
2983         for operand2.  Add condition that requires register_operand operand2
2984         before reload.
2985
2986 2004-02-19  Richard Sandiford  <rsandifo@redhat.com>
2987             Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
2988
2989         * config/mips/mips.c (mips_address_insns): Treat BLKmode specially.
2990         * config/mips/mips.md: Expand comment above unaligned loads and stores.
2991
2992 2004-02-19  Richard Henderson  <rth@redhat.com>
2993
2994         * Makefile.in (STRICT2_WARN): Add -Wno-variadic-macros.
2995         * tree.c (build0, build1, build2, build3, build4): Split out from...
2996         (build): ... here.  Call them.
2997         * tree.h (build, _buildN1, _buildN2, _buildC1, _buildC2): New.
2998
2999         * convert.c (convert_to_integer): Remove extra build argument.
3000         * tree-inline.c (expand_call_inline): Likewise.
3001
3002 2004-02-19  Richard Henderson  <rth@redhat.com>
3003
3004         * c-opts.c (warn_variadic_macros): New.
3005         (c_common_handle_option): Set it.
3006         (sanitize_cpp_opts): Copy it to cpp_opts.
3007         * c.opt (Wvariadic-macros): New.
3008         * cpplib.h (struct cpp_options): Add warn_variadic_macros.
3009         * cppinit.c (cpp_create_reader): Initialize it.
3010         * cppmacro.c (parse_params): Check it.
3011
3012 2004-02-19  David Daney <ddaney@avtrex.com>
3013
3014         PR preprocessor/14198
3015         * config/mips/linux.h (TARGET_OS_CPP_BUILTINS): Add
3016         builtin_assert ("machine=mips")
3017
3018 2004-02-19  Kazu Hirata  <kazu@cs.umass.edu>
3019
3020         * opts.c (decode_options): Don't use DEFAULT_SHORT_ENUMS.
3021         * system.h (DEFAULT_SHORT_ENUMS): Poison.
3022         * config/cris/cris.h: Remove a comment about
3023         DEFAULT_SHORT_ENUMS.
3024         * config/ip2k/ip2k.h: Likewise.
3025         * doc/tm.texi (DEFAULT_SHORT_ENUMS): Remove.
3026
3027 2004-02-19  Zack Weinberg  <zack@codesourcery.com>
3028
3029         * config/ia64/ia64.c (ia64_function_arg): In big-endian mode,
3030         when passing single SFmode quantities in general registers,
3031         put them in the high half.
3032
3033 2004-02-19  Aldy Hernandez  <aldyh@redhat.com>
3034
3035         * doc/md.texi (Standard Names): Document additional dependency on
3036         fix pattern.
3037
3038         * optabs.c (ftruncify): Remove.
3039         (expand_fix): Manually inline ftruncify above.
3040         (can_fix_p): Add FIXME note.
3041
3042 2004-02-19  Aldy Hernandez  <aldyh@redhat.com>
3043
3044         * config/rs6000/spe.md (spe_fixunssfsi2): Rename to
3045         spe_fixuns_truncsfsi2.
3046
3047         * config/rs6000/rs6000.md (fixunssfsi2): Rename to
3048         fixuns_truncsfsi2.
3049
3050 2004-02-19  Steve Ellcey  <sje@cup.hp.com>
3051
3052         * config/ia64/ia64.h (HARD_REGNO_CALLER_SAVE_MODE): New macro.
3053         * testsuite/gcc.dg/20040219-1.c: New test.
3054
3055 2004-02-19  Ulrich Weigand  <uweigand@de.ibm.com>
3056
3057         * config/s390/s390.md ("*subdf3_cc", "*subdf3_cconly", "*subsf3_cc",
3058         "*subsf3_cconly"): Subtraction is not commutative.
3059
3060 2004-02-19  Zack Weinberg  <zack@codesourcery.com>
3061
3062         * sdbout.c (preinit_symbols, sdbout_initialized): New statics.
3063         (sdbout_symbol): If called before sdbout_init, queue DECL for
3064         later and return.
3065         (sdbout_init): Set sdbout_initialized true, process decls
3066         queued earlier by sdbout_symbol.
3067         (sdbout_finish): Use size_t for index variable.
3068
3069 2004-02-19  Jeff Law  <law@redhat.com>
3070
3071         * fold-const.c (invert_truthvalue): Do not call invert_tree_comparison
3072         for unordered comparison codes.
3073
3074 2004-02-19  Ian Lance Taylor  <ian@wasabisystems.com>
3075
3076         * reload1.c (reload): Correct comment.
3077         (scan_paradoxical_subregs): Remove #if 0 and old comment.
3078         * doc/extend.texi (Local Reg Vars): Remove obsolete comment that
3079         register variables are not used by reload.
3080
3081 2004-02-19  Hans-Peter Nilsson  <hp@axis.com>
3082
3083         PR target/14209
3084         * config/cris/cris.md ("*andsi_movu", "*andhi_movu"): Tweak
3085         constraints to not match postincrement.  Adjust the predicate to
3086         exclude a volatile memory reference.
3087
3088 2004-02-19  Kazu Hirata  <kazu@cs.umass.edu>
3089
3090         * config/mcore/mcore.h (ASM_OUTPUT_EXTERNAL): Remove.
3091
3092 2004-02-19  Kazu Hirata  <kazu@cs.umass.edu>
3093
3094         * hooks.c (hook_void_tree_int): Remove.
3095         (hook_void_constcharptr): Likewise.
3096         (hook_int_void_0): Likewise.
3097         * hooks.h: Remove the prototypes for the above three
3098         functions.
3099         * targhooks.c (hook_bool_machine_mode_true): Remove.
3100         * targhooks.h: Remove the prototype for
3101         hook_bool_machine_mode_true.
3102
3103 2004-02-19  Kazu Hirata  <kazu@cs.umass.edu>
3104
3105         * emit-rtl.c (subreg_realpart_p): Remove.
3106         (reorder_insns_with_line_notes): Likewise.
3107         (end_full_sequence): Likewise.
3108         * rtl.h: Remove the prototype for the above functions.
3109
3110 2004-02-19  Kazu Hirata  <kazu@cs.umass.edu>
3111
3112         * config/arc/arc.h, config/arm/arm.h, config/frv/frv.h,
3113         config/h8300/h8300.h, config/i386/i386.h, config/i860/i860.h,
3114         config/iq2000/iq2000.h, config/m32r/m32r.h,
3115         config/pdp11/pdp11.h, config/sparc/sparc.h,
3116         config/xtensa/xtensa.h: Remove commented-out or useless
3117         definitions of CASE_VECTOR_PC_RELATIVE.
3118
3119 2004-02-19  Kazu Hirata  <kazu@cs.umass.edu>
3120
3121         * loop.c (all_sets_invariant_p): Remove.
3122
3123 2004-02-19  Eric Botcazou  <ebotcazou@libertysurf.fr>
3124
3125         PR target/12916
3126         * config/sparc/sparc.h (NPARM_REGS): Delete.
3127         (BASE_RETURN_VALUE_REG): Likewise.
3128         (BASE_OUTGOING_VALUE_REG): Likewise.
3129         (BASE_PASSING_ARG_REG): Likewise.
3130         (BASE_INCOMING_ARG_REG): Likewise.
3131         * config/sparc/sparc.c (sparc_strict_argument_naming): Test
3132         TARGET_ARCH64, not TARGET_V9.
3133         (function_arg_slotno): Dispatch based on the mode class.
3134         Handle vector modes like floating-point modes.
3135         (function_arg_record_value_1): Handle vector types like
3136         floating-point types.
3137         (function_arg_record_value_2): Likewise.
3138         Calculate regno after mode transformation.
3139         (function_arg): Handle vector modes like floating-point modes.
3140         (function_arg_partial_nregs): Replace NPARM_REGS by SPARC_INT_ARG_MAX.
3141         If ARCH64, do not recheck alignment.
3142         (function_arg_pass_by_reference): Reorder the conditions.
3143         (sparc_return_in_memory): Move after function_arg_padding.
3144         Implement calling conventions for vector modes.
3145         (sparc_struct_value_rtx): Move after sparc_return_in_memory.
3146         (function_value): Move scope of 'regbase'.
3147         Implement calling conventions for vector modes.
3148         (sparc_builtin_saveregs): Replace NPARM_REGS by SPARC_INT_ARG_MAX
3149         and BASE_INCOMING_ARG_REG by SPARC_INCOMING_INT_ARG_FIRST.
3150         (sparc_va_arg): Use function_arg_pass_by_reference to test whether
3151         the argument is passed by reference.
3152         (sparc_type_code): Handle vector types.
3153
3154 2004-02-19  Alan Modra  <amodra@bigpond.net.au>
3155
3156         * function.c (assign_parms): When building decl_rtl for
3157         SPLIT_COMPLEX_ARGS, ensure inner modes of concat match outer.
3158
3159 2004-02-19  Olivier Hainque  <hainque@act-europe.fr>
3160
3161         * expr.c (is_aligning_offset): Check if we are aligning the
3162         expressions's address over BIGGEST_ALIGNMENT in bytes, not
3163         in bits.
3164
3165 2003-02-18  Matt Austern  <austern@apple.com>
3166
3167         * gcc.c (LIBGCC_SPEC): If REAL_LIBGCC_SPEC is defined, and
3168         LIBGCC_SPEC isn't, set LIBGCC_SPEC to REAL_LIBGCC_SPEC.
3169         (init_gcc_spec): Don't define or call if REAL_LIBGCC_SPEC is
3170         defined.  Instead use REAL_LIBGCC_SPEC, unmodifed, as the libgcc
3171         spec string.
3172         * doc/tm.texi (REAL_LIBGCC_SPEC): Document.
3173
3174 2004-02-18  Zack Weinberg  <zack@codesourcery.com>
3175
3176         * dwarf2out.c (loclabel_num): Move outside #ifdef
3177         DWARF2_DEBUGGING_INFO and mark with GTY(()).
3178         * config/ia64/ia64.c (struct extern_func_list,extern_func_head):
3179         Mark with GTY(()).
3180         (ia64_hpux_add_extern_decl): Save the decl, not the name string.
3181         Allocate memory with ggc_alloc.  No need to copy anything.
3182         (ia64_hpux_file_end): Update to match.
3183
3184 2004-02-18  Jakub Jelinek  <jakub@redhat.com>
3185
3186         * config/i386/i386.c (override_options): Don't imply 3DNow! for -m64
3187         by default.
3188
3189 2004-02-18  Ulrich Weigand  <uweigand@de.ibm.com>
3190
3191         * config/s390/s390.md ("divmodtidi3"): Use canonical RTL.
3192         ("divmodtisi3"): Likewise.
3193         ("udivmoddi4", "udivmodtidi3"): Likewise.
3194         ("divmodsi4", "divmoddisi3"): Likewise.
3195         ("udivmodsi4", "udivmoddisi3"): Likewise.
3196         ("udivsi3", "umodsi3"): Likewise.
3197
3198 2004-02-18  Ulrich Weigand  <uweigand@de.ibm.com>
3199
3200         * config/s390/s390.c (s390_mainpool_start): Delete the main pool
3201         placeholder insn when chunkifying the pool.
3202
3203 2004-02-18  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
3204
3205         * pa.h (PIC_OFFSET_TABLE_REGNUM): Define to INVALID_REGNUM when not
3206         generating PIC code.
3207
3208 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3209
3210         * config/h8300/h8300-protos.h: Add a prototype for
3211         h8300_expand_branch.
3212         * config/h8300/h8300.c (h8300_expand_branch): New.
3213         * config/h8300/h8300.md (ble, bleu, bge, bgeu, blt, bltu, bgt,
3214         bgtu, beq, bne): Call h8300_expand_branch().
3215
3216 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3217
3218         * config/h8300/h8300-protos.h: Add prototypes for
3219         h8300_hard_regno_nregs and h8300_hard_regno_mode_ok.
3220         * config/h8300/h8300.c (h8300_hard_regno_nregs): New.
3221         (h8300_hard_regno_mode_ok): Likewise.
3222         * config/h8300/h8300.h (HARD_REGNO_NREGS): Call
3223         h8300_hard_regno_nregs().
3224         (HARD_REGNO_MODE_OK): Call h8300_hard_regno_mode_ok().
3225
3226 2004-02-18  Per Bothner  <per@bothner.com>
3227
3228         * cpphash.h (struct cpp_buffer):  Restore return_at_eof field.  This
3229         partly reverts my 2003-10-01 change, because we're back to logically
3230         including <command line> inside the main line.
3231         * cpplex.c (_cpp_get_fresh_line):  Check return_at_eof field.
3232         * cppmacro.c (cpp_scan_nooutput):  Set return_at_eof of current buffer.
3233         Fixes PR preprocessor/14103.
3234
3235         * cppfiles.c (_cpp_stack_include):  When appropriate decrement
3236         line_table's highest_location, fixing LAST_SOURCE_LINE_LOCATION.
3237         (cpp_push_include):  Don't need to increment pfile's line field.
3238         * line-map.h (LAST_SOURCE_LINE_LOCATION):  Only decrement by 1.
3239
3240         * c-ppoutput.c (print struct):  New first_time field.
3241         (init_pp_output):  Set print.first_time.
3242         (pp_file_change):  Use print.first_time, rather than MAIN_FILE_P,
3243         which is set also for (say) <command line>.  Clear print.first_time.
3244
3245         * cppfiles.c (struct _cpp_file):  Comment and type for pch field
3246         does not match the code, so fix both.
3247         (should_stack_file):  Inline include_pch_p function.
3248         (include_pch_p):  Remove pointless function.
3249
3250         * cpphash.h (struct cpp_buffer):  Remove unused search_cached field.
3251
3252 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3253
3254         * config/h8300/h8300.md (four define_peephole2's): Use
3255         h8300_regs_ok_for_stm().
3256
3257 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3258
3259         * config/h8300/h8300-protos.h: Update the prototype for
3260         expand_a_rotate().
3261         * config/h8300/h8300.c (expand_a_rotate): Remove the first
3262         argument.
3263         * config/h8300/h8300.md: Update all callers.
3264
3265 2004-02-18  Jan Hubicka  <jh@suse.cz>
3266
3267         * simplify-rtx.c (simplify_unary_operation): Deal with logicals on
3268         floats.
3269         (simplify_binary_operation): Deal with logicals on floats.
3270
3271         * i386.md (SSE fabs splitters): Emit new patterns.
3272         (SSE cmov splitters): Likewise.
3273         (sse_andv4sf3, sse_nandv4sf3, sse_iorv4sf3, sse_xorv4sf3
3274         (sse_andv2df3, sse_nandv2df3, sse_iorv2df3, sse_xorv2df3): Do not use
3275         subregs.
3276         (sse_andsf3, sse_nandsf3, sse_xorsf3): Kill.
3277         (sse_anddf3, sse_nanddf3, sse_xordf3): Kill.
3278
3279 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3280
3281         * config/h8300/h8300.c (expand_a_rotate): Don't generate insns
3282         by hand.
3283         (output_a_rotate): Tweak a comment.
3284         * config/h8300/h8300.md (*rotlqi3_1): Change to rotlqi3_1.
3285         (*rotlhi3_1): Change to rotlhi3_1.
3286         (*rotlsi3_1): Change to rotlsi3_1.
3287
3288 2004-02-18  Richard Earnshaw  <rearnsha@arm.com>
3289
3290         PR target/13866
3291         * arm.c (load_multiple_operation): Don't insist that the source reg
3292         of a post-increment component is the same as the destination.
3293         (store_multiple_operation): Likewise.
3294
3295 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3296
3297         * config/h8300/h8300.md: Move movsf patterns into one section
3298         of the file.
3299
3300 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3301
3302         * cfgloop.h, cfgloopanal.c, cpplex.c, except.h, loop-init.c,
3303         loop-unroll.c, scan-decls.c, scan.h, stor-layout.c,
3304         xcoffout.c, xcoffout.h, config/arm/mmintrin.h,
3305         config/mips/linux64.h, config/pa/pa-64.h,
3306         config/rs6000/aix51.h, config/rs6000/aix52.h,
3307         config/rs6000/spe.md, config/sparc/linux.h,
3308         config/sparc/linux64.h: Update copyright.
3309
3310 2004-02-18  Kazu Hirata  <kazu@cs.umass.edu>
3311
3312         * config/h8300/h8300.md: Move push patterns into one
3313         section of the file.
3314
3315 2004-02-18  Mark Mitchell <mark@codesourcery.com>
3316
3317         PR c++/11326
3318         * config/ia64/ia64.c (ia64_struct_value_rtx): Cope with NULL
3319         fntype.
3320
3321 2004-02-18  Paul Brook  <paul@codesourcery.com>
3322
3323         * rtlanal.c (rtx_varies_p): Return 0 for NULL_RTX
3324
3325 2004-02-18  Paul Brook  <paul@codesourcery.com>
3326
3327         PR debug/12934
3328         * dwarf2out.c (loc_descriptor_from_tree): Handle
3329         EXPR_WITH_FILE_LOCATION.
3330
3331 2004-02-18  Jakub Jelinek  <jakub@redhat.com>
3332
3333         * config/i386/i386.md (zero_extendqidi2, zero_extendqidi2,
3334         testdi_1_rex64, anddi_2, xordi_1_rex64, xordi_2_rex64): Remove
3335         trailing whitespace from instructions.
3336
3337 2004-02-17  Geoffrey Keating  <geoffk@apple.com>
3338
3339         * configure.ac: When generating auto-build.h, pass
3340         --enable-languages to the sub-configure.
3341         Put quotes around ${program_transform_name} when generating
3342         name of as, ld, nm, objdump.
3343         * configure: Regenerate.
3344
3345 2004-02-17  Matt Kraai  <kraai@alumni.cmu.edu>
3346
3347         * Makefile.in (s-check, s-config, s-conditions, s-flags)
3348         (s-codes, s-constants, s-emit, s-recog, s-opinit, s-extract)
3349         (s-peep, s-attr, s-attrtab, s-output, s-genrtl, s-modes)
3350         (s-preds, s-iov): Do not depend on move-if-change.
3351
3352 2004-02-17  James E Wilson  <wilson@specifixinc.com>
3353
3354         * caller-save.c (insert_restore): Pass mem through copy_rtx.
3355         (insert_save): Likewise.
3356
3357 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3358
3359         * config/h8300/h8300.c (h8300_emit_stack_adjustment): Fix a
3360         warning.
3361
3362 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3363
3364         * config/h8300/h8300.md (*one_complsi2_h8300): Change to
3365         *one_cmplsi2_h8300.
3366         (*one_complsi2_h8300hs): Change to *one_cmplsi2_h8300hs.
3367
3368 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3369
3370         * config/h8300/h8300-protos.h: Update the prototype of
3371         fix_bit_operand().
3372         * config/h8300/h8300.c (fix_bit_operand): Remove the second
3373         argument "what".
3374         * config/h8300/h8300.md: Update all callers.
3375
3376 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3377
3378         * config/h8300/h8300.c (fix_bit_operand): Change the name of
3379         the last argument to "code" from "type".
3380
3381 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3382
3383         * config/h8300/h8300.c: Remove an extern declaration of
3384         rtx_equal_function_value_matters.
3385
3386 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3387
3388         * config/h8300/h8300.c (fix_bit_operand): Don't generate insns
3389         by hand.
3390         * config/h8300/h8300.md (*andqi3_1): Change to andqi3_1.
3391         (*iorqi3_1): Change to iorqi3_1.
3392         (*xorqi3_1): Change to xorqi3_1.
3393
3394 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3395
3396         * c-common.c, cfghooks.c, rtlanal.c, varasm.c: Fix comment
3397         typos.
3398
3399 2004-02-17  Jan Hubicka  <jh@suse.cz>
3400
3401         * i386.c (x86_prologue_using_move, x86_epilogue_using_move): Disable for P4.
3402
3403 2004-02-18  Alan Modra  <amodra@bigpond.net.au>
3404
3405         PR optimization/14119
3406         * combine.c (try_combine): When attemting to fix unrecognized insns,
3407         don't delete SETs marked with REG_EH_REGION notes.
3408
3409 2004-02-17  Ulrich Weigand  <uweigand@de.ibm.com>
3410
3411         * combine.c (simplify_if_then_else): Do not replace
3412         (if_then_else (ne reg 0) (0) (const_int)) by (reg) if the
3413         modes differ.
3414
3415 2004-02017  Steven Bosscher  <stevenb@suse.de>
3416
3417         * (c-decl.c, c-semantics.c, calls.c, cgraph.c, cgraphunit.c,
3418         function.c, integrate.c, print-tree.c, toplev.c, tree-optimize.c,
3419         tree.h): Replace DECL_SAVED_INSNS with DECL_STRUCT_FUNCTION.
3420         * ada/utils.c: Likewise.
3421         * cp/decl.c: Likewise.
3422         * f/com.c: Likewise.
3423         * java/class.c: Likewise.
3424
3425 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3426
3427         * config/h8300/h8300.md: Fix comment typos.
3428
3429 2004-02-17  Rainer Orth  <ro@TechFak.Uni-Bielefeld.DE>
3430
3431         * config/mips/t-iris6gld: Renamed to ...
3432         * config/mips/t-irix-gld: ... this.
3433         * config.gcc (mips-sgi-irix6*): Reflect this
3434         (mips-sgi-irix5*): Use it with GNU ld.
3435
3436         * config/mips/irix6-crti.asm, config/mips/irix6-crtn.asm: Renamed
3437         to ...
3438         * config/mips/irix-crti.asm, config/mips/irix-crtn.asm: ... this.
3439         * config/mips/t-irix-gld: Reflect this.
3440         * config/mips/iris6gld.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
3441
3442         * config/mips/iris5gld.h: New file.
3443         * config.gcc (mips-sgi-irix5*): Use it with GNU ld.
3444         Only use collect2 without gas.
3445
3446         * config/mips/iris6.h (IRIX6_STARTFILE_SPEC, IRIX6_ENDFILE_SPEC):
3447         Renamed to IRIX_STARTFILE_SPEC, IRIX_ENDFILE_SPEC.
3448         (STARTFILE_SPEC, ENDFILE_SPEC, SUBTARGET_EXTRA_SPECS): Reflect this.
3449         * config/mips/iris6gld.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
3450
3451         * config/mips/iris6.h (SUBTARGET_EXTRA_SPECS): Moved ...
3452         * config/mips/iris5.h: ... here.
3453
3454         * config/mips/iris5.h (STARTFILE_SPEC, ENDFILE_SPEC): Renamed to
3455         IRIX_STARTFILE_SPEC, IRIX_ENDFILE_SPEC.
3456         (STARTFILE_SPEC, ENDFILE_SPEC): Define.
3457
3458         * config/mips/iris5gas.h (STARTFILE_SPEC, ENDFILE_SPEC): Simplify
3459         using irix_startfile_spec, irix_endfile_spec.
3460
3461 2004-02-16  Gunther Nikl  <gni@gecko.de>
3462
3463         * config/m68k/m68k.c: Remove obsolete support for HPUX_ASM.
3464
3465 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3466
3467         * config/h8300/h8300.c (h8300_expand_prologue): Don't generate
3468         insns by hand.
3469
3470 2004-02-17  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
3471
3472         * cfghooks.c (split_edge): Speed up updating of dominators.
3473
3474 2004-02-17  Mark Mitchell  <mark@codesourcery.com>
3475
3476         PR c++/11326
3477         * c-common.c (flag_abi_version): Remove.
3478         * c-common.h (flag_abi_version): Likewise.
3479         * c-opts.c (c_common_handle_option): Remove OPT_fabi_version case.
3480         * c.opt (fabi-version): Remove.
3481         * calls.c (expand_call): Always pass a function type to
3482         struct_value_rtx.  Use convert_memory_address.
3483         * common.opt (fabi-version): Add it.
3484         * flags.h (flag_abi_version): Likewise.
3485         (abi_version_at_least): New macro.
3486         * opts.c (common_handle_option): Add OPT_fabi_version.
3487         * toplev.c (flag_abi_version): Define it.
3488         * config/ia64/ia64.c (ia64_struct_retval_addr_is_first_parm_p):
3489         New function.
3490         (ia64_output_mi_thunk): Use it.
3491         (ia64_struct_value_rtx): Likewise.
3492
3493 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3494
3495         * config/h8300/h8300.c (h8300_emit_stack_adjustment):
3496         Don't generate insns by hand.
3497
3498 2004-02-17  Andrew Pinski  <pinskia@physics.uc.edu>
3499
3500         PR c++/14178
3501         * doc/invoke.texi (fabi-version): The default is 2 now.
3502
3503 2004-02-17  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
3504
3505         * loop-iv.c: New file.
3506         * Makefile.in (loop-iv.o): New.
3507         * basic_block.h (FOR_BB_INSNS, FOR_BB_INSNS_REVERSE): New macros.
3508         * cfgloop.c (fill_sons_in_loop, get_loop_body_in_dom_order,
3509         num_loop_branches): New functions.
3510         * cfgloop.h (get_loop_body_in_dom_order, num_loop_branches,
3511         iv_analysis_loop_init, iv_get_reaching_def, iv_analyse, get_iv_value,
3512         find_simple_exit, iv_number_of_iterations, iv_analysis_done,
3513         get_simple_loop_desc, free_simple_loop_desc): Declare.
3514         (simple_loop_desc): New inline function.
3515         (struct rtx_iv, struct niter_desc): New.
3516         * cfgloopmanip.c (loopify): Specify semantics more precisely.
3517         * expr.c (force_operand): Handle subregs of expressions created by
3518         loop unroller.
3519         * loop-init.c (loop_optimizer_init, loop_optimizer_finalize): Move
3520         parts of the initialization to toplev.c
3521         * loop-unroll.c (loop_exit_at_end_p): New.
3522         (unroll_and_peel_loops): Call iv_analysis_done.
3523         (decide_peel_once_rolling, decide_peel_completely,
3524         decide_unroll_stupid, decide_unroll_constant_iterations,
3525         decide_unroll_runtime_iterations, decide_peel_simple,
3526         peel_loop_simple, unroll_loop_stupid, unroll_loop_constant_iterations,
3527         unroll_loop_runtime_iterations): Use new simple loop analysis.
3528         * loop-unswitch.c (compare_and_jump_seq): New.
3529         (may_unswitch_on_p): Renamed to ...
3530         (may_unswitch_on): Use new iv analysis.
3531         (reversed_condition): Export.
3532         (unswitch_single_loop, unswitch_loop): Use new iv analysis.
3533         * predict.c (estimate_probability): Use new simple loop analysis.
3534         * rtl.h (get_mode_bounds, reversed_condition,compare_and_jump_seq,
3535         canon_condition, simplify_using_condition): Declare.
3536         * stor-layout.c (get_mode_bounds): New.
3537         * toplev.c (rest_of_handle_loop2): Some parts of
3538         initialization/finalization moved here from loop-init.c.
3539
3540 2004-02-17  Kazu Hirata  <kazu@cs.umass.edu>
3541
3542         * config/h8300/h8300.h (FIXED_REGISTERS): Add the soft frame
3543         pointer.
3544         (CALL_USED_REGISTERS): Likewise.
3545         (REG_ALLOC_ORDER): Likewise.
3546         (REG_CLASS) <GENERAL_REGS>: Likewise.
3547
3548 2004-02-16  Geoffrey Keating  <geoffk@apple.com>
3549
3550         * doc/md.texi (Insn Canonicalizations): Document left-chaining
3551         in associative operators.
3552         * rtlanal.c (commutative_operand_precedence): Create some new
3553         variables.  Prefer a commutative operand on the left, then
3554         binary expressions, then NEG and NOT.
3555
3556 2004-02-16  Matthias Klose  <doko@debian.org>
3557
3558         * config/t-slibgcc-elf-ver: Define SHLIB_NAME and SHLIB_SONAME
3559         in terms of SHLIB_SOVERSION.
3560         * config/m68k/t-slibgcc-elf-ver: New file.
3561         * config/pa/t-slibgcc-elf-ver: New file.
3562         * config.gcc (m68k-linux, parisc-linux): Use them when not
3563         sjlj exceptions are not configured.
3564
3565 2004-02-16  Eric Botcazou  <ebotcazou@libertysurf.fr>
3566
3567         * config/sparc/sparc.c (get_pc_symbol_name): Mark with GTY(()).
3568
3569 2004-02-16  Zack Weinberg  <zack@codesourcery.com>
3570
3571         * sdbout.c (sdb_debug_hooks): Correct the type_decl entry.
3572
3573 2004-02-16  Joseph S. Myers  <jsm@polyomino.org.uk>
3574
3575         * doc/sourcebuild.texi: Mention backends.html.
3576
3577 2004-02-16  Kazu Hirata  <kazu@cs.umass.edu>
3578
3579         * c-decl.c, c-ppoutput.c, cpphash.h, cpplib.h, dbxout.c,
3580         line-map.c, line-map.h, var-tracking.c: Fix comment
3581         formatting.
3582
3583 2004-02-16  Richard Henderson  <rth@redhat.com>
3584
3585         * cse.c (cse_insn): Don't lose REG_NON_LOCAL_GOTO note.
3586
3587         * fold-const.c (operand_equal_p): Fix VECTOR_CST comparison.
3588
3589 2004-02-15  Kazu Hirata  <kazu@cs.umass.edu>
3590
3591         * config/h8300/h8300.md: Remove unnecessary parallels from
3592         all define_insn and define_split patterns.
3593
3594 2004-02-15  Kazu Hirata  <kazu@cs.umass.edu>
3595
3596         * config/h8300/h8300.md: Remove explicit (set_attr "cc"
3597         "clobber").
3598
3599 2004-02-15  Bernardo Innocenti  <bernie@develer.com>
3600
3601         * config/m68k/m68k.h (PRINT_OPERAND_PUNCT_VALID_P): Restore support for
3602         '%#'.
3603
3604 2004-02-15  Kazu Hirata  <kazu@cs.umass.edu>
3605
3606         * config/ia64/ia64.c, config/mips/mips.c,
3607         config/mmix/mmix-modes.def: Fix comment typos.
3608
3609 2004-02-15  Roger Sayle  <roger@eyesopen.com>
3610
3611         * c-common.h (GET_DIRECTIVE_LINE): Remove unused macro.
3612         (get_directive_line): Remove unused function prototype.
3613
3614 2004-02-14  Josef Zlomek  <zlomekj@suse.cz>
3615
3616         * tree-inline.c (copy_body_r): Do not replace ret_label.
3617
3618 2004-02-14  Jan Hubicka  <jh@suse.cz>
3619
3620         * i386.c (x86_four_jump_limit): New variable.
3621         (k8_avoid_jump_misspredicts): Rename to ...
3622         (ix86_avoid_jump_misspredicts): .. this one.
3623         (ix86_pad_returns): Break out from ...
3624         (ix86_reorg): ... this one; do ix86_avoid_jump_misspredicts when asked
3625         to.
3626         * i386.h (TARGET_FOUR_JUMP_LIMIT): New macro.
3627
3628 2004-02-14  Josef Zlomek  <zlomekj@suse.cz>
3629
3630         * emit-rtl.c (set_decl_incoming_rtl): Check whether the 0th element of
3631         PARALLEL is NULL.
3632
3633 2004-02-14  Per Bothner  <per@bothner.com>
3634
3635         * fix-header.c (line_table):  Move local variable in main to global.
3636         * scan.h (line_table):  Use it.
3637         * scan-decls.c (scan_decls):  Need to call linemap_lookup on token's
3638         line (recently renamed to src_loc) before calling recognized_function.
3639
3640 2004-02-14  Matt Kraai  <kraai@alumni.cmu.edu>
3641
3642         * Makefile.in: Fix comment typos.
3643
3644 2004-02-14  Olivier Hainque  <hainque@act-europe.fr>
3645
3646         * loop.c (check_dbra_loop): Use gen_int_mode instead of GEN_INT
3647         for start_value when it is directly moved into reg, and factorize
3648         the retrieval of GET_MODE (reg).
3649
3650 2004-02-14  Richard Sandiford  <rsandifo@redhat.com>
3651
3652         * config/mips/mips-protos.h (mips_load_got_page): Delete.
3653         (mips_load_got_global): Delete.
3654         (mips_gotoff_page): Declare.
3655         * config/mips/mips.md (UNSPEC_LOAD_GOT): New constant.
3656         (*xgot_lo[sd]i, *got_disp[sd]i, *got_page[sd]i): Build an
3657         UNSPEC_LOAD_GOT pattern rather than a MEM.
3658         (*load_got[sd]i): New patterns.
3659         * config/mips/mips.c (mips_got_alias_set, mips_load_got): Delete.
3660         (mips_load_got_page, mips_load_got_global): Delete.
3661         (mips_gotoff_page): New function.
3662         (override_options): Don't initialize mips_got_alias_set.
3663
3664 2004-02-14  Richard Sandiford  <rsandifo@redhat.com>
3665
3666         * config/mips/mips.h (MASK_DEBUG_[ABEFI], TARGET_DEBUG_[ABEFI]_MODE)
3667         (TARGET_MIPS4100, TARGET_MIPS4300, TARGET_MIPS4KC, TARGET_MIPS5KC)
3668         (TARGET_SB1, TUNE_SB1, TUNE_SR71K, BIGGEST_MAX_ARGS_IN_REGISTERS)
3669         (GO_PRINTF, GO_PRINTF2, GO_DEBUG_RTX, DFMODE_NAN, SFMODE_NAN): Delete.
3670         (TARGET_SWITCHES): Remove MASK_DEBUG_[ABEFI].
3671         * config/mips/mips.c: Fix some overly-long lines.
3672         (SINGLE_WORD_MODE_P, PIC_OFFSET_TABLE_MASK): Delete.
3673         (init_cumulative_args): Remove TARGET_DEBUG_E_MODE handling.
3674
3675 2004-02-13  Rainer Orth  <ro@TechFak.Uni-Bielefeld.DE>
3676
3677         * configure.ac: Search for as, ld below libexec/gcc.
3678         * configure: Regenerate.
3679
3680 2004-02-14  Ben Elliston  <bje@wasabisystems.com>
3681
3682         * config/arm/mmintrin.h (_mm_setwcx): Reverse arguments in call to
3683         __builtin_arm_setwcx ().
3684         * config/arm/arm.c (arm_expand_builtin): Generate operands
3685         correctly and reverse their order in call to gen_iwmmxt_tmcr ().
3686
3687 2004-02-14  Ben Elliston  <bje@wasabisystems.com>
3688
3689         * config/arm/arm.c (bdesc_2arg): Correct builtin names "wmulsh"
3690         and "wmuluh" to "wmulsm" and "wmulum", respectively.
3691         * config/arm/arm.h (enum arm_builtins): Rename enumerators to
3692         ARM_BUILTIN_WMULSM and ARM_BUILTIN_WMULUM.
3693         * config/arm/mmintrin.h (_mm_mulhi_pi16): Update intrinsic call.
3694         (_mm_mulhi_pu16): Likewise.
3695
3696 2004-02-13  Zack Weinberg  <zack@codesourcery.com>
3697
3698         * xcoffout.c (xcoff_assign_fundamental_type_number): Check
3699         DECL_NAME != 0 before dereferencing.
3700
3701 2004-02-13  Ulrich Weigand  <uweigand@de.ibm.com>
3702
3703         * config/s390/s390-protos.h (s390_output_symbolic_const): Remove.
3704         (s390_output_addr_const_extra): Declare.
3705         (s390_output_pool_entry): Remove FILE * argument.
3706         * config/s390/s390.c (s390_output_symbolic_const): Remove.
3707         (s390_output_addr_const_extra): New function.
3708         (print_operand_address): Call output_addr_const instead of
3709         s390_output_symbolic_const.
3710         (print_operand): Likewise.
3711         (s390_output_pool_entry): Use assemble_integer for symbolic constants.
3712         Remove FILE * argument.
3713         * config/s390/s390.h (OUTPUT_ADDR_CONST_EXTRA): Define.
3714         * config/s390/s390.md ("*pool_entry"): Adapt s390_output_pool_entry
3715         call.
3716
3717 2004-02-13  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
3718
3719         * cfgloopanal.c (mark_irreducible_loops): Rewriten.
3720         (struct edge, struct vertex, struct graph): New.
3721         (dump_graph, new_graph, add_edge, dfs, check_irred, for_each_edge,
3722         free_graph): New functions.
3723
3724 2004-02-12  Chris Demetriou  <cgd@broadcom.com>
3725
3726         * config/mips/mips.md (casesi_internal, casesi_internal_di):
3727         Use ".set macro" to avoid warnings about multi-instruction
3728         macros, since they're intentional.
3729
3730 2004-02-12  Geoffrey Keating  <geoffk@apple.com>
3731
3732         * config/darwin.h: Add include guards.  Remove old, now incorrect,
3733         comment about STANDARD_EXEC_PREFIX.
3734
3735         * Makefile.in (install-man): Use $(CPP_INSTALL_NAME) and
3736         $(GCOV_INSTALL_NAME) to install manpages.  Remove generic rule
3737         for installing .1 manpages.  Add rules for installing cpp
3738         and gcov manpages under their installed names.
3739
3740 2004-02-12  Alexandre Oliva  <aoliva@redhat.com>
3741
3742         * configure.ac (gcc_cv_ld): Don't set to LD if target is not
3743         host, but try LD_FOR_TARGET first.
3744         * configure: Rebuilt.
3745
3746 2004-02-12  Zack Weinberg  <zack@codesourcery.com>
3747
3748         * dbxout.c: Move declaration of dbxout_type_decl outside
3749         #ifdef DBX_DEBUGGING_INFO.
3750         * c-parse.in: Don't give the asmdef production a type.
3751
3752 2004-02-12  Zack Weinberg  <zack@codesourcery.com>
3753
3754         * debug.h (struct gcc_debug_hooks): Add type_decl field.
3755         (debug_nothing_tree_int): Prototype.
3756         (dwarf_debug_hooks): Delete, unused.
3757         * debug.c (do_nothing_debug_hooks): Update.
3758         (debug_nothing_tree_int): New function.
3759         * langhooks.h (struct lang_hooks_for_decls):
3760         Remove builtin_type_decls field.
3761         * langhooks-def.h (LANG_HOOKS_BUILTIN_TYPE_DECLS): Delete.
3762         (LANG_HOOKS_DECLS): Update.
3763         * toplev.c (rest_of_decl_compilation, rest_of_type_compilation):
3764         Use debug_hooks->type_decl.
3765         * dbxout.c (preinit_symbols): New static.
3766         (dbx_debug_hooks, xcoff_debug_hooks): Update.
3767         (dbxout_init): Don't call DBX_OUTPUT_STANDARD_TYPES or
3768         lang_hooks.decls.builtin_type_decls.  Do scan preinit_symbols
3769         for symbols to output.
3770         (dbxout_type_decl): New function.
3771         (dbxout_symbol): If called before dbxout_init has run, queue
3772         the symbol for later.  Apply DBX_ASSIGN_FUNDAMENTAL_TYPE_NUMBER
3773         to TYPE_DECLs before emitting them.
3774         * xcoffout.c (assign_type_number): Delete.
3775         (xcoff_type_numbers): New static table.
3776         (xcoff_assign_fundamental_type_number): New function.
3777         * xcoffout.h: Define DBX_ASSIGN_FUNDAMENTAL_TYPE_NUMBER, not
3778         DBX_OUTPUT_STANDARD_TYPES.  Remove unnecessary #ifdefs.
3779         * sdbout.c: Include varray.h.
3780         (deferred_global_decls): New static.
3781         (sdb_debug_hooks): Update.
3782         (sdbout_global_decl): If we can't emit something right now,
3783         remember it in deferred_global_decls.
3784         (sdbout_finish): Just scan deferred_global_decls; don't call getdecls.
3785         (sdbout_init): Initialize deferred_global_decls.
3786         * Makefile.in: Update dependencies of sdbout.o.
3787         * dwarf2out.c (dwarf2out_type_decl): New function.
3788         (dwarf2_debug_hooks): Update.
3789         * vmsdbgout.c (vmsdbg_debug_hooks): Update.
3790         * c-decl.c (getdecls): Just return 0.
3791         (check_for_loop_decls): Don't use getdecls.
3792         (record_builtin_type): Call debug_hooks->type_decl on the TYPE_DECL.
3793         * c-objc-common.c (c_objc_common_finish_file): Don't use getdecls.
3794
3795 2004-02-12  Ulrich Weigand  <uweigand@de.ibm.com>
3796
3797         * config/s390/s390.c (s390_sched_reorder2): Remove.
3798         (TARGET_SCHED_REORDER2): Do not redefine.
3799
3800 2004-02-12  Zack Weinberg  <zack@codesourcery.com>
3801
3802         * c-parse.in (maybe_type_qual): Delete.
3803         (maybe_volatile, simple_asm_expr, asmdef, asm_stmt)
3804         (asm_argument): New grammar rules.
3805         (extdef_1): Use asmdef.
3806         (maybeasm): Move down with other asm rules; use simple_asm_expr.
3807         (xexpr): Move up with other expression rules.
3808         (stmt): Use asm_stmt.
3809
3810         * c-typeck.c (build_asm_expr): New function - body mostly
3811         pulled from build_asm_stmt.
3812         (build_asm_stmt): Just handle tacking on the volatile qualifier.
3813         * c-tree.h (build_asm_expr, build_asm_stmt): Update prototypes.
3814
3815 2004-02-12  Richard Sandiford  <rsandifo@redhat.com>
3816
3817         PR bootstrap/13617
3818         * config/mips/mips-protos.h (mips_output_aligned_decl_common): Declare.
3819         (mips_declare_object): Make variadic.
3820         * config/mips/mips.h (ASM_OUTPUT_ALIGNED_DECL_COMMON): Use
3821         mips_output_aligned_decl_common.
3822         * config/mips/mips.c (mips_output_aligned_decl_common): New function.
3823         (mips_declare_object): Make variadic.
3824
3825 2004-02-12  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
3826
3827         * function.c (update_epilogue_consts): Teach about binary operations.
3828
3829         * emit-rtl.c (set_mem_attributes_minus_bitpos): Don't kill
3830         previous MEM_VOLATILE in REF.
3831         * function.c (fixup_var_refs): Save volatile_ok and set to 1.
3832         * expr.c (emit_block_move_via_movstr): Save and restore volatile_ok.
3833
3834 2004-02-12  Gunther Nikl  <gni@gecko.de>
3835
3836         * config.gcc: Restore support for m68k-openbsd.
3837
3838 2004-02-12  Jan Hubicka  <jh@suse.cz>
3839
3840         * tree-optimize.c (tree_rest_of_compilation): Do not release
3841         DECL_ARGUMENTS.
3842
3843 2004-02-11  Matt Kraai  <kraai@alumni.cmu.edu>
3844
3845         * doc/install.texi: Fix the spelling of "explicitly".
3846
3847 2004-02-11  Eric Christopher  <echristo@redhat.com>
3848
3849         * cppcharset.c (_cpp_interpret_string_notranslate): Rename and
3850         duplicate argument structure of cpp_interpret_string.
3851         * cpphash.h: Move prototype...
3852         * cpplib.h: Here.
3853         * cpplib.c: Fix calls to match new function signature.
3854
3855 2004-02-11  Joseph S. Myers  <jsm@polyomino.org.uk>
3856
3857         PR c/456
3858         * cppexp.c (num_binary_op): Don't allow comma operators in #if
3859         constant expressions at all outside C99 mode if pedantic.
3860
3861 2004-02-11  Uros Bizjak  <uros@kss-loka.si>
3862
3863         * optabs.h (enum optab_index): Add new OTI_log10 and OTI_log2.
3864         (log10_optab, log2_optab): Define corresponding macros.
3865         * optabs.c (init_optabs): Initialize log10_optab and log2_optab.
3866         * genopinit.c (optabs): Implement log10_optab and log2_optab
3867         using log10?f2 and log2?f2 patterns.
3868         * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_LOG10{,F,L}
3869         using log10_optab, and BUILT_IN_LOG2{,F,L} using log2_optab.
3870         (expand_builtin): Expand BUILT_IN_LOG10{,F,L} and BUILT_IN_LOG2{,F,L}
3871         using expand_builtin_mathfn if flag_unsafe_math_optimizations is set.
3872
3873         * config/i386/i386.md (log10sf2, log10df2, log10xf2, log2sf2,
3874         log2df2, log2xf2): New patterns to implement log10, log10f, log10l,
3875         log2, log2f and log2l built-ins as inline x87 intrinsics.
3876
3877 2004-02-11  Richard Henderson  <rth@redhat.com>
3878
3879         PR target/1532
3880         * flow.c (insn_dead_p): A clobber of a dead hard register is a
3881         dead insn after reload.
3882
3883 2004-02-11  Ulrich Weigand  <uweigand@de.ibm.com>
3884
3885         * tree.h (frame_base_decl): Add GTY marker.
3886         * var-tracking.c (frame_base_decl): Likewise.
3887
3888 2004-02-11  Daniel Berlin  <dberlin@dberlin.org>
3889
3890         * dwarf2out.c (output_loc_list): Remove no longer necessary, and now
3891         incorrect, hunk.
3892         (add_location_or_const_value_attribute): Use text_section_label,
3893         not TEXT_SECTION_NAME.
3894
3895 2004-02-11  Per Bothner  <per@bothner.com>
3896
3897         Represent column numbers using line-map's source_location.
3898         The "next available source_location" is now managed internally by
3899         line-maps.c rather than by clients.
3900         * line-map.h (struct line_map):  New field column_bits.
3901         <from_line>:  Rename field to start_location.
3902         (struct line_maps):  New fields highest_location and max_column_hint.
3903         (linemap_check_files_exited):  New declaration.
3904         (linemap_line_start):  New declaration.
3905         (linemap_add):  Remove from_line parameter; use highest_location field.
3906         (SOURCE_LINE, LAST_SOURCE_LINE):  Modify to use column_bits.
3907         (SOURCE_COLUMN, LAST_SOURCE_LINE_LOCATION):  New macros.
3908         (CURRENT_LINE_MAP):  Remove macro.
3909         (linemap_position_for_column):  New inline function.
3910         * line-map.c (linemap_init):  Clear new fields.
3911         (linemap_check_files_exited):  New function, extracted from ...
3912         (linemap_free):  Use linemap_check_files_exited.
3913         (linemap_add):  Remove from_line parameter.  Various updates.
3914         (linemap_line_start):  New function.
3915         (linemap_lookeup):  Update for new field names.
3916         * cpphash.h (struct cpp_reader) <map>:  Field removed.  Because
3917         linemap_position_for_column may unpredictably change the current map,
3918         it is cleaner and simpler for us to not cache it in cpp_reader.
3919         (struct cpp_buffer):  New sysp field.
3920         Changed warned_cplusplus_comments and from_stage3 to bitfields.
3921         * cppinit.c (cpp_read_min_file):  pfile->map no longer exists.
3922         * cpplib.c (do_line, do_linemarker, _cpp_do_file_change):  Get
3923         current map using linemap_lookup.
3924         (do_linemarker):  Also set buffer's sysp field.
3925         (destringize_and_run):  No longer need to decrement current line.
3926         * cppfiles.c (_cpp_stack_file):  Set sysp from and in buffer.
3927         (search_path_head, open_file_failed):  Use buffer's sysp.
3928         (cpp_make_system_header):  Get current map using linemap_lookup.
3929         Also set buffer's sysp flag.
3930         * cppmacro.c (_cpp_builtin_macro_text):  Likewise use linemap_lookup.
3931         * cpphash.h (CPP_INCREMENT_LINE):  New macro.
3932         (struct cpp_buffer):  Moved fields saved_cur, saved_rlimit to ...
3933         (struct cpp_reader):  ... and adding saved_line_base field.
3934         * cpptrad.c (_cpp_overlay_buffer, _cpp_remove_overlay):
3935         Update accordingly.  Don't adjust line.
3936         (_cpp_scan_out_logical_line):  Use CPP_INCREMENT_LINE.
3937         * cpphash.c (CPP_IN_SYSTEM_HEADER):  Replaced macro by ...
3938         (cpp_in_system_header):  ... new inline function, using buffer's sysp.
3939         * cpperror.c (_cpp_begin_message):  Update to use cpp_in_system_header.
3940         * cpplex.c (_cpp_lex_direct):  Likewise.
3941         * cppmacro.c (_cpp_builtin_macro_text):  Likewise.
3942         * cppmacro.c (_cpp_create_definition):  Use buffer's sysp field.
3943         * cpplib.h (struct cpp_token):  Rename line field to src_loc.
3944         Remove col field as it is now subsumed by src_loc.
3945         * cpperror.c:  Update various field, parameter, and macro names.
3946         (print_location):  If col==0, try SOURCE_COLUMN of line.
3947         (cpp_error):  Use cur_token's src_loc field, rather than line+col.
3948         * cpplib.c (do_diagnostic):  Token's src_loc fields replaces line+col.
3949         * cpplex.c (_cpp_process_line_notes, _cpp_lex_direct,
3950         _cpp_skip_block_comment):  Use CPP_INCREMENT_LINE.
3951         (_cpp_temp_token):  Replace cpp_token's line+col fields by src_loc.
3952         (_cpp_get_fresh_line):  Don't need to adjust line for missing newline.
3953         (_cpp_lex_direct):  Use linemap_position_for_column.
3954         * c-ppoutput.c (maybe_print_line, print_line):  Don't take map
3955         parameter.  Instead get it from the line_table global.  Adjust callers.
3956         (print):  Remove map field.  Replace line field to src_line.
3957         (init_pp_output, account_for_newlines, maybe_print_line):  Adjust.
3958         (cb_line_change):  Use SOURCE_COLUMN.  Minor optimizations.
3959         (pp_file_change):  Use MAIN_FILE_P since we cannot checked print.map.
3960         Use LAST_SOURCE_LINE_LOCATION to "catch up" after #include.
3961         * cpptrad.c (copy_comment):  Rename variable.
3962         * c-lex.c (map):  Remove static variable, for same reason we removed
3963         cpp_reader's map field.
3964         (cb_line_change, cb_def_pragma, cb_define, cb_undef):  Hence we need
3965         to call linemap_lookup.
3966         (cb_line_change):  Token's line field replaced by src_loc.
3967         (fe_file_change):  Use MAINFILE_P and LAST_SOURCE_LINE macros.
3968         Don't save new_map.
3969
3970         * cpphash.h, cpperror.c, cpplib.h:  Some renames of fileline to
3971         source_location.
3972
3973 2004-02-11  Hartmut Penner  <hpenner@de.ibm.com>
3974
3975         * config/rs6000/altivec.md (*movv4si_internal): At least one
3976         operand must be register_operand.
3977         (*movv8hi_internal1): Likewise.
3978         (*movv16qi_internal1): Likewise.
3979         (*movv4sf_internal1): Likewise.
3980
3981 2004-02-10  Aldy Hernandez  <aldyh@redhat.com>
3982
3983         * config/rs6000/spe.md ("*movv2si_internal"): Check for register
3984         operand.
3985         (movv4hi_internal): Same.
3986         (movv2sf_internal): Same.
3987         (movv1di_internal): Same.
3988
3989 2004-02-11  Thiemo Seufer  <seufer@csv.ica.uni-stuttgart.de>
3990
3991         * config/mips/mips.h (TARGET_OLDABI): Define. Use TARGET_NEWABI and
3992         TARGET_OLDABI consistently.
3993         * config/mips/mips.c (function_arg,mips_setup_incoming_varargs,
3994         mips_va_arg,override_options,compute_frame_size,
3995         mips_initial_elimination_offset,mips16_fp_args,build_mips16_call_stub
3996         ,mips_return_in_memory,mips_strict_argument_naming): Use TARGET_NEWABI
3997         and TARGET_OLDABI consistently.
3998         * config/mips/mips.md (exception_receiver): Likewise.
3999         * config/mips/linux64.h: Likewise.
4000
4001 2004-02-11  Hartmut Penner  <hpenner@de.ibm.com>
4002
4003         * gcc/config/rs6000/rs6000.c (rs6000_override_options)
4004         Set AltiVec ABI and vrsave as default for ppc64 linux.
4005         (init_cumulative_args): Post error, if try to return
4006         value in AltiVec register without enable AltiVec.
4007         (function_arg_advance): Ditto for passing arguments.
4008
4009 2004-02-11 &nbs