]> git.ipfire.org Git - thirdparty/gcc.git/blob - gcc/ChangeLog
configure.ac: Rearrange some threading code for clarity; add section comment.
[thirdparty/gcc.git] / gcc / ChangeLog
1 2004-02-29 Nathanael Nerode <neroden@gcc.gnu.org>
2
3 * configure.ac: Rearrange some threading code for clarity;
4 add section comment.
5 * configure: Regenerate.
6
7 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
8
9 * passes.c, config/frv/frv.c, config/sh/sh.c: Fix comment
10 typos.
11 * doc/cppopts.texi: Fix a typo.
12
13 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
14
15 * config/i386/i386.md: Fix formatting.
16
17 2004-02-29 Nathanael Nerode <neroden@gcc.gnu.org>
18
19 * configure.ac: Add some comments delineating sections of code.
20
21 * doc/install.texi: Note that libada uses autoconf 2.57 also.
22
23 * doc/install.texi: Fix idiot typo in previous commit.
24
25 * doc/install.texi: Update for conversion of intl to autoconf 2.57.
26
27 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
28
29 * config/h8300/h8300.md: Add comments about peephole2's.
30
31 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
32
33 * config/h8300/h8300.md: Tweak operand numbers of some
34 peephole2's.
35
36 2004-02-29 Kazu Hirata <kazu@cs.umass.edu>
37
38 * config/h8300/h8300.md: Tweak comments about peephole2's.
39
40 2004-02-29 Waldek Hebisch <hebisch@math.uni.wroc.pl>
41
42 PR middle-end/14203
43 * function.c (uninitialized_vars_warning): Use DECL_RTL_SET_P
44 instead of testing whether DECL_RTL is not NULL.
45
46 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
47
48 * config/sh/sh.c: Fix formatting.
49
50 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
51
52 * config/sh/sh.c: Convert to ISO-C.
53
54 2004-02-28 Andrew Pinski <pinskia@physics.uc.edu>
55
56 * c-typeck.c (tagged_types_tu_compatible_p): Fix pasto in
57 my previous patch.
58
59 * config/darwin.h (machopic_finish): Output stub even if the
60 symbol is already defined.
61
62 2004-02-28 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
63
64 * pa64-hpux.h (LIB_SPEC): Fix linking under HP-UX 11.00 with -p and -pg.
65
66 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
67
68 * genattr.c (main): Don't define
69 TRADITIONAL_PIPELINE_INTERFACE or DFA_PIPELINE_INTERFACE.
70 * system.h (TRADITIONAL_PIPELINE_INTERFACE): Poison.
71 (DFA_PIPELINE_INTERFACE): Likewise.
72 * doc/tm.texi (TRADITIONAL_PIPELINE_INTERFACE): Remove.
73 (DFA_PIPELINE_INTERFACE): Likewise.
74
75 2004-02-28 Richard Sandiford <rsandifo@redhat.com>
76
77 * config/mips/mips.md (tstsi, tstdi): Delete.
78
79 2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
80
81 * config/mips/mips.c (override_options): Remove an obsolete
82 duplicate definition of the "e" constraint.
83 * config/mips/mips.h: Update a comment accordingly.
84
85 2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
86
87 * config/mips/mips.md: Complete the unfinished R4000
88 multiply/shift errata workaround. Improve documentation.
89 (hazard): Use TARGET_FIX_R4000 to decide whether an "imul" instruction
90 has a hilo hazard.
91 (mulsi3, mulsi3_internal, mulsi3_r4000): Use TARGET_FIX_R4000.
92 (muldi3, muldi3_internal): Likewise.
93 (muldi3_internal2): Remove, replacing with...
94 (muldi3_mult3, muldi3_r4000): ...these new patterns.
95 (mulsidi3): Take the errata into account.
96 (mulsidi3_32bit): Remove, replacing with...
97 (mulsidi3_32bit_internal, mulsidi3_32bit_r4000): ...these new patterns.
98 (mulsidi3_64bit, mulsidi3_64bit_parts): Disable if TARGET_FIX_R4000.
99 (umulsidi3): Take the errata into account.
100 (umulsidi3_32bit): Remove, replacing with..
101 (umulsidi3_32bit_internal, umulsidi3_32bit_r4000): ...these patterns.
102 (umulsi3_highpart, umulsi3_highpart_internal): Disable if
103 TARGET_FIX_R4000.
104 (smulsi3_highpart, smulsi3_highpart_internal): Likewise.
105 (smuldi3_highpart, umuldi3_highpart): Likewise.
106 * doc/invoke.texi: Document the errata workaround.
107
108 2004-02-28 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
109
110 * config/mips/mips-protos.h (mips_idiv_insns): Declare.
111 * config/mips/mips.h (MASK_FIX_SB1): Bump.
112 (MASK_FIX_R4000, TARGET_FIX_R4000): New macros.
113 (TARGET_SWITCHES): Add -mfix-r4000 and -mno-fix-r4000.
114 * config/mips/mips.c (mips_idiv_insns): New function.
115 (override_options): Make -march=r4000 imply -mfix-r4000 by default.
116 (mips_output_division): Add a workaround for the R4000 divide/shift
117 errata.
118 * config/mips/mips.md (length): Use mips_idiv_insns() to calculate
119 the length of an "idiv" instruction.
120 * doc/invoke.texi: Document the new switches.
121
122 2004-02-28 Kazu Hirata <kazu@cs.umass.edu>
123
124 * doc/tm.texi (IS_COSTLY_DEPENDENCE): Change to
125 TARGET_SCHED_IS_COSTLY_DEPENDENCE.
126
127 2004-02-28 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
128
129 PR optimization/14229
130 * cfgrtl.c (rtl_tidy_fallthru_edge): Do not fail for !onlyjump jump.
131
132 2004-02-28 Eric Botcazou <ebotcazou@act-europe.fr>
133
134 * fold-const.c (fold): Strip NOPs that change the signedness
135 for RSHIFT too. Expand comment.
136
137 2004-02-27 Ian Lance Taylor <ian@wasabisystems.com>
138
139 PR optimization/7871
140 * flow.c (mark_set_1): Don't add LOG_LINKS for global registers
141 from or to call insns.
142
143 2004-02-27 Eric Botcazou <ebotcazou@libertysurf.fr>
144
145 PR optimization/7871
146 * flow.c (propagate_one_insn): Interpret calls as setting global
147 registers, not merely clobbering them.
148
149 2004-02-27 Dale Johannesen <dalej@apple.com>
150
151 * config/darwin.c (machopic_output_possible_stub_label): Remove.
152 config/darwin-protos.h: Ditto.
153 config/darwin.h: Remove call to it.
154 * combine.c (distribute_notes): Do not place a REG_DEAD note
155 when value is both set and used.
156
157 2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
158
159 * config/h8300/fixunssfsi.c (__fixunssfsi): Enable on H8/300
160 as well.
161 * config/h8300/lib1funcs.asm (___fixunssfsi): Remove.
162 * config/h8300/t-h8300 (LIB1ASMFUNCS): Remove _fixunssfsi_asm.
163
164 2004-02-27 Andrew Pinski <apinski@apple.com>
165
166 * c-typeck.c (tagged_types_tu_compatible_p) <ENUMERAL_TYPE>:
167 Speedup common case of the type values being in the same order.
168
169 2004-02-27 Steve Ellcey <sje@cup.hp.com>
170
171 * config/ia64/ia64.h (no-inline-float-divide): New option.
172 * config/ia64/ia64.h (no-inline-int-divide): New option.
173 * config/ia64/ia64.h (no-inline-sqrt): New option.
174 (TARGET_DEFAULT): Add MASK_INLINE_FLOAT_DIV_THR to define.
175 * config/ia64/hpux.h (TARGET_DEFAULT): Ditto.
176 * config/ia64/ia64.c (ia64_override_options): Modify error
177 checking for inlined division/sqrt.
178
179 2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
180
181 * bb-reorder.c, cfgbuild.c, diagnostic.c, explow.c, profile.c,
182 ra-build.c, read-rtl.c, tracer.c, unwind-dw2-fde-glibc.c,
183 value-prof.c, config/darwin-protos.h, config/frv/frv-abi.h,
184 config/i386/pmmintrin.h, config/pa/pa-hpux.h: Update
185 copyright.
186
187 2004-02-27 Paul Brook <paul@codesourcery.com>
188
189 * function.c (assign_parms): Don't count pretend args for alignment.
190
191 2004-02-27 Richard Henderson <rth@redhat.com>
192
193 * passes.c: New file.
194 * Makefile.in (OBJS-common): Add it.
195 * diagnostic.c (rtl_dump_and_exit): Move decl ...
196 * flags.h (rtl_dump_and_exit): ... here.
197 * output.h (size_directive_output, last_assemble_variable_decl):
198 Move from toplev.c.
199 * rtl.h (reg_alloc): Move from toplev.c.
200 * toplev.c (HAVE_conditional_execution, DUMPFILE_FORMAT,
201 struct dump_file_info, enum dump_file_index, dump_file_tbl,
202 open_dump_file, close_dump_file, rest_of_decl_compilation,
203 rest_of_type_compilation, rest_of_handle_final,
204 rest_of_handle_delay_slots, rest_of_handle_stack_regs,
205 rest_of_handle_variable_tracking, rest_of_handle_machine_reorg,
206 rest_of_handle_new_regalloc, rest_of_handle_old_regalloc,
207 rest_of_handle_regrename, rest_of_handle_reorder_blocks,
208 rest_of_handle_sched, rest_of_handle_sched2, rest_of_handle_regmove,
209 rest_of_handle_tracer, rest_of_handle_if_conversion,
210 rest_of_handle_if_after_combine, rest_of_handle_web,
211 rest_of_handle_branch_prob,
212 rest_of_handle_value_profile_transformations, rest_of_handle_cfg,
213 rest_of_handle_addressof, rest_of_handle_sibling_calls,
214 rest_of_handle_jump_bypass, rest_of_handle_inlining,
215 rest_of_handle_null_pointer, rest_of_handle_combine,
216 rest_of_handle_life, rest_of_handle_cse, rest_of_handle_cse2,
217 rest_of_handle_gcse, rest_of_handle_loop_optimize,
218 rest_of_handle_loop2, rest_of_compilation): Move to passes.c.
219 (decode_d_option): Use enable_rtl_dump_file.
220 (compile_file, finalize, do_compile): Move profile+combine+graph
221 cleanup to finish_optimization_passes.
222 * toplev.h (init_optimization_passes, finish_optimization_passes,
223 enable_rtl_dump_file): Declare.
224
225 2004-02-27 Eric Botcazou <ebotcazou@act-europe.fr>
226 Roger Sayle <roger@eyesopen.com>
227
228 * fold-const.c (fold): Revert 2004-02-25 change. Use the original
229 operands to build a tree with swapped operands.
230 * expr.c (expand_expr_real) <MAX_EXPR>: Consistently use the
231 'unsignedp' predicate to specify the signedness.
232
233 2004-02-27 Kazu Hirata <kazu@cs.umass.edu>
234
235 * c-decl.c, c-ppoutput.c, combine.c, cppfiles.c, dwarf2out.c,
236 expr.c, fold-const.c, gcc.c, haifa-sched.c, loop-iv.c,
237 params.def, read-rtl.c, rtl.c, rtlanal.c, toplev.c: Fix
238 comment typos and formatting. Follow spelling conventions.
239
240 2004-02-26 Aldy Hernandez <aldyh@redhat.com>
241
242 * config/rs6000/rs6000.md: Add fixuns_truncsfsi2 and
243 fix_truncsfsi2.
244
245 * config/rs6000/spe.md: Delete spe_efsctuiz.
246 Add spe_fixuns_truncsfsi2.
247 Add spe_fix_truncsfsi2.
248
249 2004-02-26 Eric Christopher <echristo@redhat.com>
250
251 * c-lex.c (c_lex_string_translate): New variable.
252 (lex_string): Use to determine string translation.
253 * c-pragma.h: Prototype.
254 * c-parse.in (start_string_translation): New. Set above.
255 (stop_string_translation): Ditto.
256 (attribute, attribute_list, asm_def, asm_stmt,
257 asm_operand): Use above functions.
258 * cp/parser.c (cp_parser_declaration): Translate strings
259 unless token is RID_EXTERN. Set c_lex_string_translate
260 for recursive use.
261 (cp_parser_asm_definition): Only translate argument strings
262 to asms.
263 (cp_parser_asm_operand_list): Ditto.
264 (cp_parser_attribute_list): Do not translate attribute strings.
265
266 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
267
268 * stmt.c (expand_start_case_dummy): Remove.
269 * tree.h: Remove the corresponding prototype.
270
271 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
272
273 * builtins.c (apply_args_register_offset): Remove.
274 * tree.h: Remove the corresponding prototype.
275
276 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
277
278 * stor-layout.c (is_pending_size): Remove.
279 * tree.h: Remove the corresponding prototype.
280
281 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
282
283 * recog.c (validate_replace_src): Remove.
284 * recog.h: Remove the corresponding prototype.
285
286 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
287
288 * calls.c: Don't reference FINAL_REG_PARM_STACK_SPACE or
289 MAYBE_REG_PARM_STACK_SPACE.
290 * function.c: Likewise.
291 * system.h (FINAL_REG_PARM_STACK_SPACE): Poison.
292 (MAYBE_REG_PARM_STACK_SPACE): Likewise.
293 * doc/tm.texi (FINAL_REG_PARM_STACK_SPACE): Remove.
294 (MAYBE_REG_PARM_STACK_SPACE): Likewise.
295
296 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
297
298 * c-decl.c (c_expand_deferred_function): Remove.
299 * c-tree.h: Remove the corresponding prototype.
300
301 2004-02-26 Kazu Hirata <kazu@cs.umass.edu>
302
303 * postreload.c (reload_cse_move2add): Generate just a PLUS
304 instead of an entire SET.
305
306 2004-02-26 Jan Hubicka <jh@suse.cz>
307
308 * config.gcc: Add support for nocoma/prescott/pentium-m/pentium3m
309 /pentium4m.
310 * i386.c (override_options): Add support for new CPUs.
311 * i386.h (TARGET_CPU_DEFAULT_NAMES): New names.
312 (TARGET_CPU_DEFAULT_pentium_m, TARGET_CPU_DEFAULT_pentium4e): New
313 constants.
314 * invoke.texi: Extend documentation of -mtune/-march for new CPUs.
315
316 2004-02-26 Bob Wilson <bob.wilson@acm.org>
317
318 * config/xtensa/xtensa.h (TARGET_CPU_CPP_BUILTINS): Define __xtensa__.
319
320 2004-02-26 Eric Botcazou <ebotcazou@act-europe.fr>
321
322 * config/sparc/sparc-protos.h (sparc_emit_floatunsdi): Add 'mode'.
323 (sparc_emit_fixunsdi): New prototype.
324 * config/sparc/sparc.c (sparc_emit_floatunsdi): Use 'mode' argument.
325 (sparc_emit_fixunsdi): New function.
326 * config/sparc/sparc.md (floatunsdisf2): Use 'general_operand' for
327 operand 1. Pass SFmode to sparc_emit_floatunsdi.
328 (floatunsdidf2): Use 'general_operand' for operand 1. Pass DFmode
329 to sparc_emit_floatunsdi.
330 (fixuns_truncsfdi2): New expander.
331 (fixuns_truncdfdi2): Likewise.
332
333 2004-02-26 Alan Modra <amodra@bigpond.net.au>
334
335 * gcse.c (delete_null_pointer_checks_1): Do not delete CC setter
336 unless HAVE_cc0.
337
338 2004-02-25 Richard Henderson <rth@redhat.com>
339
340 * explow.c (force_reg): Call mark_reg_pointer as appropriate.
341 * config/alpha/alpha.c (alpha_emit_conditional_branch): Don't
342 use (op0-op1) == 0 if op0 is a pointer.
343 * config/alpha/alpha.md (cmpdi): Use some_operand.
344 (three comparison combine splits): Remove.
345
346 2004-02-25 Richard Henderson <rth@redhat.com>
347
348 PR c/12794
349 * c-common.c (handle_alias_attribute): Reject the attribute if
350 current_function_decl is set.
351
352 2004-02-25 Kelley Cook <kcook@gcc.gnu.org>
353
354 * config.gcc: Add comment describing extra_gcc_objs.
355 i[34567]86-*-cygwin*): Replace host_extra_gcc_objs with extra_gcc_objs.
356 * configure.ac (extra_gcc_objs): New substitution variable.
357 (host_extra_gcc_objs): Don't substitute.
358 * configure: Regenerate.
359 * Makefile.in: Use extra_gcc_objs.
360
361 2004-02-25 Kelley Cook <kcook@gcc.gnu.org>
362
363 * doc/contrib.texi: Add an entry for myself.
364
365 2004-02-25 Jan Hubicka <jh@suse.cz>
366
367 * basic-block.h (make_eh_edge, break_superblocks): Declare.
368 * cfgbuild.c (make_eh_edge): Make global.
369 * cfglayout.c (break_superblocks): Likewise; fix memory leak.
370 * except.c (build_post_landing_pads, connect_post_landing_pads,
371 dw2_build_landing_pads, sjlj_emit_function_enter,
372 sjlj_emit_function_exit, sjlj_emit_dispatch_table,
373 sjlj_build_landing_pads): Update CFG.
374 (emit_to_new_bb_before): New function.
375 (finish_eh_generation): Do not rebuild the CFG.
376
377 2004-02-25 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
378
379 * config.gcc (hppa*-*-*, parisc*-*-*): Add MASK_BIG_SWITCH to all
380 target_cpu_default defines.
381 * pa-hpux.h (TARGET_DEFAULT): Add MASK_BIG_SWITCH to define.
382 * pa.h (TARGET_DEFAULT): Likewise.
383
384 2004-02-25 Eric Botcazou <ebotcazou@act-europe.fr>
385
386 * fold-const.c (fold): Treat MAX_EXPR and MIN_EXPR like
387 comparisons with regard to signedness.
388
389 2004-02-25 Richard Earnshaw <rearnsha@arm.com>
390
391 * arm.c (thumb_legitimize_address): New function.
392 * arm-protos.h: Prototype it.
393 * arm.h (THUMB_LEGITIMIZE_ADDRESS): Define.
394 (LEGITIMIZE_ADDRESS): Use it.
395
396 2004-02-25 J"orn Rennecke <joern.rennecke@superh.com>
397
398 * reload1.c (reload): Only spill eliminable register with multiple
399 adjacent elimination alternatives if all alternatives fail.
400
401 2004-02-25 Richard Earnshaw <rearnsha@arm.com>
402
403 * arm.c (arm_legitimate_index_p): For QImode the range of an offset
404 is -4095...+4095 inclusive.
405
406 2004-02-25 Eric Botcazou <ebotcazou@libertysurf.fr>
407
408 * doc/install.texi (sparc-sun-solaris2* specific notes): Document
409 the bootstrap failure with Sun CC 5.4 and 5.5.
410
411 2004-02-24 Kazu Hirata <kazu@cs.umass.edu>
412
413 * cse.c (cse_change_cc_mode_insns): Stop at any instruction
414 which modifies NEWREG.
415 (cse_condition_code_reg): Update the mode of CC_REG in
416 CC_SRC_INSN on our own.
417
418 2004-02-24 Michael Matz <matz@suse.de>
419
420 * config/i386/i386.c (ix86_comp_type_attributes): Check for
421 regparm attributes.
422
423 2004-02-24 Richard Henderson <rth@redhat.com>
424
425 * toplev.c (dump_file_tbl): Rename from dump_file.
426 * bb-reorder.c, bt-load.c, cfgcleanup.c, cfglayout.c, cfgloopanal.c,
427 cfgloopmanip.c, cfgrtl.c, config/arm/arm.c, config/frv/frv.c,
428 config/i386/i386.c, config/ia64/ia64.c, config/mips/mips.c,
429 config/sh/sh.c, cse.c, flow.c, ifcvt.c, loop-iv.c, loop-unroll.c,
430 loop-unswitch.c, output.h, predict.c, profile.c, ra-build.c,
431 ra-colorize.c, ra-debug.c, ra-rewrite.c, ra.c, regrename.c, reload1.c,
432 toplev.c, tracer.c, value-prof.c, var-tracking.c, web.c:
433 s/rtl_dump_file/dump_file/g.
434
435 2004-02-24 Aldy Hernandez <aldyh@redhat.com>
436
437 * config/rs6000/spe.md (spe_fix_truncsfsi2): Delete.
438 (spe_fixuns_truncsfsi2): Delete.
439
440 * config/rs6000/rs6000.md (fix_truncsfsi2): Delete.
441 (fixuns_truncsfsi2): Delete.
442
443 2004-02-24 Josef Zlomek <zlomekj@suse.cz>
444
445 PR/14240
446 * rtlanal.c (replace_label): Fix replacing labels in constant pool.
447
448 2004-02-24 Geoffrey Keating <geoffk@apple.com>
449
450 * config/darwin.h (TARGET_HAS_F_SETLKW): Define.
451
452 2004-02-24 Jason Merrill <jason@redhat.com>
453
454 * tree.c (check_qualified_type): New fn.
455 (get_qualified_type): Use it. If type already has the desired
456 quals, just return it.
457 * tree.h: Declare it.
458
459 2003-02-24 Sanjiv Kumar Gupta <sanjivg@noida.hcltech.com>
460
461 * target-def.h (TARGET_SCHED_INIT_GLOBAL,
462 TARGET_SCHED_FINISH_GLOBAL): New macros.
463
464 * target.h (md_init_global, md_finish_global): Function
465 declarations corresponding to new target macros.
466
467 * haifa-sched.c (sched_init, sched_finish): Allow target to
468 call the new schedular hooks.
469
470 * flow.c (recompute_reg_usage): Add PROP_DEATH_NOTES flag in
471 call to update_life_info.
472
473 * config/sh/sh.h (OVERRIDE_OPTIONS): Re-enable
474 flag_schedule_insns for SH4.
475
476 * config/sh/sh.c (sh_md_init_global, sh_md_finish_global,
477 find_set_regmode_weight, find_insn_regmode_weight,
478 find_regmode_weight), sh_md_init, sh_dfa_new_cycle,
479 sh_variable_issue, high_pressure, ready_reorder,
480 rank_for_reorder, swap_reorder, sh_reorder, sh_reorder2): New
481 functions used to throttle the insn movement in first
482 scheduling pass for SH.
483
484 * gcc/doc/tm.texi: Document TARGET_SCHED_INIT_GLOBAL and
485 TARGET_SCHED_FINISH_GLOBAL.
486
487 2004-02-24 Alexandre Oliva <aoliva@redhat.com>
488
489 Implement FR-V FDPIC ABI support for frv-uclinux and frv-linux.
490 2004-02-05 Alexandre Oliva <aoliva@redhat.com>
491 * config/frv/frv.c (frv_emit_movsi): Use GOT relocations for
492 symbols in sections named by the user.
493 2004-01-30 Alexandre Oliva <aoliva@redhat.com>
494 * config/frv/linux.h (TARGET_OS_CPP_BUILTINS): New.
495 2004-01-27 Alexandre Oliva <aoliva@redhat.com>
496 * config.gcc (frv-*-*linux*): Handle like *-*-linux*.
497 * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Remove, obviated by
498 the above.
499 2004-01-20 Alexandre Oliva <aoliva@redhat.com>
500 * config/frv/frv.md (symGOT2reg_hilo, symGOTOFF2reg_hilo): Add
501 one more pseudo to further improve code generation.
502 2004-01-19 Alexandre Oliva <aoliva@redhat.com>
503 * config/frv/frv.md (movdi_ldd): Introduce explicit indirection
504 inside UNSPEC.
505 2004-01-16 Alexandre Oliva <aoliva@redhat.com>
506 * config/frv/frv.c (frv_legitimate_address_p): Added
507 allow_double_reg_p argument. Adjust all callers. Use it to
508 decide whether to enable double-register indirect addressing.
509 (frv_funcdesc_alias_set): Remove.
510 (frv_expand_fdpic_call): Force non-SYMBOL_REF operand into
511 register. Emit movdi_ldd.
512 (ldd_address_operand): New.
513 * config/frv/frv-protos.h (frv_legitimate_address_p): Adjust.
514 * config/frv/frv.h (GO_IF_LEGITIMATE_ADDRESS): Likewise.
515 (PREDICATE_CODES): Add ldd_address_operand.
516 * config/frv/frv.md (movdi_ldd): New.
517 (symGOT2reg_hilo, symGOTOFF2reg_hilo): Use separate pseudo for
518 intermediate computations if possible.
519 (symGOTOFF2reg_i): Fix harmless typo.
520 2003-12-18 Alexandre Oliva <aoliva@redhat.com>
521 * unwind-dw2-fde-glibc.c (_Unwind_IteratePhdrCallback): Cast
522 relocated p_vaddr to vaddr type.
523 * config/frv/frv-protos.h (frv_expand_fdpic_call): Return void.
524 * config/frv/frv.c (frv_get_funcdesc_alias_set): New.
525 (frv_expand_fdpic_call): Propagate incoming MEM's expr to funcdesc
526 MEM, or use a funcdesc alias set. Use regular move instead of
527 ldd.
528 (dbl_memory_one_insn_operand): Recognize function descriptors by
529 type or by alias set, and don't split them.
530 * config/frv/frv.md (call, call_value): Never use call_internal
531 for fdpic.
532 (call_internal, call_value_internal): Never match for FDPIC.
533 (call_fdpicdi, call_fdpicsi, call_value_fdpicdi,
534 call_value_fdpicsi): Require FDPIC.
535 (ldd): Removed.
536 2003-12-17 Alexandre Oliva <aoliva@redhat.com>
537 * config/frv/frv.h (CRT_GET_RFIB_DATA): Define for __FRV_FDPIC__.
538 * unwind-dw2-fde-glibc.c: Don't include elf-fdpic.h any more.
539 (_Unwind_IteratePhdrCallback): Adjust type of load_base for FRV
540 FDPIC. Compute data base address.
541 * config/frv/linux.h (SUBTARGET_DRIVER_SELF_SPECS): Enable -mfdpic
542 before the other self-specs are processed.
543 * config/frv/t-linux (CRTSTUFF_T_CFLAGS, TARGET_LIBGCC2_CFLAGS):
544 Build with -fPIC.
545 2003-12-15 Alexandre Oliva <aoliva@redhat.com>
546 * unwind-dw2-fde-glibc.c: Don't include bits/elf-fdpic.h if
547 inhibit_libc is defined.
548 2003-12-12 Alexandre Oliva <aoliva@redhat.com>
549 * unwind-dw2-fde-glibc.c: Include bits/elf-fdpic.h for
550 __FRV_FDPIC__.
551 (__RELOC_POINTER): Define.
552 (_Unwind_IteratePhdrCallback): Use it.
553 * config/frv/frv.h (Twrite): Define.
554 (TRANSFER_FROM_TRAMPOLINE): Use it.
555 * config/frv/linux.h (INVOKE__main): Undefine.
556 (Twrite): Override.
557 2003-12-05 Richard Sandiford <rsandifo@redhat.com>
558 * doc/invoke.texi (-mlong-calls, -mlinked-fp): Document FRV options.
559 (-mlibrary-pic): Emphasize that this option generates EABI code.
560 (-mcpu): Add fr550.
561 (-mpack): Remove.
562 2003-11-30 Alexandre Oliva <aoliva@redhat.com>
563 * config/frv/frv.c (int_2word_operand): Reject LABELs, SYMBOL_REFs
564 and CONSTs in FDPIC mode.
565 * gcc/config.gcc (with_cpu): Default to fr400 on frv-*-*linux*.
566 2003-11-29 Richard Sandiford <rsandifo@redhat.com>
567 * config/frv/frv.c (move_source_operand): Don't accept symbolic
568 constants.
569 * config/frv/frv.md (*movhi_internal, *movsi_internal): Use an 'n'
570 rather than 'i' constraint for the 2-instruction alternative.
571 (*movsi_2word): New, incorporating existing int_2word_operand splitter.
572 2003-11-29 Richard Sandiford <rsandifo@redhat.com>
573 * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Q): Renamed from
574 EXTRA_CONSTRAINT_FOR_Y.
575 (EXTRA_CONSTRAINT): Remove handling of 'Y'.
576 * config/frv/frv.md (*movsi_internal): Remove 'Q' constraint.
577 (addsi3): Change 'Y' constraint to 'Q'.
578 2003-11-27 Richard Sandiford <rsandifo@redhat.com>
579 * reload.c (CONST_POOL_OK_P): New macro.
580 (find_reloads): Use it to decide whether a constant can be forced
581 into memory.
582 * config/frv/frv.h (LEGITIMATE_PIC_OPERAND_P): Return true if the
583 constant satisfies got12_operand.
584 (frv_cannot_force_const_mem): Always return true for TARGET_FDPIC.
585 (frv_legitimate_address_p): Check for valid unspec offsets using
586 got12_operand rather than frv_legitimate_fdpic_operand_p.
587 (frv_legitimate_fdpic_operand_p): Delete.
588 (frv_emit_movsi): Abort if we try to use the FDPIC register during
589 or after reload.
590 (frv_legitimate_constant_p): Return LEGITIMATE_PIC_OPERAND_P if
591 TARGET_FDPIC.
592 * config/frv/frv.md (*movdf_double): Add alternatives for CONST_DOUBLE.
593 2003-11-19 Richard Sandiford <rsandifo@redhat.com>
594 * config/frv/frv-protos.h (fdpic_operand, fdpic_got12_operand)
595 (frv_fdpic_fptr_operand): Don't declare here.
596 * config/frv/frv.h (EXTRA_CONSTRAINT_FOR_Y): Call got12_operand
597 rather than fdpic_got12_operand.
598 (PREDICATE_CODES): Remove symbolic_operand entry. Add entries for
599 got12_operand and const_unspec_operand.
600 * config/frv/frv.c (got12_operand): Renamed from fdpic_got12_operand.
601 (gpr_or_int12_operand, dbl_memory_one_insn_operand): Update calls.
602 (symbolic_operand): Remove.
603 (const_unspec_operand): New predicate.
604 * config/frv/frv.md (*movsi_got): Use got12_operand.
605 (*movsi_high_got, *movsi_lo_sum_got): Use const_unspec_operand.
606 2003-11-18 Richard Sandiford <rsandifo@redhat.com>
607 * config/frv/frv-protos.h (frv_output_addr_const_extra): Remove.
608 * config/frv/frv.h (OUTPUT_ADDR_CONST_EXTRA): Remove definition.
609 * config/frv/frv.c (frv_unspec): New structure.
610 (frv_small_data_reloc_p, frv_const_unspec_p): New functions.
611 (frv_print_operand_memory_reference): Use frv_const_unspec_p to
612 validate CONST indices. Use frv_output_const_unspec to print them.
613 (frv_print_operand): Update call to unspec_got_name. Use
614 frv_output_const_unspec to print constant unspecs.
615 (frv_legitimate_fdpic_operand_p): Return true if frv_const_unspec_p.
616 Reject UNSPECs otherwise.
617 (unspec_got_name): Take the relocation number as argument, not an
618 rtx containing it.
619 (frv_output_addr_const_extra): Remove, replacing with...
620 (frv_output_const_unspec): ...this new function.
621 (frv_find_base_term): Use frv_const_unspec_p & frv_small_data_reloc_p.
622 (gpr_or_int12_operand): Use fdpic_got12_operand.
623 (dbl_memory_one_insn_operand): Likewise.
624 (fdpic_got12_operand): Use frv_const_unspec_p.
625 (frv_emit_movsi): Use frv_const_unspec_p to check for CONSTs that
626 are already legitimate. Use frv_small_data_reloc_p when deciding
627 whether to use HIGH/LO_SUM for R_FRV_GOTOFF12 and R_FRV_GPREL12.
628 2003-11-18 Alexandre Oliva <aoliva@redhat.com>
629 * config/frv/t-linux (SHLIB_MAPFILES): Override so as to export...
630 * config/frv/libgcc-frv.ver: ... frv-specific symbols. New file.
631 * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
632 label, for real this time.
633 * config/frv/frv.c (frv_local_funcdesc_p): Update to new
634 representation of visibility.
635 (fdpic_got12_operand, symbolic_operand): Mark unused arguments as
636 such.
637 2003-11-17 Richard Sandiford <rsandifo@redhat.com>
638 * config/frv/frv.h (MASK_LINKED_FP, TARGET_LINKED_FP): New macros.
639 (TARGET_SWITCHES): Add -mlinked-fp and -mno-linked-fp.
640 * config/frv/frv.c (frv_override_options): Set MASK_LINKED_FP unless
641 it was explicitly disabled.
642 (frv_stack_info): There is no need to save the link register in every
643 frame unless TARGET_LINKED_FP is true.
644 (frv_frame_pointer_required): If !TARGET_LINKED_FP, only require a
645 frame pointer if the stack pointer might change value.
646 (frv_return_addr_rtx): Check and process "count" argument.
647 2003-11-14 Richard Sandiford <rsandifo@redhat.com>
648 * config/frv/frv-protos.h (frv_legitimize_address): Remove.
649 (frv_find_base_term): Declare.
650 * config/frv/frv.h (LEGITIMIZE_ADDRESS): Do nothing.
651 (FIND_BASE_TERM): Define.
652 (PREDICATE_CODES): Remove pic_register_operand, pic_symbolic_operand,
653 small_data_register_operand, small_data_symbolic_operand. Add
654 symbolic_operand.
655 * config/frv/frv.c (const_small_data_p, plus_small_data_p): Delete.
656 (frv_print_operand_memory_reference, output_move_single): Remove
657 special handling for unlegitimized sdata addresses.
658 (frv_legitimate_address_p): Don't allow sums of SDA_BASE_REG
659 and symbolic addresses.
660 (frv_legitimize_address, frv_legitimize_fdpic_address): Delete.
661 (frv_find_base_term): New function.
662 (int_2word_operand): Check specifically for symbolic address constants.
663 (pic_register_operand, pic_symbolic_operand): Delete.
664 (small_data_register_operand, small_data_symbolic_operand): Delete.
665 (dbl_memory_one_insn_operand): Don't call plus_small_data_p.
666 Allow UNSPEC_GOT constants if !TARGET_FDPIC.
667 (move_source_operand): Only accept CONSTs if they're a two-insn
668 symbolic constant.
669 (fdpic_got12_operand): Don't require TARGET_FDPIC.
670 (frv_emit_movsi): Legitimize sdata and -mlibrary-pic addresses
671 using gen_symGOTOFF2reg*.
672 (frv_ifcvt_rewrite_mem): Remove (plus gr16 ...) special cases.
673 (frv_rtx_costs): Give all MEM addresses a cost of 0. Give MEMs
674 themselves a cost of 3 insns.
675 * config/mips/mips.md (*movsi_got): Allow for !TARGET_FDPIC too.
676 Change predicate to symbolic_operand.
677 (*movsi_high_got, *movsi_lo_sum_got): Likewise.
678 (*movsi_lda_sdata): Delete.
679 (*movsi_pic, movsi_high_pic, movsi_lo_sum_pic): Delete.
680 2003-11-05 Alexandre Oliva <aoliva@redhat.com>
681 * config.gcc: Add t-slibgcc-elf-ver and support --with-cpu for
682 frv-*-*linux*.
683 * config/frv/frv-abi.h (CREATE_DOUBLE_SHIFT): Use branch to local
684 label.
685 * config/frv/frv.h (DRIVER_SELF_SPECS): Add blank before
686 -multilib-library-pic.
687 (LINK_SPEC): Add -z text for -mfdpic.
688 * config/frv/frvbegin.c (__ROFIXUP_LIST__): Don't define on FDPIC.
689 * config/frv/frvend.c (__ROFIXUP_END__): Likewise.
690 * config/frv/linux.h (STARTFILE_SPEC, ENDFILE_SPEC, LINK_SPEC):
691 Override.
692 (OPTION_DEFAULT_SPECS, HAS_INIT_SECTION, INIT_SECTION_ASM_OP,
693 FINI_SECTION_ASM_OP, CRT_CALL_STATIC_FUNCTION): Define.
694 * config/frv/t-linux (EXTRA_MULTILIB_PARTS): Use
695 crtstuff-generated files.
696 2003-10-31 Alexandre Oliva <aoliva@redhat.com>
697 * config.gcc: Add frv-*-*linux*.
698 * config/frv/linux.h, config/frv/t-linux: New.
699 2003-10-06 Alexandre Oliva <aoliva@redhat.com>
700 * config/frv/frv.h (LINK_SPEC): Pass -melf32frvfd to the linker
701 when -mfdpic even if a linker script is explicitly listed.
702 2003-10-02 Alexandre Oliva <aoliva@redhat.com>
703 * config/frv/frv.c (frv_override_options): Clear asm_out
704 unaligned_op for SImode on FDPIC.
705 (frv_emit_movsi): Use compute_reloc_for_constant to compute the
706 argument passed to decl_readonly_section.
707 (frv_assemble_integer): Revert 2003-09-30's change, but make the
708 whole block run with FDPIC even with -fno-PIC.
709 2003-10-02 Alexandre Oliva <aoliva@redhat.com>
710 * config/frv/frv.c (frv_cannot_force_const_mem): Don't force
711 symbol or label plus offset to memory.
712 (frv_emit_movsi): Emit GPREL only if -mgprel-ro. Emit 32-bit
713 GOTOFF and GPREL for LABEL_REF.
714 * config/frv/frv.h (DRIVER_SELF_SPECS): Add -mgprel-ro with
715 -mfdpic unless -mno-gprel-ro, -fpic or -fpie.
716 (MASK_GPREL_RO, TARGET_GPREL_RO): New.
717 (TARGET_SWITCHES): Added gprel-ro and no-gprel-ro.
718 * doc/invoke.texi: Document them.
719 2003-09-30 Alexandre Oliva <aoliva@redhat.com>
720 * config/frv/frv-protos.h (frv_gen_GPsym2reg): Declare.
721 (frv_splittable_got_operand): Removed.
722 * config/frv/frv.c (frv_cannot_force_const_mem): Reject HIGH and
723 LO_SUM. Add comments.
724 (frv_override_options): Moved enabling of FDPIC to
725 DRIVER_SELF_SPECS. Don't enable MASK_DWORD.
726 (frv_local_funcdesc_p): Remove unnecessary heck for flag_pie.
727 (frv_legitimize_fdpic_address): Don't duplicate logic in
728 frv_emit_movsi.
729 (frv_gen_GPsym2reg): New.
730 (unspec_got_name): Added gprel.
731 (frv_expand_fdpic_call): Add support for inlining PLTs.
732 (fdpic_fptr_operand): Renamed from frv_fdpic_fptr_operand.
733 (gpr_or_int12_operand): Added GPREL12.
734 (pic_symbolic_operand): Match even if !flag_pic for FDPIC.
735 (small_data_symbolic_operand): Fail if FDPIC.
736 (fdpic_splittable_got_operand): Removed.
737 (fdpic_got12_operand): Added GPREL12.
738 (frv_emit_movsi): Reorganize to avoid duplication. Emit GPREL
739 when appropriate. Fix sdata GOTOFF.
740 (frv_legitimate_constant_p): Require legitimate PIC operand for
741 FDPIC with pic, but only a legitimate fdpic operand for non-pic.
742 (frv_assemble_integer): Move FDPIC funcdesc handling out of
743 flag_pic case.
744 (frv_asm_out_constructor, frv_asm_out_destructor): Abort if
745 frv_assemble_integer fails.
746 * config/frv/frv.h (DRIVER_SELF_SPECS): New.
747 (SUBTARGET_DRIVER_SELF_SPECS): New.
748 (ASM_SPEC): Don't pass -mno-fdpic.
749 (LINK_SPEC): Pass -melf32frvfd for FDPIC.
750 (MASK_INLINE_PLT, TARGET_INLINE_PLT): New.
751 (TARGET_SWITCHES): Add -minline-plt, -mno-inline-plt and
752 -multilib-library-pic.
753 (PREDICATE_CODES): Added fdpic_operand, fdpic_fptr_operand,
754 condexec_si_media_operator, condexec_sf_add_operator and
755 condexec_sf_conv_operator. Removed condexec_sf_binary_operator
756 and condexec_sf_unary_operator.
757 * config/frv/frv.md (R_FRV_GPREL12, R_FRV_GPRELHI, R_FRV_GPRELLO):
758 New.
759 (movsi_got, movsi_high_got, movsi_lo_sum_got): Move before
760 movsi_internal. Give them internal names. movsi_got has type
761 int.
762 (fdpic got splitters): Remove.
763 (symGPREL2reg, symGPREL2reg_hilo): New.
764 * config/frv/t-frv (MULTILIB_MATCHES): Don't map -fpic and -fPIC
765 to -mlibrary-pic. Map -multilib-library-pic to it.
766 * doc/invoke.texi: -mfdpic, -minline-plt, -multilib-library-pic:
767 Document.
768 2003-09-28 Alexandre Oliva <aoliva@redhat.com>
769 * config/frv/frv.c (frv_function_symbol_referenced_p): Declare.
770 (TARGET_CANNOT_FORCE_CONST_MEM): Define to...
771 (frv_cannot_force_const_mem): New function.
772 (const_small_data_p, plus_small_data_p): Update comments on sdata
773 on FDPIC.
774 (frv_override_options): Set flag_pie for FDPIC too.
775 (frv_conditional_register_usage): Mark gr16 and gr17 as non-fixed,
776 call-saved registers on FDPIC.
777 (frv_stack_info): Don't preserve the PIC register on FDPIC, and
778 don't force LR to be preserved.
779 (frv_expand_prologue): Likewise.
780 (frv_asm_output_mi_thunk): Use 12-bit funcdesc gotoff for -fpic.
781 (frv_frame_pointer_required): Don't force it just because the
782 FDPIC register is used.
783 (frv_legitimate_address_p) <CONST>: Accept a legitimate FDPIC
784 operand only if !condexec_p.
785 (frv_legitimize_address): Return the FDPIC-legitimized address.
786 Don't match small data here on FDPIC.
787 (frv_legitimate_fdpic_operand_p): Don't accept unadorned function
788 symbols. Use TRUE/FALSE instead of 1/0.
789 (frv_local_funcdesc_p): New.
790 (frv_legitimize_fdpic_address): Rewrite to use GOTOFF and 12-bit
791 immediates when possible.
792 (pic_symbolic_operand): Accept SYMBOL_REFs and CONSTs in FDPIC.
793 (dbl_memory_one_insn_operand): Accept addresses that add a REG and
794 an UNSPEC_GOT.
795 (frv_emit_movsi): Handle FDPIC before small data. Use GOTOFF and
796 12-bit immediates when possible.
797 (frv_legitimate_constant_p): In FDPIC, reject SImode operands that
798 are not legitimate pic operands.
799 (frv_in_small_data_p): Re-enable for FDPIC.
800 * config/frv/frv.h (SDA_BASE_REG): Remove comment about FDPIC.
801 (FRV_GLOBAL_P): Removed.
802 * config/frv/frv.md: Add modes to CONSTs.
803 (movsi_got): New.
804 (movsi_lo_sum_got): Use separate matches instead of match_dup.
805 (movsi_high_pic, movsi_lo_sum_pic): Match on non-FDPIC only.
806 (fdpic splittable operations): Match on flag_pic != 1.
807 2003-09-22 Alexandre Oliva <aoliva@redhat.com>
808 * config/frv/frv.c (frv_asm_out_constructor,
809 frv_asm_out_destructor): Pass to frv_assemble_integer the size in
810 bytes, not bits.
811 2003-09-19 Alexandre Oliva <aoliva@redhat.com>
812 * config/frv/frv.c (frv_assemble_integer): Reject complex
813 expressions referencing function SYMBOL_REFs.
814 * config/frv/frv.c (frv_function_symbol_referenced_p): New.
815 (move_source_operand): Reject CONSTs that reference function
816 SYMBOL_REFs on FDPIC.
817 (frv_emit_movsi): If we get such a CONST, break it up.
818 * config/frv/frv.h (CPP_SPEC): Define __FRV_FDPIC__ for -mfdpic.
819 (TRANSFER_FROM_TRAMPOLINE): Use different definitions for FDPIC.
820 * config/frv/frv.c (frv_print_operand) <I>: Recognize PLUS without
821 MEM.
822 (frv_assemble_integer): Don't use funcdesc for LABEL_REFs.
823 (frv_trampoline_size): Increase for FDPIC.
824 * config/frv/frv.h (TRAMPOLINE_ALIGNMENT): Bump to 64 for FDPIC.
825 (TRANSFER_FROM_TRAMPOLINE): Handle FDPIC trampolines.
826 * config/frv/frv.c (frv_legitimize_fdpic_address, frv_emit_movsi):
827 Disable use of GOTOFF for now.
828 (const_small_data_p, plus_small_data_p, frv_in_small_data_p):
829 Disable use of small data in FDPIC for now.
830 (frv_asm_output_mi_thunk): Implement for FDPIC.
831 * config/frv/frv.h (SDA_BASE_REG): Set to -1 with FDPIC.
832 * config/frv/frv.c (frv_asm_out_constructor): Use
833 frv_assemble_integer for FDPIC pointers.
834 (frv_asm_out_destructor): Likewise.
835 * config/frv/frv.md (ldd): Fix order of operands. Use
836 address_operand for input.
837 2003-09-18 DJ Delorie <dj@redhat.com>
838 * config/frv/frv.c (frv_legitimate_fdpic_operand_p): Remove UNSPEC_PIC.
839 (unspec_got_name): Correct typo.
840 (frv_emit_movsi): Pre-expand splittable GOTs.
841 (frv_expand_fdpic_call): Rename gen_lddi to gen_ldd.
842 * config/frv/frv.md (lddi): Fix syntax error, rename to ldd.
843 (symGOT2reg_hilo, symGOTOFF2reg_hilo): New.
844 * config/frv/t-frv: Add -mfdpic multilibs.
845 * config/frv/frv.h (ASM_SPEC): Pass -mfdpic/-mno-fdpic.
846 (TARGET_SWITCHES): Add -mno-fdpic, fix documentation.
847 * config/frv/frv.c (frv_override_options): -mfdpic assumes
848 flag_pic, default to 32-bit pics, require DWORD ops.
849 (frv_override_options): Add W and Z constraints.
850 (frv_expand_prologue): No pic prologue for -mfdpic.
851 (frv_asm_output_mi_thunk): Support -mfdpic (soon).
852 (frv_print_operand_memory_reference): Handle GOT constants.
853 (frv_legitimate_address_p): Allow GOT constants.
854 (frv_legitimize_address): Handle GOT addresses too.
855 (frv_legitimate_fdpic_operand_p): New.
856 (frv_legitimize_fdpic_address): New.
857 (unspec_got_name): New.
858 (frv_output_addr_const_extra): New.
859 (frv_expand_fdpic_call): New.
860 (frv_fdpic_fptr_operand): New.
861 (gpr_or_int12_operand): Handle GOT operands.
862 (int_2word_operand): Handle GOT operands.
863 (fdpic_operand): New.
864 (fdpic_splittable_got_operand): New.
865 (fdpic_got12_operand): New.
866 (frv_emit_movsi): Handle GOT operands.
867 (frv_assemble_integer): -mfdpic doesn't use rofixups.
868 (frv_print_operand): Support 'g' code for GOT operands.
869 * config/frv/frv-protos.h: Add prototypes as needed.
870 * config/frv/frv.md (R_FRV_GOT12, R_FRV_GOTHI, R_FRV_GOTLO,
871 R_FRV_FUNCDESC, R_FRV_FUNCDESC_GOT12, R_FRV_FUNCDESC_GOTHI,
872 R_FRV_FUNCDESC_GOTLO, R_FRV_FUNCDESC_VALUE,
873 R_FRV_FUNCDESC_GOTOFF12, R_FRV_FUNCDESC_GOTOFFHI,
874 R_FRV_FUNCDESC_GOTOFFLO, R_FRV_GOTOFF12, R_FRV_GOTOFFHI,
875 R_FRV_GOTOFFLO): New.
876 (movsi_high_got, movsi_lo_sum_got): New.
877 (*movsi_pic): Don't use this splitter for -mfdpic.
878 (addsi3): Allow GOT references also.
879 (call, call_value): Handle -mfdpic separately.
880 (call_fdpicdi, call_fdpicsi, lddi, call_value_fdpicdi,
881 call_value_fdpicsi): New.
882 (symGOT2reg, symGOT2reg_i, got splitters, symGOTOFF2reg,
883 symGOTOFF2reg_i): New.
884 * config/frv/frv.h (MASK_FDPIC): New.
885 (TARGET_FDPIC): New.
886 (TARGET_SWITCHES): Add -mfdpic.
887 (FDPIC_FPTR_REGNO): New.
888 (FDPIC_REGNO): New.
889 (OUR_FDPIC_REG): New.
890 (enum reg_class): Add FDPIC_REGS, FDPIC_FPTR_REGS, and
891 FDPIC_CALL_REGS.
892 (REG_CLASS_NAMES): Likewise.
893 (REG_CLASS_CONTENTS): Likewise.
894 (EXTRA_CONSTRAINT_FOR_Y): New, for 12-bit GOTs.
895 (EXTRA_CONSTRAINT): Add it here.
896 (FRV_GLOBAL_P): New.
897 (OUTPUT_ADDR_CONST_EXTRA): New.
898
899 2004-02-24 Kazu Hirata <kazu@cs.umass.edu>
900
901 * config/sparc/sparc.h: Remove commented-out definitions of
902 TARGET_EDOM and GEN_ERRNO_RTX.
903
904 2004-02-24 Kazu Hirata <kazu@cs.umass.edu>
905
906 * df.c, df.h, ra-build.c, ra-rewrite.c, ra.c, web.c: Replace
907 df_analyse with df_analyze.
908
909 2004-02-24 Alan Modra <amodra@bigpond.net.au>
910
911 * gcse.c (delete_null_pointer_checks_1): Set stop_insn to end, not
912 beginning of block.
913
914 2004-02-23 James E Wilson <wilson@specifixinc.com>
915
916 * calls.c (precompute_arguments): Update comment.
917
918 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
919
920 * et-forest.c: Replace et_occurences with et_occurrences.
921
922 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
923
924 * cfgloop.h, loop-iv.c, loop-unswitch.c: Replace iv_analyse
925 with iv_analyze.
926
927 2004-02-23 Kelley Cook <kcook@gcc.gnu.org>
928
929 * config/i386/i386.c: Rename pni to sse3.
930 * config/i386/i386.h: Likewise.
931 * config/i386/i386.md: Likewise.
932 * config/i386/pmmintrin.h: Likewise.
933 * doc/extend.texi: Likewise.
934 * doc/invoke.texi: Likewise.
935
936 2004-02-23 Zack Weinberg <zack@codesourcery.com>
937 Kazu Hirata <kazu@cs.umass.edu>
938
939 Remove -fwritable-strings.
940 * c-common.c (fix_string_type): Don't check
941 flag_writable_strings.
942 (fix_string_type): Likewise.
943 * c-opts.c (set_std_c89): Don't initialize
944 flag_writable_strings.
945 (set_std_c99): Likewise.
946 * common.opt (fwritable-strings): Remove.
947 * flags.h: Remove the external declaration of
948 flag_writable_strings.
949 * opts.c (common_handle_option) <OPT_fwritable_strings>:
950 Remove.
951 * toplev.c (flag_writable_strings): Remove.
952 (f_options): Remove an entry for writable-strings.
953 * varasm.c (const_hash_1) <STRING_CST>: Don't check
954 flag_writable_strings.
955 (compare_constant) <STRING_CST>: Likewise.
956 (build_constant_desc): Likewise.
957 * config/darwin.c (machopic_select_section): Likewise.
958 * config/arm/arm.c (AOF_ASSEMBLER): Likewise.
959 * config/arm/pe.c (arm_pe_encode_section_info): Likewise.
960 * config/iq2000/iq2000.c (iq2000_select_section): Likewise.
961 * config/mips/mips.c (mips_select_section): Likewise.
962 (mips_encode_section_info): Likewise.
963 * config/pa/pa.c (pa_select_section): Likewise.
964 * config/pa/pa.h (TEXT_SPACE_P): Likewise.
965 * config/v850/v850.c (v850_select_section): Likewise.
966 * doc/invoke.texi (-fwritable-strings): Remove.
967 (-fno-const-strings): Don't mention -fwritable-strings.
968 * doc/trouble.texi: Don't mention -fwritable-strings.
969
970 2003-02-23 Nathanael Nerode <neroden@gcc.gnu.org>
971
972 * doc/install.texi: Update for switch of boehm-gc to autoconf 2.57.
973
974 2004-02-23 Dale Johannesen <dalej@apple.com>
975
976 * config/rs6000.md (movsf_hardfloat): Add POWER form of nop.
977 (movdf_hardfloat64): Ditto.
978 (movdf_softfloat64): Ditto.
979
980 2004-02-23 Fariborz Jahanian <fjahanian@apple.com>
981 * config/rs6000/rs6000.c (function_arg): call to
982 rs6000_mixed_function_arg for DFmode moved to allow
983 normal DFmode incoming register assignment.
984
985 2004-02-23 Dale Johannesen <dalej@apple.com>
986
987 * config/rs6000.md (movsf_hardfloat): Accept CTR-to-CTR copy.
988 (movdf_hardfloat64): Ditto.
989
990 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
991
992 * convert.c, gcov-io.c, libgcov.c, sched-int.h, sibcall.c,
993 config/rs6000/linux.h, config/rs6000/rs6000-c.c: Update
994 copyright.
995
996 2004-02-23 Andrew Pinski <pinskia@physics.uc.edu>
997
998 PR c/14156
999 * c-typeck.c (c_expand_return): Change check for VAR_DECL
1000 to use DECL_P instead.
1001
1002 * config/rs6000/linux.h (OS_MISSING_POWERPC64): Define.
1003 * config/rs6000/linux64.h (OS_MISSING_POWERPC64): Define.
1004
1005 2004-02-23 Kazu Hirata <kazu@cs.umass.edu>
1006
1007 * Makefile.in (opts.o): Depend on target.h.
1008 * opts.c (decode_options): Use targetm.default_short_enums
1009 instead of DEFAULT_SHORT_ENUMS.
1010 * system.h (DEFAULT_SHORT_ENUMS): Poison.
1011 * target-def.h (TARGET_DEFAULT_SHORT_ENUMS): New.
1012 (TARGET_INITIALIZER): Add TARGET_DEFAULT_SHORT_ENUMS.
1013 * target.h (gcc_target): Add default_short_enums.
1014 * config/cris/cris.h: Remove a comment about
1015 DEFAULT_SHORT_ENUMS.
1016 * config/ip2k/ip2k.h: Likewise.
1017 * doc/tm.texi (DEFAULT_SHORT_ENUMS): Change to
1018 TARGET_DEFAULT_SHORT_ENUMS. Update the description.
1019
1020 2004-02-23 Eric Botcazou <ebotcazou@libertysurf.fr>
1021 Falk Hueffner <falk@debian.org>
1022
1023 PR c/14188
1024 * builtins.c (expand_builtin_va_arg): Emit an informative message
1025 if a trap is generated.
1026 * c-typeck.c (build_function_call): Likewise.
1027
1028 2004-02-22 Jakub Jelinek <jakub@redhat.com>
1029
1030 * gcov-io.c (gcov_open) [GCOV_LOCKED]: Use open + fdopen instead of
1031 fopen.
1032 * libgcov.c: Include sys/stat.h.
1033 * config/rs6000/linux.h (TARGET_HAS_F_SETLKW): Define.
1034 * config/rs6000/linux64.h (TARGET_HAS_F_SETLKW): Define.
1035 * config/sparc/linux.h (TARGET_HAS_F_SETLKW): Define.
1036 * config/sparc/linux64.h (TARGET_HAS_F_SETLKW): Define.
1037
1038 2004-02-22 Kazu Hirata <kazu@cs.umass.edu>
1039
1040 * reorg.c: Remove comments about dead ports.
1041
1042 2004-02-22 Christopher Faylor <cgf@redhat.com>
1043
1044 * config.gcc (i[34567]86-*-pe|i[34567]86-*-cygwin*): *Really* specify
1045 extra host object file when targetting cygwin rather than generic
1046 object files.
1047
1048 2004-02-22 Josef Zlomek <zlomekj@suse.cz>
1049
1050 Merge from tree-ssa:
1051 2003-11-20 Richard Henderson <rth@redhat.com>
1052
1053 * tree-inline.c (insert_decl_map): New.
1054 (remap_decl, remap_type, remap_block, copy_body_r,
1055 initialize_inlined_parameters, declare_return_variable,
1056 remap_save_expr): Use it.
1057
1058 * function.c (copy_body_r): Add mapping from id->ret_label to
1059 id->ret_label. Revert test for ret_label.
1060
1061 2004-02-22 Jakub Jelinek <jakub@redhat.com>
1062
1063 * genoutput.c (process_template): Strip trailing whitespace in @
1064 templates and issue a warning if there was any.
1065
1066 2004-02-21 Christopher Faylor <cgf@redhat.com>
1067
1068 * config.gcc (i[34567]86-*-pe|i[34567]86-*-cygwin*): Specify extra host
1069 object file when targetting cygwin.
1070 * config/i386/t-cygwin (EXTRA_GCC_OBJS): Remove definition since it is
1071 overridden by top-level Makefile.
1072
1073 2004-02-21 Roger Sayle <roger@eyesopen.com>
1074
1075 * config/i386/i386.c (standard_80387_constant_p): Also prefer
1076 the x87's load constant instructions when optimizing for size.
1077
1078 2004-02-21 Kazu Hirata <kazu@cs.umass.edu>
1079
1080 * combine.c (SHIFT_COUNT_TRUNCATED): Remove.
1081 * defaults.h (SHIFT_COUNT_TRUNCATED): Provide the default.
1082 * expmed.c: Assume SHIFT_COUNT_TRUNCATED is always defined.
1083 * fold-const.c: Likewise.
1084 * simplify-rtx.c: Likewise.
1085
1086 2004-02-21 Alan Modra <amodra@bigpond.net.au>
1087
1088 * combine.c (can_combine_p): Don't ignore SETs marked with
1089 REG_EH_REGION notes.
1090 (try_combine): When attemting to fix unrecognized insns, don't
1091 split a PARALLEL that contains the original i2.
1092
1093 2004-02-21 Ziemowit Laski <zlaski@apple.com>
1094
1095 * config/darwin.h (TARGET_OPTION_TRANSLATE_TABLE): Refer to
1096 SUBTARGET_OPTION_TRANSLATE_TABLE for architecture-specific options.
1097 * config/i386/darwin.h (SUBTARGET_OPTION_TRANSLATE_TABLE): Define it.
1098 * config/rs6000/altivec.h: #error out if '-maltivec' not specified.
1099 (vector, pixel, bool): #define to __vector, __pixel and __bool.
1100 (__un_args_eq, __bin_args_eq, __tern_args_eq): Move to C-specific
1101 portion of header.
1102 (__altivec_link_error_invalid_argument): Remove prototype; will use
1103 __builtin_altivec_compiletime_error("vec_*") instead.
1104 (vec_*): Fix/complete set of available operation overloads given the
1105 existence of distinct 'vector bool ...' and 'vector pixel' types; tighten
1106 cv-correctness of pointer arguments; in C, always check for correct
1107 argument types before macro expansion.
1108 * config/rs6000/darwin.h (SUBTARGET_OPTION_TRANSLATE_TABLE): New macro
1109 defining Darwin/PowerPC-specific '-f[no-]altivec' and
1110 '-W[no-]altivec-long-deprecated' switches.
1111 * config/rs6000/rs6000-c (rs6000_cpu_cpp_builtins): Pre-define
1112 '__vector', '__pixel' and '__bool' macros using
1113 '__attribute__((altivec(...)))' types.
1114 * config/rs6000/rs6000.c (bool_char_type_node, bool_short_type_node,
1115 bool_int_type_node, pixel_type_node, bool_V16QI_type_node,
1116 bool_V8HI_type_node, bool_V4SI_type_node, pixel_V8HI_type_node):
1117 New type nodes.
1118 (rs6000_warn_altivec_long, rs6000_warn_altivec_long_switch): New, for
1119 handling '-W[no-]altivec-long-deprecated'.
1120 (rs6000_override_options): Handle '-W[no-]altivec-long-deprecated'.
1121 (rs6000_expand_binop_builtin, rs6000_expand_ternop_builtin,
1122 altivec_expand_dst_builtin): Remove casts from integer literals.
1123 (altivec_expand_builtin): Likewise; handle expansion of new
1124 '__builtin_altivec_compiletime_error' function.
1125 (rs6000_init_builtins): Initialize 'vector bool ...' and 'vector pixel'
1126 types, and make them distinct from other vector types; register
1127 '__builtin_altivec_compiletime_error' function.
1128 (print_operand): For 'P', print a full target register name instead of
1129 merely its number.
1130 (rs6000_attribute_table): Add "altivec" attribute.
1131 (rs6000_handle_altivec_attribute): New function.
1132 * config/rs6000/rs6000.h (TARGET_OPTIONS): Describe
1133 '-m[no-]-warn-altivec-long' (which '-W[no-]altivec-long-deprecated'
1134 maps to).
1135 (rs6000_warn_altivec_long, rs6000_warn_altivec_long_switch): Forward
1136 declare.
1137 (ALTIVEC_BUILTIN_COMPILETIME_ERROR): New built-in enumeration.
1138
1139 2004-02-20 James E Wilson <wilson@specifixinc.com>
1140
1141 * config/ia64/ia64.md (shift_mix4left+1): Delete reload_completed
1142 check.
1143 (shift_mix4left+2): Delete redundant pattern.
1144
1145 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
1146
1147 * alias.c (OUTGOING_REGNO): Don't define the default.
1148 * builtins.c (OUTGOING_REGNO): Likewise.
1149 (INCOMING_REGNO): Likewise.
1150 (apply_args_register_offset): Always use OUTGOING_REGNO.
1151 * combine.c (OUTGOING_REGNO): Likewise.
1152 * sibcall.c (OUTGOING_REGNO): Likewise.
1153 * defaults.h (INCOMING_REGNO): Provide the default.
1154 (OUTGOING_REGNO): Likewise.
1155
1156 2004-02-21 Jan Hubicka <jh@suse.cz>
1157
1158 * params.def (max-peeled-insns, max-completely-peeled-insns,
1159 max-once-peeled-insns): Set to 400.
1160
1161 2004-02-20 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
1162
1163 PR c++/12007
1164 * dbxout.c (dbxout_parms): Check that DECL_RTL and DECL_INCOMING_RTL
1165 are set for parameters before outputing debugging information.
1166
1167 2004-02-20 Falk Hueffner <falk@debian.org>
1168
1169 PR target/14201
1170 * config/alpha/alpha.md (*fix_truncsfsi_ieee): Fix typoed operand
1171 numbers.
1172
1173 2004-02-20 Per Bothner <per@bothner.com>
1174
1175 * input.h: Don't #include line-map.h. It may cause link problems
1176 with undefined linemap_line_start when line-map.h is included but
1177 line-map.o is not linked, as currently happens with gengtype on
1178 compilers that don't support inline.
1179 * toplev.c: So we do have to explicitly #include line-map.h here.
1180
1181 2004-02-20 Richard Henderson <rth@redhat.com>
1182
1183 * doc/invoke.texi: Add -Wvariadic-macros.
1184
1185 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
1186
1187 * haifa-sched.c (sched_emit_insn): Remove.
1188 * sched-int.h: Remove the corresponding prototype.
1189
1190 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
1191
1192 Revert:
1193 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
1194 * opts.c (decode_options): Don't use DEFAULT_SHORT_ENUMS.
1195 * system.h (DEFAULT_SHORT_ENUMS): Poison.
1196 * config/cris/cris.h: Remove a comment about
1197 DEFAULT_SHORT_ENUMS.
1198 * config/ip2k/ip2k.h: Likewise.
1199 * doc/tm.texi (DEFAULT_SHORT_ENUMS): Remove.
1200
1201 2004-02-20 Mohan Embar <gnustuff@thisiscool.com>
1202 Tom Tromey <tromey@redhat.com>
1203
1204 * doc/install.texi: Moved --disable-libgcj and
1205 --with-system-zlib documentation to new section for
1206 Java-specific options.
1207 Added explicit Cross-Compiler-Specific Options subheading.
1208 Added section for Java-specific options.
1209
1210 2004-02-20 Matt Kraai <kraai@alumni.cmu.edu>
1211
1212 * doc/install.texi (Building the Ada compiler): Remove
1213 example.
1214
1215 2004-02-20 James E Wilson <wilson@specifixinc.com>
1216
1217 * toplev.c (dump_file_index, dump_file): Put ce3 before rnreg.
1218
1219 2004-02-20 Kazu Hirata <kazu@cs.umass.edu>
1220
1221 * gcc.c (process_command): Allow translation of the copyright
1222 symbol but not the rest of the copyright message.
1223 * gcov.c (print_version): Likewise. Allow translation of the
1224 message about warranty.
1225
1226 2004-02-20 Hans-Peter Nilsson <hp@axis.com>
1227
1228 * config/cris/cris.md ("*andsi_movu"): Correct parentheses in
1229 predicate.
1230 ("*andsi_clear"): Tweak constraints to not match postincrement.
1231 Adjust the predicate to exclude a volatile memory reference.
1232 ("*andhi_clear"): Ditto. Rename from "*andhi_clear_signed".
1233 ("*andhi_clear_unsigned"): Remove, non-matching pattern.
1234
1235 2004-02-19 Matt Kraai <kraai@alumni.cmu.edu>
1236
1237 * move-if-change: Remove.
1238 * Makefile.in (s-mlib, c-parse.y, s-check, s-gencheck)
1239 (s-specs, s-options, s-config, s-conditions, s-flags, s-codes)
1240 (s-constants, s-emit, s-recog, s-opinit, s-extract, s-peep)
1241 (s-attr, s-attrtab, s-output, s-genrtl, s-modes, s-preds)
1242 (s-gtyp-gen, s-iov): Use the top level move-if-change.
1243 * objc/Make-lang.in (objc/objc-parse.y): Likewise.
1244
1245 2004-02-19 James E Wilson <wilson@specifixinc.com>
1246
1247 * config/i386/i386.md (doloop_end_internal): Use nonimmediate_operand
1248 for operand2. Add condition that requires register_operand operand2
1249 before reload.
1250
1251 2004-02-19 Richard Sandiford <rsandifo@redhat.com>
1252 Maciej W. Rozycki <macro@ds2.pg.gda.pl>
1253
1254 * config/mips/mips.c (mips_address_insns): Treat BLKmode specially.
1255 * config/mips/mips.md: Expand comment above unaligned loads and stores.
1256
1257 2004-02-19 Richard Henderson <rth@redhat.com>
1258
1259 * Makefile.in (STRICT2_WARN): Add -Wno-variadic-macros.
1260 * tree.c (build0, build1, build2, build3, build4): Split out from...
1261 (build): ... here. Call them.
1262 * tree.h (build, _buildN1, _buildN2, _buildC1, _buildC2): New.
1263
1264 * convert.c (convert_to_integer): Remove extra build argument.
1265 * tree-inline.c (expand_call_inline): Likewise.
1266
1267 2004-02-19 Richard Henderson <rth@redhat.com>
1268
1269 * c-opts.c (warn_variadic_macros): New.
1270 (c_common_handle_option): Set it.
1271 (sanitize_cpp_opts): Copy it to cpp_opts.
1272 * c.opt (Wvariadic-macros): New.
1273 * cpplib.h (struct cpp_options): Add warn_variadic_macros.
1274 * cppinit.c (cpp_create_reader): Initialize it.
1275 * cppmacro.c (parse_params): Check it.
1276
1277 2004-02-19 David Daney <ddaney@avtrex.com>
1278
1279 PR preprocessor/14198
1280 * config/mips/linux.h (TARGET_OS_CPP_BUILTINS): Add
1281 builtin_assert ("machine=mips")
1282
1283 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
1284
1285 * opts.c (decode_options): Don't use DEFAULT_SHORT_ENUMS.
1286 * system.h (DEFAULT_SHORT_ENUMS): Poison.
1287 * config/cris/cris.h: Remove a comment about
1288 DEFAULT_SHORT_ENUMS.
1289 * config/ip2k/ip2k.h: Likewise.
1290 * doc/tm.texi (DEFAULT_SHORT_ENUMS): Remove.
1291
1292 2004-02-19 Zack Weinberg <zack@codesourcery.com>
1293
1294 * config/ia64/ia64.c (ia64_function_arg): In big-endian mode,
1295 when passing single SFmode quantities in general registers,
1296 put them in the high half.
1297
1298 2004-02-19 Aldy Hernandez <aldyh@redhat.com>
1299
1300 * doc/md.texi (Standard Names): Document additional dependency on
1301 fix pattern.
1302
1303 * optabs.c (ftruncify): Remove.
1304 (expand_fix): Manually inline ftruncify above.
1305 (can_fix_p): Add FIXME note.
1306
1307 2004-02-19 Aldy Hernandez <aldyh@redhat.com>
1308
1309 * config/rs6000/spe.md (spe_fixunssfsi2): Rename to
1310 spe_fixuns_truncsfsi2.
1311
1312 * config/rs6000/rs6000.md (fixunssfsi2): Rename to
1313 fixuns_truncsfsi2.
1314
1315 2004-02-19 Steve Ellcey <sje@cup.hp.com>
1316
1317 * config/ia64/ia64.h (HARD_REGNO_CALLER_SAVE_MODE): New macro.
1318 * testsuite/gcc.dg/20040219-1.c: New test.
1319
1320 2004-02-19 Ulrich Weigand <uweigand@de.ibm.com>
1321
1322 * config/s390/s390.md ("*subdf3_cc", "*subdf3_cconly", "*subsf3_cc",
1323 "*subsf3_cconly"): Subtraction is not commutative.
1324
1325 2004-02-19 Zack Weinberg <zack@codesourcery.com>
1326
1327 * sdbout.c (preinit_symbols, sdbout_initialized): New statics.
1328 (sdbout_symbol): If called before sdbout_init, queue DECL for
1329 later and return.
1330 (sdbout_init): Set sdbout_initialized true, process decls
1331 queued earlier by sdbout_symbol.
1332 (sdbout_finish): Use size_t for index variable.
1333
1334 2004-02-19 Jeff Law <law@redhat.com>
1335
1336 * fold-const.c (invert_truthvalue): Do not call invert_tree_comparison
1337 for unordered comparison codes.
1338
1339 2004-02-19 Ian Lance Taylor <ian@wasabisystems.com>
1340
1341 * reload1.c (reload): Correct comment.
1342 (scan_paradoxical_subregs): Remove #if 0 and old comment.
1343 * doc/extend.texi (Local Reg Vars): Remove obsolete comment that
1344 register variables are not used by reload.
1345
1346 2004-02-19 Hans-Peter Nilsson <hp@axis.com>
1347
1348 PR target/14209
1349 * config/cris/cris.md ("*andsi_movu", "*andhi_movu"): Tweak
1350 constraints to not match postincrement. Adjust the predicate to
1351 exclude a volatile memory reference.
1352
1353 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
1354
1355 * config/mcore/mcore.h (ASM_OUTPUT_EXTERNAL): Remove.
1356
1357 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
1358
1359 * hooks.c (hook_void_tree_int): Remove.
1360 (hook_void_constcharptr): Likewise.
1361 (hook_int_void_0): Likewise.
1362 * hooks.h: Remove the prototypes for the above three
1363 functions.
1364 * targhooks.c (hook_bool_machine_mode_true): Remove.
1365 * targhooks.h: Remove the prototype for
1366 hook_bool_machine_mode_true.
1367
1368 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
1369
1370 * emit-rtl.c (subreg_realpart_p): Remove.
1371 (reorder_insns_with_line_notes): Likewise.
1372 (end_full_sequence): Likewise.
1373 * rtl.h: Remove the prototype for the above functions.
1374
1375 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
1376
1377 * config/arc/arc.h, config/arm/arm.h, config/frv/frv.h,
1378 config/h8300/h8300.h, config/i386/i386.h, config/i860/i860.h,
1379 config/iq2000/iq2000.h, config/m32r/m32r.h,
1380 config/pdp11/pdp11.h, config/sparc/sparc.h,
1381 config/xtensa/xtensa.h: Remove commented-out or useless
1382 definitions of CASE_VECTOR_PC_RELATIVE.
1383
1384 2004-02-19 Kazu Hirata <kazu@cs.umass.edu>
1385
1386 * loop.c (all_sets_invariant_p): Remove.
1387
1388 2004-02-19 Eric Botcazou <ebotcazou@libertysurf.fr>
1389
1390 PR target/12916
1391 * config/sparc/sparc.h (NPARM_REGS): Delete.
1392 (BASE_RETURN_VALUE_REG): Likewise.
1393 (BASE_OUTGOING_VALUE_REG): Likewise.
1394 (BASE_PASSING_ARG_REG): Likewise.
1395 (BASE_INCOMING_ARG_REG): Likewise.
1396 * config/sparc/sparc.c (sparc_strict_argument_naming): Test
1397 TARGET_ARCH64, not TARGET_V9.
1398 (function_arg_slotno): Dispatch based on the mode class.
1399 Handle vector modes like floating-point modes.
1400 (function_arg_record_value_1): Handle vector types like
1401 floating-point types.
1402 (function_arg_record_value_2): Likewise.
1403 Calculate regno after mode transformation.
1404 (function_arg): Handle vector modes like floating-point modes.
1405 (function_arg_partial_nregs): Replace NPARM_REGS by SPARC_INT_ARG_MAX.
1406 If ARCH64, do not recheck alignment.
1407 (function_arg_pass_by_reference): Reorder the conditions.
1408 (sparc_return_in_memory): Move after function_arg_padding.
1409 Implement calling conventions for vector modes.
1410 (sparc_struct_value_rtx): Move after sparc_return_in_memory.
1411 (function_value): Move scope of 'regbase'.
1412 Implement calling conventions for vector modes.
1413 (sparc_builtin_saveregs): Replace NPARM_REGS by SPARC_INT_ARG_MAX
1414 and BASE_INCOMING_ARG_REG by SPARC_INCOMING_INT_ARG_FIRST.
1415 (sparc_va_arg): Use function_arg_pass_by_reference to test whether
1416 the argument is passed by reference.
1417 (sparc_type_code): Handle vector types.
1418
1419 2004-02-19 Alan Modra <amodra@bigpond.net.au>
1420
1421 * function.c (assign_parms): When building decl_rtl for
1422 SPLIT_COMPLEX_ARGS, ensure inner modes of concat match outer.
1423
1424 2004-02-19 Olivier Hainque <hainque@act-europe.fr>
1425
1426 * expr.c (is_aligning_offset): Check if we are aligning the
1427 expressions's address over BIGGEST_ALIGNMENT in bytes, not
1428 in bits.
1429
1430 2003-02-18 Matt Austern <austern@apple.com>
1431
1432 * gcc.c (LIBGCC_SPEC): If REAL_LIBGCC_SPEC is defined, and
1433 LIBGCC_SPEC isn't, set LIBGCC_SPEC to REAL_LIBGCC_SPEC.
1434 (init_gcc_spec): Don't define or call if REAL_LIBGCC_SPEC is
1435 defined. Instead use REAL_LIBGCC_SPEC, unmodifed, as the libgcc
1436 spec string.
1437 * doc/tm.texi (REAL_LIBGCC_SPEC): Document.
1438
1439 2004-02-18 Zack Weinberg <zack@codesourcery.com>
1440
1441 * dwarf2out.c (loclabel_num): Move outside #ifdef
1442 DWARF2_DEBUGGING_INFO and mark with GTY(()).
1443 * config/ia64/ia64.c (struct extern_func_list,extern_func_head):
1444 Mark with GTY(()).
1445 (ia64_hpux_add_extern_decl): Save the decl, not the name string.
1446 Allocate memory with ggc_alloc. No need to copy anything.
1447 (ia64_hpux_file_end): Update to match.
1448
1449 2004-02-18 Jakub Jelinek <jakub@redhat.com>
1450
1451 * config/i386/i386.c (override_options): Don't imply 3DNow! for -m64
1452 by default.
1453
1454 2004-02-18 Ulrich Weigand <uweigand@de.ibm.com>
1455
1456 * config/s390/s390.md ("divmodtidi3"): Use canonical RTL.
1457 ("divmodtisi3"): Likewise.
1458 ("udivmoddi4", "udivmodtidi3"): Likewise.
1459 ("divmodsi4", "divmoddisi3"): Likewise.
1460 ("udivmodsi4", "udivmoddisi3"): Likewise.
1461 ("udivsi3", "umodsi3"): Likewise.
1462
1463 2004-02-18 Ulrich Weigand <uweigand@de.ibm.com>
1464
1465 * config/s390/s390.c (s390_mainpool_start): Delete the main pool
1466 placeholder insn when chunkifying the pool.
1467
1468 2004-02-18 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
1469
1470 * pa.h (PIC_OFFSET_TABLE_REGNUM): Define to INVALID_REGNUM when not
1471 generating PIC code.
1472
1473 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1474
1475 * config/h8300/h8300-protos.h: Add a prototype for
1476 h8300_expand_branch.
1477 * config/h8300/h8300.c (h8300_expand_branch): New.
1478 * config/h8300/h8300.md (ble, bleu, bge, bgeu, blt, bltu, bgt,
1479 bgtu, beq, bne): Call h8300_expand_branch().
1480
1481 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1482
1483 * config/h8300/h8300-protos.h: Add prototypes for
1484 h8300_hard_regno_nregs and h8300_hard_regno_mode_ok.
1485 * config/h8300/h8300.c (h8300_hard_regno_nregs): New.
1486 (h8300_hard_regno_mode_ok): Likewise.
1487 * config/h8300/h8300.h (HARD_REGNO_NREGS): Call
1488 h8300_hard_regno_nregs().
1489 (HARD_REGNO_MODE_OK): Call h8300_hard_regno_mode_ok().
1490
1491 2004-02-18 Per Bothner <per@bothner.com>
1492
1493 * cpphash.h (struct cpp_buffer): Restore return_at_eof field. This
1494 partly reverts my 2003-10-01 change, because we're back to logically
1495 including <command line> inside the main line.
1496 * cpplex.c (_cpp_get_fresh_line): Check return_at_eof field.
1497 * cppmacro.c (cpp_scan_nooutput): Set return_at_eof of current buffer.
1498 Fixes PR preprocessor/14103.
1499
1500 * cppfiles.c (_cpp_stack_include): When appropriate decrement
1501 line_table's highest_location, fixing LAST_SOURCE_LINE_LOCATION.
1502 (cpp_push_include): Don't need to increment pfile's line field.
1503 * line-map.h (LAST_SOURCE_LINE_LOCATION): Only decrement by 1.
1504
1505 * c-ppoutput.c (print struct): New first_time field.
1506 (init_pp_output): Set print.first_time.
1507 (pp_file_change): Use print.first_time, rather than MAIN_FILE_P,
1508 which is set also for (say) <command line>. Clear print.first_time.
1509
1510 * cppfiles.c (struct _cpp_file): Comment and type for pch field
1511 does not match the code, so fix both.
1512 (should_stack_file): Inline include_pch_p function.
1513 (include_pch_p): Remove pointless function.
1514
1515 * cpphash.h (struct cpp_buffer): Remove unused search_cached field.
1516
1517 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1518
1519 * config/h8300/h8300.md (four define_peephole2's): Use
1520 h8300_regs_ok_for_stm().
1521
1522 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1523
1524 * config/h8300/h8300-protos.h: Update the prototype for
1525 expand_a_rotate().
1526 * config/h8300/h8300.c (expand_a_rotate): Remove the first
1527 argument.
1528 * config/h8300/h8300.md: Update all callers.
1529
1530 2004-02-18 Jan Hubicka <jh@suse.cz>
1531
1532 * simplify-rtx.c (simplify_unary_operation): Deal with logicals on
1533 floats.
1534 (simplify_binary_operation): Deal with logicals on floats.
1535
1536 * i386.md (SSE fabs splitters): Emit new patterns.
1537 (SSE cmov splitters): Likewise.
1538 (sse_andv4sf3, sse_nandv4sf3, sse_iorv4sf3, sse_xorv4sf3
1539 (sse_andv2df3, sse_nandv2df3, sse_iorv2df3, sse_xorv2df3): Do not use
1540 subregs.
1541 (sse_andsf3, sse_nandsf3, sse_xorsf3): Kill.
1542 (sse_anddf3, sse_nanddf3, sse_xordf3): Kill.
1543
1544 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1545
1546 * config/h8300/h8300.c (expand_a_rotate): Don't generate insns
1547 by hand.
1548 (output_a_rotate): Tweak a comment.
1549 * config/h8300/h8300.md (*rotlqi3_1): Change to rotlqi3_1.
1550 (*rotlhi3_1): Change to rotlhi3_1.
1551 (*rotlsi3_1): Change to rotlsi3_1.
1552
1553 2004-02-18 Richard Earnshaw <rearnsha@arm.com>
1554
1555 PR target/13866
1556 * arm.c (load_multiple_operation): Don't insist that the source reg
1557 of a post-increment component is the same as the destination.
1558 (store_multiple_operation): Likewise.
1559
1560 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1561
1562 * config/h8300/h8300.md: Move movsf patterns into one section
1563 of the file.
1564
1565 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1566
1567 * cfgloop.h, cfgloopanal.c, cpplex.c, except.h, loop-init.c,
1568 loop-unroll.c, scan-decls.c, scan.h, stor-layout.c,
1569 xcoffout.c, xcoffout.h, config/arm/mmintrin.h,
1570 config/mips/linux64.h, config/pa/pa-64.h,
1571 config/rs6000/aix51.h, config/rs6000/aix52.h,
1572 config/rs6000/spe.md, config/sparc/linux.h,
1573 config/sparc/linux64.h: Update copyright.
1574
1575 2004-02-18 Kazu Hirata <kazu@cs.umass.edu>
1576
1577 * config/h8300/h8300.md: Move push patterns into one
1578 section of the file.
1579
1580 2004-02-18 Mark Mitchell <mark@codesourcery.com>
1581
1582 PR c++/11326
1583 * config/ia64/ia64.c (ia64_struct_value_rtx): Cope with NULL
1584 fntype.
1585
1586 2004-02-18 Paul Brook <paul@codesourcery.com>
1587
1588 * rtlanal.c (rtx_varies_p): Return 0 for NULL_RTX
1589
1590 2004-02-18 Paul Brook <paul@codesourcery.com>
1591
1592 PR debug/12934
1593 * dwarf2out.c (loc_descriptor_from_tree): Handle
1594 EXPR_WITH_FILE_LOCATION.
1595
1596 2004-02-18 Jakub Jelinek <jakub@redhat.com>
1597
1598 * config/i386/i386.md (zero_extendqidi2, zero_extendqidi2,
1599 testdi_1_rex64, anddi_2, xordi_1_rex64, xordi_2_rex64): Remove
1600 trailing whitespace from instructions.
1601
1602 2004-02-17 Geoffrey Keating <geoffk@apple.com>
1603
1604 * configure.ac: When generating auto-build.h, pass
1605 --enable-languages to the sub-configure.
1606 Put quotes around ${program_transform_name} when generating
1607 name of as, ld, nm, objdump.
1608 * configure: Regenerate.
1609
1610 2004-02-17 Matt Kraai <kraai@alumni.cmu.edu>
1611
1612 * Makefile.in (s-check, s-config, s-conditions, s-flags)
1613 (s-codes, s-constants, s-emit, s-recog, s-opinit, s-extract)
1614 (s-peep, s-attr, s-attrtab, s-output, s-genrtl, s-modes)
1615 (s-preds, s-iov): Do not depend on move-if-change.
1616
1617 2004-02-17 James E Wilson <wilson@specifixinc.com>
1618
1619 * caller-save.c (insert_restore): Pass mem through copy_rtx.
1620 (insert_save): Likewise.
1621
1622 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1623
1624 * config/h8300/h8300.c (h8300_emit_stack_adjustment): Fix a
1625 warning.
1626
1627 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1628
1629 * config/h8300/h8300.md (*one_complsi2_h8300): Change to
1630 *one_cmplsi2_h8300.
1631 (*one_complsi2_h8300hs): Change to *one_cmplsi2_h8300hs.
1632
1633 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1634
1635 * config/h8300/h8300-protos.h: Update the prototype of
1636 fix_bit_operand().
1637 * config/h8300/h8300.c (fix_bit_operand): Remove the second
1638 argument "what".
1639 * config/h8300/h8300.md: Update all callers.
1640
1641 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1642
1643 * config/h8300/h8300.c (fix_bit_operand): Change the name of
1644 the last argument to "code" from "type".
1645
1646 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1647
1648 * config/h8300/h8300.c: Remove an extern declaration of
1649 rtx_equal_function_value_matters.
1650
1651 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1652
1653 * config/h8300/h8300.c (fix_bit_operand): Don't generate insns
1654 by hand.
1655 * config/h8300/h8300.md (*andqi3_1): Change to andqi3_1.
1656 (*iorqi3_1): Change to iorqi3_1.
1657 (*xorqi3_1): Change to xorqi3_1.
1658
1659 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1660
1661 * c-common.c, cfghooks.c, rtlanal.c, varasm.c: Fix comment
1662 typos.
1663
1664 2004-02-17 Jan Hubicka <jh@suse.cz>
1665
1666 * i386.c (x86_prologue_using_move, x86_epilogue_using_move): Disable for P4.
1667
1668 2004-02-18 Alan Modra <amodra@bigpond.net.au>
1669
1670 PR optimization/14119
1671 * combine.c (try_combine): When attemting to fix unrecognized insns,
1672 don't delete SETs marked with REG_EH_REGION notes.
1673
1674 2004-02-17 Ulrich Weigand <uweigand@de.ibm.com>
1675
1676 * combine.c (simplify_if_then_else): Do not replace
1677 (if_then_else (ne reg 0) (0) (const_int)) by (reg) if the
1678 modes differ.
1679
1680 2004-02017 Steven Bosscher <stevenb@suse.de>
1681
1682 * (c-decl.c, c-semantics.c, calls.c, cgraph.c, cgraphunit.c,
1683 function.c, integrate.c, print-tree.c, toplev.c, tree-optimize.c,
1684 tree.h): Replace DECL_SAVED_INSNS with DECL_STRUCT_FUNCTION.
1685 * ada/utils.c: Likewise.
1686 * cp/decl.c: Likewise.
1687 * f/com.c: Likewise.
1688 * java/class.c: Likewise.
1689
1690 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1691
1692 * config/h8300/h8300.md: Fix comment typos.
1693
1694 2004-02-17 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
1695
1696 * config/mips/t-iris6gld: Renamed to ...
1697 * config/mips/t-irix-gld: ... this.
1698 * config.gcc (mips-sgi-irix6*): Reflect this
1699 (mips-sgi-irix5*): Use it with GNU ld.
1700
1701 * config/mips/irix6-crti.asm, config/mips/irix6-crtn.asm: Renamed
1702 to ...
1703 * config/mips/irix-crti.asm, config/mips/irix-crtn.asm: ... this.
1704 * config/mips/t-irix-gld: Reflect this.
1705 * config/mips/iris6gld.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
1706
1707 * config/mips/iris5gld.h: New file.
1708 * config.gcc (mips-sgi-irix5*): Use it with GNU ld.
1709 Only use collect2 without gas.
1710
1711 * config/mips/iris6.h (IRIX6_STARTFILE_SPEC, IRIX6_ENDFILE_SPEC):
1712 Renamed to IRIX_STARTFILE_SPEC, IRIX_ENDFILE_SPEC.
1713 (STARTFILE_SPEC, ENDFILE_SPEC, SUBTARGET_EXTRA_SPECS): Reflect this.
1714 * config/mips/iris6gld.h (STARTFILE_SPEC, ENDFILE_SPEC): Likewise.
1715
1716 * config/mips/iris6.h (SUBTARGET_EXTRA_SPECS): Moved ...
1717 * config/mips/iris5.h: ... here.
1718
1719 * config/mips/iris5.h (STARTFILE_SPEC, ENDFILE_SPEC): Renamed to
1720 IRIX_STARTFILE_SPEC, IRIX_ENDFILE_SPEC.
1721 (STARTFILE_SPEC, ENDFILE_SPEC): Define.
1722
1723 * config/mips/iris5gas.h (STARTFILE_SPEC, ENDFILE_SPEC): Simplify
1724 using irix_startfile_spec, irix_endfile_spec.
1725
1726 2004-02-16 Gunther Nikl <gni@gecko.de>
1727
1728 * config/m68k/m68k.c: Remove obsolete support for HPUX_ASM.
1729
1730 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1731
1732 * config/h8300/h8300.c (h8300_expand_prologue): Don't generate
1733 insns by hand.
1734
1735 2004-02-17 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
1736
1737 * cfghooks.c (split_edge): Speed up updating of dominators.
1738
1739 2004-02-17 Mark Mitchell <mark@codesourcery.com>
1740
1741 PR c++/11326
1742 * c-common.c (flag_abi_version): Remove.
1743 * c-common.h (flag_abi_version): Likewise.
1744 * c-opts.c (c_common_handle_option): Remove OPT_fabi_version case.
1745 * c.opt (fabi-version): Remove.
1746 * calls.c (expand_call): Always pass a function type to
1747 struct_value_rtx. Use convert_memory_address.
1748 * common.opt (fabi-version): Add it.
1749 * flags.h (flag_abi_version): Likewise.
1750 (abi_version_at_least): New macro.
1751 * opts.c (common_handle_option): Add OPT_fabi_version.
1752 * toplev.c (flag_abi_version): Define it.
1753 * config/ia64/ia64.c (ia64_struct_retval_addr_is_first_parm_p):
1754 New function.
1755 (ia64_output_mi_thunk): Use it.
1756 (ia64_struct_value_rtx): Likewise.
1757
1758 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1759
1760 * config/h8300/h8300.c (h8300_emit_stack_adjustment):
1761 Don't generate insns by hand.
1762
1763 2004-02-17 Andrew Pinski <pinskia@physics.uc.edu>
1764
1765 PR c++/14178
1766 * doc/invoke.texi (fabi-version): The default is 2 now.
1767
1768 2004-02-17 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
1769
1770 * loop-iv.c: New file.
1771 * Makefile.in (loop-iv.o): New.
1772 * basic_block.h (FOR_BB_INSNS, FOR_BB_INSNS_REVERSE): New macros.
1773 * cfgloop.c (fill_sons_in_loop, get_loop_body_in_dom_order,
1774 num_loop_branches): New functions.
1775 * cfgloop.h (get_loop_body_in_dom_order, num_loop_branches,
1776 iv_analysis_loop_init, iv_get_reaching_def, iv_analyse, get_iv_value,
1777 find_simple_exit, iv_number_of_iterations, iv_analysis_done,
1778 get_simple_loop_desc, free_simple_loop_desc): Declare.
1779 (simple_loop_desc): New inline function.
1780 (struct rtx_iv, struct niter_desc): New.
1781 * cfgloopmanip.c (loopify): Specify semantics more precisely.
1782 * expr.c (force_operand): Handle subregs of expressions created by
1783 loop unroller.
1784 * loop-init.c (loop_optimizer_init, loop_optimizer_finalize): Move
1785 parts of the initialization to toplev.c
1786 * loop-unroll.c (loop_exit_at_end_p): New.
1787 (unroll_and_peel_loops): Call iv_analysis_done.
1788 (decide_peel_once_rolling, decide_peel_completely,
1789 decide_unroll_stupid, decide_unroll_constant_iterations,
1790 decide_unroll_runtime_iterations, decide_peel_simple,
1791 peel_loop_simple, unroll_loop_stupid, unroll_loop_constant_iterations,
1792 unroll_loop_runtime_iterations): Use new simple loop analysis.
1793 * loop-unswitch.c (compare_and_jump_seq): New.
1794 (may_unswitch_on_p): Renamed to ...
1795 (may_unswitch_on): Use new iv analysis.
1796 (reversed_condition): Export.
1797 (unswitch_single_loop, unswitch_loop): Use new iv analysis.
1798 * predict.c (estimate_probability): Use new simple loop analysis.
1799 * rtl.h (get_mode_bounds, reversed_condition,compare_and_jump_seq,
1800 canon_condition, simplify_using_condition): Declare.
1801 * stor-layout.c (get_mode_bounds): New.
1802 * toplev.c (rest_of_handle_loop2): Some parts of
1803 initialization/finalization moved here from loop-init.c.
1804
1805 2004-02-17 Kazu Hirata <kazu@cs.umass.edu>
1806
1807 * config/h8300/h8300.h (FIXED_REGISTERS): Add the soft frame
1808 pointer.
1809 (CALL_USED_REGISTERS): Likewise.
1810 (REG_ALLOC_ORDER): Likewise.
1811 (REG_CLASS) <GENERAL_REGS>: Likewise.
1812
1813 2004-02-16 Geoffrey Keating <geoffk@apple.com>
1814
1815 * doc/md.texi (Insn Canonicalizations): Document left-chaining
1816 in associative operators.
1817 * rtlanal.c (commutative_operand_precedence): Create some new
1818 variables. Prefer a commutative operand on the left, then
1819 binary expressions, then NEG and NOT.
1820
1821 2004-02-16 Matthias Klose <doko@debian.org>
1822
1823 * config/t-slibgcc-elf-ver: Define SHLIB_NAME and SHLIB_SONAME
1824 in terms of SHLIB_SOVERSION.
1825 * config/m68k/t-slibgcc-elf-ver: New file.
1826 * config/pa/t-slibgcc-elf-ver: New file.
1827 * config.gcc (m68k-linux, parisc-linux): Use them when not
1828 sjlj exceptions are not configured.
1829
1830 2004-02-16 Eric Botcazou <ebotcazou@libertysurf.fr>
1831
1832 * config/sparc/sparc.c (get_pc_symbol_name): Mark with GTY(()).
1833
1834 2004-02-16 Zack Weinberg <zack@codesourcery.com>
1835
1836 * sdbout.c (sdb_debug_hooks): Correct the type_decl entry.
1837
1838 2004-02-16 Joseph S. Myers <jsm@polyomino.org.uk>
1839
1840 * doc/sourcebuild.texi: Mention backends.html.
1841
1842 2004-02-16 Kazu Hirata <kazu@cs.umass.edu>
1843
1844 * c-decl.c, c-ppoutput.c, cpphash.h, cpplib.h, dbxout.c,
1845 line-map.c, line-map.h, var-tracking.c: Fix comment
1846 formatting.
1847
1848 2004-02-16 Richard Henderson <rth@redhat.com>
1849
1850 * cse.c (cse_insn): Don't lose REG_NON_LOCAL_GOTO note.
1851
1852 * fold-const.c (operand_equal_p): Fix VECTOR_CST comparison.
1853
1854 2004-02-15 Kazu Hirata <kazu@cs.umass.edu>
1855
1856 * config/h8300/h8300.md: Remove unnecessary parallels from
1857 all define_insn and define_split patterns.
1858
1859 2004-02-15 Kazu Hirata <kazu@cs.umass.edu>
1860
1861 * config/h8300/h8300.md: Remove explicit (set_attr "cc"
1862 "clobber").
1863
1864 2004-02-15 Bernardo Innocenti <bernie@develer.com>
1865
1866 * config/m68k/m68k.h (PRINT_OPERAND_PUNCT_VALID_P): Restore support for
1867 '%#'.
1868
1869 2004-02-15 Kazu Hirata <kazu@cs.umass.edu>
1870
1871 * config/ia64/ia64.c, config/mips/mips.c,
1872 config/mmix/mmix-modes.def: Fix comment typos.
1873
1874 2004-02-15 Roger Sayle <roger@eyesopen.com>
1875
1876 * c-common.h (GET_DIRECTIVE_LINE): Remove unused macro.
1877 (get_directive_line): Remove unused function prototype.
1878
1879 2004-02-14 Josef Zlomek <zlomekj@suse.cz>
1880
1881 * tree-inline.c (copy_body_r): Do not replace ret_label.
1882
1883 2004-02-14 Jan Hubicka <jh@suse.cz>
1884
1885 * i386.c (x86_four_jump_limit): New variable.
1886 (k8_avoid_jump_misspredicts): Rename to ...
1887 (ix86_avoid_jump_misspredicts): .. this one.
1888 (ix86_pad_returns): Break out from ...
1889 (ix86_reorg): ... this one; do ix86_avoid_jump_misspredicts when asked
1890 to.
1891 * i386.h (TARGET_FOUR_JUMP_LIMIT): New macro.
1892
1893 2004-02-14 Josef Zlomek <zlomekj@suse.cz>
1894
1895 * emit-rtl.c (set_decl_incoming_rtl): Check whether the 0th element of
1896 PARALLEL is NULL.
1897
1898 2004-02-14 Per Bothner <per@bothner.com>
1899
1900 * fix-header.c (line_table): Move local variable in main to global.
1901 * scan.h (line_table): Use it.
1902 * scan-decls.c (scan_decls): Need to call linemap_lookup on token's
1903 line (recently renamed to src_loc) before calling recognized_function.
1904
1905 2004-02-14 Matt Kraai <kraai@alumni.cmu.edu>
1906
1907 * Makefile.in: Fix comment typos.
1908
1909 2004-02-14 Olivier Hainque <hainque@act-europe.fr>
1910
1911 * loop.c (check_dbra_loop): Use gen_int_mode instead of GEN_INT
1912 for start_value when it is directly moved into reg, and factorize
1913 the retrieval of GET_MODE (reg).
1914
1915 2004-02-14 Richard Sandiford <rsandifo@redhat.com>
1916
1917 * config/mips/mips-protos.h (mips_load_got_page): Delete.
1918 (mips_load_got_global): Delete.
1919 (mips_gotoff_page): Declare.
1920 * config/mips/mips.md (UNSPEC_LOAD_GOT): New constant.
1921 (*xgot_lo[sd]i, *got_disp[sd]i, *got_page[sd]i): Build an
1922 UNSPEC_LOAD_GOT pattern rather than a MEM.
1923 (*load_got[sd]i): New patterns.
1924 * config/mips/mips.c (mips_got_alias_set, mips_load_got): Delete.
1925 (mips_load_got_page, mips_load_got_global): Delete.
1926 (mips_gotoff_page): New function.
1927 (override_options): Don't initialize mips_got_alias_set.
1928
1929 2004-02-14 Richard Sandiford <rsandifo@redhat.com>
1930
1931 * config/mips/mips.h (MASK_DEBUG_[ABEFI], TARGET_DEBUG_[ABEFI]_MODE)
1932 (TARGET_MIPS4100, TARGET_MIPS4300, TARGET_MIPS4KC, TARGET_MIPS5KC)
1933 (TARGET_SB1, TUNE_SB1, TUNE_SR71K, BIGGEST_MAX_ARGS_IN_REGISTERS)
1934 (GO_PRINTF, GO_PRINTF2, GO_DEBUG_RTX, DFMODE_NAN, SFMODE_NAN): Delete.
1935 (TARGET_SWITCHES): Remove MASK_DEBUG_[ABEFI].
1936 * config/mips/mips.c: Fix some overly-long lines.
1937 (SINGLE_WORD_MODE_P, PIC_OFFSET_TABLE_MASK): Delete.
1938 (init_cumulative_args): Remove TARGET_DEBUG_E_MODE handling.
1939
1940 2004-02-13 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
1941
1942 * configure.ac: Search for as, ld below libexec/gcc.
1943 * configure: Regenerate.
1944
1945 2004-02-14 Ben Elliston <bje@wasabisystems.com>
1946
1947 * config/arm/mmintrin.h (_mm_setwcx): Reverse arguments in call to
1948 __builtin_arm_setwcx ().
1949 * config/arm/arm.c (arm_expand_builtin): Generate operands
1950 correctly and reverse their order in call to gen_iwmmxt_tmcr ().
1951
1952 2004-02-14 Ben Elliston <bje@wasabisystems.com>
1953
1954 * config/arm/arm.c (bdesc_2arg): Correct builtin names "wmulsh"
1955 and "wmuluh" to "wmulsm" and "wmulum", respectively.
1956 * config/arm/arm.h (enum arm_builtins): Rename enumerators to
1957 ARM_BUILTIN_WMULSM and ARM_BUILTIN_WMULUM.
1958 * config/arm/mmintrin.h (_mm_mulhi_pi16): Update intrinsic call.
1959 (_mm_mulhi_pu16): Likewise.
1960
1961 2004-02-13 Zack Weinberg <zack@codesourcery.com>
1962
1963 * xcoffout.c (xcoff_assign_fundamental_type_number): Check
1964 DECL_NAME != 0 before dereferencing.
1965
1966 2004-02-13 Ulrich Weigand <uweigand@de.ibm.com>
1967
1968 * config/s390/s390-protos.h (s390_output_symbolic_const): Remove.
1969 (s390_output_addr_const_extra): Declare.
1970 (s390_output_pool_entry): Remove FILE * argument.
1971 * config/s390/s390.c (s390_output_symbolic_const): Remove.
1972 (s390_output_addr_const_extra): New function.
1973 (print_operand_address): Call output_addr_const instead of
1974 s390_output_symbolic_const.
1975 (print_operand): Likewise.
1976 (s390_output_pool_entry): Use assemble_integer for symbolic constants.
1977 Remove FILE * argument.
1978 * config/s390/s390.h (OUTPUT_ADDR_CONST_EXTRA): Define.
1979 * config/s390/s390.md ("*pool_entry"): Adapt s390_output_pool_entry
1980 call.
1981
1982 2004-02-13 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
1983
1984 * cfgloopanal.c (mark_irreducible_loops): Rewriten.
1985 (struct edge, struct vertex, struct graph): New.
1986 (dump_graph, new_graph, add_edge, dfs, check_irred, for_each_edge,
1987 free_graph): New functions.
1988
1989 2004-02-12 Chris Demetriou <cgd@broadcom.com>
1990
1991 * config/mips/mips.md (casesi_internal, casesi_internal_di):
1992 Use ".set macro" to avoid warnings about multi-instruction
1993 macros, since they're intentional.
1994
1995 2004-02-12 Geoffrey Keating <geoffk@apple.com>
1996
1997 * config/darwin.h: Add include guards. Remove old, now incorrect,
1998 comment about STANDARD_EXEC_PREFIX.
1999
2000 * Makefile.in (install-man): Use $(CPP_INSTALL_NAME) and
2001 $(GCOV_INSTALL_NAME) to install manpages. Remove generic rule
2002 for installing .1 manpages. Add rules for installing cpp
2003 and gcov manpages under their installed names.
2004
2005 2004-02-12 Alexandre Oliva <aoliva@redhat.com>
2006
2007 * configure.ac (gcc_cv_ld): Don't set to LD if target is not
2008 host, but try LD_FOR_TARGET first.
2009 * configure: Rebuilt.
2010
2011 2004-02-12 Zack Weinberg <zack@codesourcery.com>
2012
2013 * dbxout.c: Move declaration of dbxout_type_decl outside
2014 #ifdef DBX_DEBUGGING_INFO.
2015 * c-parse.in: Don't give the asmdef production a type.
2016
2017 2004-02-12 Zack Weinberg <zack@codesourcery.com>
2018
2019 * debug.h (struct gcc_debug_hooks): Add type_decl field.
2020 (debug_nothing_tree_int): Prototype.
2021 (dwarf_debug_hooks): Delete, unused.
2022 * debug.c (do_nothing_debug_hooks): Update.
2023 (debug_nothing_tree_int): New function.
2024 * langhooks.h (struct lang_hooks_for_decls):
2025 Remove builtin_type_decls field.
2026 * langhooks-def.h (LANG_HOOKS_BUILTIN_TYPE_DECLS): Delete.
2027 (LANG_HOOKS_DECLS): Update.
2028 * toplev.c (rest_of_decl_compilation, rest_of_type_compilation):
2029 Use debug_hooks->type_decl.
2030 * dbxout.c (preinit_symbols): New static.
2031 (dbx_debug_hooks, xcoff_debug_hooks): Update.
2032 (dbxout_init): Don't call DBX_OUTPUT_STANDARD_TYPES or
2033 lang_hooks.decls.builtin_type_decls. Do scan preinit_symbols
2034 for symbols to output.
2035 (dbxout_type_decl): New function.
2036 (dbxout_symbol): If called before dbxout_init has run, queue
2037 the symbol for later. Apply DBX_ASSIGN_FUNDAMENTAL_TYPE_NUMBER
2038 to TYPE_DECLs before emitting them.
2039 * xcoffout.c (assign_type_number): Delete.
2040 (xcoff_type_numbers): New static table.
2041 (xcoff_assign_fundamental_type_number): New function.
2042 * xcoffout.h: Define DBX_ASSIGN_FUNDAMENTAL_TYPE_NUMBER, not
2043 DBX_OUTPUT_STANDARD_TYPES. Remove unnecessary #ifdefs.
2044 * sdbout.c: Include varray.h.
2045 (deferred_global_decls): New static.
2046 (sdb_debug_hooks): Update.
2047 (sdbout_global_decl): If we can't emit something right now,
2048 remember it in deferred_global_decls.
2049 (sdbout_finish): Just scan deferred_global_decls; don't call getdecls.
2050 (sdbout_init): Initialize deferred_global_decls.
2051 * Makefile.in: Update dependencies of sdbout.o.
2052 * dwarf2out.c (dwarf2out_type_decl): New function.
2053 (dwarf2_debug_hooks): Update.
2054 * vmsdbgout.c (vmsdbg_debug_hooks): Update.
2055 * c-decl.c (getdecls): Just return 0.
2056 (check_for_loop_decls): Don't use getdecls.
2057 (record_builtin_type): Call debug_hooks->type_decl on the TYPE_DECL.
2058 * c-objc-common.c (c_objc_common_finish_file): Don't use getdecls.
2059
2060 2004-02-12 Ulrich Weigand <uweigand@de.ibm.com>
2061
2062 * config/s390/s390.c (s390_sched_reorder2): Remove.
2063 (TARGET_SCHED_REORDER2): Do not redefine.
2064
2065 2004-02-12 Zack Weinberg <zack@codesourcery.com>
2066
2067 * c-parse.in (maybe_type_qual): Delete.
2068 (maybe_volatile, simple_asm_expr, asmdef, asm_stmt)
2069 (asm_argument): New grammar rules.
2070 (extdef_1): Use asmdef.
2071 (maybeasm): Move down with other asm rules; use simple_asm_expr.
2072 (xexpr): Move up with other expression rules.
2073 (stmt): Use asm_stmt.
2074
2075 * c-typeck.c (build_asm_expr): New function - body mostly
2076 pulled from build_asm_stmt.
2077 (build_asm_stmt): Just handle tacking on the volatile qualifier.
2078 * c-tree.h (build_asm_expr, build_asm_stmt): Update prototypes.
2079
2080 2004-02-12 Richard Sandiford <rsandifo@redhat.com>
2081
2082 PR bootstrap/13617
2083 * config/mips/mips-protos.h (mips_output_aligned_decl_common): Declare.
2084 (mips_declare_object): Make variadic.
2085 * config/mips/mips.h (ASM_OUTPUT_ALIGNED_DECL_COMMON): Use
2086 mips_output_aligned_decl_common.
2087 * config/mips/mips.c (mips_output_aligned_decl_common): New function.
2088 (mips_declare_object): Make variadic.
2089
2090 2004-02-12 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
2091
2092 * function.c (update_epilogue_consts): Teach about binary operations.
2093
2094 * emit-rtl.c (set_mem_attributes_minus_bitpos): Don't kill
2095 previous MEM_VOLATILE in REF.
2096 * function.c (fixup_var_refs): Save volatile_ok and set to 1.
2097 * expr.c (emit_block_move_via_movstr): Save and restore volatile_ok.
2098
2099 2004-02-12 Gunther Nikl <gni@gecko.de>
2100
2101 * config.gcc: Restore support for m68k-openbsd.
2102
2103 2004-02-12 Jan Hubicka <jh@suse.cz>
2104
2105 * tree-optimize.c (tree_rest_of_compilation): Do not release
2106 DECL_ARGUMENTS.
2107
2108 2004-02-11 Matt Kraai <kraai@alumni.cmu.edu>
2109
2110 * doc/install.texi: Fix the spelling of "explicitly".
2111
2112 2004-02-11 Eric Christopher <echristo@redhat.com>
2113
2114 * cppcharset.c (_cpp_interpret_string_notranslate): Rename and
2115 duplicate argument structure of cpp_interpret_string.
2116 * cpphash.h: Move prototype...
2117 * cpplib.h: Here.
2118 * cpplib.c: Fix calls to match new function signature.
2119
2120 2004-02-11 Joseph S. Myers <jsm@polyomino.org.uk>
2121
2122 PR c/456
2123 * cppexp.c (num_binary_op): Don't allow comma operators in #if
2124 constant expressions at all outside C99 mode if pedantic.
2125
2126 2004-02-11 Uros Bizjak <uros@kss-loka.si>
2127
2128 * optabs.h (enum optab_index): Add new OTI_log10 and OTI_log2.
2129 (log10_optab, log2_optab): Define corresponding macros.
2130 * optabs.c (init_optabs): Initialize log10_optab and log2_optab.
2131 * genopinit.c (optabs): Implement log10_optab and log2_optab
2132 using log10?f2 and log2?f2 patterns.
2133 * builtins.c (expand_builtin_mathfn): Handle BUILT_IN_LOG10{,F,L}
2134 using log10_optab, and BUILT_IN_LOG2{,F,L} using log2_optab.
2135 (expand_builtin): Expand BUILT_IN_LOG10{,F,L} and BUILT_IN_LOG2{,F,L}
2136 using expand_builtin_mathfn if flag_unsafe_math_optimizations is set.
2137
2138 * config/i386/i386.md (log10sf2, log10df2, log10xf2, log2sf2,
2139 log2df2, log2xf2): New patterns to implement log10, log10f, log10l,
2140 log2, log2f and log2l built-ins as inline x87 intrinsics.
2141
2142 2004-02-11 Richard Henderson <rth@redhat.com>
2143
2144 PR target/1532
2145 * flow.c (insn_dead_p): A clobber of a dead hard register is a
2146 dead insn after reload.
2147
2148 2004-02-11 Ulrich Weigand <uweigand@de.ibm.com>
2149
2150 * tree.h (frame_base_decl): Add GTY marker.
2151 * var-tracking.c (frame_base_decl): Likewise.
2152
2153 2004-02-11 Daniel Berlin <dberlin@dberlin.org>
2154
2155 * dwarf2out.c (output_loc_list): Remove no longer necessary, and now
2156 incorrect, hunk.
2157 (add_location_or_const_value_attribute): Use text_section_label,
2158 not TEXT_SECTION_NAME.
2159
2160 2004-02-11 Per Bothner <per@bothner.com>
2161
2162 Represent column numbers using line-map's source_location.
2163 The "next available source_location" is now managed internally by
2164 line-maps.c rather than by clients.
2165 * line-map.h (struct line_map): New field column_bits.
2166 <from_line>: Rename field to start_location.
2167 (struct line_maps): New fields highest_location and max_column_hint.
2168 (linemap_check_files_exited): New declaration.
2169 (linemap_line_start): New declaration.
2170 (linemap_add): Remove from_line parameter; use highest_location field.
2171 (SOURCE_LINE, LAST_SOURCE_LINE): Modify to use column_bits.
2172 (SOURCE_COLUMN, LAST_SOURCE_LINE_LOCATION): New macros.
2173 (CURRENT_LINE_MAP): Remove macro.
2174 (linemap_position_for_column): New inline function.
2175 * line-map.c (linemap_init): Clear new fields.
2176 (linemap_check_files_exited): New function, extracted from ...
2177 (linemap_free): Use linemap_check_files_exited.
2178 (linemap_add): Remove from_line parameter. Various updates.
2179 (linemap_line_start): New function.
2180 (linemap_lookeup): Update for new field names.
2181 * cpphash.h (struct cpp_reader) <map>: Field removed. Because
2182 linemap_position_for_column may unpredictably change the current map,
2183 it is cleaner and simpler for us to not cache it in cpp_reader.
2184 (struct cpp_buffer): New sysp field.
2185 Changed warned_cplusplus_comments and from_stage3 to bitfields.
2186 * cppinit.c (cpp_read_min_file): pfile->map no longer exists.
2187 * cpplib.c (do_line, do_linemarker, _cpp_do_file_change): Get
2188 current map using linemap_lookup.
2189 (do_linemarker): Also set buffer's sysp field.
2190 (destringize_and_run): No longer need to decrement current line.
2191 * cppfiles.c (_cpp_stack_file): Set sysp from and in buffer.
2192 (search_path_head, open_file_failed): Use buffer's sysp.
2193 (cpp_make_system_header): Get current map using linemap_lookup.
2194 Also set buffer's sysp flag.
2195 * cppmacro.c (_cpp_builtin_macro_text): Likewise use linemap_lookup.
2196 * cpphash.h (CPP_INCREMENT_LINE): New macro.
2197 (struct cpp_buffer): Moved fields saved_cur, saved_rlimit to ...
2198 (struct cpp_reader): ... and adding saved_line_base field.
2199 * cpptrad.c (_cpp_overlay_buffer, _cpp_remove_overlay):
2200 Update accordingly. Don't adjust line.
2201 (_cpp_scan_out_logical_line): Use CPP_INCREMENT_LINE.
2202 * cpphash.c (CPP_IN_SYSTEM_HEADER): Replaced macro by ...
2203 (cpp_in_system_header): ... new inline function, using buffer's sysp.
2204 * cpperror.c (_cpp_begin_message): Update to use cpp_in_system_header.
2205 * cpplex.c (_cpp_lex_direct): Likewise.
2206 * cppmacro.c (_cpp_builtin_macro_text): Likewise.
2207 * cppmacro.c (_cpp_create_definition): Use buffer's sysp field.
2208 * cpplib.h (struct cpp_token): Rename line field to src_loc.
2209 Remove col field as it is now subsumed by src_loc.
2210 * cpperror.c: Update various field, parameter, and macro names.
2211 (print_location): If col==0, try SOURCE_COLUMN of line.
2212 (cpp_error): Use cur_token's src_loc field, rather than line+col.
2213 * cpplib.c (do_diagnostic): Token's src_loc fields replaces line+col.
2214 * cpplex.c (_cpp_process_line_notes, _cpp_lex_direct,
2215 _cpp_skip_block_comment): Use CPP_INCREMENT_LINE.
2216 (_cpp_temp_token): Replace cpp_token's line+col fields by src_loc.
2217 (_cpp_get_fresh_line): Don't need to adjust line for missing newline.
2218 (_cpp_lex_direct): Use linemap_position_for_column.
2219 * c-ppoutput.c (maybe_print_line, print_line): Don't take map
2220 parameter. Instead get it from the line_table global. Adjust callers.
2221 (print): Remove map field. Replace line field to src_line.
2222 (init_pp_output, account_for_newlines, maybe_print_line): Adjust.
2223 (cb_line_change): Use SOURCE_COLUMN. Minor optimizations.
2224 (pp_file_change): Use MAIN_FILE_P since we cannot checked print.map.
2225 Use LAST_SOURCE_LINE_LOCATION to "catch up" after #include.
2226 * cpptrad.c (copy_comment): Rename variable.
2227 * c-lex.c (map): Remove static variable, for same reason we removed
2228 cpp_reader's map field.
2229 (cb_line_change, cb_def_pragma, cb_define, cb_undef): Hence we need
2230 to call linemap_lookup.
2231 (cb_line_change): Token's line field replaced by src_loc.
2232 (fe_file_change): Use MAINFILE_P and LAST_SOURCE_LINE macros.
2233 Don't save new_map.
2234
2235 * cpphash.h, cpperror.c, cpplib.h: Some renames of fileline to
2236 source_location.
2237
2238 2004-02-11 Hartmut Penner <hpenner@de.ibm.com>
2239
2240 * config/rs6000/altivec.md (*movv4si_internal): At least one
2241 operand must be register_operand.
2242 (*movv8hi_internal1): Likewise.
2243 (*movv16qi_internal1): Likewise.
2244 (*movv4sf_internal1): Likewise.
2245
2246 2004-02-10 Aldy Hernandez <aldyh@redhat.com>
2247
2248 * config/rs6000/spe.md ("*movv2si_internal"): Check for register
2249 operand.
2250 (movv4hi_internal): Same.
2251 (movv2sf_internal): Same.
2252 (movv1di_internal): Same.
2253
2254 2004-02-11 Thiemo Seufer <seufer@csv.ica.uni-stuttgart.de>
2255
2256 * config/mips/mips.h (TARGET_OLDABI): Define. Use TARGET_NEWABI and
2257 TARGET_OLDABI consistently.
2258 * config/mips/mips.c (function_arg,mips_setup_incoming_varargs,
2259 mips_va_arg,override_options,compute_frame_size,
2260 mips_initial_elimination_offset,mips16_fp_args,build_mips16_call_stub
2261 ,mips_return_in_memory,mips_strict_argument_naming): Use TARGET_NEWABI
2262 and TARGET_OLDABI consistently.
2263 * config/mips/mips.md (exception_receiver): Likewise.
2264 * config/mips/linux64.h: Likewise.
2265
2266 2004-02-11 Hartmut Penner <hpenner@de.ibm.com>
2267
2268 * gcc/config/rs6000/rs6000.c (rs6000_override_options)
2269 Set AltiVec ABI and vrsave as default for ppc64 linux.
2270 (init_cumulative_args): Post error, if try to return
2271 value in AltiVec register without enable AltiVec.
2272 (function_arg_advance): Ditto for passing arguments.
2273
2274 2004-02-11 Richard Sandiford <rsandifo@redhat.com>
2275
2276 * emit-rtl.c (mark_label_nuses): Check that a LABEL_REF refers to
2277 a label before updating its usage count.
2278
2279 2004-02-10 Matt Kraai <kraai@alumni.cmu.edu>
2280
2281 * doc/install.texi: Remove extra cd.
2282
2283 2004-02-10 Ziemowit Laski <zlaski@apple.com>
2284
2285 * c-common.c (vector_size_helper): Remove; call
2286 reconstruct_complex_type() instead.
2287 * tree.c (reconstruct_complex_type): New function
2288 (formerly vector_size_helper() in c-common.c).
2289 (make_vector): Make externally visible.
2290 * tree.h (reconstruct_complex_type, make_vector): Add prototypes.
2291
2292 2004-02-10 Kazu Hirata <kazu@cs.umass.edu>
2293
2294 * config/h8300/h8300-protos.h: Add a prototype for
2295 h8300_regs_ok_for_stm.
2296 * config/h8300/h8300.c (h8300_regs_ok_for_stm): New.
2297 * config/h8300/h8300.md (stm_h8300s_2_advanced,
2298 stm_h8300s_2_normal, stm_h8300s_2, stm_h8300s_3_advanced,
2299 stm_h8300s_3_normal, stm_h8300s_3, stm_h8300s_4_advanced,
2300 stm_h8300s_4_normal, stm_h8300s_4, ldm_h8300s_2_advanced,
2301 ldm_h8300s_2_normal, ldm_h8300s_2, ldm_h8300s_3_advanced,
2302 ldm_h8300s_3_normal, ldm_h8300s_3, ldm_h8300s_4_advanced,
2303 ldm_h8300s_4_normal, ldm_h8300s_4): Use
2304 h8300_regs_ok_for_stm().
2305
2306 2004-02-10 Danny Smith <dannysmith@users.sourceforge.net>
2307
2308 PR c/14088
2309 * real.c (real_from_string): Look for 'X' as well as 'x' in
2310 hexfloat strings.
2311
2312 2004-02-10 Kazu Hirata <kazu@cs.umass.edu>
2313
2314 * config/h8300/h8300.md: Remove an incorrect comment about
2315 peephole2. Add comments.
2316
2317 2004-02-10 Josef Zlomek <zlomekj@suse.cz>
2318
2319 PR/14058
2320 * emit-rtl.c (set_decl_incoming_rtl): New.
2321 * tree.h (set_decl_incoming_rtl): New.
2322 * function.c (assign_parms): Use set_decl_incoming_rtl for setting
2323 DECL_INCOMING_RTL.
2324 * ada/misc.c (adjust_decl_rtl): Likewise.
2325
2326 2004-02-10 Per Bothner <per@bothner.com>
2327
2328 * c-opts.c (c_common_post_options): Don't emit working directory
2329 in cpp output if -P was specified.
2330
2331 2004-02-10 Paolo Bonzini <bonzini@gnu.org>
2332
2333 PR c/14092
2334 * fold-const.c (fold) <NEGATE_EXPR>: Convert result of
2335 negate_expr back to the original type.
2336
2337 2004-02-10 Alan Modra <amodra@bigpond.net.au>
2338
2339 * config/rs6000/linux64.h (MD_FALLBACK_FRAME_STATE_FOR): Don't
2340 bump retaddr here.
2341
2342 2004-02-10 Paolo Bonzini <bonzini@gnu.org>
2343
2344 * rtl.h (schedule_insns, schedule_ebbs, fix_sched_param,
2345 gen_lowpart_SUBREG): Move under the file in which they
2346 are actually declared.
2347
2348 2004-02-10 Arnaud Charlet <charlet@act-europe.fr>
2349
2350 * doc/sourcebuild.texi: Add libada documentation.
2351
2352 * doc/install.texi: Update documentation on Ada build, now
2353 that the GNAT lib and tools are built automatically.
2354
2355 2004-02-10 Richard Sandiford <rsandifo@redhat.com>
2356
2357 * config/mips/mips.h (TARGET_GPWORD): Return false for TARGET_NEWABI
2358 && TARGET_IRIX.
2359
2360 2004-02-09 Ziemowit Laski <zlaski@apple.com>
2361
2362 * objc/objc-act.c (get_super_receiver): Move '#ifdef OBJCPLUS'
2363 boundaries outside build_component_ref() call (a macro in ObjC++).
2364
2365 2004-02-09 Bob Wilson <bob.wilson@acm.org>
2366
2367 * config/xtensa/xtensa-protos.h (xtensa_copy_incoming_a7): Update.
2368 (init_cumulative_args): Likewise.
2369 (a7_overlap_mentioned_p): Delete prototype.
2370 * config/xtensa/xtensa.c (struct machine_function): Replace
2371 incoming_a7_copied field with need_a7_copy and vararg_a7 flags.
2372 Add set_frame_ptr_insn field.
2373 (xtensa_emit_move_sequence): Update call to xtensa_copy_incoming_a7.
2374 (xtensa_copy_incoming_a7): Rewrite to check need_a7_copy flag and check
2375 if the operand is an argument in a7. If so, copy a7 to a new pseudo
2376 at the function entry and replace the operand with the pseudo.
2377 (init_cumulative_args): Remove unused arguments. Add new "incoming"
2378 argument and record this flag in CUMULATIVE_ARGS.
2379 (function_arg): Remove result_mode and special-case code to handle
2380 arguments in a7. Instead, set need_a7_copy flag when there is an
2381 incoming argument in a7.
2382 (xtensa_expand_prologue): Remove code to search for set_frame_ptr insn
2383 and use the value recorded in cfun->machine->set_frame_ptr_insn.
2384 (xtensa_builtin_saveregs): Check for negative gp_left value. Set
2385 need_a7_copy and vararg_a7 flags. Use move_block_from_reg instead of
2386 special-case code.
2387 (a7_overlap_mentioned_p): Delete.
2388 * config/xtensa/xtensa.h (CUMULATIVE_ARGS): Add "incoming" flag.
2389 (INIT_CUMULATIVE_ARGS, INIT_CUMULATIVE_INCOMING_ARGS): Remove useless
2390 arguments to init_cumulative_args and pass "incoming" flag instead.
2391 (BLOCK_REG_PADDING): Delete.
2392 * config/xtensa/xtensa.md (movdi, movsf, movdf): Remove unnecessary
2393 checks for reload_in_progress and reload_completed. Update calls to
2394 xtensa_copy_incoming_a7.
2395 (ashlsi3): Rename existing insn to ashlsi3_internal. Add expander
2396 to call xtensa_copy_incoming_a7.
2397
2398 2004-02-09 DJ Delorie <dj@redhat.com>
2399
2400 * config/i386/xm-djgpp.h (GCC_DRIVER_HOST_INITIALIZATION): No
2401 longer modify standard_exec_prefix, standard_bindir_prefix, or
2402 standard_startfile_prefix.
2403
2404 2004-02-09 James E Wilson <wilson@specifixinc.com>
2405
2406 PR c++/11295
2407 * c-common.c (c_expand_expr, case STMT_EXPR): Change expand_expr call
2408 to expand_expr_real call, and pass in alt_rtl as last argument.
2409
2410 PR libstdc++/5625
2411 * builtin-types.def (BT_WORD, BT_FN_WORD_PTR): New.
2412 * builtins.c (expand_builtin): Handle BUILT_IN_EXTEND_POINTER.
2413 * builtins.def (BUILT_IN_EXTEND_POINTER): New.
2414 * except.c (expand_builtin_extend_pointer): New.
2415 * except.h (expand_builtin_extend_pointer): Declare.
2416
2417 2004-02-09 David Edelsohn <edelsohn@gnu.org>
2418
2419 * config/rs6000/rs6000.c (rs6000_emit_move): Remove splitting slow
2420 unaligned loads and stores.
2421
2422 2004-02-09 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
2423
2424 * config/mips/iris5.h (BSS_SECTION_ASM_OP): Define.
2425 * config/mips/iris6.h (BSS_SECTION_ASM_OP): Undef.
2426
2427 * config/mips/iris6.h (TARGET_ASM_NAMED_SECTION): Moved ...
2428 * config/mips/iris5.h: ... here.
2429 * config/mips/iris5gas.h (TARGET_ASM_NAMED_SECTION): Remove.
2430
2431 * config/mips/iris6.h (EXTRA_SECTION_FUNCTIONS): Move ...
2432 * config/mips/iris5.h: ... here.
2433
2434 2004-02-09 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
2435
2436 * configure.ac: Remove default executable files before AC_PROG_CC.
2437 * configure: Regenerate.
2438
2439 2004-02-09 Kazu Hirata <kazu@cs.umass.edu>
2440
2441 PR target/13721
2442 * config/h8300/h8300.c (byte_reg): Call abort() if asked to
2443 print a operand other than a register.
2444
2445 2004-02-09 Roger Sayle <roger@eyesopen.com>
2446
2447 * fold-const.c (fold) <NOP_EXPR>: Use the original type conversion
2448 tree code rather than call fold_convert, which doesn't specify a
2449 default floating point to integer conversion.
2450
2451 2004-02-08 Bernardo Innocenti <bernie@develer.com>
2452
2453 * config/m68k/m68k.c, config/m68k/m68k.md (SGS, SGS_CMP_ORDER): Remove
2454 code to support SGS assembler. Reformat adjacent code where possible.
2455 * config/m68k/m68k.c (switch_table_difference_label_flag): Remove
2456 definition.
2457 * config/m68k/m68k.h (PRINT_OPERAND_PUNCT_VALID_P): Remove support
2458 for '%#'.
2459 * config/m68k/linux.h, config/m68k/m68k.c,
2460 * config/m68k/math-68881.h: Replace `%#' with `#' in inline asm
2461 macros and asm_printf() format strings.
2462 * config/m68k/m68kelf.h (ASM_OUTPUT_CASE_END): Remove macro definition.
2463 * config/m68k/linux.h: Update copyright.
2464 * config/m68k/linux.h, config/m68k/m68k.c: Remove traling whitespace.
2465
2466 2004-02-08 Andreas Schwab <schwab@suse.de>
2467 Bernardo Innocenti <bernie@develer.com>
2468
2469 * config/m68k/m68k.h (REGISTER_NAMES): Prefix each name with
2470 REGISTER_PREFIX.
2471 * (M68K_FP_REG_NAME): New macro to specify an alternate name for the
2472 frame pointer register, overridable by OS targets.
2473 * (M68K_REGNAME): Macro to obtain register name for asm output,
2474 eventually replacing %a6 with M68K_FP_REG_NAME.
2475 * config/m68k/coff.h (REGISTER_NAMES): Don't redefine.
2476 * config/m68k/linux.h (REGISTER_NAMES): Likewise.
2477 * config/m68k/m68kelf.h (REGISTER_NAMES): Likewise.
2478 * config/m68k/netbsd-elf.h (REGISTER_NAMES): Likewise.
2479 * config/m68k/m68k.c: Use M68K_REGNAME(x) in place of reg_names[x].
2480
2481 2004-02-08 Kazu Hirata <kazu@cs.umass.edu>
2482
2483 * target-def.h (TARGET_STRUCT_VALUE_RTX): Define as
2484 hook_rtx_tree_int_null.
2485 * targhooks.c (default_struct_value_rtx): Remove.
2486 * targhooks.h: Remove the prototype for
2487 default_struct_value_rtx.
2488 * config/alpha/alpha.c, config/arc/arc.c, config/avr/avr.c,
2489 config/fr30/fr30.c, config/h8300/h8300.c, config/i386/i386.c,
2490 config/ip2k/ip2k.c, config/iq2000/iq2000.c,
2491 config/m32r/m32r.c, config/mcore/mcore.c, config/mips/mips.c,
2492 config/mn10300/mn10300.c, config/pdp11/pdp11.c,
2493 config/rs6000/rs6000.c, config/s390/s390.c,
2494 config/stormy16/stormy16.c, config/v850/v850.c,
2495 config/xtensa/xtensa.c (TARGET_STRUCT_VALUE_RTX): Remove.
2496 * doc/tm.texi (TARGET_STRUCT_VALUE_RTX): Document the default.
2497
2498 2004-02-08 Joseph S. Myers <jsm@polyomino.org.uk>
2499
2500 * README.Portability: Change "ISO C89" to "ISO C90".
2501 * c-parse.in (primary, initelt): Likewise.
2502
2503 2004-02-08 Richard Sandiford <rsandifo@redhat.com>
2504
2505 * real.c (encode_ibm_extended): Normalize the input value before
2506 converting it to a double. Handle the case where a normal value
2507 rounds to infinity.
2508
2509 2004-02-08 Kazu Hirata <kazu@cs.umass.edu>
2510
2511 * c-objc-common.c (c_cannot_inline_tree_fn): Fix a typo in a
2512 warning.
2513 * cse.c (preferrable): Change to preferable. Update all of its
2514 callers.
2515 * genautomata.c (ainsn): Change
2516 first_ainsn_with_given_equialence_num to
2517 first_ainsn_with_given_equivalence_num. Update all of its
2518 references.
2519
2520 2004-02-08 Jan Hubicka <jh@suse.cz>
2521
2522 * schedule-ebb.c (schedule_ebbs): Do not allocate reg life data.
2523
2524 2004-02-07 David Edelsohn <edelsohn@gnu.org>
2525
2526 * function.c (assign_parms): Fix formatting.
2527
2528 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
2529
2530 * default.h (PROMOTE_PROTOTYPES): Remove.
2531 * system.h (PROMOTE_FUNCTION_RETURN, PROMOTE_PROTOTYPES,
2532 STRUCT_VALUE_REGNUM, SETUP_INCOMING_VARARGS,
2533 EXPAND_BUILTIN_SAVEREGS): Poison.
2534 * target-def.h (TARGET_PROMOTE_FUNCTION_RETURN): Define as
2535 hook_bool_tree_false.
2536 (TARGET_PROMOTE_PROTOTYPES): Likewise.
2537 * target.h: Replace SETUP_INCOMING_VARARGS with
2538 targetm.calls.setup_incoming_varargs().
2539 * targhooks.c (default_promote_function_return): Remove.
2540 (default_promote_prototypes): Likewise.
2541 (default_struct_value_rtx): Always abort().
2542 (default_expand_builtin_saveregs): Always print an error
2543 message.
2544 (default_setup_incoming_varargs): Do nothing.
2545 (default_pretend_outgoing_varargs_named): Don't depend on
2546 SETUP_INCOMING_VARARGS.
2547 * targhooks.h: Remove the prototype for
2548 default_promote_function_return and
2549 default_promote_prototypes.
2550
2551 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
2552
2553 * system.h (SHARED_SECTION_ASM_OP): Poison.
2554 * varasm.c (data_section): Don't use SHARED_SECTION_ASM_OP.
2555 * doc/tm.texi (SHARED_SECTION_ASM_OP): Remove.
2556
2557 2004-02-07 Zack Weinberg <zack@codesourcery.com>
2558
2559 Bug 13856
2560 * c-decl.c (diagnose_mismatched_decls): Only give special
2561 treatment when olddecl is DECL_BUILT_IN, if C_DECL_INVISIBLE
2562 is also true.
2563 (merge_decls): Don't clear DECL_BUILT_IN_CLASS and
2564 DECL_FUNCTION_CODE when defining a built-in function.
2565 Don't update DECL_ESTIMATED_INSNS.
2566 * dwarf2out.c (dwarf2out_decl): Don't ignore built-in
2567 FUNCTION_DECLs.
2568 * tree.h: Delete DECL_ESTIMATED_INSNS.
2569 * tree-inline.c (struct inline_data): Delete inlined_insns field.
2570 (expand_call_inline, optimize_inline_calls): Don't update
2571 DECL_ESTIMATED_INSNS nor inlined_insns.
2572 * cgraphunit.c (cgraph_analyze_function): Don't update
2573 DECL_ESTIMATED_INSNS.
2574
2575 2004-02-07 Zack Weinberg <zack@codesourcery.com>
2576
2577 * c-common.c (shadow_warning): Delete.
2578 * c-common.h (free_parser_stacks, shadow_warning, sw_kind): Delete.
2579 * c-decl.c (warn_if_shadowing): Issue shadow warnings directly.
2580 * c-opts.c (c_common_parse_file): Don't call free_parser_stacks.
2581 * c-parse.in (free_parser_stacks): Delete.
2582
2583 2004-02-07 Nathanael Nerode <neroden@gcc.gnu.org>
2584
2585 * Makefile.in, config/t-slibgcc-darwin, config/t-slibgcc-elf-ver,
2586 config/t-slibgcc-sld, config/mips/t-iris5-6, config/sh/t-linux:
2587 Use the top level mkinstalldirs, not the one in the gcc subdir.
2588 * mkinstalldirs: Remove (from the gcc subdir).
2589
2590 2004-02-07 Roger Sayle <roger@eyesopen.com>
2591
2592 PR middle-end/13696
2593 * fold-const.c (fold_convert): New function to provide type
2594 conversion to the middle-end without using convert.
2595 (negate_expr, associate_trees, size_diffop, omit_one_operand,
2596 operand_equal_for_comparison_p, pedantic_omit_one_operand,
2597 invert_truthvalue, optimize_bit_field_compare, range_binop,
2598 decode_field_reference, make_range, build_range_check, unextend,
2599 fold_truthop, extract_muldiv_1, fold_mathfn_compare,
2600 fold_binary_op_with_conditional_arg, fold_inf_compare,
2601 fold_single_bit_test, fold, multiple_of_p): Replace all calls to
2602 convert with calls to fold_convert.
2603
2604 2004-02-07 Jan Hubicka <jh@suse.cz>
2605
2606 * genrecog.c (find_operand): add extra argument stop.
2607 (validate_pattern): Verify that mach_dup is duplicating operand
2608 defined lexically earlier.
2609
2610 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
2611
2612 * config.gcc: Don't mention MAX_LONG_TYPE_SIZE.
2613 * system.h (MAX_LONG_TYPE_SIZE, MAX_LONG_DOUBLE_TYPE_SIZE,
2614 MAX_WCHAR_TYPE_SIZE, GCOV_TYPE_SIZE): Poison.
2615 * config/avr/avr.h, config/h8300/h8300.h, config/i386/i386.h,
2616 config/ia64/ia64.h, config/ip2k/ip2k.h,
2617 config/iq2000/iq2000.h, config/mips/iris5.h,
2618 config/mips/mips.h, config/pa/pa-64.h, config/pa/pa.h,
2619 config/rs6000/aix51.h, config/rs6000/aix52.h,
2620 config/rs6000/darwin.h, config/rs6000/rs6000.h,
2621 config/s390/s390.h, config/sh/sh.h, config/sparc/freebsd.h,
2622 config/sparc/linux.h, config/sparc/linux64.h,
2623 config/sparc/netbsd-elf.h, config/sparc/sparc.h,
2624 config/xtensa/xtensa.h: Remove the definitions of
2625 MAX_LONG_TYPE_SIZE, MAX_LONG_DOUBLE_TYPE_SIZE, and/or
2626 MAX_WCHAR_TYPE_SIZE.
2627 * doc/tm.texi (MAX_LONG_TYPE_SIZE, MAX_LONG_DOUBLE_TYPE_SIZE,
2628 MAX_WCHAR_TYPE_SIZE, GCOV_TYPE_SIZE): Remove.
2629
2630 2004-02-07 Stephane Carrez <stcarrez@nerim.fr>
2631
2632 PR bootstrap/13990
2633 * config/m68hc11/m68hc11.md ("doloop_end"): Pass dummy arguments to
2634 gen_rtx_NE.
2635
2636 2004-02-07 Josef Zlomek <zlomekj@suse.cz>
2637
2638 * var-tracking.c (vt_add_function_parameters): Surround checkings by
2639 #ifdef ENABLE_CHECKING and #endif.
2640
2641 2004-02-07 Roger Sayle <roger@eyesopen.com>
2642
2643 * fold-const.c (negate_expr_p, negate_expr): Optimize -(A+B) into
2644 either (-A)-B or (-B)-A, if A or B is easily negated respectively.
2645 (fold) <MINUS_EXPR>: Optimize (A*C) - (B*C) -> (A-B)*C for both
2646 integer types and floating point with unsafe_math_optimizations.
2647 Add similar optimization for (A*C1) - (A*C2) -> A*(C1-C2).
2648 Optimize A - B as A + (-B), if B is easily negated.
2649
2650 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
2651
2652 * c-ppoutput.c, cfganal.c, diagnostic.h, print-rtl.c,
2653 config/darwin.c, config/darwin.h, config/ia64/ia64-c.c,
2654 config/m32r/linux.h, config/rs6000/ppc64-fp.c,
2655 config/sparc/openbsd.h, doc/makefile.texi, doc/passes.texi:
2656 Update copyright.
2657
2658 2004-02-07 Kazu Hirata <kazu@cs.umass.edu>
2659
2660 * c-ppoutput.c, var-tracking.c: Fix comment typos.
2661
2662 2004-02-06 James E Wilson <wilson@specifixinc.com>
2663
2664 * config/ia64/linux.h (MD_FALLBACK_FRAME_STATE_FOR): Only define for
2665 glibc 2.3 or better.
2666
2667 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2668
2669 * doc/tm.texi (TARGET_FLOAT_LIB_COMPARE_RETURNS_BOOL): Change
2670 to FLOAT_LIB_COMPARE_RETURNS_BOOL.
2671
2672 2004-02-07 Alan Modra <amodra@bigpond.net.au>
2673
2674 * config/rs6000/t-linux64 (LIB2FUNCS_EXTRA): Add darwin-ldouble.c.
2675 (SHLIB_MAPFILES): Add libgcc-ppc64.ver.
2676 (SHLIB_MKMAP_OPTS): Delete.
2677 (TARGET_LIBGCC2_CFLAGS): Add -specs.
2678 (bispecs): Add rule.
2679 * config/rs6000/libgcc-ppc64.ver: New file.
2680 * config/rs6000/ppc64-fp.c (__fixtfdi, __floatditf): New functions.
2681 (__floatdidf, __floatdisf): Optimize multiply.
2682 (__fixunstfdi): New function.
2683 * config/rs6000/rs6000.c (rs6000_complex_function_value): Allow for
2684 real and imag parts larger than one register.
2685 (function_arg): Correct type of reg used when fp arg split partially
2686 to stack.
2687 * config/rs6000/darwin-ldouble.c: Protect with #if !_SOFT_FLOAT
2688 and __MACH__ or __powerpc64__.
2689
2690 2004-02-06 Roger Sayle <roger@eyesopen.com>
2691 Ulrich Weigand <uweigand@de.ibm.com>
2692
2693 * builtins.c (expand_builtin_signbit): Use extract_bit_field instead
2694 of gen_highpart or gen_lowpart when the floating point format is
2695 wider than the result mode.
2696
2697 2004-02-06 Andrew Pinski <pinskia@physics.uc.edu>
2698
2699 * dwarf2out.c (loclabel_num): Move into #ifdef
2700 DWARF2_DEBUGGING_INFO.
2701
2702 2004-02-06 Ziemowit Laski <zlaski@apple.com>
2703
2704 * objc/objc-act.c (build_super_template) the 'class' field of
2705 'struct _objc_super' shall be named 'super_class' #ifdef OBJCPLUS.
2706 (get_super_receiver): Likewise.
2707
2708 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2709
2710 * reload1.c (check_eliminable_occurrences): Optimize the reset
2711 of can_eliminate.
2712 (eliminate_regs_in_insn): Likewise.
2713
2714 2004-02-06 Daniel Berlin <dberlin@dberlin.org>
2715 Josef Zlomek <zlomekj@suse.cz>
2716
2717 * dwarf2out.c (struct gcc_debug_hooks): Call dwarf2out_begin_function
2718 at the beginning of function, call dwarf2out_var_location for
2719 NOTE_INSN_VAR_LOCATION note.
2720 (struct var_loc_node, struct var_loc_list_def, loclabel_num,
2721 decl_loc_table): New.
2722 (lookup_decl_loc): New function.
2723 (add_var_loc_to_decl): New function.
2724 (based_loc_descr): Added parameter can_use_fbreg, DW_OP_fbreg is used
2725 only if can_use_fbreg.
2726 (mem_loc_descriptor): Added parameter can_use_fbreg, pass it to other
2727 functions.
2728 (loc_descriptor): Likewise. Process VAR_LOCATION.
2729 (concat_loc_descriptor): Call loc_descriptor with can_use_fbreg == true.
2730 (loc_descriptor_from_tree): Call mem_loc_descriptor with
2731 can_use_fbreg == true.
2732 (add_location_or_const_value_attribute): Added parameter enum
2733 dwarf_attribute attr, generate attribute ATTR. Create the location list.
2734 (add_bound_info): Call loc_descriptor with can_use_fbreg == true.
2735 (gen_formal_parameter_die): Call add_location_or_const_value_attribute
2736 with attr == DW_AT_location.
2737 (gen_subprogram_die): Generate the location list for DW_AT_frame_base
2738 if frame_base_decl is defined and has a location list.
2739 (gen_variable_die): Call add_location_or_const_value_attribute with
2740 attr == DW_AT_location.
2741 (dwarf2out_var_location): New function.
2742 (dwarf2out_begin_function): New function.
2743 (dwarf2out_init): Create decl_loc_table.
2744
2745 2004-02-06 Ulrich Weigand <uweigand@de.ibm.com>
2746
2747 * loop.c (force_movables): Transitively increase the priorities of
2748 all insns forces by an insn, not just the first one.
2749
2750 2004-02-06 Josef Zlomek <zlomekj@suse.cz>
2751 Daniel Berlin <dberlin@dberlin.org>
2752
2753 Josef Zlomek <zlomekj@suse.cz>
2754 * Makefile.in (var-tracking.o): New.
2755 * common.opt (fvar-tracking): New.
2756 * flags.h (flag_var_tracking): New.
2757 * gengtype.c (adjust_field_rtx_def): NOTE_INSN_VAR_LOCATION was added.
2758 * opts.c (common_handle_option): Add OPT_fvar_tracking.
2759 * print-rtl.c (print_rtx): NOTE_INSN_VAR_LOCATION was added.
2760 * rtl.c (note_insn_name): Likewise.
2761 * rtl.def (VAR_LOCATION): New.
2762 * rtl.h (NOTE_VAR_LOCATION): New.
2763 (NOTE_VAR_LOCATION_DECL): New.
2764 (NOTE_VAR_LOCATION_LOC): New.
2765 (enum insn_note): NOTE_INSN_VAR_LOCATION was added.
2766 (variable_tracking_main): New exported function.
2767 * timevar.def (TV_VAR_TRACKING): New.
2768 * toplev.c (enum dump_file_index): Added DFI_vartrack.
2769 (dump_file): "vartrack" was added (-dV).
2770 (flag_var_tracking): New.
2771 (f_options): "var-tracking" was added.
2772 (rest_of_handle_variable_tracking): New function.
2773 (rest_of_compilation): Run variable tracking.
2774 (process_options): If user has not specified flag_var_tracking set it
2775 according to optimize, debug_info_level and debug_hooks.
2776 * tree.h (frame_base_decl): New.
2777 * var-tracking.c: New file.
2778 * config/ia64/ia64.c (ia64_flag_var_tracking): New variable.
2779 (ia64_override_options): Set flags to run variable tracking in machine
2780 dependent reorg instead of toplev.c.
2781 (ia64_reorg): Run variable tracking if wanted.
2782 * doc/invoke.texi: Mention variable tracking in -dV,
2783 add and -fvar-tracking.
2784 * doc/passes.texi: Added variable tracking pass.
2785
2786 Daniel Berlin <dberlin@dberlin.org>
2787 * debug.h (struct gcc_debug_hooks): Added var_location debug hook.
2788 * dbxout.c (dbx_debug_hooks): Likewise.
2789 (xcoff_debug): Likewise.
2790 * debug.c (do_nothing_debug_hooks): Likewise.
2791 * dwarf2out.c (dwarf2_debug_hooks): Likewise.
2792 * dwarfout.c (dwarf_debug_hooks): Likewise.
2793 * sdbout.c (sdb_debug_hooks): Likewise.
2794 * vmsdbgout.c (vmsdbg_debug_hooks): Likewise.
2795 * final.c (final_scan_insn): Call var_location debug hook for each
2796 NOTE_INSN_VAR_LOCATION.
2797
2798 2004-02-06 Jan Hubicka <jh@suse.cz>
2799
2800 * flow.c (update_life_info): Allocate reg_deaths when called from
2801 scheudler.
2802 (attempt_auto_inc): Update life ranges accordingly.
2803
2804 2004-02-06 Ulrich Weigand <uweigand@de.ibm.com>
2805
2806 PR debug/11816
2807 * dwarf2out.c (gen_decl_die): Handle anonymous struct members.
2808
2809 2004-02-06 Ulrich Weigand <uweigand@de.ibm.com>
2810
2811 * cfganal.c (flow_call_edges_add): Never split a libcall block.
2812
2813 2004-02-06 Daniel Berlin <dberlin@dberlin.org>
2814
2815 * dwarf2out.c (output_loc_list): Don't use deltas if we have
2816 a separate line info table in use.
2817 Use the correct size for terminators.
2818 (output_die): Use offset, not delta.
2819
2820 2004-02-06 H.J. Lu <hongjiu.lu@intel.com>
2821
2822 * doc/invoke.texi: Remove the pni option from -mfpmath=.
2823
2824 2004-02-06 Jan Hubicka <jh@suse.cz>
2825
2826 * recog.c (split_all_insns): Do not update reg info.
2827 * regrename.c (regrename_optimize): Likewise.
2828 * toplev.c (rest_of_handle_reorder_blocks): Likewise.
2829 * flow.c (struct propagate_block_info): Add insn_num field.
2830 (reg_deaths): New array.
2831 (life_analysis): Free reg_deaths info.
2832 (allocate_reg_life_data): Allocate reg_deaths array.
2833 (propagate_one_insn): Use new array.
2834 (init_propagate_block): Initialize it.
2835 (free_propagate_block_info): Finish compuation of
2836 REG_LIVE_LENGTH
2837 (attempt_auto_inc): Sanity check that REG_INFO is not
2838 computed at same time.
2839 (mark_used_regs): Update new array.
2840
2841 * reg-stack.c (subst_stack_regs): Unshare clobbers before
2842 substitution.
2843
2844 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2845
2846 * config/s390/s390.md (*extendsiqi2_short_displ): Change to
2847 *extendqisi2_short_displ.
2848
2849 2004-02-06 Alan Modra <amodra@bigpond.net.au>
2850
2851 * doc/tm.texi (INIT_CUMULATIVE_ARGS): Update doco.
2852 * calls.c (expand_call): Pass n_named_args to INIT_CUMULATIVE_ARGS.
2853 (emit_library_call_value_1): Likewise pass nargs.
2854 * expr.c (block_move_libcall_safe_for_call_parm): Pass 3 here.
2855 * function.c (assign_parms): Pass -1 to INIT_CUMULATIVE_ARGS.
2856 * config/rs6000/rs6000.c (init_cumulative_args): Use n_named_args
2857 parameter instead of scanning TYPE_ARGS_TYPES to count args.
2858 * config/rs6000/rs6000-protos.h (init_cumulative_args): Update
2859 prototype.
2860 * config/rs6000/rs6000.h (INIT_CUMULATIVE_ARGS): Pass extra arg.
2861 (INIT_CUMULATIVE_INCOMING_ARGS): Set extra arg to 1000.
2862 (INIT_CUMULATIVE_LIBCALL_ARGS): Set extra arg to 0.
2863 * config/sh/sh.c (sh_output_mi_thunk): Pass 1 as n_named_args to
2864 INIT_CUMULATIVE_ARGS.
2865 * config/alpha/alpha.h (INIT_CUMULATIVE_ARGS): Update.
2866 * config/alpha/unicosmk.h, config/alpha/vms.h, config/arc/arc.h,
2867 config/arm/arm.h, config/avr/avr.h, config/c4x/c4x.h,
2868 config/cris/cris.h, config/fr30/fr30.h, config/frv/frv.h,
2869 config/h8300/h8300.h, config/i386/i386.h, config/i860/i860.h,
2870 config/ia64/ia64.h, config/ip2k/ip2k.h, config/iq2000/iq2000.h,
2871 config/iq2000/iq2000.c, config/m32r/m32r.h, config/m68hc11/m68hc11.h,
2872 config/m68k/m68k.h, config/mcore/mcore.h, config/mips/mips.h,
2873 config/mmix/mmix.h, config/mn10300/mn10300.h, config/ns32k/ns32k.h,
2874 config/pa/pa.h, config/pdp11/pdp11.h, config/s390/s390.h,
2875 config/sh/sh.h, config/sparc/sparc.h, config/stormy16/stormy16.h,
2876 config/v850/v850.h, config/vax/vax.h, config/xtensa/xtensa.h: Likewise.
2877
2878 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2879
2880 * genemit.c (gen_exp) [CONST_INT]: Use const_int_rtx whenever
2881 possible.
2882
2883 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2884
2885 * reload1.c (eliminate_regs_in_insn): If a set has a REG_EQUAL
2886 note containing (plus (reg) (const_int)), where reg is an
2887 eliminable reg, then perform the register elimination without
2888 depending on eliminate_regs().
2889
2890 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2891
2892 * config/arc/arc.c (arc_return_in_memory): Check the return
2893 value of int_size_in_bytes against -1. Don't check
2894 TREE_ADDRESSABLE.
2895 * config/avr/avr.c (avr_return_in_memory): Check the return
2896 value of int_size_in_bytes against -1.
2897 * config/ip2k/ip2k.c (ip2k_return_in_memory): Likewise.
2898 * config/m68hc11/m68hc11.c (m68hc11_return_in_memory):
2899 Likewise.
2900 * config/mcore/mcore.c (mcore_return_in_memory): Likewise.
2901 * config/stormy16/stormy16.c (xstormy16_return_in_memory):
2902 Likewise.
2903
2904 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2905
2906 * config/frv/frv-protos.h: Remove the prototype for
2907 frv_setup_incoming_varargs.
2908 * config/frv/frv.c (TARGET_SETUP_INCOMING_VARARGS): New.
2909 (frv_setup_incoming_varargs): Make it static.
2910 * config/frv/frv.h (SETUP_INCOMING_VARARGS): Remove.
2911
2912 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2913
2914 * config/fr30/fr30-protos.h: Remove the prototype for
2915 fr30_setup_incoming_varargs.
2916 Update the prototypes for fr30_num_arg_regs and
2917 fr30_function_arg_partial_nregs.
2918 * config/fr30/fr30.c (TARGET_STRUCT_VALUE_RTX): New.
2919 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
2920 (fr30_setup_incoming_varargs): Make it static.
2921 Add argument second_time. Don't do anything when second_time
2922 is nonzero.
2923 (fr30_num_arg_regs): Change the type of the first argument to
2924 enum machine_mode.
2925 (fr30_function_arg_partial_nregs): Change the type of the
2926 second argument to enum machine_mode.
2927 * config/fr30/fr30.h (STRUCT_VALUE): Remove.
2928 (SETUP_INCOMING_VARARGS): Remove.
2929
2930 2004-02-06 Kazu Hirata <kazu@cs.umass.edu>
2931
2932 * config/arc/arc-protos.h: Remove the prototype for
2933 arc_setup_incoming_varargs.
2934 * config/arc/arc.c (TARGET_ASM_EXTERNAL_LIBCALL): New.
2935 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
2936 (arc_setup_incoming_varargs): Make it static.
2937 (arc_external_libcall): Likewise.
2938 * config/arc/arc.h (SETUP_INCOMING_VARARGS): Remove.
2939 Remove the commented-out definition of
2940 ASM_OUTPUT_EXTERNAL_LIBCALL.
2941
2942 2004-02-05 SUGIOKA Toshinobu <sugioka@itonet.co.jp>
2943
2944 * config/sh/t-linux (SHLIB_INSTALL): Prepend $$(DESTDIR)
2945 to $$(slibdir) in the installation commands.
2946
2947 2004-02-05 David Edelsohn <edelsohn@gnu.org>
2948
2949 * reload.c (refers_to_regno_for_reload_p): Index hard_regno_nregs
2950 with inner_regno, not regno.
2951 * rtlanal.c (refers_to_regno_p): Same.
2952
2953 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
2954
2955 * config.gcc: Remove i370 support.
2956
2957 2004-02-05 Kelley Cook <kcook@gcc.gnu.org>
2958
2959 * doc/install.texi: Update automake and autoconf version
2960 requirements. Note where to find gcj automake version.
2961
2962 2004-02-05 Kelley Cook <kcook@gcc.gnu.org>
2963
2964 * Makefile.in (generate-manpages): Move dependencies to ...
2965 (man): here.
2966 * doc/makefile.texi: Document new targets.
2967 * doc/sourcebuild.texi (Make-lang.in): Document new langhooks.
2968
2969 2004-02-05 Kelley Cook <kcook@gcc.gnu.org>
2970
2971 PR/13485
2972 Makefile.in (srcextra): Add a level of indirection to ...
2973 (gcc.srcextra): ... here.
2974 (po-generated): Delete.
2975 (po/$(PACKAGE).pot: Use srcextra instead of po-generated. Depend on
2976 options.c.
2977 (start.encap): Remove superfluous lang.srcextra dependency.
2978 objc/Make-lang.in (po-generated): Delete.
2979
2980 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
2981
2982 * config/ia64/ia64.c (REG_GP): Remove.
2983
2984 2004-02-05 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
2985
2986 * config/mips/iris5gas.h (PREFERRED_DEBUGGING_TYPE): Define.
2987
2988 2004-02-05 Devang Patel <dpatel@apple.com>
2989
2990 * dwarf2out.c (force_type_die): Look up input type itself
2991 instead of root_type() of type.
2992
2993 2004-02-05 Andreas Krebbel <krebbel1@de.ibm.com>
2994
2995 * config/s390/s390.md ("*tmqidi_ext"): New insn.
2996 ("*extendqidi2_short_displ", "*extendsiqi2_short_displ"): Old
2997 pre-reload splitters are transformed to post-reload
2998 define_insn_and_split patterns.
2999 ("*tmqisi_ext"): Renamed old "*tmqi_ext".
3000
3001 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
3002
3003 * config/cris/cris.h: Replace PROMOTE_PROTOTYPES with
3004 TARGET_PROMOTE_PROTOTYPES.
3005
3006 2004-02-05 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
3007
3008 PR middle-end/13750
3009 Revert:
3010 2004-01-15 Geoffrey Keating <geoffk@apple.com>
3011 PR pch/13361
3012 * c-typeck.c (constructor_asmspec): Delete.
3013 (struct initializer_stack): Delete field 'asmspec'.
3014 (start_init): Delete saving of asmspec.
3015 (finish_init): Don't update constructor_asmspec.
3016 * dwarf2out.c (rtl_for_decl_location): Duplicate string from tree.
3017 * stmt.c (expand_asm): Duplicate strings from tree.
3018 (expand_asm_operands): Likewise.
3019 * tree.c (tree_size): Update computation of size of STRING_CST.
3020 (make_node): Don't make STRING_CST nodes.
3021 (build_string): Allocate string with tree node.
3022 * tree.def (STRING_CST): Update comment.
3023 * tree.h (TREE_STRING_POINTER): Adjust for change to STRING_CST.
3024 (tree_string): Place contents of string in tree node.
3025 * config/sh/sh.c (sh_handle_sp_switch_attribute): Duplicate string
3026 from tree.
3027
3028 2004-02-05 Joseph S. Myers <jsm@polyomino.org.uk>
3029
3030 * diagnostic.h (DEFINE_DIAGNOSTIC_KIND): Change parameter M to
3031 msgid.
3032
3033 2004-02-05 Dorit Naishlos <dorit@il.ibm.com>
3034
3035 * config/rs6000/altivec.md (*movv4si_internal): At least one
3036 operand must be altivec_register_operand.
3037 (*movv8hi_internal1): Likewise.
3038 (*movv16qi_internal1): Likewise.
3039 (*movv4sf_internal1): Likewise.
3040
3041 2004-02-05 David Edelsohn <edelsohn@gnu.org>
3042
3043 * configure.ac (gcc_cv_as_powerpc_mfcrf): Correct test for mfcr.
3044 * configure: Regenerate.
3045
3046 2004-02-05 Jonathan Wakely <redi@gcc.gnu.org>
3047
3048 * doc/install.texi: Update description of --gxx-include-dir to
3049 give correct default value.
3050
3051 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
3052
3053 * config/h8300/h8300.h (REG_OK_FOR_BASE_NONSTRICT_P): Replace
3054 8 with MAC_REG.
3055
3056 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
3057
3058 * config/pa/pa.c (emit_hpdiv_const): Replace gen_rtx with
3059 gen_rtx_PARALLEL.
3060
3061 2004-02-05 Kazu Hirata <kazu@cs.umass.edu>
3062
3063 * emit-rtl.c: Update the comment about the file.
3064
3065 2004-02-05 Joseph S. Myers <jsm@polyomino.org.uk>
3066
3067 * sourcebuild.texi (Test Idioms): Update testcase naming
3068 conventions.
3069
3070 2004-02-04 Per Bothner <per@bothner.com>
3071
3072 Partially revert/redo 2003-10-01 change; fix -fworking-directory.
3073 * c-ppoutput.c (pp_dir_change): New function.
3074 * c-common.h (pp_dir_change): New declaration.
3075 * cpplib.h (struct cpp_options): Remove working_directory field.
3076 * cppinit.c (cpp_find_main_file, cpp_push_main_file): Merge back to
3077 (cpp_read_main_file): as before 10-01. Call _cpp_stack_file.
3078 Don't handle -fworking_directory here, but in c_common_post_options.
3079 (read_original_directory): Don't back up when done.
3080 Don't clear no-longer used working_directory flag.
3081 * cpplib.h: Update declarations to match.
3082 * c-lex.c (cb_dir_change): Move to c-opts.c.
3083 (init_c_lex): Don't set dir_change callback here, since we want
3084 to set it even if flag_preprocess_only.
3085 * c-opts.c (cb_dir_change): Function moved from c-lex.c.
3086 (c_common_post_options): Set dir_change callback.
3087 Call pp_dir_change if approporiate.
3088 (finish_options): Don't call cpp_find_main_file here. Hence remove
3089 unneeded parameter and result. Do LC_RENAME for <built-in>.
3090 (c_common_post_options): Call cpp_read_main_file here instead.
3091 (c_common_init): Update accordingly.
3092 (push_command_line_include): Don't cpp_push_main_file.
3093 Do LC_RENAME rather than LC_LEASE to get back to main file.
3094 Compared to pre-10-01 version, inline cpp_rename_to_main_file.
3095 (c_common_parse_file): Call cpp_read_main_file for subsequent main
3096 files, but call finish_options for all files.
3097 * c-opts.c (sanitize_cpp_opts): Don't set cpp_opts->working_directory.
3098 * fix-header.c (read_scan_file): Call cpp_read_main_file instead of
3099 cpp_find_main_file + cpp_push_main_file.
3100 * c-lex.c (fe_file_change): Don't set main_input_filename here.
3101 * opts.c (handle_options): Only set main_input_filename first time.
3102
3103 2004-02-05 Ian Lance Taylor <ian@wasabisystems.com>
3104
3105 * config/arm/arm.h (REG_CLASS_NAMES): Add missing comma.
3106
3107 2004-02-04 Geoffrey Keating <geoffk@apple.com>
3108
3109 * reload.c (find_equiv_reg): When checking for register overlap,
3110 don't index hard_regno_nregs with a pseudo-reg.
3111
3112 2004-02-04 Ulrich Weigand <uweigand@de.ibm.com>
3113
3114 * config/s390/s390.c (s390_trampoline_template): Remove gen_rtx().
3115
3116 2004-02-04 David Edelsohn <edelsohn@gnu.org>
3117
3118 * reload.c (refers_to_regno_for_reload_p): Test regno, not inner_regno,
3119 against FIRST_PSEUDO_REGISTER.
3120
3121 2004-02-04 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
3122
3123 * Makefile.in: Move target, host overrides after per-language
3124 fragments.
3125
3126 * config/mips/t-iris5-as (FORCE_DEBUG_ADAFLAGS): Clear.
3127 (GNATLIBCFLAGS): Remove -g.
3128
3129 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3130
3131 * config/alpha/alpha.c, config/arc/arc.c, config/avr/avr.c,
3132 config/i386/i386.c, config/i386/i386.h, config/i386/i386.md,
3133 config/ia64/ia64.c, config/ia64/unwind-ia64.c,
3134 config/m32r/m32r.c, config/ns32k/ns32k.c, config/pa/pa.c,
3135 config/pdp11/pdp11.c, config/rs6000/rs6000.c,
3136 config/sparc/sparc.c, config/vax/vax.c: Revert the
3137 replacements of "FALLTHRU" with "Fall through" done in the
3138 previous patch.
3139
3140 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3141
3142 * config/darwin.c, config/darwin.h, config/freebsd-spec.h,
3143 config/arm/arm.c, config/arm/arm.md,
3144 config/cris/cris-protos.h, config/fr30/fr30.c,
3145 config/fr30/fr30.h, config/h8300/h8300.c, config/i386/i386.h,
3146 config/i860/i860.c, config/i860/i860.h, config/ia64/ia64-c.c,
3147 config/ia64/ia64.c, config/ia64/ia64.h, config/ip2k/ip2k.h,
3148 config/ip2k/ip2k.md, config/ip2k/libgcc.S,
3149 config/m32r/linux.h, config/m32r/m32r.c, config/m32r/m32r.h,
3150 config/m68k/m68k.c, config/m68k/netbsd-elf.h,
3151 config/mips/mips.c, config/mmix/mmix.c, config/mmix/mmix.md,
3152 config/ns32k/netbsd.h, config/ns32k/ns32k.c,
3153 config/ns32k/ns32k.h, config/pdp11/pdp11.h,
3154 config/rs6000/darwin-ldouble.c, config/s390/s390.h,
3155 config/s390/s390.md, config/sparc/netbsd-elf.h,
3156 config/sparc/openbsd.h, config/sparc/sparc.c,
3157 config/xtensa/lib2funcs.S: Fix comment formatting.
3158
3159 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3160
3161 * config/alpha/alpha.c, config/arc/arc.c,
3162 config/arm/arm-cores.def, config/arm/arm.c, config/arm/arm.h,
3163 config/arm/arm1026ejs.md, config/arm/arm1136jfs.md,
3164 config/arm/arm926ejs.md, config/arm/vfp.md, config/avr/avr.c,
3165 config/c4x/c4x.c, config/cris/cris.c, config/frv/frv.md,
3166 config/i386/i386.c, config/i386/i386.h, config/i386/i386.md,
3167 config/ia64/ia64.c, config/ia64/unwind-ia64.c,
3168 config/iq2000/iq2000.c, config/m32r/m32r.c,
3169 config/mips/mips.c, config/mmix/mmix.c, config/mmix/mmix.h,
3170 config/ns32k/ns32k.c, config/pa/pa.c, config/pdp11/pdp11.c,
3171 config/rs6000/darwin-ldouble.c, config/rs6000/rs6000.c,
3172 config/rs6000/rs6000.h, config/sparc/sparc.c,
3173 config/vax/vax.c: Fix comment typos. Follow spelling
3174 conventions.
3175
3176 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3177
3178 * alloc-pool.h, c-convert.c, c-lang.c, c-tree.h,
3179 caller-save.c, df.h, genconfig.c, global.c, lcm.c,
3180 ra-rewrite.c, ra.c, regclass.c, regs.h, resource.c,
3181 sched-rgn.c, config/arm/aof.h, config/arm/cirrus.md,
3182 config/arm/fpa.md, config/arm/iwmmxt.md,
3183 config/arm/netbsd-elf.h, config/arm/netbsd.h,
3184 config/m68hc11/m68hc11.md, config/mips/iris5.h,
3185 config/mn10300/mn10300.md, config/rs6000/altivec.md,
3186 config/sparc/netbsd-elf.h: Update copyright.
3187
3188 2004-02-04 Eric Botcazou <ebotcazou@libertysurf.fr>
3189
3190 * config/sparc/sparc.c (function_arg_pass_by_reference): Return 1
3191 for all modes whose size is greater than 8 bytes if ARCH32.
3192 (sparc_va_arg): Handle all modes whose size is greater than 8 bytes
3193 by reference if ARCH32.
3194
3195 2004-02-04 Aldy Hernandez <aldyh@redhat.com>
3196
3197 * cgraphunit.c (cgraph_postorder): Fix typo in comment.
3198
3199 2004-02-04 Ulrich Weigand <uweigand@de.ibm.com>
3200
3201 * config/s390/s390.md ("*la_64" + peepholes, "reload_indi"): Move
3202 to before adddi3 insn patterns.
3203 ("*la_31" + peepholes, "*la_31_and", "*la_31_and_cc", "force_la_31",
3204 "reload_insi"): Move to before addsi3 insn patterns.
3205
3206 2004-02-04 Mark Mitchell <mark@codesourcery.com>
3207
3208 * calls.c (initialize_argument_information): Add CALL_FROM_THUNK_P
3209 parameter. Use it instead of current_function_is_thunk.
3210 * function.h (struct function): Update documentation for is_thunk.
3211 * tree.h (CALL_FROM_THUNK_P): New macro.
3212 * config/alpha/alpha.c (alpha_sa_mask): Do not check
3213 no_new_pseudos when testing current_function_is_thunk.
3214 * config/rs6000/rs6000.c (rs6000_ra_ever_killed): Likeiwse.
3215
3216 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3217
3218 * doc/tm.texi: Replace SETUP_INCOMING_VARARGS with
3219 TARGET_SETUP_INCOMING_VARARGS.
3220
3221 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3222
3223 * emit-rtl.c (gen_rtx): Remove.
3224 * genattrtab.c: Don't mention gen_rtx in a comment.
3225 * rtl.h: Remove the prototype for gen_rtx.
3226 * doc/md.texi: Replace gen_rtx with gen_rtx_REG.
3227
3228 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3229
3230 * config/arc/arc.h, config/fr30/fr30.h
3231 (SETUP_INCOMING_VARARGS): Remove the target-independent
3232 comments.
3233 * doc/tm.texi: Don't mention deprecated target macros.
3234
3235 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3236
3237 * config/fr30/fr30.h (FUNCTION_VALUE): Remove the
3238 target-independent comment.
3239
3240 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3241
3242 * doc/interface.texi, doc/tm.texi, doc/trouble.texi: Don't
3243 mention deprecated target macros.
3244
3245 2004-02-04 Kazu Hirata <kazu@cs.umass.edu>
3246
3247 * config.gcc: Remove obsolete ports and configurations.
3248 * config/linux-aout.h, config/netware.h,
3249 config/t-linux-gnulibc1, config/d30v/abi,
3250 config/d30v/d30v-protos.h, config/d30v/d30v.c,
3251 config/d30v/d30v.h, config/d30v/d30v.md,
3252 config/d30v/libgcc1.asm, config/d30v/t-d30v,
3253 config/dsp16xx/dsp16xx-modes.def,
3254 config/dsp16xx/dsp16xx-protos.h, config/dsp16xx/dsp16xx.c,
3255 config/dsp16xx/dsp16xx.h, config/dsp16xx/dsp16xx.md,
3256 config/i370/README, config/i370/i370-c.c,
3257 config/i370/i370-protos.h, config/i370/i370.c,
3258 config/i370/i370.h, config/i370/i370.md, config/i370/linux.h,
3259 config/i370/mvs.h, config/i370/oe.h, config/i370/t-i370,
3260 config/i386/freebsd-aout.h, config/i386/linux-aout.h,
3261 config/i386/moss.h, config/i386/netware.h,
3262 config/i386/svr3.ifile, config/i386/svr3dbx.h,
3263 config/i386/svr3gas.h, config/i386/svr3z.ifile,
3264 config/i386/t-udk, config/i386/udk.h, config/i386/vsta.h,
3265 config/i960/i960-c.c, config/i960/i960-coff.h,
3266 config/i960/i960-modes.def, config/i960/i960-protos.h,
3267 config/i960/i960.c, config/i960/i960.h, config/i960/i960.md,
3268 config/i960/rtems.h, config/i960/t-960bare,
3269 config/m68k/hp310.h, config/m68k/hp320.h,
3270 config/m68k/hp320base.h, config/m68k/m68kv4.h,
3271 config/m68k/netbsd.h, config/m68k/sgs.h, config/m68k/t-hp320:
3272 Remove.
3273 * doc/extend.texi, doc/install.texi, doc/invoke.texi,
3274 doc/md.texi: Remove mentions of obsolete ports.
3275
3276 2004-02-04 Jan Hubicka <jh@suse.cz>
3277
3278 * alias.c (find_base_term, get_addr): Do not dereference NULL
3279 pointer when all VALUE's locations has been invalidated.
3280 (rtx_equal_for_memref_p): Simplify checking of VALUEs.
3281
3282 2004-02-03 Wolfgang Bangerth <bangerth@dealii.org>
3283
3284 * doc/invoke.texi (x86 options): Fix spelling/wording.
3285
3286 2004-02-03 Richard Sandiford <rsandifo@redhat.com>
3287
3288 * config/mips/iris5.h (ASM_OUTPUT_ASCII): Use mips_output_ascii to
3289 put the original string in a comment.
3290 * config/mips/mips-protos.h (mips_output_ascii): Add prefix argument.
3291 * config/mips/mips.c (mips_output_ascii): Likewise.
3292 * config/mips/mips.h (ASM_OUTPUT_ASCII): Adjust accordingly.
3293
3294 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
3295
3296 * system.h (GIV_SORT_CRITERION): Poison.
3297 * config/avr/avr.h (GIV_SORT_CRITERION): Remove.
3298 * config/ip2k/ip2k.h (GIV_SORT_CRITERION): Likewise.
3299
3300 2004-02-03 Roger Sayle <roger@eyesopen.com>
3301
3302 PR target/9348
3303 * expr.c (expand_expr_real) <MULT_EXPR>: When performing widening
3304 multiplies with a multiplication of the wrong signedness, its the
3305 signedness of the multiplication that we've performed that needs to
3306 be passed to expand_mult_highpart_adjust. Avoid emitting a nop-move
3307 if expand_mult_highpart_adjust places the result in target.
3308
3309 2004-02-03 Richard Henderson <rth@redhat.com>
3310
3311 * varasm.c (const_desc_rtx_sym_eq): Compare symbol strings.
3312
3313 2004-02-03 J"orn Rennecke <joern.rennecke@superh.com>
3314
3315 * config.gcc (sh[234]l): Use little endian fragments.
3316
3317 2004-02-03 Paul Koning <pkoning@equallogic.com>
3318
3319 * config/pdp11/pdp11-modes.def: Add RESET_FLOAT_FORMAT calls.
3320 * config/pdp11/pdp11-protos.h (legitimate_const_double_p): Add.
3321 * config/pdp11/pdp11.c (encode_pdp11_f, decode_pdp11_f,
3322 encode_pdp11_d, decode_pdp11_d): New functions to handle PDP11
3323 floating point format.
3324 (pdp11_f_format, pdp11_d_format): New real_format descriptors for
3325 the above functions.
3326 (output_move_quad): Output float values in correct target format.
3327 (legitimate_const_double_p): New function.
3328 * config/pdp11/pdp11.h: Fix typos.
3329 (FLOAT_WORDS_BIG_ENDIAN): Add definition.
3330 (TARGET_FLOAT_FORMAT): Ditto.
3331 (pdp11_f_format, pdp11_d_format): Add external declarations.
3332 (MAX_REGS_PER_ADDRESS): Corrected.
3333 (LEGITIMATE_CONSTANT_P): Use legitimate_const_double_p().
3334 (PRINT_OPERAND): Output float literals in target format.
3335
3336 2004-02-03 Mark Mitchell <mark@codesourcery.com>
3337
3338 PR c++/13975
3339 * tree.h (enum tree_index): Add TI_PUBLIC, TI_PROTECTED, and
3340 TI_PRIVATE.
3341 (access_public_node): Redefine.
3342 (access_protected_node): Likewise.
3343 (access_private_node): Likewise.
3344 * tree.c (build_common_tree_nodes): Create access_public_node,
3345 access_protected_node, and access_private_node.
3346
3347 2004-02-03 Steve Ellcey <sje@cup.hp.com>
3348
3349 * config/ia64/ia64.h (MASK_INLINE_INT_DIV_LAT): Change value.
3350 (MASK_INLINE_INT_DIV_THR): Ditto.
3351 (MASK_INLINE_SQRT_LAT): Ditto.
3352 (MASK_INLINE_SQRT_THR): Ditto.
3353 (MASK_DWARF2_ASM): Ditto.
3354 (MASK_EARLY_STOP_BITS): Ditto.
3355
3356 2004-02-02 Paul Brook <paul@codesourcery.com>
3357
3358 Merge from csl-arm-branch.
3359
3360 2004-01-30 Paul Brook <paul@codesourcery.com>
3361
3362 * aof.h (REGISTER_NAMES): Add vfp reg names
3363 (ADDITIONAL_REGISTER_NAMES): Ditto.
3364 * aout.h (REGISTER_NAMES): Ditto.
3365 (ADDITIONAL_REGISTER_NAMES): Ditto.
3366 * arm-protos.h: Update/Add Prototypes.
3367 * arm.c (init_fp_table): Rename from init_fpa_table. Update users.
3368 Only allow 0.0 for VFP.
3369 (fp_consts_inited): Rename from fpa_consts_inited. Update users.
3370 (values_fp): Rename from values_fpa. Update Users.
3371 (arm_const_double_rtx): Rename from const_double_rtx_ok_for_fpa.
3372 Update users. Only check valid constants for this hardware.
3373 (arm_float_rhs_operand): Rename from fpa_rhs_operand. Update Users.
3374 Only allow consts for FPA.
3375 (arm_float_add_operand): Rename from fpa_add_operand. Update users.
3376 Only allow consts for FPA.
3377 (use_return_insn): Check for saved VFP regs.
3378 (arm_legitimate_address_p): Handle VFP DFmode addressing.
3379 (arm_legitimize_address): Ditto.
3380 (arm_general_register_operand): New function.
3381 (vfp_mem_operand): New function.
3382 (vfp_compare_operand): New function.
3383 (vfp_secondary_reload_class): New function.
3384 (arm_float_compare_operand): New function.
3385 (vfp_print_multi): New function.
3386 (vfp_output_fstmx): New function.
3387 (vfp_emit_fstm): New function.
3388 (arm_output_epilogue): Output VPF reg restore code.
3389 (arm_expand_prologue): Output VFP reg save code.
3390 (arm_print_operand): Add 'P'.
3391 (arm_hard_regno_mode_ok): Return modes for VFP regs.
3392 (arm_regno_class): Return classes for VFP regs.
3393 (arm_compute_initial_elimination_offset): Include space for VFP regs.
3394 (arm_get_frame_size): Ditto.
3395 * arm.h (FIXED_REGISTERS): Add VFP regs.
3396 (CALL_USED_REGISTERS): Ditto.
3397 (CONDITIONAL_REGISTER_USAGE): Enable VFP regs.
3398 (FIRST_VFP_REGNUM): Define.
3399 (LAST_VFP_REGNUM): Define.
3400 (IS_VFP_REGNUM): Define.
3401 (FIRST_PSEUDO_REGISTER): Include VFP regs.
3402 (HARD_REGNO_NREGS): Handle VFP regs.
3403 (REG_ALLOC_ORDER): Add VFP regs.
3404 (enum reg_class): Add VFP_REGS.
3405 (REG_CLASS_NAMES): Ditto.
3406 (REG_CLASS_CONTENTS): Ditto.
3407 (CANNOT_CHANGE_MODE_CLASS) Handle VFP Regs.
3408 (REG_CLASS_FROM_LETTER): Add 'w'.
3409 (EXTRA_CONSTRAINT_ARM): Add 'U'.
3410 (EXTRA_MEMORY_CONSTRAINT): Define.
3411 (SECONDARY_OUTPUT_RELOAD_CLASS): Handle VFP regs.
3412 (SECONDARY_INPUT_RELOAD_CLASS): Ditto.
3413 (REGISTER_MOVE_COST): Ditto.
3414 (PREDICATE_CODES): Add arm_general_register_operand,
3415 arm_float_compare_operand and vfp_compare_operand.
3416 * arm.md (various): Rename as above.
3417 (divsf3): Enable when TARGET_VFP.
3418 (divdf3): Ditto.
3419 (movdfcc): Ditto.
3420 (sqrtsf2): Ditto.
3421 (sqrtdf2): Ditto.
3422 (arm_movdi): Disable when TARGET_VFP.
3423 (arm_movsi_insn): Ditto.
3424 (movsi): Only split with general regs.
3425 (cmpsf): Use arm_float_compare_operand.
3426 (push_fp_multi): Restrict to TARGET_FPA.
3427 (vfp.md): Include.
3428 * vfp.md: New file.
3429 * fpa.md (various): Rename as above.
3430 * doc/md.texi: Document ARM w and U constraints.
3431
3432 2004-01-15 Paul Brook <paul@codesourcery.com>
3433
3434 * config.gcc: Add with_fpu. Allow with-float=softfp.
3435 * config/arm/arm.c (arm_override_options): Rename *-s to *s.
3436 Break out of loop when we find a float-abi. Fix typo.
3437 * config/arm/arm.h (OPTION_DEFAULT_SPECS): Add "fpu".
3438 Set -mfloat-abi=.
3439 * doc/install.texi: Document --with-fpu.
3440
3441 2003-01-14 Paul Brook <paul@codesourcery.com>
3442
3443 * config.gcc (with_arch): Add armv6.
3444 * config/arm/arm.h: Rename TARGET_CPU_*_s to TARGET_CPU_*s.
3445 * config/arm/arm.c (arm_overrride_options): Ditto.
3446
3447 2004-01-08 Richard Earnshaw <rearnsha@arm.com>
3448
3449 * arm.c (FL_ARCH3M): Renamed from FL_FAST_MULT.
3450 (FL_ARCH6): Renamed from FL_ARCH6J.
3451 (arm_arch3m): Renamed from arm_fast_multiply.
3452 (arm_arch6): Renamed from arm_arch6j.
3453 * arm.h: Update all uses of above.
3454 * arm-cores.def: Likewise.
3455 * arm.md: Likewise.
3456
3457 * arm.h (CPP_CPU_ARCH_SPEC): Emit __ARM_ARCH_6J__ define for armV6j,
3458 not arm6j. Add entry for arch armv6.
3459
3460 2004-01-07 Richard Earnshaw <rearnsha@arm.com>
3461
3462 * arm.c (arm_emit_extendsi): Delete.
3463 * arm-protos.h (arm_emit_extendsi): Delete.
3464 * arm.md (zero_extendhisi2): Also handle zero-extension of
3465 non-subregs.
3466 (zero_extendqisi2, extendhisi2, extendqisi2): Likewise.
3467 (thumb_zero_extendhisi2): Only match if not v6.
3468 (arm_zero_extendhisi2, thumb_zero_extendqisi2, arm_zero_extendqisi2)
3469 (thumb_extendhisi2, arm_extendhisi2, arm_extendqisi)
3470 (thumb_extendqisi2): Likewise.
3471 (thumb_zero_extendhisi2_v6, arm_zero_extendhisi2_v6): New patterns.
3472 (thumb_zero_extendqisi2_v6, arm_zero_extendqisi2_v6): New patterns.
3473 (thumb_extendhisi2_insn_v6, arm_extendhisi2_v6): New patterns.
3474 (thumb_extendqisi2_v6, arm_extendqisi_v6): New patterns.
3475 (arm_zero_extendhisi2_reg, arm_zero_extendqisi2_reg): Delete.
3476 (arm_extendhisi2_reg, arm_extendqisi2_reg): Delete.
3477 (arm_zero_extendhisi2addsi): Remove subreg. Add attributes.
3478 (arm_zero_extendqisi2addsi, arm_extendhisi2addsi): Likewise.
3479 (arm_extendqisi2addsi): Likewise.
3480
3481 2003-12-31 Mark Mitchell <mark@codesourcery.com>
3482
3483 Revert this change:
3484 * config/arm/arm.h (THUMB_LEGTITIMIZE_RELOAD_ADDRESS): Reload REG
3485 + REG addressing modes.
3486
3487 * config/arm/arm.h (THUMB_LEGTITIMIZE_RELOAD_ADDRESS): Reload REG
3488 + REG addressing modes.
3489
3490 2003-12-30 Mark Mitchell <mark@codesourcery.com>
3491
3492 * config/arm/arm.h (THUMB_LEGITIMATE_CONSTANT_P): Accept
3493 CONSTANT_P_RTX.
3494
3495 2003-30-12 Paul Brook <paul@codesourcery.com>
3496
3497 * longlong.h: protect arm inlines with !defined (__thumb__)
3498
3499 2003-30-12 Paul Brook <paul@codesourcery.com>
3500
3501 * config/arm/arm.h (TARGET_CPU_CPP_BUILTINS): Always define __arm__.
3502
3503 2003-12-30 Nathan Sidwell <nathan@codesourcery.com>
3504
3505 * builtins.c (expand_builtin_apply_args_1): Fix typo in previous
3506 change.
3507
3508 2003-12-29 Nathan Sidwell <nathan@codesourcery.com>
3509
3510 * builtins.c (expand_builtin_apply_args_1): Add pretend args size
3511 to the virtual incoming args pointer for downward stacks.
3512
3513 2003-12-29 Paul Brook <paul@codesourcery.com>
3514
3515 * config/arm/arm-cores.def: Add cost function.
3516 * config/arm/arm.c (arm_*_rtx_costs): New functions.
3517 (arm_rtx_costs): Remove
3518 (struct processors): Add rtx_costs field.
3519 (all_cores, all_architectures): Ditto.
3520 (arm_override_options): Set targetm.rtx_costs.
3521 (thumb_rtx_costs): New function.
3522 (arm_rtx_costs_1): Remove cases handled elsewhere.
3523 * config/arm/arm.h (processor_type): Add COSTS parameter.
3524
3525 2003-12-29 Nathan Sidwell <nathan@codesourcery.com>
3526
3527 * config/arm/arm.md (generic_sched): arm926 has its own scheduler.
3528 (arm926ejs.md): Include it.
3529 * config/arm/arm926ejs.md: New pipeline description.
3530
3531 2003-12-24 Paul Brook <paul@codesourcery.com>
3532
3533 * config/arm/arm.c (arm_arch6j): New variable.
3534 (arm_override_options): Set it.
3535 (arm_emit_extendsi): New function.
3536 * config/arm/arm-protos.h (arm_emit_extendsi): Add prototype.
3537 * config/arm/arm.h (arm_arch6j): Declare.
3538 * config/arm/arm.md: Add sign/zero extend insns.
3539
3540 2003-12-23 Paul Brook <paul@codesourcery.com>
3541
3542 * config/arm/arm.c (all_architectures): Add armv6.
3543 * doc/invoke.texi: Document it.
3544
3545 2003-12-19 Paul Brook <paul@codesourcery.com>
3546
3547 * config/arm/arm.md: Add load1 and load_byte "type" attrs. Modify
3548 insn patterns to match.
3549 * config/arm/arm-generic.md: Ditto.
3550 * config/arm/cirrus.md: Ditto.
3551 * config/arm/fpa.md: Ditto.
3552 * config/amm/iwmmxt.md: Ditto.
3553 * config/arm/arm1026ejs.md: Ditto.
3554 * config/arm/arm1135jfs.md: Ditto. Add insn_reservation and bypasses
3555 for 11_loadb.
3556
3557 2003-12-18 Nathan Sidwell <nathan@codesourcery.com>
3558
3559 * config/arm/arm-protos.h (arm_no_early_alu_shift_value_dep): Declare.
3560 * config/arm/arm.c (arm_adjust_cost): Check shift cost for
3561 TYPE_ALU_SHIFT and TYPE_ALU_SHIFT_REG.
3562 (arm_no_early_store_addr_dep, arm_no_early_alu_shift_dep,
3563 arm_no_early_mul_dep): Correctly deal with conditional execution,
3564 parallels and single shift operations.
3565 (arm_no_early_alu_shift_value_dep): Define.
3566 * arm.md (attr type): Replace 'normal' with 'alu',
3567 'alu_shift' and 'alu_shift_reg'.
3568 (attr core_cycles): Adjust.
3569 (*addsi3_carryin_shift, andsi_not_shiftsi_si, *arm_shiftsi3,
3570 *shiftsi3_compare0, *notsi_shiftsi, *notsi_shiftsi_compare0,
3571 *not_shiftsi_compare0_scratch, *cmpsi_shiftsi, *cmpsi_shiftsi_swp,
3572 *cmpsi_neg_shiftsi, *arith_shiftsi, *arith_shiftsi_compare0,
3573 *arith_shiftsi_compare0_scratch, *sub_shiftsi,
3574 *sub_shiftsi_compare0, *sub_shiftsi_compare0_scratch,
3575 *if_shift_move, *if_move_shift, *if_shift_shift): Set type
3576 attribute appropriately.
3577 * config/arm/arm1026ejs.md (alu_op): Adjust.
3578 (alu_shift_op, alu_shift_reg_op): New.
3579 * config/arm/arm1136.md: Add better bypasses for early
3580 registers. Remove load[234] and store[234] bypasses.
3581 (11_alu_op): Adjust.
3582 (11_alu_shift_op, 11_alu_shift_reg_op): New.
3583
3584 2003-12-15 Nathan Sidwell <nathan@codesourcery.com>
3585
3586 * config/arm/arm-protos.h (arm_no_early_store_addr_dep,
3587 arm_no_early_alu_shift_dep, arm_no_early_mul_dep): Declare.
3588 * config/arm/arm.c (arm_no_early_store_addr_dep,
3589 arm_no_early_alu_shift_dep, arm_no_early_mul_dep): Define.
3590 * config/arm/arm1026ejs.md: Add load-store bypass.
3591 * config/arm/arm1136jfs.md (11_alu_op): Take 2 cycles.
3592 Add bypasses between instructions.
3593
3594 2003-12-10 Paul Brook <paul@codesourcery.com>
3595
3596 * config/arm/arm.c (arm_fpu_model): New variable.
3597 (arm_fload_abi): New variable.
3598 (target_fpe_name): Rename from target_fp_name.
3599 (target_fpu_name): New variable.
3600 (arm_is_cirrus): Remove.
3601 (fpu_desc): New struct.
3602 (all_fpus): Define.
3603 (pf_model_for_fpu): Define.
3604 (all_loat_abis): Define.
3605 (arm_override_options): Set fp arch flags based on -mfpu=
3606 and -float-abi=.
3607 (FIRST_FPA_REGNUM): Rename from FIRST_ARM_FP_REGNUM.
3608 (LAST_FPA_REGNUM): Rename from LAST_ARM_FP_REGNUM.
3609 (*): Use new TARGET_* flags.
3610 * config/arm/arm.h (TARGET_ANY_HARD_FLOAT): Remove.
3611 (TARGET_HARD_FLOAT): No longer implies TARGET_FPA.
3612 (TARGET_SOFT_FLOAT): Ditto.
3613 (TARGET_SOFT_FLOAT_ABI): New.
3614 (TARGET_MAVERICK): Rename from TARGET_CIRRUS. No longer implies
3615 TARGET_HARD_FLOAT.
3616 (TARGET_VFP): No longer implies TARGET_HARD_FLOAT.
3617 (TARGET_OPTIONS): Add -mfpu=.
3618 (FIRST_FPA_REGNUM): Rename from FIRST_ARM_FP_REGNUM.
3619 (LAST_FPA_REGNUM): Rename from LAST_ARM_FP_REGNUM.
3620 (arm_pf_model): Define.
3621 (arm_float_abi_type): Define.
3622 (fputype): Add FPUTYPE_VFP. Change SOFT_FPA->NONE
3623 * config/arm/arm.md: Use new TARGET_* flags.
3624 * config/arm/cirrus.md: Ditto.
3625 * config/arm/fpa.md: Ditto.
3626 * config/arm/elf.h (ASM_SPEC): Pass -mfloat-abi= and -mfpu=.
3627 * config/arm/semi.h (ASM_SPEC): Ditto.
3628 * config/arm/netbsd-elf.h (SUBTARGET_ASM_FLOAT_SPEC): Specify vfp.
3629 (FPUTYPE_DEFAULT): Set to VFP.
3630 * doc/invoke.texi: Document -mfpu= and -mfloat-abi=.
3631
3632 2003-11-22 Phil Edwards <phil@codesourcery.com>
3633
3634 PR target/12476
3635 * config/arm/arm.c (arm_output_mi_thunk): In Thumb mode, use
3636 'bx' instead of 'b' to avoid branch range restrictions. Output
3637 the thunk immediately before the thunked-to function.
3638 * config/arm/arm.h (ARM_DECLARE_FUNCTION_NAME): Do not emit
3639 .thumb_func if a thunk is being generated. Emit .code 16 along
3640 with .thumb_func if a thunk is not being generated.
3641
3642 2003-11-15 Nicolas Pitre <nico@cam.org>
3643
3644 * config/arm/arm.md (ashldi3, arm_ashldi3_1bit, ashrdi3,
3645 arm_ashrdi3_1bit, lshrdi3, arm_lshrdi3_1bit): New patterns.
3646 * config/arm/iwmmxt.md (ashrdi3_iwmmxt): Renamed from ashrdi3.
3647 (lshrdi3_iwmmxt): Renamed from lshrdi3.
3648 * config/arm/arm.c (IWMMXT_BUILTIN2): Renamed argument accordingly.
3649
3650 2003-11-12 Steve Woodford <scw@wasabisystems.com>
3651 Ian Lance Taylor <ian@wasabisystems.com>
3652
3653 * config/arm/lib1funcs.asm (ARM_DIV_BODY, ARM_MOD_BODY): Add new
3654 code for __ARM_ARCH__ >= 5 && ! defined (__OPTIMIZE_SIZE__).
3655
3656 2003-11-05 Phil Edwards <phil@codesourcery.com>
3657
3658 * config/arm/arm.md (insn): Add new V6 instruction names.
3659 (generic_sched): New attr.
3660 * config/arm/arm-generic.md: Use generic_sched here.
3661 * config/arm/arm1026ejs.md: Do not model fetch/issue/decode
3662 stages of pipeline. Adjust latency counts accordingly.
3663 * config/arm/arm1136jfs.md: New file.
3664
3665 2003-10-28 Mark Mitchell <mark@codesourcery.com>
3666
3667 * config/arm/arm.h (processor_type): New enumeration type.
3668 (CPP_ARCH_DEFAULT_SPEC): Set appropriately for ARM 926EJ-S,
3669 ARM1026EJ-S, ARM1136J-S, and ARM1136JF-S processor cores.
3670 (CPP_CPU_ARCH_SPEC): Likewise.
3671 * config/arm/arm.c (arm_tune): New variable.
3672 (all_cores): Use cores.def.
3673 (all_architectures): Add representative processor.
3674 (arm_override_options): Restructure way in which tuning
3675 information is deduced.
3676 * arm.md: Update "insn" and "type" attributes throughout.
3677 (insn): New attribute.
3678 (type): Compute "mult" from "insn" attribute. Add load2,
3679 load3, load4 alternatives.
3680 (arm automaton): Move to arm-generic.md.
3681 * config/arm/arm-cores.def: New file.
3682 * config/arm/arm-generic.md: Likewise.
3683 * config/arm/arm1026ejs.md: Likewise.
3684
3685 2004-02-03 Eric Botcazou <ebotcazou@libertysurf.fr>
3686
3687 * doc/invoke.texi (SPARC options): Remove -mflat and
3688 all -mxxx (xxx:chip) options.
3689 * config/sparc/aout.h (DBX_REGISTER_NUMBER): Delete.
3690 * config/sparc/litecoff.h (DBX_REGISTER_NUMBER): Likewise.
3691 * config/sparc/netbsd-elf.h (DBX_REGISTER_NUMBER): Likewise.
3692 * config/sparc/sol2.h (DBX_REGISTER_NUMBER): Likewise.
3693 * config/sparc/sparc-protos.h: Delete sparc_flat_* prototypes.
3694 * config/sparc/sparc.c: Likewise.
3695 (sparc_output_function_prologue): Remove TARGET_FLAT handling.
3696 (sparc_nonflat_function_prologue): Rename into sparc_function_prologue.
3697 (sparc_output_function_epilogue): Remove TARGET_FLAT handling.
3698 (sparc_nonflat_function_epilogue): Rename into sparc_function_epilogue.
3699 (struct sparc_frame_info, current_frame_info, zero_frame_info): Delete.
3700 (sparc_flat_must_save_register_p): Likewise.
3701 (sparc_flat_compute_frame_size): Likewise.
3702 (sparc_flat_save_restore): Likewise.
3703 (sparc_flat_function_prologue): Likewise.
3704 (sparc_flat_function_epilogue): Likewise.
3705 (sparc_flat_epilogue_delay_slots): Likewise.
3706 (sparc_flat_eligible_for_epilogue_delay): Likewise.
3707 (sparc_function_ok_for_sibcall): Remove TARGET_FLAT handling.
3708 * config/sparc/sparc.h (MASK_FLAT, TARGET_FLAT): Delete.
3709 (TARGET_SWITCHES): Remove -mflat and all -mxxx (xxx:chip) options.
3710 (SPARC_INCOMING_INT_ARG_FIRST): Remove TARGET_FLAT handling.
3711 (CONDITIONAL_REGISTER_USAGE): Likewise.
3712 (FRAME_POINTER_REQUIRED): Likewise.
3713 (INITIAL_ELIMINATION_OFFSET): Likewise.
3714 (BASE_RETURN_VALUE_REG): Likewise.
3715 (BASE_OUTGOING_VALUE_REG): Likewise.
3716 (BASE_PASSING_ARG_REG): Likewise.
3717 (BASE_INCOMING_ARG_REG): Likewise.
3718 (INCOMING_REGNO): Likewise.
3719 (OUTGOING_REGNO): Likewise.
3720 (LOCAL_REGNO): Likewise.
3721 (DELAY_SLOTS_FOR_EPILOGUE): Likewise.
3722 (ELIGIBLE_FOR_EPILOGUE_DELAY): Likewise.
3723 (EPILOGUE_USES): Likewise.
3724 * config/sparc/sparc.md ("isa" attribute): Change "v6" into "v7".
3725 ("flat" attribute): Delete.
3726 (do_builtin_setjmp_setup): Remove TARGET_FLAT and "flat" attribute
3727 handling.
3728 (call followed by jump define_peephole's): Delete.
3729 (exception_receiver): Likewise.
3730 (builtin_setjmp_receiver): Likewise.
3731 * config/sparc/t-sparclite (MULTILIB_OPTIONS): Remove -mflat.
3732
3733 2004-02-03 Paolo Bonzini <bonzini@gnu.org>
3734
3735 PR c/11658
3736 PR c/13994
3737 * Makefile.in (c-parse.o, c-convert.o, c-typeck.o): Depend
3738 on langhooks.h.
3739 * objc/Make-lang.in (objc-parse.o): Depend on langhooks.h.
3740 * c-parse.in, c-convert.c, c-typeck.c, objc/objc-act.c:
3741 Include langhooks.h. Replace c_common_truthvalue_conversion
3742 with the truthvalue_conversion language hook throughout.
3743 (expr_no_commas): Call default_conversion before save_expr
3744 for the first term of the production 'x ? : y'.
3745 * c-common.c (c_common_truthvalue_conversion): Remove
3746 obsolete block. Invoke recursively the hook instead
3747 of this function.
3748 * c-convert.c (convert): handle ERROR_MARK_NODE.
3749 * c-typeck.c (build_binary_op): handle ERROR_MARK_NODE
3750 returned by the truthvalue_conversion language hook.
3751 * c-lang.c (LANG_HOOKS_TRUTHVALUE_CONVERSION): Use
3752 c_objc_common_truthvalue_conversion.
3753 * c-objc-common.c (c_objc_common_truthvalue_conversion):
3754 New function.
3755 * c-tree.h (c_objc_common_truthvalue_conversion): Declare it.
3756 * objc/objc-lang.c (LANG_HOOKS_TRUTHVALUE_CONVERSION): Use
3757 c_objc_common_truthvalue_conversion.
3758
3759 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
3760
3761 * config/c4x/c4x.h (FUNCTION_VALUE): Use gen_rtx_REG instead
3762 of gen_rtx.
3763 (LIBCALL_VALUE): Likewise.
3764 * config/ip2k/ip2k.c (mdr_try_propagate_clr_sequence): Use
3765 gen_rtx_CC0 instead of gen_rtx.
3766 * config/m68hc11/m68hc11.c (m68hc11_emit_libcall): Use
3767 gen_rtx_fmt_e and gen_rtx_fmt_ee instead of gen_rtx.
3768 (m68hc11_expand_compare): Use gen_rtx_fmt_ee instead of
3769 gen_rtx.
3770 (m68hc11_emit_logical): Likewise.
3771
3772 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
3773
3774 * config/alpha/alpha.c, config/arm/arm.c, config/c4x/c4x.c,
3775 config/fr30/fr30.md, config/frv/frv.c, config/frv/frv.md,
3776 config/h8300/h8300.c, config/ia64/ia64.c, config/ip2k/ip2k.md,
3777 config/m32r/m32r.md, config/m68hc11/m68hc11.c,
3778 config/mips/mips.md, config/mmix/mmix.c,
3779 config/mn10300/mn10300.c, config/mn10300/mn10300.md,
3780 config/ns32k/ns32k.c, config/pa/pa.md, config/pdp11/pdp11.c,
3781 config/rs6000/altivec.md, config/s390/s390.c,
3782 config/s390/s390.h, config/s390/s390.md, config/sh/sh.c,
3783 config/sh/sh.h, config/sh/sh.md, config/stormy16/stormy16.c:
3784 Use const0_rtx instead of GEN_INT (0). Do the same for other
3785 constants that are readily available.
3786
3787 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
3788
3789 * doloop.c, optabs.c, regmove.c, sched-deps.c,
3790 config/i386/i386.c, config/i386/i386.md: Use const0_rtx
3791 instead of GEN_INT (0). Do the same for other constants that
3792 are readily available.
3793
3794 2004-02-03 Kazu Hirata <kazu@cs.umass.edu>
3795
3796 * combine.c (simplify_set): Use gen_rtx_fmt_e instead of
3797 gen_rtx.
3798 * emit-rtl.c (init_emit_once): Use gen_rtx_PC and gen_rtx_CC0
3799 instead of gen_rtx.
3800 * reload1.c (init_elim_table): Use gen_rtx_fmt_e instead of
3801 gen_rtx.
3802 * config/ns32k/ns32k.md (udivmodhi4): Use gen_rtx_IOR and
3803 gen_rtx_ASHIFT instead of gen_rtx.
3804 (udivmodqi4): Likewise.
3805
3806 2004-02-02 Richard Henderson <rth@redhat.com>
3807
3808 PR target/13789
3809 * expr.c (store_expr): Use force_operand before emit_move_insn.
3810
3811 2004-02-02 Jeff Law <law@redhat.com>
3812 Roger Sayle <roger@eyesopen.com>
3813
3814 * tree.c (commutative_tree_code, associative_tree_code): New
3815 functions.
3816 (iterative_hash_expr): Use commutative_tree_code.
3817 * tree.h (commutative_tree_code, associative_tree_code): Declare.
3818 * fold-const.c (operand_equal_p): Use commutative_tree_code
3819 rather than inlining the commutativity check.
3820 (fold): Likewise.
3821
3822 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
3823
3824 * system.h (FUNCTION_ARG_KEEP_AS_REFERENCE): Poison.
3825 * config/frv/frv-protos.h: Remove the prototype for
3826 frv_function_arg_keep_as_reference.
3827 * config/frv/frv.c (frv_function_arg_keep_as_reference):
3828 Remove.
3829 * config/frv/frv.h (FUNCTION_ARG_KEEP_AS_REFERENCE): Likewise.
3830 * config/stormy16/stormy16.h: Remove the commented-out
3831 definition of FUNCTION_ARG_KEEP_AS_REFERENCE.
3832
3833 2004-02-03 Alan Modra <amodra@bigpond.net.au>
3834
3835 PR target/13914
3836 * config/rs6000/linux64.h (MD_FALLBACK_FRAME_STATE_FOR): Use ap
3837 for retaddr_column.
3838
3839 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
3840
3841 * genemit.c (gen_exp): Generate gen_rtx_fmt_e* instead of
3842 gen_rtx.
3843
3844 2004-02-02 Eric Christopher <echristo@redhat.com>
3845 Zack Weinberg <zack@codesourcery.com>
3846
3847 * c-opts.c (c_common_handle_option): Add -finput-charset.
3848 * c.opt: Ditto.
3849 * cppcharset.c (one_iso88591_to_utf8): Remove.
3850 (convert_iso88591_utf8): Ditto.
3851 (conversion_tab): Remove 8859-1 converter.
3852 (_cpp_input_to_utf8): Remove.
3853 (_cpp_init_iconv_buffer): Ditto.
3854 (_cpp_close_iconv_buffer): Ditto.
3855 (_cpp_convert_input): New function.
3856 (_cpp_default_encoding): Ditto.
3857 * cpphash.h: Add/remove prototypes for above.
3858 * cppfiles.c (read_file_guts): Use _cpp_convert_input.
3859 * cppinit.c (cpp_create_reader): Use _cpp_default_encoding
3860 for narrow execution and input character sets.
3861 * cpplib.c (cpp_push_buffer): Delete uses of removed functions.
3862 * doc/cppopts.texi: Document -finput-charset.
3863
3864 2004-02-02 David Edelsohn <edelsohn@gnu.org>
3865
3866 * rtlanal.c (refers_to_regno_p): Test regno, not inner_regno,
3867 against FIRST_PSEUDO_REGISTER.
3868
3869 2004-02-02 Eric Botcazou <ebotcazou@libertysurf.fr>
3870
3871 * doc/invoke.texi (SPARC options): Further improve.
3872
3873 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
3874
3875 * config/arm/arm.md, config/c4x/c4x.md, config/cris/cris.md,
3876 config/h8300/h8300.c, config/ip2k/ip2k.md,
3877 config/iq2000/iq2000.c, config/mips/mips.c,
3878 config/rs6000/rs6000.c, config/rs6000/rs6000.md,
3879 config/sh/sh.c, config/sh/sh.md, config/stormy16/stormy16.c,
3880 config/v850/v850.md: Fix indentation.
3881
3882 2004-02-02 Eric Botcazou <ebotcazou@libertysurf.fr>
3883
3884 * config/sparc/sparc.c (function_arg_slotno): Align TImode
3885 arguments on a 16-byte boundary in the parameter array if ARCH64.
3886 Split handling of TFmode.
3887
3888 2004-02-02 Paolo Bonzini <bonzini@gnu.org>
3889
3890 * rtlanal.c (reg_overlap_mentioned_p) [!ENABLE_CHECKING]:
3891 Don't test CONSTANT_P (x).
3892 (reg_overlap_mentioned_p): Merge check for STRICT_LOWPART,
3893 ZERO_EXTRACT, SIGN_EXTRACT with the switch statement.
3894 Fix misindentation.
3895
3896 2004-02-02 Eric Botcazou <ebotcazou@libertysurf.fr>
3897
3898 * doc/invoke.texi (SPARC options): Document that -mflat is deprecated.
3899
3900 2004-02-02 Kazu Hirata <kazu@cs.umass.edu>
3901
3902 * config/arc/arc.md, config/arm/arm.c, config/arm/arm.md,
3903 config/c4x/c4x.c, config/c4x/c4x.md, config/cris/cris.md,
3904 config/frv/frv.c, config/h8300/h8300.c, config/ip2k/ip2k.md,
3905 config/iq2000/iq2000.c, config/m32r/m32r.c,
3906 config/mcore/mcore.c, config/mips/mips.c, config/mmix/mmix.md,
3907 config/mn10300/mn10300.c, config/rs6000/rs6000.c,
3908 config/rs6000/rs6000.md, config/sh/sh.c, config/sh/sh.md,
3909 config/stormy16/stormy16.c, config/v850/v850.md,
3910 config/xtensa/xtensa.c: Replace gen_rtx with gen_rtx_fmt_e*.
3911
3912 2004-02-01 Kazu Hirata <kazu@cs.umass.edu>
3913
3914 * config/mcore/mcore.c (block_move_sequence): Replace
3915 gen_rtx_CONST_INT with GEN_INT.
3916
3917 2004-02-02 Jan Hubicka <jh@suse.cz>
3918
3919 * alias.c (record_set): Use hard_regno_nregs.
3920 * bt-load.c (find_btr_reference, note_btr_set): Likewise.
3921 * builtins.c (apply_args_size): Likewise.
3922 * caller-save.c (setup_save_areas, save_call_clobbered_regs,
3923 mark_set_regs, add_stored_regs, mark_referenced_regs,
3924 insert_restore, insert_save, insert_one_insn): Likewise.
3925 * cfgcleanup.c: Include regs.h
3926 (mark_effect, mentions_nonequal_regs): Likewise.
3927 * cfgrtl.c (mark_killed_regs): Likewise
3928 * combine.c (update_table_tick, record_value_for_reg,
3929 record_dead_and_set_regs, get_last_value_validate, use_crosses_set_p,
3930 reg_dead_at_p_1, reg_dead_at_p, mark_used_regs_combine, move_deaths,
3931 reg_bitfield_target_p, distribute_notes): Likewise.
3932 * cse.c (mention_regs, insert, invalidate, invalidate_for_call,
3933 exp_equiv_p, cse_insn): Likewise.
3934 * cselib.c (cselib_lookup): Likewise.
3935 (cselib_invalidate_regno, cselib_record_set): Likewise.
3936 * df.c (df_ref_record): Likewise.
3937 * dwarf2out.c (reg_loc_descriptor, multiple_reg_loc_descriptor):
3938 Likewise.
3939 * flow.c (mark_reg, insn_dead_p, mark_set_1, mark_used_reg,
3940 count_or_remove_death_notes_bb): Likewise.
3941 * function.c (aggregate_value_p, keep_stack_depressed): Likewise.
3942 * gloval.c (global_alloc, find_reg, mark_reg_store, mark_reg_conflicts,
3943 mark_reg_death, set_preference, reg_becomes_live, reg_dies): Likewise.
3944 * integrate.c (mark_stores): Likewise.
3945 * jump.c (delete_prior_computation): Likewise.
3946 * lcm.c (reg_dies, reg_becomes_live): Likewise.
3947 * local-alloc.c (combine_regs, find_free_reg, post_mark_life): Likewise.
3948 * loop.c (LOOP_REGNO_NREGS): Likewise.
3949 * postreload.c (reload_combine, reload_combine_note_store,
3950 reload_combine_note_use, reload_cse_move2add, move2add_note_store): Likewise.
3951 * ra-colorize.c (combine, color_usable_p, get_free_reg,
3952 calculate_dont_begin, calculate_dont_begin, colorize_one_web,
3953 try_recolor_web, insert_coalesced_conflicts, check_colors,
3954 break_precolored_alias): Likewise.
3955 * ra-debug.c: Include regs.h
3956 (ra_print_rtx_object): Likewise.
3957 * ra-rewrite (choose_spill_colors): Likewise.
3958 (spill_same_color_p, update_spill_colors, spill_is_free): Likewise.
3959 * ra.c (init_ra): Likewise.
3960 * recog.c (reg_fits_class_p, peep2_reg_dead_p,
3961 peep2_find_free_register): Likewise.
3962 * reg-stack.c (subst_stack_regs_pat, convert_regs_exit): Likewise.
3963 * regclass.c (hard_regno_nregs): New array.
3964 (init_reg_modes_once): Initialize it.
3965 (choose_hard_reg_mode): Use it.
3966 (record_reg_classes): Likewise.
3967 * regmove.c (mark_flags_life_zones): Likewise.
3968 * regrename.c (note_sets, clear_dead_regs, regrename_optimize,
3969 scan_rtx_reg, dump_def_use_chain, kill_value, set_value_regno,
3970 copy_value, maybe_mode_change, find_oldest_value_reg,
3971 copyprop_hardreg_forward_1):
3972 * regs.h (hard_regno_nregs): Declare.
3973 * realod.c (reload_inner_reg_of_subreg): Use it.
3974 (push_reload, combine_reloads, find_dummy_reload,
3975 hard_reg_set_here_p, operands_match_p, decompose, find_reloads,
3976 refers_to_regno_for_reload_p, find_equiv_reg, regno_clobbered_p,
3977 reload_adjust_reg_for_mode): Likewise.
3978 * reload1.c (compute_use_by_pseudos, count_pseudo,
3979 count_spilled_pseudo, find_reg, find_reload_regs, mark_home_live,
3980 spill_hard_reg, forget_old_reloads_1, mark_reload_reg_in_use,
3981 clear_reload_reg_in_use, reload_reg_free_for_value_p, free_for_value_p
3982 allocate_reload_reg, choose_reload_regs, emit_reload_insns,
3983 delete_output_reload): Likewise.
3984 * resource.c (update_live_status, mark_referenced_resources,
3985 mark_set_resources, mark_target_live_regs): Likewise.
3986 * rtlanal.c: Include regs.h
3987 (refers_to_regno_p, reg_overlap_mentioned_p, dead_or_set_p,
3988 dead_or_set_regno_p, find_regno_note, find_reg_fusage,
3989 subreg_regno_offset, subreg_offset_representable_p,
3990 hoist_test_store): Likewise.
3991 * sched-deps.c (sched_analyze_1, sched_analyze_2): Likewise.
3992 * sched-rgn.c (check_live_1, update_live_1): Likewise.
3993 * stmt.c: Include regs.h
3994 (decl_conflicts_with_clobbers_p): Likewise.
3995 * varasm.c (make_decl_rtl): Likewise.
3996 * Makefile.in (cfgcleanup.o, rtlanal.o, ra-debug.o): Add regs.h dependnecy.
3997
3998 2004-02-01 Kazu Hirata <kazu@cs.umass.edu>
3999
4000 * config/arm/arm.c, config/arm/arm.h, config/arm/arm.md,
4001 config/arm/linux-gas.h, config/arm/netbsd-elf.h,
4002 config/arm/netbsd.h, config/arm/pe.c, config/avr/avr.c,
4003 config/avr/avr.h, config/avr/avr.md, config/c4x/c4x.h,
4004 config/cris/cris.h, config/fr30/fr30.h, config/frv/frv.c,
4005 config/frv/frv.h, config/ip2k/ip2k.c, config/iq2000/iq2000.c,
4006 config/iq2000/iq2000.h, config/m32r/m32r.c,
4007 config/m68hc11/m68hc11.c, config/m68hc11/m68hc11.h,
4008 config/m68hc11/m68hc11.md, config/m68k/m68k.md,
4009 config/mcore/mcore.c, config/mcore/mcore.h,
4010 config/mcore/mcore.md, config/mips/mips.c,
4011 config/ns32k/ns32k.h, config/ns32k/ns32k.md,
4012 config/rs6000/rs6000.c, config/s390/s390.c,
4013 config/s390/s390.md, config/sparc/sparc.c, config/v850/v850.c,
4014 config/xtensa/xtensa.h, config/xtensa/xtensa.md: Replace
4015 "gen_rtx (FOO, " with "gen_rtx_FOO (".
4016
4017 2004-02-01 Kazu Hirata <kazu@cs.umass.edu>
4018
4019 * config/h8300/h8300.md (two peephole2's): New.
4020
4021 2004-02-01 Eric Botcazou <ebotcazou@libertysurf.fr>
4022
4023 * config/sparc/sol2-bi.h: Handle TARGET_CPU_ultrasparc3.
4024 (CPP_CPU_SPEC): Handle -mcpu=ultrasparc3.
4025 (ASM_CPU_SPEC): Likewise
4026 * config/sparc/sol2.h: Handle TARGET_CPU_ultrasparc3.
4027 (ASM_CPU_SPEC): Remove -mcpu=v8plus. Handle -mcpu=ultrasparc3.
4028
4029 2004-02-01 Roger Sayle <roger@eyesopen.com>
4030
4031 * builtins.c (expand_builtin_pow): If flag_unsafe_math_optimizations
4032 isn't set, don't call expand_builtin_mathfn_2 to use the pow optab.
4033 (expand_builtin): Always call expand_builtin_pow.
4034
4035 2004-02-01 Roger Sayle <roger@eyesopen.com>
4036
4037 * builtins.def (BUILT_IN_SIGNBIT, BUILT_IN_SIGNBITF,
4038 BUILT_IN_SIGNBITL): New GCC builtins.
4039 * builtins.c (expand_builtin_signbit): New function to RTL expand
4040 calls to signbit, signbitf and signbitl as inline intrinsics.
4041 (expand_builtin): Call expand_builtin_signbit for BUILT_IN_SIGNBIT*.
4042 (fold_builtin_signbit): New function to perform constant folding
4043 of signbit, signbitf and signbitl.
4044 (fold_builtin): Call fold_builtin_signbit for BUILT_IN_SIGNBIT*.
4045
4046 * doc/extend.texi: Document new signbit{,f,l} builtins.
4047
4048 2004-02-01 Richard Sandiford <rsandifo@redhat.com>
4049
4050 * config/mips/mips.md (adddi3_internal_2): Remove superfluous %s.
4051
4052 2004-02-01 Chris Demetriou <cgd@broadcom.com>
4053
4054 * config/mips/mips.h (PREDICATE_CODES): Remove entries for
4055 "mips_const_double_ok" and "simple_memory_operand", which were
4056 removed from the MIPS port with the mips-3_4-rewrite branch merge.
4057 * config/mips/mips.c (mips16_lay_out_constants): Update comment
4058 for removal of simple_memory_operand.
4059
4060 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4061
4062 * config/c4x/c4x.md: Use GEN_INT instead of
4063 gen_rtx (CONST_INT, ...).
4064
4065 2004-01-31 Richard Henderson <rth@redhat.com>
4066
4067 * varasm.c (output_constant_pool): Don't zap the pool.
4068
4069 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4070
4071 * genrecog.c (decision_type): Add DT_const_int.
4072 (write_cond) [DT_const_int]: Print a comparison against small
4073 constant.
4074 (write_node): Simplify comparisons against small constants
4075 before printing tests.
4076
4077 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4078
4079 * config/m32r/m32r.c (m32r_load_pic_register): Use GEN_INT
4080 instead of gen_rtx_CONST_INT.
4081
4082 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4083
4084 * config/xtensa/xtensa.h (DYNAMIC_CHAIN_ADDRESS): Use GEN_INT
4085 instead of gen_rtx_CONST_INT.
4086
4087 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4088
4089 * target-def.h (TARGET_STRICT_ARGUMENT_NAMING): Define as
4090 hook_bool_CUMULATIVE_ARGS_false.
4091 * targhooks.c (default_strict_argument_naming): Rename to
4092 hook_bool_CUMULATIVE_ARGS_false.
4093 * targhooks.h: Update the prototype for
4094 default_strict_argument_naming.
4095
4096 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4097
4098 * config/sh/sh.c: Replace "gen_rtx (FOO, " with "gen_rtx_FOO (".
4099 * config/sh/sh.h: Likewise.
4100 * config/sh/sh.md: Likewise.
4101
4102 2004-01-31 Eric Botcazou <ebotcazou@libertysurf.fr>
4103
4104 * doc/invoke.texi (SPARC options): Restructure and update.
4105
4106 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4107
4108 * system.h (PROMOTE_FUNCTION_ARGS, STRUCT_VALUE_INCOMING, and
4109 STRICT_ARGUMENT_NAMING): Poison.
4110 * target-def.h (TARGET_PROMOTE_FUNCTION_ARGS): Define as
4111 hook_bool_tree_false.
4112 * targhooks.c (default_promote_function_args): Remove.
4113 (default_struct_value_rtx): Don't use STRUCT_VALUE_INCOMING.
4114 Don't check incoming.
4115 (default_strict_argument_naming): Don't use
4116 STRICT_ARGUMENT_NAMING.
4117 * targhooks.h: Remove the prototype for
4118 default_promote_function_args.
4119
4120 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4121
4122 * config/i386/i386-protos.h: Remove the prototype for
4123 ix86_setup_incoming_varargs.
4124 * config/i386/i386.c (TARGET_SETUP_INCOMING_VARARGS): New.
4125 (ix86_setup_incoming_varargs): Make it static.
4126 * config/i386/i386.h (SETUP_INCOMING_VARARGS): Remove.
4127
4128 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4129
4130 * alloc-pool.c: Fix comment typos.
4131 * builtin-types.def: Likewise.
4132 * builtins.def: Likewise.
4133 * c-pretty-print.c: Likewise.
4134 * df.h: Likewise.
4135 * reload1.c: Likewise.
4136
4137 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4138
4139 * doc/invoke.texi: Follow spelling conventions.
4140 * doc/tm.texi: Likewise.
4141
4142 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4143
4144 * doc/install.texi: Fix typos.
4145 * doc/invoke.texi: Likewise.
4146
4147 2004-01-31 Ulrich Weigand <uweigand@de.ibm.com>
4148
4149 * config/s390/s390.c (s390_decompose_address): Do not treat virtual
4150 registers as pointers.
4151 * config/s390/s390.md ("*la_31" second peephole2): Fix incorrect mode.
4152
4153 2004-01-31 Paolo Bonzini <bonzini@gnu.org>
4154
4155 * combine.c (cse_main): Set gen_lowpart to gen_lowpart_for_combine
4156 and restore it to gen_lowpart_general on exit.
4157 (gen_lowpart_for_combine): Adjust all callers to go through
4158 gen_lowpart.
4159 * cse.c (cse_main): Set gen_lowpart to gen_lowpart_if_possible
4160 and restore it to gen_lowpart_general on exit.
4161 (gen_lowpart_if_possible): Adjust all callers to go through
4162 gen_lowpart.
4163 * emit-rtl.c (gen_lowpart_general): New name of gen_lowpart.
4164 (gen_lowpart): Declare as pointer to function, initialized to
4165 gen_lowpart_general.
4166 * rtl.h (gen_lowpart): Declare as pointer to function.
4167
4168 2004-01-31 Kazu Hirata <kazu@cs.umass.edu>
4169
4170 * bt-load.c: Replace "gen_rtx (FOO, " with "gen_rtx_FOO (".
4171 * calls.c: Likewise.
4172 * emit-rtl.c: Likewise.
4173 * function.c: Likewise.
4174 * reload1.c: Likewise.
4175 * config/i386/cygming.h: Likewise.
4176 * config/i386/i386.c: Likewise.
4177 * config/i386/winnt.c: Likewise.
4178
4179 2004-01-30 Dara Hazeghi <dhazeghi@yahoo.com>
4180
4181 PR bootstrap/9249
4182 * doc/install.texi: document --enable-__cxa_atexit option.
4183 * configure.ac: Disable __cxa_atexit if not supported.
4184 * configure: Regenerate.
4185
4186 2003-01-30 Daniel Berlin <dberlin@dberlin.org>
4187
4188 * ggc-zone.c (ggc_free): New function.
4189
4190 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
4191
4192 alloc-pool.c, c-lex.c, c-pragma.h, c-semantics.c, cfghooks.c,
4193 cfghooks.h, cfglayout.c, cfgloopmanip.c, debug.c, debug.h,
4194 flow.c, genextract.c, ggc-common.c, ggc-page.c, ggc.h,
4195 ifcvt.c, jump.c, loop-unswitch.c, timevar.c, timevar.def,
4196 tree-optimize.c, vmsdbgout.c, config/fp-bit.c,
4197 config/alpha/alpha.c, config/alpha/alpha.h,
4198 config/alpha/alpha.md, config/alpha/unicosmk.h,
4199 config/alpha/vms.h, config/arm/linux-elf.h, config/avr/avr.c,
4200 config/c4x/c4x-protos.h, config/c4x/c4x.md,
4201 config/d30v/d30v.h, config/frv/frv.md, config/frv/frvbegin.c,
4202 config/frv/frvend.c, config/i386/cygming.h,
4203 config/i386/djgpp.h, config/i386/emmintrin.h,
4204 config/i386/gthr-win32.c, config/i386/i386-interix.h,
4205 config/i386/i386-protos.h, config/i386/openbsd.h,
4206 config/i386/winnt.c, config/i386/xm-mingw32.h,
4207 config/i386/xmmintrin.h, config/ia64/ia64.md,
4208 config/iq2000/iq2000.md, config/m32r/m32r.md,
4209 config/m68k/m68k.md, config/mcore/mcore-elf.h,
4210 config/mcore/mcore.md, config/mips/elf.h, config/mips/elf64.h,
4211 config/mips/iris5gas.h, config/mips/iris6.h,
4212 config/mips/iris6gas.h, config/mips/linux.h,
4213 config/mips/mips.md, config/mips/netbsd.h,
4214 config/mips/openbsd.h, config/mips/windiss.h,
4215 config/pa/fptr.c, config/rs6000/aix.h,
4216 config/rs6000/altivec.h, config/rs6000/darwin.h,
4217 config/rs6000/xcoff.h, config/s390/s390-protos.h,
4218 config/s390/s390.c, config/s390/s390.h, config/s390/s390.md,
4219 config/sh/netbsd-elf.h, config/sh/sh.h, config/sh/vxworks.h,
4220 config/sparc/sol2.h: Update copyright.
4221
4222 2004-01-30 Kelley Cook <kcook@gcc.gnu.org>
4223
4224 * Makefile.in (abs_docdir, abs_srcdir): Define.
4225 (doc/%.dvi, doc/gccinstall.dvi): Use $(abs_docdir).
4226
4227 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
4228
4229 * genconfig.c (main): Have CC0_P check its operand even on a
4230 target without cc0.
4231
4232 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
4233
4234 * config/alpha/alpha.c: Remove mentions of deprecates macros
4235 in comments, remove some target-independent comments about target
4236 macros, and/or add minimal function comments for target hook
4237 implementations.
4238 * config/avr/avr.c: Likewise.
4239 * config/ia64/ia64.h: Likewise.
4240 * config/ip2k/ip2k.c: Likewise.
4241 * config/iq2000/iq2000.c: Likewise.
4242 * config/m32r/m32r.h: Likewise.
4243 * config/m68hc11/m68hc11.c: Likewise.
4244 * config/mcore/mcore.c: Likewise.
4245 * config/mmix/mmix.c: Likewise.
4246 * config/mn10300/mn10300.c: Likewise.
4247 * config/pa/pa.c: Likewise.
4248 * config/pdp11/pdp11.c: Likewise.
4249 * config/rs6000/rs6000.h: Likewise.
4250 * config/sh/sh.c: Likewise.
4251 * config/sh/sh.h: Likewise.
4252 * config/sparc/sparc.c: Likewise.
4253 * config/sparc/sparc.h: Likewise.
4254 * config/stormy16/stormy16.c: Likewise.
4255 * config/xtensa/xtensa.c: Likewise.
4256
4257 2004-01-30 Ulrich Weigand <uweigand@de.ibm.com>
4258
4259 PR optimization/12147
4260 * reload1.c (reload_reg_free_p): RELOAD_OTHER conflicts with
4261 RELOAD_FOR_OPADDR_ADDR.
4262 (reload_reg_reaches_end_p): RELOAD_FOR_OTHER_ADDRESS register
4263 might be reused as RELOAD_FOR_OPADDR_ADDR register.
4264
4265 2004-01-30 Jan Hubicka <jh@suse.cz>
4266
4267 * reload.c (get_secondary_mem): Fix updating of
4268 secondary_memlocs_elim_used.
4269
4270 2004-01-30 Richard Henderson <rth@redhat.com>
4271
4272 * varasm.c (struct rtx_const, struct pool_constant): Remove.
4273 (MAX_RTX_HASH_TABLE): Remove.
4274 (const_rtx_hash_table, const_rtx_sym_hash_table): Remove.
4275 (first_pool, last_pool, pool_offset): Remove.
4276 (struct rtx_constant_pool): Split out from ...
4277 (struct varasm_status): ... here. Reference one via pointer.
4278 (struct constant_descriptor_rtx): Merge struct pool_constant.
4279 (SYMHASH): Remove.
4280 (decode_rtx_const): Remove.
4281 (const_hash_rtx, compare_constant_rtx): Remove.
4282 (record_constant_rtx): Remove.
4283 (const_desc_rtx_hash, const_desc_rtx_eq): New.
4284 (const_desc_rtx_sym_hash, const_desc_rtx_sym_eq): New.
4285 (const_rtx_hash_1, const_rtx_hash): New.
4286 (init_varasm_status): Allocate a rtx_constant_pool, and its hashes.
4287 (simplify_subtraction): Use simplify_rtx.
4288 (force_const_mem): Rewrite to use new data structures.
4289 (find_pool_constant): Likewise.
4290 (get_pool_constant, get_pool_constant_mark,
4291 get_pool_constant_for_function, get_pool_mode,
4292 get_pool_mode_for_function, get_pool_offset, get_pool_size): Likewise.
4293 (output_constant_pool_2): Split out from output_constant_pool.
4294 (output_constant_pool_1): Likewise. Use new pool datastructures.
4295 (output_constant_pool): Zap entire pool datastructure.
4296 (mark_constant): Use new pool datastructures.
4297 (mark_constants): Use for_each_rtx.
4298 (mark_constant_pool): Use new pool datastructures.
4299
4300 2004-01-30 Fariborz Jahanian <fjahanian@apple.com>
4301
4302 * config/rs6000/rs6000.c (rs6000_emit_move): Remove #if 0.
4303 Copy operands[1] to pseudo for simplify_gen_subreg.
4304
4305 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
4306
4307 * gcse.c (bypass_block): Fix a typo in the previous check-in
4308 to the file.
4309
4310 2004-01-30 Andrew Pinski <pinskia@physics.uc.edu>
4311
4312 * toplev.c: Include alloc-pool.h.
4313 * Makefile.in (toplev.c): Update dependencies.
4314
4315 2004-01-30 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
4316
4317 * combine.c (simplify_shift_const, case XOR): Be careful when
4318 commuting XOR with ASHIFTRT.
4319
4320 2004-01-30 Kazu Hirata <kazu@cs.umass.edu>
4321 Eric Botcazou <ebotcazou@libertysurf.fr>
4322
4323 * config/sparc/sparc-protos.h: Remove the prototype for
4324 sparc_builtin_saveregs.
4325 * config/sparc/sparc.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
4326 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
4327 (TARGET_PROMOTE_PROTOTYPES): Likewise.
4328 (TARGET_STRUCT_VALUE_RTX): Likewise.
4329 (TARGET_RETURN_IN_MEMORY): Likewise.
4330 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
4331 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
4332 (sparc_builtin_saveregs): Make it static.
4333 (sparc_promote_prototypes): New.
4334 (sparc_struct_value_rtx): Likewise.
4335 (sparc_return_in_memory): Likewise.
4336 * config/sparc/sparc.h: (PROMOTE_FUNCTION_ARGS): Remove.
4337 (PROMOTE_FUNCTION_RETURN): Likewise.
4338 (RETURN_IN_MEMORY): Likewise.
4339 (STRUCT_VALUE): Likewise.
4340 (STRUCT_VALUE_INCOMING): Likewise.
4341 (EXPAND_BUILTIN_SAVEREGS): Likewise.
4342 (STRICT_ARGUMENT_NAMING): Likewise.
4343 (PROMOTE_PROTOTYPES): Likewise.
4344
4345 * config/sparc/sparc.h (PROMOTE_MODE): Use word_mode.
4346
4347 2004-01-30 Eric Botcazou <ebotcazou@libertysurf.fr>
4348
4349 PR c/12818
4350 * varasm.c (const_hash_1) <STRING_CST>: Use the
4351 address to compute the hash value if flag_writable_strings.
4352 (compare_constant) <STRING_CST>: Compare the addresses
4353 if flag_writable_strings.
4354 (build_constant_desc): Do not copy the expression for a
4355 STRING_CST if flag_writable_strings.
4356
4357 2004-01-30 Jan Hubicka <jh@suse.cz>
4358
4359 * alloc-pool.c: Include hashtab.h
4360 (alloc_pool_descriptor): New structure
4361 (alloc_pool_hash): New global variable.
4362 (hash_descriptor, eq_descriptor, alloc_pool_descriptor): New.
4363 (create_alloc_pool): Update statistics.
4364 (free_alloc_pool): Likewise.
4365 (pool_alloc): Likewise.
4366 (output_info): New structure
4367 (print_statistics, dump_alloc_pool_statistics): New function.
4368 * alloc-pool.h (alloc_pool_def): Turn name to be constant.
4369 (dump_alloc_pool_statistics): Declare.
4370 * toplev.c (finalize): Dump statistics.
4371
4372 * reload.c (secondary_memlocs_elim_used): New static variable.
4373 (get_secondary_mem): Update it.
4374 (find_reloads): Use it.
4375
4376 2004-01-30 Steven Bosscher <s.bosscher@student.tudelft.nl>
4377
4378 * toplev.c: Fix broken checkin of 2003-12-30, again.
4379
4380 2004-01-30 Ulrich Weigand <uweigand@de.ibm.com>
4381
4382 * configure.ac (gcc_cv_as_dwarf2_debug_line): Enable test for
4383 s390*-*-* targets by specifying a 'nop' insn.
4384 * configure: Regenerate.
4385
4386 2004-01-30 Eric Botcazou <ebotcazou@libertysurf.fr>
4387
4388 PR target/11475
4389 * config/sparc/sparc.md (movhi_lo_sum): Tighten predicates.
4390
4391 2004-01-29 Jakub Jelinek <jakub@redhat.com>
4392
4393 * emit-rtl.c (change_address): Use XEXP (memref, 0) instead
4394 of addr when creating MEM copy.
4395
4396 2004-01-29 Devang Patel <dpatel@apple.com>
4397
4398 * dwarf2out.c (gen_field_die): Do not equate decl number to die.
4399
4400 2004-01-28 Ian Lance Taylor <ian@wasabisystems.com>
4401
4402 PR inline-asm/6162
4403 * reload.c (find_reloads): Only support one pair of commutative
4404 operands.
4405
4406 2004-01-29 Roger Sayle <roger@eyesopen.com>
4407
4408 PR java/13824
4409 * tree.c (unsafe_for_reeval): Handle EXIT_BLOCK_EXPR nodes specially
4410 as their EXIT_BLOCK_LABELED_BLOCK operands can lead to unbounded
4411 recursion.
4412
4413 2004-01-29 Kazu Hirata <kazu@cs.umass.edu>
4414
4415 * config/frv/frv.c: Don't mention deprecated macros in
4416 comments. Remove some target-independent comments about
4417 target macros.
4418 * config/frv/frv.h: Likewise.
4419
4420 2004-01-29 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
4421
4422 * cfghooks.c (split_block): Set probability and count of the
4423 new edge.
4424
4425 2005-01-29 Josef Zlomek <zlomekj@suse.cz>
4426
4427 * dwarf2out.c (struct die_struct): Added field decl_id.
4428 (decl_die_table): Changed to hash table.
4429 (decl_die_table_allocated): Deleted.
4430 (decl_die_table_in_use): Deleted.
4431 (DECL_DIE_TABLE_INCREMENT): Deleted.
4432 (decl_die_table_hash): New function.
4433 (decl_die_table_eq): New function.
4434 (lookup_decl_die): Lookup in a hash table.
4435 (equate_decl_number_to_die): Insert into a hash table.
4436 (dwarf2out_init): Init hash table decl_die_table.
4437
4438 2004-01-29 Jakub Jelinek <jakub@redhat.com>
4439
4440 PR optimization/13424
4441 * expr.c (store_constructor): Revert 2003-12-03 change.
4442
4443 * emit-rtl.c (change_address): Check also if MEM_ATTRS is set as
4444 expected before returning early. Avoid sharing RTL if they
4445 need to be changed.
4446
4447 * config/i386/i386.c (ix86_expand_movstr): Rework rep_mov and strmov
4448 handling so that memory attributes are preserved. Don't call
4449 ix86_set_move_mem_attrs.
4450 (ix86_set_move_mem_attrs_1, ix86_set_move_mem_attrs): Removed.
4451 (ix86_expand_clrstr): Rename src argument to
4452 dst. Rework rep_stos and strset handling so that memory attributes
4453 are preserved.
4454 (ix86_expand_strlen): Pass src argument to
4455 ix86_expand_strlensi_unroll_1. Rework strlenqi_1 handling so that
4456 memory attributes are preserved.
4457 (ix86_expand_strlensi_unroll_1): Add src argument. Use
4458 change_address instead of gen_rtx_MEM.
4459 * config/i386/i386.md (strmov, strmov_singleop, rep_mov): New
4460 expanders.
4461 (strmovdi_rex64, strmovsi, strmovsi_rex64, strmovhi, strmovhi_rex64,
4462 strmovqi, strmovqi_rex64): Remove.
4463 (rep_mov*, strmov*): Prefix insn names with *.
4464 (strset, strset_singleop, rep_stos): New expanders.
4465 (strsetdi_rex64, strsetsi, strsetsi_rex64, strsethi, strsethi_rex64,
4466 strsetqi, strsetqi_rex64): Remove.
4467 (rep_stos*, strset*): Prefix insn names with *.
4468 (rep_stosqi_rex64): Likewise. Fix mode of dirflag reg from DImode
4469 to SImode.
4470 (cmpstrsi): Rework cmpstrqi_1 handling so that memory attributes
4471 are preserved.
4472 (cmpstrqi_nz_1, cmpstrqi_nz_rex_1, cmpstrqi_1, cmpstrqi_rex_1):
4473 Prefix insn names with *.
4474 (cmpstrqi_nz_1, cmpstrqi_1): New expanders.
4475 (strlenqi_1, strlenqi_rex_1): Prefix insn names with *.
4476 (strlenqi_1): New expander.
4477 * config/i386/i386.h (ix86_set_move_mem_attrs): Remove prototype.
4478
4479 2004-01-29 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
4480
4481 * Makefile.in (cfghooks.o): Add TIMEVAR_H and toplev.h dependency.
4482 * basic-block.h (tidy_fallthru_edge, tidy_fallthru_edges, dump_bb,
4483 verify_flow_info): Declaration removed.
4484 * cfg.c (verify_flow_info, dump_bb): Moved to cfghooks.c.
4485 (debug_bb, debug_bb_n): Add argument to dump_bb call.
4486 * cfgcleanup.c (try_simplify_condjump, try_crossjump_to_edge,
4487 try_optimize_cfg, delete_unreachable_blocks): Use delete_basic_block
4488 instead of delete_block.
4489 * cfghooks.c: Include timevar.h and toplev.h.
4490 (cfg_hooks): Define here.
4491 (verify_flow_info, dump_bb): Moved from cfg.c.
4492 (redirect_edge_and_branch, redirect_edge_and_branch_force,
4493 split_block, split_block_after_labels, move_block_after,
4494 delete_basic_block, split_edge, create_basic_block,
4495 create_empty_bb, can_merge_blocks_p, merge_blocks,
4496 make_forwarder_block, tidy_fallthru_edge, tidy_fallthru_edges):
4497 New functions.
4498 * cfghooks.h (struct cfg_hooks): Added fields name,
4499 make_forwarder_block, tidy_fallthru_edge and
4500 move_block_after. Changed type of verify_flow_info, dump_bb,
4501 split_block fields. Renamed cfgh_split_edge and delete_block
4502 fields.
4503 (redirect_edge_and_branch, redirect_edge_and_branch_force,
4504 split_block, delete_block, split_edge, create_basic_block,
4505 can_merge_blocks_p, merge_blocks): Macros removed.
4506 (cfg_hooks): Do not export.
4507 (verify_flow_info, dump_bb, redirect_edge_and_branch,
4508 redirect_edge_and_branch_force, split_block, split_block_after_labels,
4509 move_block_after, delete_basic_block, split_edge, create_basic_block,
4510 create_empty_bb, can_merge_blocks_p, merge_blocks,
4511 make_forwarder_block, tidy_fallthru_edge, tidy_fallthru_edges):
4512 Declare.
4513 (cfg_layout_rtl_cfg_hooks): Declare.
4514 * cfgloop.c (update_latch_info, mfb_keep_just, mfb_keep_nonlatch):
4515 New functions.
4516 (canonicalize_loop_headers): Use new semantics of make_forwarder_block.
4517 (redirect_edge_with_latch_update): Removed.
4518 (make_forwarder_block): Moved to cfghooks.c, semantics changed.
4519 * cfgloopmanip.c (remove_bbs): Do not update dominators here.
4520 * cfgrtl.c (cfg_layout_split_block, rtl_split_block, rtl_dump_bb,
4521 rtl_delete_block, rtl_split_block, rtl_merge_blocks,
4522 tidy_fallthru_edge, rtl_split_edge, cfg_layout_delete_block,
4523 cfg_layout_merge_blocks, cfg_layout_split_edge): Partly moved to
4524 cfghooks.c.
4525 (rtl_create_basic_block): Coding style fix.
4526 (rtl_tidy_fallthru_edge, rtl_move_block_after,
4527 rtl_make_forwarder_block): New functions.
4528 (update_cfg_after_block_merging): Removed.
4529 (rtl_cfg_hooks, cfg_layout_rtl_cfg_hooks): Fill in new entries.
4530 * flow.c (verify_wide_reg, verify_local_live_at_start): Add argument
4531 to dump_bb.
4532 * ifcvt.c (merge_if_block, find_cond_trap, find_if_case_1,
4533 find_if_case_2): Don't update dominators.
4534 * timevar.def (TV_CFG_VERIFY): New.
4535 * loop-unswitch.c (unswitch_loop): Don't call add_to_dominance_info.
4536 * cfglayout.c (copy_bbs): Don't call add_to_dominance_info.
4537 * cfgloopmanip.c (split_loop_bb): Don't update dominators.
4538 (remove_bbs): Don't call remove_bbs.
4539 (create_preheader): Use make_forwarder_block.
4540 (mfb_keep_just, mfb_update_loops): New static functions.
4541
4542 2004-01-29 Kazu Hirata <kazu@cs.umass.edu>
4543
4544 * config/avr/avr.h: Remove target-independent comments about
4545 target macros.
4546
4547 2004-01-28 Daniel Berlin <dberlin@dberlin.org>
4548
4549 * timevar.c (timevar_print): Mention when checking is enabled.
4550
4551 2004-01-28 Giovanni Bajo <giovannibajo@gcc.gnu.org>
4552
4553 * c-lex.c (c_lex): Rename to...
4554 (c_lex_with_flags): Add new parameter to get CPP flags.
4555 (c_lex): Thunk to c_lex_with_flags while keeping the old interface.
4556 * c-pragma.h (c_lex_with_flags): Declare.
4557
4558 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4559
4560 * config/mcore/mcore.c (mcore_external_libcall): Add a
4561 comment.
4562 (mcore_return_in_memory): Likewise.
4563
4564 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4565
4566 * config/mcore/mcore-protos.h: Remove the prototype for
4567 mcore_setup_incoming_varargs.
4568 * config/mcore/mcore.c (TARGET_ASM_EXTERNAL_LIBCALL): New.
4569 (TARGET_PROMOTE_FUNCTION_ARGS): Likewise.
4570 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
4571 (TARGET_PROMOTE_PROTOTYPES): Likewise.
4572 (TARGET_STRUCT_VALUE_RTX): Likewise.
4573 (TARGET_RETURN_IN_MEMORY): Likewise.
4574 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
4575 (mcore_setup_incoming_varargs): Make it static. Receive the
4576 first argument by reference. Add argument second_time.
4577 (mcore_external_libcall): New.
4578 (mcore_return_in_memory): Likewise.
4579 * config/mcore/mcore.h (PROMOTE_FUNCTION_ARGS): New.
4580 (PROMOTE_FUNCTION_RETURN): Likewise.
4581 (STRUCT_VALUE): Likewise.
4582 (RETURN_IN_MEMORY): Likewise.
4583 (SETUP_INCOMING_VARARGS): Likewise.
4584 (PROMOTE_PROTOTYPES): Likewise.
4585 (ASM_OUTPUT_EXTERNAL_LIBCALL): Likewise.
4586
4587 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4588
4589 * config/m32r/m32r-protos.h: Remove the prototype for
4590 m32r_setup_incoming_varargs.
4591 * config/m32r/m32r.c (TARGET_PROMOTE_PROTOTYPES): New.
4592 (TARGET_STRUCT_VALUE_RTX): Likewise.
4593 (TARGET_RETURN_IN_MEMORY): Likewise.
4594 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
4595 (m32r_return_in_memory): New.
4596 (m32r_setup_incoming_varargs): Make it static.
4597 * config/m32r/m32r.h: Remove #undef of
4598 ASM_OUTPUT_EXTERNAL_LIBCALL. Remove the commented-out
4599 definitions of PROMOTE_FUNCTION_ARGS and
4600 PROMOTE_FUNCTION_RETURN.
4601 (PROMOTE_PROTOTYPES): Remove.
4602 (RETURN_IN_MEMORY): Likewise.
4603 (STRUCT_VALUE): Likewise.
4604
4605 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4606
4607 * config/m68k/m68k.c (TARGET_PROMOTE_PROTOTYPES): New.
4608 (TARGET_STRUCT_VALUE_RTX): Likewise.
4609 (m68k_struct_value_rtx): Likewise.
4610 * config/m68k/m68k.h (STRUCT_VALUE_REGNUM): Rename to
4611 STRUCT_VALUE_REGNUM.
4612 (PROMOTE_PROTOTYPES): Remove.
4613 * config/m68k/m68kelf.h (STRUCT_VALUE_REGNUM): Rename to
4614 STRUCT_VALUE_REGNUM.
4615 * config/m68k/m68kv4.h (STRUCT_VALUE_REGNUM): Likewise.
4616 * config/m68k/netbsd-elf.h (STRUCT_VALUE_REGNUM): Likewise.
4617
4618 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4619
4620 * config/stormy16/stormy16.c
4621 (TARGET_BUILD_BUILTIN_VA_LIST_TYPE): Rename to
4622 TARGET_BUILD_BUILTIN_VA_LIST.
4623
4624 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4625
4626 * config/v850/v850.c (TARGET_PROMOTE_PROTOTYPES): New.
4627 (TARGET_STRUCT_VALUE_RTX): Likewise.
4628 (TARGET_RETURN_IN_MEMORY): Likewise.
4629 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
4630 (v850_return_in_memory): Likewise.
4631 (v850_setup_incoming_varargs): Likewise.
4632 * config/v850/v850.h (PROMOTE_PROTOTYPES): Remove.
4633 (SETUP_INCOMING_VARARGS): Likewise.
4634 (RETURN_IN_MEMORY): Likewise.
4635 (STRUCT_VALUE): Likewise.
4636
4637 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4638
4639 * config/fr30/fr30.c (TARGET_PROMOTE_PROTOTYPES): New.
4640 (fr30_setup_incoming_varargs): Don't use
4641 STRICT_ARGUMENT_NAMING.
4642 * config/fr30/fr30.h (PROMOTE_PROTOTYPES): Remove.
4643 (STRICT_ARGUMENT_NAMING): Likewise.
4644
4645 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4646
4647 * config/frv/frv-protos.h: Remove the prototype for
4648 frv_expand_builtin_saveregs.
4649 * config/frv/frv.c (TARGET_STRUCT_VALUE_RTX): Likewise.
4650 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
4651 (frv_stack_info): Use FRV_STRUCT_VALUE_REGNUM instead of
4652 STRUCT_VALUE_REGNUM.
4653 (frv_expand_builtin_saveregs): Make it static.
4654 (frv_struct_value_rtx): New.
4655 * config/frv/frv.h (EXPAND_BUILTIN_SAVEREGS): Remove.
4656
4657 2004-01-29 Jan Hubicka <jh@suse.cz>
4658
4659 PR c++/12850
4660 * cgraph.c (cgraph_remove_node): Clear out saved/insns/arguments and
4661 initial pointers.
4662 * cgraphunit.c (cgraph_finalize_function): Clear out DECL_SAVED_INSNS
4663 for functions that will be only inlined.
4664 (cgraph_mark_function_to_output): Likewise.
4665 (cgraph_expand_function): Sanity check that DECL_DEFER_OUTPUT is clear;
4666 do not clear function body.
4667 * tree-optimize.c (clear_decl_rtl): Use decl_function_context.
4668 (tree_rest_of_compilation): Reorganize the logic releasing function
4669 body to use callgraph datastructure.
4670
4671 2004-01-28 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
4672
4673 * pa.md: Change predicate of a peephole2 pattern from reg_or_0_operand
4674 to register_operand.
4675
4676 2004-01-28 Zack Weinberg <zack@codesourcery.com>
4677
4678 * config/ia64/ia64.md (fetchadd_acq_si, fetchadd_acq_di)
4679 (cmpxchg_acq_si, cmpxchg_acq_di): Exchange match_dup and
4680 match_operand expressions so that all match_dups appear
4681 lexically after their corresponding match_operands.
4682
4683 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4684
4685 * config/h8300/h8300.c (WORD_REG_USED): Use
4686 HARD_FRAME_POINTER_REGNUM instead of FRAME_POINTER_REGNUM.
4687 (compute_saved_regs): Likewise.
4688 (h8300_expand_prologue): Likewise. Allocate locals after
4689 saving registers.
4690 (h8300_expand_epilogue): Use HARD_FRAME_POINTER_REGNUM instead
4691 of FRAME_POINTER_REGNUM. Deallocate locals before saving
4692 registers.
4693 (h8300_initial_elimination_offset): Adjust for the new frame
4694 layout, which swaps flips the order of locals and saved
4695 registers.
4696 * config/h8300/h8300.h (FIRST_PSEUDO_REGISTER): Change to 12.
4697 (HARD_FRAME_POINTER_REGNUM): New.
4698 (ELIMINABLE_REGS): Add an elimination rule from
4699 FRAME_POINTER_REGNUM to HARD_FRAME_POINTER_REGNUM.
4700 (REGISTER_NAMES): Add fp.
4701 * config/h8300/h8300.md (FP_REG): Change to 11.
4702 (HFP_REG): New.
4703
4704 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4705
4706 * genrecog.c (write_node): Remove a useless local variable.
4707
4708 2004-01-28 Ian Lance Taylor <ian@wasabisystems.com>
4709
4710 * Makefile.in (options.c options.h): Use stamp file s-options to
4711 avoid unnecessary rebuilds.
4712 (options.o): New target listing dependencies.
4713 (gtyp-gen.h): Use stamp file s-gtyp-gen.
4714 (STAGESTUFF): Add s-gtyp-gen.
4715
4716 2004-01-28 Richard Henderson <rth@redhat.com>
4717
4718 * ggc.h (ggc_free): Declare.
4719 * ggc-common.c (ggc_realloc): Use it.
4720 * ggc-page.c: Remove lots of inline markers.
4721 (globals): Add free_object_list.
4722 (ggc_alloc): Tidy.
4723 (ggc_free, validate_free_objects): New.
4724 (poison_pages): Provide default.
4725 (ggc_collect): Call validate_free_objects; emit markers to
4726 the debug file.
4727
4728 2004-01-28 Zack Weinberg <zack@codesourcery.com>
4729 Jim Wilson <wilson@specifixinc.com>
4730
4731 * config/ia64/ia64.c (ia64_split_tmode, ia64_split_tmode_move):
4732 Rewrite to use POST_INC/POST_DEC/POST_MODIFY instead of a
4733 scratch pointer.
4734 (ia64_secondary_reload_class): Delete case GR_REGS.
4735 * config/ia64/ia64.md (movti, *movti_internal, movtf, *movtf_internal):
4736 Do not allocate a scratch register.
4737 (reload_inti, reload_outti, reload_intf, reload_outtf): Delete.
4738
4739 2004-01-28 Jan Hubicka <jh@suse.cz>
4740
4741 * gcse.c (bypass_block): Prevent edges to be unified when we are
4742 about to emit compenstation code.
4743
4744 2004-01-28 Nick Clifton <nickc@redhat.com>
4745
4746 * config/arm/arm.c (arm_expand_builtin): Force second argument of
4747 the setcwx insn into a register.
4748
4749 2004-01-28 Richard Sandiford <rsandifo@redhat.com>
4750
4751 * config/fp-bit.c (pack_d): When using paired doubles to implement
4752 a long double, round the high part separately.
4753 (unpack_d): Fix the case in which the high part is a power of two
4754 and the low part is a nonzero value of the opposite sign.
4755
4756 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4757
4758 * config/c4x/c4x.c (TARGET_ASM_EXTERNAL_LIBCALL): New.
4759 (TARGET_STRUCT_VALUE_RTX): Likewise.
4760 (c4x_external_libcall): Likewise.
4761 (c4x_struct_value_rtx): Likewise.
4762 * config/c4x/c4x.h: Remove.
4763 (STRUCT_VALUE_REGNUM): Likewise.
4764 (ASM_OUTPUT_EXTERNAL_LIBCALL): Likewise.
4765
4766 2004-01-28 Kazu Hirata <kazu@cs.umass.edu>
4767
4768 * config/i386/i386.c (TARGET_PROMOTE_PROTOTYPES): New.
4769 (TARGET_STRUCT_VALUE_RTX): Likewise.
4770 * config/i386/i386.h (STRUCT_VALUE_INCOMING): Remove.
4771 (STRUCT_VALUE): Likewise.
4772 (PROMOTE_PROTOTYPES): Likewise.
4773
4774 2004-01-27 Roger Sayle <roger@eyesopen.com>
4775
4776 * config/pa/pa.c (emit_move_sequence): Check that operand1 is a
4777 CONST_INT before using INTVAL.
4778
4779 2004-01-27 Ulrich Weigand <uweigand@de.ibm.com>
4780
4781 * config/s390/s390.h (TARGET_DEFAULT): Default to !TARGET_BACKCHAIN.
4782 * config/s390/s390.c (s390_return_addr_rtx): Fail for all but current
4783 frame if !TARGET_BACKCHAIN.
4784 * config/s390/s390.md ("allocate_stack"): Use pattern only if
4785 TARGET_BACKCHAIN.
4786 * doc/invoke.texi (-mbackchain/-mno-backchain): Document new default.
4787
4788 2004-01-27 Zack Weinberg <zack@codesourcery.com>
4789
4790 * ia64.c (ia64_function_arg): When placing HFAs in integer
4791 registers, do not special case the mode used for complex
4792 types. Do not advance int_regs until the current register
4793 is full.
4794
4795 2004-01-27 Richard Sandiford <rsandifo@redhat.com>
4796
4797 PR target/7297
4798 * except.c (init_eh): Use a 5-word __jbuf for __builtin_setjmp().
4799
4800 2004-01-27 David Edelsohn <edelsohn@gnu.org>
4801
4802 * config/rs6000/rs6000.c (rs6000_emit_move): #if 0 splitting
4803 slow, unaligned loads and stores while debugging. Fix formatting.
4804
4805 2004-01-27 David Edelsohn <edelsohn@gnu.org>
4806
4807 * config/rs6000/rs6000.md (save_stack_nonlocal): Use Pmode instead
4808 of computing wmode.
4809 (restore_stack_nonlocal): Same.
4810
4811 2004-01-27 Devang Patel <dpatel@apple.com>
4812
4813 * Makefile.in (dwarf2out.o): Depend on input.h
4814 * dbxout.c (dbx_debug_hooks): Add new empty hook for
4815 imported_module_or_decl.
4816 (xcoff_debug_hooks): Same.
4817 * sdbout.c (sdb_debug_hooks): Same.
4818 * vmsdbgout.c (vmsdbg_debug_hooks): Same.
4819 * debug.c (do_nothing_debug_hooks): Same.
4820 (debug_nothing_tree_tree): New function.
4821 * debug.h (gcc_debug_hooks): New hook, imported_module_or_decl.
4822 * dwarf2out.c: Include input.h.
4823 (dwarf2_debug_hooks): Add new hook for imported_module_or_decl.
4824 (remove_child_TAG): New function.
4825 (dwarf_tag_name): Handle DW_TAG_imported_module.
4826 (gen_subprogram_die): Equate decl number to declaration die. Do not
4827 remove all children dies while reusing declaration die for definition.
4828 Instead, selectively remove only formal parameters.
4829 (gen_variable_die): Equate variable decl to declaration die.
4830 (gen_field_die): Equate field decl to line number.
4831 (force_namespace_die): Replace it with ...
4832 (force_decl_die): ... this.
4833 (force_type_die): New function.
4834 (setup_namespace_context): Replace use of force_namespace_die() with
4835 force_decl_die().
4836 (gen_namespace_die): Same.
4837 (dwarf2out_imported_module_or_decl): New function.
4838
4839 2004-01-27 Bob Wilson <bob.wilson@acm.org>
4840
4841 * config/xtensa/xtensa.c (xtensa_copy_incoming_a7): Remove SUBREG
4842 on CQImode and CHImode incoming arguments in register a7.
4843 (function_arg): Wrap BLKmode argument in register a7 in a PARALLEL.
4844 * config/xtensa/xtensa.h (BLOCK_REG_PADDING): Define.
4845 * config/xtensa/xtensa.md (movdi, movdf): Only call force_reg or
4846 xtensa_copy_incoming_a7 before reload.
4847
4848 2004-01-27 J"orn Rennecke <joern.rennecke@superh.com>
4849
4850 * coverage.c (get_coverage_counts): Give a different message
4851 if flag_guess_branch_prob is set.
4852 * predict.c (counts_to_freqs): Return an int.
4853 (estimate_bb_frequencies): If counts_to_freqs returns zero,
4854 calculate estimates.
4855
4856 2004-01-27 Kazu Hirata <kazu@cs.umass.edu>
4857
4858 * config/iq2000/iq2000-protos.h: Remove the prototype for
4859 iq2000_setup_incoming_varargs.
4860 * config/iq2000/iq2000.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
4861 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
4862 (TARGET_PROMOTE_PROTOTYPES): Likewise.
4863 (TARGET_STRUCT_VALUE_RTX): Likewise.
4864 (TARGET_RETURN_IN_MEMORY): Likewise.
4865 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
4866 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
4867 (iq2000_return_in_memory): Likewise.
4868 (iq2000_setup_incoming_varargs): Make it static. Receive the
4869 first argument by reference.
4870 * config/iq2000/iq2000.h (PROMOTE_FUNCTION_ARGS): Remove.
4871 (PROMOTE_FUNCTION_RETURN): Likewise.
4872 (PROMOTE_PROTOTYPES): Likewise.
4873 (RETURN_IN_MEMORY): Likewise.
4874 (STRUCT_VALUE): Likewise.
4875 (SETUP_INCOMING_VARARGS): Likewise.
4876 (STRICT_ARGUMENT_NAMING): Likewise.
4877
4878 2004-01-24 James A. Morrison <ja2morri@uwaterloo.ca>
4879
4880 * fixinc/fixinc.c (test_test): Initialize res.
4881 (start_flexer): Initialize pz_cmd_save.
4882
4883 2004-01-27 Zack Weinberg <zack@codesourcery.com>
4884
4885 * doc/rtl.texi (Arithmetic): Rewrite entries for PLUS,
4886 SS_PLUS, US_PLUS, LO_SUM, MINUS, SS_MINUS, US_MINUS.
4887
4888 2004-01-27 Zack Weinberg <zack@codesourcery.com>
4889
4890 PR 7198
4891 * config/ia64/ia64.md (*nmaddsf4, *nmadddf4, *nmadddf4_alts)
4892 (*nmadddf4_trunc, *nmaddxf4, *nmaddxf4_truncsf, *nmaddxf4_truncdf)
4893 (*nmaddxf4_alts, *nmaddxf4_truncdf_alts):
4894 Rewrite pattern as (minus (op 3) (mult (op 1) (op 2))).
4895 Possibly rename pattern for consistency.
4896 Remove ??? comments suggesting that this be done.
4897 (*nmaddsf4_alts, *nmadddf4_truncsf_alts, *nmaddxf4_truncsf_alts):
4898 New patterns.
4899 (divsi3_internal, divdi3_internal_lat, divdi3_internal_thr)
4900 (divsf3_internal_lat, divsf3_internal_thr, sqrtsf2_internal_thr)
4901 (divdf3_internal_lat, divdf3_internal_thr, sqrtdf2_internal_thr)
4902 (divxf3_internal_lat, divxf3_internal_thr, sqrtxf2_internal_thr):
4903 Update to match.
4904
4905 2004-01-27 Ian Lance Taylor <ian@wasabisystems.com>
4906
4907 * config/arm/arm.c (output_return_instruction): Only restore IP
4908 into SP if frame_pointer_needed.
4909
4910 2004-01-27 Eric Botcazou <ebotcazou@libertysurf.fr>
4911
4912 * config/sparc/sparc.c (function_arg_pass_by_reference): Return 1
4913 for SCmode and DCmode if ARCH32.
4914 (sparc_va_arg): Handle SCmode and DCmode by reference if ARCH32.
4915 * config/sparc/sparc.h (RETURN_IN_MEMORY): Return 0 for TCmode
4916 if ARCH32.
4917 (BASE_RETURN_VALUE_REG): Return 32 for all FP modes except TFmode
4918 if ARCH32.
4919 (BASE_OUTGOING_VALUE_REG): Likewise.
4920
4921 2004-01-27 Eric Botcazou <ebotcazou@libertysurf.fr>
4922
4923 PR target/10904
4924 PR target/13058
4925 * config/sparc/sparc.h (CANNOT_CHANGE_MODE_CLASS): New.
4926 Forbid mode changes from SImode for lower FP regs if ARCH64.
4927
4928 2004-01-27 J"orn Rennecke <joern.rennecke@superh.com>
4929
4930 * Makefile.in (bt-load.o): Depend on except.h.
4931 * bt-load.c (except.h): #include.
4932 (compute_defs_uses_and_gen): If insn at end of BB can throw
4933 within this function, consider registers used by it unavailable for
4934 btr migration.
4935 (move_btr_def): If insn at end of BB can throw, insert before rather
4936 than after.
4937
4938 * flags.h (flag_btr_bb_exclusive): Declare.
4939 * toplev.c (flag_btr_bb_exclusive): New variable.
4940 (f_options): Add btr-bb-exclusive.
4941 * bt-load.c (augment_live_range): Restore old behaviour if
4942 flag_btr_bb_exclusive is set.
4943 * common.opt: Add entry for -fbtr-bb-exclusive.
4944 * opts.c (common_handle_options): Same.
4945 * doc/invoke.texi: Document -fbtr-bb-exclusive.
4946
4947 * bt-load.c (btrs_live_at_end): New variable.
4948 (compute_defs_uses_and_gen): Compute its pointed-to array.
4949 (clear_btr_from_live_range, add_btr_to_live_range): Update it.
4950 (augment_live_range): When augmenting with a new dominator,
4951 use only its btrs_live_at_end set, but also add in the full set
4952 of the old dominator.
4953 (btr_def_live_range): Use btrs_live_at_end.
4954 (move_btr_def): Set other_btr_uses_before_def, and move new set
4955 to the end of the basic block, if appropriate.
4956 (migrate_btr_defs): Allocate and free btrs_live_at_end.
4957
4958 * bt-load.c (basic_block_freq): Remove outdated comment.
4959
4960 2004-01-27 Alan Modra <amodra@bigpond.net.au>
4961
4962 * config/rs6000/rs6000.h: Correct target_flags free bits comment.
4963 (PREDICATE_CODES): Remove duplicate.
4964 * config/rs6000/linux64.h (CPP_SYSV_SPEC): Don't define.
4965 (SUBSUBTARGET_OVERRIDE_OPTIONS): Disallow 32 bit TARGET_PROFILE_KERNEL.
4966 (MASK_PROFILE_KERNEL): Adjust define.
4967
4968 2004-01-27 Jakub Jelinek <jakub@redhat.com>
4969
4970 * config/i386/i386.c (ix86_constant_alignment): Decrease alignment
4971 of long string literals from 32 bytes to sizeof (void *) when !-Os
4972 and to 1 with -Os.
4973
4974 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
4975
4976 * config/h8300/h8300.c (h8300_tiny_constant_address_p): Accept
4977 constant addresses in the normal mode.
4978
4979 2004-01-26 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
4980
4981 * system.h (CHAR_BITFIELD): Delete.
4982 (BOOL_BITFIELD): New.
4983 * c-decl.c (c_scope): Use BOOL_BITFIELD.
4984 * gengtype-lex.l: Recognize BOOL_BITFIELD instead of CHAR_BITFIELD.
4985
4986 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
4987
4988 * config/arc/arc.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
4989 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
4990 (TARGET_PROMOTE_PROTOTYPES): Likewise.
4991 (TARGET_STRUCT_VALUE_RTX): Likewise.
4992 (TARGET_RETURN_IN_MEMORY): Likewise.
4993 (arc_return_in_memory): Likewise.
4994 * config/arc/arc.h (PROMOTE_FUNCTION_ARGS): Remove.
4995 (PROMOTE_FUNCTION_RETURN): Likewise.
4996 (RETURN_IN_MEMORY): Likewise.
4997 (STRUCT_VALUE): Likewise.
4998
4999 2004-01-26 Richard Henderson <rth@redhat.com>
5000
5001 * c-parse.in (extension): Use itype.
5002 (SAVE_EXT_FLAGS): Don't allocate a tree.
5003 (RESTORE_EXT_FLAGS): Don't read a tree.
5004
5005 2004-01-26 Jan Hubicka <jh@suse.cz>
5006
5007 * cselib.c (discard_useless_values): Clear out value pointer pointing
5008 to datastructure to be recycled.
5009
5010 2004-01-25 Jan Hubicka <jh@suse.cz>
5011
5012 * genextract.c (main): Do not output the memset when not checking.
5013
5014 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5015
5016 * config/h8300/h8300.c (h8300_tiny_constant_address_p): Use a
5017 switch statement instead of a chain of if statements.
5018
5019 2004-01-26 Jeff Law <law@redhat.com>
5020
5021 * doc/contrib.texi: Minor cleanup for Paolo Carlini's entry. Add
5022 acute accents for Petur Runolfsson's entry.
5023
5024 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5025
5026 * config/pdp11/pdp11.c (TARGET_STRUCT_VALUE_RTX): New.
5027 (TARGET_RETURN_IN_MEMORY): Likewise.
5028 * config/pdp11/pdp11.h (STRUCT_VALUE): Remove.
5029 (RETURN_IN_MEMORY): Likewise.
5030
5031 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
5032
5033 * config/rs6000/rs6000.c (rs6000_emit_move): split slow
5034 unaligned load/store into smaller loads and stores.
5035
5036 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
5037
5038 * function.c (assign_parms): Do not assign
5039 long long argument to memory in prologue if
5040 is it loaded into register.
5041
5042 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
5043
5044 PR middle-end/13779
5045 * expr.c (emit_group_load): split constant
5046 correctly into register components of PARALLEL insn.
5047
5048 2004-01-26 Fariborz Jahanian <fjahanian@apple.com>
5049
5050 * gcc/config/rs6000/rs6000.md (save_stack_nonlocal):
5051 Use adjust_address_nv directly with appropriate mode.
5052 (restore_stack_nonlocal): Ditto.
5053
5054 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5055
5056 * config/xtensa/xtensa-protos.h: Remove the prototype for
5057 xtensa_builtin_saveregs.
5058 * config/xtensa/xtensa.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
5059 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
5060 (TARGET_PROMOTE_PROTOTYPES): Likewise.
5061 (TARGET_STRUCT_VALUE_RTX): Likewise.
5062 (TARGET_RETURN_IN_MEMORY): Likewise.
5063 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
5064 (xtensa_builtin_saveregs): Make it static.
5065 (xtensa_return_in_memory): New.
5066 * config/xtensa/xtensa.h (PROMOTE_FUNCTION_ARGS: Remove.
5067 (PROMOTE_FUNCTION_RETURN): Likewise.
5068 (PROMOTE_PROTOTYPES): Likewise.
5069 (STRUCT_VALUE): Likewise.
5070 (RETURN_IN_MEMORY): Likewise.
5071 (EXPAND_BUILTIN_SAVEREGS): Likewise.
5072
5073 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5074
5075 * config/arm/arm.c (TARGET_SETUP_INCOMING_VARARGS): New.
5076 (arm_setup_incoming_varargs): Likewise.
5077 * config/arm/arm.h (SETUP_INCOMING_VARARGS): Remove.
5078
5079 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5080
5081 * config/cris/cris.c (TARGET_SETUP_INCOMING_VARARGS): New.
5082 (cris_setup_incoming_varargs): Likewise.
5083 * config/cris/cris.h (SETUP_INCOMING_VARARGS): Remove.
5084
5085 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5086
5087 * config/ns32k/ns32k.c (TARGET_STRUCT_VALUE_RTX): New.
5088 (ns32k_struct_value_rtx): Likewise.
5089 * config/ns32k/ns32k.h (STRUCT_VALUE_REGNUM): Rename to
5090 NS32K_STRUCT_VALUE_REGNUM.
5091
5092 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5093
5094 * config/arm/arm.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
5095 (TARGET_PROMOTE_PROTOTYPES): Likewise.
5096 (TARGET_STRUCT_VALUE_RTX): Likewise.
5097 (arm_struct_value_rtx): Likewise.
5098 * config/arm/arm.h (PROMOTE_FUNCTION_ARGS): Remove.
5099 (STRUCT_VALUE): Likewise.
5100 (STRUCT_VALUE_REGNUM): Likewise.
5101 (PROMOTE_PROTOTYPES): Likewise.
5102
5103 2004-01-26 Kazu Hirata <kazu@cs.umass.edu>
5104
5105 * config/ia64/ia64-protos.h: Remove the prototype for
5106 ia64_setup_incoming_varargs and ia64_return_in_memory.
5107 * config/ia64/ia64.c (TARGET_STRUCT_VALUE_RTX): New.
5108 (TARGET_RETURN_IN_MEMORY): Likewise.
5109 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
5110 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
5111 (ia64_setup_incoming_varargs): Adjust the arguments to meet
5112 the requirement of TARGET_SETUP_INCOMING_VARARGS.
5113 (ia64_return_in_memory): Make it static. Change the return
5114 type to bool from int. Add an argument.
5115 (ia64_struct_value_rtx): New.
5116 * config/ia64/ia64.h: Remove commented-out definitions of
5117 PROMOTE_FUNCTION_ARGS, PROMOTE_FUNCTION_RETURN, and
5118 PROMOTE_PROTOTYPES.
5119 (RETURN_IN_MEMORY): Remove.
5120 (STRUCT_VALUE_REGNUM): Likewise.
5121 (STRICT_ARGUMENT_NAMING): Likewise.
5122
5123 2004-01-26 Eric Botcazou <ebotcazou@libertysurf.fr>
5124
5125 PR target/13666
5126 * config/sparc/sparc.c (function_arg_union_value): New function.
5127 (function_arg): Use it to deal with unions.
5128 (function_value): Likewise. Define 'regbase' only for ARCH64.
5129 Replace a conditional statement by a simpler one.
5130
5131 2004-01-26 Richard Sandiford <rsandifo@redhat.com>
5132
5133 * config/mips/mips.c (mips16_optimize_gp): Delete.
5134 (mips_reorg): Don't call it.
5135
5136 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
5137
5138 * config/c4x/c4x.md (addqi3_noclobber): Move up pecking order.
5139 (floatunsqihf2): Remove operand 6.
5140 (fixhfqi_set, fix_trunchfqi2, fixuns_trunchfqi2): Group with other
5141 fix patterns.
5142 (ldi_conditional, ldf_conditional): Validate operands.
5143
5144 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
5145
5146 * config/c4x/c4x.h (BCT_CHECK_LOOP_ITERATIONS): Remove.
5147 (HAVE_GAS_HIDDEN): Undefine as interim measure.
5148
5149 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
5150
5151 * config/c4x/c4x.c (c4x_legitimate_address_p): Invalidate direct
5152 memory references if TARGET_EXPOSE_LDP nonzero.
5153
5154 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
5155
5156 * config/c4x/c4x.c (legitimize_operands): Truncate invalid shift counts.
5157
5158 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
5159
5160 * config/c4x/c4x.c (c4x_valid_operands): More aggressively reject
5161 invalid operand combinations.
5162
5163 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
5164
5165 * config/c4x/c4x.c (c4x_check_legit_addr): Rename to
5166 c4x_legitimate_address_p. Fix post_modify check.
5167
5168 * config/c4x/c4x-protos.h (c4x_check_legit_addr): Adjust.
5169 * config/c4x/c4x.h (c4x_check_legit_addr): Adjust.
5170
5171 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5172
5173 * config/pa/pa-protos.h: Remove the prototype for
5174 hppa_builtin_saveregs. Add a prototype for
5175 pa_return_in_memory.
5176 * config/pa/pa.c (TARGET_PROMOTE_FUNCTION_RETURN): New.
5177 (TARGET_PROMOTE_PROTOTYPES): Likewise.
5178 (TARGET_STRUCT_VALUE_RTX): Likewise.
5179 (TARGET_RETURN_IN_MEMORY): Likewise.
5180 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
5181 (pa_struct_value_rtx): Likewise.
5182 (pa_return_in_memory): Likewise.
5183 * config/pa/pa.h (STRUCT_VALUE_REGNUM): Rename to
5184 PA_STRUCT_VALUE_REGNUM.
5185 (INIT_CUMULATIVE_ARGS): Use pa_return_in_memory.
5186 (EXPAND_BUILTIN_SAVEREGS): Remove.
5187 (PROMOTE_PROTOTYPES): Likewise.
5188 (PROMOTE_FUNCTION_RETURN): Likewise.
5189
5190 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5191
5192 * config/vax/vax.c (TARGET_PROMOTE_PROTOTYPES): New.
5193 (TARGET_STRUCT_VALUE_RTX): Likewise.
5194 (vax_struct_value_rtx): Likewise.
5195 * config/vax/vax.h (STRUCT_VALUE_REGNUM): Rename to
5196 VAX_STRUCT_VALUE_REGNUM.
5197 (PROMOTE_PROTOTYPES): Remove.
5198
5199 2004-01-26 Michael Hayes <m.hayes@elec.canterbury.ac.nz>
5200
5201 * config/c4x/c4x.h (LEGITIMIZE_RELOAD_ADDRESS): Handle symref.
5202
5203 2003-04-25 Chris Demetriou <cgd@broadcom.com>
5204
5205 * config/mips/mips.h (ISA_HAS_HILO_INTERLOCKS): MIPS32, MIPS32r2,
5206 and MIPS64 have HI/LO interlocks. Update comment.
5207
5208 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5209
5210 * config/stormy16/stormy16-protos.h: Remove the prototype for
5211 xstormy16_setup_incoming_varargs.
5212 * config/stormy16/stormy16.c
5213 (xstormy16_setup_incoming_varargs): Remove.
5214 (xstormy16_return_in_memory): New.
5215 (TARGET_PROMOTE_FUNCTION_ARGS): Likewise.
5216 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
5217 (TARGET_PROMOTE_PROTOTYPES): Likewise.
5218 (TARGET_STRUCT_VALUE_RTX): Likewise.
5219 (TARGET_RETURN_IN_MEMORY): Likewise.
5220 * config/stormy16/stormy16.h (PROMOTE_FUNCTION_ARGS): Remove.
5221 (PROMOTE_FUNCTION_RETURN): Likewise
5222 (PROMOTE_PROTOTYPES): Likewise
5223 (RETURN_IN_MEMORY): Likewise
5224 (STRUCT_VALUE): Likewise
5225 (SETUP_INCOMING_VARARGS): Likewise
5226
5227 2004-01-25 Richard Sandiford <rsandifo@redhat.com>
5228
5229 * config/mips/mips.c (mips_offset_within_object_p): New function.
5230 (mips_symbolic_constant_p): Use it in the SYMBOL_SMALL_DATA and
5231 SYMBOL_CONSTANT_POOL cases. Also use it for SYMBOL_GENERAL if the
5232 ABI has 64-bit pointers and the object file only allows 32-bit symbols.
5233
5234 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5235
5236 * config/sh/sh.h (PROMOTE_FUNCTION_ARGS): Remove.
5237 (PROMOTE_FUNCTION_RETURN): Likewise.
5238
5239 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5240
5241 * config/mn10300/mn10300-protos.h: Remove the prototype for
5242 mn10300_builtin_saveregs.
5243 * config/mn10300/mn10300.c (TARGET_PROMOTE_PROTOTYPES): New.
5244 (TARGET_STRUCT_VALUE_RTX): Likewise.
5245 (TARGET_RETURN_IN_MEMORY): Likewise.
5246 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
5247 (mn10300_return_in_memory): Likewise.
5248 (mn10300_builtin_saveregs): Make it static.
5249 * config/mn10300/mn10300.h (PROMOTE_PROTOTYPES): Remove.
5250 (RETURN_IN_MEMORY): Likewise.
5251 (STRUCT_VALUE): Likewise.
5252 (EXPAND_BUILTIN_SAVEREGS): Likewise.
5253
5254 2004-01-25 Eric Botcazou <ebotcazou@act-europe.fr>
5255
5256 PR bootstrap/13853
5257 * cfgcleanup.c (try_optimize_cfg): Explicitly test against 0.
5258
5259 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5260
5261 * config/h8300/lib1funcs.asm (divnorm, modnorm): Optimize by
5262 using ccr.
5263
5264 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5265
5266 * config/i860/i860-protos.h: Remove the prototype for
5267 i860_saveregs.
5268 * config/i860/i860.c (i860_saveregs): Make it static.
5269 (i860_struct_value_rtx): New.
5270 (TARGET_STRUCT_VALUE_RTX): Likewise.
5271 (TARGET_EXPAND_BUILTIN_SAVEREGS): Likewise.
5272 * config/i860/i860.h (STRUCT_VALUE_REGNUM): Rename to
5273 I860_STRUCT_VALUE_REGNUM.
5274 (EXPAND_BUILTIN_SAVEREGS): Remove.
5275
5276 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5277
5278 * config/m68hc11/m68hc11.c (TARGET_STRUCT_VALUE_RTX): New.
5279 (TARGET_RETURN_IN_MEMORY): Likewise.
5280 (m68hc11_struct_value_rtx): Likewise.
5281 (m68hc11_return_in_memory): Likewise.
5282 * config/m68hc11/m68hc11.h: Remove a commented-out definition
5283 of PROMOTE_PROTOTYPES.
5284 (RETURN_IN_MEMORY): Remove.
5285 (STRUCT_VALUE_REGNUM): Likewise.
5286
5287 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5288
5289 * config/mmix/mmix-protos.h: Remove the prototype for
5290 mmix_setup_incoming_varargs.
5291 * config/mmix/mmix.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
5292 (TARGET_STRUCT_VALUE_RTX): Likewise.
5293 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
5294 (mmix_setup_incoming_varargs): Make it static.
5295 (mmix_struct_value_rtx): New.
5296 * config/mmix/mmix.h (PROMOTE_FUNCTION_ARGS): Remove.
5297 Remove a commented-out definition of PROMOTE_FUNCTION_RETURN.
5298 (STRUCT_VALUE_REGNUM): Remove.
5299 (SETUP_INCOMING_VARARGS): Likewise.
5300
5301 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5302
5303 * config/mips/mips-protos.h: Remove the prototypes for
5304 mips_setup_incoming_varargs and mips_return_in_memory.
5305 * config/mips/mips.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
5306 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
5307 (TARGET_PROMOTE_PROTOTYPES): Likewise.
5308 (TARGET_STRUCT_VALUE_RTX): Likewise.
5309 (TARGET_RETURN_IN_MEMORY): Likewise.
5310 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
5311 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
5312 (mips_setup_incoming_varargs): Match the prototype for
5313 TARGET_SETUP_INCOMING_VARARGS.
5314 (mips_return_in_memory): Make it static. Add argument fntype.
5315 (mips_strict_argument_naming): New.
5316 * config/mips/mips.h (PROMOTE_PROTOTYPES): Remove.
5317 (PROMOTE_FUNCTION_ARGS): Likewise.
5318 (PROMOTE_FUNCTION_RETURN): Likewise.
5319 (STRUCT_VALUE): Likewise.
5320 (RETURN_IN_MEMORY): Likewise.
5321 (SETUP_INCOMING_VARARGS): Likewise.
5322 (STRICT_ARGUMENT_NAMING): Likewise.
5323
5324 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5325
5326 * config/ip2k/ip2k.c (TARGET_STRUCT_VALUE_RTX): New.
5327 (TARGET_RETURN_IN_MEMORY): Likewise.
5328 (TARGET_SETUP_INCOMING_VARARGS): Likewise.
5329 (ip2k_return_in_memory): Likewise.
5330 (ip2k_setup_incoming_varargs): Likewise.
5331 * config/ip2k/ip2k.h (RETURN_IN_MEMORY): Remove.
5332 (STRUCT_VALUE): Likewise.
5333 (STRUCT_VALUE_INCOMING): Likewise.
5334 (SETUP_INCOMING_VARARGS): Likewise.
5335
5336 2004-01-25 Kazu Hirata <kazu@cs.umass.edu>
5337
5338 * config/avr/avr.c (TARGET_STRUCT_VALUE_RTX): New.
5339 (TARGET_RETURN_IN_MEMORY): Likewise.
5340 (TARGET_STRICT_ARGUMENT_NAMING): Likewise.
5341 (avr_return_in_memory): Remove.
5342 * config/avr/avr.h (RETURN_IN_MEMORY): Remove.
5343 (STRUCT_VALUE): Likewise.
5344 (STRUCT_VALUE_INCOMING): Likewise.
5345 (STRICT_ARGUMENT_NAMING): Likewise.
5346
5347 2004-01-25 Jan Hubicka <jh@suse.cz>
5348
5349 * combine.c (recog_for_combine): Avoid allocating unnecesary RTX.
5350
5351 2004-01-25 Richard Sandiford <rsandifo@redhat.com>
5352
5353 * config/mips/mips-protos.h (mips_reg_mode_ok_for_base_p): Delete.
5354 (mips_regno_mode_ok_for_base_p): Declare.
5355 * config/mips/mips.h (ARG_POINTER_REGNUM): Renumber to 77.
5356 (FRAME_POINTER_REGNUM): Renumber to 78.
5357 (FIRST_PSEUDO_REGISTER): Update comment accordingly.
5358 (BASE_REG_P, GP_REG_OR_PSEUDO_STRICT_P): Delete.
5359 (GP_REG_OR_PSEUDO_NONSTRICT_P): Delete.
5360 (REGNO_MODE_OK_FOR_BASE_P): Use mips_regno_mode_ok_for_base_p.
5361 (REG_MODE_OK_FOR_BASE_P): Likewise.
5362 * config/mips/mips.c (mips_reg_names, mips_sw_reg_names): Change
5363 entry for 77 to "$arg" and entry for 78 to "$frame".
5364 (mips_regno_to_class): Map 77 and 78 to ALL_REGS.
5365 (mips_reg_mode_ok_for_base_p): Remove.
5366 (mips_regno_mode_ok_for_base_p): New function, derived from old
5367 BASE_REG_P macro. Don't enforce the mips16 stack pointer
5368 restrictions unless we're being strict.
5369 (mips_valid_base_register_p): Use mips_regno_mode_ok_for_base_p.
5370
5371 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
5372
5373 * c-common.h: Fix comment typos.
5374 * c-decl.c: Likewise.
5375 * cgraphunit.c: Likewise.
5376 * combine.c: Likewise.
5377 * et-forest.c: Likewise.
5378 * flow.c: Likewise.
5379 * function.c: Likewise.
5380 * ifcvt.c: Likewise.
5381 * integrate.c: Likewise.
5382 * jump.c: Likewise.
5383 * postreload.c: Likewise.
5384 * varray.c: Likewise.
5385
5386 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
5387
5388 * doc/frontends.texi: Update copyright.
5389 * doc/gcov.texi: Likewise.
5390 * doc/gty.texi: Likewise.
5391 * doc/sourcebuild.texi: Likewise.
5392 * doc/standards.texi: Likewise.
5393
5394 2004-01-24 Herman A.J. ten Brugge <hermantenbrugge@home.nl>
5395
5396 PR target/12978
5397 * c4x.md: (movstrqi*) Use match_scratch instead of match_dup.
5398 Remove movstrqi_small because it conflicts with movstrqi_large.
5399
5400 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
5401
5402 * config/cris/cris.c (TARGET_PROMOTE_FUNCTION_ARGS): New.
5403 (TARGET_STRUCT_VALUE_RTX): Likewise.
5404 (cris_struct_value_rtx): Likewise.
5405 * config/cris/cris.h (PROMOTE_FUNCTION_ARGS): Remove.
5406 (CRIS_STACKADJ_REG): Use CRIS_STRUCT_VALUE_REGNUM instead of
5407 STRUCT_VALUE_REGNUM.
5408 (STRUCT_VALUE_REGNUM): Rename to CRIS_STRUCT_VALUE_REGNUM.
5409
5410 2004-01-24 Ian Lance Taylor <ian@wasabisystems.com>
5411
5412 PR bootstrap/13848
5413 * cse.c (cse_cc_succs): Change the mode of the source expression
5414 as soon as decide we need a new mode. Don't permit changing modes
5415 if we found a match in a successor block.
5416 (cse_condition_code_reg): Save original mode of source expression
5417 so that we know whether we have to change the mode in other
5418 insns.
5419
5420 2004-01-24 Jan Hubicka <jh@suse.cz>
5421
5422 * emit-rtl.c (change_address, adjust_address_1, offset_address,
5423 widen_memory_access): Return early when there is nothing to change.
5424
5425 2004-01-24 Jakub Jelinek <jakub@redhat.com>
5426
5427 * simplify-rtx.c (simplify_relational_operation): Don't
5428 simplify address == constant into address + -constant == 0.
5429
5430 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
5431
5432 * gcc.c (process_command): Don't internationalize the
5433 Copyright message.
5434 * mips-tfile.c (main): Likewise.
5435
5436 2004-01-24 Andreas Tobler <a.tobler@schweiz.ch>
5437
5438 * cse.c: (cse_cc_succs) Fix comparison warning.
5439
5440 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
5441
5442 * config/h8300/h8300.md: Remove extraneous USE in expanders.
5443
5444 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
5445
5446 * config/h8300/h8300-protos.h: Provide prototypes for
5447 h8300_legitimate_constant_p and h8300_legitimate_address_p.
5448 * config/h8300/h8300.c (h8300_legitimate_constant_p): New.
5449 (h8300_rtx_ok_for_base_p): Likewise.
5450 (h8300_legitimate_address_p): Likewise.
5451 * config/h8300/h8300.h (LEGITIMATE_CONSTANT_P): Use
5452 h8300_legitimate_constant_p.
5453 (RTX_OK_FOR_BASE_P): Remove.
5454 (GO_IF_LEGITIMATE_ADDRESS): Use h8300_legitimate_address_p.
5455
5456 2004-01-24 Kazu Hirata <kazu@cs.umass.edu>
5457
5458 * config/h8300/h8300.h (REG_OK_FOR_INDEX_NONSTRICT_P): New.
5459 (REG_OK_FOR_BASE_NONSTRICT_P): Likewise.
5460 (REG_OK_FOR_INDEX_STRICT_P): Likewise.
5461 (REG_OK_FOR_BASE_STRICT_P): Likewise.
5462 (REG_OK_FOR_INDEX_STRICT_P): Use REGNO_OK_FOR_INDEX_P.
5463 (REG_OK_FOR_BASE_STRICT_P): Use REGNO_OK_FOR_BASE_P.
5464 (REG_OK_FOR_INDEX_P): Use REG_OK_FOR_INDEX_STRICT_P.
5465 (REG_OK_FOR_BASE_P): Use REG_OK_FOR_BASE_STRICT_P.
5466
5467 2004-01-24 Jan Hubicka <jh@suse.cz>
5468
5469 * cselib.c (remove_useless_values): Do not access discarded values.
5470
5471 2004-01-24 Joseph S. Myers <jsm@polyomino.org.uk>
5472
5473 * c-typeck.c (build_conditional_expr): Do not allow non-lvalue
5474 arrays.
5475
5476 2004-01-23 Kazu Hirata <kazu@cs.umass.edu>
5477
5478 * recog.c: Fix a typo in copyright.
5479
5480 2004-01-23 Andrew Pinski <apinski@apple.com>
5481
5482 * config/rs6000/rs6000.md (call): Fix misappiled patch.
5483 (call_value): Likewise.
5484
5485 2004-01-23 Richard Henderson <rth@redhat.com>
5486
5487 PR opt/12941
5488 * combine.c (SHIFT_COUNT_TRUNCATED): Provide default value.
5489 (simplify_comparison): Don't simplify (eq (zero_extract c 1 r) 0)
5490 if SHIFT_COUNT_TRUNCATED is set.
5491
5492 2004-01-23 Bob Wilson <bob.wilson@acm.org>
5493
5494 * config/xtensa/xtensa.c (xtensa_va_arg): Handle complex values as
5495 separate real and imaginary parts.
5496 * config/xtensa/xtensa.h (SPLIT_COMPLEX_ARGS): Define.
5497
5498 2004-01-23 Hartmut Penner <hpenner@de.ibm.com>
5499
5500 PR target/13674
5501 * config/rs6000/rs6000.md (movdf_hardfloat64): Do not disparage
5502 loading into GPR.
5503
5504 2004-01-23 Jan Hubicka <jh@suse.cz>
5505
5506 * emit-rtl.c (change_address_1): Do not re-generate the RTX if nothing
5507 change.
5508
5509 * alloc-pool.c (align_four): Kill.
5510 (create_alloc_pool): Align size to eight.
5511 (free_alloc_pool, free_pool): Invalidate deallocated data.
5512
5513 2004-01-23 Ian Lance Taylor <ian@wasabisystems.com>
5514
5515 PR gcc/1532
5516 * cse.c (cse_change_cc_mode): New static function.
5517 (cse_change_cc_mode_insns, cse_cc_succs): Likewise.
5518 (cse_condition_code_reg): New function.
5519 * rtl.h (cse_condition_code_reg): Declare.
5520 * toplev.c (rest_of_handle_cse2): Call cse_condition_code_reg.
5521 * target.h (struct gcc_target): Add fixed_condition_code_regs and
5522 cc_modes_compatible.
5523 * target-def.h (TARGET_FIXED_CONDITION_CODE_REGS): Define.
5524 (TARGET_CC_MODES_COMPATIBLE): Define.
5525 (TARGET_INITIALIZER): Add new initializers.
5526 * targhooks.c (default_cc_modes_compatible): New function.
5527 * targhooks.c (default_cc_modes_compatible): Declare.
5528 * hooks.c (hook_bool_intp_intp_false): New function.
5529 * hooks.h (hook_bool_intp_intp_false): Declare.
5530 * config/i386/i386.c (TARGET_FIXED_CONDITION_CODE_REGS): Define.
5531 (TARGET_CC_MODES_COMPATIBLE): Define.
5532 (ix86_fixed_condition_code_regs): New static function.
5533 (ix86_cc_modes_compatible): Likewise.
5534 * doc/tm.texi (Condition Code): Document new hooks.
5535
5536 2004-01-23 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
5537
5538 * fixinc/inclhack.def (bad_lval): Renamed to ...
5539 (alpha_bad_lval): ... this.
5540 Removed file list.
5541 Restrict to alpha*-dec-osf*.
5542 * fixinc/fixincl.x: Regenerate.
5543 * fixinc/tests/base/dirent.h: Remove, moving test ...
5544 * fixinc/tests/base/testing.h: ... here, reflecting new name.
5545
5546 2004-01-23 Zack Weinberg <zack@codesourcery.com>
5547
5548 PR c/13814
5549 * c-decl.c (diagnose_mismatched_decls): Also discard a
5550 built-in if we encounter an old-style definition with the
5551 same name.
5552
5553 2004-01-23 Jakub Jelinek <jakub@redhat.com>
5554
5555 * config.gcc (powerpc*-*): Clear $with_cpu or $with_tune if it was
5556 set to default{32,64}.
5557
5558 2004-01-21 Jakub Jelinek <jakub@redhat.com>
5559
5560 * config/rs6000/linux64.h (MD_FALLBACK_FRAME_STATE_FOR)
5561 [!__powerpc64__]: Corrected to handle kernels with changed ucontext.
5562
5563 2004-01-23 Eric Botcazou <ebotcazou@act-europe.fr>
5564 Olivier Hainque <hainque@act-europe.fr>
5565
5566 * fold-const.c (fold_binary_op_with_conditional_arg): Only
5567 build a COMPOUND_EXPR if 'arg' is really a SAVE_EXPR.
5568
5569 2004-01-23 Daniel Jacobowitz <drow@mvista.com>
5570
5571 * config/arm/arm.c (arm_legitimate_address_p): Don't check the mode
5572 size for minipool references.
5573
5574 2004-01-23 Roger Sayle <roger@eyesopen.com>
5575
5576 * real.c (real_floor, real_ceil): Tweak to allow input and output
5577 arguments to overlap.
5578 (real_round): New function to implement round(3m) semantics.
5579 * real.h (real_round): Prototype here.
5580 * builtins.c (fold_builtin_round): New function to constant fold
5581 round, roundf and roundl.
5582 (fold_builtin): Call fold_builtin_round for BUILT_IN_ROUND{,F,L}.
5583
5584 2004-01-23 Alexandre Oliva <aoliva@redhat.com>
5585
5586 PR optimization/13819
5587 * config/sh/sh.c (sh_reorg): Compensate for sharing of CLOBBERs
5588 introduced by 2004-01-20's Jan Hubicka's copy_insn change.
5589 (sh_handle_sp_switch_attribute): Remove warning.
5590
5591 2003-11-30 Jan Hubicka <jh@suse.cz>
5592
5593 * i386.c (ix86_emit_restore_regs_using_mov): Deal with large offsets.
5594
5595 2004-01-23 J"orn Rennecke <joern.rennecke@superh.com>
5596
5597 * doc/tm.texi: Insert some weasel words when LOAD_EXTEND_OP
5598 may or may not return non-NIL.
5599 * postreload.c (reload_cse_simplify_operands): In LOAD_EXTEND_OP code,
5600 check CANNOT_CHANGE_MODE_CLASS
5601
5602 2004-01-23 Jan Hubicka <jh@suse.cz>
5603
5604 * basic-block.h (PROP_POSTRELOAD): New macro.
5605 (CLEANUP_LOG_LINKS): New.
5606 * cfgcleanup.c (cleanup_cfg): Only PROP_LOG_LINKS when asked to.
5607 * toplev.c (rest_of_handle_life): Preserve LOG_LINKS trought cleanup_cfg.
5608
5609 * cselib.c (value_pool): New.
5610 (new_cselib_val): Use pool.
5611 (cselib_init): Initialize value_pool
5612 (cselib_finish): Free pool.
5613
5614 2004-01-23 Eric Botcazou <ebotcazou@libertysurf.fr>
5615
5616 * config/sparc/sparc.c (scan_record_type): New function.
5617 (function_arg_slotno): Use it to determine which kinds of
5618 registers the record can be passed in.
5619
5620 2004-01-22 James A. Mmorrison <ja2morri@uwaterloo.ca>
5621
5622 * config/pa/fptr.c: Fix old-style definition.
5623
5624 2004-01-22 Paolo Bonzini <bonzini@gnu.org>
5625
5626 PR optimization/13724
5627 * cse.c (fold_rtx) <SUBREG>: Fold a SUBREG to zero if it
5628 represents the zero bits produced by a ZERO_EXTEND operation.
5629
5630 2004-01-22 Roger Sayle <roger@eyesopen.com>
5631
5632 PR optimization/13821
5633 * simplify-rtx.c (simplify_subreg): Use subreg_lowpart_offset to
5634 correctly calculate the lowpart offset of the contracted subreg.
5635
5636 2004-01-22 Ian Lance Taylor <ian@wasabisystems.com>
5637
5638 * doc/invoke.texi (Optimize Options): Note that --param arguments
5639 are subject to change without notice.
5640
5641 2004-01-22 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
5642
5643 * config.gcc (mips-sgi-irix6*o32): Removed.
5644 * config/mips/iris6-o32-as.h: Likewise.
5645 * config/mips/iris6-o32-gas.h: Likewise.
5646 * config/mips/iris6-o32.h: Likewise.
5647
5648 2004-01-22 Jan Hubicka <jh@suse.cz>
5649
5650 * cfgcleanup.c (first_pass): New static variable.
5651 (try_forward_edges): Add work limiting check for threading.
5652 (try_crossjump_bb): Add work limiting check for crossjumping.
5653 (try_optimize_cfg): Maintain first pass variable.
5654
5655 2004-01-22 Bob Wilson <bob.wilson@acm.org>
5656
5657 * config/xtensa/xtensa.c (function_arg): Generalize logic so that it
5658 handles complex and vector modes.
5659
5660 2004-01-22 Kazu Hirata <kazu@cs.umass.edu>
5661
5662 * config/h8300/h8300.h (REG_OK_FOR_INDEX_P_STRICT): Remove.
5663 (REG_OK_FOR_BASE_P_STRICT): Likewise.
5664 (STRICT): Likewise.
5665
5666 2004-01-22 Daniel Jacobowitz <drow@mvista.com>
5667
5668 * c-semantics.c (genrtl_while_stmt, genrtl_do_stmt_1)
5669 (genrtl_for_stmt): Remove emit_nop calls.
5670
5671 2004-01-22 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
5672
5673 PR target/13713
5674 PR target/13324
5675 * pa.md (movstrsi_prereload, movstrsi_postreload, movstrdi_prereload,
5676 movstrdi_postreload, clrstrsi_prereload, clrstrsi_postreload,
5677 clrstrdi_prereload, clrstrdi_postreload): Fix constraints.
5678
5679 2004-01-22 Daniel Jacobowitz <drow@mvista.com>
5680
5681 * config/arm/arm.c: Include "debug.h".
5682 (thumb_pushpop): Take two new arguments. Add some commentary.
5683 Output frame information when pushing.
5684 (thumb_exit, thumb_unexpanded_epilogue): Update calls to
5685 thumb_pushpop.
5686 (thumb_output_function_prologue): Likewise. Accumulate a CFA
5687 offset, and pass it to thumb_pushpop. Output CFI information.
5688 (thumb_expand_prologue): Add some frame-related markers and notes.
5689
5690 2004-01-22 Ulrich Weigand <uweigand@de.ibm.com>
5691
5692 * config/s390/s390.c (s390_frame_info): Allow large frame sizes
5693 for TARGET_64BIT.
5694 (s390_arg_frame_offset): Change return type to HOST_WIDE_INT.
5695 * config/s390/s390-protos.h (s390_arg_frame_offset): Likewise.
5696
5697 2004-01-22 Roger Sayle <roger@eyesopen.com>
5698 Paolo Bonzini <bonzini@gnu.org>
5699
5700 * rtlanal.c (subreg_lsb_1): New function split out from subreg_lsb.
5701 (subreg_lsb): Change to call new subreg_lsb_1 helper function.
5702 * rtl.h (subreg_lsb_1): Prototype here.
5703 * simplify-rtx.c (simplify_subreg): Optimize subregs of zero and
5704 sign extensions.
5705
5706 2004-01-22 Kazu Hirata <kazu@cs.umass.edu>
5707
5708 * doc/tm.texi (CASE_VECTOR_PC_RELATIVE): Mention that the
5709 macro need not be defined if jump-tables should contain
5710 relative addresses only when -fPIC or -fPIC is in effect.
5711
5712 2004-01-22 Jan Hubicka <jh@suse.cz>
5713
5714 * alias.c (reg_base_value): Turn into varray.
5715 (reg_base_value_size): Kill.
5716 (old_reg_base_value): New deletable varray.
5717 (alias_invariant_size): New variable.
5718 (REG_BASE_VALUE): Update to use varray.
5719 (find_base_value): Likewise.
5720 (record_set): Likewise.
5721 (record_base_value): Likewise.
5722 (memrefs_conflict_p): Likewise.
5723 (record_set): Likewise
5724 (record_base_value): Likewise.
5725 (memrefs_conflict_p): Use alias_invariant_size.
5726 (init_alias_analysis): Use varray; set alias_invariant_size;
5727 rescale other arrays to be sized by maxreg.
5728 (end_alias_analysis): Save reg_base_value; clear alias_invariant_size.
5729
5730 2004-01-22 Eric Botcazou <ebotcazou@libertysurf.fr>
5731
5732 * config/sparc/sparc.c (function_arg_slotno): Use
5733 FLOAT_TYPE_P to detect FP fields in structures.
5734 (function_arg_record_value_1): Likewise.
5735 (function_arg_record_value_2): Likewise.
5736
5737 2004-01-22 Jan Hubicka <jh@suse.cz>
5738
5739 * function.c (allocate_struct_function): Do not initialize expr, emit
5740 and varasm.
5741 (prepare_function_start): Do it here.
5742 * c-parse.in (maybe_type_qual): Do not produce line number notes.
5743
5744 2004-01-22 Eric Botcazou <ebotcazou@libertysurf.fr>
5745
5746 PR target/13559
5747 * config/sparc/sparc.c (function_arg_record_value_3): Revert
5748 to 'word_mode' once the first slot has been filled.
5749
5750 2004-01-22 Olivier Hainque <hainque@act-europe.fr>
5751
5752 * config/sparc/sparc.c (function_arg_record_value_1): Fix
5753 computation of the number of integer registers required.
5754
5755 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
5756
5757 * config/i386/i386.md: Simplify certain comparisons of
5758 const_int.
5759
5760 2004-01-21 Andrew Pinski <apinski@apple.com>
5761
5762 PR target/13785
5763 * config/rs6000/rs6000.md (call_value): Force operand
5764 1 not operand 0 into a register.
5765
5766 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
5767
5768 * cpperror.c, cpptrad.c, longlong.h, params.def, rtl.def,
5769 unwind-dw2-fde.h: Update copyright.
5770
5771 2004-01-21 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
5772
5773 * pa-protos.h: Update copyright.
5774 * pa.h: Likewise.
5775 * pa.md: Likewise.
5776
5777 2004-01-21 Caroline Tice <ctice@apple.com>
5778
5779 PR target/12308
5780 * config/i386/i386.md (fix_truncxfdi2): Add clause to clobber
5781 flags register.
5782 (fix_truncdfdi2): Likewise.
5783 (fix_truncsfdi2): Likewise.
5784 (*fix_truncdi_1): Likewise.
5785 (fix_truncxfsi2): Likewise.
5786 (fix_truncdfsi2): Likewise.
5787 (fix_truncsfsi2): Likewise.
5788 (*fix_truncsi_1): Likewise.
5789 (fix_truncxfhi2): Likewise.
5790 (fix_truncdfhi2): Likewise.
5791 (fix_truncsfhi2): Likewise.
5792 (*fix_trunchi_1): Likewise.
5793
5794 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
5795
5796 * alias.c, basic-block.h, c-common.c, c-common.h,
5797 c-cppbuiltin.c, c-opts.c, c-pragma.c, c-pretty-print.c,
5798 calls.c, cfg.c, cfgcleanup.c, cfgrtl.c, cgraph.h, collect2.c,
5799 combine.c, cppcharset.c, cpphash.h, cppinit.c, cpplib.c,
5800 cpplib.h, cppmacro.c, crtstuff.c, cselib.c, cselib.h,
5801 defaults.h, df.c, dominance.c, et-forest.c, expmed.c, expr.c,
5802 expr.h, fix-header.c, function.h, gcc.c, gcse.c, genattrtab.c,
5803 genautomata.c, genconditions.c, genemit.c, genflags.c,
5804 gengtype.c, gengtype.h, genopinit.c, genrecog.c, gensupport.c,
5805 ggc-zone.c, graph.c, haifa-sched.c, input.h, integrate.c,
5806 langhooks-def.h, langhooks.c, langhooks.h, line-map.c,
5807 line-map.h, local-alloc.c, optabs.c, optabs.h, postreload.c,
5808 ra.h, recog.c, reg-stack.c, regmove.c, reload.c, reorg.c,
5809 rtl.c, sched-deps.c, sched-ebb.c, sdbout.c, system.h,
5810 target.h, targhooks.c, toplev.h, tree-inline.c, unwind-pe.h,
5811 unwind.h, varray.c, varray.h: Update copyright.
5812
5813 2004-01-21 Kazu Hirata <kazu@cs.umass.edu>
5814
5815 * config/h8300/coff.h: Update copyright.
5816 * config/h8300/elf.h: Likewise.
5817 * config/h8300/h8300-protos.h: Likewise.
5818 * config/h8300/h8300.c: Likewise.
5819 * config/h8300/h8300.h: Likewise.
5820 * config/h8300/h8300.md: Likewise.
5821
5822 2004-01-21 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
5823
5824 * fixinc/inclhack.def (hpux10_stdio_declarations, ultrix_const3,
5825 ultrix_locale, ultrix_stdlib, ultrix_strings, ultrix_sys_time,
5826 ultrix_unistd): New hacks.
5827 * fixinc/tests/base/stdio.h (HPUX10_STDIO_DECLARATIONS_CHECK,
5828 ULTRIX_CONST2_CHECK): Add checks.
5829 * fixinc/tests/base/stdlib.h (ULTRIX_STDLIB_CHECK): Likewise.
5830 * fixinc/tests/base/strings.h (ULTRIX_STRINGS2_CHECK): Likewise.
5831 * fixinc/tests/base/unistd.h (ULTRIX_UNISTD_CHECK): Likewise.
5832 * fixinc/tests/base/sys/time.h (ULTRIX_SYS_TIME_CHECK): Likewise.
5833 * fixinc/tests/base/locale.h: New file.
5834 * fixinc/fixincl.x: Rebuilt.
5835
5836 2004-01-21 Andreas Jaeger <aj@suse.de>
5837 Michael Matz <matz@suse.de>
5838
5839 * doc/extend.texi (Extended Asm): Clarify memory clobber.
5840
5841 2004-01-21 Jakub Jelinek <jakub@redhat.com>
5842
5843 * crtstuff.c (frame_dummy, __do_global_ctors_1): Call
5844 _Jv_RegisterClasses through a function pointer.
5845
5846 2004-01-21 Falk Hueffner <falk@debian.org>
5847
5848 PR target/12898
5849 * config/alpha/alpha.c (alpha_emit_set_const_1): If
5850 no_new_pseudos, use gen_rtx_SET directly for SImode constants
5851 which need multiple instructions to emit.
5852
5853 2004-01-21 Inaoka Kazuhiro <inaoka.kazuhiro@renesas.com>
5854
5855 * config/m32r/m32r.h (CPP_SPEC): Define.
5856
5857 2004-01-21 Zack Weinberg <zack@codesourcery.com>
5858
5859 * c-decl.c (merge_decls): Kill different_binding_level and
5860 different_tu arguments; simplify throughout.
5861 (duplicate_decls): Likewise.
5862 (pushdecl, merge_translation_unit_decls): Update calls to
5863 duplicate_decls.
5864
5865 2004-01-20 Kaveh R. Ghazi <ghazi@caip.rutgers.edu>
5866
5867 * Makefile.in (pretty-print.o): Depend on $(CONFIG_H) and
5868 $(SYSTEM_H).
5869 (print-rtl1.o): Depend on $(SYSTEM_H).
5870
5871 2004-01-20 Kelley Cook <kcook@gcc.gnu.org>
5872
5873 PR bootstrap/12730
5874 * configure.ac: Delete definition and subsitution of docdir.
5875 Add info, man, srcman and srcinfo to target hooks. Create doc/
5876 directory.
5877 * configure: Regenerate.
5878 * Makefile.in: Don't substitute docdir and delete all references
5879 throughout.
5880 (MAKEINFOFLAGS): Define.
5881 (stmp-docobjdir): Delete.
5882 (INFOFILES, MANFILES): Define.
5883 (info): Call lang.info, srcinfo and lang.srcinfo.
5884 (generated-manpages): Call lang.man, srcman and lang.srcman.
5885 (srcinfo, srcman): New rules to copy back files to source directory.
5886 (doc/%.info, doc/%.dvi, doc/%.1, doc/%.7): New implict rule.
5887 (install-man): Revamp rule.
5888 (clean): Update dvi directory.
5889 (distclean): Delete TAGS from front end directorys.
5890 (maintainer-clean): Delete all document files in source directory.
5891
5892 objc/Make-lang.in (objc.man, objc.info): Dummy entries.
5893 (objc.srcman, objc.srcinfo): Likewise.
5894
5895 2004-01-20 Bruce Korb <bkorb@gnu.org>
5896
5897 * fixinc/inclhack.def(math_exception): bypass only for glibc.
5898 (matherr_decl): rename & relocate as exception_structure.
5899 This fix must precede the math_exception fix.
5900
5901 2004-01-20 Roger Sayle <roger@eyesopen.com>
5902
5903 * fold-const.c (fold_convert): Rename to fold_convert_const.
5904 (fold_convert_const): Change arguments to take a tree_code,
5905 a type and the operand/expression to be converted. Return
5906 NULL_TREE if no simplification is possible. Add support for
5907 FIX_CEIL_EXPR and FIX_FLOOR_EXPR in addition to FIX_TRUNC_EXPR.
5908 (fold): Handle FIX_CEIL_EXPR and FIX_FLOOR_EXPR.
5909 Adjust call to fold_convert to match new fold_convert_const.
5910 Avoid modifying the tree passed to fold in-place.
5911
5912 2004-01-21 Alan Modra <amodra@bigpond.net.au>
5913
5914 * config/rs6000/sysv4.h (DWARF2_FRAME_REG_OUT): Define.
5915 * dwarf2out.c (output_cfi): Map regs using DWARF2_FRAME_REG_OUT.
5916 * doc/tm.texi (DWARF_FRAME_REGNUM, DWARF2_FRAME_REG_OUT): Document.
5917
5918 2004-01-20 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
5919
5920 * pa-protos.h (compute_frame_size): Use HOST_WIDE_INT for frame sizes.
5921 * pa.c (store_reg, store_reg_modify, load_reg, set_reg_plus_d):
5922 Likewise. Handle frames larger than 0x7fffffff on 64-bit ports.
5923 (emit_move_sequence): Check scratch_reg first in various if statements.
5924 Extend source simplification to handle all 64-bit CONST_INTs.
5925 (pa_output_function_prologue): Use HOST_WIDE_INT_PRINT_DEC for printing
5926 frame size.
5927 (hppa_expand_prologue, hppa_expand_epilogue): Use HOST_WIDE_INT for
5928 frame offset calculations.
5929 * pa.h (NEW_HP_ASSEMBLER): Add comment.
5930 (MAX_LEGIT_64BIT_CONST_INT, MIN_LEGIT_64BIT_CONST_INT,
5931 LEGITIMATE_64BIT_CONST_INT_P): Define.
5932 (LEGITIMATE_CONSTANT_P): Use LEGITIMATE_64BIT_CONST_INT_P. Treat
5933 any CONST_INT as legitimate during and after reload.
5934 (VAL_32_BITS_P, INT_32_BITS): Define.
5935 (LEGITIMIZE_RELOAD_ADDRESS): Handle large frame offsets.
5936
5937 2004-01-20 Jan Hubicka <jh@suse.cz>
5938
5939 * emit-rtl.c (verify_rtx_sharing, copy_insn_1,
5940 emit_copy_of_insn_after, emit_copy_of_insn_after): Clobbers
5941 containing hard regs are shared.
5942 (gen_hard_reg_clobber): New function.
5943 (hard_reg_clobbers): New array.
5944 * genemit.c (gen_exp): Use gen_hard_reg_clobber.
5945 (copy_rtx): Do not copy clobbers containing hard regs.
5946 * rtl.h (gen_hard_reg_clobber): Declare.
5947
5948 2004-01-20 Jan Hubicka <jh@suse.cz>
5949
5950 * varray.c: Include hashtab.h
5951 (varray_descriptor): New structure.
5952 (hash_descriptor, eq_descriptor, varray_descriptor,
5953 print_statistics): New static functions
5954 (varray_init, varray_grow): Update statistics
5955 (dump_varray_statistics): New function.
5956 * varray.h (dump_varray_statistics): Declare.
5957 * toplev.c (finalize): Call it.
5958 * Makefile.in (varray.o): Add dependency.
5959
5960 2004-01-20 Jan Hubicka <jh@suse.cz>
5961
5962 * cselib.c: Include alloc-pool.h
5963 (empty_vals, empty_elt_lists, empty_elt_loc_lists): Kill.
5964 (elt_loc_list_pool, elt_list_pool, cselib_val_pool): Declare.
5965 (new_elt_list, new_elt_loc_list, unchain_one_elt_list,
5966 unchain_one_elt_loc_list_pool, unchain_one_value,
5967 new_cselib_val): Simplify using allocpool.
5968 (cselib_init): Initialize allocpools.
5969 (cselib_finish): Finish allocpools.
5970 * Makefile.in (cselib.o): Depend on alloc-pool.h
5971
5972 2004-01-20 Richard Sandiford <rsandifo@redhat.com>
5973
5974 * config/mips/mips.c (mips_load_call_address): Make the call insn
5975 use $gp if it could be calling a lazy binding stub.
5976
5977 2004-01-20 Kazu Hirata <kazu@cs.umass.edu>
5978
5979 * config/s390/s390.c (TARGET_PROMOTE_FUNCTION_ARGS): Define.
5980 (TARGET_PROMOTE_FUNCTION_RETURN): Likewise.
5981 (TARGET_STRUCT_VALUE_RTX): Likewise.
5982 * config/s390/s390.h (PROMOTE_FUNCTION_ARGS): Remove.
5983 (PROMOTE_FUNCTION_RETURN): Remove.
5984 (STRUCT_VALUE): Remove.
5985
5986 2004-01-20 Denis Chertykov <denisc@overta.ru>
5987
5988 PR bootstrap/13735
5989 * config/avr/avr.h (BASE_REG_CLASS): Don't permit to use X
5990 register as pointer after reload.
5991
5992 2004-01-20 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
5993
5994 PR optimization/12440
5995 * loop.c: Include ggc.h.
5996 (loop_optimize): Run garbage collector between optimization of loops.
5997 * Makefile.in (loop.o): Add GGC_H dependency.
5998
5999 2004-01-20 Hartmut Penner <hpenner@de.ibm.com>
6000
6001 * gcc/config/rs6000/rs6000.c (function_arg) Handle
6002 vector register special in function without prototype.
6003 (function_arg_advance): Vector parameters get always
6004 GPRs allocated for the linux64 target.
6005
6006 2004-01-20 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
6007
6008 * config/m32r/m32r.h (TARGET_M32R2). Test for TARGET_M32R2_MASK
6009 not TARGET_M32RX_MASK.
6010
6011 2004-01-20 Eric Botcazou <ebotcazou@libertysurf.fr>
6012
6013 PR target/13557
6014 * config/sparc/sparc.c (function_arg): Reorder the cases.
6015
6016 2004-01-19 Per Bothner <per@bothner.com>
6017
6018 Move cpp_reader's line_maps field to a shared global.
6019 * cpphash.h (cpp_reader): Rename line_maps field to line_table
6020 and change the type to a pointer rather than a struct.
6021 * cppinit.c (cpp_push_main_field): Adjust accordingly.
6022 * cpplib.c (do_include_common, _cpp_do_file_change, cpp_get_callbacks):
6023 Likewise.
6024 * cppfiles.c (validate_pch): Likewise.
6025 * cppmacro.c (_cpp_warn_if_unused_macro, _cpp_builtin_macro_text):
6026 Likewise.
6027 * cpperror.c (print_location): Likewise.
6028 * cpplib.h (cpp_create_reader): New line_maps pointer parameter.
6029 * cppinit.c (cpp_create_reader): Handle new parameter.
6030 (cpp_destroy): Don't free line_maps - that's no longer our job.
6031 * input.h (line_table): New variable.
6032 * toplev.c (line_table): Declare variable.
6033 (general_init): Initialize line_table.
6034 * c-opts.c (c_common_init_options): Pass line_table to
6035 cpp_create_reader.
6036 * fix-header.c (read_scan_file): New local variable line_table.
6037 Initialize, and pass it to cpp_create_reader.
6038 * Makefile.in (LIBS, LIBDEPS): Add libcpp.a.
6039 (C_AND_OBJC_OBJS, fix-header): Remove redundant libcpp.a.
6040
6041 2004-01-19 Per Bothner <per@bothner.com>
6042
6043 Implement a cache for linemap_lookup.
6044 * line-map.h (struct_line_maps): Add cache field.
6045 * line-map.c (linemap_init): Zero cache field.
6046 (linemap_add): Set cache field to offset of newly allocated map.
6047 (linemap_lookup): Use and set cache field.
6048
6049 2004-01-20 Kaz Kojima <kkojima@gcc.gnu.org>
6050
6051 PR optimization/13567
6052 * cse.c (cse_basic_block): Call cse_insn with a non-null
6053 libcall_insn for the last SET insn of a no-confilict block.
6054
6055 2004-01-20 Kelley Cook <kcook@gcc.gnu.org>
6056
6057 * Makefile.in (target_noncanonical, program_transform_name): Use
6058 immediate define instead of deferred.
6059 (GCC_INSTALL_NAME, GCC_TARGET_INSTALL_NAME, CPP_INSTALL_NAME,
6060 PROTOIZE_INSTALL_NAME, UNPROTOIZE_INSTALL_NAME, GCOV_INSTALL_NAME,
6061 GCCBUG_INSTALL_NAME): Define via a immediate $(shell) instead of
6062 deferred backquote.
6063
6064 2004-01-20 Joseph S. Myers <jsm@polyomino.org.uk>
6065
6066 * c-decl.c (c_init_decl_processing): Set pedantic_lvalues to
6067 true unconditionally.
6068 * c-typeck.c (unary_complex_lvalue, pedantic_lvalue_warning):
6069 Remove.
6070 (build_unary_op, build_modify_expr): Don't handle extended
6071 lvalues.
6072 (build_component_ref, build_conditional_expr): Call non_lvalue
6073 instead of pedantic_non_lvalue.
6074 (build_c_cast): Don't condition use of non_lvalue on pedantic.
6075 * fold-const.c (fold): Don't check pedantic directly for
6076 COMPOUND_EXPR. Ensure that results for COMPOUND_EXPR are
6077 passed to pedantic_non_lvalue.
6078 * doc/extend.texi: Remove documentation of extended lvalues.
6079
6080 2004-01-19 Roger Sayle <roger@eyesopen.com>
6081
6082 PR optimization/5263
6083 * simplify-rtx.c (associative_constant_p): Delete.
6084 (simplify_associative_operation): Rewrite to linearize terms, and
6085 attempt to simplify new term against both left and right subterms.
6086 (simplify_binary_operation): Call swap_commutative_operands_p on
6087 op0 and op1, not trueop0 and trueop1. Move the initialization of
6088 trueop0 and trueop1 down to where first needed.
6089 (simplify_relational_operation): Likewise.
6090 * rtlanal.c (commutative_operand_precedence): Also order constant
6091 operands using avoid_constant_pool_reference.
6092
6093 2004-01-19 Richard Henderson <rth@redhat.com>
6094
6095 * config/alpha/alpha.c (aligned_memory_operand): Check MEM_ALIGN,
6096 don't check memory mode.
6097 (unaligned_memory_operand): Likewise.
6098 (reload_inqi, reload_inhi, reload_outqi, reload_outhi): Don't
6099 abort for op0 not MEM.
6100
6101 * config/alpha/alpha.c (alpha_expand_mov_nobwx): If the destination
6102 is not a reg, copy to a scratch first.
6103 (aligned_loadqi, aligned_loadhi, unaligned_loadqi, unaligned_loadhi,
6104 unaligned_loadqi_le, unaligned_loadqi_be, unaligned_loadhi_le,
6105 unaligned_loadhi_be): Expect op0 in DImode; don't SUBREG.
6106 (reload_inqi, reload_inhi): Fix mode of op0.
6107 (reload_inqi_help, reload_inhi_help, reload_outqi_help,
6108 reload_outhi_help): Likewise. Use define_insn_and_split.
6109
6110 * config/alpha/alpha.md (call peepholes): Check for REG_NORETURN
6111 as well as $29 dead.
6112
6113 2004-01-19 Eric Botcazou <ebotcazou@libertysurf.fr>
6114
6115 * config/sparc/sol2.h (ASM_DECLARE_OBJECT_NAME): New. Emit
6116 "tls_object" for thread-local objects.
6117 * config/sparc/sparc.c (sparc_elf_asm_named_section): Emit
6118 "#tls" for thread-local sections.
6119 * configure.ac (thread-local checks): Specify --fatal-warnings in
6120 every binutils-specific checks. For sparc*-*-*, test whether the
6121 OS is Solaris and the tools are native and act accordingly.
6122 * configure: Rebuild.
6123
6124 2004-01-19 Jeff Law <law@redhat.com>
6125
6126 * contrib.texi: Update Paolo Carlini's entry. New entries for
6127 Jerry Quinn and Petur Runolfsson.
6128
6129 2004-01-19 Roger Sayle <roger@eyesopen.com>
6130
6131 * config/i386/i386.md (*movhi_1, *movqi_1): When optimizing for
6132 size, don't use the larger zero-extending loads.
6133
6134 2004-01-19 Richard Henderson <rth@redhat.com>
6135
6136 * alpha.h (HARD_REGNO_MODE_OK): Disallow SImode in FP regs.
6137 * alpha.md (UNSPEC_NT_LDA): Remove.
6138 (UNSPEC_CVTLQ, cvtlq): New.
6139 (extendsidi2_1): Rename from extendsidi2_nofix; remove f/f.
6140 (extendsidi2_fix): Remove.
6141 (extendsidi2 splitter): Use cvtlq.
6142 (extendsidi2 fp peepholes): Remove.
6143 (cvtql): Use SFmode instead of SImode.
6144 (fix_trunc?fsi): Update to match.
6145 (floatsisf2_ieee, floatsisf2, floatsidf2_ieee, floatsidf2): New.
6146 (movsi): Rename from movsi_nofix, remove f alternatives.
6147 (movsi_nt_vms): Similarly.
6148 (movsi_fix, movsi_nt_vms_fix): Remove.
6149 (nt_lda): Remove.
6150 * alpha.c (alpha_expand_prologue): Use adddi3, not nt_lda.
6151
6152 2004-01-19 Jan Hubicka <jh@suse.cz>
6153
6154 * cgraph.c (cgraph_remove_node): Fix removal from linked list.
6155 * cgraphunit.c (cgraph_finalize_compilation_unit): Clear next_needed
6156 list.
6157 (cgraph_remove_unreachable_nodes): New function
6158 (cgraph_decide_inlining_of_small_function): Fix pasto.
6159 (cgraph_decide_inlining_incrementally): Fix pasto.
6160 (cgrpah_decide_inlining): Likewise; remove unreachable nodes.
6161
6162 2004-01-19 Steven Bosscher <stevenb@suse.de>
6163
6164 * gengtype.c (header_file): Make it static.
6165 (write_types_process_field, write_enum_defn): Minor whitespace fixes.
6166 * gengtype.h (header_file): No longer extern.
6167
6168 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
6169
6170 * defaults.h (CASE_VECTOR_PC_RELATIVE): Provide the default.
6171 * expr.c (CASE_VECTOR_PC_RELATIVE): Remove.
6172 * stmt.c (CASE_VECTOR_PC_RELATIVE): Likewise.
6173
6174 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
6175
6176 * stmt.c (HAVE_casesi): Define it not already defined.
6177 (HAVE_tablejump): Likewise.
6178 (expand_end_case_type): Resort to the binary tree method if
6179 neither casesi or tablejump is available.
6180
6181 2004-01-18 Daniel Jacobowitz <drow@mvista.com>
6182
6183 * final.c (final_scan_insn): Make non-static again.
6184 * output.h (final_scan_insn): Re-add prototype.
6185 * config/arc/arc.c (arc_output_function_epilogue): Add NULL
6186 to final_scan_insn call.
6187 * config/cris/cris.c (cris_target_asm_function_epilogue): Likewise.
6188 * config/mips/mips.c (mips_output_conditional_branch): Likewise.
6189 * config/pa/pa.c (output_lbranch, output_call): Likewise.
6190 * config/sh/sh.c (print_slot): Likewise.
6191 * config/sparc/sparc.c (sparc_nonflat_function_epilogue): Likewise.
6192 (output_sibcall, sparc_flat_function_epilogue): Likewise.
6193
6194 2004-01-18 Jan Hubicka <jh@suse.cz>
6195
6196 * basic-block.h (try_redirect_by_replacing_jump): Declare.
6197 * cfgcleanup.c (try_optimize_cfg): Use it.
6198 * cfgrtl.c (try_redirect_by_replacing_jump): Export.
6199 (rtl_redirect_edge_and_branch, cfg_layout_redirect_edge_and_branch):
6200 Kill hack.
6201 (cfg_layout_merge_blocks): Use try_redirect_by_replacing_jump.
6202
6203 Revert:
6204 2004-01-16 Geoffrey Keating <geoffk@apple.com>
6205
6206 * cfgrtl.c (try_redirect_by_replacing_jump): Optimize tablejumps
6207 even after reload, just don't remove the actual jump tables.
6208
6209 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
6210
6211 * config/rs6000/rs6000.h (STRICT_ARGUMENT_NAMING): Remove.
6212
6213 2004-01-18 Kazu Hirata <kazu@cs.umass.edu>
6214
6215 * defaults.h (ASM_OUTPUT_ADDR_VEC_ELT): Fix the computation of
6216 the size of a pointer in bytes.
6217
6218 2004-01-18 Roger Sayle <roger@eyesopen.com>
6219
6220 * builtins.c (expand_builtin_expect_jump): Fix thinko of reusing
6221 live "next" variable, which could lead to an infinite loop.
6222
6223 2004-01-18 Andrew Pinski <pinskia@physics.uc.edu>
6224
6225 * config/rs6000/altivec.h: Wrap C++ functions in extern "C++"
6226 block.
6227
6228 * config/rs6000/rs6000.c (rs6000_special_round_type_align):
6229 Check for NULL in the chain and remove repeated code.
6230
6231 2004-01-18 Jan Hubicka <jh@suse.cz>
6232
6233 * coverage.c (checksum_string): Rename to ...
6234 (coverage_checksum_string): ... this one, Use crc32_string; recognize
6235 names containing random number and zero the number out in order to get
6236 match.
6237
6238 2004-01-18 Richard Sandiford <rsandifo@redhat.com>
6239
6240 * config/mips/mips.c (mips_got_alias_set): Mark for PCH.
6241
6242 2004-01-18 Joseph S. Myers <jsm@polyomino.org.uk>
6243
6244 * doc/c-tree.texi, doc/cpp.texi, doc/extend.texi,
6245 doc/frontends.texi, doc/gcov.texi, doc/gty.texi, doc/install.texi,
6246 doc/invoke.texi, doc/libgcc.texi, doc/md.texi, doc/rtl.texi,
6247 doc/sourcebuild.texi, doc/standards.texi, doc/tm.texi,
6248 doc/trouble.texi: Remove trailing whitespace.
6249
6250 2004-01-18 Richard Sandiford <rsandifo@redhat.com>
6251
6252 PR target/7618
6253 * config/mips/mips.c: Include cfglayout.h.
6254 (TARGET_ASM_OUTPUT_MI_THUNK, TARGET_ASM_CAN_OUTPUT_MI_THUNK): Define.
6255 (mips_unspec_offset_high): Add temporary register argument.
6256 (mips_load_call_address): New function, split out from...
6257 (mips_expand_call): ...here.
6258 (mips_output_cplocal): New function.
6259 (mips_output_function_prologue, mips_output_function_epilogue): Use it.
6260 (mips_emit_loadgp): New function, split out from...
6261 (mips_expand_prologue): ...here.
6262 (mips_output_mi_thunk): New function.
6263
6264 2004-01-17 Bernardo Innocenti <bernie@develer.com>
6265
6266 * longlong.h (mc68020, __mc68030__, mc68030, __mc68040__, mc68040,
6267 mcpu32): Remove redundant checks for implied target predefines.
6268
6269 2004-1-17 Andrew Pinski <pinskia@physics.uc.edu>
6270
6271 * config/rs6000/rs6000.c (rs6000_special_round_type_align):
6272 Return type is unsigned int not int.
6273 * config/rs6000/rs6000-protos.h (rs6000_special_round_type_align):
6274 Likewise.
6275
6276 2004-01-18 Joseph S. Myers <jsm@polyomino.org.uk>
6277
6278 * doc/contrib.texi, doc/cppenv.texi, doc/extend.texi,
6279 doc/install.texi, doc/invoke.texi, doc/tm.texi: Consistently use
6280 "GNU/Linux" and "Microsoft Windows" terminology.
6281
6282 2004-01-18 Joseph S. Myers <jsm@polyomino.org.uk>
6283
6284 * doc/c-tree.texi, doc/compat.texi, doc/cpp.texi,
6285 doc/cppopts.texi, doc/extend.texi, doc/install.texi,
6286 doc/interface.texi, doc/invoke.texi, doc/libgcc.texi, doc/md.texi,
6287 doc/objc.texi, doc/rtl.texi, doc/tm.texi, doc/trouble.texi: Use
6288 @smallexample instead of @example.
6289
6290 2004-01-17 Ziemowit Laski <zlaski@apple.com>
6291
6292 * objc/objc-act.c (build_objc_method_call): Use target
6293 hooks instead of macros to determine if ..._stret
6294 dispatchers should be used (NeXT runtime only).
6295
6296 2004-01-17 Roger Sayle <roger@eyesopen.com>
6297
6298 * builtins.c (expand_builtin_expect_jump): Fix mistake in my
6299 last patch. Use XEXP (x, 0) to get a LABEL_REF's CODE_LABEL.
6300
6301 2004-01-17 Daniel Jacobowitz <drow@mvista.com>
6302
6303 * rtl.h (emit_insn_before_sameloc, emit_jump_insn_before_sameloc)
6304 (emit_call_insn_before_sameloc, emit_insn_after_sameloc)
6305 (emit_jump_insn_after_sameloc, emit_call_insn_after_sameloc): New
6306 macros.
6307 * reload1.c (emit_reload_insns): Use them.
6308 * emit-rtl.c (emit_insn_before_sameloc, emit_insn_after_sameloc)
6309 (emit_jump_insn_after_sameloc, emit_call_insn_after_sameloc): Check
6310 for NULL PATTERN.
6311
6312 2004-01-17 Daniel Jacobowitz <drow@mvista.com>
6313
6314 * final.c (SEEN_BB, SEEN_NOTE, SEEN_EMITTED): Define.
6315 (final_scan_insn): Update to take an additional SEEN argument. Emit
6316 a line note after the prologue. Make static.
6317 (line_note_exists): Remove.
6318 (final): Don't initialize line_note_exists. Update call to
6319 final_scan_insn.
6320 * output.h (final_scan_insn): Remove prologue.
6321 * function.c (set_insn_locators): Update comment.
6322 (thread_prologue_and_epilogue_insns): Add a comment.
6323
6324 2004-01-17 Andrew Pinski <pinskia@physics.uc.edu>
6325
6326 PR target/10781
6327 * config/rs6000/rs6000-protos.h (rs6000_special_round_type_align):
6328 Prototype.
6329 * config/rs6000/rs6000.c (rs6000_special_round_type_align):
6330 New function.
6331 * config/rs6000/linux64.h (ROUND_TYPE_ALIGN): Use it.
6332 * config/rs6000/aix.h (ROUND_TYPE_ALIGN): Likewise.
6333 * config/rs6000/darwin.h (ROUND_TYPE_ALIGN): Likewise.
6334
6335 2004-01-17 Jan Hubicka <jh@suse.cz>
6336
6337 * toplev.c (rest_of_handle_reorder_blocks): Fix pasto in previous
6338 commit.
6339
6340 * toplev.c (HAVE_conditional_execution): Provide default.
6341 (rest_of_handle_reorder_blocks): For conditional_execution target
6342 update liveness once after all transformations
6343 (rest_of_compilation): Do crossjumping before ce3.
6344
6345 2004-01-17 Geoffrey Keating <geoffk@apple.com>
6346
6347 * alias.c (new_alias_set): Mark last_alias_set for PCH.
6348 (get_varargs_alias_set): Rename 'set' to 'varargs_set' and mark it
6349 for PCH.
6350 (get_frame_alias_set): Likewise, except rename it to 'frame_set'.
6351 * config/rs6000/rs6000.c (rs6000_sr_alias_set): Mark for PCH.
6352 (get_TOC_alias_set): Mark 'set' for PCH.
6353
6354 2004-01-16 Geoffrey Keating <geoffk@apple.com>
6355
6356 * cfgrtl.c (try_redirect_by_replacing_jump): Optimize tablejumps
6357 even after reload, just don't remove the actual jump tables.
6358
6359 2004-01-17 J. Brobecker <brobecker@gnat.com>
6360
6361 * dwarf2out.c (is_subrange_type): Renamed from is_ada_subrange_type().
6362 Remove checks for is_ada() and TREE_UNSIGNED.
6363 (subrange_type_die): Emit a byte_size attribute if the subrange
6364 type size is different from the base type size.
6365 (modified_type_die): Replace call to is_ada_subrange_type() by
6366 call to is_subrange_type().
6367
6368 2004-01-16 Andrew Pinski <pinskia@physics.uc.edu>
6369
6370 * config/sh/sh.c: Include ggc.h.
6371
6372 2004-01-16 Geoffrey Keating <geoffk@apple.com>
6373
6374 * Makefile.in (MD5_H): New.
6375 (fold-const.o): Depend on md5.h.
6376 (dwarf2out.o): Likewise.
6377 (cppfiles.o): Likewise.
6378 * cppfiles.c: Include md5.h.
6379 (should_stack_file): Check against list read from PCH file.
6380 (struct pchf_data): New.
6381 (pchf): New variable.
6382 (struct pchf_adder_info): New.
6383 (pchf_adder): New.
6384 (pchf_save_compare): New.
6385 (_cpp_save_file_entries): New.
6386 (_cpp_read_file_entries): New.
6387 (struct pchf_compare_data): New.
6388 (pchf_compare): New.
6389 (check_file_against_entries): New.
6390 * cpphash.h (_cpp_save_file_entries): Prototype.
6391 (_cpp_read_file_entries): Prototype.
6392 * cpppch.c (cpp_write_pch_state): Write the list of headers.
6393 (cpp_read_state): Read the list of headers.
6394
6395 2004-01-17 Jan Hubicka <jh@suse.cz>
6396
6397 * c-common.c (c_estimate_num_insns_1): Handle builtin_constant_p and
6398 builtin_expect specially.
6399 * params.def (PARAM_MAX_INLINE_INSNS_AUTO): Set to 100.
6400 (PARAM_LARGE_FUNCTION_INSNS): Set to 3000.
6401 * invoke.texi (max-inline-insns-single): Set to 100.
6402 (large-function-insns): Set to 3000.
6403
6404 2004-01-16 Eric Christopher <echristo@redhat.com>
6405 Chandrakala Chavva <cchavva@redhat.com>
6406
6407 * cppcharset.c (one_iso88591_to_utf8): New function.
6408 (convert_iso88591_utf8): Ditto. Use.
6409 (conversion_tab): Use.
6410 (_cpp_input_to_utf8): New function.
6411 (_cpp_init_iconv_buffer): Ditto.
6412 (_cpp_close_iconv_buffer): Ditto.
6413 * cpphash.h: Prototype new functions.
6414 (cpp_buffer): Add input_cset_desc.
6415 * cppinit.c: Add input_charset default.
6416 * cpplib.c (cpp_push_buffer): Support init and
6417 close of iconv.
6418 * cpplib.h (cpp_options): Add input_charset.
6419
6420 2004-01-16 Kazu Hirata <kazu@cs.umass.edu>
6421
6422 * system.h (ASM_OUTPUT_SECTION_NAME): Poison.
6423 * config/alpha/unicosmk.h: Remove a commented-out definition
6424 of ASM_OUTPUT_SECTION_NAME.
6425 * config/stormy16/stormy16.h: Likewise.
6426
6427 2004-01-16 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
6428
6429 * fixinc/inclhack.def (alpha___extern_prefix): Renamed to ...
6430 (alpha___extern_prefix_sys_stat): ... this.
6431 Apply to <sys/mount.h>, too.
6432 Tweak to match more variations.
6433 * fixinc/tests/base/sys/stat.h: Adapt for new hackname.
6434
6435 * fixinc/inclhack.def (alpha___extern_prefix,
6436 alpha___extern_prefix_standards): New hacks to obey
6437 __PRAGMA_EXTERN_PREFIX.
6438 * fixinc/tests/base/testing.h [ALPHA___EXTERN_PREFIX_CHECK]: New
6439 test.
6440 * fixinc/tests/base/standards.h: Likewise.
6441
6442 * fixincl/inclhack.def (alpha_pthread): Tweak to match more
6443 variations.
6444 New testcase.
6445 * fixinc/tests/base/pthread.h: Handle it.
6446
6447 * fixincl/inclhack.def (bad_lval): Sort file list.
6448 Add many missing files up to Tru64 UNIX V5.1B.
6449 * gcc/fixinc/tests/base/libgen.h: Renamed to ...
6450 * gcc/fixinc/tests/base/dirent.h: ... this to match new file list
6451 order.
6452
6453 * fixinc/fixincl.x: Regenerate.
6454
6455 2004-01-16 Mark Mitchell <mark@codesourcery.com>
6456
6457 * version.c (version_string): Change to 3.5.0.
6458 * doc/include/gcc-common.texi (version-GCC): Likewise.
6459
6460 2004-01-16 Jan Hubicka <jh@suse.cz>
6461
6462 * i386.md (load_tp_di): Fix pasto.
6463
6464 PR opt/13608
6465 * i386.c (ix86_compute_frame_layout): Fix for alloca on leaf function.
6466
6467 * c-pretty-print.c (pp_c_type_cast, pp_c_abstract_declarator,
6468 pp_c_character_constant, pp_c_floating_constant,
6469 pp_c_additive_expression, pp_c_shift_expression,
6470 pp_c_equality_expression, pp_c_and_expression,
6471 pp_c_exclusive_or_expression, pp_c_inclusive_or_expression,
6472 pp_c_logical_and_expression): Remove inline modifier.
6473 * dwarf2out.c (get_AT): Likewise.
6474 * et-forest.c (et_splay): Likewise.
6475 * ra.h (ra_alloc, ra_calloc): Likewise
6476
6477 2004-01-16 Kazu Hirata <kazu@cs.umass.edu>
6478
6479 * config/frv/frv-protos.h: Fix comment formatting.
6480 * config/frv/frv.c: Likewise.
6481 * config/frv/frv.h: Likewise.
6482 * config/frv/frv.md: Likewise.
6483 * config/frv/frvbegin.c: Likewise.
6484 * config/frv/frvend.c: Likewise.
6485
6486 2004-01-16 Kazu Hirata <kazu@cs.umass.edu>
6487
6488 * system.h (LINKER_DOES_NOT_WORK_WITH_DWARF2): Poison.
6489 * doc/tm.texi (PREFERRED_DEBUGGING_TYPE): Don't mention
6490 LINKER_DOES_NOT_WORK_WITH_DWARF2.
6491 (LINKER_DOES_NOT_WORK_WITH_DWARF2): Remove.
6492
6493 2004-01-16 J"orn Rennecke <joern.rennecke@superh.com>
6494
6495 PR 11864
6496 * postreload.c (reload_cse_simplify_operands): Don't remove
6497 implicit extension from LOAD_EXTEND_OP.
6498
6499 2004-01-16 Jan Hubicka <jh@suse.cz>
6500
6501 PR opt/11350
6502 * cfgcleanup.c (try_optimize_cfg): Suppress tablejump removal
6503 after reload.
6504 * cfgrtl.c (rtl_can_merge_blocks, cfglayout_can_merge_blocks,
6505 rtl_try_redirect_by_replacing_branch): Likewise.
6506
6507 2004-01-15 Geoffrey Keating <geoffk@apple.com>
6508
6509 PR pch/13689
6510 * alias.c (struct alias_set_entry): Mark for GC.
6511 (alias_sets): Make static, mark for GC.
6512 (record_alias_subset): Use GC to allocate alias structures.
6513 * varray.c (element): Make generic varrays GCed.
6514
6515 PR pch/13361
6516 * c-typeck.c (constructor_asmspec): Delete.
6517 (struct initializer_stack): Delete field 'asmspec'.
6518 (start_init): Delete saving of asmspec.
6519 (finish_init): Don't update constructor_asmspec.
6520 * dwarf2out.c (rtl_for_decl_location): Duplicate string from tree.
6521 * stmt.c (expand_asm): Duplicate strings from tree.
6522 (expand_asm_operands): Likewise.
6523 * tree.c (tree_size): Update computation of size of STRING_CST.
6524 (make_node): Don't make STRING_CST nodes.
6525 (build_string): Allocate string with tree node.
6526 * tree.def (STRING_CST): Update comment.
6527 * tree.h (TREE_STRING_POINTER): Adjust for change to STRING_CST.
6528 (tree_string): Place contents of string in tree node.
6529 * config/sh/sh.c (sh_handle_sp_switch_attribute): Duplicate string
6530 from tree.
6531
6532 * config/rs6000/rs6000.c (rs6000_va_arg): No need to special-case
6533 altivec operands.
6534
6535 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
6536
6537 * c-common.h: Fix comment formatting.
6538 * c-cppbuiltin.c: Likewise.
6539 * c-pragma.c: Likewise.
6540 * calls.c: Likewise.
6541 * collect2.c: Likewise.
6542 * cppcharset.c: Likewise.
6543 * cpptrad.c: Likewise.
6544 * dbxout.c: Likewise.
6545 * defaults.h: Likewise.
6546 * dwarf2out.c: Likewise.
6547 * fold-const.c: Likewise.
6548 * genautomata.c: Likewise.
6549 * genconditions.c: Likewise.
6550 * genflags.c: Likewise.
6551 * gengtype.c: Likewise.
6552 * integrate.c: Likewise.
6553 * loop.c: Likewise.
6554 * predict.c: Likewise.
6555 * sdbout.c: Likewise.
6556
6557 2004-01-15 Zack Weinberg <zack@codesourcery.com>
6558
6559 * config/ia64/ia64.md (*movti_internal): C output template
6560 extracted to ia64.c.
6561 (*movti_internal_reg): Delete.
6562 (reload_inti, reload_outti): Use the correct mode on operand 2
6563 in the first place, don't fix it up in the output template.
6564 (movtf, reload_ointf, reload_outtf): New expanders.
6565 (*movtf_internal): New define_insn_and_split.
6566 * config/ia64/ia64.c (ia64_split_timode): Rename to ia64_split_tmode;
6567 make static; do not hand TFmode CONST_DOUBLEs to split_double.
6568 (ia64_split_tmode_move): New function, body mostly pulled
6569 from ia64.md:*movti_internal.
6570 (ia64_function_arg_words): New function, extracted common
6571 logic from ia64_function_arg et seq.
6572 (ia64_function_arg_offset): Likewise. Handle correctly the
6573 case of a scalar quantity 16 bytes wide with only 8-byte alignment.
6574 (ia64_function_arg, ia64_function_arg_partial_nregs)
6575 (ia64_function_arg_advance): Use ia64_function_arg_words and
6576 ia64_function_arg_offset.
6577 (ia64_function_value): TCmode does not go in float regs.
6578 (ia64_secondary_reload_class): Also handle TFmode.
6579 * config/ia64/ia64-protos.h: Remove prototype for
6580 ia64_split_timode; add prototype for ia64_split_tmode_move.
6581
6582 2004-01-15 Kelley Cook <kcook@gcc.gnu.org>
6583
6584 * Makefile.in (MAINT): Make it an immediate assignment.
6585
6586 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
6587
6588 * config/m32r/m32r.md: Remove useless calls to gen_lowpart.
6589
6590 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
6591
6592 * config/h8300/coff.h: Replace Hitachi with Renesas.
6593 * config/h8300/elf.h: Likewise.
6594 * config/h8300/h8300-protos.h: Likewise.
6595 * config/h8300/h8300.c: Likewise.
6596 * config/h8300/h8300.h: Likewise.
6597 * config/h8300/h8300.md: Likewise.
6598 * config/h8300/lib1funcs.asm: Likewise.
6599
6600 2004-01-15 Andrew Pinski <apinski@apple.com>
6601
6602 * config/rs6000/rs6000.c (uses_TOC): Wrap #if TARGET_ELF
6603 around it.
6604
6605 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
6606
6607 * config/h8300/h8300.c (h8300_return_in_memory): New.
6608 (TARGET_STRUCT_VALUE_RTX): Likewise.
6609 (TARGET_RETURN_IN_MEMORY): Likewise.
6610 * config/h8300/h8300.h (STRUCT_VALUE): Remove.
6611 (RETURN_IN_MEMORY): Likewise.
6612
6613 2004-01-15 Richard Earnshaw <rearnsha@arm.com>
6614
6615 PR optimization/13375
6616 * gcse.c (handle_avail_expr): Just return if the source is not a
6617 single set.
6618
6619 2004-01-15 Richard Earnshaw <rearnsha@arm.com>
6620 Daniel Jacobowitz <drow@mvista.com>
6621
6622 * arm/lib1funcs.asm (ARM_FUNC_START): Correct interworking case.
6623 (EQUIV): Define.
6624 (ARM_FUNC_ALIAS): New macro.
6625 * arm/ieee754-df.S (gedf2, ledf2, nedf2, eqdf2): Use it.
6626 * arm/ieee754-sf.S (gesf2, lesf2, nesf2, eqsf2): Use it.
6627
6628 2004-01-15 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
6629
6630 PR optimization/12372
6631 * calls.c (expand_call): Add call_fusage data for stack arguments in
6632 constant calls.
6633
6634 2004-01-15 Alan Modra <amodra@bigpond.net.au>
6635
6636 * config/rs6000/rs6000.c (uses_TOC): Correct comment. Make static.
6637 (rs6000_elf_declare_function_name): Formatting.
6638 * config/rs6000/rs6000-protos.h (uses_TOC): Remove declaration.
6639
6640 2004-01-15 Jan Hubicka <jh@suse.cz>
6641
6642 PR bootstrap/13692
6643 * sched-deps.c (sched_analyze_1, sched_analyze_2): Fix thinko in
6644 previous patch.
6645
6646 2004-01-15 Richard Henderson <rth@redhat.com>
6647
6648 * config/alpha/alpha.h (REG_ALLOC_ORDER): Reorder fp regs after
6649 integer regs of the same call-savedness.
6650
6651 2004-01-15 Andreas Schwab <schwab@suse.de>
6652
6653 PR bootstrap/13562
6654 * config/m68k/m68k.c (output_move_const_into_data_reg): Clear cc
6655 status for NOTB/NOTW/NEGW methods.
6656
6657 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
6658
6659 * doc/invoke.texi: Update dump file names. Fix a typo.
6660
6661 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
6662
6663 * builtins.c (expand_builtin_va_end): Don't use
6664 EXPAND_BUILTIN_VA_END.
6665 * system.h (EXPAND_BUILTIN_VA_END): Poison.
6666 * config/d30v/d30v.h: Remove a commented-out definition of
6667 EXPAND_BUILTIN_VA_END.
6668 * config/stormy16/stormy16.h: Likewise.
6669
6670 2004-01-15 Kazu Hirata <kazu@cs.umass.edu>
6671
6672 * system.h (STRUCT_VALUE_INCOMING_REGNUM): Poison.
6673 * targhooks.c (default_struct_value_rtx): Don't use
6674 STRUCT_VALUE_INCOMING_REGNUM.
6675
6676 2004-01-15 Kelley Cook <kcook@gcc.gnu.org>
6677
6678 PR bootstrap/12744
6679 * configure.in: Revamp enable-generated-files-in-srcdir rule to define
6680 GENINSRC and not parsedir. Define srcextra as a langhook.
6681 * configure: Regenerate.
6682 * Makefile.in: Suppress default .l.c rule. Don't substitute
6683 parsedir and delete all references throughout. Conditionally define
6684 rule for srcextra dependent on GENINSRC.
6685 (stmp-docobjdir): Delete.
6686 (c-parse.o, gengtype-lex.o, gengtype-yacc.o): Use implicit build rule.
6687 (srcextra): Copy c-parse.y, c-parse.c, gengtype-lex.c, gengtype-yacc.c,
6688 and gengtype-yacc.h back to source directory.
6689 (maintainer-clean): Delete all parse files in source directory.
6690 (distclean): Delete generated files.
6691
6692 * objc/Make-lang.in (objc-parse.o): Use implicit build rule.
6693 (objc-parse.c, objc-parse.y): Don't use parsedir.
6694 (objc.srcextra): Copy objc-parse.y and objc-parse.c back to source
6695 directory if requested.
6696 (po-generated): Don't use parsedir.
6697 (objc.maintainer-clean): Delete above files from source directory.
6698
6699 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
6700
6701 * doc/tm.texi (FUNCTION_VALUE): Fix a typo.
6702
6703 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
6704
6705 * doc/tm.texi: Replace RETURN_IN_MEMORY with
6706 TARGET_RETURN_IN_MEMORY.
6707
6708 2004-01-15 Jan Hubicka <jh@suse.cz>
6709
6710 * builtins.c (std_expand_builtin_va_arg): Align operand when needed.
6711 * i386.c (init_cumulative_args): Set warn_sse; fix handling of variadic
6712 functions accepting SSE arguments
6713 (function_arg): Warn only when asked to warn.
6714 * i386.h (ix86_args): Add warn_sse/warn_mmx fiels.
6715
6716 2004-01-14 Joseph S. Myers <jsm@polyomino.org.uk>
6717
6718 * c-parse.in (stmts_and_decls): Make label at end of compound
6719 statement a hard error.
6720
6721 2004-01-14 Jan Hubicka <jh@suse.cz>
6722
6723 * cgraph.c (create_edge): Use local.redefined_extern_inline.
6724 * cgraph.h (cgraph_local_info): Sort fields by size; add
6725 redefined_extern_inline
6726 (cgraph_global_info): Sort fields by size.
6727 (cgraph_node): Likewise.
6728 * cgraphunit.c (cgraph_finalize_function): Se
6729 local.redefined_extern_inline on redefinition.
6730 (cgraph_analyze_function): Use it; fix formating.
6731
6732 2004-01-14 Jan Hubicka <jh@suse.cz>
6733
6734 PR c++/10776
6735 * sched-deps.c (trye_dependency_cache, anti_dependency_cache,
6736 outptu_dependency_cache, forward_dependency_cahe): Trun to vectors of
6737 bitmaps
6738 (cache_size): New variable
6739 (add_dependence): Update use; canonize early memory locations
6740 (sched_analyze_1): Likewise.
6741 (sched_analyze_2): Likewise.
6742 (init_dependency_caches): Initialize bitmaps.
6743 (free_dependency_caches): Free bitmaps
6744
6745 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
6746
6747 * calls.c: Replace STRICT_ARGUMENT_NAMING in comments with
6748 targetm.calls.strict_argument_naming().
6749 * target.h: Likewise.
6750
6751 2004-01-14 Richard Henderson <rth@redhat.com>
6752
6753 PR debug/13231
6754 * dwarf2out.c (dwarf2out_stack_adjust): Skip prologue and epilogue
6755 instructions.
6756
6757 2004-01-14 Richard Henderson <rth@redhat.com>
6758
6759 PR c++/12491
6760 * except.c (struct eh_region): Add u.fixup.resolved.
6761 (resolve_one_fixup_region): Split out from ...
6762 (resolve_fixup_regions): ... here.
6763
6764 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
6765
6766 * config/mn10300/mn10300.h (STRUCT_VALUE): Change to 0.
6767
6768 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
6769
6770 * config/alpha/alpha.h (STRUCT_VALUE): Remove.
6771 * config/alpha/vms.h (STRUCT_VALUE_REGNUM): Remove #undef.
6772 (STRUCT_VALUE): Remove.
6773
6774 2004-01-14 Steven Bosscher <stevenb@suse.de>
6775
6776 * system.h: Poison PROMOTED_MODE
6777 * integrate.c (expand_inline_function): Don't mention the
6778 PROMOTED_MODE.
6779 * loop.c (update_giv_derive): Same.
6780 * tree.h (DECL_RTL): Same.
6781
6782 2004-01-14 J"orn Rennecke <joern.rennecke@superh.com>
6783
6784 PR target/9365
6785 * sh.c (gen_block_redirect): Add special handling of RETURN.
6786 (gen_far_branch) Don't call gen_stuff_delay_slot if there is no
6787 far branch target (i.e. it's a return).
6788
6789 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
6790
6791 * regrename.c (find_oldest_value_reg): Fix a warning.
6792
6793 2004-01-14 Richard Earnshaw <rearnsha@arm.com>
6794
6795 PR bootstrap/12527
6796 * config.gcc (arm*-*-linux*): Don't include unknown-elf.h in tm_file.
6797 Move linux-gas.h and linux-elf.h before aout.h.
6798 * arm/arm.h (INITIALIZE_TRAMPOLINE): Only define if not already.
6799 * arm/linux-elf.h (SUBTARGET_CPU_DEFAULT): Define.
6800
6801 2004-01-14 Kazu Hirata <kazu@cs.umass.edu>
6802
6803 * config/m32r/m32r.md: Use GEN_INT instead of gen_rtx
6804 (CONST_INT, VOIDmode, ...).
6805
6806 2004-01-14 Richard Earnshaw <rearnsha@arm.com>
6807
6808 * regrename.c (find_oldest_value_reg): If the replacement uses
6809 multiple hard registers, check that all of them are in CLASS.
6810
6811 2004-01-14 Jan Hubicka <jh@suse.cz>
6812
6813 * alias.c (get_alias_set): Initialize alias set to 0 when subset is
6814 impossible.
6815
6816 2004-01-14 Kelley Cook <kcook@gcc.gnu.org>
6817
6818 * Makefile.in: Define MAINT from --enable-maintainer-mode.
6819
6820 2004-01-14 Hartmut Penner <hpenner@de.ibm.com>
6821
6822 * gcc/config/rs6000/rs6000.c (rs6000_stack_info)
6823 Calculate always vrsave_mask if TARGET_ALTIVEC.
6824 (rs6000_emit_prologue): Emit code for vrsave
6825 only if TARGET_ALTIVEC_VRSAVE.
6826 (rs6000_emit_epilogue): Likewise.
6827
6828 2004-01-14 Eric Botcazou <ebotcazou@libertysurf.fr>
6829
6830 * config/sparc/sparc.md (tie_add32): Fix pasto.
6831 (tie_add64): Likewise.
6832
6833 2004-01-14 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
6834
6835 * config/i386/i386.md (*addqi_1_slp): Do not access operands[2].
6836
6837 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
6838
6839 * config/iq2000/iq2000-protos.h: Fix comment formatting.
6840 * config/iq2000/iq2000.c: Likewise.
6841 * config/iq2000/iq2000.md: Likewise.
6842
6843 2004-01-14 J. Brobecker <brobecker@gnat.com>
6844
6845 * dwarf2out.c (is_ada_subrange_type): No longer check the TYPE_NAME.
6846 (subrange_type_die): Add handle for nameless subrange types.
6847
6848 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
6849
6850 * config/h8300/h8300-protos.h: Replace do_movsi with
6851 h8300_expand_movsi.
6852 * config/h8300/h8300.c (do_movsi): Change to
6853 h8300_expand_movsi.
6854 * config/h8300/h8300.md (movsi): Replace do_movsi with
6855 h8300_expand_movsi.
6856 (movsf): Likewise.
6857
6858 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
6859
6860 * config/h8300/h8300.c (dosize): Change to
6861 h8300_emit_stack_adjustment. Update callers.
6862
6863 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
6864
6865 * config/h8300/h8300.md (movstrictqi): Add an alternative with
6866 the source being post_inc. Tighten the predicate for the
6867 destination to register_operand.
6868 (movstricthi): Likewise.
6869
6870 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
6871
6872 * system.h (SHARED_BSS_SECTION_ASM_OP): Poison.
6873 * varasm.c (bss_section): Don't use SHARED_BSS_SECTION_ASM_OP.
6874 * doc/tm.texi (SHARED_BSS_SECTION_ASM_OP): Remove.
6875
6876 2004-01-14 Jan Hubicka <jh@suse.cz>
6877
6878 Partial fix PR c++/12850
6879 * cgraphunit.c (cgraph_finalize_function): Always ggc_collect when
6880 at zero nest level.
6881
6882 2004-01-13 Bernardo Innocenti <bernie@develer.com>
6883
6884 * config/m68k/netbsd-elf.h (REGISTER_NAMES): Add missing "argptr"
6885 pseudo-register.
6886
6887 2004-01-13 Devang Patel <dpatel@apple.com
6888
6889 PR debug/7078
6890 * dbxout.c (dbxout_symbol_name): Emit mangled names for
6891 NAMESPACE_DECL memebers.
6892
6893 2004-01-13 Andrew Pinski <pinskia@physics.uc.edu>
6894
6895 PR c++/12709
6896 * c-common.c (finish_fname_decls): Use the chain only if the
6897 tree is an expr_stmt.
6898
6899 2004-01-13 Vladimir Makarov <vmakarov@redhat.com>
6900
6901 * rtl.def: Add comment about new option in automata_option.
6902
6903 * genautomata.c (PROGRESS_OPTION): New macro.
6904 (progress_flag): New global variable.
6905 (gen_automata_option): Process `progress'.
6906 (transform_insn_regexps, check_unit_distributions_to_automata,
6907 make_automaton, NDFA_to_DFA, build_automaton, create_automata,
6908 expand_automata, write_automata): Print about the progress only if
6909 progress_flag. Remove fflush.
6910 (initiate_automaton_gen): Process command line flag `-progress'.
6911
6912 * doc/md.texi: Describe the new option.
6913
6914 2004-01-13 Zdenek Dvorak <rakdver@atrey.karlin.mff.cuni.cz>
6915
6916 * cfg.c (dump_bb): Dump entry edges.
6917
6918 2004-01-13 Richard Earnshaw <rearnsha@arm.com>
6919
6920 * arm.c (thumb_legitimate_address_p): Only allow constant pool
6921 references from SImode.
6922 * arm.md (thumb_movhi_insn): Don't allow minipool references.
6923
6924 2004-01-13 Kazu Hirata <kazu@cs.umass.edu>
6925
6926 * system.h (TEXT_SECTION): Poison.
6927 * varasm.c (text_section): Don't use TEXT_SECTION.
6928 * config/sh/sh.c (sh_file_start): Fix a comment typo.
6929 * doc/tm.texi (TEXT_SECTION): Remove.
6930
6931 2004-01-13 Ben Elliston <bje@wasabisystems.com>
6932
6933 * doc/rtl.texi (Vector Operations): Remove defunct vec_const item.
6934
6935 2004-01-12 James E Wilson <wilson@specifixinc.com>
6936
6937 * unwind-libunwind.c: Delete.
6938
6939 2004-01-12 Zack Weinberg <zack@codesourcery.com>
6940
6941 PR 13656
6942 * c-decl.c (diagnose_mismatched_decls): Whenever newtype or
6943 oldtype is set, set *newtypep or *oldtypep too. Do not set
6944 them at the very end.
6945 (validate_proto_after_old_defn): Restructure for comprehensibility;
6946 make error messages clearer.
6947
6948 2004-01-12 Zack Weinberg <zack@codesourcery.com>
6949
6950 * varray.h (VARRAY_POP): Add checking variant, aborts on underflow.
6951 (VARRAY_TOP): Use VARRAY_CHECK so the access is bounds-checked.
6952 * varray.c: No need to prototype error.
6953 (varray_check_failed): Wrap long string onto two lines.
6954 (varray_underflow): New function.
6955
6956 2004-01-13 Steven Bosscher <stevenb@suse.de>
6957
6958 PR c++/13376
6959 * function.h (struct function): Kill `name' field.
6960 (current_function_name): Make it an extern function.
6961 * function.c (current_function_name): New function.
6962 * graph.c: Update all uses of current_function_name.
6963 * gcse.c: Likewise.
6964 * config/alpha/alpha.c, config/avr/avr.c, config/c4x/c4x.c,
6965 config/mips/mips.c, config/pdp11/pdp11.c: Likewise.
6966 * config/ip2k/ip2k.c (function_prologue): Use MAIN_NAME_P
6967 instead of a strcmp with "main".
6968
6969 2004-01-13 Jan Hubicka <jh@suse.cz>
6970
6971 * c-decl.c (diagnose_mismatched_decls): Fix warning calls.
6972
6973 * cgraphunit.c (cgraph_optimize_function): Always do
6974 optimize_inline_calls when there is always_inline callee.
6975 (cgraph_decide_inlining): Fix formating.
6976 * tree-inline.c (inlinable_function_p): Do sorry for alwaysinline
6977 functions.
6978 (expand_call_inline): Likewise.
6979 * toplev.h (sorry): Fix prototype.
6980
6981 2004-01-12 Roger Sayle <roger@eyesopen.com>
6982
6983 * builtins.c (expand_builtin_expect_jump): Simplify logic. Handle
6984 conditional jumps that drop through to unconditional jumps or the
6985 end of the sequence.
6986
6987 2004-01-13 Jan Hubicka <jh@suse.cz>
6988
6989 * alias.c (new_alias_set): Construct the alias_set varray.
6990 (init_alias_once): Don't do it here.
6991
6992 2004-01-12 Marc Espie <espie@openbsd.org>
6993
6994 * system.h: handle YYBYACC like YYBISON.
6995
6996 2004-01-12 Jonathan Merriman <jonm@dualitymedia.com>
6997
6998 PR target/10847
6999 * config.gcc: No longer includes conflicting header sparc/sol2.h when
7000 building on sparc64-*-openbsd*.
7001
7002 2004-01-12 Andrew Pinski <pinskia@physics.uc.edu>
7003
7004 PR debug/13539
7005 * dbxout.c (dbxout_type): Protected inheritance is not
7006 private but protected.
7007
7008 2004-01-12 Richard Sandiford <rsandifo@redhat.com>
7009
7010 * config/mips/mips.c (mips_symbolic_constant_p): Revert last patch.
7011
7012 2004-01-12 Kazu Hirata <kazu@cs.umass.edu>
7013
7014 PR optimization/12508.
7015 * combine.c (try_combine): Remove a dead set in a parallel
7016 even if its destination is a subreg.
7017
7018 Revert:
7019 2003-06-03 Kazu Hirata <kazu@cs.umass.edu>
7020 * combine.c (simplify_set): Don't move a subreg in SET_SRC to
7021 SET_DEST if WORD_REGISTER_OPERATIONS is not defined.
7022
7023 2004-01-12 Geoffrey Keating <geoffk@apple.com>
7024
7025 * real.c: Update copyright date.
7026 * emit-rtl.c: Likewise.
7027 * rtl.h: Likewise.
7028 * dwarf2out.c: Likewise.
7029 * config/rs6000/darwin-ldouble.c: Likewise.
7030 * config/rs6000/rs6000.md: Likewise.
7031
7032 2004-01-12 David Edelsohn <edelsohn@gnu.org>
7033
7034 * config/rs6000/rs6000.c (rs6000_init_libfuncs): Add AIX
7035 TFmode to SImode libfuncs.
7036
7037 2004-01-12 Roger Sayle <roger@eyesopen.com>
7038
7039 PR middle-end/11397
7040 * varasm.c (assemble_alias): Remove weak aliases from weak_decls.
7041
7042 2004-01-12 Jan Hubicka <jh@suse.cz>
7043
7044 PR opt/12826
7045 * loop.c (insert_loop_mem): Preffer VOLATILE memory references to be
7046 stored.
7047
7048 PR opt/12863
7049 * cfgcleanup.c (label_is_jump_target_p): Move to...
7050 * rtlanal.c (label_is_jump_target_p): ... here.
7051 * cfgrtl.c (cfg_layout_redirect_edge_and_branch): Fix redirecting of fallthru
7052 edges unified with branch edges.
7053
7054 2004-01-12 Richard Earnshaw <rearnsha@arm.com>
7055
7056 * simplify-rtx.c (simplify_immed_subreg): Correctly extract the
7057 high word of an integral CONST_DOUBLE.
7058
7059 2004-01-12 Paul Brook <paul@codesourcery.com>
7060
7061 * simplify-rtx.c (simplify_plus_minus): Always generate canonical form.
7062
7063 2004-01-12 J"orn Rennecke <joern.rennecke@superh.com>
7064
7065 PR target/13585
7066 * sh-protos.h (check_use_sfunc_addr): Declare.
7067 * sh.c (extract_sfunc_addr, check_use_sfunc_addr): New functions.
7068 * sh.md (use_sfunc_addr): Use check_use_sfunc_addr in insn predicate.
7069
7070 2004-01-12 Jan Hubicka <jh@suse.cz>
7071
7072 * alias.c: Invlude varray.h
7073 (alias_sets): Turn into varray.
7074 (get_alias_set_entry): Use VARRAY; mark inline.
7075 (mems_in_disjoint_alias_sets_p): Mark inline.
7076 (record_alias_subset): Use varray.
7077 (init_alias_once): Initialize varray.
7078 (new_alias_set): Grow array.
7079 * varray.c: Make VARRAY_GENERIC_PTR non GTYized.
7080
7081 2004-01-12 Jan Hubicka <jh@suse.cz>
7082
7083 Partial fix for PR opt/10776 II
7084 * cselib.c: Include params.h
7085 (cselib_invalidate_mem): Limit amount of nonconflicting memory
7086 locations.
7087 * params.def (PARAM_MAX_CSELIB_MEMORY_LOCATIONS): New.
7088 * Makefile.in (cselib.o): Depend on params.h
7089
7090 2004-01-12 Richard Sandiford <rsandifo@redhat.com>
7091
7092 * combine.c (combine_simplify_rtx): Don't pass VOIDmode to
7093 simplify_unary_operation if the operand has a known mode.
7094
7095 2004-01-12 Hartmut Penner <hpenner@de.ibm.com>
7096
7097 PR target/13534
7098 * gcc/config/rs6000/rs6000.c (word_offset_memref_operand): New
7099 predicate to handle 'ld' conform addresses.
7100 * gcc/config/rs6000/rs6000.h (EXTRA_CONSTRAINT): New 'Y'
7101 contraint.
7102 (EXTRA_MEMORY_CONSTRAINT): Tell reload which constraint
7103 are memory contraints.
7104 * gcc/config/rs6000/rs6000-protos.h (word_offset_memref_operand):
7105 New prototype.
7106 * gcc/config/rs6000/rs6000.md (*movdf_hardfloat64):
7107 Change 'o' to 'Y' constraint.
7108 (*movdf_softfloat64): Ditto.
7109
7110 2004-01-12 Bernardo Innocenti <bernie@develer.com>
7111
7112 * gcc/config/m68k/m68k.md: Switch from the "*..." syntax to the
7113 brace-enclosed syntax in all C output statements.
7114
7115 2004-01-12 David Edelsohn <edelsohn@gnu.org>
7116
7117 PR target/13401
7118 * config/rs6000/rs6000.c (rs6000_output_function_epilogue):
7119 Objective-C language type value is 14.
7120
7121 2004-01-12 Markus F.X.J. Oberhumer <markus@oberhumer.com>
7122
7123 PR c/12148
7124 * config/m68k/fpgnulib.c: Fix `-mshort' bugs: Use `long' instead of
7125 `int' in a number of places to make sure we always have a SImode
7126 and not a HImode. Add a 'L' suffix to a number of constants.
7127
7128 2004-01-11 John David Anglin <dave.anglin@nrc-cnrc.gc.ca>
7129
7130 * pa.c: Don't include obstack.h.
7131
7132 * pa.md: Correct constraint in pattern for loading PIC label address.
7133
7134 2004-01-11 Kaz Kojima <kkojima@gcc.gnu.org>
7135
7136 * config/sh/linux.h (ASM_PREFERRED_EH_DATA_FORMAT): Undefine
7137 before defining.
7138
7139 2004-01-11 Steven Bosscher <stevenb@suse.de>
7140
7141 PR fortran/9972
7142 * toplev.c (rest_of_handle_inline): Also consider functions
7143 for deferral if the language is GNU F77.
7144
7145 2004-01-11 Zack Weinberg <zack@codesourcery.com>
7146
7147 * c-decl.c (diagnose_arglist_conflict): Add missing space to
7148 diagnostic messages.
7149
7150 2004-01-11 Jakub Jelinek <jakub@redhat.com>
7151
7152 PR middle-end/13392
7153 * builtins.c (expand_builtin_expect_jump): Handle conditional jumps
7154 to drop through label. Don't fall back to SCC even when conditional
7155 jump has not been found.
7156
7157 2004-01-11 Jan Hubicka <jh@suse.cz>
7158
7159 * invoke.texi: Fix syntax error in previous patch.
7160
7161 Partial fix for PR opt/10776
7162 * Makefile.in (reload.o): Include param.h
7163 * params.def (PARAM_MAX_RELOAD_SEARCH_INSNS): New parameter.
7164 * reload.c: Include params.h.
7165 (find_equiv_reg): Work limiting check.
7166 * invoke.texi: Document.
7167
7168 2004-01-11 Richard Sandiford <rsandifo@redhat.com>
7169
7170 * config/mips/mips.c (mips_symbolic_constant_p): Don't allow
7171 out-of-bounds accesses to string constants. Simplify mips16
7172 case accordingly.
7173
7174 2004-01-11 Richard Sandiford <rsandifo@redhat.com>
7175
7176 PR optimization/13469
7177 * toplev.c (rest_of_compilation): Call purge_all_dead_edges after
7178 reload_cse_regs (-fnon-call-exceptions only).
7179
7180 2004-01-11 Kazu Hirata <kazu@cs.umass.edu>
7181
7182 * config/mcore/lib1.asm: Fix comment formatting.
7183 * config/mcore/mcore-elf.h: Likewise.
7184 * config/mcore/mcore.c: Likewise.
7185 * config/mcore/mcore.h: Likewise.
7186 * config/mcore/mcore.md: Likewise.
7187
7188 2004-01-10 Zack Weinberg <zack@codesourcery.com>
7189
7190 * c-decl.c (duplicate_decls): Break apart into...
7191 (diagnose_arglist_conflict, validate_proto_after_old_defn)
7192 (locate_old_defn, diagnose_mismatched_decls, merge_decls):
7193 ... these new functions. Restructure for comprehensibility.
7194 Remove various archaic special cases. Always report the
7195 location of the previous declaration when a diagnostic is issued.
7196 (redeclaration_error_message): Fold into diagnose_mismatched_decls.
7197 (match_builtin_function_types): Delete unnecessary forward declaration.
7198
7199 2004-01-10 Zack Weinberg <zack@codesourcery.com>
7200
7201 * genautomata.c (make_automaton, NDFA_to_DFA):
7202 Print progress bars with '.' characters instead of '*'.
7203 (build_automaton): Change notes to match.
7204
7205 2004-01-10 Kazu Hirata <kazu@cs.umass.edu>
7206
7207 * config/m32r/m32r.md: Use define_constants for unspec and
7208 unspec_volatile.
7209
7210 2004-01-10 Jan Hubicka <jh@suse.cz>
7211
7212 PR opt/11635
7213 * expr.c (expand_expr_real): More curefully expand union casts.
7214
7215 2004-01-10 Kazu Hirata <kazu@cs.umass.edu>
7216
7217 * config/m32r/m32r.md (flush_icache): Use 1 for
7218 unspec_volatile.
7219
7220 2004-01-10 David Edelsohn <edelsohn@gnu.org>
7221 James E Wilson <wilson@specifixinc.com>
7222
7223 PR debug/12860
7224 * dbxout.c (dbxout_symbol): Remove initialization of
7225 current_sym_code, current_sym_value, and current_sym_addr.
7226 (dbxout_symbol_location): Same.
7227 (dbxout_prepare_symbol): Zero current_sym_code,
7228 current_sym_value, and current_sym_addr.
7229
7230 2004-01-10 Richard Sandiford <rsandifo@redhat.com>
7231
7232 * tree.c (get_unwidened): Reorder conditions so that the null pointer
7233 check is done first.
7234
7235 2004-01-09 Eric Christopher <echristo@redhat.com>
7236
7237 * toplev.c (rest_of_handle_cfg): Add reg_scan pass
7238 if we're running mark_constant_function.
7239
7240 2004-01-09 Jeff Bailey <jbailey@nisa.net>
7241
7242 PR target/12561
7243 * config/t-gnu: Rename SYSTEM_HEADER_DIR to NATIVE_SYSTEM_HEADER_DIR.
7244
7245 2004-01-09 Andrew Pinski <pinskia@physics.uc.edu>
7246
7247 PR debug/11231
7248 * dbxout.c (dbxout_type_fields): Return if any item is
7249 error_mark_node or the type is error_mark_node.
7250
7251 2004-01-09 Geoffrey Keating <geoffk@apple.com>
7252
7253 * config/rs6000/darwin-ldouble.c: Add big comment explaining
7254 exactly what is expected as a 'long double'.
7255 (_xlqadd): When a value to be returned is representable as a
7256 'double', just return it directly, do not construct it using a union.
7257 Also, correct final fixup.
7258 (_xlqmul): Likewise.
7259 (_xlqdiv): Likewise.
7260 * real.c (encode_ibm_extended): Make consistent with darwin-ldouble.c.
7261
7262 * config/rs6000/rs6000.md (fix_trunctfdi2): Delete.
7263
7264 2004-01-09 Richard Henderson <rth@redhat.com>
7265
7266 * recog.c (constrain_operands): Validate mem operands.
7267
7268 2004-01-09 James E Wilson <wilson@specifixinc.com>
7269
7270 * gcc.c (init_spec): Remove -lunwind from shared case.
7271 * conifg/ia64/t-hpux (SHLIB_LINK): Add -lunwind.
7272
7273 2004-01-09 Steve Ellcey <sje@cup.hp.com>
7274
7275 * configure.ac: (gcc_cv_ld_hidden) Set to true for ia64*-*-hpux*.
7276 * configure: Regenerate
7277
7278 2004-01-09 Joseph S. Myers <jsm@polyomino.org.uk>
7279
7280 PR c/11234
7281 * c-typeck.c (build_c_cast): If pedantic, warn for conversions
7282 between function and object pointers.
7283 (digest_init): When comparing a pointer to function type to the
7284 target type, only apply TREE_TYPE once to the pointer to function
7285 type.
7286 * except.c (for_each_eh_label_1): Treat data as a pointer to a
7287 function pointer rather than casting it to a function pointer.
7288 (for_each_eh_label): Update caller.
7289 * recog.h (struct insn_data): Use a struct or union for output.
7290 * genoutput.c (output_insn_data): Update.
7291 * final.c (get_insn_template): Update.
7292
7293 2004-01-09 Mark Mitchell <mark@codesourcery.com>
7294
7295 * expr.h (expand_expr): Make it a macro, not a function.
7296 (expand_expr_real): New function.
7297 * expr.c (store_expr): Adjust logic for deciding whether or not to
7298 copy the value returned by expand_expr.
7299 (expand_expr): Rename to ...
7300 (expand_expr_real): ... this. Add alt_rtl parameter. Adjust
7301 calls to language hooks.
7302 * c-common.h (c_expand_expr): Adjust prototype.
7303 * c-common.c (c_expand_expr): Add alt_rtl parameter.
7304 * langhooks-def.h (lhd_expand_expr): Change prototype.
7305 * langhooks.c (lhd_expand_expr): Add all_rtl parameter.
7306 * langhooks.h (lang_hooks): Change type of expand_expr.
7307 * stmt.c (stmt_status): Add x_last_expr_alt_rtl.
7308 (last_expr_alt_rtl): Likewise.
7309 (expand_expr_stmt_value): Set last_expr_alt_rtl.
7310 (clear_last_expr): Clear it.
7311 (expand_end_stmt_expr): Set RTL_EXPR_ATL_RTL.
7312 (expand_end_bindings): Save and restor last_expr_alt_rtl.
7313 * tree.def (RTL_EXPR): Give it an additional operand.
7314 * tree.h (RTL_EXPR_ALT_RTL): New macro.
7315
7316 2004-01-09 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
7317
7318 * config/m32r/m32r.h (TARGET_CPU_CPP_BUILTINS): Add __m32r__.
7319 * config/m32r/m32r.c (call26_operand): Allow in PIC mode.
7320
7321 2004-01-09 Kazu Hirata <kazu@cs.umass.edu>
7322
7323 PR target/13380.
7324 * config/m32r/m32r.md: Replace (reg:SI 17) with (reg:CC 17)
7325 or (ne:SI (reg:CC 17) (const_int 0)).
7326 Be specific about modes wherever possible.
7327
7328 2004-01-09 Kazu Hirata <kazu@cs.umass.edu>
7329
7330 * config/m32r/m32r.c (m32r_expand_block_move): Call
7331 gen_movestrsi_internal with two more arguments.
7332 (m32r_output_block_move): Adjust operand numbers.
7333 Properly update the source and destination pointers.
7334 * config/m32r/m32r.md (movstrsi_internal): Use 'r' instead of
7335 'r+'. Change the set detinations to match_operand.
7336
7337 2004-01-09 Kazu Hirata <kazu@cs.umass.edu>
7338
7339 * final.c (FIRST_INSN_ADDRESS): Remove.
7340 (shorten_branches): Don't use FIRST_INSN_ADDRESS.
7341 * system.h (FIRST_INSN_ADDRESS): Poison.
7342 * config/avr/avr.h: Remove a comment about FIRST_INSN_ADDRESS.
7343 * config/m32r/m32r-protos.h: Remove the prototype for
7344 m32r_first_insn_address.
7345 * config/m32r/m32r.c (m32r_first_insn_address): Remove.
7346 * config/m32r/m32r.h (FIRST_INSN_ADDRESS): Likewise.
7347 * doc/md.texi (FIRST_INSN_ADDRESS): Likewise.
7348
7349 2004-01-09 J. Brobecker <brobecker@gnat.com>
7350
7351 * dwarf2out.c (gen_enumeration_type_die): Return the DIE that
7352 we just created.
7353 (is_ada_subrange_type): DIEs for enumeration subtypes should be
7354 emitted as subrange types too.
7355 (subrange_type_die): Add handling of enumeration subtypes.
7356
7357 2004-01-08 Richard Henderson <rth@redhat.com>
7358
7359 PR opt/12441
7360 Revert: Sat Mar 30 14:08:55 CET 2002 Jan Hubicka <jh@suse.cz>
7361 * i386.c (aligned_operand): Be prepared for SUBREGed registers.
7362 (ix86_decompose_address): Use REG_P instead of GET_CODE (...) == REG.
7363 (ix86_address_cost): Be prepared for SUBREGed registers.
7364 (legitimate_address_p): Accept SUBREGed registers.
7365
7366 2004-01-08 Kelley Cook <kcook@gcc.gnu.org>
7367
7368 * Makefile.in: Rename configure.in to configure.ac
7369 * doc/sourcebuild.texi: Likewise.
7370 * configure: Regenerate.
7371 * config.in: Regenerate.
7372
7373 2004-01-08 Stuart Hastings <stuart@apple.com>
7374
7375 * config/i386/i386.md: Typos in MMX/SSE immediate shifts.
7376
7377 2004-01-08 Jan Hubicka <jh@suse.cz>
7378
7379 * cgraphunit.c (cgraph_decide_inlining): Fix typo.
7380
7381 2004-01-08 Geoffrey Keating <geoffk@apple.com>
7382
7383 * config/rs6000/rs6000.md (cmptf_internal1): Correct branch offset.
7384 (UNSPEC_FIX_TRUNC_TF): New constant.
7385 (movtf_internal): Make splitter active only when insn is active.
7386 (extenddftf2): Rewrite to properly load zero into low part.
7387 (extenddftf2_internal): New.
7388 (extendsftf2): Rewrite.
7389 (truncdftf2): Correct length.
7390 (floatditf2): Delete.
7391 (fix_trunc_helper): New.
7392 (fix_trunctfdi2): Use fix_trunc_helper.
7393 (fix_trunctfsi2): Likewise.fix_trunc
7394 (fix_trunctfsi2_internal): New.
7395
7396 * config/rs6000/rs6000.c (legitimate_lo_sum_address_p): lo_sum
7397 addresses are legitimate on Darwin even when flag_pic.
7398 (rs6000_legitimize_reload_address) [TARGET_MACHO]: Don't create
7399 non-offsettable addresses for loads of TFmode constants.
7400
7401 2004-01-08 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
7402
7403 * config/m32r/m32r.h (ASM_OUTPUT_ALIGNED_BSS): Actually emit
7404 variables in the appropriate bss section.
7405
7406 2004-01-09 Alan Modra <amodra@bigpond.net.au>
7407
7408 * config/rs6000/linux64.h (SUBSUBTARGET_OVERRIDE_OPTIONS): Ensure
7409 target_flags has MASK_POWERPC64 when -m64.
7410 * config/rs6000/rs6000.c (processor_target_table): Add MASK_POWERPC64
7411 to 620, 630, power3, power4 and rs64a entries.
7412 * config/rs6000/rs6000.h (MASK_64BIT): Expand comment.
7413
7414 2004-01-08 Richard Sandiford <rsandifo@redhat.com>
7415
7416 * simplify-rtx.c (simplify_immed_subreg): Fix construction of
7417 floating-point constants.
7418
7419 2004-01-08 J. Brobecker <brobecker@gnat.com>
7420
7421 * dwarf2out.c (subrange_type_die): Add context_die parameter.
7422 Create the subrange_type DIE using the given context DIE.
7423 (modified_type_die): Update call to subrange_type_die.
7424
7425 2004-01-08 Zack Weinberg <zack@codesourcery.com>
7426
7427 * dwarf2.h, unwind-dw2-fde.h, unwind-pe.h, unwind.h:
7428 Add multiple-include guard.
7429
7430 2004-01-08 Hartmut Penner <hpenner@de.ibm.com>
7431
7432 * gcc/config/rs6000/rs6000.c (easy_vector_constant): Accept
7433 all vector constant loadable by vsplt*.
7434 (output_vec_const_move): Likewise.
7435
7436 2004-01-07 Joseph S. Myers <jsm@polyomino.org.uk>
7437
7438 PR c/6024
7439 * c-typeck.c (comptypes): Only treat enumerated types in the same
7440 translation unit as compatible with each other when they are the
7441 same type.
7442 * doc/extend.texi: Update.
7443
7444 2004-01-07 Joseph S. Myers <jsm@polyomino.org.uk>
7445
7446 PR c/12165
7447 * c-decl.c (grokdeclarator): Take type qualifiers of typedefed
7448 array type from the array element type.
7449
7450 2004-01-07 Alan Modra <amodra@bigpond.net.au>
7451
7452 * config/rs6000/rs6000.c (rs6000_dbx_register_number): New function.
7453 * config/rs6000/rs6000-protos.h (rs6000_dbx_register_number): Declare.
7454 * config/rs6000/rs6000.h (DWARF_FRAME_REGNUM): Define.
7455 (DWARF_REG_TO_UNWIND_COLUMN): Correct column adjustment and comment.
7456 * config/rs6000/sysv4.h (DBX_REGISTER_NUMBER): Define.
7457
7458 2004-01-06 Eric Christopher <echristo@redhat.com>
7459
7460 * config/mips/mips.h (MDEBUG_ASM_SPEC): Change for dwarf2 default.
7461 (DWARF2_DEBUGGING_INFO): Define.
7462 (PREFERRED_DEBUGGING_TYPE): Set to dwarf2.
7463 * config/mips/openbsd.h (PREFERRED_DEBUGGING_TYPE): Remove.
7464 * config/mips/iris6.h (SUBTARGET_ASM_DEBUGGING_SPEC): Only pass -g0
7465 for irix as.
7466 (SUBTARGET_ASM_OPTIMIZING_SPEC): Only pass O0 for irix as.
7467 * config/mips/iris6gas.h (MDEBUG_ASM_SPEC): Remove.
7468 * config/mips/iris5gas.h: Ditto.
7469 (DBX_DEBUGGING_INFO): Remove.
7470 (DWARF2_DEBUGGING_INFO): Ditto.
7471 (MIPS_DEBUGGING_INFO): Ditto.
7472 (PREFERRED_DEBUGGING_TYPE): Ditto.
7473 * config/mips/elf.h (DWARF2_DEBUGGING_INFO): Remove.
7474 (PREFERRED_DEBUGGING_TYPE): Ditto.
7475 (SUBTARGET_ASM_DEBUGGING_SPEC): Ditto.
7476 * config/mips/elf64.h: Ditto.
7477
7478 2004-01-06 Jan Hubicka <jh@suse.cz>
7479
7480 * Makefile.in (STAGEPROFILE_FLAGS_TO_PASS): Use -fprofile-generate.
7481 (STAGEFEEDBACK_FLAGS_TO_PASS): Use -fprofile-use.
7482
7483 2004-01-06 Geoffrey Keating <geoffk@apple.com>
7484
7485 * config/rs6000/t-darwin (LIB2FUNCS_EXTRA): Compile darwin-ldouble.c.
7486 (TARGET_LIBGCC2_CFLAGS): Use -mlong-double-128.
7487 * config/rs6000/darwin-ldouble.c: New.
7488
7489 * emit-rtl.c (gen_lowpart_common): Use simplify_gen_subreg
7490 for constants.
7491 (constant_subword): Delete.
7492 * rtl.h (constant_subword): Delete prototype.
7493 (immed_double_const): Is not in varasm.c.
7494 * simplify-rtx.c (simplify_immed_subreg): New.
7495 (simplify_subreg): Use simplify_immed_subreg.
7496
7497 * config/rs6000/rs6000.md (floatsitf2): Use expand_float rather
7498 than trying to generate RTL directly.
7499 (fix_trunctfsi2): Use expand_fix rather than trying to generate
7500 RTL directly.
7501
7502 * dwarf2out.c (add_const_value_attribute): Remove incorrect comment.
7503
7504 2004-01-06 David Edelsohn <edelsohn@gnu.org>
7505
7506 * config/rs6000/xcoff.h (EXTRA_SECTION_FUNCTIONS): Split each
7507 function into a separate macro.
7508 (read_only_data_section): Add void argument.
7509 (private_data_section): Same.
7510 (read_only_private_data_section): Same.
7511 (toc_section): Same.
7512
7513 2004-01-06 Jan Hubicka <jh@suse.cz>
7514
7515 * invoke.texi: Remove typo in last change.
7516
7517 PR target/10301
7518 * config.gcc: Accept opteron and athlon-64 as variants
7519 of k8.
7520 * i386.c (override_options): Likewise.
7521 * invoke.texi (i386 -mtune): Expand documentation.
7522
7523 2004-01-06 Kazu Hirata <kazu@cs.umass.edu>
7524
7525 * alias.c: Fix comment typos.
7526 * builtins.c: Likewise.
7527 * cfg.c: Likewise.
7528 * df.c: Likewise.
7529 * dominance.c: Likewise.
7530 * dwarf2out.c: Likewise.
7531 * emit-rtl.c: Likewise.
7532 * expr.c: Likewise.
7533 * final.c: Likewise.
7534 * fold-const.c: Likewise.
7535 * gcse.c: Likewise.
7536 * genattrtab.c: Likewise.
7537 * genrecog.c: Likewise.
7538 * gensupport.c: Likewise.
7539 * ggc-zone.c: Likewise.
7540 * integrate.c: Likewise.
7541 * local-alloc.c: Likewise.
7542 * loop.c: Likewise.
7543 * recog.c: Likewise.
7544 * regmove.c: Likewise.
7545 * reg-stack.c: Likewise.
7546 * reorg.c: Likewise.
7547 * rtlanal.c: Likewise.
7548 * rtl.h: Likewise.
7549 * sched-ebb.c: Likewise.
7550 * simplify-rtx.c: Likewise.
7551 * toplev.c: Likewise.
7552 * varasm.c: Likewise.
7553
7554 2004-01-06 Kazu Hirata <kazu@cs.umass.edu>
7555
7556 * doc/install.texi: Fix typos.
7557 * doc/invoke.texi: Likewise.
7558 * doc/md.texi: Likewise.
7559
7560 2004-01-06 Kazuhiro Inaoka <inaoka.kazuhiro@renesas.com>
7561
7562 * config/m32r/m32r.h (TRAMPOLINE_LINE_SIZE): Changed
7563
7564 2004-01-06 Jan Hubicka <jh@suse.cz>
7565
7566 * i386.c (init_cumulative_args): Add handling of MMX_REGPARM.
7567 (function_arg_advance): Do not pass aggregates in SSE; deal handling
7568 of MMX_REGPARM.
7569 (function_arg): Add new warnings about ABI changes; fix SSE_REGPARM;
7570 add MMX_REGPARM.
7571 * i386.h (ix86_args): Add mmx_words/mmx_regs/mmx_regno fields.
7572 (SSE_REGPARM_MAX): Default to 3 on i386 -msse ABI.
7573 (MMX_REGPARM_MAX): Similarly for -mmmx.
7574
7575 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
7576
7577 * config/sh/linux.h: Fix comment formatting.
7578 * config/sh/netbsd-elf.h: Likewise.
7579 * config/sh/sh.c: Likewise.
7580 * config/sh/sh.h: Likewise.
7581 * config/sh/vxworks.h: Likewise.
7582
7583 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
7584
7585 * system.h (ASM_OUTPUT_MAIN_SOURCE_FILENAME): Poison.
7586 * toplev.c (output_file_directive): Don't use
7587 ASM_OUTPUT_MAIN_SOURCE_FILENAME.
7588
7589 2004-01-05 Steven Bosscher <s.bosscher@student.tudelft.nl>
7590
7591 * toplev.c: Fix broken checkin of 2003-12-30.
7592
7593 2004-01-05 Daniel Berlin <dberlin@dberlin.org>
7594
7595 * ggc-zone.c: Remove everything in #ifdef USING_MALLOC_PAGE_GROUPS
7596 (USING_MMAP): We don't support non-mmap.
7597 (struct alloc_chunk): Steal 1 bit from typecode, use it to mark
7598 large objects.
7599 (struct page_entry): Remove bytes_free.
7600 (struct page_table_chain): Remove.
7601 (struct globals): Remove page_table member.
7602 (loookup_page_table_entry): Function deleted.
7603 (set_page_table_entry): Ditto.
7604 (ggc_allocated_p): No longer need page table lookups.
7605 (ggc_marked_p): Ditto.
7606 (alloc_small_page): Don't care about bytes_free anymore.
7607 (alloc_large_page): Round up size.
7608 (ggc_alloc_zone_1): Mark large objects as such, and calculate
7609 their size the new way.
7610 Remove page table lookups and setting.
7611 (ggc_get_size): Calculate large object size the new way.
7612 (sweep_pages): Redo to account for fact that we no longer have
7613 bytes_free.
7614 (ggc_collect): No longer need to reincrement bytes_free.
7615 (ggc_pch_alloc_object): Handle new large objects properly.
7616 (ggc_pch_read): Put PCH stuff into it's own uncollected zone.
7617
7618 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
7619
7620 * doc/invoke.texi: Remove a page break.
7621
7622 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
7623
7624 * config/avr/avr.c (avr_output_function_prologue): Remove an
7625 extra pair of curly braces.
7626
7627 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
7628
7629 * config/mn10300/mn10300.c: Fix comment formatting.
7630 * config/mn10300/mn10300.h: Likewise.
7631
7632 2004-01-05 Richard Kenner <kenner@vlsi1.ultra.nyu.edu>
7633
7634 * tree.h: Update documentation on nothrow_flag.
7635 * print-tree.c (print_node): Print TREE_NOTHROW as "align-ok" for
7636 types.
7637
7638 2004-01-05 Kazu Hirata <kazu@cs.umass.edu>
7639
7640 * doc/invoke.texi: Remove traces of dead ports.
7641
7642 2004-01-05 Richard Sandiford <rsandifo@redhat.com>
7643
7644 * doc/invoke.texi: Add documentation for the MIPS -mexplicit-relocs
7645 option.
7646
7647 2004-01-05 Richard Sandiford <rsandifo@redhat.com>
7648
7649 PR target/12945
7650 * coverage.c (coverage_counter_alloc): Set SYMBOL_FLAG_LOCAL for
7651 counter labels.
7652 * config/mips/mips.c (INTERNAL_SYMBOL_P): Delete.
7653 (mips_classify_symbol): Always treat SYMBOL_REF_FLAG as indicating
7654 string constants if TARGET_MIPS16. Use SYMBOL_REF_DECL to check
7655 the binding of decl symbols, otherwise check SYMBOL_REF_LOCAL_P.
7656 (mips_symbol_insns): Don't trust the local/global classification.
7657 (m16_usym8_4, m16_usym5_4): Same mips16 change as mips_classify_symbol.
7658 (override_options): Make -mabicalls -fno-unit-at-a-time imply
7659 -mno-explicit-relocs.
7660 (mips_encode_section_info): Don't use SYMBOL_REF_FLAG to distinguish
7661 between local and global symbols.
7662
7663 2004-01-05 Richard Sandiford <rsandifo@redhat.com>
7664
7665 * config/mips/mips-protos.h (mips_dangerous_for_la25_p): Declare.
7666 (mips_preferred_reload_class): Declare.
7667 * config/mips/mips.h (DANGEROUS_FOR_LA25_P): Replace with function.
7668 (EXTRA_CONSTRAINT): Update accordingly.
7669 (PREFERRED_RELOAD_CLASS): Use mips_preferred_reload_class.
7670 * config/mips/mips.c (mips_dangerous_for_la25_p): New function.
7671 (mips_preferred_reload_class): New function. Prefer LEA_REGS if
7672 mips_dangerous_for_la25_p.
7673 (mips_secondary_reload_class): Use LEA_REGS rather than GR_REGS
7674 if mips_dangerous_for_la25_p.
7675
7676 2004-01-05 Bernardo Innocenti <bernie@develer.com>
7677
7678 * config/m68k/m68k.c (output_andsi3): Fix signed/unsigned comparison
7679 warning.
7680
7681 2004-01-04 Nathanael Nerode <neroden@gcc.gnu.org>
7682
7683 * configure.ac: Use AC_PROG_CPP_WERROR.
7684 * configure: Regenerate.
7685
7686 2004-01-04 Zack Weinberg <zack@codesourcery.com>
7687
7688 * .cvsignore: Add autom4te.cache.
7689
7690 2004-01-04 Richard Sandiford <rsandifo@redhat.com>
7691
7692 * doc/invoke.texi: Revamp documentation of MIPS options. Remove
7693 -mabi=meabi, -mabi-fake-default, -mmips-as, -mgas, -mmips-tfile,
7694 -m4650, -mfix7000 and -(m)no-crt0. Put endianness options first,
7695 then architecture options, then ABI options. General rewording.
7696
7697 2004-01-04 Joseph S. Myers <jsm@polyomino.org.uk>
7698
7699 PR c/3414
7700 * doc/extend.texi: Clarify definition of malloc attribute.
7701
7702 2004-01-04 Jan Hubicka <jh@suse.cz>
7703
7704 * Makefile.in (cgraph.o, cgraphunit.o): Add intl.h dependency.
7705 * cgraph.c (create_edge, dump_cgraph): Update to use inline_failed
7706 * cgraph.h (cgraph_edge): Replace inline_call by inline_failed
7707 (cgraph_inline_p): Add extra argument reason.
7708 * cgraphunit.c: Minor formating fixes.
7709 cgraph_first_inlined_callee): New functions.
7710 (record_call_1): Record builtins too.
7711 (cgraph_analyze_function): Update inline_failed messages.
7712 (cgraph_mark_functions_to_output, cgraph_expand_function, cgraph_inlined_into,
7713 cgraph_inlined_callees, cgraph_estimate_growth): Update to use inline_failed.
7714 (cgraph_check_inline_limits): Likewise; Add argument reason.
7715 (cgraph_set_inline_failed): New static function.
7716 (cgraph_decide_inlining_of_small_function, cgraph_decide_inlining): Set
7717 reasons.
7718 (cgraph_inline_p): Add new argument reason.
7719 * tree-inline.c (expand_call_inline): Update warning.
7720
7721 2004-01-03 Nathanael Nerode <neroden@gcc.gnu.org>
7722
7723 * configure.ac: Replace AC_INIT, AC_OUTPUT, AC_CANONICAL_SYSTEM
7724 with modern equivalents.
7725 * configure: Regenerate.
7726
7727 * configure.ac: Replace gcc_AC_CHECK_TYPE with AC_CHECK_TYPE.
7728 * aclocal.m4 (gcc_AC_CHECK_TYPE): Remove.
7729 * configure: Regenerate.
7730
7731 * doc/install.texi: Note that 'gcc' is now a 2.57 directory.
7732
7733 * configure.in: Rename to configure.ac.
7734 * configure.ac: Renamed from configure.in; make minimum necessary
7735 changes for autoconf 2.5x.
7736 * aclocal.m4: Make minimum necessary changes for autoconf 2.5x.
7737 * configure: Regenerate with autoconf 2.57.
7738
7739 2004-01-03 Kazu Hirata <kazu@cs.umass.edu>
7740
7741 * config/mips/linux.h: Fix comment formatting.
7742 * config/mips/mips.c: Likewise.
7743 * config/mips/mips.h: Likewise.
7744 * config/mips/mips.md: Likewise.
7745 * config/mips/netbsd.h: Likewise.
7746 * config/mips/windiss.h: Likewise.
7747
7748 2004-01-02 Richard Henderson <rth@redhat.com>
7749
7750 * config/i386/i386.md (fp constant pool splitter): Reorg suppression
7751 for sse and 387; add suppression for mmx.
7752
7753 2004-01-02 Andrew Pinski <pinskia@physics.uc.edu>
7754
7755 * loop.c (loop_optimize): Free all loops_info's mems.
7756
7757 * c-typeck.c (finish_init): Free spelling_base before
7758 setting it again.
7759
7760 * cfgloop.c (flow_loops_find): Always free the sbitmap
7761 headers.
7762
7763 * predict.c (estimate_probability): Free bbs after being
7764 done with it.
7765
7766 2004-01-02 Kazu Hirata <kazu@cs.umass.edu>
7767
7768 * config/mn10300/mn10300.h (PREDICATE_CODES): Add
7769 const_8bit_operand and call_address_operand.
7770
7771 2004-01-02 Jan Hubicka <jh@suse.cz>
7772
7773 * cgraphunit.c (cgraph_optimize_function): Call optimize_inline_calls
7774 when there is nothing to inline but warnings are requested.
7775 (cgraph_decide_inlining): Fix memory leak.
7776
7777 2004-01-02 Jan Hubicka <jh@suse.cz>
7778
7779 * expr.c (store_constructor): Fix pasto in previous patch.
7780
7781 2004-01-02 Kazu Hirata <kazu@cs.umass.edu>
7782
7783 * config/i386/cygming.h: Fix comment formatting.
7784 * config/i386/djgpp.h: Likewise.
7785 * config/i386/gthr-win32.c: Likewise.
7786 * config/i386/i386-interix.h: Likewise.
7787 * config/i386/i386.c: Likewise.
7788 * config/i386/i386.h: Likewise.
7789 * config/i386/openbsd.h: Likewise.
7790 * config/i386/winnt.c: Likewise.
7791 * config/i386/xm-mingw32.h: Likewise.
7792
7793 2004-01-02 Joseph S. Myers <jsm@polyomino.org.uk>
7794
7795 * doc/gcc.texi, doc/invoke.texi, doc/install.texi: Update
7796 copyright and last modification dates.
7797
7798 2004-01-02 Andreas Jaeger <aj@suse.de>, Gerald Pfeifer <gp@suse.de>
7799
7800 * doc/install.texi (Specific): Mention x86_64.
7801
7802 2004-01-01 Hans-Peter Nilsson <hp@bitrange.com>
7803
7804 * builtins.c (expand_builtin_apply_args_1) [STACK_GROWS_DOWNWARD]:
7805 Call force_operand on plus_constant result.
7806
7807 2004-01-01 Jan Hubicka <jh@suse.cz>
7808
7809 * expmed.c (store_bit_field, extract_bit_field): Use new named patterns
7810 * expr.c (store_constructor): Use vec_init pattern.
7811 * genopinit.c (optabs): Initailize vec_set/vec_extract/vec_init.
7812 * optabs.h (optab_index): ADD OTI_vec_set/OTI_vec_extract/OTI_vec_init
7813 (vec_set_optab, vec_extract_optab, vec_init_optab): New.
7814 * i386.md (vec_setv2df, vec_extractv2df, vec_setv4sf, vec_extractv4sf):
7815 New patterns.
7816 (sse2_unpc?pd): Fix pattern.
7817 (sse2_movlpd): Kill.
7818 (sse2_movsd): Deal with movlpd too.
7819 * i386.c (ix86_expand_builtin): Use sse2_movsd instead of sse2_movlpd.
7820 (ix86_expand_vector_init): New.
7821 * emmintrin.h (__mm_set_pd, __mm_set_ps): Use vector extensions.
7822 * md.texi (vec_set, vec_extract): Document
7823
7824 2003-12-31 Jan Hubicka <jh@suse.cz>
7825
7826 PR opt/13473
7827 * recog.c (validate_replace_rtx_1): Take care for RTL sharing inside
7828 ASM input operands
7829
7830 PR opt/12617
7831 * toplev.c (dump_file_index): Reorder ce3 and bbro.
7832 (dump_file): Likewise.
7833 (rest_of_compilation): Likewise.
7834
7835 PR debug/13367
7836 * cgraph.c (cgraph_function_possibly_inlined): Even with
7837 flag_really_no_inline we inline always_inline functions.
7838 * cgraphunit.c (cgraph_analyze_function): Clear inlinable flag
7839 for non-always_inline functions when there is flag_really_no_inline.
7840 (cgraph_decide_inlining): Limit work done when not inlining.
7841 (cgraph_decide_inlining_incrementally): Likewise.
7842 (cgraph_optimize_function): Check whether something got inlined.
7843 * c-objc-common.c (c_disregard_inline_limits): Do not always inline
7844 extern inline functions when not inlining.
7845
7846 * opts.c (decode_options): Disable crossjumping at -O1
7847 * invoke.texi (-O1): Document change.
7848
7849 See ChangeLog.10 for earlier changes.