OSDN Git Service

462feb758d1b5b0cf9321f6aa6657542284e6c98
[pf3gnuchains/gcc-fork.git] / gcc / ChangeLog
1 2004-03-30  David Edelsohn  <edelsohn@gnu.org>
2
3         * config/rs6000/rs6000.md (tls_gd_32, tls_gd_64,
4         tls_ld_32, tls_ld_64, tls_dtprel_32, tls_dtprel_64,
5         tls_dtprel_ha_32, tls_dtprel_ha_64,
6         tls_dtprel_lo_32, tls_dtprel_lo_64,
7         tls_got_dtprel_64, tls_tprel_32, tls_tprel_64,
8         tls_tprel_ha_32, tls_tprel_ha_64,
9         tls_tprel_lo_32, tls_tprel_lo_64,
10         tls_got_tprel_32, tls_got_tprel_64,
11         tls_tls_32, tls_tls_64): Replace register_operand with
12         gpc_reg_operand.
13
14 2004-03-30  Mostafa Hagog  <mustafa@il.ibm.com>
15
16         * config/rs6000/rs6000.md (*ctrsi_internal1, *ctrsi_internal2,
17         *ctrdi_internal1, *ctrdi_internal2, *ctrsi_internal3,
18         *ctrsi_internal4, *ctrdi_internal3, *ctrdi_internal4,
19         *ctrsi_internal5, *ctrsi_internal6, *ctrdi_internal5,
20         *ctrdi_internal6): Replace register_operand with
21         nonimmediate_operand.
22
23 2004-03-29  Fariborz Jahanian <fjahanian@apple.com>
24
25         * fold-const.c (fold): Reassociate multiply expression
26         with an adjacent non-multiply expression to use
27         architecture's multiply-add instruction.
28
29 2004-03-30  Zack Weinberg  <zack@codesourcery.com>
30
31         * gengtype.c (create_option): New function.
32         * gengtype.h: Prototype it.
33         * gengtype-yacc.y (stringseq): New rule.
34         (option): Use create_option.  Add new bare ID production.  Use
35         stringseq, not STRING directly.
36
37         * alias.c, bitmap.c, c-decl.c, cgraph.h, cpplib.h, cselib.h
38         * dwarf2out.c, emit-rtl.c, function.h, lists.c, tree.h
39         * varray.h, config/alpha/alpha.c:
40         Use new shorter form of GTY markers.
41
42         * doc/gty.texi: Rewrite.
43
44 2004-03-30  Andrew Pinski  <pinskia@physics.uc.edu>
45
46         * config/darwin.c (machopic_function_base_name):
47         Remove current_name and getting the name of the
48         current function.
49
50 2004-03-30  Nick Clifton  <nickc@redhat.com>
51
52         * config/arm/arm.md (thumb_jump): Reduce the backward branch
53         range, and increase the forward branch range, to allow for
54         the fact that the PC will be off by 4.
55
56 2004-03-30  Alan Modra  <amodra@bigpond.net.au>
57
58         * .cvsignore: Add GPATH, GRTAGS, GSYMS and GTAGS (GNU GLOBAL)
59
60 2004-03-30  Hartmut Penner  <hpenner@de.ibm.com>
61
62         * config/rs6000/rs6000.c (output_vec_const_move):
63         Find all cases of EASY_VECTOR_15_ADD_SELF.
64         (easy_vector_constant_add_self): Accept
65         all vector constant loadable by vsplt* and vadd*.
66         (easy_vector_same): Use easy_vector_splat_const.
67         (easy_vector_const): Use easy_vector_splat_const.
68         (easy_vector_splat_const): New function.
69         (gen_easy_vector_constant_add_self): New function.
70
71         * config/rs6000/rs6000-protos.c (gen_easy_vector_constant_add_self):
72         New prototype.
73
74         * config/rs6000/altivec.md (movv4si splitter): Change to
75         emit move insn with halfed vector constant.
76         (*movv8hi splitter): Likewise.
77         (*movv16qi splitter): Likewise.
78
79 2004-03-30  Hartmut Penner  <hpenner@de.ibm.com>
80
81         PR 11591
82         * config/rs6000/rs6000.c (rs6000_legitimate_address):
83         Allow any offset to argument pointer in no-strict case.
84
85 2004-03-30  Jan Hubicka  <jh@suse.cz>
86
87         * toplev.c (backend_init): Add missing call to inint_optimization_passes.
88         * passes.c (init_optimization_passes, finish_optimization_passes): Output cgraph
89         dump file in non-unit-at-a-time mode.
90
91 2004-03-29  Hans-Peter Nilsson  <hp@axis.com>
92
93         * config/cris/cris.h: Correct #ifdef to test for
94         HAVE_AS_NO_MUL_BUG_ABORT_OPTION, not
95         HAVE_AS_MUL_BUG_ABORT_OPTION.
96
97 2004-03-29  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
98
99         * function.c (put_var_into_stack): If old RTL was ADDRESSOF, update
100         the address inside the old RTL.
101
102 2004-03-28  Zack Weinberg  <zack@codesourcery.com>
103
104         * c-decl.c: Verify that C_SIZEOF_STRUCT_LANG_IDENTIFIER is correct.
105         (struct c_binding, struct c_scope): Add chain_next
106         attributes to GTY markers.
107         (struct lang_identifier, struct lang_tree_node): Define
108         here...
109         * c-tree.h: ... not here.  No longer need to declare struct
110         c_binding either.  Do define C_SIZEOF_STRUCT_LANG_IDENTIFIER.
111         * c-lang.c, objc/objc-lang.c: Set LANG_HOOKS_IDENTIFIER_SIZE
112         to C_SIZEOF_STRUCT_LANG_IDENTIFIER.
113
114         PR 14734, 11944
115         * c-decl.c (get_parm_info): If error_mark_node is encountered
116         in the bindings chain, unbind and discard it; don't abort.
117
118 2004-03-28  Olga Golovonevsky <olga@il.ibm.com>
119             Dorit Naishlos <dorit@il.ibm.com>
120
121         * config/rs6000/altivec.md: (andvv16qi3, andv8hi3, one_cmplv16qi2,
122         one_cmplv8hi2, one_cmplv4si2, iorv16qi3, iorv8hi3,): New modelling.
123
124 2004-03-28  Stephane Carrez  <stcarrez@nerim.fr>
125
126         * config/m68hc11/m68hc11-protos.h (m68hc11_page0_symbol_p): Declare.
127
128         * config/m68hc11/m68hc11.c (m68hc11_handle_page0_attribute): New.
129         (m68hc11_attribute_table): New attribute "page0" to mark a global
130         variable as being allocated from within page0 section.
131         (m68hc11_encode_label): New function.
132         (m68hc11_strip_name_encoding): New function.
133         (m68hc11_page0_symbol_p): New function.
134         (m68hc11_indirect_p): Accept global variables marked in page0.
135         (m68hc11_encode_section_info): Lookup "page0" attribute.
136
137         * config/m68hc11/m68hc11.h (EXTRA_CONSTRAINT): 'R' constraint also
138         represents access to page0 variables.
139
140         * config/m68hc11/m68hc11.md ("*logicalsi3_zexthi"): Use gen_rtx_REG.
141         ("*logicalsi3_silshl16_zext"): Likewise.
142         ("*ashldi3_const32"): Likewise.
143         (peephole2 ashift): Likewise.
144
145 2004-03-28  Joseph S. Myers  <jsm@polyomino.org.uk>
146
147         * c-tree.h (C_DECL_REGISTER): New.
148         * c-aux-info.c (gen_decl), c-decl.c (objc_mark_locals_volatile,
149         finish_decl, grokdeclarator, get_parm_info), c-typeck.c
150         (build_array_ref, c_mark_addressable): Set and use it.
151         * c-decl.c (grokdeclarator), c-typeck.c (c_mark_addressable):
152         Allow structures with volatile fields to be declared register.
153         Don't check TREE_ADDRESSABLE before warning about taking address
154         of register.
155         * c-decl.c (finish_decl): Don't allow structures with volatile
156         fields to be placed in named register.
157         * doc/trouble.texi: Remove reference to structures with volatile
158         fields in registers.
159
160 2004-03-27  Ulrich Weigand  <uweigand@de.ibm.com>
161
162         * function.c (thread_prologue_and_epilogue): Move
163         NOTE_INSN_FUNCTION_END and NOTE_INSN_FUNCTION_BEG notes
164         before the epilogue.
165
166 2004-03-27  Ulrich Weigand  <uweigand@de.ibm.com>
167
168         * expr.c (store_constructor): Use gen_int_mode to correctly
169         sign-extend CONST_INT value.
170
171 2004-03-27  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
172
173         * builtin-types.def (BT_WINT, BT_FN_INT_WINT, BT_FN_WINT_WINT): New.
174         * builtins.def (DEF_C94_BUILTIN): New.  Add wctype builtins.
175         * doc/extend.texi: Likewise.
176
177 2004-03-26  Diego Novillo  <dnovillo@redhat.com>
178
179         * c-typeck.c (comptypes): Replace calls to TYPE_DOMAIN
180           with TYPE_ORIG_SIZE_TYPE.
181
182 2004-03-25  Aldy Hernandez  <aldyh@redhat.com>
183
184         PR 14219
185         * c-typeck.c (build_binary_op): Do not allow comparisons of
186         vectors.
187
188 2004-03-26  James A. Morrison  <ja2morri@uwaterloo.ca>
189
190         * config.gcc: Remove sparc-tti-*.
191         * config/sparc/pbd.h: Delete.
192
193         * config/sparc/sol2.h: Remove note about Sun OS 4.x.
194         * config/sparc/aout.h: Likewise.
195
196         * config/sparc/sparc.h: Remove if 0'd code.
197         * config/sparc/sparc.md (call): Remove if 0'd code.
198         (call_value): Likewise.
199         (nonlocal_goto): Likewise.
200         (unimp_insn): Delete.
201
202 2004-03-25  Roger Sayle  <roger@eyesopen.com>
203
204         * fold-const.c (tree_expr_nonnegative_p): Handle BIT_XOR_EXPR like
205         BIT_IOR_EXPR; A^B is nonnegative when A and B are nonnegative.
206
207 2004-03-25  Richard Henderson  <rth@redhat.com>
208
209         PR 11527
210         * c-typeck.c (pop_init_level): Emit pending init elements earlier
211         rather than later.
212
213 2004-03-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
214
215         * builtins.c (fold_builtin): Fix error in last change.
216
217 2004-03-25  Richard Sandiford  <rsandifo@redhat.com>
218
219         * config/mips/mips.h: Formatting fix.
220
221 2004-03-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
222
223         * builtins.def: Add ctype builtins.
224         * doc/extend.texi: Likewise.
225
226 2004-03-25  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
227
228         * builtins.c (fold_builtin): Add new builtin optimizations for
229         sqrt and/or cbrt.
230         * fold-const.c (fold): Likewise.
231
232 2004-03-25  David Edelsohn  <edelsohn@gnu.org>
233
234         * config/rs6000/rs6000.c (rs6000_always_hint): New variable.
235         (rs6000_sched_groups): New variable.
236         (processor_target_table): Add power5.
237         (rs6000_override_options): Set rs6000_sched_insert_nops,
238         rs6000_sched_costly_dep and rs6000_sched_restricted_insns_priority
239         from rs6000_sched_groups.
240         (output_cbranch): Use rs6000_always_hint.
241         (rs6000_variable_issue): Use rs6000_sched_groups.
242         (rs6000_adjust_cost): Add CPU_POWER5.
243         (is_microcoded_insn): Use rs6000_sched_groups.
244         (is_dispatch_slot_restricted): Use rs6000_sched_groups.
245         Return 2 for POWER5 cracked instructions.
246         (is_cracked_insn): Use rs6000_sched_groups.
247         (is_branch_slot_insn): Use rs6000_sched_groups.
248         (rs6000_issue_rate): Add CPU_POWER5.
249         (rs6000_sched_finish): Use rs6000_sched_groups.
250         (rs6000_rtx_costs): Add PROCESSOR_POWER5.
251         * config/rs6000/rs6000.h (processor_type): Add PROCESSOR_POWER5.
252         (DEFAULT_SCHED_COSTLY_DEP): Delete.
253         (DEFAULT_RESTRICTED_INSNS_PRIORITY): Delete.
254         (DEFAULT_SCHED_FINISH_NOP_INSERTION_SCHEME): Delete.
255         * config/rs6000/rs6000.md (define_attr "cpu"): Add power5.
256         * config/rs6000/power5.md: New file.
257         * doc/invoke.texi: Add power5 option.
258
259 2004-03-25  Kazu Hirata  <kazu@cs.umass.edu>
260
261         * cfgrtl.c, dbxout.c, tree.def, config/darwin.h,
262         config/arm/arm.c, objc/objc-act.c: Fix comment typos.
263         * doc/invoke.texi: Fix a typo.
264
265 2004-03-25  Kazu Hirata  <kazu@cs.umass.edu>
266
267         PR optimization/9707.
268         * stmt.c (emit_case_nodes): Emit equality comparisons instead
269         of recursing if both children are single-valued cases with no
270         children.
271
272 2004-03-25  Paul Brook  <paul@codesourcery.com>
273
274         * config/arm/arm.c (vfp_print_multi): Remove.
275         (arm_output_fldmx): New function.
276         (vfp_emit_fstmx): Return block size, not insn. Add ARM10 VFPr1 bugfix.
277         (arm_expand_prologue): Update to match.
278         (arm_get_vfp_saved_size): New Function.
279         (arm_get_frame_offsets): Use it.
280         (arm_output_epilogue): Use new functions.
281
282 2004-03-24  Richard Henderson  <rth@redhat.com>
283
284         * alias.c (alias_invariant, alias_invariant_size): Mark GTY.
285         (reg_known_value, reg_known_value_size): Likewise; make static.
286         (reg_known_equiv_p): Make static.
287         (clear_reg_alias_info): Update for new indexing.
288         (get_reg_known_value, set_reg_known_value): New.
289         (get_reg_known_equiv_p, set_reg_known_equiv_p): New.
290         (canon_rtx): Use them.
291         (init_alias_analysis): Likewise.  Allocate reg_known_value with gc.
292         Don't play queer offsetting games with reg_known_value and
293         reg_known_equiv_p.
294         (end_alias_analysis): Free reg_known_value with gc.
295         * rtl.h (get_reg_known_value, get_reg_known_equiv_p): Declare.
296         * sched-deps.c (reg_known_equiv_p, reg_known_value): Remove.
297         (deps_may_trap_p, sched_analyze_1, sched_analyze_2): Use the new
298         functions instead.
299
300 2004-03-24  Kazu Hirata  <kazu@cs.umass.edu>
301
302         * dwarf2asm.c, loop.h, pretty-print.c, pretty-print.h,
303         config/i386/mmintrin.h: Update copyright.
304
305 2004-03-24  Nathanael Nerode  <neroden@gcc.gnu.org>
306
307         * configure.ac: Add --enable-werror-always (for top level bootstrap
308         support).
309         * configure: Regenerate.
310
311 2004-03-24  Ziemowit Laski  <zlaski@apple.com>
312
313         * objc/objc-act.c (objc_comptypes): Treat comparisons
314         between 'Class' and '<class> *' as explicitly invalid.
315
316 2004-03-24  David Edelsohn  <edelsohn@gnu.org>
317
318         * doc/invoke.texi (-frename-registers: Add enabled at -O3.
319         (-fprofile-values): Add enabled with profile-{generate,use}.
320         (-fvpt): Same.
321         (-ftracer): Add enabled with profile-use.
322         (-funit-at-a-time): Add enabled at -O2,-O3.
323         (-funroll-loops): Add enabled with profile-use.
324         (-funswitch-loops): Add enabled with profile-use.  Remove duplicates.
325         (max-gcse-passes): Mention default.
326         (max-cse-path-length): Mention default.
327
328 2004-03-24  Nathanael Nerode  <neroden@gcc.gnu.org>
329
330         * Makefile.in (STRICT2_WARN): Reorder.
331         * configure.ac: Check for -Wold-style-definition, and use it
332         in strict1_warn if it's available.
333         * configure: Regnerate.
334
335 2004-03-24  Paul Brook  <paul@nowt.org>
336
337         * config.gcc <arm>: Add --with-abi=
338         * config/arm/arm-protos.h (arm_get_frame_size, thumb_get_frame_size,
339         thumb_far_jump_used): Remove prototypes.
340         (arm_needs_doubleword_align): Add prototype.
341         (thumb_compute_initial_elimination_offset): Ditto.
342         * config/arm/arm.c (arm_get_frame_offsets): New function.
343         (use_return_insn, output_return_instruction, arm_output_epilogue,
344         arm_output_function_epilogue, arm_compute_initial_elimination_offset,
345         arm_expand_prologue, thumb_expand_epilogue): Use it.
346         (arm_abi, target_abi_name, all_arm_abis): New variables.
347         (arm_override_options): Set them.  Set structure padding for AAPCS.
348         (arm_return_in_memory): Update ABI check.
349         (arm_init_cumulative_args): Initialize can_split.
350         (arm_needs_doubleword_align): New function.
351         (arm_function_arg): Don't split args after pushing to stack. Handle
352         doubleword/even reg alignment.
353         (arm_va_arg): Handle all doubleword aligned args.
354         (add_minpoolforward ref, dump_minpool, push_minpool_fix): Align based
355         on ABI, not CPU.
356         (arm_compute_save_reg0_reg12_mask): Fix comment.
357         (thumb_get_frame_size, thumb_get_frame_size): Remove.
358         (thumb_jump_far_used_p): Remove superfluous argument.  Return save
359         value for alignment.
360         (thumb_unexpanded_epilogue, thumb_output_function_prologue): Change
361         to match.
362         (thumb_compute_initial_elimination_offset): New function.
363         (thumb_expand_prologue): Use arm_get_frame_offsets.  Remove
364         unneccessary rounding.
365         * config/arm/arm.h (target_abi_name): Declare.
366         (ARM_DOUBLEWORD_ALIGN, DOUBLEWORD_ALIGNMENT, TARGET_IWMMXT_ABI,
367         arm_abi_type, ARM_DEFAULT_ABI): Define.
368         (ARM_FLAG_ATPCS): Remove.
369         (TARGET_OPTIONS, OPTION_DEFAULT_SPECS): Add -mabi=.
370         (BIGGEST_ALIGNMENT, PREFERRED_STACK_BOUNDARY, STACK_BOUNDARY): Use it.
371         (ADJUST_FIELD_ALIGN, DATA_ALIGNMENT, LOCAL_ALIGNMENT,
372         TYPE_NEEDS_IWMMXT_ALIGNMENT): Remove.
373         (LIBCALL_VALUE, FUNCTION_VALUE_REGNO_P, FUNCTION_ARG_REGNO_P):
374         Contitionalize on ABI, not CPU.
375         (struct arm_stack_offsets): Define.
376         (struct machine_function): Add stack_offsets.  Remove frame_size.
377         (FUNCTION_ARG_PARTIAL_NREGS): Don't split if previous args have been
378         pushed.
379         (FUNCTION_ARG_ADVANCE, FUNCTION_ARG_BOUNDARY): Handle general
380         doubleword alignment.
381         (THUMB_INITIAL_ELIMINATION_OFFSET,
382         ARM_INITIAL_ELIMINATION_OFFSET): Remove.
383         (INITIAL_ELIMINATION_OFFSET): Call functions directly.
384         * config/arm/arm.md (align_8): Enable for all targets.
385         * config/arm/netbsd-elf.h (TARGET_DEFAULT): Remove TARGET_ATPCS.
386         (ARM_DEFAULT_ABI): Define.
387         * doc/invoke.texi <ARM>: Document -mabi=. Update documentation for
388         -mstructure-size-boundary.
389
390 2004-03-24  Nathanael Nerode  <neroden@gcc.gnu.org>
391
392         * configure.ac: Check for -Wno-variadic-macros; don't use
393         -pedantic (in stage 1 or a simple 'make all') unless it's available,
394         and if it's available, use it.  Also, clean up check for
395         -Wno-long-long.
396         * configure: Regenerate.
397
398 2004-03-24  Richard Sandiford  <rsandifo@redhat.com>
399
400         * config.gcc (mips64vr-*-elf*, mips64vrel-*-elf*): Remove tm_defines.
401         * config/mips/vr.h (DEFAULT_VR_ARCH): New macro, defined to vr4130.
402         (MULTILIB_DEFAULTS): Use it.
403         (MIPS_CPU_STRING_DEFAULT): Remove.
404         (MIPS_ABI_DEFAULT, MIPS_MARCH_CONTROLS_SOFT_FLOAT): Define.
405         (DRIVER_SELF_SPECS): Make -mfix-vr4122-bugs imply -march=vr4120.  Make
406         EABI64 -mlong32 the default ABI.  Enforce the default architecture.
407         * config/mips/t-vr (MULTILIB_OPTIONS): Add mfix-vr4122-bugs,
408         march=vr4130, march=vr4300, march=vr5000 and march=vr5500.
409         (MULTILIB_MATCHES): Use -mfix-vr4122-bugs multilibs for -march=vr4120.
410         (MULTILIB_EXCEPTIONS): Change choice of multilibs.  Update comments
411         accordingly.
412
413 2004-03-24  DJ Delorie  <dj@redhat.com>
414             Richard Sandiford  <rsandifo@redhat.com>
415
416         * config/mips/mips.h (MASK_FIX_VR4122, TARGET_FIX_VR4122): New macros.
417         (TARGET_SWITCHES): Add -mfix-vr4122-bugs and -mno-fix-vr4122-bugs.
418         (ASM_SPEC): Pass down -mfix-vr4122-bugs.
419         * config/mips/mips.c (mips_avoid_hazards): Don't emit whole functions
420         in .set noreorder and .set nomacro if TARGET_FIX_VR4122.
421         (mips_init_libfuncs): Use special functions for divsi3 and modsi3
422         if TARGET_FIX_VR4122.
423         * config/mips/mips.md (define_attr length): Account for nops inserted
424         after macc and dmult when using -mfix-vr4122-bugs.
425         (umuldi3_highpart, divmodsi4, divmoddi4): Disable if TARGET_FIX_VR4122.
426         * config/mips/t-vr (LIB2FUNCS_STATIC_EXTRA): Define instead of
427         LIB2FUNCS_EXTRA.  Add config/mips/vr4122-div.S.
428         * config/mips/vr4122-div.S: New file.
429         * doc/invoke.texi: Document -mfix-vr4122-bugs.
430
431 2004-03-24  Richard Sandiford  <rsandifo@redhat.com>
432
433         * config/mips/mips.h (PROCESSOR_R4130): New processor_type.
434         (TARGET_MIPS4130): New macro.
435         (ISA_HAS_MACC): Return true if TARGET_MIPS4130 && !TARGET_MIPS16.
436         * config/mips/mips.c (mips_cpu_info_table): Add a vr4130 entry.
437         (override_options): Extend MIPS_MARCH_CONTROLS_SOFT_FLOAT to deal
438         with PROCESSOR_R4130.
439         * config/mips/mips.md (define_attr cpu): Add r4130.
440         * doc/invoke.texi: Document vr4130 as a supported MIPS architecture.
441
442 2004-03-24  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
443             Richard Sandiford  <rsandifo@redhat.com>
444
445         * doc/invoke.texi: Apply missed hunk from 2004-03-03 change.
446
447 2004-03-24  Alexandre Oliva  <aoliva@redhat.com>
448
449         PR preprocessor/14438
450         * cpplib.c (do_pragma): Remove line_change call after pragma
451         handler.
452
453 2004-03-23  Ian Lance Taylor  <ian@wasabisystems.com>
454
455         * doc/extend.texi (ARM Built-in Functions): Replace with correct
456         declarations.
457
458 2004-03-23  Roger Sayle  <roger@eyesopen.com>
459
460         * reg-stack.c (get_true_reg): Handle FLOAT_TRUNCATE like FLOAT_EXTEND
461         if flag_unsafe_math_optimizations.
462         * config/i386/i386.md (truncdfsf2): If flag_unsafe_math_optimizations
463         and TARGET_80387 expand using truncdfsf2_noop pattern.
464         (truncxfsf2): Likewise using truncxfsf2_noop.
465         (truncxfdf2): Likewise using truncxfdf2_noop.
466         (truncdfsf2_noop, truncxfsf2_noop, truncxfdf2_noop): New patterns.
467
468 2004-03-23  Ziemowit Laski  <zlaski@apple.com>
469
470         * hooks.c (hook_constcharptr_tree_null): New hook.
471         * hooks.h (hook_constcharptr_tree_null): New prototype.
472         * target-def.h (TARGET_MANGLE_FUNDAMENTAL_TYPE): New target hook.
473         * target.h (mangle_fundamental_type): New target hook.
474         * config/rs6000/rs6000.c (TARGET_MANGLE_FUNDAMENTAL_TYPE): Point
475         target hook at rs6000_mangle_fundamental_type.
476         (rs6000_mangle_fundamental_type): New function.
477         * doc/tm.texi (TARGET_MANGLE_FUNDAMENTAL_TYPE): Document.
478
479 2004-03-23  Zack Weinberg  <zack@codesourcery.com>
480
481         PR 12267, 12391, 12560, 13129, 14114, 14133
482         * c-tree.h: Forward declare struct c_binding.  Declare
483         c_override_bindings_to_false.  Update prototypes.
484         (struct lang_identifier): Update comments.  Change fields to be
485         struct c_binding *.
486         (IDENTIFIER_SYMBOL_VALUE, IDENTIFIER_TAG_VALUE)
487         (IDENTIFIER_LABEL_VALUE, C_DECL_INVISIBLE)
488         (KEEP_NO, KEEP_YES, KEEP_MAYBE): Delete.
489         (C_DECL_IN_EXTERNAL_SCOPE, C_DECL_DECLARED_BUILTIN): New.
490         * c-common.h: Update prototypes.
491         * c-decl.c (struct c_scope): Update commentary.  Remove names,
492         names_last, parms, parms_last, tags, and shadowed fields.  Add
493         bindings and depth fields.
494         (scope_freelist): Move to more appropriate location.
495         (c_print_identifier): Update for changes to struct lang_identifier.
496         (objc_mark_locals_volatile): Update for new bindings structures.
497         (global_bindings_p): Honor c_override_global_bindings_to_false.
498         (pushlevel): Rename to push_scope; take no arguments; use the
499         scope_freelist; initialize scope->depth and check for overflow.
500         (poplevel): Rename to pop_scope; totally rewritten for new bindings
501         structures.
502         (diagnose_mismatched_decls): Use C_DECL_DECLARED_BUILTIN, not
503         C_DECL_INVISIBLE, for certain decisions.  Adjust some diagnostics.
504         Improve some commentary.  Adjust handling of forward parm decls.
505         (merge_decls): Set C_DECL_DECLARED_BUILTIN when appropriate.
506         Preserve C_DECL_IN_EXTERNAL_SCOPE.
507         (warn_if_shadowing): Correct indentation.  Improve diagnostics.
508         (pushdecl): Remove unnecessary assertion.  Short-circuit anonymous
509         decls.  Rewrite for new bindings structures.  Improve commentary.
510         Eliminate the copy_node call.
511         (implicit_decl_warning): Use the "diag" idiom (as seen in
512         locate_old_decl) to reduce code duplication; call locate_old_decl
513         if appropriate.  Relocate to remove need for forward declaration.
514         (implicitly_declare): Adjust for new bindings structures.  Kludge
515         around Objective-C not-really-builtin functions.
516         (undeclared_variable): Improve diagnostics.  If current_function_decl
517         is nonnull but current_function_scope is null, use current_scope.
518         Use bind.
519         (lookup_tag): Adjust for new bindings structures.  Kludge around
520         Objective-C's tag declarations that wind up in the external scope.
521         (lookup_name): Adjust for new bindings structures.  Kludge around
522         c-common.c's pseudo-typedefs that wind up in the external scope.
523         (lookup_name_current_level): Rename lookup_name_in_scope; take a
524         second argument indicating the scope to examine; rewrite for
525         new bindings structures.
526         (c_init_decl_processing): Adjust for renamed functions.  Do not
527         initialize current_file_decl, first_builtin_decl, last_builtin_decl.
528         First scope pushed is the external scope, not the global scope.
529         (builtin_function): Use bind, not pushdecl.  Adjust other bits
530         for new data structures.  Keep track of builtins that should be
531         made visible automatically.
532         (start_decl): Adjust diagnostics.  Remove unnecessary call to
533         expand_decl.
534         (grokparms): Return 0 if arg_types is error_mark_node.
535         (get_parm_info): Rename "void_at_end" argument to "ellipsis", with
536         reversed sense.  Rewrite for new bindings structures.  Do not
537         leave any decls in the scope, to prevent pop_scope from doing
538         contradictory things with them.
539         (finish_struct, finish_enum): Remove redundant diagnostics.
540         (build_enumerator): Don't cascade diagnostics for error_mark_node.
541         Mark location where -pedantic changes the meaning of the program.
542         (store_parm_decls_newstyle, store_parm_decls_oldstyle): Load the
543         parameter decls into the function's scope structure using bind.
544         Warn here about function definitions in the wrong style.
545         Adjust diagnostics.
546         (store_parm_decls): Correct the determination of whether a
547         function was defined with a prototype.
548         (c_write_global_declarations): Operate on all file decls and on
549         the external scope.  Split body of the loop to...
550         (c_write_global_declarations_1): ... this new function, to avoid
551         code duplication.
552         (truly_local_externals, first_builtin_decl, last_builtin_decl)
553         (make_scope, pop_scope, in_parm_level_p, set_block)
554         (any_external_decl, record_external_decl, bind_label, getdecls)
555         (link_hash_hash, link_hash_eq, merge_translation_unit_decls)
556         (c_reset_state): Delete.
557         (visible_builtins, c_override_global_bindings_to_false)
558         (c_binding, I_SYMBOL_BINDING, I_SYMBOL_DECL, I_TAG_BINDING)
559         (I_TAG_DECL, I_LABEL_BINDING, I_LABEL_DECL, file_scope)
560         (external_scope, binding_freelist, bind, free_binding_and_advance)
561         (push_file_scope, pop_file_scope): New.
562         (pushtag, pushdecl_top_level, lookup_label, declare_label)
563         (define_label, c_make_fname_decl, finish_decl)
564         (mark_forward_parm_decls, build_compound_literal)
565         (grokdeclarator, start_function, check_for_loop_decls)
566         (identifier_global_value, record_builtin_type): Minor adjustments
567         for new bindings structures.  Improve diagnostics and commentary.
568         * c-objc-common.c (start_cdtor, finish_cdtor): Adjust calls to
569         pushlevel/poplevel respectively.
570         (c_objc_common_finish_file): Don't call merge_translation_unit_decls.
571         * c-opts.c (c_common_parse_file): Remove spurious ATTRIBUTE_UNUSED.
572         Warn about YYDEBUG not being defined only if -dy.  Remove no-longer-
573         correct loop over multiple translation units; call fatal_error if
574         requested to compile more than one file at once.  (This disables
575         IMA temporarily - an up-front error being preferable to a crash.)
576         * c-parse.in (pushlevel, poplevel rules): Rename push_scope, pop_scope.
577         (all actions): Adjust calls to pushlevel/poplevel.
578         (parsing_iso_function_signature): Delete.
579         (extdef_1): Fold into extdef.
580         (old_style_parm_decls_1): Fold into old_style_parm_decls.  Don't
581         warn here about function definitions in the wrong style.
582         (after_tyle_declarator, parm_declarator_starttypename)
583         (parm_declarator_nostarttypename, notype_declarator): Remove
584         commented-out productions.
585         (parmlist_1, parmlist_2): Use make_node, not tree_cons, to create
586         an empty TREE_LIST node.  Adjust calls to get_parm_info.
587         (parmlist_2 : ELLIPSIS): Tag the arg-info block with error_mark_node
588         to suppress -Wold-style-definition after this error.
589         (c_parse_file): Don't clear the binding stack or call
590         finish_fname_decls here.  Correct comment.
591         * c-typeck.c (same_translation_unit_p): Export.
592         (common_type): Use c_override_global_bindings_to_false, not
593         pushlevel/poplevel/declare_parm_level.
594         * c-lang.c: Override LANG_HOOKS_CLEAR_BINDING_STACK,
595         LANG_HOOKS_PUSHLEVEL, LANG_HOOKS_POPLEVEL, LANG_HOOKS_SET_BLOCK,
596         and LANG_HOOKS_GETDECLS with do-nothing stubs.
597         * objc/objc-lang.c: Likewise.
598         * objc/objc-act.c: Adjust all calls to pushlevel, poplevel,
599         get_parm_info.
600         (OBJC_VOID_AT_END): Delete; replace all uses
601         with void_list_node.
602         (generate_forward_declaration_to_string_table): Delete.
603         * objc/objc-act.h (OCTI_STRG_DECL, UOBJC_STRINGS_decl): Delete.
604
605         * coverage.c (create_coverage): Don't pushdecl anything.
606         * langhooks.c (lhd_clear_binding_stack): Call
607         lang_hooks.decls.poplevel, not poplevel.
608         * tree.c (list_length): If ENABLE_TREE_CHECKING, abort on a
609         circular list rather than going into an infinite loop.
610
611 2004-03-23  Olivier Hainque  <hainque@act-europe.fr>
612
613         * optabs.c (expand_binop): When synthesizing double word rotates
614         from single word shifts, use a new register target if the provided
615         target is not a REG already.
616
617 2004-03-23  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
618
619         * alias.c (get_alias_set): Add support for TYPE_REF_CAN_ALIAS_ALL.
620         * c-common.c (handle_mode_attribute): Add extra arg to
621         build_pointer_type_for_mode and build_reference_type_for_mode.
622         * c-typeck.c (build_c_cast): Only look at TREE_CONSTANT_OVERFLOW
623         for INTEGER_CST.
624         * tree.c (build_pointer_type_for_mode): Add arg CAN_ALIAS_ALL.
625         Chain pointers via TYPE_NEXT_PTR_TO.
626         (build_reference_type_for_mode): Similarly.
627         (build_type_no_quals): Add extra arg to build_pointer_type_for_mode
628         and build_reference_type_for_mode.
629         (tree_check4_failed): New function.
630         * tree.h (TREE_CHECK4, PTR_OR_REF_CHECK): New macros.
631         (TYPE_REF_CAN_ALIAS_ALL, TYPE_NEXT_PTR_TO, TYPE_NEXT_REF_TO): Likewise.
632         (TREE_NO_UNSUED_WARNING, TREE_VIA_VIRTUAL, TREE_CONSTANT_OVERFLOW):
633         Add check.
634
635 2004-03-23  Roger Sayle  <roger@eyesopen.com>
636
637         * fold-const.c (tree_expr_nonnegative_p): A&B is nonnegative when
638         A is nonnegative or B is nonnegative.  Similarly A|B is nonnegative
639         when both A and B are nonnegative.
640         (tree_expr_nonzero_p): A|B is nonzero when A is nonzero or B is
641         nonzero.
642
643 2004-03-23  Kazu Hirata  <kazu@cs.umass.edu>
644
645         * fold-const.c (fold): Remove cases for INTEGER_CST, REAL_CST,
646         VECTOR_CST, STRING_CST, COMPLEX_CST, and CONSTRUCTOR.
647
648 2004-03-23  Kazu Hirata  <kazu@cs.umass.edu>
649
650         PR optimization/14669
651         * fold-const.c (fold): Only unwiden integer comparisons for equality
652         and inequality operators, or when the signedness doesn't change.
653
654 2004-03-23  Jakub Jelinek  <jakub@redhat.com>
655
656         * config.gcc (sparc-*-linux*): Add sparc/t-linux to tmake_file.
657         * config/sparc/t-linux64 (TARGET_LIBGCC2_CFLAGS): Set.
658         * config/sparc/t-linux: New file.
659
660 2004-03-23  Richard Sandiford  <rsandifo@redhat.com>
661
662         * gcse.c (can_assign_to_reg_p): New function, split out from...
663         (want_to_gcse_p): ...here.
664         (compute_ld_motion_mems): Use can_assign_to_reg_p to validate
665         the rhs of a store.
666
667 2004-03-22  Diego Novillo  <dnovillo@redhat.com>
668
669         * c-typeck.c (same_translation_unit_p): Fix pasto.
670
671 2004-03-22  David Edelsohn  <edelsohn@gnu.org>
672
673         * params.def (PARAM_MAX_SCHED_REGION_BLOCKS): New.
674         (PARAM_MAX_SCHED_REGION_INSNS): New.
675         * sched-rgn.c: Include params.h
676         (MAX_RGN_BLOCKS): Delete.
677         (MAX_RGN_INSNS): Delete.
678         (too_large): Return bool.  Convert to PARAM_VALUE.
679         * Makefile.in (sched-rgn.o): Depend on $(PARAMS_H).
680         * doc/invoke.texi (param): Document max-sched-region-blocks and
681         max-sched-region-insns.
682
683 2004-03-22  Joel Brobecker  <brobecker@gnat.com>
684
685         * dwarf2out.c (is_subrange_type): Do not emit a subrange_type DIE
686         for base types.
687
688 2004-03-22  Joel Brobecker  <brobecker@gnat.com>
689
690         * dwarf2out.c (is_subrange_type): Minor code rework. No behavior
691         change.
692
693 2004-03-22  Jakub Jelinek  <jakub@redhat.com>
694
695         PR c/14069
696         * c-decl.c (finish_struct): Change type of incorrect flexible array
697         field into error_mark_node.
698
699 2004-03-22  Andrew Pinski  <pinskia@physics.uc.edu>
700
701         PR target/14580
702         * config/rs6000/rs6000.c (symbol_ref_operand): Reject symbols
703         who are not local for Darwin PIC.
704
705 2004-03-22  Ulrich Weigand  <uweigand@de.ibm.com>
706
707         * regrename.c (regrename_optimize): Set regs_ever_live for all
708         registers introduced as replacement.
709
710 2004-03-22  Eric Botcazou  <ebotcazou@libertysurf.fr>
711
712         PR middle-end/14470
713         * expr.c (mark_queue): New function.
714         (emit_insns_enqueued_after_mark): New function replacing
715         emit_queue.  Clear the body of emitted queued insns.
716         (emit_queue): Call emit_insns_enqueued_after_mark.
717         (store_expr): Mark the increment queue on entry.  Emit
718         only the incrementations queued when expanding the source.
719
720 2004-03-22  Nathanael Nerode  <neroden@gcc.gnu.org>
721
722         * configure.ac: Allow --disable-coverage-flags (for the future benefit
723         of top level bootstrap, and consistency).  Reindent.
724         * configure: Regenerate.
725
726 2004-03-21  Kazu Hirata  <kazu@cs.umass.edu>
727
728         * bt-load.c, builtins.c, cfghooks.c, cfgrtl.c, gcse.c,
729         ggc-page.c, integrate.c, var-tracking.c, web.c: Remove
730         unnecessary casts.
731
732 2004-03-22  Danny Smith  <dannysmith@users.sourceforge.net>
733
734         PR target/14291
735         * gcov-io.h (gcov_truncate): Define ftruncate as _chsize for
736         __MINGW32__.
737
738 2004-03-21  Ulrich Weigand  <uweigand@de.ibm.com>
739
740         * config/s390/s390.md ("*doloop_si"): Change predicate for operand 2
741         to nonimmediate_operand.
742         ("*doloop_di"): Likewise.
743
744 2004-03-21  Alexandre Oliva  <aoliva@redhat.com>
745
746         * real.h (struct real_value): Use the same type for all
747         bitfields.  Rename exp to uexp.
748         (REAL_EXP, SET_REAL_EXP): New accessor macros for uexp.
749         Adjust all uses of exp...
750         * builtins.c: ... here, ...
751         * emit-rtl.c: ... here, and ...
752         * real.c: ... and here.
753
754 2004-03-21  Gabriel Dos Reis  <gdr@integrable-solutions.net>
755
756         * pretty-print.c (pp_base_maybe_space): New function.
757         * pretty-print.h (pp_base_maybe_space): Declare.
758         (pp_maybe_space): New macro.
759
760 2004-03-21  Ulrich Weigand  <uweigand@de.ibm.com>
761
762         * config/s390/s390.md ("addti3", "subti3"): New insns and splitters.
763
764 2004-03-21  Ulrich Weigand  <uweigand@de.ibm.com>
765
766         * expmed.c (choose_mult_variant): Pass MULT_COST as argument instead
767         of using register multiplication cost.
768         (expand_mult): Adapt choose_mult_variant call.
769         (expand_mult_highpart): Call choose_mult_variant with WIDER_MODE
770         of MODE; pass appropriate cost bound.  Adjust result when
771         performing signed multiplication by a negative constant.
772         Don't use intermediate modes larger than word_mode.
773
774 2004-03-21  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
775
776         * alias.c (get_alias_set): Remove handling of PLACEHOLDER_EXPR.
777         * emit-rtl.c (component_ref_for_mem_expr): Likewise.
778         (set_mem_attributes_minus_bitpos): Call SUBSTITUTE_PLACEHOLDER_IN_EXPR.
779         * explow.c (expr_size): Likewise.
780         * expr.h (placeholder_list, find_placeholder): Deleted.
781         * expr.c (store_constructor): Likewise.
782         (get_inner_reference): Likewise.  Also don't call find_placeholder.
783         (placeholder_list, find_placeholder): Deleted.
784         (is_aligning_offset): Don't handle WITH_RECORD_EXPR, PLACEHOLDER_EXPR.
785         (expand_expr_real, cases PLACEHOLDER_EXPR, WITH_RECORD_EXPR): Likewise.
786         (highest_pow2_factor, case WITH_RECORD_EXPR): Remove.
787         * dojump.c (do_jump, case WITH_RECORD_EXPR): Likewise.
788         * dwarf2out.c (loc_descriptor_from_tree, case WITH_RECORD_EXPR):
789         Likewise.
790         * fold-const.c (invert_truthvalue, case WITH_RECORD_EXPR): Likewise.
791         (extract_muldiv, case WITH_RECORD_EXPR): Likewise.
792         * tree.c (expr_align, case WITH_RECORD_EXPR): Likewise.
793         (contains_placeholder_p): Don't handle WITH_RECORD_EXPR.
794         Clean up by using first_rtl_op.
795         (substitute_in_expr): Use SUBSTITUTE_IN_EXPR for recursive call.
796         (substitute_placeholder_in_expr): New function.
797         * tree.def (WITH_RECORD_EXPR): Deleted.
798         * tree.h (SUBSTITUTE_IN_EXPR, SUBSTITUTE_PLACEHOLDER_IN_EXPR): New.
799         (substitute_placeholder_in_expr): New.
800
801 2004-03-21  Andrew Pinski  <pinskia@gcc.gnu.org>
802
803         * dojump.c (prefer_and_bit_test): Fix which part of
804         the and_test is replaced.
805
806 2004-03-21  Joseph S. Myers  <jsm@polyomino.org.uk>
807
808         * frontends.texi: Add missing line.
809
810 2004-03-21  Zack Weinberg  <zack@codesourcery.com>
811             Chris Devers  <cdevers@pobox.com>
812             Joseph S. Myers  <jsm@polyomino.org.uk>
813
814         * doc/frontends.texi: Rewrite.
815         * doc/gcc.texi: Update last modification date.
816
817 2004-03-21  Josef Zlomek  <zlomekj@suse.cz>
818
819         * cfgrtl.c (cfg_layout_redirect_edge_and_branch): Print the debug
820         message before redirecting the edge.
821
822 2004-03-20  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
823
824         * emit-rtl.c (set_mem_attributes_minus_bitpos): Set MEM_POINTER
825         flag.
826         * explow.c (force_not_mem): Set REG_POINTER flag according to
827         MEM_POINTER one.
828         * rtl.h (MEM_POINTER): New macro.
829         (struct rtx_def): Use integrated for MEM_SCALAR_P and frame_related
830         for MEM_POINTER.
831
832 2004-03-20  Roger Sayle  <roger@eyesopen.com>
833
834         PR target/13889
835         * cse.c (fold_rtx): Avoid substituting constants into unary
836         conversion operations.
837
838 2004-03-20  Kazu Hirata  <kazu@cs.umass.edu>
839
840         * fold-const.c (fold): Replace "expr" with "t".
841
842 2004-03-20  Ian Lance Taylor  <ian@wasabisystems.com>
843
844         PR c/12373
845         * c-typeck.c (tagged_types_tu_compatible_p): Don't use
846         DECL_ORIGINAL_TYPE if there isn't one.
847
848 2004-03-20  Kazu Hirata  <kazu@cs.umass.edu>
849
850         * fold-const.c (fold): Replace "final_type" with "type".
851         Remove variable "final_type".
852
853 2004-03-20  Kazu Hirata  <kazu@cs.umass.edu>
854
855         * fold-const.c (fold): Constify "type".
856         Replace "TREE_TYPE (t)" with "type".
857
858 2004-03-20  Kazu Hirata  <kazu@cs.umass.edu>
859
860         * bb-reorder.c, bt-load.c, c-decl.c, cfgcleanup.c, coverage.c,
861         dwarf2asm.c, ifcvt.c, stor-layout.c, varasm.c: Replace calls
862         via (*targetm.foo) () with targetm.foo ().
863
864 2004-03-20  Joseph S. Myers  <jsm@polyomino.org.uk>
865
866         PR other/14630
867         * doc/install.texi: Add info directory category and entry.
868
869 2004-03-20  Kazu Hirata  <kazu@cs.umass.edu>
870
871         * fold-const.c (fold): Replace "t" with "tem" where it is used
872         as a temporary variable.  Remove "orig_t" and all of its uses.
873
874 2004-03-20  Kazu Hirata  <kazu@cs.umass.edu>
875
876         * fold-const.c (fold): Remove variable "invert".
877         Move the handling of relational expressions that can be folded
878         to a constant ...
879         (fold_relational_const): ... here.
880         (tree_expr_nonzero_p): New.
881
882 2004-03-20  Joseph S. Myers  <jsm@polyomino.org.uk>
883
884         PR c/14635
885         * builtins.def (nan, nanf, nanl, nans, nansf, nansl): Change to
886         DEF_GCC_BUILTIN.
887
888 2004-03-20  Richard Sandiford  <rsandifo@redhat.com>
889
890         * Makefile.in (dojump.o): Depend on $(GGC_H) and dojump.h.
891         (GTFILES): Add $(srcdir)/dojump.h.
892         (gt-dojump.h): New dependency.
893         * dojump.c (and_reg, and_test, shift_test): New static variables.
894         (prefer_and_bit_test): New function.
895         (do_jump): Use it to choose between (X & (1 << C)) and (X >> C) & 1.
896
897 2004-03-20  Kazu Hirata  <kazu@cs.umass.edu>
898
899         * c-common.c, cfgcleanup.c, cgraphunit.c, c-pretty-print.c,
900         expmed.c, ggc-common.c, jump.c, passes.c, recog.c, regmove.c,
901         reorg.c, tree.h: Fix comment typos.
902
903 2004-03-19  Kazu Hirata  <kazu@cs.umass.edu>
904
905         * alias.c, attribs.c, bt-load.c, builtins.c, c-common.c,
906         c-decl.c, c-objc-common.c, c-typeck.c, calls.c, cfglayout.c,
907         cse.c, dbxout.c, dwarf2out.c, except.c, final.c,
908         haifa-sched.c, integrate.c, passes.c, rtlanal.c, sched-rgn.c,
909         sched-vis.c, simplify-rtx.c, stor-layout.c, tree.c, varasm.c,
910         vmsdbgout.c: Replace calls via (*targetm.foo) () with
911         targetm.foo ().
912
913 2004-03-19  Ziemowit Laski  <zlaski@apple.com>
914
915         * config/rs6000/altivec.h (vec_dst, vec_dstst, vec_dststt,
916         vec_dstt, vec_sld, vec_splat): Add prototypes, marked with
917         always_inline attribute.
918         * config/rs6000/rs6000.c (altivec_expand_dst_builtin):
919         Treat expansion as completed even if literal argument is
920         invalid (so that other expansions are not tried in vain).
921
922 2004-03-19  Kazu Hirata  <kazu@cs.umass.edu>
923
924         * loop-doloop.c (add_test): Replace GEN_INT (0) with
925         const0_rtx.
926
927 2004-03-19  Kazu Hirata  <kazu@cs.umass.edu>
928
929         * fold-const.c (fold) <ABS_EXPR>: Move the handling of constants
930         ...
931         (fold_abs_const): ... here.
932
933 2004-03-19  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
934
935         * tree.h (TYPE_ARRAY_MAX_SIZE): Use type.maxval directly.
936
937 2004-03-19  Denis Chertykov  <denisc@overta.ru>
938
939         PR target/11520
940         * config/avr/avr.md ("call_insn"): Handle explicit integer
941         specially.
942         (call_value_insn): Likewise.
943
944 2004-03-19  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
945
946         * tree.c (substitute_in_expr): Rewrite to simplify and be more generic.
947
948 2004-03-19  Kazu Hirata  <kazu@cs.umass.edu>
949
950         * fold-const.c (negate_expr): Move the handling of constants
951         ...
952         (fold_negate_const): ... here.
953
954 2004-03-19  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
955
956         * langhooks-def.h (LANG_HOOKS_HASH_TYPES): New macro and hook.
957         * langhooks.h (struct lang_hooks_for_types): New field hash_types.
958         * tree.c (debug_no_type_hash): Deleted.
959         (type_hash_canon): Abort if passed a variant.
960         Check lang_hooks.types.hash_types.
961         (build_type_no_quals): Copy mode of POINTER_TYPE and REFERENCE_TYPE.
962         (build_array_type): Remove unnecessary allocation of pointer type.
963         (build_complex_type): Properly qualify resulting type.
964
965 2004-03-19  Paolo Bonzini  <bonzini@gnu.org>
966
967         * config/rs6000/rs6000.c (rs6000_init_builtins): Fix typo.
968
969 2004-03-19  Richard Sandiford  <rsandifo@redhat.com>
970
971         * expmed.c (choose_mult_variant, expand_mult_const): New, split from...
972         (expand_mult): ...here.
973         (extract_high_half): New, split out from expand_mult_highpart.
974         (expand_highpart_optab): Likewise.  Don't clobber target prematurely.
975         (expand_highpart): Evaluate the cost of a shift/add sequence,
976         then see if any of the specialized optabs are cheaper.
977
978 2004-03-18  Ian Lance Taylor  <ian@wasabisystems.com>
979
980         * mklibgcc.in: Remove obsolete MAYBE_USE_COLLECT2.
981
982 2004-03-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
983
984         * convert.c (convert_to_real): Add more math builtins.
985
986 2004-03-18  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
987
988         * convert.c (convert_to_real): Reformat using switch stmt.
989
990 2004-03-18  Mark Mitchell  <mark@codesourcery.com>
991
992         * c-common.c (pointer_int_sum): Do not complain about using
993         pointers to pointers-to-members.
994
995 2004-03-18  Kazu Hirata  <kazu@cs.umass.edu>
996
997         * system.h (MD_ASM_CLOBBERS): Move to "Old target macros that
998         have moved to the target hooks structure".
999
1000 2004-03-18  James E Wilson  <wilson@specifixinc.com>
1001
1002         * config/mips/mips.md (type): Split move into arith and fmove.  Split
1003         hilo into mthilo and mfhilo.  Add trap.  Delete icmp.  Fix all uses.
1004         * config/mips/5400.md (ir_vr54_hilo, ir_vr54_arith, ir_vr54_fabs):
1005         Likewise.
1006         * config/mips/5500.md (ir_vr55_hilo, ir_vr55_arith, ir_vr55_fabs):
1007         Likewise.
1008         * config/mips/7000.md (rm7_int_other, rm7_mthilo, rm7_mfhilo,
1009         rm7_fp_quick): Likewise.
1010         * config/mips/9000.md (rm9k_int, rm9k_mfhilo, rm9k_mthilo,
1011         rm9k_fquick): Likewise.
1012         * config/mips/sr71k.md (ir_sr70_hilo, ir_sr70_arith, ir_sr70_fabs):
1013         Likewise.
1014         (ir_sr70_icmp): Delete.
1015
1016 2004-03-18  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
1017
1018         * tree.h (TREE_CHECK2, TREE_CHECK3, TREE_CHECK5): New macros.
1019         (tree_check2_failed, tree_check3_failed, tree_check5_failed): New decl.
1020         (FUNC_OR_METHOD_CHECK, SET_ARRAY_OR_VECTOR_CHECK): New macros.
1021         (REC_OR_UNION_CHECK, NUMERICAL_TYPE_CHECK): Likewise.
1022         (TYPE_VALUES, TYPE_DOMAIN, TYPE_FIELDS, TYPE_METHODS, TYPE_VFIELD):
1023         Protect with proper check.
1024         (TYPE_ARG_TYPES, TYPE_METHOD_BASETYPE, TYPE_OFFSET_BASETYPE): Likewise.
1025         (TYPE_MIN_VALUE, TYPE_MAX_VALUE): Likewise.
1026         * tree.c (type_hash_eq): Rewrite to access proper fields for each type.
1027         (tree_check2_failed, tree_check3_failed, tree_check5_failed): New.
1028         * c-typeck.c (build_array_ref): Use TYPE_DOMAIN, not TYPE_VALUES.
1029         * dwarf2out.c (gen_enumeration_type_die): Use TYPE_VALUES,
1030         not TYPE_FIELDS.
1031         * stor-layout.c (set_sizetype): Use TYPE_ORIG_SIZE_TYPE.
1032
1033 2004-03-18  Mostafa Hagog  <mustafa@il.ibm.com>
1034
1035         * gcse.c (eliminate_partially_redundant_loads): Reject change if
1036         dest is set between beginning and current insn.
1037
1038 2004-03-18  Mark Mitchell  <mark@codesourcery.com>
1039
1040         * c-decl.c (grokdeclarator): Do not complain about redeclaring
1041         visible "static" identifiers "extern" in a local scope.
1042         * dwarf2out.c (loc_descriptor_from_tree): Handle pre- and
1043         post-increments/decrements.
1044
1045 2004-03-18  Bob Wilson  <bob.wilson@acm.org>
1046
1047         * config/xtensa/xtensa.c (current_function_arg_words): Delete.
1048         (xtensa_builtin_saveregs): Use current_function_args_info.arg_words.
1049         (xtensa_va_start): Remove assignment to current_function_arg_words.
1050
1051 2004-03-18  Richard Sandiford  <rsandifo@redhat.com>
1052
1053         * alias.c (record_set): Detect the case where a register is assigned
1054         a new value that has the same base term as the old one.
1055
1056 2004-03-18  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
1057
1058         * doloop.c: Removed.
1059         * loop-doloop.c: New file.
1060         * Makefile.in (doloop.o): Remove.
1061         (loop-doloop.o): New.
1062         * cfgloop.h (get_loop_level, doloop_optimize_loops): Declare.
1063         * cfgloopanal.c (get_loop_level): New function.
1064         * loop-iv.c (iv_number_of_iterations): Handle case when loop
1065         is leaved immediatelly.
1066         * loop.c (strength_reduce): Do not call doloop optimization.
1067         * loop.h (LOOP_BCT): Removed.
1068         * passes.c (rest_of_handle_loop_optimize): Do not use LOOP_BCT.
1069         (rest_of_handle_loop2): Call doloop_optimize_loops.
1070         (rest_of_compilation): Test for optimizations moved to
1071         rest_of_handle_loop2.
1072
1073 2004-03-17  Fariborz Jahanian <fjahanian@apple.com>
1074
1075         * config/rs6000/rs6000.c (rs6000_stack_info): correct reg_size
1076         for mixed mode.
1077         (rs6000_emit_prologue): Ditto.
1078         (rs6000_emit_epilogue): Ditto.
1079         * config/rs6000/rs6000.h: Definition of DWARF_CIE_DATA_ALIGNMENT
1080         macro for mixed mode.
1081
1082 2004-03-18  Jan Hubicka  <jh@suse.cz>
1083
1084         * predict.c (propagate_freq): Compute correctly frequency of
1085         EXIT_BLOCK.
1086
1087 2004-03-17  Eric Christopher  <echristo@redhat.com>
1088
1089         * builtins.c (apply_args_size): Use reg_raw_mode.
1090         (apply_result_size): Ditto.
1091
1092 2004-03-17  Ralf Corsepius <corsepiu@faw.uni-ulm.de>
1093
1094         PR target/14620
1095         * config/rtems.h: Add STD_LIB_SPEC and LIB_SPEC.
1096
1097 2004-03-17  Jakub Jelinek  <jakub@redhat.com>
1098
1099         * config/rs6000/t-linux64 (bispecs): Don't add -mlong-double-128 for
1100         32-bit builds when defaulting to 32-bit.
1101
1102 2004-03-17  Jan Hubicka  <jh@suse.cz>
1103
1104         * cfgrtl.c (rtl_create_basic_block): Pre-allocate basic_block_info
1105         array.
1106
1107 2004-03-17  James E Wilson  <wilson@specifixinc.com>
1108
1109         * config/mips/mips.md (zero_extendsidi2): Add length attribute.
1110         (hazard_nop): Change type to nop.
1111         (type): Split arith into arith, shift, slt, clz.  Delete darith.
1112         Fix all uses.  Change arith to multi if more than one insn emitted.
1113         * config/mips/5400.md (ir_vr54_arith): Likewise.
1114         * config/mips/5500.md (ir_vr55_arith): Likewise.
1115         * config/mips/7000.md (rm7_int_other): Likewise.
1116         * config/mips/9000.md (rm9k_int): Likewise.
1117         * config/mips/sr71k.md (ir_sr70_arith): Likewise.
1118
1119 2004-03-17  Joel Brobecker  <brobecker@gnat.com>
1120
1121         * dwarf2out.c (subrange_type_die): Define new variable "subtype"
1122         to hold the subtype tree instead of recomputing it several times.
1123
1124 2004-03-17  Kazu Hirata  <kazu@cs.umass.edu>
1125
1126         * config/mn10300/mn10300.c (notice_update_cc): Don't handle
1127         CC_INVERT.
1128         * config/mn10300/mn10300.md (cc): Remove "invert".
1129
1130 2004-03-16  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1131
1132         * builtins.c (integer_valued_real_p): Add builtin rint.
1133         (fold_builtin): Likewise.
1134         * convert.c (convert_to_real): Likewise.
1135
1136         * convert.c (convert_to_real): Fix typos in `long double'
1137         builtins.
1138
1139 2004-03-16  Mark Mitchell  <mark@codesourcery.com>
1140
1141         PR c++/14481
1142         * fold-const.c (fold): Set TREE_NO_UNUSED_WARNING on implicitly
1143         generated COMPOUND_EXPRs.
1144
1145 2004-03-16  Ralf Corsepius <corsepiu@faw.uni-ulm.de>
1146
1147         * config/h8300/t-rtems (h8300-*-rtems*): New.
1148
1149 2004-03-16  Eric Christopher  <echristo@redhat.com>
1150
1151         * doc/cppopts.texi(fwide-exec-charset): Fix typo.
1152
1153 2004-03-16  Kazu Hirata  <kazu@cs.umass.edu>
1154
1155         * config/i386/i386-protos.h: Add a prototype for
1156         ix86_reverse_condition.
1157         * config/i386/i386.c (ix86_reverse_condition): New.
1158         * config/i386/i386.h (REVERSE_CONDITION): Use
1159         ix86_reverse_condition.
1160         * config/i386/i386.md: Use ix86_reverse_condition instead of
1161         REVERSE_CONDITION.
1162
1163 2004-03-16  J. Brobecker  <brobecker@gnat.com>
1164
1165         * dwarf2out.c (loc_descriptor_from_tree): Add handling for MIN_EXPR.
1166
1167 2004-03-16  Nathanael Nerode  <neroden@gcc.gnu.org>
1168
1169         PR bootstrap/12974
1170         * Makefile.in: Pass $(INCLUDES) down to libgcc.mk explicitly.
1171
1172 2004-03-16  Paolo Bonzini  <bonzini@gnu.org>
1173
1174         * c-common.c (c_common_type_for_mode): Build vector types on
1175         demand.
1176         (handle_mode_attribute): Deprecate using the mode attribute
1177         to create vector types.  Fix indentation.
1178         (vector_type_node_list): Remove.
1179         (handle_vector_size_attribute): Create vector types on demand.
1180         Strip a NON_LVALUE_EXPR from the attribute if there is one.
1181         * c-typeck.c (comptypes): Make vector types compatible if they
1182         have the same underlying mode.
1183         (convert_for_assignment): Use comptypes to convert between
1184         vector types.
1185         * tree.c (build_common_tree_nodes_2): Do not create vector types.
1186         * config/arm/arm.c (arm_init_iwmmxt_builtins): Create necessary
1187         vector types.
1188         * tree.h: Remove vector types.
1189         * config/i386/i386.c (i386_init_mmx_sse_builtins): Likewise.
1190         * config/rs6000/rs6000.c (rs6000_init_builtins): Likewise.
1191         (V16QI_type_node, V2SI_type_node, V2SF_type_node, V4HI_type_node,
1192         V4SI_type_node, V4SF_type_node, V8HI_type_node): New globals.
1193         * doc/extend.texi (Vector Types): Document how to use the
1194         vector_size attribute to create vectors, rather than mode.
1195
1196         * config/arm/mmintrin.h: Use vector_size attribute, not mode.
1197         * config/i386/emmintrin.h: Likewise.
1198         * config/i386/mmintrin.h: Likewise.
1199         * config/i386/xmmintrin.h: Likewise.
1200         * config/sh/ushmedia.h: Likewise.
1201
1202 2004-03-16  Kazu Hirata  <kazu@cs.umass.edu>
1203
1204         * config/freebsd-spec.h, config/arc/arc-protos.h,
1205         config/arm/aout.h, config/arm/elf.h, config/arm/freebsd.h,
1206         config/arm/linux-gas.h, config/arm/semi.h,
1207         config/cris/cris-protos.h, config/i386/xm-djgpp.h,
1208         config/ia64/freebsd.h, config/mips/7000.md,
1209         config/mips/9000.md, config/ns32k/ns32k-protos.h,
1210         config/sparc/pbd.h: Update copyright.
1211
1212 2004-03-16  Ralf Corsepius <corsepiu@faw.uni-ulm.de>
1213
1214         PR target/14577
1215         * config.gcc: Switch sh-*-rtems* to ELF.  Add sh-*-rtemscoff.
1216
1217 2004-03-16  Paolo Bonzini  <bonzini@gnu.org>
1218
1219         * combine.c (combine_simplify_rtx): Remove the "last"
1220         parameter and its documentation.  Adjust recursive calls.
1221         (simplify_logical): Always perform the only simplification
1222         controlled by "last", if the simplified expression is
1223         actually different.
1224         (try_combine): Do not pass the "last" parameter to
1225         combine_simplify_rtx.
1226
1227 2004-03-16  Richard Sandiford  <rsandifo@redhat.com>
1228
1229         PR target/14599
1230         * config/mips/mips.md (UNSPEC_GP): New constant.
1231         * config/mips/mips.c (CONST_GP_P): Expect the CONST to contain
1232         an UNSPEC instead of (reg $gp).
1233         (mips16_gp_pseudo_reg): Change accordingly.
1234         (print_operand): Print $gp directly when handling CONST_GP_P.
1235
1236 2004-03-16  Richard Zidlicky  <rz@linux-m68k.org>
1237
1238         * config.gcc, config/m68k/linux.h: Implement with-cpu for m68k-linux.
1239         * longlong.h: Make code 68060 clean when compiling for m68060.
1240
1241 2004-03-16  Richard Zidlicky  <rz@linux-m68k.org>
1242
1243         * config/m68k/m68k.md: Fix constraints for bitfield instructions.
1244         * doc/md.texi: Clarify description of "i" constraint.
1245
1246 2004-03-15  James E Wilson  <wilson@specifixinc.com>
1247
1248         * config/mips/mips.md (type): Split load into load, fpload, fpidxload.
1249         Split store into store, fpstore, fpidxstore.  Fix all uses.
1250         * config/mips/5400.md (ir_vr54_load, ir_vr54_store, ir_vr54_fstore):
1251         Likewise.
1252         * config/mips/5500.md (ir_vr55_load, i5_vr55_store): Likewise.
1253         * config/mips/7000.md (rm7_ld, rm7_st): Likewise.
1254         * config/mips/9000.md (rm9k_load, rm9k_store): Likewise.
1255         * config/mips/sr71k.md (ir_sr70_load, ir_sr70_store, ir_sr70_fload,
1256         ir_sr70_fstore): Likewise.
1257
1258 2004-03-15  Richard Henderson  <rth@redhat.com>
1259
1260         PR middle-end/14535
1261         * except.c (collect_one_action_chain): Record action for cleanup
1262         outer of exception spec.
1263
1264 2004-03-15  Ian Lance Taylor  <ian@wasabisystems.com>
1265
1266         * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_use_address):
1267         Fix the check for abort and only do the mmap if we can.
1268
1269 2004-03-15  Eric Botcazou  <ebotcazou@act-europe.fr>
1270
1271         * config/sparc/sparc.h: Rework comments about the code model
1272         in 64-bit environment and the mode 'Pmode'.
1273         * doc/invoke.texi (SPARC options): Rework description of the
1274         different code models supported in 64-bit environment.
1275
1276 2004-03-15  Kazu Hirata  <kazu@cs.umass.edu>
1277
1278         * defaults.h (REVERSIBLE_CC_MODE): Define.
1279         * jump.c (reversed_comparison_code_parts): Don't check if
1280         REVERSIBLE_CC_MODE is defined.
1281
1282 2004-03-15  Kazu Hirata  <kazu@cs.umass.edu>
1283
1284         * c-incpath.c, c-incpath.h, c-pch.c, c.opt, cppexp.c,
1285         et-forest.h, genattr.c, ggc-none.c, hosthooks-def.h,
1286         hosthooks.h, params.h, ra-colorize.c, web.c,
1287         config/darwin-c.c, config/alpha/freebsd.h, config/arm/pe.c,
1288         config/avr/avr-protos.h, config/avr/avr.md,
1289         config/fr30/fr30-protos.h, config/fr30/fr30.md,
1290         config/h8300/fixunssfsi.c, config/i386/darwin.h,
1291         config/i386/freebsd.h, config/i386/freebsd64.h,
1292         config/ia64/hpux.h, config/ia64/unwind-ia64.c,
1293         config/ip2k/libgcc.S, config/m32r/xm-m32r.h,
1294         config/mmix/mmix-modes.def, config/ns32k/netbsd.h,
1295         config/ns32k/ns32k.md, config/pa/pa64-hpux.h,
1296         config/pa/pa64-regs.h, config/rs6000/aix41.h,
1297         config/rs6000/aix43.h, config/rs6000/host-darwin.c,
1298         config/sparc/aout.h, config/sparc/freebsd.h,
1299         config/sparc/litecoff.h, config/vax/vax-protos.h,
1300         doc/hostconfig.texi, doc/include/gcc-common.texi: Update
1301         copyright.
1302
1303 2004-03-15  Paul Brook  <paul@codesourcery.com>
1304
1305         * config/arm/arm.c (thumb_expand_prologue): Tie prologue insns to fp.
1306
1307 2004-03-15  Gabriel Dos Reis  <gdr@integrable-solutions.net>
1308
1309         * c-pretty-print.c (pp_c_semicolon): Fix formatting.
1310         (pp_c_cv_qualifier): Document.
1311         (pp_c_space_for_pointer_operator): Likewise.
1312         (pp_c_integer_constant): Likewise.
1313         (pp_c_identifier): Likewise.
1314         (pp_c_init_declarator): Don't print function body.
1315
1316 2004-03-14  Joseph S. Myers  <jsm@polyomino.org.uk>
1317
1318         * doc/contrib.texi, doc/extend.texi, doc/gcov.texi,
1319         doc/install.texi, doc/invoke.texi, doc/makefile.texi,
1320         doc/sourcebuild.texi, doc/tm.texi, doc/trouble.texi: Capitalize
1321         "gcc", "g++" and "g77" or mark up with appropriate markup.  Adjust
1322         wording and grammar.
1323
1324 2004-03-14  Roger Sayle  <roger@eyesopen.com>
1325
1326         * alias.c (get_alias_set): Replace calls via (*lang_hooks.foo) ()
1327         with lang_hooks.foo ().
1328         * builtins.c (expand_builtin_va_arg): Likewise.
1329         * c-common.c (fname_as_string, c_common_truthvalue_conversion,
1330         c_common_type_for_mode, c_common_nodes_and_builtins,
1331         handle_mode_attribute, handle_vector_size_attribute): Likewise.
1332         * c-convert.c (convert): Likewise.
1333         * c-format.c (check_format_types): Likewise.
1334         * c-objc-common.c (c_tree_printer): Likewise.
1335         * c-typeck.c (build_unary_op, build_conditional_expr,
1336         build_binary_op): Likewise.
1337         * calls.c (try_to_integrate, expand_call,
1338         emit_library_call_value_1): Likewise.
1339         * cgraph.c (cgraph_node_name, cgraph_function_possibly_inlined_p):
1340         Likewise.
1341         * cgraphunit.c (record_call_1, cgraph_analyze_function,
1342         cgraph_expand_function): Likewise.
1343         * convert.c (convert_to_pointer, convert_to_integer): Likewise.
1344         * coverage.c (build_fn_info_type, build_ctr_info_type,
1345         build_gcov_info, create_coverage): Likewise.
1346         * dbxout.c (dbxout_init): Likewise.
1347         * diagnostic.c (diagnostic_report_current_function): Likewise.
1348         * dojump.c (do_jump): Likewise.
1349         * dwarf2out.c (dwarf2_name): Likewise.
1350         * except.c (init_eh): Likewise.
1351         * explow.c (expr_size, int_expr_size): Likewise.
1352         * expmed.c (make_tree, const_mult_add_overflow_p, expand_mult_add):
1353         Likewise.
1354         * expr.c (store_expr, store_constructor, safe_from_p,
1355         expand_expr_real, do_store_flag, try_casesi): Likewise.
1356         * function.c (push_function_context_to, pop_function_context_from,
1357         free_after_parsing, assign_stack_local_1, assign_stack_temp_for_type,
1358         put_var_into_stack, allocate_struct_function, current_function_name):
1359         Likewise.
1360         * integrate.c (copy_decl_for_inlining, expand_inline_function):
1361         Likewise.
1362         * langhooks.c (lhd_clear_binding_stack, write_global_declarations,
1363         lhd_print_error_function): Likewise.
1364         * opts.c (handle_option, decode_options): Likewise.
1365         * passes.c (open_dump_file): Likewise.
1366         * print-tree.c (print_node): Likewise.
1367         * stmt.c (expand_fixup, fixup_gotos, expand_asm_operands,
1368         expand_decl_cleanup, emit_case_nodes): Likewise.
1369         * stor-layout.c (variable_size): Likewise.
1370         * toplev.c (announce_function, wrapup_global_declarations,
1371         check_global_declarations, compile_file, default_tree_printer,
1372         process_options, lang_dependent_init, finalize): Likewise.
1373         * tree-dump.c (dequeue_and_dump): Likewise.
1374         * tree-inline.c (remap_decl, remap_block, copy_body_r,
1375         initialize_inlined_parameters, declare_return_variable,
1376         inlinable_function_p, expand_call_inline, optimize_inline_calls,
1377         walk_tree, copy_tree_r): Likewise.
1378         * tree-optimize.c (tree_rest_of_compilation): Likewise.
1379         * tree.c (decl_assembler_name, tree_size, size_in_bytes, staticp,
1380         unsafe_for_reeval, get_unwidened, get_narrower, get_callee_fndecl,
1381         variably_modified_type_p, dump_tree_statistics): Likewise.
1382         * varasm.c (assemble_variable, compare_constant, copy_constant,
1383         force_const_mem, compute_reloc_for_constant, output_constant,
1384         output_addressed_constants, initializer_constant_valid_p): Likewise.
1385
1386 2004-03-14  Kelley Cook  <kcook@gcc.gnu.org>
1387
1388         * doc/install.texi: Make autoconf 2.13 the exception, not the rule.
1389
1390 2004-03-14  Andreas Tobler  <a.tobler@schweiz.ch>
1391
1392         * doc/install.texi: Reflect autoconf and automake version for
1393         libffi. Update autoconf version to 2.59.
1394
1395 2004-03-13  Roger Sayle  <roger@eyesopen.com>
1396
1397         * fold-const.c (negate_expr, operand_equal_for_comparison_p,
1398         optimize_bit_field_compare, decode_field_reference, all_ones_mask_p,
1399         make_range, build_range_check, fold_range_test, unextend,
1400         constant_boolean_node, fold_binary_op_with_conditional_arg,
1401         fold_truthop, fold_mathfn_compare, fold_inf_compare,
1402         fold_single_bit_test, fold): Replace calls via (*lang_hooks.foo) ()
1403         with lang_hooks.foo ().
1404
1405 2004-03-14  Richard Earnshaw  <rearnsha@arm.com>
1406
1407         * arm.h (EXTRA_CONSTRAINT_STR_ARM): Update comment.
1408
1409 2004-03-13  Dara Hazeghi  <dhazeghi@yahoo.com>
1410
1411         * doc/install.texi: Note status of -fnew-ra.
1412
1413 2004-03-13  Eric Botcazou  <ebotcazou@libertysurf.fr>
1414
1415         PR middle-end/14470
1416         * expr.c (store_expr): Call emit_queue before generating the move
1417         from the temporary to the original target.  Protect the temporary
1418         from emit_queue.
1419
1420 2004-03-13  Jakub Jelinek  <jakub@redhat.com>
1421
1422         PR target/14533
1423         * config/s390/s390.c (legitimize_pic_address): Don't abort on UNSPEC
1424         other than UNSPEC_GOTOFF.
1425
1426 2004-03-13  Richard Earnshaw  <rearnsha@arm.com>
1427
1428         * arm.c (arm_legitimate_address_p): New argument, OUTER.  Pass through
1429         to arm_legitimate_index_p.  Update all callers with SET as default
1430         value.
1431         (arm_legitimate_index_p): New argument, OUTER.  Restrict the index
1432         range if OUTER is a sign-extend operation on QImode.  Correctly
1433         reject shift operations on sign-extended QImode addresses.
1434         (bad_signed_byte_operand): Delete.
1435         (arm_extendqisi_mem_op): New function.
1436         * arm.h (EXTRA_CONSTRAINT_ARM): Delete.  Replace with...
1437         (EXTRA_CONSTRAINT_STR_ARM): ... this.  Handle extended address
1438         constraints.
1439         (CONSTRAINT_LEN): New.
1440         (EXTRA_CONSTRAINT): Delete.  Replace with...
1441         (EXTRA_CONSTRAINT_STR): ... this.
1442         (PREDICATE_CODES): Remove bad_signed_byte_operand.
1443         * arm.md (extendqihi_insn): Use new constraint Uq.  Rework.  Length
1444         is now always default.
1445         (define_splits for bad sign-extend loads): Delete.
1446         (arm_extendqisi, arm_extendqisi_v5): Likewise.
1447         * arm/vfp.md (arm_movsi_vfp, arm_movdi_vfp, movsf_vfp, movdf_vfp):
1448         Rework 'U' constraint to 'Uv'.
1449         * arm-protos.h: Remove bad_signed_byte_operand.  Add
1450         arm_extendqisi_mem_op.
1451         * doc/md.texi (ARM constraints): Rename VFP constraint (now Uv).
1452         Add Uq constraint.
1453
1454 2004-03-13  Alan Modra  <amodra@bigpond.net.au>
1455
1456         * config/rs6000/rs6000.c (rs6000_va_arg): Replace SPLIT_COMPLEX_ARGS
1457         with targetm version.
1458
1459         PR target/14567
1460         * config/rs6000/rs6000.h (UNITS_PER_ARG, RS6000_ARG_SIZE): Delete.
1461         (HARD_REGNO_MODE_OK): Disallow TFmode for fp31.
1462         * config/rs6000/rs6000.c (rs6000_arg_size): New function.
1463         Update all users of RS6000_ARG_SIZE.
1464         (function_arg_advance): Count fregno using mode size.
1465         (function_arg): Handle long double split over regs and memory.
1466         (function_arg_partial_nregs): Likewise.
1467         (rs6000_va_arg): Repackage complex args.
1468
1469 2004-03-13  Dean Ferreyra <dferreyra@igc.org>
1470
1471         PR target/14047
1472         * config/avr/avr.c (avr_progmem_p): Add "attributes" parameter.
1473         (avr_insert_attributes): Pass "attributes" to avr_progmem_p.
1474         * config/avr/avr-protos.h (avr_progmem_p): Change prototype.
1475
1476 2004-03-12  Jakub Jelinek  <jakub@redhat.com>
1477
1478         * config/rs6000/rs6000-protos.h (rs6000_output_dwarf_dtprel): Add
1479         prototype.
1480         * config/rs6000/rs6000.c (rs6000_output_dwarf_dtprel): New.
1481         * config/rs6000/rs6000.h (ASM_OUTPUT_DWARF_DTPREL): Define.
1482
1483 2003-03-12  Andrew Pinski  <apinski@apple.com>
1484
1485         * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_use_address):
1486         Use ret instead of result. Use addr instead of base.
1487
1488 2004-03-12  David Edelsohn  <edelsohn@gnu.org>
1489
1490         * doc/install.texi (*-ibm-aix*): Document assembler and achiver
1491         fixes required by libstdc++ and update installation instructions
1492         for libstdc++.a.
1493
1494 2004-03-12  Danny Smith  <dannysmith@users.sourceforge.net>
1495
1496         * config/i386/winnt.c (i386_pe_strip_name_encoding_full): Strip
1497         leading '@' on fastcall symbols before stripping suffix.
1498
1499 2004-03-12  Roger Sayle  <roger@eyesopen.com>
1500
1501         * combine.c (unmentioned_reg_p): New function to check whether an
1502         expression is a "specialization" of another, i.e. that there are
1503         no registers or memory references mentioned in the first that don't
1504         appear in the second.
1505         (unmentioned_reg_p_1): New helper subroutine of unmentioned_reg_p.
1506         (combine_instructions): Also try combining instructions using the
1507         REG_EQUAL note from a preceding log-linked instruction.
1508
1509 2004-03-12  Roger Sayle  <roger@eyesopen.com>
1510
1511         * config/i386/i386.c (ix86_split_ashrdi): Optimize shift by 63.
1512
1513 2004-03-12  Matt Austern  <austern@apple.com>
1514
1515         * target.h (struct gcc_target): New target hook, unwind_label.
1516         * target-def.h (TARGET_ASM_EMIT_UNWIND_LABEL): New hook.
1517         * output.h (default_emit_unwind_label): New function.
1518         * default.h (TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY): New macro.
1519         (TARGET_USES_WEAK_UNWIND_INFO): New target macro.
1520         (TARGET_SUPPORTS_HIDDEN): New target macro.
1521         * dwarf2out.c (struct dw_fde_struct): Add field for function decl
1522         that corresponds to this FDE.
1523         (FRAME_BEGIN_LABEL): Allow target to override default label.
1524         (output_call_frame_info): If FDEs are linknonce, then use extra
1525         indirection for FDE encoding, output a label for each FDE, and
1526         output an empty label for each function without an FDE.
1527         (dwarf2out_begin_prologue): Set up decl field when creating an FDE.
1528         * varasm.c (globalize_decl): Call ASM_MAKE_LABEL_LINKONCE for
1529         decls with DECL_ONE_ONLY set, if that macro is defined.
1530         (make_decl_one_only): Don't use DECL_COMMON if we're compiling
1531         for a SUPPORTS_ONE_ONLY target.
1532         * config/darwin-protos.h (darwin_unique_section): Declare.
1533         (darwin_asm_named_section): Likewise.
1534         (darwin_section_type_flags): Likewise.
1535         (darwin_non_lazy_pcrel): Likewise.
1536         (darwin_emit_unwind_label): Likewise.
1537         (darwin_make_decl_one_only): Likewise.
1538         * config/darwin.c (machopic_finish): Get rid of tweak that
1539         eliminate stubs for symbols that are defined.
1540         (darwin_encode_section_info): Don't treat weak functions as defined.
1541         (darwin_make_decl_one_only): Define.
1542         (darwin_asm_named_section): Likewise.
1543         (darwin_section_type_flags): Likewise.
1544         (darwin_unique_section): Likewise.
1545         (darwin_emit_unwind_label): Likewise.
1546         (darwin_non_lazy_pcrel): Likewise.
1547         (darwin_asm_output_dwarf_delta): Difference between two labels is
1548         local only if both labels are local.
1549         * config/darwin.h (MAKE_DECL_ONE_ONLY): Define.
1550         (ASM_MAKE_LABEL_LINKONCE): Likewise.
1551         (TARGET_SUPPORTS_HIDDEN): Likewise.
1552         (TARGET_USES_WEAK_UNWIND_INFO): Likewise.
1553         (TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY): Likewise.
1554         (FRAME_BEGIN_LABEL): Likewise.
1555         (ASM_DECLARE_OBJECT_NAME): Make references to weak symbols indirect.
1556         (ASM_DECLARE_FUNCTION_NAME): Likewise.
1557         (darwin_eh_frame_section): Give __eh_frame section the coalesced flag.
1558         (TARGET_ASM_UNIQUE_SECTION): Define.
1559         (EH_FRAME_SECTION_NAME): Define.
1560         (EH_FRAME_SECTION_ATTR): Likewise.
1561         (ASM_MAYBE_OUTPUT_ENCODED_ADDR_RTX): Likewise.
1562         (TARGET_ASM_NAMED_SECTION): Likewise.
1563         (TARGET_SECTION_TYPE_FLAGS): Likewise.
1564         * doc/tm.texi: Document TARGET_USES_WEAK_UNWIND_INFO,
1565         TARGET_EXPLICIT_INSTANTIATIONS_ONE_ONLY, TARGET_SUPPORTS_HIDDEN,
1566         TARGET_ASM_EMIT_UNWIND_LABEL.
1567
1568 2004-03-12  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1569
1570         * builtins.c (expand_builtin_mathfn): Add pow10* to the
1571         existing exp10* case.
1572         (expand_builtin): Likewise.
1573
1574 2004-03-12  Eric Botcazou  <ebotcazou@libertysurf.fr>
1575
1576         * doc/tm.texi (registers) <Values in Registers>: Add
1577         entry for REGMODE_NATURAL_SIZE.
1578
1579 2004-03-12  Richard Henderson  <rth@redhat.com>
1580
1581         PR target/14547
1582         * target.h (struct gcc_target): Move calls substructure before
1583         booleans.  Add split_complex_arg.
1584         * function.c (assign_parms, split_complex_args): Use it.
1585         * calls.c (expand_call): Likewise.
1586         (split_complex_values): Likewise.  Check for splittable types
1587         before allocating memory.
1588         (split_complex_types): Likewise.
1589         * system.h (SPLIT_COMPLEX_ARGS): Poison.
1590         * expr.h (SPLIT_COMPLEX_ARGS): Remove.
1591         * target-def.h (TARGET_SPLIT_COMPLEX_ARG): New.
1592         * config/alpha/alpha.c (alpha_split_complex_arg): New.
1593         (TARGET_SPLIT_COMPLEX_ARG): New.
1594         * config/alpha/alpha.h (SPLIT_COMPLEX_ARGS): Remove.
1595         * config/rs6000/rs6000.c (TARGET_SPLIT_COMPLEX_ARG): New.
1596         (rs6000_override_options): Zap it for non-AIX.
1597         (rs6000_function_value): Use targetm.calls.split_complex_arg.
1598         * config/rs6000/rs6000.h (SPLIT_COMPLEX_ARGS): Remove.
1599         * config/xtensa/xtensa.c (TARGET_SPLIT_COMPLEX_ARG): New.
1600         * config/xtensa/xtensa.h (SPLIT_COMPLEX_ARGS): Remove.
1601         * doc/tm.texi (TARGET_SPLIT_COMPLEX_ARG): Modify from old
1602         SPLIT_COMPLEX_ARGS entry.
1603
1604 2004-03-11  Richard Henderson  <rth@redhat.com>
1605
1606         * config/alpha/alpha.c (xfloating_ops, vax_cvt_ops): New.
1607         (alpha_lookup_xfloating_lib_func): Use them, return rtx.
1608         (alpha_emit_xfloating_arith): Update to match.
1609         (alpha_emit_xfloating_compare): Likewise.
1610         (alpha_emit_xfloating_cvt): Likewise.
1611         (alpha_emit_xfloating_libcall): Take already built symbol,
1612         mark call const.
1613         * config/alpha/alpha.md (extendsftf2, extenddftf2): Take
1614         op1 in a register.
1615
1616 2004-03-11  Richard Henderson  <rth@redhat.com>
1617
1618         PR target/14539
1619         * config/alpha/alpha.h (STACK_BOUNDARY): Set to 128.
1620
1621         * simplify-rtx.c (simplify_relational_operation): Fix typo.
1622
1623 2004-03-11  Richard Henderson  <rth@redhat.com>
1624
1625         PR middle-end/14477
1626         * except.c (remove_unreachable_regions): Look thru CALL_PLACEHOLDER.
1627
1628 2004-03-11  Ulrich Weigand  <uweigand@de.ibm.com>
1629
1630         PR target/14262
1631         * calls.c (load_register_parameters): If BLOCK_REG_PADDING is not
1632         defined, pass small BLKmode values in registers in the low-order part.
1633
1634 2004-03-11  Ulrich Weigand  <uweigand@de.ibm.com>
1635
1636         * combine.c (if_then_else_cond): Check for NULL return value of
1637         simplify_gen_subreg.
1638
1639 2004-03-11  Richard Sandiford  <rsandifo@redhat.com>
1640
1641         PR target/14496
1642         * config/mips/mips.h (UNITS_PER_FPVALUE): Fix value for
1643         TARGET_SINGLE_FLOAT.
1644
1645 2004-03-11  Steve Ellcey  <sje@cup.hp.com>
1646
1647         * config/ia64/hpux.h (TARGET_INIT_LIBFUNCS): Add undef.
1648         * config/ia64/ia64.h (TARGET_INIT_LIBFUNCS): Add define.
1649         * config/ia64/ia64.c (ia64_init_libfuncs): New.
1650         (ia64_hpux_init_libfuncs): Add call to ia64_init_libfuncs.
1651
1652 2004-03-11  Roger Sayle  <roger@eyesopen.com>
1653
1654         * fold-const.c (negate_expr_p) <RSHIFT_EXPR>: We can optimize
1655         -((int)X>>C) where C is an integer constant one bit less than the
1656         size of X into (unsigned)X>>C.  Similarly for unsigned->signed.
1657         (negate_expr) <RSHIFT_EXPR>: Implement the above transformations.
1658
1659         * simplify-rtx.c (simplify_unary_operation): Also implement the
1660         above transformations at the RTL level.
1661
1662 2004-03-11  Alan Modra  <amodra@bigpond.net.au>
1663
1664         * real.c (encode_ibm_extended): Do round low word.
1665
1666 2004-03-11  Ben Elliston  <bje@wasabisystems.com>
1667
1668         * config/arm/arm.md (is_xscale): Comment this attribute and move
1669         it a bit further up in the file, closer to related attributes.
1670
1671 2004-03-11  Eric Botcazou  <ebotcazou@libertysurf.fr>
1672
1673         * config/host-solaris.c (sol_gt_pch_use_address): Add
1674         missing terminating marker to comment.
1675
1676 2004-03-11  Richard Sandiford  <rsandifo@redhat.com>
1677
1678         * config/mips/mips.md: Use move_operand in splitters for 64-bit moves.
1679         (movdi, movsi, movhi, movqi, movsf, movdf): Remove predicates.
1680         (*movdi_32bit_mips16, *movsi_mips16, *movhi_mips16, *movqi_mips16)
1681         (*movsf_mips16, *movdf_mips16):  Name unnamed patterns.  Use
1682         move_operand as source predicate in all cases.
1683         (*movdi_32bit): Renamed from movdi_internal.  Remove 'F' constraint.
1684         Test reg_or_0_operand.  Use move_operand as source predicate.
1685         (*movdi_64bit): Renamed from movdi_internal2.  Test reg_or_0_operand.
1686         (*movdi_64bit_mips16): Renamed from movdi_internal2_mips16.
1687         (*movsi_internal): Renamed from movsi_internal.  Test reg_or_0_operand.
1688         (movhi, movqi, movsf, movdf): Use mips_legitimize_move.
1689         (*movhi_internal): Renamed from movhi_internal.  Test reg_or_0_operand.
1690         Use move_operand as source predicate.  Remove 'K' constraint.
1691         (*movqi_internal): Likewise movqi_internal.
1692         (*movsf_hardfloat): Renamed from movsf_internal1.  Test
1693         reg_or_0_operand.  Use move_operand as source predicate.
1694         (*movsf_softfloat): Likewise movsf_internal2.
1695         (*movdf_hardfloat_64bit): Likewise movsf_internal1a.
1696         (*movdf_hardfloat_32bit): Likewise movsf_internal1b.
1697         (*movdf_softfloat): Likewise movdf_internal2.
1698         * config/mips/mips.c (move_operand): Match arbitrary CONST_INTs
1699         for DImode if !TARGET_64BIT.
1700         (mips_legitimize_move): Simplify accordingly.
1701
1702 2004-03-11  Josef Zlomek  <zlomekj@suse.cz>
1703
1704         PR/14362
1705         * var-tracking.c (struct variable_def): Added field refcount.
1706         (variable_htab_free): Decrease the refcount and delete variable
1707         only if there are no more references.
1708         (unshare_variable): New function.
1709         (vars_copy_1): Increase refcount instead of copying the variable.
1710         (variable_union): Share the variables where possible, unshare
1711         the variables if needed.
1712         (variable_different_p): Return false if var1 and var2 are
1713         the same structure.
1714         (variable_was_changed): Init the refcount of new variable.
1715         (set_frame_base_location): Unshare variable if needed.
1716         (set_variable_part): Init the refcount of new variable.
1717         Unshare the variables if needed.
1718         (delete_variable_part): Unshare the variables if needed.
1719         (emit_notes_for_differences_1): Init the refcount of new variable.
1720         (vt_add_function_parameters): Do not add function parameters to
1721         IN set of ENTRY_BLOCK_PTR because it is unused anyway.
1722         (vt_initialize): Do not add frame_base_decl to IN set of
1723         ENTRY_BLOCK_PTR because it is unused anyway.
1724
1725 2004-03-11  Josef Zlomek  <zlomekj@suse.cz>
1726
1727         * var-tracking.c (vars_copy_1): Cleanup and speedup chain operations.
1728         (vars_copy): Likewise.
1729         (variable_union): Likewise.
1730         (set_variable_part): Likewise.
1731         (delete_variable_part): Likewise.
1732
1733 2004-03-11  Kazu Hirata  <kazu@cs.umass.edu>
1734
1735         * c-typeck.c, combine.c, cse.c, dominance.c, et-forest.h,
1736         ggc-page.c, var-tracking.c, config/fp-bit.c, config/c4x/c4x.c,
1737         config/cris/cris.c, config/i386/ppro.md, config/i860/i860.c,
1738         config/i860/i860.h, config/m32r/m32r.h, config/m32r/xm-m32r.h,
1739         config/m68hc11/m68hc11.h, config/m68hc11/m68hc11.md,
1740         config/mips/mips.c, config/mmix/mmix.c, config/ns32k/ns32k.h,
1741         config/pa/pa.c, config/pa/pa32-regs.h, config/pa/pa64-regs.h,
1742         config/pdp11/pdp11.h, config/rs6000/rs6000.c,
1743         config/stormy16/stormy16.c: Fix comment typos and formatting.
1744
1745 2004-03-11  Nathanael Nerode  <neroden@gcc.gnu.org>
1746
1747         * configure: Regenerate, since I forgot to while committing Paolo's
1748         changes.
1749
1750 2004-03-08  Paolo Bonzini  <bonzini@gnu.org>
1751
1752         PR ada/14131
1753         Move language detection to the top level.
1754         * configure.ac: Remove code to detect languages,
1755         it now lives exclusively in the top level.
1756         * aclocal.m4 (gcc_AC_PROG_GNAT): Moved to the
1757         top level, renamed to ACX_PROG_GNAT.
1758
1759 2004-03-10  Richard Henderson  <rth@redhat.com>
1760
1761         * c-pch.c (c_common_no_more_pch): Update for gt_pch_use_address
1762         extra arguments.
1763         * config.host (*-*-solaris2*, *-*-linux*): Add out_host_hook_obj
1764         and host_xmake_file fragments.
1765         * ggc-common.c (gt_pch_save): Update for gt_pch_get_address change.
1766         (gt_pch_restore): Similarly for gt_pch_use_address.
1767         (default_gt_pch_get_address): New.
1768         (mmap_gt_pch_get_address): Split out of gt_pch_save.
1769         (default_gt_pch_use_address): Split out of gt_pch_restore.
1770         (mmap_gt_pch_use_address): Likewise.
1771         * hooks.c (hook_voidp_size_t_null): Remove.
1772         (hook_bool_voidp_size_t_false): Remove.
1773         * hooks.h: Likewise.
1774         * hosthooks-def.h (HOST_HOOKS_GT_PCH_GET_ADDRESS): Use one of the
1775         default_ or mmap_ definitions.
1776         (HOST_HOOKS_GT_PCH_USE_ADDRESS): Likewise.
1777         * hosthooks.h (struct host_hooks): Update gt_pch_get_address
1778         and gt_pch_use_address.
1779         * config/host-linux.c, config/host-solaris.c: New files.
1780         * config/x-linux, config/x-solaris: New files.
1781         * config/rs6000/host-darwin.c (darwin_rs6000_gt_pch_get_address):
1782         Update for changed definition.
1783         (darwin_rs6000_gt_pch_use_address): Likewise.
1784         * doc/hostconfig.texi: Update docs.
1785
1786 2004-03-10  Richard Henderson  <rth@redhat.com>
1787
1788         PR c/14517
1789         * c-decl.c (grokdeclarator): Don't warn for duplicate qualifiers
1790         except for pedantic c90 mode.
1791
1792 2004-03-10  Kelley Cook  <kcook@gcc.gnu.org>
1793
1794         * configure.ac: Bump AC_PREREQ to 2.59.
1795         * configure: Regenerate.
1796
1797 2004-03-10  Uros Bizjak  <uros@kss-loka.si>
1798
1799         * optabs.h (enum optab_index): Add new OTI_exp10 and OTI_exp2.
1800         (exp10_optab, exp2_optab): Define corresponding macros.
1801         * optabs.c (init_optabs): Initialize exp10_optab and exp2_optab.
1802         * genopinit.c (optabs): Implement exp10_optab and exp2_optab
1803         using exp10?f2 and exp2?f2 patterns.
1804         * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_EXP10{,F,L}
1805         using exp10_optab, and BUILT_IN_EXP2{,F,L} using exp2_optab.
1806         (expand_builtin): Expand BUILT_IN_EXP10{,F,L} and BUILT_IN_EXP2{,F,L}
1807         using expand_builtin_mathfn if flag_unsafe_math_optimizations is set.
1808
1809         * config/i386/i386.md (exp10sf2, exp10df2, exp10xf2, exp2sf2,
1810         exp2df2, exp2xf2): New patterns to implement exp10, exp10f, exp10l,
1811         exp2, exp2f and exp2l built-ins as inline x87 intrinsics.
1812
1813 2004-03-10  Anthony Green  <green@redhat.com>
1814
1815         * doc/invoke.texi (ARM Options): Fix -mpfu typo.
1816
1817 2004-03-10  David Edelsohn  <edelsohn@gnu.org>
1818
1819         * config/rs6000/aix.h (TARGET_OS_CPP_BUILTINS): Rename to ...
1820         (TARGET_OS_AIX_CPP_BUILTINS): this.  Conditionally define
1821         __LONGDOUBLE128.
1822         * config/rs6000/aix41.h (TARGET_OS_CPP_BUILTINS): Use
1823         TARGET_OS_AIX_CPP_BUILTINS.
1824         * config/rs6000/aix43.h (TARGET_OS_CPP_BUILTINS): Same.
1825         * config/rs6000/aix51.h (TARGET_OS_CPP_BUILTINS): Same.
1826         * config/rs6000/aix52.h (TARGET_OS_CPP_BUILTINS): Same.
1827         * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Revert
1828         previous change.
1829
1830 2004-03-10  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
1831
1832         * fold-const.c (tree_expr_nonnegative_p): Add more builtin cases.
1833
1834 2004-03-10  David Edelsohn  <edelsohn@gnu.org>
1835
1836         * config/rs6000/rs6000-c.c (rs6000_cpu_cpp_builtins): Define
1837         __LONGDOUBLE128 on AIX.
1838
1839 2004-03-10  Andrew Haley  <aph@redhat.com>
1840
1841         PR optimization/14381
1842         * function.c (expand_function_end): Emit a blockage insn before
1843         the epilogue when -fnon-call-exceptions is used.
1844
1845         * except.c (expand_start_all_catch): Make comment more accurate.
1846
1847 2004-03-08  Joel Sherrill  <joel@oarcorp.com>
1848
1849         PR target/14480
1850         * config/rs6000/t-rtems: Add missing file on branch.
1851
1852 2004-03-10  Ulrich Weigand  <uweigand@de.ibm.com>
1853
1854         * dbxout.c (dbxout_symbol_location): Do not output references
1855         to optimized-out constant pool symbols.
1856
1857 2004-03-10  Andreas Schwab  <schwab@suse.de>
1858
1859         * config/ia64/ia64.md (divsi3, udivsi3): Remove unused variable
1860         twon34_r.
1861
1862 2004-03-09  James E Wilson  <wilson@specifixinc.com>
1863
1864         * alias.c (alias_sets_might_conflict_p): New.
1865         * c-typeck.c (build_c_cast): Call it if warn_strict_aliasing > 1.
1866         * common.opt (Wstrict-aliasing=): New.
1867         * flags.h (warn_strict_aliasing): Change type to int.
1868         * opts.c (warn_strict_aliasing): Change type to int.
1869         (common_handle_option): Handle OPT_Wstrict_aliasing_.
1870         * tree.h (alias_sets_might_conflict_p): Declare it.
1871         * doc/invoke.tex (-Wstrict-aliasing=2): Document it.
1872
1873 2004-03-10  Roman Zippel  <zippel@linux-m68k.org>
1874
1875         PR bootstrap/12371
1876         * config/m68k/m68k.h (FIXED_REGISTERS): Add arg pointer.
1877         (CALL_USED_REGISTERS): Likewise.
1878         (REG_CLASS_CONTENTS): Likewise.
1879         (REG_ALLOC_ORDER): New.
1880         (REGNO_REG_CLASS): Use regno_reg_class.
1881         * config/m68k/m68k.c: Add regno_reg_class array.
1882
1883 2004-03-09  Steve Ellcey  <sje@cup.hp.com>
1884
1885         * config/ia64/ia64.md (divsi3): Fix algorithm.
1886           (udivsi3): Ditto.
1887           (setf_exp_xf): Remove '*' from name.
1888         * testsuite/gcc.dg/20040309-1.c: New test.
1889
1890 2004-03-09  Ian Lance Taylor  <ian@wasabisystems.com>
1891
1892         * system.h (SUNOS4_SHARED_LIBRARIES): Poison.
1893         * collect2.c: Remove SUNOS4_SHARED_LIBRARIES code.
1894         * config/sparc/aout.h (TARGET_ASM_SELECT_SECTION): Don't define.
1895         * config/sparc/sparc.c (sparc_aout_select_section): Remove.
1896         (sparc_aout_select_rtx_section): Don't check
1897         SUNOS4_SHARED_LIBRARIES.
1898         * config/sparc/sparc.h (SUNOS4_SHARED_LIBRARIES): Don't define.
1899
1900 2004-03-10  Hans-Peter Nilsson  <hp@axis.com>
1901
1902         PR other/14474
1903         * doc/md.texi (Pattern Ordering, Dependent Patterns)
1904         (Jump Patterns, Looping Patterns): Wrap in separate "@ifset
1905         INTERNALS".
1906
1907 2004-03-09  Zack Weinberg  <zack@codesourcery.com>
1908
1909         * config/ia64/hpux.h (MULTILIB_DEFAULTS): Define.
1910         (LIBGCC_SPEC): Update to match.
1911
1912 2004-03-09  Zack Weinberg  <zack@codesourcery.com>
1913
1914         * c-decl.c (last_function_parms, last_function_parm_tags)
1915         (last_function_parm_others, current_function_parms)
1916         (current_function_parm_tags, current_function_parm_others):
1917         Delete.
1918         (ARG_INFO_PARMS, ARG_INFO_TAGS, ARG_INFO_TYPES, ARG_INFO_OTHERS):
1919         New macros.
1920         (grokdeclarator): For function definitions, save the arg-info
1921         block from the declarator in DECL_ARGUMENTS.
1922         (grokparms): Do not write to last_function_parm*.  Use ARG_INFO_*
1923         macros to operate on arg-info block.  Can assume ARG_INFO_PARMS
1924         contains only PARM_DECLs.  Improve diagnostics.
1925         (get_parm_info): Use ARG_INFO_* macros.  Improve comments and
1926         diagnostics.  Disable some expensive checks if not ENABLE_CHECKING.
1927         (store_parm_decls_newstyle): Take the function to operate on,
1928         and an arg-info block, as arguments; don't get anything from
1929         current_function_* globals.
1930         (store_parm_decls_oldstyle): Likewise.
1931         (store_parm_decls): Pass fndecl and its arg-info block down to
1932         store_parm_decls_newstyle/oldstyle.  Send functions with empty
1933         argument lists through store_parm_decls_newstyle to reduce
1934         overhead.
1935         (pushdecl): Comment on the problems with the call to copy_node.
1936         Clear DECL_ARGUMENTS of the old node after copying it, if it
1937         is an arg-info block instead of a chain of decls.
1938         (start_function): Do not manipulate current_function_parm* or
1939         last_function_parm*.
1940
1941 2004-03-09  Roger Sayle  <roger@eyesopen.com>
1942             Andrew Pinski  <pinskia@physics.uc.edu>
1943
1944         * ifcvt.c (noce_try_sign_mask): New function to transform
1945         "x = (y < 0) ? z : 0" into the equivalent "x = (y >> C) & z".
1946         (noce_process_if_block): Call noce_try_sign_mask.
1947
1948 2004-03-09  Andrew Pinski  <apinski@apple.com>
1949
1950         * c-typeck.c (tagged_types_tu_compatible_p):
1951         Fix typo.
1952
1953 2004-03-09  Roger Sayle  <roger@eyesopen.com>
1954
1955         * simplify-rtx.c (simplify_const_relational_operation): New function
1956         renamed from simplify_relational_operation.
1957         (simplify_relational_operation): Change prototype to accept an
1958         additional mode argument.  Call simplify_const_relational_operation.
1959         (simplify_gen_relational): Update simplify_relational_operation call.
1960         (simplify_ternary_operation): Update simplify_relational_operation
1961         subroutine call to use simplify_const_relational_operation instead.
1962
1963         * rtl.h (simplify_const_relational_operation): Prototype here.
1964         (simplify_relational_operation): Add addtional mode argument.
1965
1966         * combine.c (combine_simplify_rtx): Update calls to
1967         simplify_relational_operation.
1968         (simplify_set): Likewise.
1969         (gen_binary): Likewise.
1970         * cse.c (fold_rtx): Likewise.
1971         * dojump.c (compare_from_rtx): Likewise.
1972         (do_compare_rtx_and_jump): Likewise.
1973         * integrate.c (subst_constants): Likewise.
1974         * unroll.c (simplify_cmp_and_jump_insns): Likewise.
1975
1976 2004-03-09  Kazu Hirata  <kazu@cs.umass.edu>
1977
1978         * config/m32r/m32r.md: Remove all define_peephole's.
1979
1980 2004-03-09  Alan Modra  <amodra@bigpond.net.au>
1981
1982         * config/rs6000/rs6000.md: Remove trailing whitespace.
1983
1984 2004-03-08  Eric Christopher  <echristo@redhat.com>
1985
1986         * Makefile.in (site.exp): Add libiconv variable definition.
1987
1988 2004-03-09  Hans-Peter Nilsson  <hp@axis.com>
1989
1990         * configure: Regenerate for config/accross.m4 correction.
1991
1992 2004-03-08  Joel Sherrill  <joel@oarcorp.com>
1993
1994         PR target/14480
1995         * config/rs6000/t-rtems: Add missing file on branch.
1996
1997 2004-03-08  Roger Sayle  <roger@eyesopen.com>
1998
1999         PR middle-end/14289
2000         * c-typeck.c (c_mark_addressable): A register variable should
2001         be considered global if its not automatic, i.e. TREE_PUBLIC,
2002         TREE_STATIC or DECL_EXTERNAL.
2003         * function.c (put_var_into_stack): Call abort when placing a
2004         hard register into the stack, if x_parm_reg_stack_loc is NULL.
2005
2006 2004-03-08  Ulrich Weigand  <uweigand@de.ibm.com>
2007
2008         * config/s390/s390.md ("*extendqidi2_short_displ"): Add CC clobber.
2009         ("*extendqisi2_short_displ"): Likewise.
2010
2011 2004-03-08  Kazu Hirata  <kazu@cs.umass.edu>
2012
2013         * config/pdp11/pdp11.c (comparison_operator_index): Remove.
2014         (comp_operator): Likewise.
2015         * config/pdp11/pdp11-protos.h: Remove corresponding
2016         prototypes.
2017
2018 2004-03-08  Eric Botcazou  <ebotcazou@act-europe.fr>
2019
2020         * expr.c (highest_pow2_factor_for_type): Rename into
2021         highest_pow2_factor_for_target.  Use DECL_ALIGN instead of
2022         TYPE_ALIGN when the target is a COMPONENT_REF.
2023         (expand_assignment): Ajust call to highest_pow2_factor_for_type.
2024
2025 2004-03-08  Alan Modra  <amodra@bigpond.net.au>
2026
2027         * config/rs6000/rs6000.c: Formatting fix.
2028         (legitimate_offset_address_p): Correct offset range check.
2029
2030         * config/rs6000/rs6000.c (rs6000_override_options): Don't override
2031         -msoft-float by -mcpu.  Consolidate similar code for MASK_MULTIPLE
2032         and MASK_STRING.
2033
2034 2004-03-07  Aldy Hernandez  <aldyh@redhat.com>
2035
2036         * config/rs6000/rs6000.md (ashrdi3): Do not call ashrdi3_no_power
2037         for little endian.
2038         ("ashrdi3_no_power"): Disable for little endian.
2039         (ashrdi3): Same.
2040
2041 2004-03-07  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2042
2043         * fold-const.c (tree_expr_nonnegative_p): Reformat checks for
2044         builtins.
2045
2046 2004-03-08  Hans-Peter Nilsson  <hp@axis.com>
2047
2048         PR target/14471
2049         * configure.ac (Target-specific assembler checks) <cris-*-*>: New
2050         case, checking for -no-mul-bug-abort option.
2051         * configure, config.in: Regenerate.
2052         * doc/invoke.texi (CRIS Options): Document -mmul-bug-workaround
2053         and -mno-mul-bug-workaround.
2054         * config/cris/cris.md ("smulsi3_highpart", "umulsi3_highpart")
2055         ("mulsidi3", "umulsidi3"): Prefix output template with "%!".
2056         ("umulhisi3", "umulqihi3", "mulsi3", "mulqihi3", "mulhisi3"):
2057         Ditto.  Make attribute "slottable" dependent on TARGET_MUL_BUG.
2058         * config/cris/mulsi3.asm (__Mul) [__CRIS_arch_version >= 10]: Make
2059         sure mulu.d is not last on cache-line.
2060         * config/cris/cris.h (ASM_SPEC): Translate -mno-mul-bug-workaround
2061         into -no-mul-bug-abort depending on HAVE_AS_MUL_BUG_ABORT_OPTION.
2062         (TARGET_MASK_MUL_BUG, TARGET_MUL_BUG): New macros.
2063         (TARGET_SWITCHES): New options -mmul-bug-workaround and
2064         -mno-mul-bug-workaround.
2065         (TARGET_DEFAULT): Include TARGET_MASK_MUL_BUG.
2066         (PRINT_OPERAND_PUNCT_VALID_P): Include '!'.
2067         * config/cris/cris.c (cris_operand_extend_operator): Clarify
2068         relation to MULT in head comment.
2069         (cris_op_str): Abort for MULT.
2070         (cris_print_operand) <case '!'>: New case.
2071
2072 2004-03-08  Alan Modra  <amodra@bigpond.net.au>
2073
2074         PR debug/11983
2075         * dwarf2out.c (enum dw_val_class): Rename dw_val_class_float to
2076         dw_val_class_vec.  Replace use throughout file.
2077         (dw_float_const): Delete.
2078         (dw_vec_const): New.
2079         (dw_val_struct_union): Rename val_float to val_vec.  Replace use
2080         throughout file.
2081         (add_AT_vec): Rename from add_AT_float.  Add elt_size param.
2082         (same_dw_val_p): Adjust vec comparison.  Use memcmp.
2083         (size_of_die): Adjust dw_val_class_vec sizing.
2084         (output_die): Output dw_val_class_vec.
2085         (insert_int, extract_int, insert_float): New functions.
2086         (add_const_value_attribute): Use insert_float for CONST_DOUBLE.
2087         Handle CONST_VECTOR.
2088         (add_location_or_const_value_attribute): Handle CONST_VECTOR.
2089
2090 2004-03-07  Aldy Hernandez  <aldyh@redhat.com>
2091
2092         * config/rs6000/rs6000.c (rs6000_parse_abi_options): SPE and
2093         AltiVec abi cannot co-exist.
2094
2095         * config/rs6000/eabispe.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Same.
2096
2097 2004-03-07  Jan Hubicka  <jh@suse.cz>
2098
2099         * except.c (emit_to_new_bb_before):  Break fallthru edges.
2100
2101 2004-03-07  Stephane Carrez  <stcarrez@nerim.fr>
2102
2103         * config/m68hc11/m68hc11.md ("*lshrsi3_const"): Disable for 68HC12.
2104         ("*lshrsi3"): Also accept an immediate for 68HC12.
2105         ("*ashrsi3_const"): Likewise.
2106         ("*ashrsi3"): Likewise.
2107         ("*ashlsi3_const"): Likewise.
2108         ("*ashlsi3"): Likewise.
2109         ("cmphi_1_hc12"): Compare two hard register by pushing them and
2110         comparing with a pop; don't use a split for that.
2111         ("cmphi split"): Disable compare split for 68HC12.
2112
2113         * config/m68hc11/m68hc11.c (m68hc11_notice_update_cc): Invalidate
2114         the status operands if they have side effects.
2115
2116 2004-03-07  Kazu Hirata  <kazu@cs.umass.edu>
2117
2118         * defaults.h (LEGITIMIZE_ADDRESS): Provide a default
2119         definition.
2120         * config/arc/arc.h, config/fr30/fr30.h, config/frv/frv.h,
2121         config/h8300/h8300.h, config/ia64/ia64.h,
2122         config/mcore/mcore.h, config/mmix/mmix.h,
2123         config/ns32k/ns32k.h, config/pdp11/pdp11.h,
2124         config/stormy16/stormy16.h, config/v850/v850.h,
2125         config/vax/vax.h (LEGITIMIZE_ADDRESS): Remove.
2126         * doc/tm.texi (LEGITIMIZE_ADDRESS): Mention the default
2127         definition.
2128
2129 2004-03-07  Roger Sayle  <roger@eyesopen.com>
2130
2131         * fold-const.c (fold) <IOR_EXPR>: Fold x | x as x.
2132         <XOR_EXPR>: Fold x ^ x as zero.
2133         <AND_EXPR>: Fold x & x as x.
2134
2135 2004-03-07  Roger Sayle  <roger@eyesopen.com>
2136
2137         * fold-const.c (fold) <EQ_EXPR>: Rewrite optimization to transform
2138         "foo++ == const" into "++foo == const+incr".
2139
2140 2004-03-07  Richard Sandiford  <rsandifo@redhat.com>
2141
2142         * config/mips/mips.c (mips_in_small_data_p): Return false if
2143         TARGET_ABICALLS.
2144
2145 2004-03-06  Stephane Carrez  <stcarrez@nerim.fr>
2146
2147         * config/m68hc11/m68hc11.c (m68hc11_gen_movhi): Use 2,-sp to push
2148         the stack register.
2149         (expand_prologue): Don't make an interrupt or a trap handler a far
2150         symbol.
2151         (m68hc11_initial_elimination_offset): Likewise.
2152
2153 2004-03-06  Richard Henderson  <rth@redhat.com>
2154
2155         * config/alpha/alpha.c (alpha_in_small_data_p): False for functions.
2156
2157 2004-03-06  Kazu Hirata  <kazu@cs.umass.edu>
2158
2159         * config/ns32k/ns32k-protos.h: Add a prototype for
2160         ns32k_notice_update_cc.
2161         * config/ns32k/ns32k.c (ns32k_notice_update_cc): New.
2162         * config/ns32k/ns32k.h (NOTICE_UPDATE_CC): Call
2163         ns32k_notice_update_cc.
2164
2165 2004-03-06  Ulrich Weigand  <uweigand@de.ibm.com>
2166
2167         * config/s390/s390.md ("load_multiple", "*load_multiple_di",
2168         "*load_multiple_si"): Allow only if reload_completed.
2169         ("store_multiple", "*store_multiple_di", "*store_multiple_si"):
2170         Likewise.
2171
2172 2004-03-06  Kazu Hirata  <kazu@cs.umass.edu>
2173
2174         * config/vax/vax-protos.h: Add a prototype for
2175         vax_notice_update_cc.
2176         * config/vax/vax.c (vax_notice_update_cc): New.
2177         * config/vax/vax.h (NOTICE_UPDATE_CC): Call
2178         vax_notice_update_cc.
2179
2180 2004-03-06  David Edelsohn  <edelsohn@gnu.org>
2181
2182         * collect2.c (main): Only export initfunc and finifunc if
2183         LD_INIT_SWITCH not defined.
2184         (scan_prog_file): Only export constructors and destructors if
2185         LD_INIT_SWITCH not defined.  Only export symbols not found in
2186         shared objects.
2187
2188 2004-03-06  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
2189
2190         * pa.md (icacheflush): Reorder operands to make match_scratch operand
2191         last.
2192         * pa.h (INITIALIZE_TRAMPOLINE): Remove unnecessary scratch argument
2193         from calls to gen_icacheflush.
2194
2195 2004-03-06  Richard Henderson  <rth@redhat.com>
2196
2197         * config/alpha/alpha.h (MASK_LONG_DOUBLE_128): New.
2198         (TARGET_LONG_DOUBLE_128): New.
2199         (TARGET_SWITCHES): Add long-double-{128,64}.
2200         (TARGET_HAS_XFLOATING_LIBS): Default to TARGET_LONG_DOUBLE_128.
2201         (LONG_DOUBLE_TYPE_SIZE): Honor TARGET_LONG_DOUBLE_128.
2202         (LIBGCC2_LONG_DOUBLE_TYPE_SIZE): New.
2203         (WIDEST_HARDWARE_FP_SIZE): New.
2204         (TARGET_CPU_CPP_BUILTINS): Define __LONG_DOUBLE_128__.
2205         * config/alpha/alpha.c (override_options): Clear MASK_LONG_DOUBLE_128
2206         if TARGET_VAX_FLOAT.
2207         * config/alpha/osf5.h (LONG_DOUBLE_TYPE_SIZE): Remove.
2208         (TARGET_DEFAULT): Set MASK_LONG_DOUBLE_128.
2209
2210 2004-03-06  Richard Henderson  <rth@redhat.com>
2211
2212         * config/alpha/alpha.c (alpha_swapped_comparison_operator): Fix
2213         botched rtx class conversion.
2214
2215 2004-03-06  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2216
2217         * tree.h (BUILTIN_EXP10_P, BUILTIN_EXPONENT_P, BUILTIN_SQRT_P,
2218         BUILTIN_CBRT_P, BUILTIN_ROOT_P): New macros.
2219
2220         * builtins.c (fold_builtin_logarithm, fold_builtin): Use new
2221         macros.
2222         * fold-const.c (fold_mathfn_compare, fold): Likewise.
2223
2224 2004-03-06  Eric Botcazou  <ebotcazou@libertysurf.fr>
2225
2226         PR target/14343
2227         * config/i386/i386.md (movv2di_internal): Conditionalize on
2228         TARGET_SSE, not TARGET_SSE2.
2229
2230 2004-03-05  Chris Demetriou  <cgd@broadcom.com>
2231
2232         * config.gcc (mips64orion-*-elf*, mips64orionel-*-elf*): Delete
2233         duplicated line.
2234
2235 2004-03-05  Kaveh R. Ghazi  <ghazi@caip.rutgers.edu>
2236
2237         * builtins.c: Consistently use logN not log* in comments.
2238
2239 2004-03-05  Andreas Krebbel  <krebbel1@de.ibm.com>
2240
2241         * rtl.h (mem_expr_equal_p): Function prototype added.
2242         * cfgcleanup.c (merge_memattrs): New function.
2243         (flow_find_cross_jump): Call merge_memattrs for matching insns.
2244         * emit-rtl.c (mem_expr_equal_p): New function.
2245
2246 2004-03-05  Ziemowit Laski  <zlaski@apple.com>
2247
2248         * objc/objc-act.c (synth_module_prologue): Const-qualify
2249         objc_selector type if using the GNU runtime; fix generated
2250         signatures for objc_msg_lookup and objc_msg_lookup_super
2251         to match what GNU ObjC headers provide; reformat and clean up.
2252         (synth_self_and_ucmd_args): Use previously constructed (and
2253         hence possibly const-qualified) objc_selector type.
2254
2255 2004-03-05  Kazu Hirata  <kazu@cs.umass.edu>
2256
2257         * doc/tm.texi (HARD_REGNO_RENAME_OK): Document.
2258
2259 2004-03-05  Jason Merrill  <jason@redhat.com>
2260
2261         * tree.h (TYPE_HASH): Use TYPE_UID.
2262         (TREE_HASH): New macro with old definition of TYPE_HASH.
2263         * tree.c (build_type_attribute_variant): Use iterative_hash_object.
2264         (build_array_type, build_function_type): Likewise.
2265         (build_method_type_directly): Likewise.
2266         (build_offset_type, build_complex_type): Likewise.
2267         (type_hash_list, attribute_hash_list): Likewise. Now static.
2268         * except.c: s/TYPE_HASH/TREE_HASH/.
2269
2270 2004-03-05  Bob Wilson  <bob.wilson@acm.org>
2271
2272         * config/xtensa/xtensa.c (function_arg): Handle 16-byte aligned args.
2273         (xtensa_va_start): Initialize __va_stk to ($arg_ptr - 32).  Adjust
2274         __va_ndx by 2 words when referencing an argument on the stack.
2275         (xtensa_va_arg): Handle 16-byte aligned args.  Adjust __va_ndx by 2
2276         words when an arg on the stack is first seen.
2277
2278 2004-03-05  Paul Brook  <paul@codesourcery.com>
2279
2280         * arm.h (ARM_FLAG_VFP): Remove.
2281         (ARM_FLAG_ATPCS, CIRRUS_FIX_INVALID_INSNS): Renumber.
2282         * netbsd-elf.h (ARM_FLAG_VFP): Remove.
2283
2284 2004-03-05  Paul Brook  <paul@codesourcery.com>
2285
2286         * function.c (assign_parms): Include pretend alignment offset.
2287
2288 2004-03-05  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
2289
2290         * stor-layout.c (layout_type, case FUNCTION_TYPE): Make size
2291         FUNCTION_BOUNDARY, not POINTER_SIZE * 2.
2292
2293 2004-03-05  Ian Lance Taylor  <ian@wasabisystems.com>
2294
2295         * configure.ac: When passing --enable-languages to subdir
2296         configure when host != build, make sure we don't pass an empty
2297         value.
2298         * configure: Regenerate.
2299
2300 2004-03-05  Nathan Sidwell  <nathan@codesourcery.com>
2301
2302         PR 13577
2303         * gcc.c (cc1_options): Robustify -auxbase-strip from multiple -o
2304         options.
2305
2306 2004-03-05  Paolo Bonzini  <bonzini@gnu.org>
2307
2308         * simplify-rtx.c (simplify_relational_operation): If
2309         flag_wrapv is set, do not move terms between the two
2310         side of a relational operator.
2311
2312 2004-03-05  Paolo Bonzini  <bonzini@gnu.org>
2313
2314         * rtlanal.c: Include target.h and output.h
2315         (rtx_cost, address_cost, default_address_cost): Move from...
2316         * cse.c (rtx_cost, address_cost, default_address_cost):
2317         ... this file.
2318         * rtl.h (rtx_cost, address_cost): Move under rtlanal.c.
2319         * Makefile.in: Adjust dependencies.
2320
2321 2004-03-05  Paolo Bonzini <bonzini@gnu.org>
2322
2323         * cse.c (cse_end_of_basic_block): Make static.
2324         * local-alloc.c (function_invariant_p): Move to
2325         reload1.c.
2326         * loop.c (libcall_other_reg, record_excess_regs):
2327         Make static.
2328         * reload1.c (function_invariant_p): Moved here
2329         from local-alloc.c, made static.
2330         * rtl.h (cse_end_of_basic_block, function_invariant_p,
2331         libcall_other_reg, record_excess_regs): Remove
2332         declarations.
2333
2334 2004-03-05  Kazu Hirata  <kazu@cs.umass.edu>
2335
2336         * config/m32r/m32r.c (signed_comparison_operator): Add a
2337         missing parenthesis.
2338
2339 2004-03-04  Ian Lance Taylor  <ian@wasabisystems.com>
2340
2341         * ggc-common.c (gt_pch_restore): Don't unmap addr unless we are
2342         going to call mmap again.  Read the file into the right place.
2343         Give a fatal error if we have to relocate.
2344
2345 2004-03-04  Bob Wilson  <bob.wilson@acm.org>
2346
2347         * config/xtensa/xtensa.c (xtensa_return_in_msb): New function.
2348         (TARGET_RETURN_IN_MSB): Define to xtensa_return_in_msb.
2349
2350 2004-03-05  Hans-Peter Nilsson  <hp@axis.com>
2351
2352         PR other/14354
2353         * config/fp-bit.c (_fpdiv_parts): Do not round when pack_d would
2354         round the same.  When rounding, clear bits that would cause a
2355         second rounding in pack_d.
2356         (_fpmul_parts): Ditto.  Remove #if 0:d code.
2357
2358 2004-03-04  Ziemowit Laski  <zlaski@apple.com>
2359
2360         PR c++/14425, c++/14426
2361         * config/rs6000/altivec.h (vec_splat_s8, vec_splat_s16,
2362         vec_splat_s32, vec_splat_u8, vec_splat_u16, vec_splat_u32):
2363         Change C++ definitions to accept a 'const int' argument;
2364         the prototypes already do.
2365         * config/rs6000/rs6000.c (rs6000_common_init_builtins):
2366         Rename v4si_ftype_char, v8hi_ftype_char, v16qi_ftype_char,
2367         v4sf_ftype_v4si_char, v4si_ftype_v4sf_char, v4si_ftype_v4si_char,
2368         v8hi_ftype_v8hi_char, v16qi_ftype_v16qi_char,
2369         v16qi_ftype_v16qi_v16qi_char, v8hi_ftype_v8hi_v8hi_char,
2370         v4si_ftype_v4si_v4si_char and v4sf_ftype_v4sf_v4sf_char to
2371         end in ..._int; change them to accept an int instead of a char
2372         as the last parameter.
2373
2374 2004-03-04  Phil Edwards  <phil@codesourcery.com>
2375
2376         * genmultilib:  Change '=' to '-' when translating option names
2377         to directory names.
2378
2379 2004-03-04  Richard Kenner  <kenner@vlsi1.ultra.nyu.edu>
2380
2381         * expr.c (expand_expr_real, case COMPONENT_REF): Get proper type of
2382         stack slot for temp used for result of BLKmode but in integral mode.
2383
2384 2004-03-04  Jan Hubicka  <jh@suse.cz>
2385
2386         * reload.c (find_reloads): Reorganize if seqeunce to switch.
2387
2388         * cfgrtl.c (rtl_redirect_edge_and_branch):  Set the source BB as dirty.
2389         (cfglayout_redirect_edge_and_branch):  Set the source BB as dirty.
2390
2391 2004-03-04  Steve Ellcey  <sje@cup.hp.com>
2392
2393         * config/ia64/ia64.md (divdf3_internal_thr): Fix algorithm.
2394         * testsuite/gcc.dg/20040303-1.c: New test.
2395
2396 2004-03-04  Steven Bosscher  <stevenb@suse.de>
2397
2398         * ppro.md: Rewrite as a DFA pipeline description.
2399         * i386.md: Remove all uses of the ppro_uops attribute.
2400         * i386.c: (ix86_safe_ppro_uops, ix86_dump_ppro_packet,
2401         ix86_reorder_insn, ix86_sched_reorder_ppro, ix86_sched_init,
2402         ix86_sched_reorder, ix86_variable_issue,
2403         struct ix86_sched_data, TARGET_SCHED_VARIABLE_ISSUE,
2404         TARGET_SCHED_INIT, TARGET_SCHED_REORDER): Remove.
2405         (ia32_use_dfa_pipeline_interface): Add TARGET_PENTIUMPRO.
2406         (ia32_multipass_dfa_lookahead): Add TARGET_PENTIUMPRO.
2407         * athlon.md (athlon_ssecmp_load): Fix comment
2408
2409 2004-03-04  Stuart Hastings  <stuart@apple.com>
2410
2411         * gcc/doc/invoke.texi: Document -mlongcall for Darwin/PPC.
2412
2413 2004-03-04  Stuart Hastings  <stuart@apple.com>
2414
2415         * gcc/config/i386/darwin.h: Darwin/x86 doesn't support CPUs before
2416         686, tell Darwin assembler to allow prefetch insns, non-empty def
2417         of SUBTARGET_OPTION_TRANSLATE_TABLE.
2418
2419 2004-03-04  DJ Delorie  <dj@redhat.com>
2420
2421         PR optimization/14282
2422         * sched-deps.c (sched_analyze_insn): Allow a stack adjustment
2423         between a call and the assignment of its return value.
2424
2425 2004-03-04  Kazu Hirata  <kazu@cs.umass.edu>
2426
2427         * config/h8300/h8300.c: Put a comment for every function.
2428
2429 2004-03-04  Kazu Hirata  <kazu@cs.umass.edu>
2430
2431         * config/h8300/h8300.md: Add comments about peephole2's.
2432
2433 2004-03-04  Steven Bosscher  <stevenb@suse.de>
2434
2435         * i386.h (TARGET_CPU_DEFAULT_nocona): Fix value.
2436
2437 2004-03-04  Jan Hubicka  <jh@suse.cz>
2438
2439         * cfgcleanup.c (thread_jump): Update call of cselib_init.
2440         * cselib.c (cselib_record_memory): New static variable.
2441         (cselib_lookup_mem, cselib_record_set, cselib_record_sets):
2442         Give up on memories when asked for.
2443         (cselib_init): Accept new argument.
2444         * cselib.h (cselib_init): Update prototype.
2445         * gcse.c (local_cprop_pass): Update call of cselib_init.
2446         * loop.c (load_mems): Update call of cselib_init.
2447         * postreload.c (reload_cse_regs_1): Update call of cselib_init.
2448         * sched-deps.c (sched_analyze): Update call of cselib_init.
2449
2450 2004-03-04  David Edelsohn  <edelsohn@gnu.org>
2451             GP <gp@qnx.com>
2452
2453         * config/rs6000/rs6000.c (output_function_profiler): Append @plt
2454         when compiling PIC.
2455
2456 2004-03-04  Josef Zlomek  <zlomekj@suse.cz>
2457
2458         PR/14362
2459         * var-tracking.c (track_expr_p): Do not track variables which
2460         should be ignored for debugging purposes.
2461
2462 2004-03-04  Alan Modra  <amodra@bigpond.net.au>
2463
2464         * real.c (encode_ibm_extended): Don't bother rounding low double.
2465         * c-cppbuiltin.c (builtin_define_float_constants): Tweak MAX
2466         when fmt->pnan < fmt->p.
2467
2468 2004-03-04  Eric Christopher  <echristo@redhat.com>
2469
2470         * config/mips/mips.h (FUNCTION_ARG_REGNO_P): Fix to check
2471         only range of valid arg registers and fixed_regs.
2472
2473 2004-03-04  Alan Modra  <amodra@bigpond.net.au>
2474
2475         PR target/14406
2476         * config/rs6000/rs6000.md (abstf2, abstf2+1): Delete define_insn.
2477         (abstf2, abstf2_internal): New define_expand.
2478
2479 2004-03-04  Eric Botcazou  <ebotcazou@libertysurf.fr>
2480
2481         PR optimization/14235
2482         * expr.c (convert_move): Copy the source to a new pseudo
2483         when converting from a sub-word source to a larger-than-word
2484         register which conflicts with the source.
2485
2486 2004-03-03  Zack Weinberg  <zack@codesourcery.com>
2487
2488         PR 13728
2489         * c-decl.c (diagnose_mismatched_decls): Issue an error for two
2490         parameters with the same name, unless one is a forward decl.
2491         Do not issue a redundant-redeclaration warning for forward
2492         decls of parameters.
2493
2494 2004-03-04  David Edelsohn  <edelsohn@gnu.org>
2495
2496         * doc/install.texi (*-ibm-aix*): Document use of Bash to speed up
2497         configuration.
2498
2499 2004-03-03  Ian Lance Taylor  <ian@wasabisystems.com>
2500
2501         * ggc-zone.c (ggc_pch_write_object): Don't align file pointer.
2502
2503 2004-03-04  Alan Modra  <amodra@bigpond.net.au>
2504
2505         * target-def.h (TARGET_OPTF): Delete.
2506         * c-opts.c (TARGET_OPTF): Define.
2507
2508 2004-03-04  Jan Hubicka  <jh@suse.cz>
2509
2510         * cselib.c (cselib_finish): Fix another miss-application of my previous
2511         patch.
2512
2513 2004-03-03  Mike Stump  <mrs@apple.com>
2514
2515         Add framework support for darwin.
2516
2517         * c-incpath.c: Include target.h and machmode.h.
2518         (add_path): Use a consistent style for cpp_dir.  Initialize
2519         p->construct to 0.
2520         (add_cpp_dir_path): New.
2521         (register_include_chains): Add use of extra_includes callback.
2522         (hook_void_int): Add.
2523         (target_c_incpath): Add.
2524         * c-incpath.h (add_cpp_dir_path): New.
2525         (target_c_incpath_s): Add.
2526         (target_c_incpath): Add.
2527         (C_INCPATH_INIT): Add.
2528         * c-opts.c (c_common_missing_argument,
2529         c_common_handle_option): Add -F argument processing.
2530         * c.opt: Add -F argument processing.
2531         * gcc.c (trad_capable_cpp): Add -F argument processing.
2532         * cppfiles.c (find_file_in_dir): Update to use construct
2533         callback.
2534         (search_path_exhausted, cpp_get_path, cpp_get_buffer,
2535         cpp_get_prev): New.
2536         (_cpp_find_file): Use search_path_exhausted.
2537         (make_cpp_dir): Initialize construct to 0.
2538         * cpplib.h (missing_header_cb
2539         cpp_get_path, cpp_get_buffer, cpp_get_file, cpp_get_prev): New.
2540         (cpp_callbacks): Add missing_header
2541         (cpp_dir): Add construct.
2542         * target-def.h: (TARGET_OPTF): New.
2543         * hooks.c (hook_void_int, hook_void_charptr): Add.
2544         * hooks.h (hook_void_int, hook_void_charptr): Add.
2545         * Makefile.in (c-incpath.o) : Add $(TARGET_H) and
2546         $(MACHMODE_H) dependencies.
2547         * doc/invoke.texi (Darwin Options): Document -F.
2548         * doc/tm.texi (TARGET_EXTRA_INCLUDES): Add.
2549         (TARGET_OPTF): Add.
2550         * fix-header.c (target_c_incpath): Add.
2551
2552         * config/darwin-c.c: Add c-incpath.h include.
2553         (using_frameworks, find_subframework_file,
2554         find_subframework_header, add_system_framework_path,
2555         frameworks_in_use, num_frameworks, max_frameworks,
2556         add_framework, find_framework, struct framework_header,
2557         framework_header_dirs, framework_construct_pathname,
2558         find_subframework_file, add_system_framework_path,
2559         add_framework_path, framework_defaults,
2560         darwin_register_frameworks, find_subframework_header): Add.
2561         * config/darwin.h (TARGET_EXTRA_INCLUDES, TARGET_OPTF): New.
2562         (TARGET_OPTION_TRANSLATE_TABLE): Add -framework support.
2563         (CPP_SPEC): Add __APPLE_CC__ support.
2564         * t-darwin (darwin-c.o): Add c-incpath.h dependency.
2565
2566 2004-03-04  Jan Hubicka  <jh@suse.cz>
2567
2568         * cselib.c (cselib_finish): Fix miss-application of my previous
2569         patch.
2570
2571 2004-03-03  Kazu Hirata  <kazu@cs.umass.edu>
2572
2573         * hooks.c (hook_tree_tree_identity): New.
2574         * hooks.h: Add a prototype for hook_tree_tree_identity.
2575         * stmt.c (expand_asm_operands): Use targetm.md_asm_clobbers
2576         instead of MD_ASM_CLOBBERS.
2577         * system.h (MD_ASM_CLOBBERS): Poison.
2578         * target-def.h (TARGET_MD_ASM_CLOBBERS): New.
2579         (TARGET_INITIALIZER): Add TARGET_MD_ASM_CLOBBERS.
2580         * target.h (gcc_target): Add md_asm_clobbers.
2581         * config/i386/i386.c (TARGET_MD_ASM_CLOBBERS): New.
2582         (ix86_md_asm_clobbers): New.
2583         * config/i386/i386.h (MD_ASM_CLOBBERS): Remove.
2584         * doc/tm.texi (MD_ASM_CLOBBERS): Change to
2585         TARGET_MD_ASM_CLOBBERS.
2586
2587 2004-03-03  Stuart Hastings  <stuart@apple.com>
2588
2589         * gcc/config.gcc: Arrange for Darwin/x86 to build libgcc_eh.a.
2590
2591 2004-03-03  Eric Botcazou  <ebotcazou@libertysurf.fr>
2592
2593         * config/sparc/sparc.c (noov_compare64_op): Fix typo.
2594
2595         * config/sparc/sparc.h (ASM_FLOAT): Delete.
2596         (ASM_DOUBLE): Likewise.
2597         (ASM_LONGDOUBLE): Likewise.
2598         * config/sparc/pbd.h (ASM_INT_OP): Delete.
2599
2600 2003-03-03  Richard Henderson  <rth@redhat.com>
2601
2602         PR opt/13862
2603         * cselib.c (cselib_record_sets): Don't record multiple sets in
2604         asm insns.
2605
2606 2004-03-03  Mostafa Hagog  <mustafa@il.ibm.com>
2607
2608         * common.opt: Add description of the new -fgcse-after-reload flag.
2609
2610         * flags.h (flag_gcse_after_reload): Declaration of global variable.
2611
2612         * gcse.c (reg_used_on_edge ,reg_set_between_after_reload_p,
2613         reg_used_between_after_reload_p, rtx get_avail_load_store_reg,
2614         is_jump_table_basic_block, bb_has_well_behaved_predecessors,
2615         get_bb_avail_insn, hash_scan_set_after_reload,
2616         compute_hash_table_after_reload, eliminate_partially_redundant_loads,
2617         gcse_after_reload, get_bb_avail_insn): New functions to implement
2618         gcse-after-reload.
2619         (gcse_after_reload_main): New function, the main entry point to
2620         gcse-after-reload.
2621
2622         * rtl.h (gcse_after_reload_main): Declaration of the new function.
2623
2624         * opts.c (common_handle_option): Handle the -fgcse-after-reload flag.
2625
2626         * toplev.c (flag_gcse_after_reload): Initialization.
2627
2628         * passes.c (rest_of_handl_gcse2): Call gcse_after_reload_main.
2629
2630         * params.def (PARAM_GCSE_AFTER_RELOAD_PARTIAL_FRACTION,
2631         PARAM_GCSE_AFTER_RELOAD_CRITICAL_FRACTION): New parameters for tuning
2632         the gcse after reload optimization.
2633
2634         * params.h (GCSE_AFTER_RELOAD_PARTIAL_FRACTION,
2635         GCSE_AFTER_RELOAD_CRITICAL_FRACTION): Two macros to access the tuning
2636         parameters.
2637
2638         * doc/invoke.texi: Documentation for the new flag gcse-after-reload.
2639
2640 2004-03-03  Nicolas Pitre <nico@cam.org>
2641
2642         * config/arm/ieee754-df.S (muldf3, divdf3): Fix denormalization of
2643         small negative values.
2644
2645 2004-03-03  Jan Hubicka  <jh@suse.cz>
2646
2647         * cselib.c (hash_table):  Remove GTY marker.
2648         (reg_values): Turn into array.
2649         (used_regs): Likewise.
2650         (n_used_regs): New static variable.
2651         (reg_values_old): Kill.
2652         (clear_table): Update uses of arrays.
2653         (cselib_lookup): Likewise.
2654         (cselib_record_set): Likewise.
2655         (cselib_init): Likewise.
2656         (cselib_finish): Likewise.
2657         (cselib_udpate_varray_sizes): Kill.
2658         * cselib.h (cselib_update_varray_sizes): Kill.
2659
2660 2004-03-03  Paul Brook  <paul@codesourcery.com>
2661
2662         * flow.c (ior_reg_cond, and_reg_cond): Remove stray ")".
2663
2664 2004-03-03  Jan Hubicka  <jh@suse.cz>
2665
2666         * ggc-common.c (ggc_alloc_cleared_stat, ggc_realloc_stat):
2667         Rename from ...; make statistics transparent.
2668         (ggc_alloc_cleared, ggc_realloc_stat): ... these.
2669         (loc_descriptor): New structure.
2670         (hash_descriptor, eq_descriptor, loc_descriptor, cmp_statistics,
2671         add_statistics):
2672         New static function.
2673         (ggc_record_overhead, dump_statistics): New global function.
2674         * ggc-none.c (ggc_alloc_types_stat, ggc_alloc_stat, ggc_alloc_zone_stat,
2675         ggc_alloc_cleared_stat, ggc_realloc_stat, ggc_alloc_typed_stat): Rename
2676         from ...; accept locations
2677         (ggc_alloc_types, ggc_alloc, ggc_alloc_zone, ggc_alloc_cleared,
2678         ggc_realloc, ggc_alloc_typed):  ... this one.
2679         from ...; accept locations
2680         * ggc-page.c (ggc_alloc_typed_stat, ggc_alloc_zone_stat,
2681         ggc_alloc_stat): Rename from ... ; pass locations
2682         * ggc-page.c (ggc_alloc_typed, ggc_alloc_zone, ggc_alloc):
2683         ... this one.
2684         (ggc_alloc_stat): Record overehead.
2685         * ggc.h (ggc_alloc_types, ggc_alloc, ggc_alloc_zone, ggc_alloc_cleared,
2686         ggc_realloc, ggc_alloc_typed):  Turn to macros
2687         (ggc_alloc_types_stat, ggc_alloc_stat, ggc_alloc_zone_stat,
2688         ggc_alloc_cleared_stat, ggc_realloc_stat, ggc_alloc_typed_stat): Declare.
2689         (dump_ggc_loc_satistics, ggc_record_overehead): Declare.
2690         * langhooks.h (lhd_make_node): Declare.
2691         (LANG_HOOKS_MAKE_TYPE): Default to new function,
2692         * langhooks.c (lhd_make_node): New.
2693         * rtl.c (rtx_alloc_stat, swallow_copy_rtx_stat): Rename from ... ; pass
2694         locations.
2695         (rtx_alloc, swallow_copy_rtx): ... this one.
2696         * rtl.h (rtx_alloc, swallow_copy_rtx): Turn to macros.
2697         * rtl.c (rtx_alloc_stat, swallow_copy_rtx_stat): Declare.
2698         * toplpev.c (finalize): Dump stats.
2699         * tree.c (make_node_stat, copy_node_stat, make_tree_vec_stat,
2700         build_tree_list_stat, tree_cons_stat, build?_stat,  build_decl_stat):
2701         Rename from ... ; pass locators.
2702         (make_node, copy_node, make_tree_vec, build_tree_list, tree_cons,
2703         build?,  build_decl): Declare.
2704         * tree.h (make_node_stat, copy_node_stat, make_tree_vec_stat,
2705         build_tree_list_stat, tree_cons_stat, build?_stat,  build_decl_stat):
2706         Declare.
2707         (make_node, copy_node, make_tree_vec, build_tree_list, tree_cons,
2708         build?,  build_decl): New macros.
2709         * Makefile.in (RTL_H, TREE_H): Add statistics.h dependency.
2710         * statistics.h: New file.
2711
2712 2004-03-03  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
2713             Richard Sandiford  <rsandifo@redhat.com>
2714
2715         * config/mips/mips.h (MASK_FIX_SB1): Bump.
2716         (MASK_FIX_R4400, TARGET_FIX_R4400): New macros.
2717         (TARGET_SWITCHES): Add -mfix-r4400 and -mno-fix-r4400.
2718         * config/mips/mips.c (mips_output_division): Fill the branch delay
2719         slot with a nop if TARGET_FIX_R4000.  Extend R4000 workarounds to
2720         TARGET_FIX_R4400.
2721         (mips_output_division): Adjust accordingly.
2722         (override_options): Make -march=r4400 imply -mfix-r4400 by default.
2723         * doc/invoke.texi: Document -mfix-r4400 and new errata workarounds.
2724
2725 2004-03-03  Paolo Bonzini  <bonzini@gnu.org>
2726
2727         * alias.c (rtx_equal_for_memref_p): Use predicates
2728         to test rtx classes and new rtx class codes, possibly
2729         splitting conditionals that tested against '<' and 'o'.
2730         * caller-save.c (save_call_clobbered_regs): Likewise.
2731         * combine.c (contains_muldiv, find_split_point, subst,
2732         combine_simplify_rtx, simplify_if_then_else,
2733         simplify_set, simplify_logical, expand_compound_operation,
2734         make_compound_operation, if_then_else_cond, known_cond,
2735         apply_distributive_law, cached_nonzero_bits,
2736         cached_num_sign_bit_copies, simplify_shift_const,
2737         gen_binary, simplify_comparison, update_table_tick,
2738         record_value_for_reg, get_lsat_value_validate): Likewise.
2739         * cse.c (mention_regs, find_best_addr, find_comparison_args,
2740         fold_rtx, cse_insn, invalidate_memory, cse_basic_block):
2741         Likewise.
2742         * emit-rtl.c (copy_insn_1): Likewise.
2743         * expr.c (force_operand): Likewise.
2744         * final.c (final_scan_insn, get_mem_expr_from_op): Likewise.
2745         * flow.c (notice_stack_pointer_modification_1,
2746         invalidate_mems_from_autoinc, ior_reg_cond, not_reg_cond,
2747         and_reg_cond, elim_reg_cond): Likewise.
2748         * function.c (update_epilogue_consts): Likewise.
2749         * genattrtab.c (attr_rtx_1): Likewise.
2750         * genopinit.c (gen_insn): Likewise.
2751         * integrate.c (subst_constants): Likewise.
2752         * jump.c (reversed_comparison_code_parts,
2753         reversed_comparison_code, delete_related_insns,
2754         rtx_renumbered_equal_p): Likewise.
2755         * local-alloc.c (block_alloc): Likewise.
2756         * loop.c (rtx_equal_for_prefetch_p, maybe_eliminate_biv,
2757         canonicalize_condition): Likewise.
2758         * loop-iv.c (simplify_using_conditions, iv_number_of_iterations):
2759         Likewise.
2760         * optabs.c (add_equal_node, expand_binop): Likewise.
2761         * predict.c (estimate_probability): Likewise.
2762         * ra-debug.c (ra_print_rtx_2op, ra_print_rtx): Likewise.
2763         * recog.c (validate_replace_rtx_1, comparison_operator,
2764         offsettable_address_p, constrain_operands): Likewise.
2765         * reg-stack.c (swap_rtx_condition_1, subst_stack_regs_pat):
2766         Likewise.
2767         * regclass.c (scan_one_insn): Likewise.
2768         * regmove.c (stable_and_no_regs_but_for_p): Likewise.
2769         * regrename.c (kill_autoinc_value): Likewise.
2770         * reload.c (find_reusable_reload, find_reloads,
2771         reg_overlap_mentioned_for_reload_p): Likewise.
2772         * reload1.c (gen_reload, delete_address_reloads_1): Likewise.
2773         * rtl.c (copy_rtx): Likewise.
2774         * rtl.h (CONSTANT_P, INSN_P): Likewise.
2775         * rtlanal.c (commutative_operand_precedence): Likewise.
2776         * sched-deps.c (conditions_mutex_p): Likewise.
2777         * sched-rgn.c (is_cfg_nonregular): Likewise.
2778         * simplify-rtx.c (simplify_gen_binary,
2779         simplify_gen_relational, simplify_replace_rtx,
2780         simplify_unary_operation, simplify_binary_operation,
2781         simplify_ternary_operation, simplify_rtx): Likewise.
2782         * unroll.c (reg_dead_after_loop): Likewise.
2783         * config/alpha/alpha.c (alpha_swapped_comparison_operator,
2784         print_operand): Likewise.
2785         * config/arc/arc.c (proper_comparison_operator): Likewise.
2786         * config/arm/arm.c (arm_arm_address_cost, arm_select_cc_mode):
2787         Likewise.
2788         * config/avr/avr.c (_reg_unused_after): Likewise.
2789         * config/frv/frv.c (frv_ifcvt_modify_tests,
2790         frv_ifcvt_modify_insn, frv_pack_insn): Likewise.
2791         * config/i386/i386.c (ix86_comparison_operator,
2792         ix86_carry_flag_operator, fcmov_comparison_operator,
2793         arith_or_logical_operator, print_operand,
2794         ix86_expand_binary_operator, ix86_binary_operator_ok):
2795         Likewise.
2796         * config/i386/i386.md: Likewise.
2797         * config/ia64/ia64.c (not_postinc_memory_operand,
2798         ia64_print_operand, update_set_flags, errata_emit_nops):
2799         Likewise.
2800         * config/ia64/ia64.h (PREFERRED_RELOAD_CLASS,
2801         CONSTRAINT_OK_FOR_S): Likewise.
2802         * config/ip2k/ip2k.c (mdr_resequence_xy_yx,
2803         mdr_try_move_dp_reload, ip2k_check_can_adjust_stack_ref,
2804         ip2k_xexp_not_uses_reg_for_mem, ip2k_xexp_not_uses_reg_p,
2805         ip2k_composite_xexp_not_uses_reg_p, ip2k_unary_operator):
2806         Likewise.
2807         * config/iq2000/iq2000.c (cmp_op, symbolic_expression_p,
2808         eqne_comparison_operator, signed_comparison_operator):
2809         Likewise.
2810         * config/mips/mips.c (cmp_op, symbolic_expression_p):
2811         Likewise.
2812         * config/mmix/mmix (mmix_foldable_comparison_operator,
2813         mmix_comparison_operator): Likewise.
2814         * config/pa/pa.c (hppa_legitimize_address): Likewise.
2815         * config/rs6000/rs6000.c (stmw_operation,
2816         branch_comparison_operator, trap_comparison_operator,
2817         ccr_bit): Likewise.
2818         * config/rs6000/rs6000.h (SELECT_CC_MODE): Likewise.
2819         * config/s390/s390.c (s390_alc_comparison,
2820         s390_slb_comparison):L Likewise.
2821         * config/sh/sh.c (gen_block_redirect, reg_unused_after):
2822         Likewise.
2823         * config/sparc/sparc.c (eq_or_neq, normal_comp_operator,
2824         noov_compare_op, noov_compare64_op, v9_regcmp_op,
2825         emit_hard_tfmode_operation, reg_unused_after)
2826         * doc/md.texi, doc/rtl.texi: Likewise.
2827
2828         * ra-debug.c: Add 2004 to list of copyright years.
2829         * unroll.c: Likewise.
2830
2831         * combine.c (simplify_logical): Remove dummy test,
2832         (apply_distributive_law): Fix typo in comment.
2833         GET_CODE (x) == AND so x is a commutative binary op.
2834         * jump.c (delete_related_insns): simplify loop
2835         condition, move testing of RTX codes inside the loop.
2836         (rtx_renumbered_equal_p): do not use RTX_CODE.
2837         * rtl.c (rtx_class): Declare as enum rtx_class.
2838         * rtl.def (EQ, NE, UNEQ, LTGT, UNORDERED, ORDERED):
2839         Move to RTX_COMM_COMPARE class.
2840         (HIGH, SYMBOL_REF, LABEL_REF, CONST, CONST_INT, CONST_DOUBLE):
2841         Move to RTX_CONST_OBJ class.
2842         * rtl.h (enum rtx_class): New declaration,
2843         (RTX_OBJ_MASK, RTX_OBJ_RESULT, RTX_COMPARE_MASK,
2844         RTX_COMPARE_RESULT, RTX_ARITHMETIC_MASK, RTX_ARITHMETIC_RESULT,
2845         RTX_BINARY_MASK, RTX_BINARY_RESULT, RTX_COMMUTATIVE_MASK,
2846         RTX_COMMUTATIVE_RESULT, RTX_NON_COMMUTATIVE_RESULT,
2847         RTX_EXPR_FIRST, RTX_EXPR_LAST, UNARY_P, BINARY_P,
2848         ARITHMETIC_P, COMMUTATIVE_ARITHMETIC_P, COMPARISON_P,
2849         SWAPPABLE_OPERANDS_P, NON_COMMUTATIVE_P, COMMUTATIVE_P,
2850         OBJECT_P): New macros.
2851         * config/sparc/sparc.c (noov_compare_op): Remove register
2852         from parameter.
2853
2854 2004-03-03  Kazu Hirata  <kazu@cs.umass.edu>
2855
2856         * target.h: Remove texi jargons in comments.
2857
2858 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
2859
2860         * config/h8300/lib1funcs.asm (___fixunssfsi): Change the
2861         threshold to 0x4f.
2862
2863         Revert:
2864         2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
2865         * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
2866         as well.
2867         * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
2868         * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
2869
2870 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
2871
2872         * doc/md.texi (cbranchmode4): New.
2873
2874 2004-03-02  Eric Christopher  <echristo@redhat.com>
2875
2876         * config/mips/mips16.S: Change fixsfsi and fixdfsi to
2877         fix_trunc.
2878         * config/mips/mips.c (mips_init_libfuncs): Change accordingly.
2879         * config/mips/t-elf (LIB1ASMFUNCS): Ditto.
2880         * config/mips/t-isa3264 (LIB1ASMFUNCS): Ditto.
2881         * config/mips/t-r3900 (LIB1ASMFUNCS): Ditto.
2882
2883 2004-03-02  Richard Henderson  <rth@redhat.com>
2884
2885         PR middle-end/11767
2886         * coverage.c (coverage_counter_ref): Set MEM_NOTRAP_P.
2887         * optabs.c (prepare_cmp_insn): Force trapping memories to registers
2888         before the compare, if flag_non_call_exceptions.
2889
2890 2004-03-02  Richard Henderson  <rth@redhat.com>
2891
2892         PR middle-end/14327
2893         * stmt.c (expand_computed_goto): Do do_pending_stack_adjust before
2894         emitting the label, not after.
2895
2896 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
2897
2898         * config/m68hc11/m68hc11.c (m68hc11_addr_mode): New variable.
2899         (m68hc11_mov_addr_mode): Likewise.
2900         (m68hc11_override_options): Initialize them based on target.
2901         (register_indirect_p): Allow a MEM for indirect addressing modes and
2902         use flags to control what is allowed.
2903         (m68hc11_small_indexed_indirect_p): Use m68hc11_mov_addr_mode for
2904         supported addressing modes.
2905         (m68hc11_register_indirect_p): Use m68hc11_addr_mode.
2906         (go_if_legitimate_address_internal): Likewise.
2907         (m68hc11_indirect_p): Likewise and check the mode.
2908         (print_operand): Allow a (MEM (MEM)) and generate indirect addressing.
2909
2910 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
2911
2912         * builtins.c (BUILTIN_SETJMP_FRAME_VALUE): Remove.
2913         (expand_builtin_setjmp_setup): Use
2914         targetm.builtin_setjmp_frame_value instead of
2915         BUILTIN_SETJMP_FRAME_VALUE.
2916         * system.h (BUILTIN_SETJMP_FRAME_VALUE): Poison.
2917         * target-def.h (TARGET_BUILTIN_SETJMP_FRAME_VALUE): New.
2918         (TARGET_INITIALIZER): Add TARGET_BUILTIN_SETJMP_FRAME_VALUE.
2919         * target.h (gcc_target): Add builtin_setjmp_frame_value.
2920         * targhooks.c (default_builtin_setjmp_frame_value): New.
2921         * targhooks.h: Add a prototype for
2922         default_builtin_setjmp_frame_value.
2923         * doc/tm.texi (BUILTIN_SETJMP_FRAME_VALUE): Change to
2924         TARGET_BUILTIN_SETJMP_FRAME_VALUE.
2925
2926 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
2927
2928         * config/m68hc11/m68hc11.md (move peephole2): New peepholes to optimize
2929         sequences of moves.
2930         (add peepholes): New peepholes to optimize sequences adding small
2931         constants.
2932         (bset peepholes): New peepholes to transform an OR in a bset form
2933         (bclr peepholes): Likewise for bclr form.
2934         (cmp peepholes): New peepholes to avoid register copies when comparing.
2935
2936 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
2937
2938         * config/m68hc11/m68hc11.md ("*pushdi_internal"): New insn and split
2939         to separate push from moves.
2940         ("*pushdf_internal"): Likewise.
2941         ("*pushsf_internal"): Likewise.
2942         ("*pushsi_internal"): Likewise.
2943         ("movdi_internal"): Use define_insn_and_split; non push operand.
2944         ("movdf_internal"): Likewise.
2945         ("movsf_internal"): Likewise.
2946         ("movsi_internal"): Likewise.
2947         ("*movhi_68hc12", "*addhi3_68hc12"): Fix and tune constraints
2948         ("*addhi3", "*subhi3", "*andhi3_mem", "*iorhi3_mem"): Likewise.
2949         ("*ashlsi3_const1", "*lshrsi3_const1"): Likewise.
2950
2951 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
2952
2953         * config/m68hc11/m68hc11.md ("tstqi_z_used"): Use define_insn_and_split.
2954         ("cmphi_z_used", "cmpqi_z_used"): Likewise.
2955         ("movstrictsi", "movstricthi", "movstrictqi"): Likewise.
2956         ("anddi3", "andsi3", "iordi3", "iorsi3"): Likewise.
2957         ("xordi3", "xorsi3", "*logicalsi3_zexthi"): Likewise.
2958         ("*logicalsi3_zextqi", "*logicalhi3_zexthi_ashift8"): Likewise.
2959         ("logicalhi3_zexthi", "*logicalsi3_silshr16"): Likewise.
2960         ("*logicalsi3_silshl16", "*logicalsi3_silshl16_zext"): Likewise.
2961         ("*ashldi3_const32", "*ashldi3_const1", "addsi_silshr16"): Likewise.
2962         ("addsi_andshr16", "*ashlsi3_const16_zexthi"): Likewise.
2963         ("*lshrdi3_const32", "*lshrdi_const1"): Likewise.
2964
2965 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
2966
2967         * config/m68hc11/m68hc11.md (SOFT_TMP_REGNUM): Define.
2968         (SOFT_XY_REGNUM): Define.
2969         (cmp split): Use the above instead of hard coded numbers.
2970         (8-bit op split): No need to check the mode; allow Q_REG.
2971         (ashift split): Adjust the first operand if it uses the SP and we
2972         are pushing the shifted value.
2973         (plus shift split): Fix when a source is in register D+X.
2974         ("doloop_end"): Pass dummy arguments to gen_rtx_NE.
2975
2976 2004-03-02  Stephane Carrez  <stcarrez@nerim.fr>
2977
2978         * config/m68hc11/m68hc11.c (m68hc11_check_z_replacement): Fix when
2979         comparing with Z register.
2980
2981 2004-03-02  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
2982
2983         * cfgloop.h (struct loop_desc): Removed.
2984         (struct loop): Fields simple, desc and has_desc removed.
2985         (simple_loop_p, count_loop_iterations): Declaration removed.
2986         * cfgloopanal.c (struct unmark_altered_insn_data): Removed.
2987         (unmark_altered, blocks_invariant_registers, unmark_altered_insn
2988         blocks_single_set_registers, invariant_rtx_wrto_regs_p_helper,
2989         invariant_rtx_wrto_regs_p, test_for_iteration, constant_iterations,
2990         simple_loop_exit_p, variable_initial_value, variable_initial_values,
2991         simple_condition_p, simple_increment, count_strange_loop_iterations,
2992         inverse, fits_in_mode_p, simple_loop_p, count_loop_iterations):
2993         Removed.
2994         * loop-iv.c (check_simple_exit, find_simple_exit): Update comments.
2995
2996 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
2997
2998         * genattrtab.c: Don't handle MATCH_INSN.
2999         * genrecog.c: Likewise.
3000         * gensupport.c: Likewise.
3001         * rtl.def (match_insn): Remove.
3002         * doc/md.texi (match_insn, match_insn2): Remove.
3003
3004 2004-03-02  Mark Mitchell  <mark@codesourcery.com>
3005
3006         * doc/c-tree.texi (DECL_ASSEMBLER_NAME): Mention that using this
3007         macro results in memory allocation.
3008
3009 2004-03-02  David O'Brien  <obrien@FreeBSD.org>
3010
3011         * config/freebsd-spec.h (FBSD_DYNAMIC_LINKER): Add.
3012         * config/alpha/freebsd.h (SUBTARGET_EXTRA_SPECS): Define
3013         %(fbsd_dynamic_linker),
3014         (LINK_SPEC): Use %(fbsd_dynamic_linker), and sync style with
3015         config/i386/freebsd.h
3016         * config/arm/freebsd.h: Ditto.
3017         * config/i386/freebsd.h: Ditto.
3018         * config/i386/freebsd64.h: Ditto.
3019         * config/ia64/freebsd.h: Ditto.
3020         * config/rs6000/sysv4.h: Ditto.
3021         * config/sparc/freebsd.h: Ditto.
3022
3023 2004-03-02  Loren James Rittle  <ljrittle@acm.org>
3024
3025         * gcc/doc/install.texi (*-*-freebsd*): Update target information.
3026
3027 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
3028
3029         * rtl.def (define_combine): Remove.
3030
3031 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
3032
3033         * config/h8300/h8300.md: Tweak formatting.
3034
3035 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
3036
3037         * config/h8300/h8300.md (*cmphi_h8300): Rename to
3038         *cmphi_h8300_znvc.
3039         (*cmphi_h8300hs): Rename to *cmphi_h8300hs_znvc.
3040
3041 2004-03-01  Mark Mitchell  <mark@codesourcery.com>
3042
3043         PR bootstrap/14356
3044         * gcc.c (process_command): Remove const-qualification from argv.
3045         (main): Likewise.
3046
3047 2004-03-02  Kazu Hirata  <kazu@cs.umass.edu>
3048
3049         * config/h8300/h8300.md (pushqi1_h8300hs): Rename to
3050         pushqi1_h8300hs_advanced.  Adjust its caller.
3051         (pushhi1_h8300hs): Rename to pushhi1_h8300hs_advanced.
3052         Adjust its caller.
3053
3054 2004-03-02  Nicolas Roche  <roche@act-europe.fr>
3055
3056         * Makefile.in (install-libgcc, install-multilib): Pass
3057         mkinstalldirs var to libgcc.mk.
3058
3059 2004-03-01  Kazu Hirata  <kazu@cs.umass.edu>
3060
3061         * system.h (DBX_OUTPUT_STANDARD_TYPES): Poison.
3062         * doc/tm.texi (DBX_OUTPUT_STANDARD_TYPES): Remove.
3063
3064 2004-03-01  Kazu Hirata  <kazu@cs.umass.edu>
3065
3066         * config/h8300/h8300.c (gtle_operator): Accept GT and LE.
3067         * config/h8300/h8300.md: Split several peephole2's, each into
3068         two.
3069
3070 2004-03-02  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
3071
3072         * dominance.c (recount_dominator): Handle postdominators.
3073
3074 2004-03-01  Richard Sandiford  <rsandifo@redhat.com>
3075
3076         * config/mips/mips-protos.h (enum mips_symbol_type): Move from mips.h.
3077         (NUM_SYMBOL_TYPES): Likewise.
3078         (SYMBOL_64_HIGH, SYMBOL_64_MID, SYMBOL_64_LOW): New symbol types.
3079         (mips_unspec_address): Declare.
3080         (mips_gotoff_page, mips_gotoff_global): Delete.
3081         * config/mips/mips.h (PREDICATE_CODES): Add general_symbolic_operand.
3082         * config/mips/mips.c (enum mips_symbol_type, NUM_SYMBOL_TYPES): Delete.
3083         (mips_symbolic_constant_p, mips_symbolic_address_p)
3084         (mips_symbol_insns): Handle new symbol types.
3085         (general_symbolic_operand): New predicate.
3086         (mips_unspec_address): Make extern.
3087         (mips_gotoff_page, mips_gotoff_global): Delete.
3088         (override_options): Allow -mabi=64 -mno-abicalls -mexplicit-relocs.
3089         Handle new symbol types.
3090         * config/mips/mips.md (*lea_high64, *lea64): New patterns.
3091         (*xgot_hi[sd]i, *xgot_lo[sd]i, *got_disp[sd]i, *got_disp[sd]i): Call
3092         mips_unspec_address directly.
3093         * doc/invoke.texi: Remove the -mabi=64 -mno-abicalls exception from
3094         the documentation of -mexplicit-relocs.
3095
3096 2004-03-01  Jeff Law  <law@redhat.com>
3097
3098         * fold-const.c (fold): An equality comparison of a non-weak object
3099         against zero has a known result.  Similarly an equality comparison
3100         of the address of two non-weak, unaliased symbols has a known result.
3101
3102         * ggc-page.c (struct page_entry): New field PREV.
3103         (ggc_alloc): Update PREV field appropriately.
3104         (sweep_pages): Likewise.
3105         (ggc_free): Likewise.  Use PREV field rather than loop to
3106         improve ggc_free performance.
3107
3108 2004-03-01  Richard Sandiford  <rsandifo@redhat.com>
3109
3110         * config/mips/mips.c (mips_output_division): Use the division
3111         instruction to fill the delay slot of a zero check.
3112         (mips_idiv_insns): Adjust accordingly.
3113
3114 2004-03-01  Nathanael Nerode  <neroden@gcc.gnu.org>
3115
3116         * config.gcc: Create a default tmake_file for linux, and use
3117         it in all but two linux clauses.  Comment those two.
3118
3119 2004-03-01  Paolo Bonzini  <bonzini@gnu.org>
3120
3121         * combine.c (try_combine):  Do not refer to is_replaced.
3122         (gen_lowpart_for_combine):  Perverse subregs now have a
3123         more politically correct name.
3124         * cse.c (cse_insn): Likewise.
3125         * jump.c: Fix bogus reference to delete_insn.
3126
3127 2004-02-29  Mark Mitchell  <mark@codesourcery.com>
3128
3129         PR debug/14328
3130         * dwarf2out.c (gen_enumeration_type_die): Output all enumeration
3131         constants as signed values.
3132
3133         PR middle-end/13448
3134         * c-tree.h (readonly_warning): Rename to ...
3135         (readonly_error): ... this.
3136         * c-typeck.c (build_unary_op): Adjust accordingly.
3137         (readonly_warning): Rename to ...
3138         (readonly_error): ... this and issue errors, not warnings.
3139         (build_modify_expr): Call readonly_error, not readonly_warning.
3140         (c_expand_asm_operands): Likewise.
3141         * tree-inline.c (optimize_inline_calls): Do not inline functions
3142         after errors have occurred.
3143
3144 2004-02-29  Nathanael Nerode  <neroden@gcc.gnu.org>
3145
3146         * configure.ac: Rearrange some threading code for clarity;
3147         add section comment.
3148         * configure: Regenerate.
3149
3150 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
3151
3152         * passes.c, config/frv/frv.c, config/sh/sh.c: Fix comment
3153         typos.
3154         * doc/cppopts.texi: Fix a typo.
3155
3156 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
3157
3158         * config/i386/i386.md: Fix formatting.
3159
3160 2004-02-29  Nathanael Nerode  <neroden@gcc.gnu.org>
3161
3162         * configure.ac: Add some comments delineating sections of code.
3163
3164         * doc/install.texi: Note that libada uses autoconf 2.57 also.
3165
3166         * doc/install.texi: Fix idiot typo in previous commit.
3167
3168         * doc/install.texi: Update for conversion of intl to autoconf 2.57.
3169
3170 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
3171
3172         * config/h8300/h8300.md: Add comments about peephole2's.
3173
3174 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
3175
3176         * config/h8300/h8300.md: Tweak operand numbers of some
3177         peephole2's.
3178
3179 2004-02-29  Kazu Hirata  <kazu@cs.umass.edu>
3180
3181         * config/h8300/h8300.md: Tweak comments about peephole2's.
3182
3183 2004-02-29  Waldek Hebisch  <hebisch@math.uni.wroc.pl>
3184
3185         PR middle-end/14203
3186         * function.c (uninitialized_vars_warning): Use DECL_RTL_SET_P
3187         instead of testing whether DECL_RTL is not NULL.
3188
3189 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
3190
3191         * config/sh/sh.c: Fix formatting.
3192
3193 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
3194
3195         * config/sh/sh.c: Convert to ISO-C.
3196
3197 2004-02-28  Andrew Pinski  <pinskia@physics.uc.edu>
3198
3199         * c-typeck.c (tagged_types_tu_compatible_p): Fix pasto in
3200         my previous patch.
3201
3202         * config/darwin.h (machopic_finish): Output stub even if the
3203         symbol is already defined.
3204
3205 2004-02-28  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
3206
3207         * pa64-hpux.h (LIB_SPEC): Fix linking under HP-UX 11.00 with -p and -pg.
3208
3209 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
3210
3211         * genattr.c (main): Don't define
3212         TRADITIONAL_PIPELINE_INTERFACE or DFA_PIPELINE_INTERFACE.
3213         * system.h (TRADITIONAL_PIPELINE_INTERFACE): Poison.
3214         (DFA_PIPELINE_INTERFACE): Likewise.
3215         * doc/tm.texi (TRADITIONAL_PIPELINE_INTERFACE): Remove.
3216         (DFA_PIPELINE_INTERFACE): Likewise.
3217
3218 2004-02-28  Richard Sandiford  <rsandifo@redhat.com>
3219
3220         * config/mips/mips.md (tstsi, tstdi): Delete.
3221
3222 2004-02-28  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
3223
3224         * config/mips/mips.c (override_options): Remove an obsolete
3225         duplicate definition of the "e" constraint.
3226         * config/mips/mips.h: Update a comment accordingly.
3227
3228 2004-02-28  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
3229
3230         * config/mips/mips.md: Complete the unfinished R4000
3231         multiply/shift errata workaround.  Improve documentation.
3232         (hazard): Use TARGET_FIX_R4000 to decide whether an "imul" instruction
3233         has a hilo hazard.
3234         (mulsi3, mulsi3_internal, mulsi3_r4000): Use TARGET_FIX_R4000.
3235         (muldi3, muldi3_internal): Likewise.
3236         (muldi3_internal2): Remove, replacing with...
3237         (muldi3_mult3, muldi3_r4000): ...these new patterns.
3238         (mulsidi3): Take the errata into account.
3239         (mulsidi3_32bit): Remove, replacing with...
3240         (mulsidi3_32bit_internal, mulsidi3_32bit_r4000): ...these new patterns.
3241         (mulsidi3_64bit, mulsidi3_64bit_parts): Disable if TARGET_FIX_R4000.
3242         (umulsidi3): Take the errata into account.
3243         (umulsidi3_32bit): Remove, replacing with..
3244         (umulsidi3_32bit_internal, umulsidi3_32bit_r4000): ...these patterns.
3245         (umulsi3_highpart, umulsi3_highpart_internal): Disable if
3246         TARGET_FIX_R4000.
3247         (smulsi3_highpart, smulsi3_highpart_internal): Likewise.
3248         (smuldi3_highpart, umuldi3_highpart): Likewise.
3249         * doc/invoke.texi: Document the errata workaround.
3250
3251 2004-02-28  Maciej W. Rozycki  <macro@ds2.pg.gda.pl>
3252
3253         * config/mips/mips-protos.h (mips_idiv_insns): Declare.
3254         * config/mips/mips.h (MASK_FIX_SB1): Bump.
3255         (MASK_FIX_R4000, TARGET_FIX_R4000): New macros.
3256         (TARGET_SWITCHES): Add -mfix-r4000 and -mno-fix-r4000.
3257         * config/mips/mips.c (mips_idiv_insns): New function.
3258         (override_options): Make -march=r4000 imply -mfix-r4000 by default.
3259         (mips_output_division): Add a workaround for the R4000 divide/shift
3260         errata.
3261         * config/mips/mips.md (length): Use mips_idiv_insns() to calculate
3262         the length of an "idiv" instruction.
3263         * doc/invoke.texi: Document the new switches.
3264
3265 2004-02-28  Kazu Hirata  <kazu@cs.umass.edu>
3266
3267         * doc/tm.texi (IS_COSTLY_DEPENDENCE): Change to
3268         TARGET_SCHED_IS_COSTLY_DEPENDENCE.
3269
3270 2004-02-28  Zdenek Dvorak  <rakdver@atrey.karlin.mff.cuni.cz>
3271
3272         PR optimization/14229
3273         * cfgrtl.c (rtl_tidy_fallthru_edge): Do not fail for !onlyjump jump.
3274
3275 2004-02-28  Eric Botcazou  <ebotcazou@act-europe.fr>
3276
3277         * fold-const.c (fold): Strip NOPs that change the signedness
3278         for RSHIFT too.  Expand comment.
3279
3280 2004-02-27  Ian Lance Taylor  <ian@wasabisystems.com>
3281
3282         PR optimization/7871
3283         * flow.c (mark_set_1): Don't add LOG_LINKS for global registers
3284         from or to call insns.
3285
3286 2004-02-27  Eric Botcazou  <ebotcazou@libertysurf.fr>
3287
3288         PR optimization/7871
3289         * flow.c (propagate_one_insn): Interpret calls as setting global
3290         registers, not merely clobbering them.
3291
3292 2004-02-27  Dale Johannesen  <dalej@apple.com>
3293
3294         * config/darwin.c (machopic_output_possible_stub_label):  Remove.
3295         config/darwin-protos.h:  Ditto.
3296         config/darwin.h:  Remove call to it.
3297         * combine.c (distribute_notes): Do not place a REG_DEAD note
3298         when value is both set and used.
3299
3300 2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
3301
3302         * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
3303         as well.
3304         * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
3305         * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
3306
3307 2004-02-27  Andrew Pinski  <apinski@apple.com>
3308
3309         * c-typeck.c (tagged_types_tu_compatible_p) <ENUMERAL_TYPE>:
3310         Speedup common case of the type values being in the same order.
3311
3312 2004-02-27  Steve Ellcey  <sje@cup.hp.com>
3313
3314         * config/ia64/ia64.h (no-inline-float-divide): New option.
3315         * config/ia64/ia64.h (no-inline-int-divide): New option.
3316         * config/ia64/ia64.h (no-inline-sqrt): New option.
3317         (TARGET_DEFAULT): Add MASK_INLINE_FLOAT_DIV_THR to define.
3318         * config/ia64/hpux.h (TARGET_DEFAULT): Ditto.
3319         * config/ia64/ia64.c (ia64_override_options): Modify error
3320         checking for inlined division/sqrt.
3321
3322 2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
3323
3324         * bb-reorder.c, cfgbuild.c, diagnostic.c, explow.c, profile.c,
3325         ra-build.c, read-rtl.c, tracer.c, unwind-dw2-fde-glibc.c,
3326         value-prof.c, config/darwin-protos.h, config/frv/frv-abi.h,
3327         config/i386/pmmintrin.h, config/pa/pa-hpux.h: Update
3328         copyright.
3329
3330 2004-02-27  Paul Brook  <paul@codesourcery.com>
3331
3332         * function.c (assign_parms): Don't count pretend args for alignment.
3333
3334 2004-02-27  Richard Henderson  <rth@redhat.com>
3335
3336         * passes.c: New file.
3337         * Makefile.in (OBJS-common): Add it.
3338         * diagnostic.c (rtl_dump_and_exit): Move decl ...
3339         * flags.h (rtl_dump_and_exit): ... here.
3340         * output.h (size_directive_output, last_assemble_variable_decl):
3341         Move from toplev.c.
3342         * rtl.h (reg_alloc): Move from toplev.c.
3343         * toplev.c (HAVE_conditional_execution, DUMPFILE_FORMAT,
3344         struct dump_file_info, enum dump_file_index, dump_file_tbl,
3345         open_dump_file, close_dump_file, rest_of_decl_compilation,
3346         rest_of_type_compilation, rest_of_handle_final,
3347         rest_of_handle_delay_slots, rest_of_handle_stack_regs,
3348         rest_of_handle_variable_tracking, rest_of_handle_machine_reorg,
3349         rest_of_handle_new_regalloc, rest_of_handle_old_regalloc,
3350         rest_of_handle_regrename, rest_of_handle_reorder_blocks,
3351         rest_of_handle_sched, rest_of_handle_sched2, rest_of_handle_regmove,
3352         rest_of_handle_tracer, rest_of_handle_if_conversion,
3353         rest_of_handle_if_after_combine, rest_of_handle_web,
3354         rest_of_handle_branch_prob,
3355         rest_of_handle_value_profile_transformations, rest_of_handle_cfg,
3356         rest_of_handle_addressof, rest_of_handle_sibling_calls,
3357         rest_of_handle_jump_bypass, rest_of_handle_inlining,
3358         rest_of_handle_null_pointer, rest_of_handle_combine,
3359         rest_of_handle_life, rest_of_handle_cse, rest_of_handle_cse2,
3360         rest_of_handle_gcse, rest_of_handle_loop_optimize,
3361         rest_of_handle_loop2, rest_of_compilation): Move to passes.c.
3362         (decode_d_option): Use enable_rtl_dump_file.
3363         (compile_file, finalize, do_compile): Move profile+combine+graph
3364         cleanup to finish_optimization_passes.
3365         * toplev.h (init_optimization_passes, finish_optimization_passes,
3366         enable_rtl_dump_file): Declare.
3367
3368 2004-02-27  Eric Botcazou  <ebotcazou@act-europe.fr>
3369             Roger Sayle  <roger@eyesopen.com>
3370
3371         * fold-const.c (fold): Revert 2004-02-25 change.  Use the original
3372         operands to build a tree with swapped operands.
3373         * expr.c (expand_expr_real) <MAX_EXPR>: Consistently use the
3374         'unsignedp' predicate to specify the signedness.
3375
3376 2004-02-27  Kazu Hirata  <kazu@cs.umass.edu>
3377
3378         * c-decl.c, c-ppoutput.c, combine.c, cppfiles.c, dwarf2out.c,
3379         expr.c, fold-const.c, gcc.c, haifa-sched.c, loop-iv.c,
3380         params.def, read-rtl.c, rtl.c, rtlanal.c, toplev.c: Fix
3381         comment typos and formatting.  Follow spelling conventions.
3382
3383 2004-02-26  Aldy Hernandez  <aldyh@redhat.com>
3384
3385         * config/rs6000/rs6000.md: Add fixuns_truncsfsi2 and
3386         fix_truncsfsi2.
3387
3388         * config/rs6000/spe.md: Delete spe_efsctuiz.
3389         Add spe_fixuns_truncsfsi2.
3390         Add spe_fix_truncsfsi2.
3391
3392 2004-02-26  Eric Christopher  <echristo@redhat.com>
3393
3394         * c-lex.c (c_lex_string_translate): New variable.
3395         (lex_string): Use to determine string translation.
3396         * c-pragma.h: Prototype.
3397         * c-parse.in (start_string_translation): New. Set above.
3398         (stop_string_translation): Ditto.
3399         (attribute, attribute_list, asm_def, asm_stmt,
3400         asm_operand): Use above functions.
3401         * cp/parser.c (cp_parser_declaration): Translate strings
3402         unless token is RID_EXTERN. Set c_lex_string_translate
3403         for recursive use.
3404         (cp_parser_asm_definition): Only translate argument strings
3405         to asms.
3406         (cp_parser_asm_operand_list): Ditto.
3407         (cp_parser_attribute_list): Do not translate attribute strings.
3408
3409 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
3410
3411         * stmt.c (expand_start_case_dummy): Remove.
3412         * tree.h: Remove the corresponding prototype.
3413
3414 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
3415
3416         * builtins.c (apply_args_register_offset): Remove.
3417         * tree.h: Remove the corresponding prototype.
3418
3419 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
3420
3421         * stor-layout.c (is_pending_size): Remove.
3422         * tree.h: Remove the corresponding prototype.
3423
3424 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
3425
3426         * recog.c (validate_replace_src): Remove.
3427         * recog.h: Remove the corresponding prototype.
3428
3429 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
3430
3431         * calls.c: Don't reference FINAL_REG_PARM_STACK_SPACE or
3432         MAYBE_REG_PARM_STACK_SPACE.
3433         * function.c: Likewise.
3434         * system.h (FINAL_REG_PARM_STACK_SPACE): Poison.
3435         (MAYBE_REG_PARM_STACK_SPACE): Likewise.
3436         * doc/tm.texi (FINAL_REG_PARM_STACK_SPACE): Remove.
3437         (MAYBE_REG_PARM_STACK_SPACE): Likewise.
3438
3439 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
3440
3441         * c-decl.c (c_expand_deferred_function): Remove.
3442         * c-tree.h: Remove the corresponding prototype.
3443
3444 2004-02-26  Kazu Hirata  <kazu@cs.umass.edu>
3445
3446         * postreload.c (reload_cse_move2add): Generate just a PLUS
3447         instead of an entire SET.
3448
3449 2004-02-26  Jan Hubicka  <jh@suse.cz>
3450
3451         * config.gcc: Add support for nocoma/prescott/pentium-m/pentium3m
3452         /pentium4m.
3453         * i386.c (override_options): Add support for new CPUs.
3454         * i386.h (TARGET_CPU_DEFAULT_NAMES): New names.
3455         (TARGET_CPU_DEFAULT_pentium_m, TARGET_CPU_DEFAULT_pentium4e): New
3456         constants.
3457         * invoke.texi: Extend documentation of -mtune/-march for new CPUs.
3458
3459 2004-02-26  Bob Wilson  <bob.wilson@acm.org>
3460
3461         * config/xtensa/xtensa.h (TARGET_CPU_CPP_BUILTINS): Define __xtensa__.
3462
3463 2004-02-26  Eric Botcazou  <ebotcazou@act-europe.fr>
3464
3465         * config/sparc/sparc-protos.h (sparc_emit_floatunsdi): Add 'mode'.
3466         (sparc_emit_fixunsdi): New prototype.
3467         * config/sparc/sparc.c (sparc_emit_floatunsdi): Use 'mode' argument.
3468         (sparc_emit_fixunsdi): New function.
3469         * config/sparc/sparc.md (floatunsdisf2): Use 'general_operand' for
3470         operand 1.  Pass SFmode to sparc_emit_floatunsdi.
3471         (floatunsdidf2): Use 'general_operand' for operand 1.  Pass DFmode
3472         to sparc_emit_floatunsdi.
3473         (fixuns_truncsfdi2): New expander.
3474         (fixuns_truncdfdi2): Likewise.
3475
3476 2004-02-26  Alan Modra  <amodra@bigpond.net.au>
3477
3478         * gcse.c (delete_null_pointer_checks_1): Do not delete CC setter
3479         unless HAVE_cc0.
3480
3481 2004-02-25  Richard Henderson  <rth@redhat.com>
3482
3483         * explow.c (force_reg): Call mark_reg_pointer as appropriate.
3484         * config/alpha/alpha.c (alpha_emit_conditional_branch): Don't
3485         use (op0-op1) == 0 if op0 is a pointer.
3486         * config/alpha/alpha.md (cmpdi): Use some_operand.
3487         (three comparison combine splits): Remove.
3488
3489 2004-02-25  Richard Henderson  <rth@redhat.com>
3490
3491         PR c/12794
3492         * c-common.c (handle_alias_attribute): Reject the attribute if
3493         current_function_decl is set.
3494
3495 2004-02-25  Kelley Cook  <kcook@gcc.gnu.org>
3496
3497         * config.gcc: Add comment describing extra_gcc_objs.
3498         i[34567]86-*-cygwin*): Replace host_extra_gcc_objs with extra_gcc_objs.
3499         * configure.ac (extra_gcc_objs): New substitution variable.
3500         (host_extra_gcc_objs): Don't substitute.
3501         * configure: Regenerate.
3502         * Makefile.in: Use extra_gcc_objs.
3503
3504 2004-02-25  Kelley Cook  <kcook@gcc.gnu.org>
3505
3506         * doc/contrib.texi: Add an entry for myself.
3507
3508 2004-02-25  Jan Hubicka  <jh@suse.cz>
3509
3510         * basic-block.h (make_eh_edge, break_superblocks): Declare.
3511         * cfgbuild.c (make_eh_edge):  Make global.
3512         * cfglayout.c (break_superblocks): Likewise; fix memory leak.
3513         * except.c (build_post_landing_pads, connect_post_landing_pads,
3514         dw2_build_landing_pads, sjlj_emit_function_enter,
3515         sjlj_emit_function_exit, sjlj_emit_dispatch_table,
3516         sjlj_build_landing_pads): Update CFG.
3517         (emit_to_new_bb_before): New function.
3518         (finish_eh_generation): Do not rebuild the CFG.
3519
3520 2004-02-25  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
3521
3522         * config.gcc (hppa*-*-*, parisc*-*-*): Add MASK_BIG_SWITCH to all
3523         target_cpu_default defines.
3524         * pa-hpux.h (TARGET_DEFAULT): Add MASK_BIG_SWITCH to define.
3525         * pa.h (TARGET_DEFAULT): Likewise.
3526
3527 2004-02-25  Eric Botcazou  <ebotcazou@act-europe.fr>
3528
3529         * fold-const.c (fold): Treat MAX_EXPR and MIN_EXPR like
3530         comparisons with regard to signedness.
3531
3532 2004-02-25  Richard Earnshaw  <rearnsha@arm.com>
3533
3534         * arm.c (thumb_legitimize_address): New function.
3535         * arm-protos.h: Prototype it.
3536         * arm.h (THUMB_LEGITIMIZE_ADDRESS): Define.
3537         (LEGITIMIZE_ADDRESS): Use it.
3538
3539 2004-02-25  J"orn Rennecke <joern.rennecke@superh.com>
3540
3541         * reload1.c (reload): Only spill eliminable register with multiple
3542         adjacent elimination alternatives if all alternatives fail.
3543
3544 2004-02-25  Richard Earnshaw  <rearnsha@arm.com>
3545
3546         * arm.c (arm_legitimate_index_p): For QImode the range of an offset
3547         is -4095...+4095 inclusive.
3548
3549 2004-02-25  Eric Botcazou  <ebotcazou@libertysurf.fr>
3550
3551         * doc/install.texi (sparc-sun-solaris2* specific notes): Document
3552         the bootstrap failure with Sun CC 5.4 and 5.5.
3553
3554 2004-02-24  Kazu Hirata  <kazu@cs.umass.edu>
3555
3556         * cse.c (cse_change_cc_mode_insns): Stop at any instruction
3557         which modifies NEWREG.
3558         (cse_condition_code_reg): Update the mode of CC_REG in
3559         CC_SRC_INSN on our own.
3560
3561 2004-02-24  Michael Matz  <matz@suse.de>
3562
3563         * config/i386/i386.c (ix86_comp_type_attributes): Check for
3564         regparm attributes.
3565
3566 2004-02-24  Richard Henderson  <rth@redhat.com>
3567
3568         * toplev.c (dump_file_tbl): Rename from dump_file.
3569         * bb-reorder.c, bt-load.c, cfgcleanup.c, cfglayout.c, cfgloopanal.c,
3570         cfgloopmanip.c, cfgrtl.c, config/arm/arm.c, config/frv/frv.c,
3571         config/i386/i386.c, config/ia64/ia64.c, config/mips/mips.c,
3572         config/sh/sh.c, cse.c, flow.c, ifcvt.c, loop-iv.c, loop-unroll.c,
3573         loop-unswitch.c, output.h, predict.c, profile.c, ra-build.c,
3574         ra-colorize.c, ra-debug.c, ra-rewrite.c, ra.c, regrename.c, reload1.c,
3575         toplev.c, tracer.c, value-prof.c, var-tracking.c, web.c:
3576         s/rtl_dump_file/dump_file/g.
3577
3578 2004-02-24  Aldy Hernandez  <aldyh@redhat.com>
3579
3580         * config/rs6000/spe.md (spe_fix_truncsfsi2): Delete.
3581         (spe_fixuns_truncsfsi2): Delete.
3582
3583         * config/rs6000/rs6000.md (fix_truncsfsi2): Delete.
3584         (fixuns_truncsfsi2): Delete.
3585
3586 2004-02-24  Josef Zlomek  <zlomekj@suse.cz>
3587
3588         PR/14240
3589         * rtlanal.c (replace_label): Fix replacing labels in constant pool.
3590
3591 2004-02-24  Geoffrey Keating  <geoffk@apple.com>
3592
3593         * config/darwin.h (TARGET_HAS_F_SETLKW): Define.
3594
3595 2004-02-24  Jason Merrill  <jason@redhat.com>
3596
3597         * tree.c (check_qualified_type): New fn.
3598         (get_qualified_type): Use it.  If type already has the desired
3599         quals, just return it.
3600         * tree.h: Declare it.
3601
3602 2003-02-24  Sanjiv Kumar Gupta  <sanjivg@noida.hcltech.com>
3603
3604         * target-def.h (TARGET_SCHED_INIT_GLOBAL,
3605         TARGET_SCHED_FINISH_GLOBAL): New macros.
3606
3607         * target.h (md_init_global, md_finish_global): Function
3608         declarations corresponding to new target macros.
3609
3610         * haifa-sched.c (sched_init, sched_finish): Allow target to
3611         call the new schedular hooks.
3612
3613         * flow.c (recompute_reg_usage): Add PROP_DEATH_NOTES flag in
3614         call to update_life_info.
3615
3616         * config/sh/sh.h (OVERRIDE_OPTIONS): Re-enable
3617         flag_schedule_insns for SH4.
3618
3619         * config/sh/sh.c (sh_md_init_global, sh_md_finish_global,
3620         find_set_regmode_weight, find_insn_regmode_weight,
3621         find_regmode_weight), sh_md_init, sh_dfa_new_cycle,
3622         sh_variable_issue, high_pressure, ready_reorder,
3623         rank_for_reorder, swap_reorder, sh_reorder, sh_reorder2): New
3624         functions used to throttle the insn movement in first
3625         scheduling pass for SH.
3626
3627         * gcc/doc/tm.texi: Document TARGET_SCHED_INIT_GLOBAL and
3628         TARGET_SCHED_FINISH_GLOBAL.
3629
3630 2004-02-24  Alexandre Oliva  <aoliva@redhat.com>
3631
3632         Implement FR-V FDPIC ABI support for frv-uclinux and frv-linux.
3633         2004-02-05  Alexandre Oliva  <aoliva@redhat.com>
3634         * config/frv/frv.c (frv_emit_movsi): Use GOT relocations for
3635         symbols in sections named by the user.
3636         2004-01-30  Alexandre Oliva  <aoliva@redhat.com>
3637         * config/frv/linux.h (TARGET_OS_CPP_BUILTINS): New.
3638         2004-01-27  Alexandre Oliva  <aoliva@redhat.com>
3639         * config.gcc (frv-*-*linux*): Handle like *-*-linux*.
3640         * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Remove, obviated by
3641         the above.
3642         2004-01-20  Alexandre Oliva  <aoliva@redhat.com>
3643         * config/frv/frv.md (symGOT2reg_hilo, symGOTOFF2reg_hilo): Add
3644         one more pseudo to further improve code generation.
3645         2004-01-19  Alexandre Oliva  <aoliva@redhat.com>
3646         * config/frv/frv.md (movdi_ldd): Introduce explicit indirection
3647         inside UNSPEC.
3648         2004-01-16  Alexandre Oliva  <aoliva@redhat.com>
3649         * config/frv/frv.c (frv_legitimate_address_p): Added
3650         allow_double_reg_p argument.  Adjust all callers.  Use it to
3651         decide whether to enable double-register indirect addressing.
3652         (frv_funcdesc_alias_set): Remove.
3653         (frv_expand_fdpic_call): Force non-SYMBOL_REF operand into
3654         register.  Emit movdi_ldd.
3655         (ldd_address_operand): New.
3656         * config/frv/frv-protos.h (frv_legitimate_address_p): Adjust.
3657         * config/frv/frv.h (GO_IF_LEGITIMATE_ADDRESS): Likewise.
3658         (PREDICATE_CODES): Add ldd_address_operand.
3659         * config/frv/frv.md (movdi_ldd): New.
3660         (symGOT2reg_hilo, symGOTOFF2reg_hilo): Use separate pseudo for
3661         intermediate computations if possible.
3662         (symGOTOFF2reg_i): Fix harmless typo.
3663         2003-12-18  Alexandre Oliva  <aoliva@redhat.com>
3664         * unwind-dw2-fde-glibc.c (_Unwind_IteratePhdrCallback): Cast
3665         relocated p_vaddr to vaddr type.
3666         * config/frv/frv-protos.h (frv_expand_fdpic_call): Return void.
3667         * config/frv/frv.c (frv_get_funcdesc_alias_set): New.
3668         (frv_expand_fdpic_call): Propagate incoming MEM's expr to funcdesc
3669         MEM, or use a funcdesc alias set.  Use regular move instead of
3670         ldd.
3671         (dbl_memory_one_insn_operand): Recognize function descriptors by
3672         type or by alias set, and don't split them.
3673         * config/frv/frv.md (call, call_value): Never use call_internal
3674         for fdpic.
3675         (call_internal, call_value_internal): Never match for FDPIC.
3676         (call_fdpicdi, call_fdpicsi, call_value_fdpicdi,
3677         call_value_fdpicsi): Require FDPIC.
3678         (ldd): Removed.
3679         2003-12-17  Alexandre Oliva  <aoliva@redhat.com>
3680         * config/frv/frv.h (CRT_GET_RFIB_DATA): Define for __FRV_FDPIC__.
3681         * unwind-dw2-fde-glibc.c: Don't include elf-fdpic.h any more.
3682         (_Unwind_IteratePhdrCallback): Adjust type of load_base for FRV
3683         FDPIC.  Compute data base address.
3684         * config/frv/linux.h (SUBTARGET_DRIVER_SELF_SPECS): Enable -mfdpic
3685         before the other self-specs are processed.
3686         * config/frv/t-linux (CRTSTUFF_T_CFLAGS, TARGET_LIBGCC2_CFLAGS):
3687         Build with -fPIC.
3688         2003-12-15  Alexandre Oliva  <aoliva@redhat.com>
3689         * unwind-dw2-fde-glibc.c: Don't include bits/elf-fdpic.h if
3690         inhibit_libc is defined.
3691         2003-12-12  Alexandre Oliva  <aoliva@redhat.com>
3692         * unwind-dw2-fde-glibc.c: Include bits/elf-fdpic.h for
3693         __FRV_FDPIC__.
3694         (__RELOC_POINTER): Define.
3695         (_Unwind_IteratePhdrCallback): Use it.
3696         * config/frv/frv.h (Twrite): Define.
3697         (TRANSFER_FROM_TRAMPOLINE): Use it.
3698         * config/frv/linux.h (INVOKE__main): Undefine.
3699         (Twrite): Override.
3700         2003-12-05  Richard Sandiford  <rsandifo@redhat.com>
3701         * doc/invoke.texi (-mlong-calls, -mlinked-fp): Document FRV options.
3702         (-mlibrary-pic): Emphasize that this option generates EABI code.
3703         (-mcpu): Add fr550.
3704         (-mpack): Remove.
3705         2003-11-30  Alexandre Oliva  <aoliva@redhat.com>
3706         * config/frv/frv.c (int_2word_operand): Reject LABELs, SYMBOL_REFs
3707         and CONSTs in FDPIC mode.
3708         * gcc/config.gcc (with_cpu): Default to fr400 on frv-*-*linux*.
3709         2003-11-29  Richard Sandiford  <rsandifo@redhat.com>
3710         * config/frv/frv.c (move_source_operand): Don't accept symbolic
3711         constants.
3712         * config/frv/frv.md (*movhi_internal, *movsi_internal): Use an 'n'
3713         rather than 'i' constraint for the 2-instruction alternative.
3714         (*movsi_2word): New, incorporating existing int_2word_operand splitter.
3715         2003-11-29  Richard Sandiford  <rsandifo@redhat.com>
3716         * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Q): Renamed from
3717         EXTRA_CONSTRAINT_FOR_Y.
3718         (EXTRA_CONSTRAINT): Remove handling of 'Y'.
3719         * config/frv/frv.md (*movsi_internal): Remove 'Q' constraint.
3720         (addsi3): Change 'Y' constraint to 'Q'.
3721         2003-11-27  Richard Sandiford  <rsandifo@redhat.com>
3722         * reload.c (CONST_POOL_OK_P): New macro.
3723         (find_reloads): Use it to decide whether a constant can be forced
3724         into memory.
3725         * config/frv/frv.h (LEGITIMATE_PIC_OPERAND_P): Return true if the
3726         constant satisfies got12_operand.
3727         (frv_cannot_force_const_mem): Always return true for TARGET_FDPIC.
3728         (frv_legitimate_address_p): Check for valid unspec offsets using
3729         got12_operand rather than frv_legitimate_fdpic_operand_p.
3730         (frv_legitimate_fdpic_operand_p): Delete.
3731         (frv_emit_movsi): Abort if we try to use the FDPIC register during
3732         or after reload.
3733         (frv_legitimate_constant_p): Return LEGITIMATE_PIC_OPERAND_P if
3734         TARGET_FDPIC.
3735         * config/frv/frv.md (*movdf_double): Add alternatives for CONST_DOUBLE.
3736         2003-11-19  Richard Sandiford  <rsandifo@redhat.com>
3737         * config/frv/frv-protos.h (fdpic_operand, fdpic_got12_operand)
3738         (frv_fdpic_fptr_operand): Don't declare here.
3739         * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Y): Call got12_operand
3740         rather than fdpic_got12_operand.
3741         (PREDICATE_CODES): Remove symbolic_operand entry.  Add entries for
3742         got12_operand and const_unspec_operand.
3743         * config/frv/frv.c (got12_operand): Renamed from fdpic_got12_operand.
3744         (gpr_or_int12_operand, dbl_memory_one_insn_operand): Update calls.
3745         (symbolic_operand): Remove.
3746         (const_unspec_operand): New predicate.
3747         * config/frv/frv.md (*movsi_got): Use got12_operand.
3748         (*movsi_high_got, *movsi_lo_sum_got): Use const_unspec_operand.
3749         2003-11-18  Richard Sandiford  <rsandifo@redhat.com>
3750         * config/frv/frv-protos.h (frv_output_addr_const_extra): Remove.
3751         * config/frv/frv.h (OUTPUT_ADDR_CONST_EXTRA): Remove definition.
3752         * config/frv/frv.c (frv_unspec): New structure.
3753         (frv_small_data_reloc_p, frv_const_unspec_p): New functions.
3754         (frv_print_operand_memory_reference): Use frv_const_unspec_p to
3755         validate CONST indices.  Use frv_output_const_unspec to print them.
3756         (frv_print_operand): Update call to unspec_got_name.  Use
3757         frv_output_const_unspec to print constant unspecs.
3758         (frv_legitimate_fdpic_operand_p): Return true if frv_const_unspec_p.
3759         Reject UNSPECs otherwise.
3760         (unspec_got_name): Take the relocation number as argument, not an
3761         rtx containing it.
3762         (frv_output_addr_const_extra): Remove, replacing with...
3763         (frv_output_const_unspec): ...this new function.
3764         (frv_find_base_term): Use frv_const_unspec_p & frv_small_data_reloc_p.
3765         (gpr_or_int12_operand): Use fdpic_got12_operand.
3766         (dbl_memory_one_insn_operand): Likewise.
3767         (fdpic_got12_operand): Use frv_const_unspec_p.
3768         (frv_emit_movsi): Use frv_const_unspec_p to check for CONSTs that
3769         are already legitimate.  Use frv_small_data_reloc_p when deciding
3770         whether to use HIGH/LO_SUM for R_FRV_GOTOFF12 and R_FRV_GPREL12.
3771         2003-11-18  Alexandre Oliva  <aoliva@redhat.com>
3772         * config/frv/t-linux (SHLIB_MAPFILES): Override so as to export...
3773         * config/frv/libgcc-frv.ver: ... frv-specific symbols.  New file.
3774         * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
3775         label, for real this time.
3776         * config/frv/frv.c (frv_local_funcdesc_p): Update to new
3777         representation of visibility.
3778         (fdpic_got12_operand, symbolic_operand): Mark unused arguments as
3779         such.
3780         2003-11-17  Richard Sandiford  <rsandifo@redhat.com>
3781         * config/frv/frv.h (MASK_LINKED_FP, TARGET_LINKED_FP): New macros.
3782         (TARGET_SWITCHES): Add -mlinked-fp and -mno-linked-fp.
3783         * config/frv/frv.c (frv_override_options): Set MASK_LINKED_FP unless
3784         it was explicitly disabled.
3785         (frv_stack_info): There is no need to save the link register in every
3786         frame unless TARGET_LINKED_FP is true.
3787         (frv_frame_pointer_required): If !TARGET_LINKED_FP, only require a
3788         frame pointer if the stack pointer might change value.
3789         (frv_return_addr_rtx): Check and process "count" argument.
3790         2003-11-14  Richard Sandiford  <rsandifo@redhat.com>
3791         * config/frv/frv-protos.h (frv_legitimize_address): Remove.
3792         (frv_find_base_term): Declare.
3793         * config/frv/frv.h (LEGITIMIZE_ADDRESS): Do nothing.
3794         (FIND_BASE_TERM): Define.
3795         (PREDICATE_CODES): Remove pic_register_operand, pic_symbolic_operand,
3796         small_data_register_operand, small_data_symbolic_operand.  Add
3797         symbolic_operand.
3798         * config/frv/frv.c (const_small_data_p, plus_small_data_p): Delete.
3799         (frv_print_operand_memory_reference, output_move_single): Remove
3800         special handling for unlegitimized sdata addresses.
3801         (frv_legitimate_address_p): Don't allow sums of SDA_BASE_REG
3802         and symbolic addresses.
3803         (frv_legitimize_address, frv_legitimize_fdpic_address): Delete.
3804         (frv_find_base_term): New function.
3805         (int_2word_operand): Check specifically for symbolic address constants.
3806         (pic_register_operand, pic_symbolic_operand): Delete.
3807         (small_data_register_operand, small_data_symbolic_operand): Delete.
3808         (dbl_memory_one_insn_operand): Don't call plus_small_data_p.
3809         Allow UNSPEC_GOT constants if !TARGET_FDPIC.
3810         (move_source_operand): Only accept CONSTs if they're a two-insn
3811         symbolic constant.
3812         (fdpic_got12_operand): Don't require TARGET_FDPIC.
3813         (frv_emit_movsi): Legitimize sdata and -mlibrary-pic addresses
3814         using gen_symGOTOFF2reg*.
3815         (frv_ifcvt_rewrite_mem): Remove (plus gr16 ...) special cases.
3816         (frv_rtx_costs): Give all MEM addresses a cost of 0.  Give MEMs
3817         themselves a cost of 3 insns.
3818         * config/mips/mips.md (*movsi_got): Allow for !TARGET_FDPIC too.
3819         Change predicate to symbolic_operand.
3820         (*movsi_high_got, *movsi_lo_sum_got): Likewise.
3821         (*movsi_lda_sdata): Delete.
3822         (*movsi_pic, movsi_high_pic, movsi_lo_sum_pic): Delete.
3823         2003-11-05  Alexandre Oliva  <aoliva@redhat.com>
3824         * config.gcc: Add t-slibgcc-elf-ver and support --with-cpu for
3825         frv-*-*linux*.
3826         * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
3827         label.
3828         * config/frv/frv.h (DRIVER_SELF_SPECS): Add blank before
3829         -multilib-library-pic.
3830         (LINK_SPEC): Add -z text for -mfdpic.
3831         * config/frv/frvbegin.c (__ROFIXUP_LIST__): Don't define on FDPIC.
3832         * config/frv/frvend.c (__ROFIXUP_END__): Likewise.
3833         * config/frv/linux.h (STARTFILE_SPEC, ENDFILE_SPEC, LINK_SPEC):
3834         Override.
3835         (OPTION_DEFAULT_SPECS, HAS_INIT_SECTION, INIT_SECTION_ASM_OP,
3836         FINI_SECTION_ASM_OP, CRT_CALL_STATIC_FUNCTION): Define.
3837         * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Use
3838         crtstuff-generated files.
3839         2003-10-31  Alexandre Oliva  <aoliva@redhat.com>
3840         * config.gcc: Add frv-*-*linux*.
3841         * config/frv/linux.h, config/frv/t-linux: New.
3842         2003-10-06  Alexandre Oliva  <aoliva@redhat.com>
3843         * config/frv/frv.h (LINK_SPEC): Pass -melf32frvfd to the linker
3844         when -mfdpic even if a linker script is explicitly listed.
3845         2003-10-02  Alexandre Oliva  <aoliva@redhat.com>
3846         * config/frv/frv.c (frv_override_options): Clear asm_out
3847         unaligned_op for SImode on FDPIC.
3848         (frv_emit_movsi): Use compute_reloc_for_constant to compute the
3849         argument passed to decl_readonly_section.
3850         (frv_assemble_integer): Revert 2003-09-30's change, but make the
3851         whole block run with FDPIC even with -fno-PIC.
3852         2003-10-02  Alexandre Oliva  <aoliva@redhat.com>
3853         * config/frv/frv.c (frv_cannot_force_const_mem): Don't force
3854         symbol or label plus offset to memory.
3855         (frv_emit_movsi): Emit GPREL only if -mgprel-ro.  Emit 32-bit
3856         GOTOFF and GPREL for LABEL_REF.
3857         * config/frv/frv.h (DRIVER_SELF_SPECS): Add -mgprel-ro with
3858         -mfdpic unless -mno-gprel-ro, -fpic or -fpie.
3859         (MASK_GPREL_RO, TARGET_GPREL_RO): New.
3860         (TARGET_SWITCHES): Added gprel-ro and no-gprel-ro.
3861         * doc/invoke.texi: Document them.
3862         2003-09-30  Alexandre Oliva  <aoliva@redhat.com>
3863         * config/frv/frv-protos.h (frv_gen_GPsym2reg): Declare.
3864         (frv_splittable_got_operand): Removed.
3865         * config/frv/frv.c (frv_cannot_force_const_mem): Reject HIGH and
3866         LO_SUM.  Add comments.
3867         (frv_override_options): Moved enabling of FDPIC to
3868         DRIVER_SELF_SPECS.  Don't enable MASK_DWORD.
3869         (frv_local_funcdesc_p): Remove unnecessary heck for flag_pie.
3870         (frv_legitimize_fdpic_address): Don't duplicate logic in
3871         frv_emit_movsi.
3872         (frv_gen_GPsym2reg): New.
3873         (unspec_got_name): Added gprel.
3874         (frv_expand_fdpic_call): Add support for inlining PLTs.
3875         (fdpic_fptr_operand): Renamed from frv_fdpic_fptr_operand.
3876         (gpr_or_int12_operand): Added GPREL12.
3877         (pic_symbolic_operand): Match even if !flag_pic for FDPIC.
3878         (small_data_symbolic_operand): Fail if FDPIC.
3879         (fdpic_splittable_got_operand): Removed.
3880         (fdpic_got12_operand): Added GPREL12.
3881         (frv_emit_movsi): Reorganize to avoid duplication.  Emit GPREL
3882         when appropriate.  Fix sdata GOTOFF.
3883         (frv_legitimate_constant_p): Require legitimate PIC operand for
3884         FDPIC with pic, but only a legitimate fdpic operand for non-pic.
3885         (frv_assemble_integer): Move FDPIC funcdesc handling out of
3886         flag_pic case.
3887         (frv_asm_out_constructor, frv_asm_out_destructor): Abort if
3888         frv_assemble_integer fails.
3889         * config/frv/frv.h (DRIVER_SELF_SPECS): New.
3890         (SUBTARGET_DRIVER_SELF_SPECS): New.
3891         (ASM_SPEC): Don't pass -mno-fdpic.
3892         (LINK_SPEC): Pass -melf32frvfd for FDPIC.
3893         (MASK_INLINE_PLT, TARGET_INLINE_PLT): New.
3894         (TARGET_SWITCHES): Add -minline-plt, -mno-inline-plt and
3895         -multilib-library-pic.
3896         (PREDICATE_CODES): Added fdpic_operand, fdpic_fptr_operand,
3897         condexec_si_media_operator, condexec_sf_add_operator and
3898         condexec_sf_conv_operator.  Removed condexec_sf_binary_operator
3899         and condexec_sf_unary_operator.
3900         * config/frv/frv.md (R_FRV_GPREL12, R_FRV_GPRELHI, R_FRV_GPRELLO):
3901         New.
3902         (movsi_got, movsi_high_got, movsi_lo_sum_got): Move before
3903         movsi_internal.  Give them internal names.  movsi_got has type
3904         int.
3905         (fdpic got splitters): Remove.
3906         (symGPREL2reg, symGPREL2reg_hilo): New.
3907         * config/frv/t-frv (MULTILIB_MATCHES): Don't map -fpic and -fPIC
3908         to -mlibrary-pic.  Map -multilib-library-pic to it.
3909         * doc/invoke.texi: -mfdpic, -minline-plt, -multilib-library-pic:
3910         Document.
3911         2003-09-28  Alexandre Oliva  <aoliva@redhat.com>
3912         * config/frv/frv.c (frv_function_symbol_referenced_p): Declare.
3913         (TARGET_CANNOT_FORCE_CONST_MEM): Define to...
3914         (frv_cannot_force_const_mem): New function.
3915         (const_small_data_p, plus_small_data_p): Update comments on sdata
3916         on FDPIC.
3917         (frv_override_options): Set flag_pie for FDPIC too.
3918         (frv_conditional_register_usage): Mark gr16 and gr17 as non-fixed,
3919         call-saved registers on FDPIC.
3920         (frv_stack_info): Don't preserve the PIC register on FDPIC, and
3921         don't force LR to be preserved.
3922         (frv_expand_prologue): Likewise.
3923         (frv_asm_output_mi_thunk): Use 12-bit funcdesc gotoff for -fpic.
3924         (frv_frame_pointer_required): Don't force it just because the
3925         FDPIC register is used.
3926         (frv_legitimate_address_p) <CONST>: Accept a legitimate FDPIC
3927         operand only if !condexec_p.
3928         (frv_legitimize_address): Return the FDPIC-legitimized address.
3929         Don't match small data here on FDPIC.
3930         (frv_legitimate_fdpic_operand_p): Don't accept unadorned function
3931         symbols.  Use TRUE/FALSE instead of 1/0.
3932         (frv_local_funcdesc_p): New.
3933         (frv_legitimize_fdpic_address): Rewrite to use GOTOFF and 12-bit
3934         immediates when possible.
3935         (pic_symbolic_operand): Accept SYMBOL_REFs and CONSTs in FDPIC.
3936         (dbl_memory_one_insn_operand): Accept addresses that add a REG and
3937         an UNSPEC_GOT.
3938         (frv_emit_movsi): Handle FDPIC before small data.  Use GOTOFF and
3939         12-bit immediates when possible.
3940         (frv_legitimate_constant_p): In FDPIC, reject SImode operands that
3941         are not legitimate pic operands.
3942         (frv_in_small_data_p): Re-enable for FDPIC.
3943         * config/frv/frv.h (SDA_BASE_REG): Remove comment about FDPIC.
3944         (FRV_GLOBAL_P): Removed.
3945         * config/frv/frv.md: Add modes to CONSTs.
3946         (movsi_got): New.
3947         (movsi_lo_sum_got): Use separate matches instead of match_dup.
3948         (movsi_high_pic, movsi_lo_sum_pic): Match on non-FDPIC only.
3949         (fdpic splittable operations): Match on flag_pic != 1.
3950         2003-09-22  Alexandre Oliva  <aoliva@redhat.com>
3951         * config/frv/frv.c (frv_asm_out_constructor,
3952         frv_asm_out_destructor): Pass to frv_assemble_integer the size in
3953         bytes, not bits.
3954         2003-09-19  Alexandre Oliva  <aoliva@redhat.com>
3955         * config/frv/frv.c (frv_assemble_integer): Reject complex
3956         expressions referencing function SYMBOL_REFs.
3957         * config/frv/frv.c (frv_function_symbol_referenced_p): New.
3958         (move_source_operand): Reject CONSTs that reference function
3959         SYMBOL_REFs on FDPIC.
3960         (frv_emit_movsi): If we get such a CONST, break it up.
3961         * config/frv/frv.h (CPP_SPEC): Define __FRV_FDPIC__ for -mfdpic.
3962         (TRANSFER_FROM_TRAMPOLINE): Use different definitions for FDPIC.
3963         * config/frv/frv.c (frv_print_operand) <I>: Recognize PLUS without
3964         MEM.
3965         (frv_assemble_integer): Don't use funcdesc for LABEL_REFs.
3966         (frv_trampoline_size): Increase for FDPIC.
3967         * config/frv/frv.h (TRAMPOLINE_ALIGNMENT): Bump to 64 for FDPIC.
3968         (TRANSFER_FROM_TRAMPOLINE): Handle FDPIC trampolines.
3969         * config/frv/frv.c (frv_legitimize_fdpic_address, frv_emit_movsi):
3970         Disable use of GOTOFF for now.
3971         (const_small_data_p, plus_small_data_p, frv_in_small_data_p):
3972         Disable use of small data in FDPIC for now.
3973         (frv_asm_output_mi_thunk): Implement for FDPIC.
3974         * config/frv/frv.h (SDA_BASE_REG): Set to -1 with FDPIC.
3975         * config/frv/frv.c (frv_asm_out_constructor): Use
3976         frv_assemble_integer for FDPIC pointers.
3977         (frv_asm_out_destructor): Likewise.
3978         * config/frv/frv.md (ldd): Fix order of operands.  Use
3979         address_operand for input.
3980         2003-09-18  DJ Delorie  <dj@redhat.com>
3981         * config/frv/frv.c (frv_legitimate_fdpic_operand_p): Remove UNSPEC_PIC.
3982         (unspec_got_name): Correct typo.
3983         (frv_emit_movsi): Pre-expand splittable GOTs.
3984         (frv_expand_fdpic_call): Rename gen_lddi to gen_ldd.
3985         * config/frv/frv.md (lddi): Fix syntax error, rename to ldd.
3986         (symGOT2reg_hilo, symGOTOFF2reg_hilo): New.
3987         * config/frv/t-frv: Add -mfdpic multilibs.
3988         * config/frv/frv.h (ASM_SPEC): Pass -mfdpic/-mno-fdpic.
3989         (TARGET_SWITCHES): Add -mno-fdpic, fix documentation.
3990         * config/frv/frv.c (frv_override_options): -mfdpic assumes
3991         flag_pic, default to 32-bit pics, require DWORD ops.
3992         (frv_override_options): Add W and Z constraints.
3993         (frv_expand_prologue): No pic prologue for -mfdpic.
3994 &nbs